# Contents

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.1</td>
<td>Audience</td>
<td>21</td>
</tr>
<tr>
<td>1.2</td>
<td>Organization</td>
<td>21</td>
</tr>
<tr>
<td>1.3</td>
<td>Suggested Reading</td>
<td>21</td>
</tr>
<tr>
<td>1.4</td>
<td>Conventions</td>
<td>22</td>
</tr>
<tr>
<td>1.5</td>
<td>Register Access</td>
<td>24</td>
</tr>
<tr>
<td>1.6</td>
<td>Acronyms and Abbreviations</td>
<td>26</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 2</strong></td>
<td></td>
</tr>
<tr>
<td>2.1</td>
<td>Introduction</td>
<td>29</td>
</tr>
<tr>
<td>2.2</td>
<td>Features</td>
<td>31</td>
</tr>
<tr>
<td>2.3</td>
<td>Target Applications</td>
<td>33</td>
</tr>
<tr>
<td>2.4</td>
<td>Endianness Support</td>
<td>33</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 3</strong></td>
<td></td>
</tr>
<tr>
<td>3.1</td>
<td>Memory system overview</td>
<td>35</td>
</tr>
<tr>
<td>3.2</td>
<td>Arm Platform Memory Map</td>
<td>35</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 4</strong></td>
<td></td>
</tr>
<tr>
<td>4.1</td>
<td>Chip-specific Interrupt information</td>
<td>43</td>
</tr>
<tr>
<td>4.2</td>
<td>Overview</td>
<td>43</td>
</tr>
<tr>
<td>4.3</td>
<td>CM7 interrupts</td>
<td>43</td>
</tr>
<tr>
<td>4.4</td>
<td>DMA Mux</td>
<td>52</td>
</tr>
<tr>
<td>4.5</td>
<td>PIT Channel Assignments For Periodic DMA Triggering</td>
<td>60</td>
</tr>
<tr>
<td>4.6</td>
<td>XBAR Resource Assignments</td>
<td>61</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 5</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Direct Memory Access Multiplexer (DMAMUX)</td>
<td></td>
</tr>
</tbody>
</table>

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

3
<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>5.1</td>
<td>Chip-specific DMAMUX information</td>
<td>75</td>
</tr>
<tr>
<td>5.2</td>
<td>Introduction</td>
<td>75</td>
</tr>
<tr>
<td>5.3</td>
<td>External signal description</td>
<td>77</td>
</tr>
<tr>
<td>5.4</td>
<td>Functional description</td>
<td>77</td>
</tr>
<tr>
<td>5.5</td>
<td>Initialization/application information</td>
<td>82</td>
</tr>
<tr>
<td>5.6</td>
<td>Memory map/register definition</td>
<td>85</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 6</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Enhanced Direct Memory Access (eDMA)</strong></td>
<td></td>
</tr>
<tr>
<td>6.1</td>
<td>Chip-specific eDMA information</td>
<td>89</td>
</tr>
<tr>
<td>6.2</td>
<td>Introduction</td>
<td>89</td>
</tr>
<tr>
<td>6.3</td>
<td>Modes of operation</td>
<td>93</td>
</tr>
<tr>
<td>6.4</td>
<td>Functional description</td>
<td>93</td>
</tr>
<tr>
<td>6.5</td>
<td>Initialization/application information</td>
<td>99</td>
</tr>
<tr>
<td>6.6</td>
<td>Memory map/register definition</td>
<td>115</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 7</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>System Security</strong></td>
<td></td>
</tr>
<tr>
<td>7.1</td>
<td>Chapter overview</td>
<td>175</td>
</tr>
<tr>
<td>7.2</td>
<td>Feature summary</td>
<td>175</td>
</tr>
<tr>
<td>7.3</td>
<td>High-Assurance Boot (HAB)</td>
<td>177</td>
</tr>
<tr>
<td>7.4</td>
<td>Secure Non-Volatile Storage (SNVS) module</td>
<td>180</td>
</tr>
<tr>
<td>7.5</td>
<td>Data Co-Processor (DCP)</td>
<td>182</td>
</tr>
<tr>
<td>7.6</td>
<td>Standalone True Random Number Generator (TRNG)</td>
<td>182</td>
</tr>
<tr>
<td>7.7</td>
<td>On-Chip OTP Controller (OCOTP_CTRL)</td>
<td>182</td>
</tr>
<tr>
<td>7.8</td>
<td>Central Security Unit (CSU)</td>
<td>183</td>
</tr>
<tr>
<td>7.9</td>
<td>System JTAG Controller (SJC)</td>
<td>183</td>
</tr>
<tr>
<td>7.10</td>
<td>Bus Encryption Engine (BEE)</td>
<td>184</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 8</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>System Debug</strong></td>
<td></td>
</tr>
<tr>
<td>8.1</td>
<td>Overview</td>
<td>185</td>
</tr>
<tr>
<td>8.2</td>
<td>Chip and Arm Platform Debug Architecture</td>
<td>185</td>
</tr>
<tr>
<td>Section number</td>
<td>Title</td>
<td>Page</td>
</tr>
<tr>
<td>----------------</td>
<td>----------------------------------------------------------------------</td>
<td>------</td>
</tr>
<tr>
<td>8.3</td>
<td>Miscellaneous</td>
<td>193</td>
</tr>
<tr>
<td>9.1</td>
<td>Chip-specific Boot Information</td>
<td>195</td>
</tr>
<tr>
<td>9.2</td>
<td>Overview</td>
<td>200</td>
</tr>
<tr>
<td>9.3</td>
<td>Boot modes</td>
<td>202</td>
</tr>
<tr>
<td>9.4</td>
<td>Device configuration</td>
<td>206</td>
</tr>
<tr>
<td>9.5</td>
<td>Device initialization</td>
<td>208</td>
</tr>
<tr>
<td>9.6</td>
<td>Boot devices</td>
<td>214</td>
</tr>
<tr>
<td>9.7</td>
<td>Program image</td>
<td>260</td>
</tr>
<tr>
<td>9.8</td>
<td>Plugin image</td>
<td>267</td>
</tr>
<tr>
<td>9.9</td>
<td>Serial Downloader</td>
<td>268</td>
</tr>
<tr>
<td>9.10</td>
<td>Recovery devices</td>
<td>278</td>
</tr>
<tr>
<td>9.11</td>
<td>SD/MMC manufacture mode</td>
<td>278</td>
</tr>
<tr>
<td>9.12</td>
<td>High-Assurance Boot (HAB)</td>
<td>279</td>
</tr>
<tr>
<td>9.13</td>
<td>ROM APIs</td>
<td>280</td>
</tr>
<tr>
<td></td>
<td>Chapter 10</td>
<td></td>
</tr>
<tr>
<td></td>
<td>External Signals and Pin Multiplexing</td>
<td></td>
</tr>
<tr>
<td>10.1</td>
<td>Overview</td>
<td>293</td>
</tr>
<tr>
<td></td>
<td>Chapter 11</td>
<td></td>
</tr>
<tr>
<td></td>
<td>IOMUX Controller (IOMUXC)</td>
<td></td>
</tr>
<tr>
<td>11.1</td>
<td>Overview</td>
<td>321</td>
</tr>
<tr>
<td>11.2</td>
<td>Clocks</td>
<td>323</td>
</tr>
<tr>
<td>11.3</td>
<td>Functional description</td>
<td>323</td>
</tr>
<tr>
<td>11.4</td>
<td>IOMUXC GPR Memory Map/Register Definition</td>
<td>326</td>
</tr>
<tr>
<td>11.5</td>
<td>IOMUXC SNVS Memory Map/Register Definition</td>
<td>380</td>
</tr>
<tr>
<td>11.6</td>
<td>IOMUXC SNVS GPR Memory Map/Register Definition</td>
<td>399</td>
</tr>
<tr>
<td>11.7</td>
<td>IOMUXC Memory Map/Register Definition</td>
<td>403</td>
</tr>
<tr>
<td></td>
<td>Chapter 12</td>
<td></td>
</tr>
<tr>
<td></td>
<td>General Purpose Input/Output (GPIO)</td>
<td></td>
</tr>
<tr>
<td>Section number</td>
<td>Title</td>
<td>Page</td>
</tr>
<tr>
<td>----------------</td>
<td>------------------------------------------------------------</td>
<td>------</td>
</tr>
<tr>
<td>12.1</td>
<td>Chip-specific GPIO information</td>
<td>949</td>
</tr>
<tr>
<td>12.2</td>
<td>Overview</td>
<td>949</td>
</tr>
<tr>
<td>12.3</td>
<td>Clocks</td>
<td>953</td>
</tr>
<tr>
<td>12.4</td>
<td>GPIO Functional Description</td>
<td>953</td>
</tr>
<tr>
<td>12.5</td>
<td>GPIO Register Descriptions</td>
<td>961</td>
</tr>
</tbody>
</table>

Chapter 13

Clock and Power Management

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>13.1</td>
<td>Introduction</td>
<td>981</td>
</tr>
<tr>
<td>13.2</td>
<td>Device Power Management Architecture Components</td>
<td>981</td>
</tr>
<tr>
<td>13.3</td>
<td>Clock Management</td>
<td>984</td>
</tr>
<tr>
<td>13.4</td>
<td>Power management</td>
<td>993</td>
</tr>
<tr>
<td>13.5</td>
<td>ONOFF (Button)</td>
<td>1007</td>
</tr>
<tr>
<td>13.6</td>
<td>WAKEUP Pin</td>
<td>1008</td>
</tr>
</tbody>
</table>

Chapter 14

Clock Controller Module (CCM)

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>14.1</td>
<td>Chip-specific CCM information</td>
<td>1011</td>
</tr>
<tr>
<td>14.2</td>
<td>Overview</td>
<td>1011</td>
</tr>
<tr>
<td>14.3</td>
<td>External Signals</td>
<td>1014</td>
</tr>
<tr>
<td>14.4</td>
<td>CCM Clock Tree</td>
<td>1014</td>
</tr>
<tr>
<td>14.5</td>
<td>System Clocks</td>
<td>1017</td>
</tr>
<tr>
<td>14.6</td>
<td>Functional Description</td>
<td>1032</td>
</tr>
<tr>
<td>14.7</td>
<td>CCM Memory Map/Register Definition</td>
<td>1045</td>
</tr>
<tr>
<td>14.8</td>
<td>CCM Analog Memory Map/Register Definition</td>
<td>1095</td>
</tr>
</tbody>
</table>

Chapter 15

Crystal Oscillator (XTALOSC)

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>15.1</td>
<td>Chip-specific XTALOSC information</td>
<td>1137</td>
</tr>
<tr>
<td>15.2</td>
<td>Overview</td>
<td>1137</td>
</tr>
<tr>
<td>15.3</td>
<td>External Signals</td>
<td>1138</td>
</tr>
<tr>
<td>15.4</td>
<td>Crystal Oscillator 24 MHz</td>
<td>1138</td>
</tr>
<tr>
<td>15.5</td>
<td>Crystal Oscillator 32 kHz</td>
<td>1140</td>
</tr>
</tbody>
</table>
### Chapter 16
**Power Management Unit (PMU)**

16.1 Chip-specific PMU information
16.2 Overview
16.3 Analog LDO Regulators
16.4 USB LDO Regulator
16.5 SNVS Regulator
16.6 PMU Memory Map/Register Definition

### Chapter 17
**General Power Controller (GPC)**

17.1 Chip-specific GPC information
17.2 Overview
17.3 Clocks
17.4 Power Gating Control (PGC)
17.5 GPC Interrupt Controller (INTC)
17.6 GPC Memory Map/Register Definition
17.7 PGC Memory Map/Register Definition

### Chapter 18
**DCDC Converter (DCDC)**

18.1 Chip-specific DCDC information
18.2 Introduction
18.3 Features
18.4 Block diagram
18.5 Functional description
18.6 Application information
18.7 Memory Map and register definition

### Chapter 19
**Temperature Monitor (TEMPMON)**

19.1 Chip-specific TEMPMON information
<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>19.2</td>
<td>Overview</td>
<td>1221</td>
</tr>
<tr>
<td>19.3</td>
<td>Software Usage Guidelines</td>
<td>1223</td>
</tr>
<tr>
<td>19.4</td>
<td>TEMPMON Memory Map/Register Definition</td>
<td>1224</td>
</tr>
<tr>
<td>20.1</td>
<td>Chip-specific SNVS information</td>
<td>1231</td>
</tr>
<tr>
<td>20.2</td>
<td>SNVS introduction</td>
<td>1231</td>
</tr>
<tr>
<td>20.3</td>
<td>SNVS Structure</td>
<td>1233</td>
</tr>
<tr>
<td>20.4</td>
<td>Runtime Procedures</td>
<td>1235</td>
</tr>
<tr>
<td>20.5</td>
<td>Reset and Initialization of SNVS</td>
<td>1238</td>
</tr>
<tr>
<td>20.6</td>
<td>SNVS register descriptions</td>
<td>1241</td>
</tr>
<tr>
<td>21.1</td>
<td>Chip-specific SRC information</td>
<td>1271</td>
</tr>
<tr>
<td>21.2</td>
<td>SRC Overview</td>
<td>1271</td>
</tr>
<tr>
<td>21.3</td>
<td>External Signals</td>
<td>1272</td>
</tr>
<tr>
<td>21.4</td>
<td>Clocks</td>
<td>1272</td>
</tr>
<tr>
<td>21.5</td>
<td>Top-level resets, power-up sequence and external supply integration</td>
<td>1273</td>
</tr>
<tr>
<td>21.6</td>
<td>Power-On Reset and power sequencing</td>
<td>1278</td>
</tr>
<tr>
<td>21.7</td>
<td>Functional Description</td>
<td>1279</td>
</tr>
<tr>
<td>21.8</td>
<td>SRC Memory Map/Register Definition</td>
<td>1284</td>
</tr>
<tr>
<td>22.1</td>
<td>Boot Fusemap</td>
<td>1299</td>
</tr>
<tr>
<td>22.2</td>
<td>Lock Fusemap</td>
<td>1310</td>
</tr>
<tr>
<td>22.3</td>
<td>Fusemap Descriptions Table</td>
<td>1311</td>
</tr>
<tr>
<td>23.1</td>
<td>Chip-specific OCOTP_CTRL information</td>
<td>1323</td>
</tr>
<tr>
<td>23.2</td>
<td>Overview</td>
<td>1323</td>
</tr>
<tr>
<td>Section number</td>
<td>Title</td>
<td>Page</td>
</tr>
<tr>
<td>----------------</td>
<td>------------------------------------------------------------</td>
<td>------</td>
</tr>
<tr>
<td>23.3</td>
<td>Clocks</td>
<td>1324</td>
</tr>
<tr>
<td>23.4</td>
<td>Top-Level Symbol and Functional Overview</td>
<td>1325</td>
</tr>
<tr>
<td>23.5</td>
<td>Fuse Map</td>
<td>1331</td>
</tr>
<tr>
<td>23.6</td>
<td>OCOTP Memory Map/Register Definition</td>
<td>1331</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 24</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>External Memory Controllers</strong></td>
<td></td>
</tr>
<tr>
<td>24.1</td>
<td>Overview</td>
<td>1375</td>
</tr>
<tr>
<td>24.2</td>
<td>Smart External Memory Controller (SEMC) Overview</td>
<td>1375</td>
</tr>
<tr>
<td>24.3</td>
<td>eMMC/eSD/SDIO</td>
<td>1376</td>
</tr>
<tr>
<td>24.4</td>
<td>Quad Serial Peripheral Interface</td>
<td>1377</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 25</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Smart External Memory Controller (SEMC)</strong></td>
<td></td>
</tr>
<tr>
<td>25.1</td>
<td>Chip-specific SEMC information</td>
<td>1379</td>
</tr>
<tr>
<td>25.2</td>
<td>About this module</td>
<td>1380</td>
</tr>
<tr>
<td>25.3</td>
<td>Signals</td>
<td>1383</td>
</tr>
<tr>
<td>25.4</td>
<td>Memory Map and register definition</td>
<td>1385</td>
</tr>
<tr>
<td>25.5</td>
<td>Functional description</td>
<td>1449</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 26</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Ultra Secured Digital Host Controller (uSDHC)</strong></td>
<td></td>
</tr>
<tr>
<td>26.1</td>
<td>Chip-specific uSDHC information</td>
<td>1491</td>
</tr>
<tr>
<td>26.2</td>
<td>Overview</td>
<td>1491</td>
</tr>
<tr>
<td>26.3</td>
<td>External Signals</td>
<td>1495</td>
</tr>
<tr>
<td>26.4</td>
<td>Clocks</td>
<td>1497</td>
</tr>
<tr>
<td>26.5</td>
<td>Functional Description</td>
<td>1497</td>
</tr>
<tr>
<td>26.6</td>
<td>Initialization/Application of uSDHC</td>
<td>1520</td>
</tr>
<tr>
<td>26.7</td>
<td>Commands for MMC/SD/SDIO</td>
<td>1545</td>
</tr>
<tr>
<td>26.8</td>
<td>Software Restrictions</td>
<td>1551</td>
</tr>
<tr>
<td>26.9</td>
<td>uSDHC Memory Map/Register Definition</td>
<td>1553</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 27</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>FlexSPI Controller</strong></td>
<td></td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
NXP Semiconductors
<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>27.1</td>
<td>Chip-specific FlexSPI information</td>
<td>1621</td>
</tr>
<tr>
<td>27.2</td>
<td>Overview</td>
<td>1622</td>
</tr>
<tr>
<td>27.3</td>
<td>Glossary for FlexSPI module</td>
<td>1625</td>
</tr>
<tr>
<td>27.4</td>
<td>External Signal Description</td>
<td>1626</td>
</tr>
<tr>
<td>27.5</td>
<td>Functional description</td>
<td>1627</td>
</tr>
<tr>
<td>27.6</td>
<td>Application information</td>
<td>1676</td>
</tr>
<tr>
<td>27.7</td>
<td>Memory Map and register definition</td>
<td>1695</td>
</tr>
<tr>
<td>27.8</td>
<td>AHB Memory Map definition</td>
<td>1737</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 28</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>ARM Cortex M7 Platform</strong></td>
<td></td>
</tr>
<tr>
<td>28.1</td>
<td>Chip-specific Arm Cortex M7 information</td>
<td>1739</td>
</tr>
<tr>
<td>28.2</td>
<td>Arm Cortex M7 Platform</td>
<td>1740</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 29</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Network Interconnect Bus System (NIC-301)</strong></td>
<td></td>
</tr>
<tr>
<td>29.1</td>
<td>Chip-specific NIC-301 information</td>
<td>1743</td>
</tr>
<tr>
<td>29.2</td>
<td>Overview</td>
<td>1743</td>
</tr>
<tr>
<td>29.3</td>
<td>External Signals</td>
<td>1744</td>
</tr>
<tr>
<td>29.4</td>
<td>Memory Map and Register Definition</td>
<td>1744</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 30</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>On-Chip RAM Memory Controller (OCRAM)</strong></td>
<td></td>
</tr>
<tr>
<td>30.1</td>
<td>Chip-specific OCRAM information</td>
<td>1755</td>
</tr>
<tr>
<td>30.2</td>
<td>Overview</td>
<td>1755</td>
</tr>
<tr>
<td>30.3</td>
<td>Basic Functions</td>
<td>1756</td>
</tr>
<tr>
<td>30.4</td>
<td>Advanced Features</td>
<td>1757</td>
</tr>
<tr>
<td>30.5</td>
<td>Programmable Registers</td>
<td>1759</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 31</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>FlexRAM</strong></td>
<td></td>
</tr>
<tr>
<td>31.1</td>
<td>Chip-specific FlexRAM information</td>
<td>1761</td>
</tr>
<tr>
<td>31.2</td>
<td>Overview</td>
<td>1762</td>
</tr>
<tr>
<td>31.3</td>
<td>Functional description</td>
<td>1763</td>
</tr>
</tbody>
</table>
Chapter 32
AHB to IP Bridge (AIPSTZ)

32.1 Chip-specific AIPSTZ information ............................................................................................................................... 1773
32.2 Overview ....................................................................................................................................................................... 1773
32.3 Clocks ........................................................................................................................................................................... 1774
32.4 Functional Description .................................................................................................................................................. 1774
32.5 Access Protections ........................................................................................................................................................ 1775
32.6 Access Support .............................................................................................................................................................. 1776
32.7 Initialization Information .............................................................................................................................................. 1776
32.8 AIPSTZ Memory Map/Register Definition .................................................................................................................. 1778

Chapter 33
Display and Camera Overview

33.1 Display and Camera Overview ..................................................................................................................................... 1797

Chapter 34
CMOS Sensor Interface (CSI)

34.1 Chip-specific CSI information ...................................................................................................................................... 1801
34.2 Overview ....................................................................................................................................................................... 1801
34.3 External Signals ............................................................................................................................................................ 1802
34.4 Clocks ........................................................................................................................................................................... 1804
34.5 Principles of Operation ................................................................................................................................................. 1804
34.6 Interrupt Generation ...................................................................................................................................................... 1811
34.7 Data Packing Style ........................................................................................................................................................ 1814
34.8 CSI Memory Map/Register Definition .......................................................................................................................... 1818

Chapter 35
Enhanced LCD Interface (eLCDIF)

35.1 Chip-specific eLCDIF information ............................................................................................................................... 1841
35.2 Overview ....................................................................................................................................................................... 1841
35.3 External Signals ............................................................................................................................................................ 1842
35.4 Clocks ........................................................................................................................................................................... 1843
<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>35.5</td>
<td>Functional Description</td>
<td>1843</td>
</tr>
<tr>
<td>35.6</td>
<td>Behavior During Reset</td>
<td>1860</td>
</tr>
<tr>
<td>35.7</td>
<td>LCDIF Memory Map/Register Definition</td>
<td>1860</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 36</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Pixel Pipeline (PXP)</strong></td>
<td></td>
</tr>
<tr>
<td>36.1</td>
<td>Chip-specific PXP information</td>
<td>1889</td>
</tr>
<tr>
<td>36.2</td>
<td>Overview</td>
<td>1889</td>
</tr>
<tr>
<td>36.3</td>
<td>Clocks</td>
<td>1890</td>
</tr>
<tr>
<td>36.4</td>
<td>Top-level architecture</td>
<td>1890</td>
</tr>
<tr>
<td>36.5</td>
<td>Output Image Processing</td>
<td>1921</td>
</tr>
<tr>
<td>36.6</td>
<td>Queuing PXP transactions</td>
<td>1922</td>
</tr>
<tr>
<td>36.7</td>
<td>Error Handling</td>
<td>1923</td>
</tr>
<tr>
<td>36.8</td>
<td>PXP Memory Map/Register Definition</td>
<td>1923</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 37</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Audio Overview</strong></td>
<td></td>
</tr>
<tr>
<td>37.1</td>
<td>Audio Overview</td>
<td>1961</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 38</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Synchronous Audio Interface (SAI)</strong></td>
<td></td>
</tr>
<tr>
<td>38.1</td>
<td>Chip-specific SAI information</td>
<td>1967</td>
</tr>
<tr>
<td>38.2</td>
<td>Introduction</td>
<td>1968</td>
</tr>
<tr>
<td>38.3</td>
<td>External signals</td>
<td>1970</td>
</tr>
<tr>
<td>38.4</td>
<td>Functional description</td>
<td>1971</td>
</tr>
<tr>
<td>38.5</td>
<td>Memory map and register definition</td>
<td>1981</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 39</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Medium Quality Sound (MQS)</strong></td>
<td></td>
</tr>
<tr>
<td>39.1</td>
<td>Chip-specific MQS information</td>
<td>2017</td>
</tr>
<tr>
<td>39.2</td>
<td>Overview</td>
<td>2017</td>
</tr>
<tr>
<td>39.3</td>
<td>External Signals</td>
<td>2019</td>
</tr>
<tr>
<td>39.4</td>
<td>Interface Signals</td>
<td>2019</td>
</tr>
<tr>
<td>39.5</td>
<td>Programming Considerations</td>
<td>2020</td>
</tr>
<tr>
<td>Section number</td>
<td>Title</td>
<td>Page</td>
</tr>
<tr>
<td>----------------</td>
<td>-------</td>
<td>------</td>
</tr>
<tr>
<td><strong>Chapter 40</strong></td>
<td>Sony/Philips Digital Interface (SPDIF)</td>
<td></td>
</tr>
<tr>
<td>40.1</td>
<td>Chip-specific SPDIF information</td>
<td>2021</td>
</tr>
<tr>
<td>40.2</td>
<td>Overview</td>
<td>2021</td>
</tr>
<tr>
<td>40.3</td>
<td>External Signals</td>
<td>2024</td>
</tr>
<tr>
<td>40.4</td>
<td>Clocks</td>
<td>2024</td>
</tr>
<tr>
<td>40.5</td>
<td>Functional Description</td>
<td>2024</td>
</tr>
<tr>
<td>40.6</td>
<td>SPDIF Memory Map/Register Definition</td>
<td>2035</td>
</tr>
<tr>
<td><strong>Chapter 41</strong></td>
<td>10/100 /1000-Mbps Ethernet MAC (ENET)</td>
<td></td>
</tr>
<tr>
<td>41.1</td>
<td>Chip-specific ENET information</td>
<td>2055</td>
</tr>
<tr>
<td>41.2</td>
<td>Introduction</td>
<td>2055</td>
</tr>
<tr>
<td>41.3</td>
<td>Overview</td>
<td>2055</td>
</tr>
<tr>
<td>41.4</td>
<td>External Signals</td>
<td>2060</td>
</tr>
<tr>
<td>41.5</td>
<td>Clocks</td>
<td>2068</td>
</tr>
<tr>
<td>41.6</td>
<td>Memory map/register definition</td>
<td>2068</td>
</tr>
<tr>
<td>41.7</td>
<td>Functional description</td>
<td>2141</td>
</tr>
<tr>
<td><strong>Chapter 42</strong></td>
<td>Universal Serial Bus Controller (USB)</td>
<td></td>
</tr>
<tr>
<td>42.1</td>
<td>Chip-specific USB information</td>
<td>2203</td>
</tr>
<tr>
<td>42.2</td>
<td>Overview</td>
<td>2203</td>
</tr>
<tr>
<td>42.3</td>
<td>External Signals</td>
<td>2206</td>
</tr>
<tr>
<td>42.4</td>
<td>Functional Description</td>
<td>2207</td>
</tr>
<tr>
<td>42.5</td>
<td>USB Operation Model</td>
<td>2211</td>
</tr>
<tr>
<td>42.6</td>
<td>USB Non-Core Memory Map/Register Definition</td>
<td>2376</td>
</tr>
<tr>
<td>42.7</td>
<td>USB Core Memory Map/Register Definition</td>
<td>2385</td>
</tr>
<tr>
<td><strong>Chapter 43</strong></td>
<td>Universal Serial Bus 2.0 Integrated PHY (USB-PHY)</td>
<td></td>
</tr>
<tr>
<td>43.1</td>
<td>Chip-specific USB-PHY information</td>
<td>2463</td>
</tr>
<tr>
<td>43.2</td>
<td>USB PHY Overview</td>
<td>2463</td>
</tr>
</tbody>
</table>
### Chapter 44
**Flexible Controller Area Network (FLEXCAN)**

- **44.1 Chip-specific FLEXCAN information** ................................................................. 2513
- **44.2 Overview** ........................................................................................................ 2513
- **44.3 External Signals** .......................................................................................... 2518
- **44.4 Clocks** ........................................................................................................ 2519
- **44.5 Message Buffer Structure** ............................................................................ 2520
- **44.6 Rx FIFO Structure** ...................................................................................... 2524
- **44.7 Functional Description** ................................................................................ 2527
- **44.8 Initialization/Application Information** ......................................................... 2554
- **44.9 FLEXCAN Memory Map/Register Definition** ............................................. 2555

### Chapter 45
**Flexible Data-rate Controller Area Network (CANFD/FlexCAN3)**

- **45.1 Chip-specific FLEXCAN information** ................................................................. 2595
- **45.2 Introduction** .................................................................................................. 2595
- **45.3 FlexCAN signal descriptions** ........................................................................ 2600
- **45.4 Functional description** ................................................................................ 2601
- **45.5 Initialization/application information** ......................................................... 2652
- **45.6 Memory map/register definition** ................................................................... 2654

### Chapter 46
**Keypad Port (KPP)**

- **46.1 Chip-specific KPP information** .................................................................... 2719
- **46.2 Overview** ..................................................................................................... 2719
- **46.3 Clocks** ....................................................................................................... 2721
- **46.4 External Signals** ......................................................................................... 2721
- **46.5 Functional Description** .............................................................................. 2723
- **46.6 Initialization/Application Information** ......................................................... 2731

---

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>43.3</td>
<td>Operation</td>
<td>2463</td>
</tr>
<tr>
<td>43.4</td>
<td>USB PHY Memory Map/Register Definition</td>
<td>2474</td>
</tr>
<tr>
<td>43.5</td>
<td>USB Analog Memory Map/Register Definition</td>
<td>2491</td>
</tr>
<tr>
<td>44.1</td>
<td>Chip-specific FLEXCAN information</td>
<td>2513</td>
</tr>
<tr>
<td>44.2</td>
<td>Overview</td>
<td>2513</td>
</tr>
<tr>
<td>44.3</td>
<td>External Signals</td>
<td>2518</td>
</tr>
<tr>
<td>44.4</td>
<td>Clocks</td>
<td>2519</td>
</tr>
<tr>
<td>44.5</td>
<td>Message Buffer Structure</td>
<td>2520</td>
</tr>
<tr>
<td>44.6</td>
<td>Rx FIFO Structure</td>
<td>2524</td>
</tr>
<tr>
<td>44.7</td>
<td>Functional Description</td>
<td>2527</td>
</tr>
<tr>
<td>44.8</td>
<td>Initialization/Application Information</td>
<td>2554</td>
</tr>
<tr>
<td>44.9</td>
<td>FLEXCAN Memory Map/Register Definition</td>
<td>2555</td>
</tr>
<tr>
<td>45.1</td>
<td>Chip-specific FLEXCAN information</td>
<td>2595</td>
</tr>
<tr>
<td>45.2</td>
<td>Introduction</td>
<td>2595</td>
</tr>
<tr>
<td>45.3</td>
<td>FlexCAN signal descriptions</td>
<td>2600</td>
</tr>
<tr>
<td>45.4</td>
<td>Functional description</td>
<td>2601</td>
</tr>
<tr>
<td>45.5</td>
<td>Initialization/application information</td>
<td>2652</td>
</tr>
<tr>
<td>45.6</td>
<td>Memory map/register definition</td>
<td>2654</td>
</tr>
<tr>
<td>46.1</td>
<td>Chip-specific KPP information</td>
<td>2719</td>
</tr>
<tr>
<td>46.2</td>
<td>Overview</td>
<td>2719</td>
</tr>
<tr>
<td>46.3</td>
<td>Clocks</td>
<td>2721</td>
</tr>
<tr>
<td>46.4</td>
<td>External Signals</td>
<td>2721</td>
</tr>
<tr>
<td>46.5</td>
<td>Functional Description</td>
<td>2723</td>
</tr>
<tr>
<td>46.6</td>
<td>Initialization/Application Information</td>
<td>2731</td>
</tr>
<tr>
<td>Section number</td>
<td>Title</td>
<td>Page</td>
</tr>
<tr>
<td>----------------</td>
<td>--------------------------------------------</td>
<td>------</td>
</tr>
<tr>
<td>46.7</td>
<td>KPP Memory Map/Register Definition</td>
<td>2732</td>
</tr>
<tr>
<td>47.1</td>
<td>Chip-specific LPI2C information</td>
<td>2739</td>
</tr>
<tr>
<td>47.2</td>
<td>Introduction</td>
<td>2740</td>
</tr>
<tr>
<td>47.3</td>
<td>Functional description</td>
<td>2746</td>
</tr>
<tr>
<td>47.4</td>
<td>Memory Map and Registers</td>
<td>2758</td>
</tr>
<tr>
<td>48.1</td>
<td>Chip-specific LPSPI information</td>
<td>2799</td>
</tr>
<tr>
<td>48.2</td>
<td>Introduction</td>
<td>2799</td>
</tr>
<tr>
<td>48.3</td>
<td>Functional description</td>
<td>2801</td>
</tr>
<tr>
<td>48.4</td>
<td>Memory Map and Registers</td>
<td>2810</td>
</tr>
<tr>
<td>49.1</td>
<td>Chip-specific LPUART information</td>
<td>2833</td>
</tr>
<tr>
<td>49.2</td>
<td>Introduction</td>
<td>2833</td>
</tr>
<tr>
<td>49.3</td>
<td>Functional description</td>
<td>2837</td>
</tr>
<tr>
<td>49.4</td>
<td>Register definition</td>
<td>2853</td>
</tr>
<tr>
<td>50.1</td>
<td>Chip-specific FlexIO information</td>
<td>2881</td>
</tr>
<tr>
<td>50.2</td>
<td>Introduction</td>
<td>2882</td>
</tr>
<tr>
<td>50.3</td>
<td>Functional description</td>
<td>2884</td>
</tr>
<tr>
<td>50.4</td>
<td>Application Information</td>
<td>2896</td>
</tr>
<tr>
<td>50.5</td>
<td>Memory Map and Registers</td>
<td>2912</td>
</tr>
<tr>
<td>51.1</td>
<td>Overview</td>
<td>2941</td>
</tr>
<tr>
<td>52</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Section number</td>
<td>Title</td>
<td>Page</td>
</tr>
<tr>
<td>----------------</td>
<td>-------</td>
<td>------</td>
</tr>
<tr>
<td><strong>52.1</strong></td>
<td>Chip-specific GPT information</td>
<td>2945</td>
</tr>
<tr>
<td><strong>52.2</strong></td>
<td>Overview</td>
<td>2945</td>
</tr>
<tr>
<td><strong>52.3</strong></td>
<td>External Signals</td>
<td>2947</td>
</tr>
<tr>
<td><strong>52.4</strong></td>
<td>Clocks</td>
<td>2950</td>
</tr>
<tr>
<td><strong>52.5</strong></td>
<td>Functional Description</td>
<td>2951</td>
</tr>
<tr>
<td><strong>52.6</strong></td>
<td>Initialization/ Application Information</td>
<td>2956</td>
</tr>
<tr>
<td><strong>52.7</strong></td>
<td>GPT Memory Map/Register Definition</td>
<td>2957</td>
</tr>
</tbody>
</table>

**Chapter 53**

**Periodic Interrupt Timer (PIT)**

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>53.1</strong></td>
<td>Chip-specific PIT information</td>
<td>2971</td>
</tr>
<tr>
<td><strong>53.2</strong></td>
<td>Introduction</td>
<td>2971</td>
</tr>
<tr>
<td><strong>53.3</strong></td>
<td>Modes of operation</td>
<td>2973</td>
</tr>
<tr>
<td><strong>53.4</strong></td>
<td>PIT External Signals</td>
<td>2973</td>
</tr>
<tr>
<td><strong>53.5</strong></td>
<td>Functional description</td>
<td>2973</td>
</tr>
<tr>
<td><strong>53.6</strong></td>
<td>Initialization and application information</td>
<td>2975</td>
</tr>
<tr>
<td><strong>53.7</strong></td>
<td>Example configuration for chained timers</td>
<td>2976</td>
</tr>
<tr>
<td><strong>53.8</strong></td>
<td>Example configuration for the lifetime timer</td>
<td>2977</td>
</tr>
<tr>
<td><strong>53.9</strong></td>
<td>PIT register descriptions</td>
<td>2978</td>
</tr>
</tbody>
</table>

**Chapter 54**

**Quad Timer (TMR)**

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>54.1</strong></td>
<td>Chip-specific TMR information</td>
<td>2987</td>
</tr>
<tr>
<td><strong>54.2</strong></td>
<td>Overview</td>
<td>2987</td>
</tr>
<tr>
<td><strong>54.3</strong></td>
<td>Features</td>
<td>2988</td>
</tr>
<tr>
<td><strong>54.4</strong></td>
<td>Modes of Operation</td>
<td>2989</td>
</tr>
<tr>
<td><strong>54.5</strong></td>
<td>Block Diagram</td>
<td>2989</td>
</tr>
<tr>
<td><strong>54.6</strong></td>
<td>Memory Map and Registers</td>
<td>2990</td>
</tr>
<tr>
<td><strong>54.7</strong></td>
<td>Functional Description</td>
<td>3008</td>
</tr>
<tr>
<td><strong>54.8</strong></td>
<td>Resets</td>
<td>3026</td>
</tr>
<tr>
<td><strong>54.9</strong></td>
<td>Clocks</td>
<td>3026</td>
</tr>
</tbody>
</table>
## Section number  | Title                                                                 | Page  
--- | --- | ---  
54.10  | Interrupts | 3026  
54.11  | DMA | 3028  

### Chapter 55  
Enhanced Flex Pulse Width Modulator (eFlexPWM)  

55.1  | Chip-specific FlexPWM information | 3029  
55.2  | Introduction | 3029  
55.3  | Signal Descriptions | 3032  
55.4  | Functional Description | 3034  
55.5  | Resets | 3069  
55.6  | Interrupts | 3070  
55.7  | DMA | 3071  
55.8  | PWM register descriptions | 3073  

### Chapter 56  
Quadrature Encoder/Decoder (ENC)  

56.1  | Chip-specific ENC information | 3143  
56.2  | Introduction | 3143  
56.3  | Signal Descriptions | 3147  
56.4  | Functional Description | 3148  
56.5  | Resets | 3150  
56.6  | Clocks | 3150  
56.7  | Interrupts | 3150  
56.8  | ENC register descriptions | 3151  

### Chapter 57  
Watchdog Timer (WDOG1-2)  

57.1  | Chip-specific WDOG information | 3175  
57.2  | Overview | 3175  
57.3  | External signals | 3177  
57.4  | Clocks | 3177  
57.5  | Watchdog mechanism and system integration | 3178  
57.6  | Functional description | 3178  

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019  
NXP Semiconductors
<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>57.7</td>
<td>Initialization</td>
<td>3186</td>
</tr>
<tr>
<td>57.8</td>
<td>WDOG Memory Map/Register Definition</td>
<td>3187</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 58</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>RTWDOG (WDOG3)</strong></td>
<td></td>
</tr>
<tr>
<td>58.1</td>
<td>Chip-specific RTWDOG information</td>
<td>3195</td>
</tr>
<tr>
<td>58.2</td>
<td>Introduction</td>
<td>3195</td>
</tr>
<tr>
<td>58.3</td>
<td>Functional description</td>
<td>3197</td>
</tr>
<tr>
<td>58.4</td>
<td>Application Information</td>
<td>3204</td>
</tr>
<tr>
<td>58.5</td>
<td>Memory map and register definition</td>
<td>3205</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 59</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>External Watchdog Monitor (EWM)</strong></td>
<td></td>
</tr>
<tr>
<td>59.1</td>
<td>Chip-specific EWM information</td>
<td>3213</td>
</tr>
<tr>
<td>59.2</td>
<td>Introduction</td>
<td>3214</td>
</tr>
<tr>
<td>59.3</td>
<td>EWM Signal Descriptions</td>
<td>3216</td>
</tr>
<tr>
<td>59.4</td>
<td>Clocking</td>
<td>3217</td>
</tr>
<tr>
<td>59.5</td>
<td>Functional Description</td>
<td>3217</td>
</tr>
<tr>
<td>59.6</td>
<td>Memory Map/Register Definition</td>
<td>3221</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 60</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>On Chip Cross Triggers Overview</strong></td>
<td></td>
</tr>
<tr>
<td>60.1</td>
<td>Overview</td>
<td>3229</td>
</tr>
<tr>
<td></td>
<td><strong>Chapter 61</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Inter-Peripheral Crossbar Switch A (XBARA)</strong></td>
<td></td>
</tr>
<tr>
<td>61.1</td>
<td>Chip-specific XBAR information</td>
<td>3231</td>
</tr>
<tr>
<td>61.2</td>
<td>Introduction</td>
<td>3231</td>
</tr>
<tr>
<td>61.3</td>
<td>Signal Descriptions</td>
<td>3233</td>
</tr>
<tr>
<td>61.4</td>
<td>Memory Map and Register Descriptions</td>
<td>3234</td>
</tr>
<tr>
<td>61.5</td>
<td>Functional Description</td>
<td>3275</td>
</tr>
<tr>
<td>61.6</td>
<td>Resets</td>
<td>3276</td>
</tr>
<tr>
<td>61.7</td>
<td>Clocks</td>
<td>3276</td>
</tr>
<tr>
<td>61.8</td>
<td>Interrupts and DMA Requests</td>
<td>3276</td>
</tr>
<tr>
<td>Section number</td>
<td>Title</td>
<td>Page</td>
</tr>
<tr>
<td>----------------</td>
<td>-----------------------------------------------------------</td>
<td>------</td>
</tr>
<tr>
<td>62.1</td>
<td>Chip-specific XBAR information</td>
<td>3277</td>
</tr>
<tr>
<td>62.2</td>
<td>Introduction</td>
<td>3277</td>
</tr>
<tr>
<td>62.3</td>
<td>Memory Map and Register Descriptions</td>
<td>3278</td>
</tr>
<tr>
<td>63.1</td>
<td>Chip-specific AOI information</td>
<td>3283</td>
</tr>
<tr>
<td>63.2</td>
<td>Introduction</td>
<td>3283</td>
</tr>
<tr>
<td>63.3</td>
<td>External Signal Description</td>
<td>3286</td>
</tr>
<tr>
<td>63.4</td>
<td>Memory Map and Register Descriptions</td>
<td>3286</td>
</tr>
<tr>
<td>63.5</td>
<td>Functional Description</td>
<td>3291</td>
</tr>
<tr>
<td>64.1</td>
<td>Overview</td>
<td>3295</td>
</tr>
<tr>
<td>65.1</td>
<td>Chip-specific CMP information</td>
<td>3297</td>
</tr>
<tr>
<td>65.2</td>
<td>Introduction</td>
<td>3297</td>
</tr>
<tr>
<td>65.3</td>
<td>Memory map/register definitions</td>
<td>3302</td>
</tr>
<tr>
<td>65.4</td>
<td>Functional description</td>
<td>3308</td>
</tr>
<tr>
<td>65.5</td>
<td>CMP interrupts</td>
<td>3322</td>
</tr>
<tr>
<td>65.6</td>
<td>DMA support</td>
<td>3322</td>
</tr>
<tr>
<td>65.7</td>
<td>Digital-to-analog converter</td>
<td>3323</td>
</tr>
<tr>
<td>65.8</td>
<td>DAC functional description</td>
<td>3323</td>
</tr>
<tr>
<td>65.9</td>
<td>DAC resets</td>
<td>3324</td>
</tr>
<tr>
<td>65.10</td>
<td>DAC clocks</td>
<td>3324</td>
</tr>
<tr>
<td>65.11</td>
<td>DAC interrupts</td>
<td>3324</td>
</tr>
<tr>
<td>66.1</td>
<td>Overview</td>
<td>3325</td>
</tr>
<tr>
<td>66.2</td>
<td>Analog-to-Digital Converter (ADC)</td>
<td>3326</td>
</tr>
</tbody>
</table>

Chapter 62
Inter-Peripheral Crossbar Switch B (XBARB)

Chapter 63
And-Or-Inverter (AOI)

Chapter 64
Analog Overview

Chapter 65
Analog Comparator (ACMP)

Chapter 66
Analog-to-Digital Converter (ADC)
<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>66.1</td>
<td>Chip-specific ADC information</td>
<td>3325</td>
</tr>
<tr>
<td>66.2</td>
<td>Overview</td>
<td>3325</td>
</tr>
<tr>
<td>66.3</td>
<td>External Signals</td>
<td>3329</td>
</tr>
<tr>
<td>66.4</td>
<td>Clocks</td>
<td>3331</td>
</tr>
<tr>
<td>66.5</td>
<td>Functional Description</td>
<td>3331</td>
</tr>
<tr>
<td>66.6</td>
<td>Initialization Information</td>
<td>3346</td>
</tr>
<tr>
<td>66.7</td>
<td>Application Information</td>
<td>3348</td>
</tr>
<tr>
<td>66.8</td>
<td>Memory map and register definition</td>
<td>3352</td>
</tr>
</tbody>
</table>

Chapter 67
ADC External Trigger Control (ADC_ETC)

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>67.1</td>
<td>Chip-specific ADC_ETC information</td>
<td>3371</td>
</tr>
<tr>
<td>67.2</td>
<td>About this module</td>
<td>3371</td>
</tr>
<tr>
<td>67.3</td>
<td>Block diagram</td>
<td>3373</td>
</tr>
<tr>
<td>67.4</td>
<td>Functional description</td>
<td>3373</td>
</tr>
<tr>
<td>67.5</td>
<td>Memory Map and register definition</td>
<td>3376</td>
</tr>
</tbody>
</table>

Chapter 68
Touch Screen Controller (TSC)

<table>
<thead>
<tr>
<th>Section number</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>68.1</td>
<td>Chip-specific TSC information</td>
<td>3399</td>
</tr>
<tr>
<td>68.2</td>
<td>Overview</td>
<td>3399</td>
</tr>
<tr>
<td>68.3</td>
<td>Functional Description</td>
<td>3401</td>
</tr>
<tr>
<td>68.4</td>
<td>TSC Memory Map/Register Definition</td>
<td>3406</td>
</tr>
</tbody>
</table>
Chapter 1
About this Document

1.1 Audience

The reference manual is intended for the board-level product designers and product software developers. This manual assumes that the reader has a background in computer engineering and/or software engineering and understands the concepts of the digital system design, microprocessor architecture, input/output (I/O) devices, industry standard communication, and device interface protocols.

1.2 Organization

The reference manual describes the chip at a system level and provides an architectural overview. It also describes the system memory map, system-level interrupt events, external pins and pin multiplexing, external memory, system debug, system boot, multimedia subsystem, power management, and system security.

1.3 Suggested Reading

This section lists additional resources that provide background for the information in the reference manual, as well as general information about the architecture.

Table 1-1. Suggested Reading

<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
<th>Resource</th>
</tr>
</thead>
<tbody>
<tr>
<td>Fact Sheet</td>
<td>The Fact Sheet is an overview of the product key features and its uses.</td>
<td>i.MX RT Series Crossover Processor Fact Sheet</td>
</tr>
<tr>
<td>Reference Manual</td>
<td>The Reference Manual contains a comprehensive description of the structure and function (operation) of a device.</td>
<td>This document</td>
</tr>
<tr>
<td>Data Sheet</td>
<td>The Data Sheet includes electrical characteristics and signal connections.</td>
<td>i.MX RT1060 Data Sheet - Industrial Products</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 1-1. Suggested Reading (continued)

<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
<th>Resource</th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip Errata</td>
<td>The Chip mask set Errata provides additional or corrective information for a particular device mask set.</td>
<td>i.MX RT1060 Chip Errata</td>
</tr>
<tr>
<td>Application Notes</td>
<td>Provides additional information about particular device feature or function.</td>
<td>AN12419</td>
</tr>
<tr>
<td></td>
<td>AN12419: Secure JTAG for i.MXRT10xx</td>
<td></td>
</tr>
<tr>
<td></td>
<td>AN12085: How to use i.MX RT Low Power Feature</td>
<td>AN12085</td>
</tr>
<tr>
<td></td>
<td>AN12077: Using the i.MX RT FlexRAM</td>
<td>AN12077</td>
</tr>
<tr>
<td>Web Sites</td>
<td>Product summary page on nxp.com with documentation, software, and resources for the device.</td>
<td>i.MX RT1060 Product Summary Page</td>
</tr>
<tr>
<td></td>
<td>Product documentation page on nxp.com with a list of all documentation related to the device.</td>
<td>i.MX RT1060 Documentation</td>
</tr>
<tr>
<td>Community Forum</td>
<td>i.MX RT Community support forum for questions, support, and information about the device.</td>
<td>i.MX RT Community</td>
</tr>
</tbody>
</table>

1.4 Conventions

The reference manual uses the following notational conventions:

**cleared / set**

When a bit has a value of zero, it is said to be cleared; when it has a value of one, it is said to be set.

**mnemonics**

Instruction mnemonics are shown in lowercase bold.

**italics**

Italics indicate variable command parameters, for example, `bectrx`.

The book titles in the text are set in italics.

15

An integer in decimal.

0x

the prefix to denote a hexadecimal number.

0b

The prefix to denote a binary number. Binary values of 0 and 1 are written without a prefix.

n'H4000CA00

The n-bit hexadecimal number.
The register names are all uppercase. The block mnemonic is prepended with an underscore delimiter (_).

The fields within registers appear in brackets. For example, ESR[RLS] refers to the Receive Last Slot field of the ESAI Status Register.

The bit number $n$ within the BLK.REG register.

The register bit ranges. The ranges are indicated by the left-most bit number $l$ and the right-most bit number $r$, separated by a colon (:). For example, ESR[15:0] refers to the lower half word in the ESAI Status Register.

In some contexts, such as signal encodings, an unitalicized $x$ indicates a "don't care" or "uninitialized". The binary value can be 1 or 0.

An italicized $x$ indicates an alphanumeric variable.

Italicized $n$ or $m$ represent integer variables.

Binary logic operator NOT.

Binary logic operator AND.

Binary logic operator OR.

Binary logic operator XOR. For example, $A <O+> B$.

Bit-wise OR. For example, $0b0001 \mid 0b1000$ yields the value of $0b1001$.

Bit-wise AND. For example, $0b0001$ and $0b1000$ yields the value of $0b0000$.

Concatenation, where the $n$-bit value $A$ is prepended to the $m$-bit value $B$ to form an $(n + m)$-bit value. For example, $\{0, \text{REG}m[14:0]\}$ yeilds a 16-bit value with 0 in the most significant bit.

Indicates a reserved bit field in a register. Although these bits can be written to with ones or zeros, they always read zeros.

Shift right logical one position.
Shift left logical one position.

$\leq$

Assignment.

$=\$

Compare equal.

$!=\$

Compare not equal.

$>$

Greater than.

$<$

Less than.

## 1.5 Register Access

### 1.5.1 Register Diagram Field Access Type Legend

This figure provides the interpretation of the notation used in the register diagrams for a number of common field access types:

![Register Diagram Field Access Type Legend](image)

**Figure 1-1. Register Field Conventions**

**NOTE**

For reserved register fields, the software should mask off the data in the field after a read (the software can't rely on the contents of data read from a reserved field) and always write all zeros.

### 1.5.2 Register Macro Usage

A common operation is to update one field without disturbing the contents of the remaining fields in the register. Normally, this requires a read-modify-write (RMW) operation, where the CPU reads the register, modifies the target field, then writes the results back to the register. This is an expensive operation in terms of CPU cycles, because of the initial register read.
To address this issue, some hardware registers are implemented as a group, including registers that can be used to either set, clear, or toggle (SCT) individual bits of the primary register. When writing to an SCT register, all the bits set to 1 perform the associated operation on the primary register, while the bits set to 0 are not affected. The SCT registers always read back 0, and should be considered write-only. The SCT registers are not implemented if the primary register is read-only.

With this architecture, it is possible to update one or more fields using only register writes. First, all bits of the target fields are cleared by a write to the associated clear register, then the desired value of the target fields is written to the set register. This sequence of two writes is referred to as a clear-set (CS) operation.

A CS operation does have one potential drawback. Whenever a field is modified, the hardware sees a value of 0 before the final value is written. For most fields, passing through the 0 state is not a problem. Nonetheless, this behavior is something to consider when using a CS operation.

Also, a CS operation is not required for fields that are one-bit wide. While the CS operation works in this case, it is more efficient to simply set or clear the target bit (that is, one write instead of two). A simple set or clear operation is also atomic, while a CS operation is not.

Note that not all macros for set, clear, or toggle (SCT) are atomic. For registers that do not provide hardware support for this functionality, these macros are implemented as a sequence of read-modify-write operations. When an atomic operation is required, the developer should pay attention to this detail, because unexpected behavior might result if an interrupt occurs in the middle of the critical section comprising the update sequence.

A set of SCT registers is offered for registers in many modules on this device, as described in this manual. In a module memory map table, the suffix _SET, _CLR, or _TOG is added to the base name of the register. For example, the CCM_ANALOG_PLL_ARM register has three other registers called CCM_ANALOG_PLL_ARM_SET, CCM_ANALOG_PLL_ARM_CLR, and CCM_ANALOG_PLL_ARM_TOG.

In the sub-section that describes one of these sets of registers, a short-hand convention is used to denote that a register has the SCT register set. There is an italicized $n$ appended to the end of the short register name. Using the above example, the name used for this register is CCM_ANALOG_PLL_ARM$n$. When you see this designation, there is a SCT register set associated with the register, and you can verify this by checking it in the memory map table. The address offset for each of these registers is given in the form of the following example:

Address: 20C_8000h base + 0h offset + (4d × i), where i=0d to 3d
In this example, the address for each of the base registers and their three SCT registers can be calculated as:

<table>
<thead>
<tr>
<th>Register</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_ANALOG_PLL_ARM</td>
<td>20C_8000h</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_ARM_SET</td>
<td>20C_8004h</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_ARM_CLR</td>
<td>20C_8008h</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_ARM_TOG</td>
<td>20C_800Ch</td>
</tr>
</tbody>
</table>

1.6 Acronyms and Abbreviations

The table below contains acronyms and abbreviations used in this document.

<table>
<thead>
<tr>
<th>Term</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACMP</td>
<td>Analog Comparator</td>
</tr>
<tr>
<td>ADC</td>
<td>Analog-to-Digital Converter</td>
</tr>
<tr>
<td>AHB</td>
<td>Advanced High-performance Bus</td>
</tr>
<tr>
<td>AIPS</td>
<td>Arm IP Bus</td>
</tr>
<tr>
<td>ALU</td>
<td>Arithmetic Logic Unit</td>
</tr>
<tr>
<td>AMBA</td>
<td>Advanced Microcontroller Bus Architecture</td>
</tr>
<tr>
<td>APB</td>
<td>Advanced Peripheral Bus</td>
</tr>
<tr>
<td>ASRC</td>
<td>Asynchronous Sample Rate Converter</td>
</tr>
<tr>
<td>AXI</td>
<td>Advanced eXtensible Interface</td>
</tr>
<tr>
<td>BEE</td>
<td>Bus Encryption Engine</td>
</tr>
<tr>
<td>BIST</td>
<td>Built-In Self Test</td>
</tr>
<tr>
<td>CA/CM</td>
<td>Arm Cortex-A/Cortex-M</td>
</tr>
<tr>
<td>CAN</td>
<td>Controller Area Network</td>
</tr>
<tr>
<td>CCM</td>
<td>Clock Controller Module</td>
</tr>
<tr>
<td>CM7</td>
<td>ARM Cortex M7 Core</td>
</tr>
<tr>
<td>CPU</td>
<td>Central Processing Unit</td>
</tr>
<tr>
<td>CSI</td>
<td>CMOS Sensor Interface</td>
</tr>
<tr>
<td>CSU</td>
<td>Central Security Unit</td>
</tr>
<tr>
<td>CTI</td>
<td>Cross Trigger Interface</td>
</tr>
<tr>
<td>DAP</td>
<td>Debug Access Port</td>
</tr>
<tr>
<td>DCP</td>
<td>Data Co-Processor</td>
</tr>
<tr>
<td>DDR</td>
<td>Double data rate</td>
</tr>
<tr>
<td>DMA</td>
<td>Direct memory access</td>
</tr>
<tr>
<td>DPLL</td>
<td>Digital phase-locked loop</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Term</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>DRAM</td>
<td>Dynamic random access memory</td>
</tr>
<tr>
<td>ECC</td>
<td>Error correcting codes</td>
</tr>
<tr>
<td>LPSPI</td>
<td>Low-power SPI</td>
</tr>
<tr>
<td>EDMA</td>
<td>Enhanced Direct Memory Access</td>
</tr>
<tr>
<td>EIM</td>
<td>External Interface Module</td>
</tr>
<tr>
<td>ENET</td>
<td>Ethernet</td>
</tr>
<tr>
<td>EPIT</td>
<td>Enhanced Periodic Interrupt Timer</td>
</tr>
<tr>
<td>EPROM</td>
<td>Erasable Programmable Read-Only Memory</td>
</tr>
<tr>
<td>ETF</td>
<td>Embedded Trace FIFO</td>
</tr>
<tr>
<td>ETM</td>
<td>Embedded Trace Macrocell</td>
</tr>
<tr>
<td>FIFO</td>
<td>First-In-First-Out</td>
</tr>
<tr>
<td>GIC</td>
<td>General Interrupt Controller</td>
</tr>
<tr>
<td>GPC</td>
<td>General Power Controller</td>
</tr>
<tr>
<td>GPIO</td>
<td>General-Purpose I/O</td>
</tr>
<tr>
<td>GPR</td>
<td>General-Purpose Register</td>
</tr>
<tr>
<td>GPS</td>
<td>Global Positioning System</td>
</tr>
<tr>
<td>GPT</td>
<td>General-Purpose Timer</td>
</tr>
<tr>
<td>GPU</td>
<td>Graphics Processing Unit</td>
</tr>
<tr>
<td>GPV</td>
<td>Global Programmers View</td>
</tr>
<tr>
<td>HAB</td>
<td>High-Assurance Boot</td>
</tr>
<tr>
<td>I2C or I²C</td>
<td>Inter-Integrated Circuit</td>
</tr>
<tr>
<td>IC</td>
<td>Integrated Circuit</td>
</tr>
<tr>
<td>IEEE</td>
<td>Institute of Electrical and Electronics Engineers</td>
</tr>
<tr>
<td>IOMUX</td>
<td>Input-Output Multiplexer</td>
</tr>
<tr>
<td>IP</td>
<td>Intellectual Property</td>
</tr>
<tr>
<td>IrDA</td>
<td>Infrared Data Association</td>
</tr>
<tr>
<td>JTAG</td>
<td>Joint Test Action Group (a serial bus protocol usually used for test purposes)</td>
</tr>
<tr>
<td>LDO</td>
<td>Low-Dropout</td>
</tr>
<tr>
<td>LIFO</td>
<td>Last-In-First-Out</td>
</tr>
<tr>
<td>LRU</td>
<td>Least-Recently Used</td>
</tr>
<tr>
<td>LSB</td>
<td>Least-Significant Byte</td>
</tr>
<tr>
<td>LUT</td>
<td>Look-Up Table</td>
</tr>
<tr>
<td>LVDS</td>
<td>Low Voltage Differential Signaling</td>
</tr>
<tr>
<td>MAC</td>
<td>Medium Access Control</td>
</tr>
<tr>
<td>MCM</td>
<td>Miscellaneous control Module</td>
</tr>
<tr>
<td>MMC</td>
<td>Multimedia Card</td>
</tr>
<tr>
<td>MSB</td>
<td>Most-Significant Byte</td>
</tr>
<tr>
<td>MT/s</td>
<td>Mega Transfers per second</td>
</tr>
<tr>
<td>OCRAM</td>
<td>On-Chip Random-Access Memory</td>
</tr>
<tr>
<td>OCOTP</td>
<td>On-Chip One-Time Programmable Controller</td>
</tr>
<tr>
<td>PCI</td>
<td>Peripheral Component Interconnect</td>
</tr>
</tbody>
</table>

*Table continues on the next page*...
<table>
<thead>
<tr>
<th>Term</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>PCIe</td>
<td>PCI express</td>
</tr>
<tr>
<td>PCMCIA</td>
<td>Personal Computer Memory Card International Association</td>
</tr>
<tr>
<td>PGC</td>
<td>Power Gating Controller</td>
</tr>
<tr>
<td>PIC</td>
<td>Programmable Interrupt Controller</td>
</tr>
<tr>
<td>PMU</td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>POR</td>
<td>Power-On Reset</td>
</tr>
<tr>
<td>PSRAM</td>
<td>Pseudo-Static Random Access Memory</td>
</tr>
<tr>
<td>PWM</td>
<td>Pulse Width Modulation</td>
</tr>
<tr>
<td>PXP</td>
<td>Pixel Pipeline</td>
</tr>
<tr>
<td>QoS</td>
<td>Quality of Service</td>
</tr>
<tr>
<td>R2D</td>
<td>Radians to Degrees</td>
</tr>
<tr>
<td>RISC</td>
<td>Reduced Instruction Set Computing</td>
</tr>
<tr>
<td>ROM</td>
<td>Read-Only Memory</td>
</tr>
<tr>
<td>ROMCP</td>
<td>ROM Controller with Patch</td>
</tr>
<tr>
<td>RTOS</td>
<td>Real-Time Operating System</td>
</tr>
<tr>
<td>Rx</td>
<td>Receive</td>
</tr>
<tr>
<td>SAI</td>
<td>Synchronous Audio Interface</td>
</tr>
<tr>
<td>SCU</td>
<td>Snoop Control Unit</td>
</tr>
<tr>
<td>SD</td>
<td>Secure Digital</td>
</tr>
<tr>
<td>SDIO</td>
<td>Secure Digital Input/Output</td>
</tr>
<tr>
<td>SDLC</td>
<td>Synchronous Data Link Control</td>
</tr>
<tr>
<td>SDMA</td>
<td>Smart DMA</td>
</tr>
<tr>
<td>SIM</td>
<td>Subscriber Identification Module</td>
</tr>
<tr>
<td>SNVS</td>
<td>Secure Non-Volatile Storage</td>
</tr>
<tr>
<td>SoC</td>
<td>System-on-Chip</td>
</tr>
<tr>
<td>SPBA</td>
<td>Shared Peripheral Bus Arbiter</td>
</tr>
<tr>
<td>SPDIF</td>
<td>Sony Phillip Digital Interface</td>
</tr>
<tr>
<td>SPI</td>
<td>Serial Peripheral Interface</td>
</tr>
<tr>
<td>SRAM</td>
<td>Static Random-Access Memory</td>
</tr>
<tr>
<td>SRC</td>
<td>System Reset Controller</td>
</tr>
<tr>
<td>TFT</td>
<td>Thin-Film Transistor</td>
</tr>
<tr>
<td>TPIU</td>
<td>Trace Port Interface</td>
</tr>
<tr>
<td>TSGEN</td>
<td>Time Stamp Generator</td>
</tr>
<tr>
<td>Tx</td>
<td>Transmit</td>
</tr>
<tr>
<td>TZASC</td>
<td>TrustZone Address Space Controller</td>
</tr>
<tr>
<td>UART</td>
<td>Universal Asynchronous Receiver/Transmitter</td>
</tr>
<tr>
<td>USB</td>
<td>Universal Serial Bus</td>
</tr>
<tr>
<td>USDHC</td>
<td>Ultra Secured Digital Host Controller</td>
</tr>
<tr>
<td>WDOG</td>
<td>Watchdog</td>
</tr>
<tr>
<td>WLAN</td>
<td>Wireless Local Area Network</td>
</tr>
<tr>
<td>WXGA</td>
<td>Wide Extended Graphics Array</td>
</tr>
</tbody>
</table>

**Acronyms and Abbreviations**
Chapter 2
Introduction

2.1 Introduction

The i.MX RT1060 is a new processor family featuring NXP's advanced implementation of the high performance Arm Cortex®-M7 Core. It offers high-performance processing optimized for lowest power consumption and best real-time response.

This device provides various memory interfaces, including SDRAM, Raw NAND FLASH, NOR FLASH, SD/eMMC, Quad SPI (FlexSPI), and a wide range of other interfaces for connecting peripherals, such as WLAN, Bluetooth™, displays, camera sensors, and GPS. Same as other i.MX processors, this i.MX RT series also has rich audio and video features, including LCD display, basic 2D graphics, camera interface, SPDIF and I2S audio interface.

2.1.1 Block Diagram

The functional block diagram is shown in the figure below. This diagram provides a view of the chip's major functional components and core complexes.
Figure 2-1. Simplified Block Diagram
2.2 Features

The i.MX RT1060 processors are based on Arm® Cortex®-M7 Platform, which have the following features:

Single Arm Cortex-M7 with:
- 32 KB L1 Instruction Cache
- 32 KB L1 Data Cache
- Single-precision and double-precision FPU (Floating Point Unit)
- Integrated Memory Protection Unit (MPU), up to 16 individual protection regions
- Tightly coupled GPIOs (GPIO6/7/8/9), operating at the same frequency as Arm
- Up to 512KB I-TCM and D-TCM in total

On Chip Memory:
- Boot ROM (128 KB)
- On-chip RAM, configurable RAM up to 1MB (512KB OCRAM shared between ITCM/DTCM and OCRAM, as well as dedicated 512KB OCRAM)

External Memory Interfaces:
- 8/16-bit SDRAM, up to SDRAM-166
- 8-bit SLC NAND FLASH, with ECC handled in SW
- SD/eMMC
- \times2 Single/Dual channel Quad SPI FLASH with XIP support
- Parallel NOR FLASH with XIP support
- SPI NOR/NAND FLASH

Graphics:
- Generic 2D Graphics engine (PXP)
  - BitBlit
  - Flexible image composition options – alpha, chroma key
  - Image rotation (90, 180, 270 degree rotation)
  - Porter-Daff operation
  - Image size
  - Color space conversion
  - Multiple pixel format support (RGB, YUV444, YUV422, YUV420, YUV400)
  - Standard 2D-DMA operation

Display Interface:
- Parallel RGB LCD interface
  - Support 8/16/24 bit interface
  - Support upto WXGA resolution
Features

- Smart LCD Display with 8/16-bit MPU/8080 interface
- Support Index color with 256 entry × 24bit color LUT

Camera Sensor Interface:
- Support 8/16/24-bit CSI Input

Audio:
- S/PDIF Input and Output
- 3x SAI (synchronous audio interface) modules supporting I2S, AC97, TDM, and codec/DSP interfaces
- MQS interface for medium quality audio via GPIO pads

Connectivity:
- 2x USB 2.0 OTG controller with integrated PHY interface
- 2x Ultra Secure Digital Host Controller (uSDHC) interfaces
- 2× 10M/100M Ethernet controller with support for IEEE1588
- 8x Universal asynchronous receiver/transmitter (UARTs) modules
- 4x I2C modules
- 4x SPI modules
- 2x FlexCAN modules
- 1x FlexCAN module with Flexible Data-rate support (CANFD/FlexCAN3)
- 3x FlexIO modules

Timers:
- 2x General Programmable Timer (GPT)
- 4-channel Periodical Interrupt Timer (PIT)
- 4x Quad Timer (QTimer)
- 4x FlexPWM

Analog:
- 2x Analog-Digital-Converters (ADC) (upto 20 channels)
- 4x Analog Comparators (ACMP)

Security:
- High Assurance Boot (HAB)
- Data Co-Processor (DCP)
  - AES-128, ECB, and CBC mode
  - SHA-1 and SHA-256
  - CRC-32
- Bus Encryption Engine (BEE)
  - AES-128, ECB, and CTR mode
  - On-the-fly QSPI Flash decryption
- True Random Number Generator (TRNG)
- Secure Non-volatile Storage (SNVS)
• Secure real-time clock (RTC)
• Zero Master Key (ZMK)
• Secure JTAG Controller (SJC)

System Debug:
• Arm CoreSight debug and trace architecture
• Trace Port Interface Unit (TPIU) to support off-chip real-time trace
• Cross Triggering Interface (CTI)
• Support for 5-pin (JTAG) and SWD debug interfaces

Power Management:
• Full PMIC integration, including on-chip DCDC and LDO
• Temperature sensor with programmable trim points
• GPC hardware power management controller

2.3 Target Applications

This processor can be used in areas such as industrial HMI, IoT, motor control and home appliances, etc.

The architecture’s flexibility enables it to be used in a wide variety of other general embedded applications too. This processor provides all interfaces necessary to connect peripherals such as WLAN, Bluetooth™, GPS, camera sensors, and multiple displays.

2.4 Endianness Support

The chip supports only the Little Endian mode.
Chapter 3
Memory Maps

3.1 Memory system overview
This section introduces the memory architecture of the chip.

NOTE
Accessing the reserved memory regions can result in unpredictable behavior.

3.2 Arm Platform Memory Map
The chip memory map has been provided in the following tables.

Table 3-1. System memory map (CM7)

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Size</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>E010_0000</td>
<td>FFFF_FFFF</td>
<td>511MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>E000_0000</td>
<td>E00F_FFFF</td>
<td>1MB</td>
<td>CM7 PPB</td>
</tr>
<tr>
<td>8000_0000</td>
<td>DFFF_FFFF</td>
<td>1.5GB</td>
<td>SEMC external memories (SDRAM, NOR, PSRAM, NAND and 8080) shared memory space</td>
</tr>
<tr>
<td>7FC0_0000</td>
<td>7FFF_FFFF</td>
<td>4MB</td>
<td>FlexSPI RX FIFO</td>
</tr>
<tr>
<td>7F80_0000</td>
<td>7FBF_FFFF</td>
<td>4MB</td>
<td>FlexSPI TX FIFO</td>
</tr>
<tr>
<td>7F40_0000</td>
<td>7F7F_FFFF</td>
<td>4MB</td>
<td>FlexSPI2 RX FIFO</td>
</tr>
<tr>
<td>7F00_0000</td>
<td>7F3F_FFFF</td>
<td>4MB</td>
<td>FlexSPI2 TX FIFO</td>
</tr>
<tr>
<td>7000_0000</td>
<td>7EFF_FFFF</td>
<td>240MB</td>
<td>FlexSPI2/ FlexSPI2 ciphertext</td>
</tr>
<tr>
<td>6000_0000</td>
<td>6FFF_FFFF</td>
<td>256MB</td>
<td>FlexSPI/ FlexSPI ciphertext</td>
</tr>
<tr>
<td>4800_0000</td>
<td>5FFF_FFFF</td>
<td>384MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4400_0000</td>
<td>47FF_FFFF</td>
<td>64MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4210_0000</td>
<td>43FF_FFFF</td>
<td>31MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4200_0000</td>
<td>420F_FFFF</td>
<td>1MB</td>
<td>AIPS-5</td>
</tr>
<tr>
<td>4180_0000</td>
<td>41FF_FFFF</td>
<td>8MB</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 3-1. System memory map (CM7) (continued)

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Size</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4170_0000</td>
<td>417F_FFFF</td>
<td>1MB</td>
<td>GPV Reserved</td>
</tr>
<tr>
<td>4160_0000</td>
<td>416F_FFFF</td>
<td>1MB</td>
<td>GPV Reserved</td>
</tr>
<tr>
<td>4150_0000</td>
<td>415F_FFFF</td>
<td>1MB</td>
<td>GPV Reserved</td>
</tr>
<tr>
<td>4140_0000</td>
<td>414F_FFFF</td>
<td>1MB</td>
<td>”cpu” configuration port</td>
</tr>
<tr>
<td>4130_0000</td>
<td>413F_FFFF</td>
<td>1MB</td>
<td>Reserved for ”ems” GPV</td>
</tr>
<tr>
<td>4120_0000</td>
<td>412F_FFFF</td>
<td>1MB</td>
<td>Reserved for ”per” GPV</td>
</tr>
<tr>
<td>4110_0000</td>
<td>411F_FFFF</td>
<td>1MB</td>
<td>”m” configuration port</td>
</tr>
<tr>
<td>4100_0000</td>
<td>410F_FFFF</td>
<td>1MB</td>
<td>”main” configuration port</td>
</tr>
<tr>
<td>4040_0000</td>
<td>40FF_FFFF</td>
<td>12MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4030_0000</td>
<td>403F_FFFF</td>
<td>1MB</td>
<td>AIPS-4</td>
</tr>
<tr>
<td>4020_0000</td>
<td>402F_FFFF</td>
<td>1MB</td>
<td>AIPS-3</td>
</tr>
<tr>
<td>4010_0000</td>
<td>401F_FFFF</td>
<td>1MB</td>
<td>AIPS-2</td>
</tr>
<tr>
<td>4000_0000</td>
<td>400F_FFFF</td>
<td>1MB</td>
<td>AIPS-1</td>
</tr>
<tr>
<td>3000_0000</td>
<td>3FFF_FFFF</td>
<td>256MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>2040_0000</td>
<td>2FFF_FFFF</td>
<td>252MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>2030_0000</td>
<td>203F_FFFF</td>
<td>512KB</td>
<td>OCRAM Reserved</td>
</tr>
<tr>
<td>2028_0000</td>
<td>202F_FFFF</td>
<td>512KB</td>
<td>OCRAM - FlexRAM</td>
</tr>
<tr>
<td>2020_0000</td>
<td>2027_FFFF</td>
<td>512KB</td>
<td>OCRAM2</td>
</tr>
<tr>
<td>2010_0000</td>
<td>201F_FFFF</td>
<td>1MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>2008_0000</td>
<td>200F_FFFF</td>
<td>512KB</td>
<td>DTCM Reserved</td>
</tr>
<tr>
<td>2000_0000</td>
<td>2007_FFFF</td>
<td>512KB</td>
<td>DTCM</td>
</tr>
<tr>
<td>1000_0000</td>
<td>1FFF_FFFF</td>
<td>256MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>0800_0000</td>
<td>0FFF_FFFF</td>
<td>128MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>0040_0000</td>
<td>07FF_FFFF</td>
<td>124MB</td>
<td>Reserved</td>
</tr>
<tr>
<td>0028_0000</td>
<td>003F_FFFF</td>
<td>1536KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>0022_0000</td>
<td>0027_FFFF</td>
<td>384KB</td>
<td>ROMCP Reserved</td>
</tr>
<tr>
<td>0020_0000</td>
<td>0021_FFFF</td>
<td>128KB</td>
<td>ROMCP</td>
</tr>
<tr>
<td>0010_0000</td>
<td>001F_FFFF</td>
<td>1MB</td>
<td>ITCM Reserved</td>
</tr>
<tr>
<td>0008_0000</td>
<td>000F_FFFF</td>
<td>512KB</td>
<td>ITCM</td>
</tr>
<tr>
<td>0000_0000</td>
<td>0007_FFFF</td>
<td>512KB</td>
<td>ITCM</td>
</tr>
</tbody>
</table>

The table below shows the Arm IP Bus (AIPS) detailed memory map.

Table 3-2. AIPS-1 memory map

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>400F_C000</td>
<td>400F_FFFF</td>
<td>AIPS-1</td>
<td>16KB</td>
<td>CCM(CCM)</td>
</tr>
<tr>
<td>400F_8000</td>
<td>400F_BFFF</td>
<td></td>
<td>16KB</td>
<td>SRC(SRC)</td>
</tr>
<tr>
<td>400F_4000</td>
<td>400F_7FFF</td>
<td></td>
<td>16KB</td>
<td>GPC</td>
</tr>
<tr>
<td>400F_0000</td>
<td>400F_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 3-2. AIPS-1 memory map (continued)

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>400E_C000</td>
<td>400E_FFFF</td>
<td></td>
<td>16KB</td>
<td>DMA_CH_MUX</td>
</tr>
<tr>
<td>400E_8000</td>
<td>400E_BFFF</td>
<td></td>
<td>16KB</td>
<td>EDMA</td>
</tr>
<tr>
<td>400E_4000</td>
<td>400E_7FFF</td>
<td></td>
<td>16KB</td>
<td>SJC</td>
</tr>
<tr>
<td>400E_0000</td>
<td>400E_3FFF</td>
<td></td>
<td>16KB</td>
<td>TSC_DIG</td>
</tr>
<tr>
<td>400D_C000</td>
<td>400D_FFFF</td>
<td></td>
<td>16KB</td>
<td>CSU</td>
</tr>
<tr>
<td>400D_8000</td>
<td>400D_BFFF</td>
<td></td>
<td>16KB</td>
<td>ANALOG</td>
</tr>
<tr>
<td>400D_4000</td>
<td>400D_7FFF</td>
<td></td>
<td>16KB</td>
<td>SNVS_HP</td>
</tr>
<tr>
<td>400D_0000</td>
<td>400D_3FFF</td>
<td></td>
<td>16KB</td>
<td>WDOG2</td>
</tr>
<tr>
<td>400C_C000</td>
<td>400C_FFFF</td>
<td></td>
<td>16KB</td>
<td>TRNG</td>
</tr>
<tr>
<td>400C_8000</td>
<td>400C_BFFF</td>
<td></td>
<td>16KB</td>
<td>ADC2</td>
</tr>
<tr>
<td>400C_4000</td>
<td>400C_7FFF</td>
<td></td>
<td>16KB</td>
<td>ADC1</td>
</tr>
<tr>
<td>400C_0000</td>
<td>400C_3FFF</td>
<td></td>
<td>16KB</td>
<td>GPIO5</td>
</tr>
<tr>
<td>400B_C000</td>
<td>400B_FFFF</td>
<td></td>
<td>16KB</td>
<td>WDOG3</td>
</tr>
<tr>
<td>400B_8000</td>
<td>400B_BFFF</td>
<td></td>
<td>16KB</td>
<td>WDOG1</td>
</tr>
<tr>
<td>400B_4000</td>
<td>400B_7FFF</td>
<td></td>
<td>16KB</td>
<td>EWM</td>
</tr>
<tr>
<td>400B_0000</td>
<td>400B_3FFF</td>
<td></td>
<td>16KB</td>
<td>CM7_MXRT (FLEXRAM)</td>
</tr>
<tr>
<td>400A_C000</td>
<td>400A_FFFF</td>
<td></td>
<td>16KB</td>
<td>IOMUXC_GPR</td>
</tr>
<tr>
<td>400A_8000</td>
<td>400A_BFFF</td>
<td></td>
<td>16KB</td>
<td>IOMUXC_SNV</td>
</tr>
<tr>
<td>400A_4000</td>
<td>400A_7FFF</td>
<td></td>
<td>16KB</td>
<td>IOMUXC_SNV_GPR</td>
</tr>
<tr>
<td>400A_0000</td>
<td>400A_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4009_C000</td>
<td>4009_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4009_8000</td>
<td>4009_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4009_4000</td>
<td>4009_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4009_0000</td>
<td>4009_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4008_C000</td>
<td>4008_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4008_8000</td>
<td>4008_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4008_4000</td>
<td>4008_7FFF</td>
<td></td>
<td>16KB</td>
<td>PIT</td>
</tr>
<tr>
<td>4008_0000</td>
<td>4008_3FFF</td>
<td></td>
<td>16KB</td>
<td>DCDC</td>
</tr>
<tr>
<td>4007_C000</td>
<td>4007_FFFF</td>
<td></td>
<td>16KB</td>
<td>AIPS-1 Configuration</td>
</tr>
<tr>
<td>4004_0000</td>
<td>4007_BFFF</td>
<td></td>
<td>240KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4000_0000</td>
<td>4003_FFFF</td>
<td></td>
<td>256KB</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The table below shows the AIPS-2 detailed memory map.

### Table 3-3. AIPS-2 memory map

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_C000</td>
<td>401F_FFFF</td>
<td>AIPS-2</td>
<td>16KB</td>
<td>KPP</td>
</tr>
<tr>
<td>401F_8000</td>
<td>401F_BFFF</td>
<td></td>
<td>16KB</td>
<td>IOMUXC</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 3-3. AIPS-2 memory map (continued)

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_4000</td>
<td>401F_7FFF</td>
<td></td>
<td>16KB</td>
<td>OCOTP</td>
</tr>
<tr>
<td>401F_0000</td>
<td>401F_3FFF</td>
<td></td>
<td>16KB</td>
<td>GPT2</td>
</tr>
<tr>
<td>401E_C000</td>
<td>401E_FFFF</td>
<td></td>
<td>16KB</td>
<td>GPT1</td>
</tr>
<tr>
<td>401E_8000</td>
<td>401E_BFFF</td>
<td></td>
<td>16KB</td>
<td>QTimer4</td>
</tr>
<tr>
<td>401E_4000</td>
<td>401E_7FFF</td>
<td></td>
<td>16KB</td>
<td>QTimer3</td>
</tr>
<tr>
<td>401E_0000</td>
<td>401E_3FFF</td>
<td></td>
<td>16KB</td>
<td>QTimer2</td>
</tr>
<tr>
<td>401D_C000</td>
<td>401D_FFFF</td>
<td></td>
<td>16KB</td>
<td>QTimer1</td>
</tr>
<tr>
<td>401D_8000</td>
<td>401D_BFFF</td>
<td></td>
<td>16KB</td>
<td>FlexCAN3</td>
</tr>
<tr>
<td>401D_4000</td>
<td>401D_7FFF</td>
<td></td>
<td>16KB</td>
<td>FlexCAN2</td>
</tr>
<tr>
<td>401D_0000</td>
<td>401D_3FFF</td>
<td></td>
<td>16KB</td>
<td>FlexCAN1</td>
</tr>
<tr>
<td>401C_C000</td>
<td>401C_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>401C_8000</td>
<td>401C_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>401C_4000</td>
<td>401C_7FFF</td>
<td></td>
<td>16KB</td>
<td>GPIO4</td>
</tr>
<tr>
<td>401C_0000</td>
<td>401C_3FFF</td>
<td></td>
<td>16KB</td>
<td>GPIO3</td>
</tr>
<tr>
<td>401B_C000</td>
<td>401B_FFFF</td>
<td></td>
<td>16KB</td>
<td>GPIO2</td>
</tr>
<tr>
<td>401B_8000</td>
<td>401B_BFFF</td>
<td></td>
<td>16KB</td>
<td>GPIO1</td>
</tr>
<tr>
<td>401B_4000</td>
<td>401B_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>401B_0000</td>
<td>401B_3FFF</td>
<td></td>
<td>16KB</td>
<td>FlexIO2</td>
</tr>
<tr>
<td>401A_C000</td>
<td>401A_FFFF</td>
<td></td>
<td>16KB</td>
<td>FlexIO1</td>
</tr>
<tr>
<td>401A_8000</td>
<td>401A_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>401A_4000</td>
<td>401A_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>401A_0000</td>
<td>401A_3FFF</td>
<td></td>
<td>16KB</td>
<td>LPUART8</td>
</tr>
<tr>
<td>4019_C000</td>
<td>4019_FFFF</td>
<td></td>
<td>16KB</td>
<td>LPUART7</td>
</tr>
<tr>
<td>4019_8000</td>
<td>4019_BFFF</td>
<td></td>
<td>16KB</td>
<td>LPUART6</td>
</tr>
<tr>
<td>4019_4000</td>
<td>4019_7FFF</td>
<td></td>
<td>16KB</td>
<td>LPUART5</td>
</tr>
<tr>
<td>4019_0000</td>
<td>4019_3FFF</td>
<td></td>
<td>16KB</td>
<td>LPUART4</td>
</tr>
<tr>
<td>4018_C000</td>
<td>4018_FFFF</td>
<td></td>
<td>16KB</td>
<td>LPUART3</td>
</tr>
<tr>
<td>4018_8000</td>
<td>4018_BFFF</td>
<td></td>
<td>16KB</td>
<td>LPUART2</td>
</tr>
<tr>
<td>4018_4000</td>
<td>4018_7FFF</td>
<td></td>
<td>16KB</td>
<td>LPUART1</td>
</tr>
<tr>
<td>4018_0000</td>
<td>4018_3FFF</td>
<td></td>
<td>16KB</td>
<td>ROMCP</td>
</tr>
<tr>
<td>4017_C000</td>
<td>4017_FFFF</td>
<td></td>
<td>16KB</td>
<td>AIPS-2 Configuration</td>
</tr>
<tr>
<td>4014_0000</td>
<td>4017_BFFF</td>
<td></td>
<td>240KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4010_0000</td>
<td>4013_FFFF</td>
<td></td>
<td>256KB</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The table below shows the AIPS-3 detailed memory map.

### Table 3-4. AIPS-3 memory map

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>402F_C000</td>
<td>402F_FFFF</td>
<td>AIPS-3</td>
<td>16KB</td>
<td>DCP</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 3-4. AIPS-3 memory map (continued)

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>402F_8000</td>
<td>402F_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402F_4000</td>
<td>402F_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402F_0000</td>
<td>402F_3FFF</td>
<td></td>
<td>16KB</td>
<td>SEMC</td>
</tr>
<tr>
<td>402E_C000</td>
<td>402E_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402E_8000</td>
<td>402E_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402E_4000</td>
<td>402E_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402E_0000</td>
<td>402E_3FFF</td>
<td></td>
<td>16KB</td>
<td>USB(USB)</td>
</tr>
<tr>
<td>402D_C000</td>
<td>402D_FFFF</td>
<td></td>
<td>16KB</td>
<td>ENET</td>
</tr>
<tr>
<td>402D_8000</td>
<td>402D_BFFF</td>
<td></td>
<td>16KB</td>
<td>ENET2</td>
</tr>
<tr>
<td>402D_4000</td>
<td>402D_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402C_0000</td>
<td>402C_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402C_8000</td>
<td>402C_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402C_4000</td>
<td>402C_7FFF</td>
<td></td>
<td>16KB</td>
<td>USDHC2</td>
</tr>
<tr>
<td>402C_0000</td>
<td>402C_3FFF</td>
<td></td>
<td>16KB</td>
<td>USDHC1</td>
</tr>
<tr>
<td>402B_C000</td>
<td>402B_FFFF</td>
<td></td>
<td>16KB</td>
<td>CSI</td>
</tr>
<tr>
<td>402B_8000</td>
<td>402B_BFFF</td>
<td></td>
<td>16KB</td>
<td>LCDIF</td>
</tr>
<tr>
<td>402B_4000</td>
<td>402B_7FFF</td>
<td></td>
<td>16KB</td>
<td>PXP</td>
</tr>
<tr>
<td>402A_0000</td>
<td>402A_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402A_C000</td>
<td>402A_FFFF</td>
<td></td>
<td>16KB</td>
<td>FlexSPI</td>
</tr>
<tr>
<td>402A_8000</td>
<td>402A_BFFF</td>
<td></td>
<td>16KB</td>
<td>FlexSPI2</td>
</tr>
<tr>
<td>402A_4000</td>
<td>402A_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>402A_0000</td>
<td>402A_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4029_C000</td>
<td>4029_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4029_8000</td>
<td>4029_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4029_4000</td>
<td>4029_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4029_0000</td>
<td>4029_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4028_C000</td>
<td>4028_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4028_8000</td>
<td>4028_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4028_4000</td>
<td>4028_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4028_0000</td>
<td>4028_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4027_C000</td>
<td>4027_FFFF</td>
<td></td>
<td>16KB</td>
<td>AIPS-3 Configuration</td>
</tr>
<tr>
<td>4024_0000</td>
<td>4027_BFFF</td>
<td></td>
<td>240KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4020_0000</td>
<td>4023_FFFF</td>
<td></td>
<td>256KB</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The table below shows the AIPS-4 detailed memory map.
### Table 3-5. AIPS-4 memory map

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>403F_C000</td>
<td>403F_FFFF</td>
<td>AIPS-4</td>
<td>16KB</td>
<td>LPI2C4</td>
</tr>
<tr>
<td>403F_8000</td>
<td>403F_BFFF</td>
<td></td>
<td>16KB</td>
<td>LPI2C3</td>
</tr>
<tr>
<td>403F_4000</td>
<td>403F_7FFF</td>
<td></td>
<td>16KB</td>
<td>LPI2C2</td>
</tr>
<tr>
<td>403F_0000</td>
<td>403F_3FFF</td>
<td></td>
<td>16KB</td>
<td>LPI2C1</td>
</tr>
<tr>
<td>403E_C000</td>
<td>403E_FFFF</td>
<td></td>
<td>16KB</td>
<td>BEE</td>
</tr>
<tr>
<td>403E_8000</td>
<td>403E_BFFF</td>
<td></td>
<td>16KB</td>
<td>FLEXPWM4</td>
</tr>
<tr>
<td>403E_4000</td>
<td>403E_7FFF</td>
<td></td>
<td>16KB</td>
<td>FLEXPWM3</td>
</tr>
<tr>
<td>403E_0000</td>
<td>403E_3FFF</td>
<td></td>
<td>16KB</td>
<td>FLEXPWM2</td>
</tr>
<tr>
<td>403D_C000</td>
<td>403D_FFFF</td>
<td></td>
<td>16KB</td>
<td>FLEXPWM1</td>
</tr>
<tr>
<td>403D_8000</td>
<td>403D_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>403D_4000</td>
<td>403D_7FFF</td>
<td></td>
<td>16KB</td>
<td>ENC4</td>
</tr>
<tr>
<td>403D_0000</td>
<td>403D_3FFF</td>
<td></td>
<td>16KB</td>
<td>ENC3</td>
</tr>
<tr>
<td>403C_C000</td>
<td>403C_FFFF</td>
<td></td>
<td>16KB</td>
<td>ENC2</td>
</tr>
<tr>
<td>403C_8000</td>
<td>403C_BFFF</td>
<td></td>
<td>16KB</td>
<td>ENC1</td>
</tr>
<tr>
<td>403C_4000</td>
<td>403C_7FFF</td>
<td></td>
<td>16KB</td>
<td>XBAR3</td>
</tr>
<tr>
<td>403C_0000</td>
<td>403C_3FFF</td>
<td></td>
<td>16KB</td>
<td>XBAR2</td>
</tr>
<tr>
<td>403B_C000</td>
<td>403B_FFFF</td>
<td>AIPS-4</td>
<td></td>
<td>AOI2</td>
</tr>
<tr>
<td>403B_8000</td>
<td>403B_BFFF</td>
<td></td>
<td></td>
<td>AOI1</td>
</tr>
<tr>
<td>403B_0000</td>
<td>403B_3FFF</td>
<td></td>
<td></td>
<td>ADC_ETC</td>
</tr>
<tr>
<td>403A_C000</td>
<td>403A_FFFF</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>403A_8000</td>
<td>403A_BFFF</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>403A_4000</td>
<td>403A_7FFF</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>403A_0000</td>
<td>403A_3FFF</td>
<td></td>
<td></td>
<td>LPSPI4</td>
</tr>
<tr>
<td>4039_C000</td>
<td>4039_FFFF</td>
<td></td>
<td></td>
<td>LPSPI3</td>
</tr>
<tr>
<td>4039_8000</td>
<td>4039_BFFF</td>
<td></td>
<td></td>
<td>LPSPI2</td>
</tr>
<tr>
<td>4039_4000</td>
<td>4039_7FFF</td>
<td></td>
<td></td>
<td>LPSPI1</td>
</tr>
<tr>
<td>4039_0000</td>
<td>4039_3FFF</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4038_C000</td>
<td>4038_FFFF</td>
<td></td>
<td></td>
<td>SAI3</td>
</tr>
<tr>
<td>4038_8000</td>
<td>4038_BFFF</td>
<td></td>
<td></td>
<td>SAI2</td>
</tr>
<tr>
<td>4038_4000</td>
<td>4038_7FFF</td>
<td></td>
<td></td>
<td>SAI1</td>
</tr>
<tr>
<td>4038_0000</td>
<td>4038_3FFF</td>
<td></td>
<td></td>
<td>SPDIF</td>
</tr>
<tr>
<td>4037_C000</td>
<td>4037_FFFF</td>
<td></td>
<td></td>
<td>AIPS-4 Configuration</td>
</tr>
<tr>
<td>4034_0000</td>
<td>4037_BFFF</td>
<td></td>
<td>240KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4030_0000</td>
<td>4033_FFFF</td>
<td></td>
<td>256KB</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The table below shows the AIPS-5 detailed memory map.
Table 3-6. AIPS-5 memory map

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Region</th>
<th>Size</th>
<th>NIC Port</th>
</tr>
</thead>
<tbody>
<tr>
<td>4208_0000</td>
<td>420F_FFFF</td>
<td>AIPS-5</td>
<td>512KB</td>
<td>Reserved off platform slots</td>
</tr>
<tr>
<td>4207_C000</td>
<td>4207_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4207_8000</td>
<td>4207_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4207_4000</td>
<td>4207_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4207_0000</td>
<td>4207_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4206_C000</td>
<td>4206_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4206_8000</td>
<td>4206_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4206_4000</td>
<td>4206_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4206_0000</td>
<td>4206_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4205_C000</td>
<td>4205_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4205_8000</td>
<td>4205_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4205_4000</td>
<td>4205_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4205_0000</td>
<td>4205_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4204_C000</td>
<td>4204_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4204_8000</td>
<td>4204_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4204_4000</td>
<td>4204_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4204_0000</td>
<td>4204_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4203_C000</td>
<td>4203_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4203_8000</td>
<td>4203_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4203_4000</td>
<td>4203_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4203_0000</td>
<td>4203_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4202_C000</td>
<td>4202_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4202_8000</td>
<td>4202_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4202_4000</td>
<td>4202_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4202_0000</td>
<td>4202_3FFF</td>
<td></td>
<td>16KB</td>
<td>FlexIO3</td>
</tr>
<tr>
<td>4201_C000</td>
<td>4201_FFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4201_8000</td>
<td>4201_BFFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4201_4000</td>
<td>4201_7FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4201_0000</td>
<td>4201_3FFF</td>
<td></td>
<td>16KB</td>
<td>Reserved</td>
</tr>
<tr>
<td>4200_C000</td>
<td>4200_FFFF</td>
<td></td>
<td>16KB</td>
<td>GPIO9</td>
</tr>
<tr>
<td>4200_8000</td>
<td>4200_BFFF</td>
<td></td>
<td>16KB</td>
<td>GPIO8</td>
</tr>
<tr>
<td>4200_4000</td>
<td>4200_7FFF</td>
<td></td>
<td>16KB</td>
<td>GPIO7</td>
</tr>
<tr>
<td>4200_0000</td>
<td>4200_3FFF</td>
<td></td>
<td>16KB</td>
<td>GPIO6</td>
</tr>
</tbody>
</table>

The table below shows the PPB detailed memory map.
### Table 3-7. PPB memory map

<table>
<thead>
<tr>
<th>Start Address</th>
<th>End Address</th>
<th>Size</th>
<th>Allocation</th>
</tr>
</thead>
<tbody>
<tr>
<td>E00F_F000</td>
<td>E00F_FFFF</td>
<td>4KB</td>
<td>PPB ROM</td>
</tr>
<tr>
<td>E00F_E000</td>
<td>E00F_EFFF</td>
<td>4KB</td>
<td>Processor ROM</td>
</tr>
<tr>
<td>E00F_D000</td>
<td>E00F_DFFF</td>
<td>4KB</td>
<td>SYS ROM</td>
</tr>
<tr>
<td>E00F_0000</td>
<td>E00F_CFFF</td>
<td>52KB</td>
<td>PPB Reserved</td>
</tr>
<tr>
<td>E00F_1000</td>
<td>E00E_FFFF</td>
<td>444KB</td>
<td>PPB Reserved</td>
</tr>
<tr>
<td>E00F_0000</td>
<td>E008_0FFF</td>
<td>4KB</td>
<td>MCM</td>
</tr>
<tr>
<td>E00F_5000</td>
<td>E007_FFFF</td>
<td>236KB</td>
<td>PPB Reserved</td>
</tr>
<tr>
<td>E00F_4000</td>
<td>E004_4FFF</td>
<td>4KB</td>
<td>PPB RES</td>
</tr>
<tr>
<td>E00F_3000</td>
<td>E004_3FFF</td>
<td>4KB</td>
<td>TSGEN</td>
</tr>
<tr>
<td>E00F_2000</td>
<td>E004_2FFF</td>
<td>4KB</td>
<td>CTI</td>
</tr>
<tr>
<td>E00F_1000</td>
<td>E004_1FFF</td>
<td>4KB</td>
<td>ETM</td>
</tr>
<tr>
<td>E00F_0000</td>
<td>E004_0FFF</td>
<td>4KB</td>
<td>TPIU</td>
</tr>
</tbody>
</table>

**NOTE**
Accessing the reserved memory regions can result in unpredictable behavior.
Chapter 4
Interrupts, DMA Events, and XBAR Assignments

4.1 Chip-specific Interrupt information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module or subsystem</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Audio Subsystem</td>
<td>Audio Subsystem</td>
<td>Audio Subsystem Overview</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

4.2 Overview

This section describes the assignments of interrupts from the Arm domain and from the DMA events.

4.3 CM7 interrupts

The Nested Vectored Interrupt Controller (NVIC) collects interrupt request sources and provides an interface to the Cortex-M7 core.

This table describes the Cortex-M7 interrupt sources:
NOTE
Due to the clock frequency difference between CPU and peripheral, in some corner case, peripheral interrupt flag may not be really cleared before CPU exit ISR. In such case, user should add DSB instruction right after instruction to clear interrupt flag.

<table>
<thead>
<tr>
<th>IRQ</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>eDMA</td>
<td>OR</td>
<td>eDMA Channel 0 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 16 Transfer Complete</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 1 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 17 Transfer Complete</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 2 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 18 Transfer Complete</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 3 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 19 Transfer Complete</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 4 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 20 Transfer Complete</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 5 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 21 Transfer Complete</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 6 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 22 Transfer Complete</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 7 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 23 Transfer Complete</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 8 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 24 Transfer Complete</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 9 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 25 Transfer Complete</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 10 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 26 Transfer Complete</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 11 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 27 Transfer Complete</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 12 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 28 Transfer Complete</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 13 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 29 Transfer Complete</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 14 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 30 Transfer Complete</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td>OR</td>
<td>eDMA Channel 15 Transfer Complete</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>eDMA Channel 31 Transfer Complete</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td>-</td>
<td>Error Interrupt, Channels 0-15 / 16-31</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>IRQ</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17</td>
<td>CM7</td>
<td>-</td>
<td>CTI trigger outputs (internal: CTIIRQ[0])</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>CTI trigger outputs (internal: CTIIRQ[1])</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>Core Platform exception IRQ</td>
</tr>
<tr>
<td>20</td>
<td>LPUART1</td>
<td>OR</td>
<td>UART1 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART1 RX interrupt</td>
</tr>
<tr>
<td>21</td>
<td>LPUART2</td>
<td>OR</td>
<td>UART2 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART2 RX interrupt</td>
</tr>
<tr>
<td>22</td>
<td>LPUART3</td>
<td>OR</td>
<td>UART3 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART3 RX interrupt</td>
</tr>
<tr>
<td>23</td>
<td>LPUART4</td>
<td>OR</td>
<td>UART4 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART4 RX interrupt</td>
</tr>
<tr>
<td>24</td>
<td>LPUART5</td>
<td>OR</td>
<td>UART5 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART5 RX interrupt</td>
</tr>
<tr>
<td>25</td>
<td>LPUART6</td>
<td>OR</td>
<td>UART6 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART6 RX interrupt</td>
</tr>
<tr>
<td>26</td>
<td>LPUART7</td>
<td>OR</td>
<td>UART7 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART7 RX interrupt</td>
</tr>
<tr>
<td>27</td>
<td>LPUART8</td>
<td>OR</td>
<td>UART8 TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>UART8 RX interrupt</td>
</tr>
<tr>
<td>28</td>
<td>LPI2C1</td>
<td>OR</td>
<td>I2C-1 Interrupt master async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-1 Interrupt slave async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-1 Interrupt master</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-1 Interrupt slave</td>
</tr>
<tr>
<td>29</td>
<td>LPI2C2</td>
<td>OR</td>
<td>I2C-2 Interrupt master async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-2 Interrupt slave async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-2 Interrupt master</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-2 Interrupt slave</td>
</tr>
<tr>
<td>30</td>
<td>LPI2C3</td>
<td>OR</td>
<td>I2C-3 Interrupt master async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-3 Interrupt slave async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-3 Interrupt master</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-3 Interrupt slave</td>
</tr>
<tr>
<td>31</td>
<td>LPI2C4</td>
<td>OR</td>
<td>I2C-4 Interrupt master async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-4 Interrupt slave async</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-4 Interrupt master</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>I2C-4 Interrupt slave</td>
</tr>
<tr>
<td>32</td>
<td>LP SPI1</td>
<td>-</td>
<td>LP SPI interrupt request line to the core</td>
</tr>
<tr>
<td>33</td>
<td>LP SPI2</td>
<td>-</td>
<td>LP SPI interrupt request line to the core</td>
</tr>
<tr>
<td>34</td>
<td>LP SPI3</td>
<td>-</td>
<td>LP SPI interrupt request line to the core</td>
</tr>
<tr>
<td>35</td>
<td>LP SPI4</td>
<td>-</td>
<td>LP SPI interrupt request line to the core</td>
</tr>
<tr>
<td>IRQ</td>
<td>Module</td>
<td>Logic</td>
<td>Description</td>
</tr>
<tr>
<td>-----</td>
<td>--------------</td>
<td>-------</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td>36</td>
<td>FLEXCAN1</td>
<td>-</td>
<td>Combined interrupt of ini_int_busoff, ini_int_error, ipi_int_mbor, ipi_int_rxwarning, ipi_int_txwarning and ipi_int_wakein.</td>
</tr>
<tr>
<td>37</td>
<td>FLEXCAN2</td>
<td>-</td>
<td>Combined interrupt of ini_int_busoff, ini_int_error, ipi_int_mbor, ipi_int_rxwarning, ipi_int_txwarning and ipi_int_wakein.</td>
</tr>
<tr>
<td>38</td>
<td>CM7</td>
<td>-</td>
<td>FlexRAM address out of range Or access hit IRQ</td>
</tr>
<tr>
<td>39</td>
<td>KPP</td>
<td>-</td>
<td>Keypad Interrupt</td>
</tr>
<tr>
<td>40</td>
<td>TSC_DIG</td>
<td>-</td>
<td>TSC interrupt</td>
</tr>
<tr>
<td>41</td>
<td>GPR_IRQ</td>
<td>-</td>
<td>Used to notify cores on exception condition while boot</td>
</tr>
<tr>
<td>42</td>
<td>LCDIF</td>
<td>-</td>
<td>LCDIF Sync Interrupt</td>
</tr>
<tr>
<td>43</td>
<td>CSI</td>
<td>-</td>
<td>CSI interrupt</td>
</tr>
<tr>
<td>44</td>
<td>PXP</td>
<td>-</td>
<td>PXP interrupt</td>
</tr>
<tr>
<td>45</td>
<td>WDOG2</td>
<td>-</td>
<td>Watchdog Timer reset</td>
</tr>
<tr>
<td>46</td>
<td>SNVS_HP_WRAPPER</td>
<td>-</td>
<td>SNVS Functional Interrupt</td>
</tr>
<tr>
<td>47</td>
<td>SNVS_LP_WRAPPER OR SNVS_HP_WRAPPER</td>
<td>-</td>
<td>SNVS Security Interrupt</td>
</tr>
<tr>
<td>48</td>
<td>CSU</td>
<td>-</td>
<td>CSU Interrupt Request 1. Indicates to the processor that one or more alarm inputs were asserted</td>
</tr>
<tr>
<td>50</td>
<td>DCP</td>
<td>-</td>
<td>Combined DCP channel interrupts (except channel 0) and CRC interrupt</td>
</tr>
<tr>
<td>51</td>
<td></td>
<td>-</td>
<td>IRQ of DCP channel 0</td>
</tr>
<tr>
<td>52</td>
<td></td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>53</td>
<td>TRNG</td>
<td>-</td>
<td>TRNG Interrupt</td>
</tr>
<tr>
<td>54</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>55</td>
<td>BEE</td>
<td>-</td>
<td>BEE IRQ</td>
</tr>
<tr>
<td>56</td>
<td>SAI1</td>
<td>OR</td>
<td>SAI RX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>SAI RX async interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>SAI TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>SAI TX async interrupt</td>
</tr>
<tr>
<td>57</td>
<td>SAI2</td>
<td>OR</td>
<td>SAI RX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>SAI RX async interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>SAI TX interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>SAI TX async interrupt</td>
</tr>
<tr>
<td>58</td>
<td>SAI3</td>
<td>-</td>
<td>SAI RX interrupt</td>
</tr>
<tr>
<td>59</td>
<td></td>
<td>-</td>
<td>SAI TX interrupt</td>
</tr>
<tr>
<td>60</td>
<td>SPDIF</td>
<td>OR</td>
<td>SPDIF Rx interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>SPDIF Tx interrupt</td>
</tr>
<tr>
<td>61</td>
<td>PMU</td>
<td>-</td>
<td>Brown-out event on either the 1.1, 2.5 or 3.0 regulators.</td>
</tr>
<tr>
<td>62</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>IRQ</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>63</td>
<td>Temperature Monitor</td>
<td>OR</td>
<td>TempSensor low</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>TempSensor high</td>
</tr>
<tr>
<td>64</td>
<td></td>
<td></td>
<td>TempSensor panic</td>
</tr>
<tr>
<td>65</td>
<td>USB PHY</td>
<td></td>
<td>USBPHY (UTMI0), Interrupt</td>
</tr>
<tr>
<td>66</td>
<td></td>
<td></td>
<td>USBPHY (UTMI1), Interrupt</td>
</tr>
<tr>
<td>67</td>
<td>ADC1</td>
<td>OR</td>
<td>ADC1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ADC1 async interrupt</td>
</tr>
<tr>
<td>68</td>
<td>ADC2</td>
<td>OR</td>
<td>ADC2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>ADC2 async interrupt</td>
</tr>
<tr>
<td>69</td>
<td>DCDC</td>
<td></td>
<td>DCDC IRQ</td>
</tr>
<tr>
<td>70</td>
<td>Reserved</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>71</td>
<td>Reserved</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>72</td>
<td>GPIO1</td>
<td></td>
<td>Active HIGH Interrupt from INT0 from GPIO</td>
</tr>
<tr>
<td>73</td>
<td></td>
<td></td>
<td>Active HIGH Interrupt from INT1 from GPIO</td>
</tr>
<tr>
<td>74</td>
<td></td>
<td></td>
<td>Active HIGH Interrupt from INT2 from GPIO</td>
</tr>
<tr>
<td>75</td>
<td></td>
<td></td>
<td>Active HIGH Interrupt from INT3 from GPIO</td>
</tr>
<tr>
<td>76</td>
<td></td>
<td></td>
<td>Active HIGH Interrupt from INT4 from GPIO</td>
</tr>
<tr>
<td>77</td>
<td></td>
<td></td>
<td>Active HIGH Interrupt from INT5 from GPIO</td>
</tr>
<tr>
<td>78</td>
<td></td>
<td></td>
<td>Active HIGH Interrupt from INT6 from GPIO</td>
</tr>
<tr>
<td>79</td>
<td></td>
<td></td>
<td>Active HIGH Interrupt from INT7 from GPIO</td>
</tr>
<tr>
<td>80</td>
<td></td>
<td></td>
<td>Combined interrupt indication for GPIO1 signal 0 throughout 15</td>
</tr>
<tr>
<td>81</td>
<td></td>
<td></td>
<td>Combined interrupt indication for GPIO1 signal 16 throughout 31</td>
</tr>
<tr>
<td>82</td>
<td>GPIO2</td>
<td></td>
<td>Combined interrupt indication for GPIO2 signal 0 throughout 15</td>
</tr>
<tr>
<td>83</td>
<td></td>
<td></td>
<td>Combined interrupt indication for GPIO2 signal 16 throughout 31</td>
</tr>
<tr>
<td>84</td>
<td>GPIO3</td>
<td></td>
<td>Combined interrupt indication for GPIO3 signal 0 throughout 15</td>
</tr>
<tr>
<td>85</td>
<td></td>
<td></td>
<td>Combined interrupt indication for GPIO3 signal 16 throughout 31</td>
</tr>
<tr>
<td>86</td>
<td>GPIO4</td>
<td></td>
<td>Combined interrupt indication for GPIO4 signal 0 throughout 15</td>
</tr>
<tr>
<td>87</td>
<td></td>
<td></td>
<td>Combined interrupt indication for GPIO4 signal 16 throughout 31</td>
</tr>
<tr>
<td>88</td>
<td>GPIO5</td>
<td></td>
<td>Combined interrupt indication for GPIO5 signal 0 throughout 15</td>
</tr>
<tr>
<td>89</td>
<td></td>
<td></td>
<td>Combined interrupt indication for GPIO5 signal 16 throughout 31</td>
</tr>
<tr>
<td>90</td>
<td>FLEXIO1</td>
<td>OR</td>
<td>FlexIo interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>FlexIo asynchronous interrupt</td>
</tr>
<tr>
<td>IRQ</td>
<td>Module</td>
<td>Logic</td>
<td>Description</td>
</tr>
<tr>
<td>-----</td>
<td>--------------</td>
<td>-------</td>
<td>--------------------------------------------------</td>
</tr>
<tr>
<td>91</td>
<td>FLEXIO2</td>
<td>OR</td>
<td>FlexIO interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>FlexIO asynchronous interrupt</td>
</tr>
<tr>
<td>92</td>
<td>WDOG1</td>
<td>-</td>
<td>Watchdog Timer reset</td>
</tr>
<tr>
<td>93</td>
<td>RTWDOG</td>
<td>OR</td>
<td>Watchdog Timer reset</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Watchdog Timer Async reset</td>
</tr>
<tr>
<td>94</td>
<td>EWM</td>
<td>-</td>
<td>EWM IRQ</td>
</tr>
<tr>
<td>95</td>
<td>CCM</td>
<td>-</td>
<td>CCM, Interrupt Request 1</td>
</tr>
<tr>
<td>96</td>
<td></td>
<td>-</td>
<td>CCM, Interrupt Request 2</td>
</tr>
<tr>
<td>97</td>
<td>GPC</td>
<td>-</td>
<td>GPC, Interrupt Request</td>
</tr>
<tr>
<td>98</td>
<td>SRC</td>
<td>-</td>
<td>SRC interrupt request</td>
</tr>
<tr>
<td>99</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>100</td>
<td>GPT1</td>
<td>-</td>
<td>All interrupts combined. OR of GPT1 Rollover interrupt line, Input Capture 1 &amp; 2 lines, Output Compare 1,2 &amp;3 Interrupt lines</td>
</tr>
<tr>
<td>101</td>
<td>GPT2</td>
<td>-</td>
<td>All interrupts combined. OR of GPT2 Rollover interrupt line, Input Capture 1 &amp; 2 lines, Output Compare 1,2 &amp;3 Interrupt lines</td>
</tr>
<tr>
<td>102</td>
<td>FLEXPWM1</td>
<td>OR</td>
<td>capture PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload PWM0 interrupt</td>
</tr>
<tr>
<td>103</td>
<td></td>
<td>OR</td>
<td>capture PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload PWM1 interrupt</td>
</tr>
<tr>
<td>104</td>
<td></td>
<td>OR</td>
<td>capture PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload PWM2 interrupt</td>
</tr>
<tr>
<td>105</td>
<td></td>
<td>OR</td>
<td>capture PWM3 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare PWM3 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload PWM3 interrupt</td>
</tr>
<tr>
<td>106</td>
<td></td>
<td>OR</td>
<td>fault interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload error interrupt</td>
</tr>
<tr>
<td>107</td>
<td>FLEXSPI2</td>
<td>-</td>
<td>FlexSPI2 IRQ</td>
</tr>
<tr>
<td>108</td>
<td>FLEXSPI</td>
<td>-</td>
<td>FlexSPI IRQ</td>
</tr>
<tr>
<td>109</td>
<td>SEMC</td>
<td>-</td>
<td>SEMC</td>
</tr>
<tr>
<td>110</td>
<td>USDHC1</td>
<td>-</td>
<td>uSDHC1 Interrupt Request</td>
</tr>
<tr>
<td>111</td>
<td>USDHC2</td>
<td>-</td>
<td>uSDHC2 Interrupt Request</td>
</tr>
<tr>
<td>112</td>
<td>USB</td>
<td>-</td>
<td>USBO2 USB OTG2</td>
</tr>
<tr>
<td>113</td>
<td></td>
<td>-</td>
<td>USBO2 USB OTG1</td>
</tr>
<tr>
<td>114</td>
<td>ENET</td>
<td>OR</td>
<td>MAC 0 Periodic Timer Overflow</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Time Stamp Available</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Payload Receive Error</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>IRQ</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Transmit FIFO Underrun</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Collision Retry Limit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Late Collision</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Ethernet Bus Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 MII Data Transfer Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Receive Buffer Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Receive Frame Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Transmit Buffer Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Transmit Frame Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Graceful Stop</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Babbling Transmit Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Babbling Receive Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Wakeup Request (sync)</td>
</tr>
<tr>
<td>115</td>
<td></td>
<td></td>
<td>MAC 0 1588 Timer Interrupt – synchronous</td>
</tr>
<tr>
<td>116</td>
<td>XBAR1</td>
<td>OR</td>
<td>XBAR IRQ0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>XBAR IRQ1</td>
</tr>
<tr>
<td>117</td>
<td></td>
<td>OR</td>
<td>XBAR IRQ2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>XBAR IRQ3</td>
</tr>
<tr>
<td>118</td>
<td>ADC_ETC</td>
<td>-</td>
<td>adc_etc IRQ0</td>
</tr>
<tr>
<td>119</td>
<td></td>
<td>-</td>
<td>adc_etc IRQ1</td>
</tr>
<tr>
<td>120</td>
<td></td>
<td>-</td>
<td>adc_etc IRQ2</td>
</tr>
<tr>
<td>121</td>
<td></td>
<td>-</td>
<td>adc_etc Error IRQ</td>
</tr>
<tr>
<td>122</td>
<td>PIT</td>
<td>OR</td>
<td>PIT timer 0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>PIT timer 1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>PIT timer 2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>PIT timer 3 interrupt</td>
</tr>
<tr>
<td>123</td>
<td>ACMP</td>
<td>-</td>
<td>ACMP 1 IRQ</td>
</tr>
<tr>
<td>124</td>
<td></td>
<td>-</td>
<td>ACMP 2 IRQ</td>
</tr>
<tr>
<td>125</td>
<td></td>
<td>-</td>
<td>ACMP 3 IRQ</td>
</tr>
<tr>
<td>126</td>
<td></td>
<td>-</td>
<td>ACMP 4 IRQ</td>
</tr>
<tr>
<td>127</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>128</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>129</td>
<td>ENC1</td>
<td>OR</td>
<td>Index marker interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Home marker interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>watchdog timeout interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>simultaneous input switching interrupt</td>
</tr>
<tr>
<td>130</td>
<td>ENC2</td>
<td>OR</td>
<td>Index marker interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Home marker interrupt</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>IRQ</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>131</td>
<td>ENC3</td>
<td>OR</td>
<td>watchdog timeout interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>simultaneous input switching interrupt</td>
</tr>
<tr>
<td>132</td>
<td>ENC4</td>
<td>OR</td>
<td>Index marker interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Home marker interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>watchdog timeout interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>simultaneous input switching interrupt</td>
</tr>
<tr>
<td>133</td>
<td>QTIMER1</td>
<td>OR</td>
<td>Interrupt request for timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #3</td>
</tr>
<tr>
<td>134</td>
<td>QTIMER2</td>
<td>OR</td>
<td>Interrupt request for timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #3</td>
</tr>
<tr>
<td>135</td>
<td>QTIMER3</td>
<td>OR</td>
<td>Interrupt request for timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #3</td>
</tr>
<tr>
<td>136</td>
<td>QTIMER4</td>
<td>OR</td>
<td>Interrupt request for timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt request for timer #3</td>
</tr>
<tr>
<td>137</td>
<td>FLEXPWM2</td>
<td>OR</td>
<td>capture PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload PWM0 interrupt</td>
</tr>
<tr>
<td>138</td>
<td></td>
<td>OR</td>
<td>capture PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload PWM1 interrupt</td>
</tr>
<tr>
<td>139</td>
<td></td>
<td>OR</td>
<td>capture PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>compare PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>reload PWM2 interrupt</td>
</tr>
<tr>
<td>140</td>
<td></td>
<td>OR</td>
<td>capture PWM3 interrupt</td>
</tr>
<tr>
<td>IRQ</td>
<td>Module</td>
<td>Logic</td>
<td>Description</td>
</tr>
<tr>
<td>-----</td>
<td>--------</td>
<td>-------</td>
<td>-------------</td>
</tr>
<tr>
<td>141</td>
<td></td>
<td>OR</td>
<td>fault interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload error interrupt</td>
</tr>
<tr>
<td>142</td>
<td>FLEXPWM3</td>
<td>OR</td>
<td>capture PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM0 interrupt</td>
</tr>
<tr>
<td>143</td>
<td></td>
<td>OR</td>
<td>capture PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM1 interrupt</td>
</tr>
<tr>
<td>144</td>
<td></td>
<td>OR</td>
<td>capture PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM2 interrupt</td>
</tr>
<tr>
<td>145</td>
<td></td>
<td>OR</td>
<td>capture PWM3 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM3 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM3 interrupt</td>
</tr>
<tr>
<td>146</td>
<td></td>
<td>OR</td>
<td>fault interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload error interrupt</td>
</tr>
<tr>
<td>147</td>
<td>FLEXPWM4</td>
<td>OR</td>
<td>capture PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM0 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM0 interrupt</td>
</tr>
<tr>
<td>148</td>
<td></td>
<td>OR</td>
<td>capture PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM1 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM1 interrupt</td>
</tr>
<tr>
<td>149</td>
<td></td>
<td>OR</td>
<td>capture PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM2 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM2 interrupt</td>
</tr>
<tr>
<td>150</td>
<td></td>
<td>OR</td>
<td>capture PWM3 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>compare PWM3 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload PWM3 interrupt</td>
</tr>
<tr>
<td>151</td>
<td></td>
<td>OR</td>
<td>fault interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>reload error interrupt</td>
</tr>
<tr>
<td>152</td>
<td>ENET2</td>
<td>OR</td>
<td>MAC 0 Periodic Timer Overflow</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>MAC 0 Time Stamp Available</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>MAC 0 Payload Receive Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>MAC 0 Transmit FIFO Underrun</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>MAC 0 Collision Retry Limit</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>MAC 0 Late Collision</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>MAC 0 Ethernet Bus Error</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 4-2. CM7 domain interrupt summary (continued)

<table>
<thead>
<tr>
<th>IRQ</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 MII Data Transfer Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Receive Buffer Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Receive Frame Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Transmit Buffer Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Transmit Frame Done</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Graceful Stop</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Babbling Transmit Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Babbling Receive Error</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MAC 0 Wakeup Request (sync)</td>
</tr>
<tr>
<td>153</td>
<td>ENET2</td>
<td>-</td>
<td>MAC 0 1588 Timer Interrupt – synchronous</td>
</tr>
<tr>
<td>154</td>
<td>FLEXCAN3</td>
<td>OR</td>
<td>Interrupt from busoff</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt from CAN line error</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>OR’ed interrupts from ipi_int_MB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>RX warning Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>TX warning Interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt from wake up</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt from match in PN</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt from timeout in PN</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Correctable error interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Non correctable error int host</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Non correctable error int internal</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Busoff done interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>FD error interrupt</td>
</tr>
<tr>
<td>155</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>156</td>
<td>FLEXIO3</td>
<td>OR</td>
<td>FlexIO3 interrupt</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>FlexIO3 asynchronous interrupt</td>
</tr>
<tr>
<td>157</td>
<td>GPIO6/7/8/9</td>
<td>-</td>
<td>OR’ed interrupt of gpio6, gpio7, gpio8 and gpio9</td>
</tr>
<tr>
<td>158-159</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 4.4 DMA Mux

This table shows the DMA request signals for the peripherals in the chip:

### Table 4-3. DMA MUX Mapping

<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>FLEXIO1</td>
<td>OR</td>
<td>FlexIO DMA Request 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO Async DMA Request 0</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>FLEXIO2</td>
<td>OR</td>
<td>FlexIO DMA Request 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO Async DMA Request 1</td>
</tr>
<tr>
<td>2</td>
<td>LPUART1</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>3</td>
<td>LPUART1</td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>4</td>
<td>LPUART3</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>5</td>
<td>LPUART3</td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>6</td>
<td>LPUART5</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>7</td>
<td>LPUART5</td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>8</td>
<td>LPUART7</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>9</td>
<td>LPUART7</td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>FLEXCAN3</td>
<td>-</td>
<td>FLEXCAN3 DMA Request</td>
</tr>
<tr>
<td>12</td>
<td>CSI</td>
<td>-</td>
<td>CSI Write DMA Request</td>
</tr>
<tr>
<td>13</td>
<td>LP SPI1</td>
<td>OR</td>
<td>LP SPI RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>LP SPI RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>14</td>
<td>LP SPI1</td>
<td>OR</td>
<td>LP SPI TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>LP SPI TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>15</td>
<td>LP SPI3</td>
<td>OR</td>
<td>LP SPI RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>LP SPI RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>16</td>
<td>LP SPI3</td>
<td>OR</td>
<td>LP SPI TX FIFO DMA Request</td>
</tr>
<tr>
<td>Channel</td>
<td>Module</td>
<td>Logic</td>
<td>Description</td>
</tr>
<tr>
<td>---------</td>
<td>--------</td>
<td>-------</td>
<td>-------------</td>
</tr>
<tr>
<td>17</td>
<td>LPI2C1</td>
<td>OR</td>
<td>LP SPI TX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master RX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave RX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master TX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>18</td>
<td>LPI2C3</td>
<td>OR</td>
<td>LP SPI TX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master RX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave RX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master TX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>19</td>
<td>SAI1</td>
<td>-</td>
<td>SAI RX FIFO DMA Request</td>
</tr>
<tr>
<td>20</td>
<td>SAI1</td>
<td>-</td>
<td>SAI TX FIFO DMA Request</td>
</tr>
<tr>
<td>21</td>
<td>SAI2</td>
<td>-</td>
<td>SAI RX FIFO DMA Request</td>
</tr>
<tr>
<td>22</td>
<td>SAI2</td>
<td>-</td>
<td>SAI TX FIFO DMA Request</td>
</tr>
<tr>
<td>23</td>
<td>ADC_ETC</td>
<td>-</td>
<td>ADC ETC DMA Request</td>
</tr>
<tr>
<td>24</td>
<td>ADC1</td>
<td>-</td>
<td>ADC DMA Request</td>
</tr>
<tr>
<td>25</td>
<td>ACMP</td>
<td>-</td>
<td>ACMP1 DMA Request</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td>-</td>
<td>ACMP3 DMA Request</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>FLEXSPI</td>
<td>-</td>
<td>FlexSPI RX FIFO DMA Request</td>
</tr>
<tr>
<td>29</td>
<td>FLEXSPI</td>
<td>-</td>
<td>FlexSPI TX FIFO DMA Request</td>
</tr>
<tr>
<td>30</td>
<td>XBAR1</td>
<td>-</td>
<td>XBAR DMA Request 0</td>
</tr>
<tr>
<td>31</td>
<td>XBAR1</td>
<td>-</td>
<td>XBAR DMA Request 1</td>
</tr>
<tr>
<td>32</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM0</td>
</tr>
<tr>
<td>33</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM1</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>34</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM2</td>
</tr>
<tr>
<td>35</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM3</td>
</tr>
<tr>
<td>36</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM0</td>
</tr>
<tr>
<td>37</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM1</td>
</tr>
<tr>
<td>38</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM2</td>
</tr>
<tr>
<td>39</td>
<td>FLEXPWM1</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM3</td>
</tr>
<tr>
<td>40</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM0</td>
</tr>
<tr>
<td>41</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM1</td>
</tr>
<tr>
<td>42</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM2</td>
</tr>
<tr>
<td>43</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM3</td>
</tr>
<tr>
<td>44</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM0</td>
</tr>
<tr>
<td>45</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM1</td>
</tr>
<tr>
<td>46</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM2</td>
</tr>
<tr>
<td>47</td>
<td>FLEXPWM3</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM3</td>
</tr>
<tr>
<td>48</td>
<td>QTIMER1</td>
<td>-</td>
<td>DMA read request for capt in timer #0</td>
</tr>
<tr>
<td>49</td>
<td>QTIMER1</td>
<td>-</td>
<td>DMA read request for capt in timer #1</td>
</tr>
<tr>
<td>50</td>
<td>QTIMER1</td>
<td>-</td>
<td>DMA read request for capt in timer #2</td>
</tr>
<tr>
<td>51</td>
<td>QTIMER1</td>
<td>-</td>
<td>DMA read request for capt in timer #3</td>
</tr>
<tr>
<td>52</td>
<td>QTIMER1</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #1</td>
</tr>
<tr>
<td>53</td>
<td>QTIMER1</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #0</td>
</tr>
<tr>
<td>54</td>
<td>QTIMER1</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>55</td>
<td>QTIMER1</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #3</td>
</tr>
<tr>
<td>56</td>
<td>QTIMER3</td>
<td>OR</td>
<td>DMA read request for capt in timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #1</td>
</tr>
<tr>
<td>57</td>
<td>QTIMER3</td>
<td>OR</td>
<td>DMA read request for capt in timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #0</td>
</tr>
<tr>
<td>58</td>
<td>QTIMER3</td>
<td>OR</td>
<td>DMA read request for capt in timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #3</td>
</tr>
<tr>
<td>59</td>
<td>QTIMER3</td>
<td>OR</td>
<td>DMA read request for capt in timer #3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #2</td>
</tr>
<tr>
<td>60</td>
<td>FlexSPI2</td>
<td>-</td>
<td>FlexSPI2 RX FIFO DMA Request</td>
</tr>
<tr>
<td>61</td>
<td>FlexSPI2</td>
<td>-</td>
<td>FlexSPI2 TX FIFO DMA Request</td>
</tr>
<tr>
<td>62</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>63</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>64</td>
<td>FLEXIO1</td>
<td>OR</td>
<td>FlexIO DMA Request 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO Async DMA Request 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO DMA Request 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO Async DMA Request 3</td>
</tr>
<tr>
<td>65</td>
<td>FLEXIO2</td>
<td>OR</td>
<td>FlexIO DMA Request 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO Async DMA Request 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO DMA Request 3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>FlexIO Async DMA Request 3</td>
</tr>
<tr>
<td>66</td>
<td>LPUART2</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>67</td>
<td>LPUART2</td>
<td>OR</td>
<td>UART TX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>68</td>
<td>LPUART4</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>69</td>
<td>LPUART4</td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>70</td>
<td>LPUART6</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>71</td>
<td>LPUART6</td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>72</td>
<td>LPUART8</td>
<td>OR</td>
<td>UART TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>73</td>
<td>LPUART8</td>
<td>OR</td>
<td>UART RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>UART RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>74</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>75</td>
<td>PXP</td>
<td>-</td>
<td>PXP DMA Event</td>
</tr>
<tr>
<td>76</td>
<td>LCDIF</td>
<td>-</td>
<td>LCDIF DMA Event</td>
</tr>
<tr>
<td>77</td>
<td>LP SPI2</td>
<td>OR</td>
<td>LP SPI2 RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>LP SPI2 RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>78</td>
<td>LP SPI2</td>
<td>OR</td>
<td>LP SPI2 TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>LP SPI2 TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>79</td>
<td>LP SPI4</td>
<td>OR</td>
<td>LP SPI4 RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>LP SPI4 RX FIFO Async DMA Request</td>
</tr>
<tr>
<td>80</td>
<td>LP SPI4</td>
<td>OR</td>
<td>LP SPI4 TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>LP SPI4 TX FIFO Async DMA Request</td>
</tr>
<tr>
<td>81</td>
<td>LPI2C2</td>
<td>OR</td>
<td>I2C Master RX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master RX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave RX FIFO DMA Request</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 4-3. DMA MUX Mapping (continued)

<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>82</td>
<td>LPI2C4</td>
<td>OR</td>
<td>I2C Slave RX FIFO Async DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Master TX FIFO DMA Request</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>I2C Slave RX FIFO DMA Request</td>
</tr>
<tr>
<td>83</td>
<td>SAI3</td>
<td>-</td>
<td>SAI RX FIFO DMA Request</td>
</tr>
<tr>
<td>84</td>
<td>SAI3</td>
<td>-</td>
<td>SAI TX FIFO DMA Request</td>
</tr>
<tr>
<td>85</td>
<td>SPDIF</td>
<td>-</td>
<td>SPDIF RX DMA Request</td>
</tr>
<tr>
<td>86</td>
<td>SPDIF</td>
<td>-</td>
<td>SPDIF TX DMA Request</td>
</tr>
<tr>
<td>87</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>88</td>
<td>ADC2</td>
<td>-</td>
<td>ADC DMA Request</td>
</tr>
<tr>
<td>89</td>
<td>ACMP</td>
<td>-</td>
<td>ACMP2 DMA Request</td>
</tr>
<tr>
<td>90</td>
<td></td>
<td>-</td>
<td>ACMP4 DMA Request</td>
</tr>
<tr>
<td>91</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>92</td>
<td>ENET</td>
<td>-</td>
<td>ENET Timer DMA Request 0</td>
</tr>
<tr>
<td>93</td>
<td>ENET</td>
<td>-</td>
<td>ENET Timer DMA Request 1</td>
</tr>
<tr>
<td>94</td>
<td>XBAR1</td>
<td>-</td>
<td>XBAR DMA Request 2</td>
</tr>
<tr>
<td>95</td>
<td>XBAR1</td>
<td>-</td>
<td>XBAR DMA Request 3</td>
</tr>
<tr>
<td>96</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM0</td>
</tr>
<tr>
<td>97</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM1</td>
</tr>
<tr>
<td>98</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM2</td>
</tr>
<tr>
<td>99</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM3</td>
</tr>
<tr>
<td>100</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM0</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 4-3. DMA MUX Mapping (continued)

<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>101</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM1</td>
</tr>
<tr>
<td>102</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM2</td>
</tr>
<tr>
<td>103</td>
<td>FLEXPWM2</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM3</td>
</tr>
<tr>
<td>104</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM0</td>
</tr>
<tr>
<td>105</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM1</td>
</tr>
<tr>
<td>106</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM2</td>
</tr>
<tr>
<td>107</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Read DMA request for capture regs of sub-module PWM3</td>
</tr>
<tr>
<td>108</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM0</td>
</tr>
<tr>
<td>109</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM1</td>
</tr>
<tr>
<td>110</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM2</td>
</tr>
<tr>
<td>111</td>
<td>FLEXPWM4</td>
<td>-</td>
<td>Write DMA request for value regs of sub-module PWM3</td>
</tr>
<tr>
<td>112</td>
<td>QTIMER2</td>
<td>-</td>
<td>DMA read request for capt in timer #0</td>
</tr>
<tr>
<td>113</td>
<td>QTIMER2</td>
<td>-</td>
<td>DMA read request for capt in timer #1</td>
</tr>
<tr>
<td>114</td>
<td>QTIMER2</td>
<td>-</td>
<td>DMA read request for capt in timer #2</td>
</tr>
<tr>
<td>115</td>
<td>QTIMER2</td>
<td>-</td>
<td>DMA read request for capt in timer #3</td>
</tr>
<tr>
<td>116</td>
<td>QTIMER2</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #1</td>
</tr>
<tr>
<td>117</td>
<td>QTIMER2</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #0</td>
</tr>
<tr>
<td>118</td>
<td>QTIMER2</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #3</td>
</tr>
<tr>
<td>119</td>
<td>QTIMER2</td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 4-3. DMA MUX Mapping (continued)

<table>
<thead>
<tr>
<th>Channel</th>
<th>Module</th>
<th>Logic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>120</td>
<td>QTIMER4</td>
<td>OR</td>
<td>DMA read request for capt in timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #1</td>
</tr>
<tr>
<td>121</td>
<td>QTIMER4</td>
<td>OR</td>
<td>DMA read request for capt in timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #0</td>
</tr>
<tr>
<td>122</td>
<td>QTIMER4</td>
<td>OR</td>
<td>DMA read request for capt in timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #3</td>
</tr>
<tr>
<td>123</td>
<td>QTIMER4</td>
<td>OR</td>
<td>DMA read request for capt in timer #3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld1 in timer #3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>OR</td>
<td>DMA write request for cmpld2 in timer #2</td>
</tr>
<tr>
<td>124</td>
<td>ENET2</td>
<td>-</td>
<td>ENET2 Timer DMA Request 0</td>
</tr>
<tr>
<td>125</td>
<td>ENET2</td>
<td>-</td>
<td>ENET2 Timer DMA Request 1</td>
</tr>
<tr>
<td>126-127</td>
<td>Reserved</td>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

4.5 PIT Channel Assignments For Periodic DMA Triggering

This table shows the PIT channel to DMA channel correspondence.

Table 4-4. PIT Channel Assignments For Periodic DMA Triggering

<table>
<thead>
<tr>
<th>DMA Channel Number</th>
<th>PIT Channel</th>
</tr>
</thead>
<tbody>
<tr>
<td>eDMA Channel 0</td>
<td>PIT Channel 0</td>
</tr>
<tr>
<td>eDMA Channel 1</td>
<td>PIT Channel 1</td>
</tr>
<tr>
<td>eDMA Channel 2</td>
<td>PIT Channel 2</td>
</tr>
<tr>
<td>eDMA Channel 3</td>
<td>PIT Channel 3</td>
</tr>
</tbody>
</table>
### 4.6 XBAR Resource Assignments

This table shows the XBAR resource assignments in the chip.

**NOTE**

ADC_ETC0_COCO0 ... ADC_ETC1_COCO3 in the table are corresponding to coco0 ... coco7, also ADC_ETC_TRIG00 ... ADC_ETC_TRIG13 corresponding to trg0 ... trg7, see the figure "ADC_ETC block diagram" in the ADC_ETC chapter.

**Table 4-5. XBAR1 Input Assignments**

<table>
<thead>
<tr>
<th>Assigned Input</th>
<th>XBAR1 Input</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOGIC LOW</td>
<td>XBAR1_IN00</td>
<td>-</td>
</tr>
<tr>
<td>LOGIC HIGH</td>
<td>XBAR1_IN01</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN02</td>
<td>XBAR1_IN02</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN03</td>
<td>XBAR1_IN03</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT04</td>
<td>XBAR1_IN04</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT05</td>
<td>XBAR1_IN05</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT06</td>
<td>XBAR1_IN06</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT07</td>
<td>XBAR1_IN07</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT08</td>
<td>XBAR1_IN08</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT09</td>
<td>XBAR1_IN09</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT10</td>
<td>XBAR1_IN10</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT11</td>
<td>XBAR1_IN11</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT12</td>
<td>XBAR1_IN12</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT13</td>
<td>XBAR1_IN13</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT14</td>
<td>XBAR1_IN14</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT15</td>
<td>XBAR1_IN15</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT16</td>
<td>XBAR1_IN16</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT17</td>
<td>XBAR1_IN17</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT18</td>
<td>XBAR1_IN18</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_INOUT19</td>
<td>XBAR1_IN19</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN20</td>
<td>XBAR1_IN20</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN21</td>
<td>XBAR1_IN21</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN22</td>
<td>XBAR1_IN22</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN23</td>
<td>XBAR1_IN23</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN24</td>
<td>XBAR1_IN24</td>
<td>-</td>
</tr>
<tr>
<td>IOMUX_XBAR_IN25</td>
<td>XBAR1_IN25</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_OUT</td>
<td>XBAR1_IN26</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_OUT</td>
<td>XBAR1_IN27</td>
<td>-</td>
</tr>
<tr>
<td>ACMP3_OUT</td>
<td>XBAR1_IN28</td>
<td>-</td>
</tr>
</tbody>
</table>

*Table continues on the next page*
### Table 4-5. XBAR1 Input Assignments (continued)

<table>
<thead>
<tr>
<th>Assigned Input</th>
<th>XBAR1 Input</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACMP4_OUT</td>
<td>XBAR1_IN29</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR1_IN30</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR1_IN31</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER0</td>
<td>XBAR1_IN32</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER1</td>
<td>XBAR1_IN33</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER2</td>
<td>XBAR1_IN34</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER3</td>
<td>XBAR1_IN35</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER0</td>
<td>XBAR1_IN36</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER1</td>
<td>XBAR1_IN37</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER2</td>
<td>XBAR1_IN38</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER3</td>
<td>XBAR1_IN39</td>
<td>-</td>
</tr>
<tr>
<td>FLEXPWM1_PWM1_OUT_TRIG0</td>
<td>XBAR1_IN40</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM1_OUT_TRIG1</td>
<td>XBAR1_IN41</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM2_OUT_TRIG0</td>
<td>XBAR1_IN42</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM2_OUT_TRIG1</td>
<td>XBAR1_IN43</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM3_OUT_TRIG0</td>
<td>XBAR1_IN44</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM3_OUT_TRIG1</td>
<td>XBAR1_IN45</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM1_OUT_TRIG0</td>
<td>XBAR1_IN46</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM1_OUT_TRIG1</td>
<td>XBAR1_IN47</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_OUT_TRIG0</td>
<td>XBAR1_IN48</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_OUT_TRIG1</td>
<td>XBAR1_IN49</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_OUT_TRIG0</td>
<td>XBAR1_IN50</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_OUT_TRIG1</td>
<td>XBAR1_IN51</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM1_OUT_TRIG0</td>
<td>XBAR1_IN52</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM1_OUT_TRIG1</td>
<td>XBAR1_IN53</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM2_OUT_TRIG0</td>
<td>XBAR1_IN54</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM2_OUT_TRIG1</td>
<td>XBAR1_IN55</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM3_OUT_TRIG0</td>
<td>XBAR1_IN56</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM3_OUT_TRIG1</td>
<td>XBAR1_IN57</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM1_OUT_TRIG0</td>
<td>XBAR1_IN58</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM1_OUT_TRIG1</td>
<td>XBAR1_IN59</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM2_OUT_TRIG0</td>
<td>XBAR1_IN60</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM2_OUT_TRIG1</td>
<td>XBAR1_IN61</td>
<td>OR</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 4-5. XBAR1 Input Assignments (continued)

<table>
<thead>
<tr>
<th>Assigned Input</th>
<th>XBAR1 Input</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXPWM4_PWM3_OUT_TRIG0</td>
<td>XBAR1_IN54</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM3_OUT_TRIG1</td>
<td>XBAR1_IN55</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM4_OUT_TRIG0</td>
<td>XBAR1_IN56</td>
<td>-</td>
</tr>
<tr>
<td>FLEXPWM4_PWM4_OUT_TRIG1</td>
<td>XBAR1_IN57</td>
<td>-</td>
</tr>
<tr>
<td>PIT_TRIGGER0</td>
<td>XBAR1_IN58</td>
<td>-</td>
</tr>
<tr>
<td>PIT_TRIGGER1</td>
<td>XBAR1_IN59</td>
<td>-</td>
</tr>
<tr>
<td>PIT_TRIGGER2</td>
<td>XBAR1_IN60</td>
<td>-</td>
</tr>
<tr>
<td>PIT_TRIGGER3</td>
<td>XBAR1_IN61</td>
<td>-</td>
</tr>
<tr>
<td>ENC1_POS_MATCH</td>
<td>XBAR1_IN62</td>
<td>-</td>
</tr>
<tr>
<td>ENC2_POS_MATCH</td>
<td>XBAR1_IN63</td>
<td>-</td>
</tr>
<tr>
<td>ENC3_POS_MATCH</td>
<td>XBAR1_IN64</td>
<td>-</td>
</tr>
<tr>
<td>ENC4_POS_MATCH</td>
<td>XBAR1_IN65</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE0</td>
<td>XBAR1_IN66</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE1</td>
<td>XBAR1_IN67</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE2</td>
<td>XBAR1_IN68</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE3</td>
<td>XBAR1_IN69</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE4</td>
<td>XBAR1_IN70</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE5</td>
<td>XBAR1_IN71</td>
<td>-</td>
</tr>
<tr>
<td>AOI1_OUT0</td>
<td>XBAR1_IN72</td>
<td>-</td>
</tr>
<tr>
<td>AOI1_OUT1</td>
<td>XBAR1_IN73</td>
<td>-</td>
</tr>
<tr>
<td>AOI1_OUT2</td>
<td>XBAR1_IN74</td>
<td>-</td>
</tr>
<tr>
<td>AOI1_OUT3</td>
<td>XBAR1_IN75</td>
<td>-</td>
</tr>
<tr>
<td>AOI2_OUT0</td>
<td>XBAR1_IN76</td>
<td>-</td>
</tr>
<tr>
<td>AOI2_OUT1</td>
<td>XBAR1_IN77</td>
<td>-</td>
</tr>
<tr>
<td>AOI2_OUT2</td>
<td>XBAR1_IN78</td>
<td>-</td>
</tr>
<tr>
<td>AOI2_OUT3</td>
<td>XBAR1_IN79</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO0</td>
<td>XBAR1_IN80</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO1</td>
<td>XBAR1_IN81</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO2</td>
<td>XBAR1_IN82</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO3</td>
<td>XBAR1_IN83</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO0</td>
<td>XBAR1_IN84</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO1</td>
<td>XBAR1_IN85</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO2</td>
<td>XBAR1_IN86</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO3</td>
<td>XBAR1_IN87</td>
<td>-</td>
</tr>
</tbody>
</table>
### Table 4-6. XBAR2 Input Assignments

<table>
<thead>
<tr>
<th>Assigned Input</th>
<th>XBAR2 Input</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOGIC LOW</td>
<td>XBAR2_IN00</td>
<td></td>
</tr>
<tr>
<td>LOGIC HIGH</td>
<td>XBAR2_IN01</td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR2_IN02</td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR2_IN03</td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR2_IN04</td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR2_IN05</td>
<td></td>
</tr>
<tr>
<td>ACMP1_OUT</td>
<td>XBAR2_IN06</td>
<td></td>
</tr>
<tr>
<td>ACMP2_OUT</td>
<td>XBAR2_IN07</td>
<td></td>
</tr>
<tr>
<td>ACMP3_OUT</td>
<td>XBAR2_IN08</td>
<td></td>
</tr>
<tr>
<td>ACMP4_OUT</td>
<td>XBAR2_IN09</td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR2_IN10</td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR2_IN11</td>
<td></td>
</tr>
<tr>
<td>QTIMER3_TIMER0</td>
<td>XBAR2_IN12</td>
<td></td>
</tr>
<tr>
<td>QTIMER3_TIMER1</td>
<td>XBAR2_IN13</td>
<td></td>
</tr>
<tr>
<td>QTIMER3_TIMER2</td>
<td>XBAR2_IN14</td>
<td></td>
</tr>
<tr>
<td>QTIMER3_TIMER3</td>
<td>XBAR2_IN15</td>
<td></td>
</tr>
<tr>
<td>QTIMER4_TIMER0</td>
<td>XBAR2_IN16</td>
<td></td>
</tr>
<tr>
<td>QTIMER4_TIMER1</td>
<td>XBAR2_IN17</td>
<td></td>
</tr>
<tr>
<td>QTIMER4_TIMER2</td>
<td>XBAR2_IN18</td>
<td></td>
</tr>
<tr>
<td>QTIMER4_TIMER3</td>
<td>XBAR2_IN19</td>
<td></td>
</tr>
<tr>
<td>FLEXPWM1_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN20</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM1_OUT_TRIG1</td>
<td>XBAR2_IN20</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN21</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN21</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN22</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN22</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN23</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN23</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN24</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM1_OUT_TRIG1</td>
<td>XBAR2_IN24</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN25</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN25</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN26</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN26</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN27</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN27</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN28</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM1_OUT_TRIG1</td>
<td>XBAR2_IN28</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN29</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN29</td>
<td>OR</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 4-6. XBAR2 Input Assignments (continued)

<table>
<thead>
<tr>
<th>Assigned Input</th>
<th>XBAR2 Input</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXPWM3_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN29</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN30</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN30</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN31</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN31</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN32</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM1_OUT_TRIG1</td>
<td>XBAR2_IN32</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN33</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN33</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN34</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN34</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN35</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN35</td>
<td>OR</td>
</tr>
<tr>
<td>PIT_TRIGGER0</td>
<td>XBAR2_IN36</td>
<td>-</td>
</tr>
<tr>
<td>PIT_TRIGGER1</td>
<td>XBAR2_IN37</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO0</td>
<td>XBAR2_IN38</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO1</td>
<td>XBAR2_IN39</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO2</td>
<td>XBAR2_IN40</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO3</td>
<td>XBAR2_IN41</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO0</td>
<td>XBAR2_IN42</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO1</td>
<td>XBAR2_IN43</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO2</td>
<td>XBAR2_IN44</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO3</td>
<td>XBAR2_IN45</td>
<td>-</td>
</tr>
<tr>
<td>ENC1_POS_MATCH</td>
<td>XBAR2_IN46</td>
<td>-</td>
</tr>
<tr>
<td>ENC2_POS_MATCH</td>
<td>XBAR2_IN47</td>
<td>-</td>
</tr>
<tr>
<td>ENC3_POS_MATCH</td>
<td>XBAR2_IN48</td>
<td>-</td>
</tr>
<tr>
<td>ENC4_POS_MATCH</td>
<td>XBAR2_IN49</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE0</td>
<td>XBAR2_IN50</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE1</td>
<td>XBAR2_IN51</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE2</td>
<td>XBAR2_IN52</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE3</td>
<td>XBAR2_IN53</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE4</td>
<td>XBAR2_IN54</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE5</td>
<td>XBAR2_IN55</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE6</td>
<td>XBAR2_IN56</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE7</td>
<td>XBAR2_IN57</td>
<td>-</td>
</tr>
</tbody>
</table>
### Table 4-7. XBAR3 Input Assignments

<table>
<thead>
<tr>
<th>Assigned Input</th>
<th>XBAR3 Input</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOGIC LOW</td>
<td>XBAR3_IN00</td>
<td>-</td>
</tr>
<tr>
<td>LOGIC HIGH</td>
<td>XBAR3_IN01</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR3_IN02</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR3_IN03</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR3_IN04</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR3_IN05</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_OUT</td>
<td>XBAR3_IN06</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_OUT</td>
<td>XBAR3_IN07</td>
<td>-</td>
</tr>
<tr>
<td>ACMP3_OUT</td>
<td>XBAR3_IN08</td>
<td>-</td>
</tr>
<tr>
<td>ACMP4_OUT</td>
<td>XBAR3_IN09</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR3_IN10</td>
<td>-</td>
</tr>
<tr>
<td>Reserved</td>
<td>XBAR3_IN11</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER0</td>
<td>XBAR3_IN12</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER1</td>
<td>XBAR3_IN13</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER2</td>
<td>XBAR3_IN14</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER3_TIMER3</td>
<td>XBAR3_IN15</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER0</td>
<td>XBAR3_IN16</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER1</td>
<td>XBAR3_IN17</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER2</td>
<td>XBAR3_IN18</td>
<td>-</td>
</tr>
<tr>
<td>QTIMER4_TIMER3</td>
<td>XBAR3_IN19</td>
<td>-</td>
</tr>
<tr>
<td>FLEXPWM1_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN20</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM1_OUT_TRIG1</td>
<td>XBAR2_IN20</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN21</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN21</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN22</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN22</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN23</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM1_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN23</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN24</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM1_OUT_TRIG1</td>
<td>XBAR2_IN24</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN25</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN25</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN26</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN26</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN27</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM2_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN27</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN28</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM1_OUT_TRIG1</td>
<td>XBAR2_IN28</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN29</td>
<td>OR</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 4-7. XBAR3 Input Assignments (continued)

<table>
<thead>
<tr>
<th>Assigned Input</th>
<th>XBAR3 Input</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXPWM3_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN29</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN30</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN30</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN31</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM3_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN31</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM1_OUT_TRIG0</td>
<td>XBAR2_IN32</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM2_OUT_TRIG0</td>
<td>XBAR2_IN32</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM2_OUT_TRIG1</td>
<td>XBAR2_IN33</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM3_OUT_TRIG0</td>
<td>XBAR2_IN34</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM3_OUT_TRIG1</td>
<td>XBAR2_IN34</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM4_OUT_TRIG0</td>
<td>XBAR2_IN35</td>
<td>OR</td>
</tr>
<tr>
<td>FLEXPWM4_PWM4_OUT_TRIG1</td>
<td>XBAR2_IN35</td>
<td>OR</td>
</tr>
<tr>
<td>PIT_TRIGGER0</td>
<td>XBAR3_IN36</td>
<td>-</td>
</tr>
<tr>
<td>PIT_TRIGGER1</td>
<td>XBAR3_IN37</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO0</td>
<td>XBAR3_IN38</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO1</td>
<td>XBAR3_IN39</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO2</td>
<td>XBAR3_IN40</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC0_COCO3</td>
<td>XBAR3_IN41</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO0</td>
<td>XBAR3_IN42</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO1</td>
<td>XBAR3_IN43</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO2</td>
<td>XBAR3_IN44</td>
<td>-</td>
</tr>
<tr>
<td>ADC_ETC1_COCO3</td>
<td>XBAR3_IN45</td>
<td>-</td>
</tr>
<tr>
<td>ENC1_POS_MATCH</td>
<td>XBAR3_IN46</td>
<td>-</td>
</tr>
<tr>
<td>ENC2_POS_MATCH</td>
<td>XBAR3_IN47</td>
<td>-</td>
</tr>
<tr>
<td>ENC3_POS_MATCH</td>
<td>XBAR3_IN48</td>
<td>-</td>
</tr>
<tr>
<td>ENC4_POS_MATCH</td>
<td>XBAR3_IN49</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE0</td>
<td>XBAR3_IN50</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE1</td>
<td>XBAR3_IN51</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE2</td>
<td>XBAR3_IN52</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE3</td>
<td>XBAR3_IN53</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE4</td>
<td>XBAR3_IN54</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE5</td>
<td>XBAR3_IN55</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE6</td>
<td>XBAR3_IN56</td>
<td>-</td>
</tr>
<tr>
<td>DMA_DONE7</td>
<td>XBAR3_IN57</td>
<td>-</td>
</tr>
</tbody>
</table>
### Table 4-8. XBAR1 Output Assignments

<table>
<thead>
<tr>
<th>XBAR1 Output</th>
<th>Assigned Output</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR1_OUT00</td>
<td>DMA_CH_MUX_REQ30</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT01</td>
<td>DMA_CH_MUX_REQ31</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT02</td>
<td>DMA_CH_MUX_REQ94</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT03</td>
<td>DMA_CH_MUX_REQ95</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT04</td>
<td>IOMUX_XBAR_INOUT04</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT05</td>
<td>IOMUX_XBAR_INOUT05</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT06</td>
<td>IOMUX_XBAR_INOUT06</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT07</td>
<td>IOMUX_XBAR_INOUT07</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT08</td>
<td>IOMUX_XBAR_INOUT08</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT09</td>
<td>IOMUX_XBAR_INOUT09</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT10</td>
<td>IOMUX_XBAR_INOUT10</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT11</td>
<td>IOMUX_XBAR_INOUT11</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT12</td>
<td>IOMUX_XBAR_INOUT12</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT13</td>
<td>IOMUX_XBAR_INOUT13</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT14</td>
<td>IOMUX_XBAR_INOUT14</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT15</td>
<td>IOMUX_XBAR_INOUT15</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT16</td>
<td>IOMUX_XBAR_INOUT16</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT17</td>
<td>IOMUX_XBAR_INOUT17</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT18</td>
<td>IOMUX_XBAR_INOUT18</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT19</td>
<td>IOMUX_XBAR_INOUT19</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT20</td>
<td>ACMP1_SAMPLE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT21</td>
<td>ACMP2_SAMPLE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT22</td>
<td>ACMP3_SAMPLE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT23</td>
<td>ACMP4_SAMPLE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT24</td>
<td>Reserved</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT25</td>
<td>Reserved</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT26</td>
<td>FLEXPWM1_PWM0_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT27</td>
<td>FLEXPWM1_PWM1_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT28</td>
<td>FLEXPWM1_PWM2_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT29</td>
<td>FLEXPWM1_PWM3_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT30</td>
<td>FLEXPWM1_PWM0_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT31</td>
<td>FLEXPWM1_PWM1_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT32</td>
<td>FLEXPWM1_PWM2_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT33</td>
<td>FLEXPWM1_PWM3_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT34</td>
<td>FLEXPWM1_EXT_CLK</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT35</td>
<td>FLEXPWM1_FAULT0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT36</td>
<td>FLEXPWM1_FAULT1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT37</td>
<td>FLEXPWM1_FAULT2</td>
<td>-</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>XBAR1 Output</th>
<th>Assigned Output</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>FLEXPWM3_FAULT2</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_FAULT2</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT38</td>
<td>FLEXPWM1_FAULT3</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM2_FAULT3</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_FAULT3</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_FAULT3</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT39</td>
<td>FLEXPWM1_EXT_FORCE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT40</td>
<td>FLEXPWM2_PWM0_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM0_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM0_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT41</td>
<td>FLEXPWM2_PWM1_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM1_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM1_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT42</td>
<td>FLEXPWM2_PWM2_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM2_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM2_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT43</td>
<td>FLEXPWM2_PWM3_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM3_EXTA</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM3_EXTA</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT44</td>
<td>FLEXPWM2_PWM0_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT45</td>
<td>FLEXPWM2_PWM1_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT46</td>
<td>FLEXPWM2_PWM2_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT47</td>
<td>FLEXPWM2_PWM3_EXT_SYNC</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT48</td>
<td>FLEXPWM2_EXT_CLK</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_EXT_CLK</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_EXT_CLK</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT49</td>
<td>FLEXPWM2_FAULT0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT50</td>
<td>FLEXPWM2_FAULT1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT51</td>
<td>FLEXPWM2_EXT_FORCE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT52</td>
<td>FLEXPWM3_EXT_SYNC0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT53</td>
<td>FLEXPWM3_EXT_SYNC1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT54</td>
<td>FLEXPWM3_EXT_SYNC2</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT55</td>
<td>FLEXPWM3_EXT_SYNC3</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT56</td>
<td>FLEXPWM3_FAULT0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT57</td>
<td>FLEXPWM3_FAULT1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT58</td>
<td>FLEXPWM3_EXT_FORCE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT59</td>
<td>FLEXPWM4_EXT_SYNC0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT60</td>
<td>FLEXPWM4_EXT_SYNC1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT61</td>
<td>FLEXPWM4_EXT_SYNC2</td>
<td>-</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>XBAR1 Output</th>
<th>Assigned Output</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR1_OUT62</td>
<td>FLEXPWM4_EXT_SYNC3</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT63</td>
<td>FLEXPWM4_FAULT0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT64</td>
<td>FLEXPWM4_FAULT1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT65</td>
<td>FLEXPWM4_EXT_FORCE</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT66</td>
<td>ENC1_PHASEA_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT67</td>
<td>ENC1_PHASEB_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT68</td>
<td>ENC1_INDEX</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT69</td>
<td>ENC1_HOME</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT70</td>
<td>ENC1_TRIGGER</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT71</td>
<td>ENC2_PHASEA_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT72</td>
<td>ENC2_PHASEB_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT73</td>
<td>ENC2_INDEX</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT74</td>
<td>ENC2_HOME</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT75</td>
<td>ENC2_TRIGGER</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT76</td>
<td>ENC3_PHASEA_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT77</td>
<td>ENC3_PHASEB_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT78</td>
<td>ENC3_INDEX</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT79</td>
<td>ENC3_HOME</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT80</td>
<td>ENC3_TRIGGER</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT81</td>
<td>ENC4_PHASEA_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT82</td>
<td>ENC4_PHASEB_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT83</td>
<td>ENC4_INDEX</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT84</td>
<td>ENC4_HOME</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT85</td>
<td>ENC4_TRIGGER</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT86</td>
<td>QTIMER1_TIMER0</td>
<td>Selectable by setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR6[QTIMER1_TRM0_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT87</td>
<td>QTIMER1_TIMER1</td>
<td>Selectable by setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR6[QTIMER1_TRM1_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT88</td>
<td>QTIMER1_TIMER2</td>
<td>Selectable by setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR6[QTIMER1_TRM2_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT89</td>
<td>QTIMER1_TIMER3</td>
<td>Selectable by setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR6[QTIMER1_TRM3_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT90</td>
<td>QTIMER2_TIMER0</td>
<td>Selectable by setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR6[QTIMER2_TRM0_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT91</td>
<td>QTIMER2_TIMER1</td>
<td>Selectable by setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR6[QTIMER2_TRM1_INPUT_SEL]</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>XBAR1 Output</th>
<th>Assigned Output</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR1_OUT92</td>
<td>QTIMER2_TIMER2</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER2_TRM1_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT93</td>
<td>QTIMER2_TIMER3</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER2_TRM2_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT94</td>
<td>QTIMER3_TIMER0</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER3_TRM0_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT95</td>
<td>QTIMER3_TIMER1</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER3_TRM1_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT96</td>
<td>QTIMER3_TIMER2</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER3_TRM2_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT97</td>
<td>QTIMER3_TIMER3</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER3_TRM3_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT98</td>
<td>QTIMER4_TIMER0</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER4_TRM0_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT99</td>
<td>QTIMER4_TIMER1</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER4_TRM1_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT100</td>
<td>QTIMER4_TIMER2</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER4_TRM2_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT101</td>
<td>QTIMER4_TIMER3</td>
<td>Selectable by setting IOMUXC_GPR_GPR6[QTIMER4_TRM3_INPUT_SEL]</td>
</tr>
<tr>
<td>XBAR1_OUT102</td>
<td>EWM_EWM_IN</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT103</td>
<td>ADC_ETC_TRIG00</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT104</td>
<td>ADC_ETC_TRIG01</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT105</td>
<td>ADC_ETC_TRIG02</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT106</td>
<td>ADC_ETC_TRIG03</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT107</td>
<td>ADC_ETC_TRIG10</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT108</td>
<td>ADC_ETC_TRIG11</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT109</td>
<td>ADC_ETC_TRIG12</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT110</td>
<td>ADC_ETC_TRIG13</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT111</td>
<td>LPI2C1_TRG_INPUT</td>
<td>-</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 4-8. XBAR1 Output Assignments (continued)

<table>
<thead>
<tr>
<th>XBAR1 Output</th>
<th>Assigned Output</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR1_OUT112</td>
<td>LPI2C2_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT113</td>
<td>LPI2C3_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT114</td>
<td>LPI2C4_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT115</td>
<td>LPSPI1_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT116</td>
<td>LPSPI2_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT117</td>
<td>LPSPI3_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT118</td>
<td>LPSPI4_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT119</td>
<td>LPUART1_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT120</td>
<td>LPUART2_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT121</td>
<td>LPUART3_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT122</td>
<td>LPUART4_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT123</td>
<td>LPUART5_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT124</td>
<td>LPUART6_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT125</td>
<td>LPUART7_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT126</td>
<td>LPUART8_TRG_INPUT</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT127</td>
<td>FLEXIO1_TRIGGER_IN0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT128</td>
<td>FLEXIO1_TRIGGER_IN1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT129</td>
<td>FLEXIO2_TRIGGER_IN0</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT130</td>
<td>FLEXIO2_TRIGGER_IN1</td>
<td>-</td>
</tr>
<tr>
<td>XBAR1_OUT131</td>
<td>Reserved</td>
<td>-</td>
</tr>
</tbody>
</table>

### Table 4-9. XBAR2 Output Assignments

<table>
<thead>
<tr>
<th>XBAR2 Output</th>
<th>Assigned Output</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR2_OUT00</td>
<td>AOI1_IN00</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT01</td>
<td>AOI1_IN01</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT02</td>
<td>AOI1_IN02</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT03</td>
<td>AOI1_IN03</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT04</td>
<td>AOI1_IN04</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT05</td>
<td>AOI1_IN05</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT06</td>
<td>AOI1_IN06</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT07</td>
<td>AOI1_IN07</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT08</td>
<td>AOI1_IN08</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT09</td>
<td>AOI1_IN09</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT10</td>
<td>AOI1_IN10</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT11</td>
<td>AOI1_IN11</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT12</td>
<td>AOI1_IN12</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT13</td>
<td>AOI1_IN13</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT14</td>
<td>AOI1_IN14</td>
<td>-</td>
</tr>
<tr>
<td>XBAR2_OUT15</td>
<td>AOI1_IN15</td>
<td>-</td>
</tr>
</tbody>
</table>
### Table 4-10. XBAR3 Output Assignments

<table>
<thead>
<tr>
<th>XBAR3 Output</th>
<th>Assigned Output</th>
<th>Gate</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR3_OUT00</td>
<td>AOI2_IN00</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT01</td>
<td>AOI2_IN01</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT02</td>
<td>AOI2_IN02</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT03</td>
<td>AOI2_IN03</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT04</td>
<td>AOI2_IN04</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT05</td>
<td>AOI2_IN05</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT06</td>
<td>AOI2_IN06</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT07</td>
<td>AOI2_IN07</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT08</td>
<td>AOI2_IN08</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT09</td>
<td>AOI2_IN09</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT10</td>
<td>AOI2_IN10</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT11</td>
<td>AOI2_IN11</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT12</td>
<td>AOI2_IN12</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT13</td>
<td>AOI2_IN13</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT14</td>
<td>AOI2_IN14</td>
<td>-</td>
</tr>
<tr>
<td>XBAR3_OUT15</td>
<td>AOI2_IN15</td>
<td>-</td>
</tr>
</tbody>
</table>
Chapter 5
Direct Memory Access Multiplexer (DMAMUX)

5.1 Chip-specific DMAMUX information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>DMA Mux Mapping</td>
<td>DMAMUX</td>
<td>DMA Mux</td>
</tr>
</tbody>
</table>

On this device, only 32-bit write is supported for the DMA_CH_MUX registers.

5.2 Introduction

5.2.1 Overview

The Direct Memory Access Multiplexer (DMAMUX) routes DMA sources, called slots, to any of the 32 DMA channels. This process is illustrated in the following figure.
5.2.2 Features

The DMAMUX module provides these features:

- Up to 128 peripheral slots can be routed to 32 channels.
- 32 independently selectable DMA channel routers.
  - Each channel output can be individually configured to be Always On and not depend on any of the peripheral slots.
  - The first 4 channels additionally provide a trigger functionality.
- Each channel router can be assigned to one of the possible peripheral DMA slots.
- On every memory map configuration change for any channel, this module signals to the DMA Controller to reset the internal state machine for that channel and it can accept a new request based on the new configuration.
5.2.3 Modes of operation

The following operating modes are available:

- Disabled mode
  
  In this mode, the DMA channel is disabled. Because disabling and enabling of DMA channels is done primarily via the DMA configuration registers, this mode is used mainly as the reset state for a DMA channel in the DMA channel MUX. It may also be used to temporarily suspend a DMA channel while reconfiguration of the system takes place, for example, changing the period of a DMA trigger.

- Normal mode
  
  In this mode, a DMA source is routed directly to the specified DMA channel. The operation of the DMAMUX in this mode is completely transparent to the system.

- Periodic Trigger mode
  
  In this mode, a DMA source may only request a DMA transfer, such as when a transmit buffer becomes empty or a receive buffer becomes full, periodically.

  Configuration of the period is done in the registers of the periodic interrupt timer (PIT). This mode is available only for channels 0 to 3.

5.3 External signal description

The DMAMUX has no external pins.

5.4 Functional description

The primary purpose of the DMAMUX is to provide flexibility in the system's use of the available DMA channels.

As such, configuration of the DMAMUX is intended to be a static procedure done during execution of the system boot code. However, if the procedure outlined in Enabling and configuring sources is followed, the configuration of the DMAMUX may be changed during the normal operation of the system.

Functionally, the DMAMUX channels may be divided into two classes:
- Channels that implement the normal routing functionality plus periodic triggering capability
- Channels that implement only the normal routing functionality

### 5.4.1 DMA channels with periodic triggering capability

Besides the normal routing functionality, the first 4 channels of the DMAMUX provide a special periodic triggering capability that can be used to provide an automatic mechanism to transmit bytes, frames, or packets at fixed intervals without the need for processor intervention.

The trigger is generated by the periodic interrupt timer (PIT); as such, the configuration of the periodic triggering interval is done via configuration registers in the PIT. See the section on periodic interrupt timer for more information on this topic.

**Note**

Because of the dynamic nature of the system (due to DMA channel priorities, bus arbitration, interrupt service routine lengths, etc.), the number of clock cycles between a trigger and the actual DMA transfer cannot be guaranteed.
The DMA channel triggering capability allows the system to schedule regular DMA transfers, usually on the transmit side of certain peripherals, without the intervention of the processor. This trigger works by gating the request from the peripheral to the DMA until a trigger event has been seen. This is illustrated in the following figure.

After the DMA request has been serviced, the peripheral will negate its request, effectively resetting the gating mechanism until the peripheral reasserts its request and the next trigger event is seen. This means that if a trigger is seen, but the peripheral is not requesting a transfer, then that trigger will be ignored. This situation is illustrated in the following figure.
This triggering capability may be used with any peripheral that supports DMA transfers, and is most useful for two types of situations:

- **Periodically polling external devices on a particular bus**
  
  As an example, the transmit side of an SPI is assigned to a DMA channel with a trigger, as described above. After it has been set up, the SPI will request DMA transfers, presumably from memory, as long as its transmit buffer is empty. By using a trigger on this channel, the SPI transfers can be automatically performed every 5 μs (as an example). On the receive side of the SPI, the SPI and DMA can be configured to transfer receive data into memory, effectively implementing a method to periodically read data from external devices and transfer the results into memory without processor intervention.

- **Using the GPIO ports to drive or sample waveforms**
  
  By configuring the DMA to transfer data to one or more GPIO ports, it is possible to create complex waveforms using tabular data stored in on-chip memory. Conversely, using the DMA to periodically transfer data from one or more GPIO ports, it is possible to sample complex waveforms and store the results in tabular form in on-chip memory.

A more detailed description of the capability of each trigger, including resolution, range of values, and so on, may be found in the periodic interrupt timer section.

### 5.4.2 Always-enabled DMA sources

In addition to the peripherals that can be used as DMA sources, each DMA Channel can be individually configured to function as an Always Enabled source. Unlike the peripheral DMA sources, where the peripheral controls the flow of data during DMA transfers, the always enabled channel provide no such "throttling" of the data transfers. These sources are most useful in the following cases:
• Performing DMA transfers to/from GPIO—Moving data from/to one or more GPIO pins, either unthrottled (that is, as fast as possible), or periodically (using the DMA triggering capability).

• Performing DMA transfers from memory to memory—Moving data from memory to memory, typically as fast as possible, sometimes with software activation.

• Performing DMA transfers from memory to the external bus, or vice-versa—Similar to memory to memory transfers, this is typically done as quickly as possible.

• Any DMA transfer that requires software activation—Any DMA transfer that should be explicitly started by software.

In cases where software should initiate the start of a DMA transfer, an always-enabled DMA channel can be used to provide maximum flexibility. When activating a DMA channel via software, subsequent executions of the minor loop require that a new start event be sent. This can either be a new software activation, or a transfer request from the DMA channel MUX. The options for doing this are:

• Transfer all data in a single minor loop.

  By configuring the DMA to transfer all of the data in a single minor loop (that is, major loop counter = 1), no reactivation of the channel is necessary. The disadvantage to this option is the reduced granularity in determining the load that the DMA transfer will impose on the system. For this option, the DMA channel must be disabled in the DMA channel MUX.

• Use explicit software reactivation.

  In this option, the DMA is configured to transfer the data using both minor and major loops, but the processor is required to reactivate the channel by writing to the DMA registers after every minor loop. For this option, the DMA channel must be disabled in the DMA channel MUX.

• Use an always-enabled DMA source.

  In this option, the DMA is configured to transfer the data using both minor and major loops, and the DMA channel MUX does the channel reactivation. For this option, the DMA channel should be enabled and configured as "always enabled" channel. Note that the reactivation of the channel can be continuous (DMA triggering is disabled) or can use the DMA triggering capability. In this manner, it is possible to execute periodic transfers of packets of data from one source to another, without processor intervention.
NOTE
When a channel is configured as "Always Enabled", then the peripheral DMA sources for that channel are ignored; i.e. SOURCE field has no effect.

5.5 Initialization/application information

This section provides instructions for initializing the DMA channel MUX.

5.5.1 Reset

The reset state of each individual bit is shown in Memory map/register definition. In summary, after reset, all channels are disabled and must be explicitly enabled before use.

5.5.2 Enabling and configuring sources

To enable a source with periodic triggering:

1. Determine with which DMA channel the source will be associated. Note that only the first 4 DMA channels have periodic triggering capability.
2. Clear the CHCFG[ENBL] and CHCFG[TRIG] fields of the DMA channel.
3. Ensure that the DMA channel is properly configured in the DMA. The DMA channel may be enabled at this point.
4. Configure the corresponding timer.
5. Select the source to be routed to the DMA channel. Write to the corresponding CHCFG register, ensuring that the CHCFG[ENBL] and CHCFG[TRIG] fields are set.

NOTE
The following is an example. See the chip configuration details for the number of this device's DMA channels that have triggering capability.

To configure source #5 transmit for use with DMA channel 1, with periodic triggering capability:

1. Write 0x00000000 to CHCFG1.
2. Configure channel 1 in the DMA, including enabling the channel.
3. Configure a timer for the desired trigger interval.
4. Write 0xC0000005 to CHCFG1.
The following code example illustrates steps 1 and 4 above:

```c
void DMAMUX_Init(uint8_t DMA_CH, uint8_t DMAMUX_SOURCE)
{
    DMAMUX_0.CHCFG[(DMA_CH)].B.SOURCE = DMAMUX_SOURCE;
    DMAMUX_0.CHCFG[(DMA_CH)].B.ENBL  = 1;
    DMAMUX_0.CHCFG[(DMA_CH)].B.TRIG  = 1;
}
```

To enable a source without periodic triggering:

1. Determine with which DMA channel the source will be associated. Note that only the first 4 DMA channels have periodic triggering capability.
2. Clear the CHCFG[ENBL] and CHCFG[TRIG] fields of the DMA channel.
3. Ensure that the DMA channel is properly configured in the DMA. The DMA channel may be enabled at this point.
4. Select the source to be routed to the DMA channel. Write to the corresponding CHCFG register, ensuring that CHCFG[ENBL] is set while CHCFG[TRIG] is cleared.

**NOTE**

The following is an example. See the chip configuration details for the number of this device’s DMA channels that have triggering capability.

To configure source #5 transmit for use with DMA channel 1 with no periodic triggering capability:

1. Write 0x00000000 to CHCFG1.
2. Configure channel 1 in the DMA, including enabling the channel.
3. Write 0x80000005 to CHCFG1.

The following code example illustrates steps 1 and 3 above:

In File registers.h:

```c
#define DMAMUX_BASE_ADDR     0x40021000/* Example only ! */
/* Following example assumes long is 32-bits */
volatile unsigned long *CHCFG0 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0000);
volatile unsigned long *CHCFG1 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0004);
volatile unsigned long *CHCFG2 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0008);
volatile unsigned long *CHCFG3 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x000C);
volatile unsigned long *CHCFG4 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0010);
volatile unsigned long *CHCFG5 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0014);
volatile unsigned long *CHCFG6 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0018);
volatile unsigned long *CHCFG7 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x001C);
volatile unsigned long *CHCFG8 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0020);
volatile unsigned long *CHCFG9 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0024);
volatile unsigned long *CHCFG10= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0028);
volatile unsigned long *CHCFG11= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x002C);
volatile unsigned long *CHCFG12= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0030);
volatile unsigned long *CHCFG13= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0034);
volatile unsigned long *CHCFG14= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0038);
volatile unsigned long *CHCFG15= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x003C);
```

In File main.c:

```c
#include "registers.h"
```
To disable a source:
A particular DMA source may be disabled by not writing the corresponding source value into any of the CHCFG registers. Additionally, some module-specific configuration may be necessary. See the appropriate section for more details.

To switch the source of a DMA channel:

1. Disable the DMA channel in the DMA and reconfigure the channel for the new source.
2. Clear the CHCFG[ENBL] and CHCFG[TRIG] bits of the DMA channel.
3. Select the source to be routed to the DMA channel. Write to the corresponding CHCFG register, ensuring that the CHCFG[ENBL] and CHCFG[TRIG] fields are set.

To switch DMA channel 8 from source #5 transmit to source #7 transmit:
1. In the DMA configuration registers, disable DMA channel 8 and reconfigure it to handle the transfers to peripheral slot 7. This example assumes channel 8 doesn't have triggering capability.
2. Write 0x00000000 to CHCFG8.
3. Write 0x80000007 to CHCFG8. (In this example, setting CHCFG[TRIG] would have no effect due to the assumption that channel 8 does not support the periodic triggering functionality.)

The following code example illustrates steps 2 and 3 above:

In File registers.h:
#define DMAMUX_BASE_ADDR 0x40021000/* Example only! */
/* Following example assumes long is 32-bits */
volatile unsigned long *CHCFG0 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0000);
volatile unsigned long *CHCFG1 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0004);
volatile unsigned long *CHCFG2 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0008);
volatile unsigned long *CHCFG3 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x000C);
volatile unsigned long *CHCFG4 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0010);
volatile unsigned long *CHCFG5 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0014);
volatile unsigned long *CHCFG6 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0018);
volatile unsigned long *CHCFG7 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x001C);
volatile unsigned long *CHCFG8 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0020);
volatile unsigned long *CHCFG9 = (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0024);
volatile unsigned long *CHCFG10= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0028);
volatile unsigned long *CHCFG11= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x002C);
volatile unsigned long *CHCFG12= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0030);
volatile unsigned long *CHCFG13= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0034);
volatile unsigned long *CHCFG14= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x0038);
volatile unsigned long *CHCFG15= (volatile unsigned long *) (DMAMUX_BASE_ADDR+0x003C);

In File main.c:
#include "registers.h"
:
*:CHCFG8 = 0x00000000;
*CHCFG8 = 0x80000007;
5.5.2.1 Configuration options

Table 5-2. Channel Configuration Options

<table>
<thead>
<tr>
<th>ENBL</th>
<th>TRIG</th>
<th>A_ON</th>
<th>Function</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>X</td>
<td>X</td>
<td>DMA channel is disabled</td>
<td>Disabled Mode</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>DMA channel is enabled with no triggering</td>
<td>Normal Mode</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>DMA channel is enabled with triggering</td>
<td>Periodic Trigger Mode</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>DMA channel is always enabled</td>
<td>Always On Mode</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>DMA channel is always enabled with triggering</td>
<td>Always On Trigger Mode</td>
</tr>
</tbody>
</table>

5.6 Memory map/register definition

This section provides a detailed description of all memory-mapped registers in the DMAMUX.

5.6.1 DMA_CH_MUX Register Descriptions

5.6.1.1 DMA_CH_MUX Memory Map

Base address: 400E_C000.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h - 7Ch</td>
<td>Channel a Configuration (CHCFG0 - CHCFG31)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
</tbody>
</table>

5.6.1.2 Channel a Configuration (CHCFGa)

5.6.1.2.1 Address

For a = 0 to 31:
5.6.1.2.2 Function

Each of the DMA channels can be independently enabled/disabled and associated with one of the DMA slots (peripheral slots or always-on slots) in the system.

**NOTE**

Setting multiple CHCFG registers with the same source value will result in unpredictable behavior. This is true, even if a channel is disabled (ENBL==0).

Before changing the trigger or source settings, a DMA channel must be disabled via CHCFGn[ENBL].

5.6.1.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ENBL</td>
<td>TRIG</td>
<td>A_ON</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SOURCE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

5.6.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 ENBL</td>
<td>DMA Mux Channel Enable</td>
</tr>
<tr>
<td></td>
<td>Enables the channel for DMA Mux. The DMA has separate channel enables/disables, which should be used to disable or reconfigure a DMA channel.</td>
</tr>
<tr>
<td></td>
<td>0b - DMA Mux channel is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - DMA Mux channel is enabled</td>
</tr>
<tr>
<td>30 TRIG</td>
<td>DMA Channel Trigger Enable</td>
</tr>
<tr>
<td></td>
<td>Enables the periodic trigger capability for the triggered DMA channel.</td>
</tr>
<tr>
<td></td>
<td>0b - Triggering is disabled. If triggering is disabled and ENBL is set, the DMA Channel will simply route the specified source to the DMA channel. (Normal mode)</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
1b - Triggering is enabled. If triggering is enabled and ENBL is set, the DMA_CH_MUX is in Periodic Trigger mode. : 29

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>29</td>
<td>A_ON</td>
</tr>
<tr>
<td>DMA Channel Always Enable</td>
<td>Enables the DMA Channel to be always ON. If TRIG bit is set, the module will assert request on every trigger.</td>
</tr>
</tbody>
</table>
| 0b - DMA Channel Always ON function is disabled  
1b - DMA Channel Always ON function is enabled | |

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>28-7</td>
<td>Reserved field</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>6-0</td>
<td>SOURCE</td>
</tr>
<tr>
<td>DMA Channel Source (Slot Number)</td>
<td>Specifies which DMA source, if any, is routed to a particular DMA channel. See the &quot;DMA MUX Mapping&quot; table in the &quot;Interrupts, DMA Events, and XBAR Assignments&quot; chapter for details about DMA source and channel information.</td>
</tr>
</tbody>
</table>
Chapter 6
Enhanced Direct Memory Access (eDMA)

6.1 Chip-specific eDMA information

Table 6-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

6.2 Introduction

The enhanced direct memory access (eDMA) controller is a second-generation module capable of performing complex data transfers with minimal intervention from a host processor. The hardware microarchitecture includes:

- A DMA engine that performs:
  - Source address and destination address calculations
  - Data-movement operations
  - Local memory containing transfer control descriptors for each of the 32 channels
6.2.1 eDMA system block diagram

Figure 6-1 illustrates the components of the eDMA system, including the eDMA module ("engine").

![Figure 6-1. eDMA system block diagram](image)

6.2.2 Block parts

The eDMA module is partitioned into two major modules: the eDMA engine and the transfer-control descriptor local memory.

The eDMA engine is further partitioned into four submodules:

<table>
<thead>
<tr>
<th>Submodule</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>Address path</td>
<td>This block implements registered versions of two channel transfer control descriptors, channel x and channel y, and manages all master bus-address calculations. All the channels provide the same functionality. This structure allows data transfers associated with one channel to be preempted after the completion of a read/write sequence if a higher priority channel activation is asserted while the first channel is active. After a channel is activated, it runs until the minor loop is executed.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 6-2. eDMA engine submodules (continued)

<table>
<thead>
<tr>
<th>Submodule</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>completed, unless preempted by a higher priority channel. This provides a mechanism (enabled by DCHPRIn[ECP]) where a large data move operation can be preempted to minimize the time another channel is blocked from execution. When any channel is selected to execute, the contents of its TCD are read from local memory and loaded into the address path channel x registers for a normal start and into channel y registers for a preemption start. After the minor loop completes execution, the address path hardware writes the new values for the TCDn_{SADDR, DADDR, CITER} back to local memory. If the major iteration count is exhausted, additional processing is performed, including the final address pointer updates, reloading the TCDn_CITER field, and a possible fetch of the next TCDn from memory as part of a scatter/gather operation.</td>
<td></td>
</tr>
<tr>
<td>Data path</td>
<td>This block implements the bus master read/write datapath. It includes a data buffer and the necessary multiplex logic to support any required data alignment. The internal read data bus is the primary input, and the internal write data bus is the primary output. The address and data path modules directly support the 2-stage pipelined internal bus. The address path module represents the 1st stage of the bus pipeline (address phase), while the data path module implements the 2nd stage of the pipeline (data phase).</td>
</tr>
<tr>
<td>Program model/channel arbitration</td>
<td>This block implements the first section of the eDMA programming model as well as the channel arbitration logic. The programming model registers are connected to the internal peripheral bus. The eDMA peripheral request inputs and interrupt request outputs are also connected to this block (via control logic).</td>
</tr>
<tr>
<td>Control</td>
<td>This block provides all the control functions for the eDMA engine. For data transfers where the source and destination sizes are equal, the eDMA engine performs a series of source read/destination write operations until the number of bytes specified in the minor loop byte count has moved. For descriptors where the sizes are not equal, multiple accesses of the smaller size data are required for each reference of the larger size. As an example, if the source size references 16-bit data and the destination is 32-bit data, two reads are performed, then one 32-bit write.</td>
</tr>
</tbody>
</table>

The transfer-control descriptor local memory is further partitioned into:

Table 6-3. Transfer control descriptor memory

<table>
<thead>
<tr>
<th>Submodule</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Memory controller</td>
<td>This logic implements the required dual-ported controller, managing accesses from the eDMA engine as well as references from the internal peripheral bus. As noted earlier, in the event of simultaneous accesses, the eDMA engine is given priority and the peripheral transaction is stalled.</td>
</tr>
<tr>
<td>Memory array</td>
<td>TCD storage for each channel's transfer profile.</td>
</tr>
</tbody>
</table>

6.2.3 Features

The eDMA is a highly programmable data-transfer engine optimized to minimize any required intervention from the host processor. It is intended for use in applications where the data size to be transferred is statically known and not defined within the transferred data itself. The eDMA module features:
• All data movement via dual-address transfers: read from source, write to destination
  • Programmable source and destination addresses and transfer size
  • Support for enhanced addressing modes
• 32-channel implementation that performs complex data transfers with minimal intervention from a host processor
  • Internal data buffer, used as temporary storage to support 16- and 32-byte transfers
  • Connections to the crossbar switch for bus mastering the data movement
• Transfer control descriptor (TCD) organized to support two-deep, nested transfer operations
  • 32-byte TCD stored in local memory for each channel
  • An inner data transfer loop defined by a minor byte transfer count
  • An outer data transfer loop defined by a major iteration count
• Channel activation via one of three methods:
  • Explicit software initiation
  • Initiation via a channel-to-channel linking mechanism for continuous transfers
  • Peripheral-paced hardware requests, one per channel
• Fixed-priority and round-robin channel arbitration
• Channel completion reported via programmable interrupt requests
  • One interrupt per channel, which can be asserted at completion of major iteration count
  • Programmable error terminations per channel and logically summed together to form one error interrupt to the interrupt controller
• Programmable support for scatter/gather DMA processing
• Support for complex data structures

In the discussion of this module, \( n \) is used to reference the channel number.
6.3 Modes of operation

The eDMA operates in the following modes:

<table>
<thead>
<tr>
<th>Mode</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Normal</td>
<td>In Normal mode, the eDMA transfers data between a source and a destination. The source and destination can be a memory block or an I/O block capable of operation with the eDMA. A service request initiates a transfer of a specific number of bytes (NBYTES) as specified in the transfer control descriptor (TCD). The minor loop is the sequence of read-write operations that transfers these NBYTES per service request. Each service request executes one iteration of the major loop, which transfers NBYTES of data.</td>
</tr>
</tbody>
</table>
| Debug  | DMA operation is configurable in Debug mode via the control register:  
• If CR[EDBG] is cleared, the DMA continues to operate.  
• If CR[EDBG] is set, the eDMA stops transferring data. If Debug mode is entered while a channel is active, the eDMA continues operation until the channel retires. |
| Wait   | Before entering Wait mode, the DMA attempts to complete its current transfer. After the transfer completes, the device enters Wait mode. |

6.4 Functional description

The operation of the eDMA is described in the following subsections.

6.4.1 eDMA basic data flow

The basic flow of a data transfer can be partitioned into three segments.

As shown in the following diagram, the first segment involves the channel activation:
This example uses the assertion of the eDMA peripheral request signal to request service for channel $n$. Channel activation via software and the TCD$_n$ _CSR[START] bit follows the same basic flow as peripheral requests. The eDMA request input signal is registered internally and then routed through the eDMA engine: first through the control module, then into the program model and channel arbitration. In the next cycle, the channel arbitration performs, using the fixed-priority or round-robin algorithm. After arbitration is complete, the activated channel number is sent through the address path and converted into the required address to access the local memory for TCD$_n$. Next, the TCD memory is accessed and the required descriptor read from the local memory and loaded into the eDMA engine address path channel x or y registers. The TCD memory is 64 bits wide to minimize the time needed to fetch the activated channel descriptor and load it into the address path channel x or y registers.

The following diagram illustrates the second part of the basic data flow:
The modules associated with the data transfer (address path, data path, and control) sequence through the required source reads and destination writes to perform the actual data movement. The source reads are initiated and the fetched data is temporarily stored in the data path block until it is gated onto the internal bus during the destination write. This source read/destination write processing continues until the minor byte count has transferred.

After the minor byte count has moved, the final phase of the basic data flow is performed. In this segment, the address path logic performs the required updates to certain fields in the appropriate TCD, for example, SADDR, DADDR, CITER. If the major iteration count is exhausted, additional operations are performed. These include the final address adjustments and reloading of the BITER field into the CITER. Assertion of an optional interrupt request also occurs at this time, as does a possible fetch of a new TCD from memory using the scatter/gather address pointer included in the descriptor (if scatter/gather is enabled). The updates to the TCD memory and the assertion of an interrupt request are shown in the following diagram.
6.4.2 Fault reporting and handling

Channel errors are reported in the Error Status register (DMAx_ES) and can be caused by:

- A configuration error, which is an illegal setting in the transfer-control descriptor or an illegal priority register setting in Fixed-Arbitration mode, or
- An error termination to a bus master read or write cycle

A configuration error is reported when the starting source or destination address, source or destination offsets, minor loop byte count, or the transfer size represent an inconsistent state. Each of these possible causes are detailed below:

- The addresses and offsets must be aligned on 0-modulo-transfer-size boundaries.
- The minor loop byte count must be a multiple of the source and destination transfer sizes.
• All source reads and destination writes must be configured to the natural boundary of the programmed transfer size respectively.
• In fixed arbitration mode, a configuration error is caused by any two channel priorities being equal. All channel priority levels must be unique when fixed arbitration mode is enabled.

**NOTE**

When two channels have the same priority, a channel priority error exists and will be reported in the Error Status register. However, the channel number will not be reported in the Error Status register. When all of the channel priorities within a group are not unique, the channel number selected by arbitration in undetermined.

To aid in Channel Priority Error (CPE) debug, set the Halt On Error bit in the DMA’s Control Register. If all of the channel priorities within a group are not unique, the DMA will be halted after the CPE error is recorded. The DMA will remain halted and will not process any channel service requests. Once all of the channel priorities are set to unique numbers, the DMA may be enabled again by clearing the Halt bit.

• If a scatter/gather operation is enabled upon channel completion, a configuration error is reported if the scatter/gather address (DLAST_SGA) is not aligned on a 32-byte boundary.
• If minor loop channel linking is enabled upon channel completion, a configuration error is reported when the link is attempted if the TCDn_CITER[E_LINK] bit does not equal the TCDn_BITER[E_LINK] bit.

If enabled, all configuration error conditions, except the scatter/gather and minor-loop link errors, report as the channel activates and asserts an error interrupt request. A scatter/gather configuration error is reported when the scatter/gather operation begins at major loop completion when properly enabled. A minor loop channel link configuration error is reported when the link operation is serviced at minor loop completion.

If a system bus read or write is terminated with an error, the data transfer is stopped and the appropriate bus error flag set. In this case, the state of the channel's transfer control descriptor is updated by the eDMA engine with the current source address, destination address, and current iteration count at the point of the fault. When a system bus error occurs, the channel terminates after the next transfer. Due to pipeline effect, the next transfer is already in progress when the bus error is received by the eDMA. If a bus error
occurs on the last read prior to beginning the write sequence, the write executes using the data captured during the bus error. If a bus error occurs on the last write prior to switching to the next read sequence, the read sequence executes before the channel terminates due to the destination bus error.

A transfer may be cancelled by software with the CR[CX] bit. When a cancel transfer request is recognized, the DMA engine stops processing the channel. The current read-write sequence is allowed to finish. If the cancel occurs on the last read-write sequence of a major or minor loop, the cancel request is discarded and the channel retires normally.

The error cancel transfer is the same as a cancel transfer except the Error Status register (DMAx_ES) is updated with the cancelled channel number and ECX is set. The TCD of a cancelled channel contains the source and destination addresses of the last transfer saved in the TCD. If the channel needs to be restarted, you must re-initialize the TCD because the aforementioned fields no longer represent the original parameters. When a transfer is cancelled by the error cancel transfer mechanism, the channel number is loaded into DMA_ES[ERRCHN] and ECX and VLD are set. In addition, an error interrupt may be generated if enabled.

NOTE

The cancel transfer request allows the user to stop a large data transfer in the event the full data transfer is no longer needed. The cancel transfer bit does not abort the channel. It simply stops the transferring of data and then retires the channel through its normal shutdown sequence. The application software must handle the context of the cancel. If an interrupt is desired (or not), then the interrupt should be enabled (or disabled) before the cancel request. The application software must clean up the transfer control descriptor since the full transfer did not occur.

The occurrence of any error causes the eDMA engine to stop normal processing of the active channel immediately (it goes to its error processing states and the transaction to the system bus still has pipeline effect), and the appropriate channel bit in the eDMA error register is asserted. At the same time, the details of the error condition are loaded into the Error Status register (DMAx_ES). The major loop complete indicators, setting the transfer control descriptor DONE flag and the possible assertion of an interrupt request, are not affected when an error is detected. After the error status has been updated, the eDMA engine continues operating by servicing the next appropriate channel. A channel that experiences an error condition is not automatically disabled. If a channel is terminated by an error and then issues another service request before the error is fixed, that channel executes and terminates with the same error condition.
6.4.3 Channel preemption

Channel preemption is enabled on a per-channel basis by setting the DCHPRIn[ECP] bit. Channel preemption allows the executing channel’s data transfers to temporarily suspend in favor of starting a higher priority channel. After the preemting channel has completed all its minor loop data transfers, the preempted channel is restored and resumes execution. After the restored channel completes one read/write sequence, it is again eligible for preemption. If any higher priority channel is requesting service, the restored channel is suspended and the higher priority channel is serviced. Nested preemption, that is, attempting to preempt a preemting channel, is not supported. After a preemting channel begins execution, it cannot be preempted. Preemption is available only when fixed arbitration is selected.

A channel’s ability to preempt another channel can be disabled by setting DCHPRIn[DPA]. When a channel’s preempt ability is disabled, that channel cannot suspend a lower priority channel’s data transfer, regardless of the lower priority channel’s ECP setting. This allows for a pool of low priority, large data-moving channels to be defined. These low priority channels can be configured to not preempt each other, thus preventing a low priority channel from consuming the preempt slot normally available to a true, high priority channel.

6.5 Initialization/application information

The following sections discuss initialization of the eDMA and programming considerations.

6.5.1 eDMA initialization

To initialize the eDMA:

1. Write to the CR if a configuration other than the default is desired.
2. Write the channel priority levels to the DCHPRIn registers if a configuration other than the default is desired.
3. Enable error interrupts in the EEI register if so desired.
4. Write the 32-byte TCD for each channel that may request service.
5. Enable any hardware service requests via the ERQ register.
6. Request channel service via either:
   • Software: setting the TCDn_CSR[START]
   • Hardware: slave device asserting its eDMA peripheral request signal

After any channel requests service, a channel is selected for execution based on the arbitration and priority levels written into the programmer's model. The eDMA engine reads the entire TCD, including the TCD control and status fields, as shown in the following table, for the selected channel into its internal address path module.

As the TCD is read, the first transfer is initiated on the internal bus, unless a configuration error is detected. Transfers from the source, as defined by TCDn_SADDR, to the destination, as defined by TCDn_DADDR, continue until the number of bytes specified by TCDn_NBYTES are transferred.

When the transfer is complete, the eDMA engine's local TCDn_SADDR, TCDn_DADDR, and TCDn_CITER are written back to the main TCD memory and any minor loop channel linking is performed, if enabled. If the major loop is exhausted, further post processing executes, such as interrupts, major loop channel linking, and scatter/gather operations, if enabled.

### Table 6-5. TCD Control and Status fields

<table>
<thead>
<tr>
<th>TCDn_CSR field name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>START</td>
<td>Control bit to start channel explicitly when using a software initiated DMA service (Automatically cleared by hardware)</td>
</tr>
<tr>
<td>ACTIVE</td>
<td>Status bit indicating the channel is currently in execution</td>
</tr>
<tr>
<td>DONE</td>
<td>Status bit indicating major loop completion (cleared by software when using a software initiated DMA service)</td>
</tr>
<tr>
<td>D_REQ</td>
<td>Control bit to disable DMA request at end of major loop completion when using a hardware initiated DMA service</td>
</tr>
<tr>
<td>BWC</td>
<td>Control bits for throttling bandwidth control of a channel</td>
</tr>
<tr>
<td>E_SG</td>
<td>Control bit to enable scatter-gather feature</td>
</tr>
<tr>
<td>INT_HALF</td>
<td>Control bit to enable interrupt when major loop is half complete</td>
</tr>
<tr>
<td>INT_MAJ</td>
<td>Control bit to enable interrupt when major loop completes</td>
</tr>
</tbody>
</table>

The following figure shows how each DMA request initiates one minor-loop transfer, or iteration, without CPU intervention. DMA arbitration can occur after each minor loop, and one level of minor loop DMA preemption is allowed. The number of minor loops in a major loop is specified by the beginning iteration count (BITER).
The following figure lists the memory array terms and how the TCD settings interrelate.

![Diagram showing memory array terms]

**Figure 6-6. Memory array terms**

### 6.5.2 Programming errors

The eDMA performs various tests on the transfer control descriptor to verify consistency in the descriptor data. Most programming errors are reported on a per channel basis with the exception of channel priority error (ES[CPE]).
For all error types other than group or channel priority errors, the channel number causing the error is recorded in the Error Status register (DMAx_ES). If the error source is not removed before the next activation of the problem channel, the error is detected and recorded again.

Channel priority errors are identified within a group once that group has been selected as the active group. For example:

1. The eDMA is configured for fixed group and fixed channel arbitration modes.
2. Group 1 is the highest priority and all channels are unique in that group.
3. Group 0 is the next highest priority and has two channels with the same priority level.
4. If Group 1 has any service requests, those requests will be executed.
5. After all of Group 1 requests have completed, Group 0 will be the next active group.
6. If Group 0 has a service request, then an undefined channel in Group 0 will be selected and a channel priority error will occur.
7. This repeats until all of Group 0 requests have been removed or a higher priority Group 1 request comes in.

In this sequence, for item 2, the eDMA acknowledge lines will assert only if the selected channel is requesting service via the eDMA peripheral request signal. If interrupts are enabled for all channels, the user will get an error interrupt, but the channel number for the ERR register and the error interrupt request line may be wrong because they reflect the selected channel. A group priority error is global and any request in any group will cause a group priority error.

If priority levels are not unique, when any channel requests service, a channel priority error is reported. The highest channel/group priority with an active request is selected, but the lowest numbered channel with that priority is selected by arbitration and executed by the eDMA engine. The hardware service request handshake signals, error interrupts, and error reporting is associated with the selected channel.

### 6.5.3 Arbitration mode considerations

This section discusses arbitration considerations for the eDMA.
6.5.3.1 Fixed group arbitration, Fixed channel arbitration

In this mode, the channel service request from the highest priority channel in the highest priority group is selected to execute. If the eDMA is programmed so that the channels within one group use "fixed" priorities, and that group is assigned the highest "fixed" priority of all groups, that group can take all the bandwidth of the eDMA controller. That is, no other groups will be serviced if there is always at least one DMA request pending on a channel in the highest priority group when the controller arbitrates the next DMA request. The advantage of this scenario is that latency can be small for channels that need to be serviced quickly. Preemption is available in this scenario only.

6.5.3.2 Fixed group arbitration, Round-robin channel arbitration

The highest priority group with a request will be serviced. Lower priority groups will be serviced if no pending requests exist in the higher priority groups.

Within each group, channels are serviced starting with the highest channel number and rotating through to the lowest channel number without regard to the channel priority levels assigned within the group.

This scenario could cause the same bandwidth consumption problem as indicated in Fixed group arbitration, Fixed channel arbitration, but all the channels in the highest priority group will be serviced. Service latency will be short on the highest priority group, but could potentially be very much longer as the group priority decreases.

6.5.4 Performing DMA transfers

This section presents examples on how to perform DMA transfers with the eDMA.

6.5.4.1 Single request

To perform a simple transfer of n bytes of data with one activation, set the major loop to one (TCDn_CITER = TCDn_BITER = 1). The data transfer begins after the channel service request is acknowledged and the channel is selected to execute. After the transfer is complete, the TCDn_CSR[DONE] bit is set and an interrupt generates if properly enabled.

For example, the following TCD entry is configured to transfer 16 bytes of data. The eDMA is programmed for one iteration of the major loop transferring 16 bytes per iteration. The source memory has a byte wide memory port located at 0x1000. The destination memory has a 32-bit port located at 0x2000. The address offsets are
programmed in increments to match the transfer size: one byte for the source and four bytes for the destination. The final source and destination addresses are adjusted to return to their beginning values.

```plaintext
TCD[n]_CITER = TCD[n]_BITER = 1
TCD[n]_NBYTES = 16
TCD[n]_SADDR = 0x1000
TCD[n]_SOFF = 1
TCD[n]_ATTR[SSIZE] = 0
TCD[n]_SLAST = -16
TCD[n]_DADDR = 0x2000
TCD[n]_DOFF = 4
TCD[n]_ATTR[DSIZE] = 2
TCD[n]_DLAST_SGA = -16
TCD[n]_CSR[INT_MAJ] = 1
TCD[n]_CSR[START] = 1 (Should be written last after all other fields have been initialized)
All other TCD[n] fields = 0
```

This generates the following event sequence:

1. User write to the TCD[n]_CSR[START] bit requests channel service.
2. The channel is selected by arbitration for servicing.
4. eDMA engine reads: channel TCD data from local memory to internal register file.
5. The source-to-destination transfers are executed as follows:
   a. Read byte from location 0x1000, read byte from location 0x1001, read byte from 0x1002, read byte from 0x1003.
   b. Write 32-bits to location 0x2000 → first iteration of the minor loop.
   c. Read byte from location 0x1004, read byte from location 0x1005, read byte from 0x1006, read byte from 0x1007.
   d. Write 32-bits to location 0x2004 → second iteration of the minor loop.
   e. Read byte from location 0x1008, read byte from location 0x1009, read byte from 0x100A, read byte from 0x100B.
   f. Write 32-bits to location 0x2008 → third iteration of the minor loop.
   g. Read byte from location 0x100C, read byte from location 0x100D, read byte from 0x100E, read byte from 0x100F.
   h. Write 32-bits to location 0x200C → last iteration of the minor loop → major loop complete.
6. The eDMA engine writes: TCDn_SADDR = 0x1000, TCDn_DADDR = 0x2000, TCDn_CITER = 1 (TCDn_BITER).


8. The channel retires and the eDMA goes idle or services the next channel.

### 6.5.4.2 Multiple requests

The following example transfers 32 bytes via two hardware requests, but is otherwise the same as the previous example. The only fields that change are the major loop iteration count and the final address offsets. The eDMA is programmed for two iterations of the major loop transferring 16 bytes per iteration. After the channel's hardware requests are enabled in the ERQ register, the slave device initiates channel service requests.

TCDn_CITER = TCDn_BITER = 2
TCDn_SLAST = -32
TCDn_DLAST_SGA = -32

This would generate the following sequence of events:

1. First hardware, that is, eDMA peripheral, request for channel service.
2. The channel is selected by arbitration for servicing.
4. eDMA engine reads: channel TCDn data from local memory to internal register file.
5. The source to destination transfers are executed as follows:
   a. Read byte from location 0x1000, read byte from location 0x1001, read byte from 0x1002, read byte from 0x1003.
   b. Write 32-bits to location 0x2000 → first iteration of the minor loop.
   c. Read byte from location 0x1004, read byte from location 0x1005, read byte from 0x1006, read byte from 0x1007.
   d. Write 32-bits to location 0x2004 → second iteration of the minor loop.
   e. Read byte from location 0x1008, read byte from location 0x1009, read byte from 0x100A, read byte from 0x100B.
   f. Write 32-bits to location 0x2008 → third iteration of the minor loop.
g. Read byte from location 0x100C, read byte from location 0x100D, read byte from 0x100E, read byte from 0x100F.

h. Write 32-bits to location 0x200C → last iteration of the minor loop.

6. eDMA engine writes: TCD\(_n\)_SADDR = 0x1010, TCD\(_n\)_DADDR = 0x2010, TCD\(_n\)_CITER = 1.

7. eDMA engine writes: TCD\(_n\)_CSR[ACTIVE] = 0.

8. The channel retires → one iteration of the major loop. The eDMA goes idle or services the next channel.

9. Second hardware, that is, eDMA peripheral, requests channel service.

10. The channel is selected by arbitration for servicing.


12. eDMA engine reads: channel TCD data from local memory to internal register file.

13. The source to destination transfers are executed as follows:
   a. Read byte from location 0x1010, read byte from location 0x1011, read byte from 0x1012, read byte from 0x1013.
   b. Write 32-bits to location 0x2010 → first iteration of the minor loop.
   c. Read byte from location 0x1014, read byte from location 0x1015, read byte from 0x1016, read byte from 0x1017.
   d. Write 32-bits to location 0x2014 → second iteration of the minor loop.
   e. Read byte from location 0x1018, read byte from location 0x1019, read byte from 0x101A, read byte from 0x101B.
   f. Write 32-bits to location 0x2018 → third iteration of the minor loop.
   g. Read byte from location 0x101C, read byte from location 0x101D, read byte from 0x101E, read byte from 0x101F.
   h. Write 32-bits to location 0x201C → last iteration of the minor loop → major loop complete.

14. eDMA engine writes: TCD\(_n\)_SADDR = 0x1000, TCD\(_n\)_DADDR = 0x2000, TCD\(_n\)_CITER = 2 (TCD\(_n\)_BITER).

16. The channel retires → major loop complete. The eDMA goes idle or services the next channel.

### 6.5.4.3 Using the modulo feature

The modulo feature of the eDMA provides the ability to implement a circular data queue in which the size of the queue is a power of 2. MOD is a 5-bit field for the source and destination in the TCD, and it specifies which lower address bits increment from their original value after the address+offset calculation. All upper address bits remain the same as in the original value. A setting of 0 for this field disables the modulo feature.

The following table shows how the transfer addresses are specified based on the setting of the MOD field. Here a circular buffer is created where the address wraps to the original value while the 28 upper address bits (0x1234567 x) retain their original value. In this example the source address is set to 0x12345670, the offset is set to 4 bytes and the MOD field is set to 4, allowing for a $2^4$ byte (16-byte) size queue.

<table>
<thead>
<tr>
<th>Transfer Number</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0x12345670</td>
</tr>
<tr>
<td>2</td>
<td>0x12345674</td>
</tr>
<tr>
<td>3</td>
<td>0x12345678</td>
</tr>
<tr>
<td>4</td>
<td>0x1234567C</td>
</tr>
<tr>
<td>5</td>
<td>0x12345670</td>
</tr>
<tr>
<td>6</td>
<td>0x12345674</td>
</tr>
</tbody>
</table>

### 6.5.5 Monitoring transfer descriptor status

This section discusses how to monitor eDMA status.

#### 6.5.5.1 Testing for minor loop completion

There are two methods to test for minor loop completion when using software initiated service requests. The first is to read the TCDn_CITER field and test for a change. Another method may be extracted from the sequence shown below. The second method is to test the TCDn_CSR[START] bit and the TCDn_CSR[ACTIVE] bit. The minor-loop-
complete condition is indicated by both bits reading zero after the TCDn_CSR[START] was set. Polling the TCDn_CSR[ACTIVE] bit may be inconclusive, because the active status may be missed if the channel execution is short in duration.

The TCD status bits execute the following sequence for a software activated channel:

<table>
<thead>
<tr>
<th>Stage</th>
<th>TCDn_CSR bits</th>
<th>State</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>START</td>
<td>ACTIVE</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>3a</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3b</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

The best method to test for minor-loop completion when using hardware, that is, peripheral, initiated service requests is to read the TCDn_CITER field and test for a change. The hardware request and acknowledge handshake signals are not visible in the programmer's model.

The TCD status bits execute the following sequence for a hardware-activated channel:

<table>
<thead>
<tr>
<th>Stage</th>
<th>TCDn_CSR bits</th>
<th>State</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>START</td>
<td>ACTIVE</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>3a</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3b</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

For both activation types, the major-loop-complete status is explicitly indicated via the TCDn_CSR[DONE] bit.

The TCDn_CSR[START] bit is cleared automatically when the channel begins execution regardless of how the channel activates.

### 6.5.5.2 Reading the transfer descriptors of active channels

The eDMA reads back the true TCDn_SADDR, TCDn_DADDR, and TCDn_NBYTES values if read while a channel executes. The true values of the SADDR, DADDR, and NBYTES are the values the eDMA engine currently uses in its internal register file and not the values in the TCD local memory for that channel. The addresses, SADDR and
DADDR, and NBYTES, which decrement to zero as the transfer progresses, can give an indication of the progress of the transfer. All other values are read back from the TCD local memory.

### 6.5.5.3 Checking channel preemption status

Preemption is available only when fixed arbitration is selected for both group and channel arbitration modes. A preemptive situation is one in which a preempt-enabled channel runs and a higher priority request becomes active. When the eDMA engine is not operating in fixed group, fixed channel arbitration mode, the determination of the actively running relative priority outstanding requests become undefined. Channel and/or group priorities are treated as equal, that is, constantly rotating, when Round-Robin Arbitration mode is selected.

The TCD\(n\)\_CSR[ACTIVE] bit for the preempted channel remains asserted throughout the preemption. The preempted channel is temporarily suspended while the preemiting channel executes one major loop iteration. If two TCD\(n\)\_CSR[ACTIVE] bits are set simultaneously in the global TCD map, a higher priority channel is actively preempting a lower priority channel.

### 6.5.6 Channel Linking

Channel linking (or chaining) is a mechanism where one channel sets the TCD\(n\)\_CSR[START] bit of another channel (or itself), therefore initiating a service request for that channel. When properly enabled, the EDMA engine automatically performs this operation at the major or minor loop completion.

The minor loop channel linking occurs at the completion of the minor loop (or one iteration of the major loop). The TCD\(n\)\_CITER[E\_LINK] field determines whether a minor loop link is requested. When enabled, the channel link is made after each iteration of the major loop except for the last. When the major loop is exhausted, only the major loop channel link fields are used to determine if a channel link should be made. For example, the initial fields of:

\[
\begin{align*}
\text{TCD}\_\text{CITER[E\_LINK]} &= 1 \\
\text{TCD}\_\text{CITER[LINKCH]} &= 0xC \\
\text{TCD}\_\text{CITER[CITER]} \text{ value} &= 0x4 \\
\text{TCD}\_\text{CSR[MAJOR_E\_LINK]} &= 1 \\
\text{TCD}\_\text{CSR[MAJOR\_LINKCH]} &= 0x7
\end{align*}
\]

executes as:

1. Minor loop done → set TCD12\_CSR[START] bit
2. Minor loop done → set TCD12_CSR[START] bit
3. Minor loop done → set TCD12_CSR[START] bit
4. Minor loop done, major loop done → set TCD7_CSR[START] bit

When minor loop linking is enabled (TCDn_CITER[E_LINK] = 1), the TCDn_CITER[CITER] field uses a nine bit vector to form the current iteration count. When minor loop linking is disabled (TCDn_CITER[E_LINK] = 0), the TCDn_CITER[CITER] field uses a 15-bit vector to form the current iteration count. The bits associated with the TCDn_CITER[LINKCH] field are concatenated onto the CITER value to increase the range of the CITER.

**Note**

The TCDn_CITER[E_LINK] bit and the TCDn_BITER[E_LINK] bit must equal or a configuration error is reported. The CITER and BITER vector widths must be equal to calculate the major loop, half-way done interrupt point.

The following table summarizes how a DMA channel can link to another DMA channel, i.e, use another channel's TCD, at the end of a loop.

**Table 6-7. Channel Linking Parameters**

<table>
<thead>
<tr>
<th>Desired Link Behavior</th>
<th>TCD Control Field Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Link at end of Minor Loop</td>
<td>CITER[E_LINK]</td>
<td>Enable channel-to-channel linking on minor loop completion (current iteration)</td>
</tr>
<tr>
<td>Link at end of Minor Loop</td>
<td>CITER[LINKCH]</td>
<td>Link channel number when linking at end of minor loop (current iteration)</td>
</tr>
<tr>
<td>Link at end of Major Loop</td>
<td>CSR[MAJOR_E_LINK]</td>
<td>Enable channel-to-channel linking on major loop completion</td>
</tr>
<tr>
<td>Link at end of Major Loop</td>
<td>CSR[MAJOR_LINKCH]</td>
<td>Link channel number when linking at end of major loop</td>
</tr>
</tbody>
</table>

### 6.5.7 Dynamic programming

This section provides recommended methods to change the programming model during channel execution.

#### 6.5.7.1 Dynamically changing the channel priority

The following two options are recommended for dynamically changing channel priority levels:
1. Switch to Round-Robin Channel Arbitration mode, change the channel priorities, then switch back to Fixed Arbitration mode,

2. Disable all the channels, change the channel priorities, then enable the appropriate channels.

6.5.7.2 Dynamic channel linking

Dynamic channel linking is the process of setting the TCDn_CSR[MAJORELINK] bit during channel execution (see the diagram in TCD structure). This bit is read from the TCD local memory at the end of channel execution, thus allowing the user to enable the feature during channel execution.

Because the user is allowed to change the configuration during execution, a coherency model is needed. Consider the scenario where the user attempts to execute a dynamic channel link by enabling the TCDn_CSR[MAJORELINK] bit at the same time the eDMA engine is retiring the channel. The TCDn_CSR[MAJORELINK] would be set in the programmer’s model, but it would be unclear whether the actual link was made before the channel retired.

The following coherency model is recommended when executing a dynamic channel link request.

1. Write 1 to the TCDn_CSR[MAJORELINK] bit.
2. Read back the TCDn_CSR[MAJORELINK] bit.
3. Test the TCDn_CSR[MAJORELINK] request status:
   - If TCDn_CSR[MAJORELINK] = 1, the dynamic link attempt was successful.
   - If TCDn_CSR[MAJORELINK] = 0, the attempted dynamic link did not succeed (the channel was already retiring).

For this request, the TCD local memory controller forces the TCDn_CSR[MAJORELINK] bit to zero on any writes to a channel’s TCD.word7 after that channel’s TCD.done bit is set, indicating the major loop is complete.

NOTE

The user must clear the TCDn_CSR[DONE] bit before writing the TCDn_CSR[MAJORELINK] bit. The TCDn_CSR[DONE] bit is cleared automatically by the eDMA engine after a channel begins execution.
6.5.7.3 Dynamic scatter/gather

Scatter/gather is the process of automatically loading a new TCD into a channel. It allows a DMA channel to use multiple TCDs; this enables a DMA channel to scatter the DMA data to multiple destinations or gather it from multiple sources. When scatter/gather is enabled and the channel has finished its major loop, a new TCD is fetched from system memory and loaded into that channel’s descriptor location in eDMA programmer’s model, thus replacing the current descriptor.

Because the user is allowed to change the configuration during execution, a coherency model is needed. Consider the scenario where the user attempts to execute a dynamic scatter/gather operation by enabling the TCDn_CSR[ESG] bit at the same time the eDMA engine is retiring the channel. The ESG bit would be set in the programmer’s model, but it would be unclear whether the actual scatter/gather request was honored before the channel retired.

Two methods for this coherency model are shown in the following subsections. Method 1 has the advantage of reading the MAJORLINKCH field and the ESG bit with a single read. For both dynamic channel linking and scatter/gather requests, the TCD local memory controller forces the TCD MAJOR.E_LINK and E_SG bits to zero on any writes to a channel’s TCD word 7 if that channel’s TCD.DONE bit is set indicating the major loop is complete.

NOTE
The user must clear the TCDn_CSR[DONE] bit before writing the MAJORELINK or ESG bits. The TCDn_CSR[DONE] bit is cleared automatically by the eDMA engine after a channel begins execution.

6.5.7.3.1 Method 1 (channel not using major loop channel linking)

For a channel not using major loop channel linking, the coherency model described here may be used for a dynamic scatter/gather request.

When the TCDn_CSR[MAJORELINK] bit is zero, the TCDn_CSR[MAJORLINKCH] field is not used by the eDMA. In this case, the MAJORLINKCH field may be used for other purposes. This method uses the MAJORLINKCH field as a TCD identification (ID).

1. When the descriptors are built, write a unique TCD ID in the TCDn_CSR[MAJORLINKCH] field for each TCD associated with a channel using dynamic scatter/gather.

2. Write 1b to the TCDn_CSR[DREQ] bit.
Should a dynamic scatter/gather attempt fail, setting the DREQ bit will prevent a future hardware activation of this channel. This stops the channel from executing with a destination address (DADDR) that was calculated using a scatter/gather address (written in the next step) instead of a dlast final offset value.

3. Write the TCDn_DLASTSGA register with the scatter/gather address.

4. Write 1b to the TCDn_CSR[ESG] bit.

5. Read back the 16 bit TCD control/status field.

6. Test the ESG request status and MAJORLINKCH value in the TCDn_CSR register:
   - If ESG = 1b, the dynamic link attempt was successful.
   - If ESG = 0b and the MAJORLINKCH (ID) did not change, the attempted dynamic link did not succeed (the channel was already retiring).
   - If ESG = 0b and the MAJORLINKCH (ID) changed, the dynamic link attempt was successful (the new TCD’s E_SG value cleared the ESG bit).

### 6.5.7.3.2 Method 2 (channel using major loop channel linking)

For a channel using major loop channel linking, the coherency model described here may be used for a dynamic scatter/gather request. This method uses the TCD.DLAST_SGA field as a TCD identification (ID).

1. Write 1b to the TCDn_CSR[DREQ] bit.
   - Should a dynamic scatter/gather attempt fail, setting the DREQ bit will prevent a future hardware activation of this channel. This stops the channel from executing with a destination address (DADDR) that was calculated using a scatter/gather address (written in the next step) instead of a dlast final offset value.

2. Write the TCDn_DLASTSGA register with the scatter/gather address.

3. Write 1b to the TCDn_CSR[ESG] bit.

4. Read back the ESG bit.

5. Test the ESG request status:
   - If ESG = 1b, the dynamic link attempt was successful.
   - If ESG = 0b, read the 32 bit TCDn_DLASTSGA field.
   - If ESG = 0b and the TCDn_DLASTSGA did not change, the attempted dynamic link did not succeed (the channel was already retiring).
If ESG = 0b and the TCDn_DLASTSGA changed, the dynamic link attempt was successful (the new TCD’s E_SG value cleared the ESG bit).

6.5.8 Suspend/resume a DMA channel with active hardware service requests

The DMA allows the user to move data from memory or peripheral registers to another location in memory or peripheral registers without CPU interaction. Once the DMA and peripherals have been configured and are active, it is rare to suspend a peripheral's service request dynamically. In this scenario, there are certain restrictions to disabling a DMA hardware service request. For coherency, a specific procedure must be followed. This section provides guidance on how to coherently suspend and resume a Direct Memory Access (DMA) channel when the DMA is triggered by a slave module such as the Serial Peripheral Interface (SPI), ADC, or other module.

6.5.8.1 Suspend an active DMA channel

To suspend an active DMA channel:
1. Stop the DMA service request at the peripheral first. Confirm it has been disabled by reading back the appropriate register in the peripheral.
2. Check the DMA's Hardware Request Status Register (DMA_HRSn) to ensure there is no service request to the DMA channel being suspended. Then disable the hardware service request by clearing the ERQ bit on appropriate DMA channel.

6.5.8.2 Resume a DMA channel

To resume a DMA channel:
1. Enable the DMA service request on the appropriate channel by setting the its ERQ bit.
2. Enable the DMA service request at the peripheral.

For example, assume the SPI is set as a master for transmitting data via a DMA service request when the SPI_TXFIFO has an empty slot. The DMA will transfer the next command and data to the TXFIFO upon the request. If the user needs to suspend the DMA/SPI transfer loop, perform the following steps:
1. Disable the DMA service request at the source by writing 0 to SPI_RSER[TFFF_RE]. Confirm that SPI_RSER[TFFF_RE] is 0.
2. Ensure there is no DMA service request from the SPI by verifying that DMA_HRS[HRS\text{n}] is 0 for the appropriate channel. If no service request is present, disable the DMA channel by clearing the channel's ERQ bit. If a service request is present, wait until the request has been processed and the HRS bit reads zero.

### 6.6 Memory map/register definition

The eDMA's programming model is partitioned into two regions:

- The first region defines a number of registers providing control functions
- The second region corresponds to the local transfer control descriptor (TCD) memory

#### 6.6.1 TCD memory

Each channel requires a 32-byte transfer control descriptor for defining the desired data movement operation. The channel descriptors are stored in the local memory in sequential order: channel 0, channel 1, ... channel 31. Each TCD\text{n} definition is presented as 11 registers of 16 or 32 bits.

#### 6.6.2 TCD initialization

Prior to activating a channel, you must initialize its TCD with the appropriate transfer profile.
6.6.3  TCD structure

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000h</td>
<td>SADDR</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0004h</td>
<td>SADDR</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SMOD</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SSIZE</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>DMOD</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>DSIZE</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SOFF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0008h</td>
<td>NBYTES</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>MLOFF or NBYTES</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>NBYTES</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>000Ch</td>
<td>SLAST</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0010h</td>
<td>DADDR</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0014h</td>
<td>CITER or</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CITER.LINKCH</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>CITER</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>DOFF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0018h</td>
<td>DLAST_SGA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>001Ch</td>
<td>BITER or</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>BITER.LINKCH</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>BITER</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>BWC</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>MAJOR.LINKCH</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Active</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Done</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Major E. Link</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>E.SS</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>D Req</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Init Half</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Init Maj</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Start</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

6.6.4  Reserved memory and bit fields

- Reading reserved bits in a register returns the value of zero.
- Writes to reserved bits in a register are ignored.
- Reading or writing a reserved memory location generates a bus error.

6.6.5  DMA register descriptions

6.6.5.1  DMA Memory map

DMA base address: 400E_8000h

Table continues on the next page...
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>4h</td>
<td>Error Status Register (ES)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>Enable Request Register (ERQ)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Enable Error Interrupt Register (EEI)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>18h</td>
<td>Clear Enable Error Interrupt Register (CEEI)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>19h</td>
<td>Set Enable Error Interrupt Register (SEEI)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>1Ah</td>
<td>Clear Enable Request Register (CERQ)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>18h</td>
<td>Set Enable Request Register (SERQ)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>1Ch</td>
<td>Clear DONE Status Bit Register (CDNE)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>1Dh</td>
<td>Set START Bit Register (SSRT)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>1Eh</td>
<td>Clear Error Register (CERR)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>1Fh</td>
<td>Clear Interrupt Request Register (CINT)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>24h</td>
<td>Interrupt Request Register (INT)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>2Ch</td>
<td>Error Register (ERR)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>34h</td>
<td>Hardware Request Status Register (HRS)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>44h</td>
<td>Enable Asynchronous Request in Stop Register (EARS)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>100h</td>
<td>Channel Priority Register (DCHPRI3)</td>
<td>8</td>
<td>RW</td>
<td>03h</td>
</tr>
<tr>
<td>101h</td>
<td>Channel Priority Register (DCHPRI2)</td>
<td>8</td>
<td>RW</td>
<td>02h</td>
</tr>
<tr>
<td>102h</td>
<td>Channel Priority Register (DCHPRI1)</td>
<td>8</td>
<td>RW</td>
<td>01h</td>
</tr>
<tr>
<td>103h</td>
<td>Channel Priority Register (DCHPRI0)</td>
<td>8</td>
<td>RW</td>
<td>00h</td>
</tr>
<tr>
<td>104h</td>
<td>Channel Priority Register (DCHPRI7)</td>
<td>8</td>
<td>RW</td>
<td>07h</td>
</tr>
<tr>
<td>105h</td>
<td>Channel Priority Register (DCHPRI6)</td>
<td>8</td>
<td>RW</td>
<td>06h</td>
</tr>
<tr>
<td>106h</td>
<td>Channel Priority Register (DCHPRI5)</td>
<td>8</td>
<td>RW</td>
<td>05h</td>
</tr>
<tr>
<td>107h</td>
<td>Channel Priority Register (DCHPRI4)</td>
<td>8</td>
<td>RW</td>
<td>04h</td>
</tr>
<tr>
<td>108h</td>
<td>Channel Priority Register (DCHPRI11)</td>
<td>8</td>
<td>RW</td>
<td>08h</td>
</tr>
<tr>
<td>109h</td>
<td>Channel Priority Register (DCHPRI10)</td>
<td>8</td>
<td>RW</td>
<td>0Ah</td>
</tr>
<tr>
<td>10Ah</td>
<td>Channel Priority Register (DCHPRI9)</td>
<td>8</td>
<td>RW</td>
<td>09h</td>
</tr>
<tr>
<td>10Bh</td>
<td>Channel Priority Register (DCHPRI8)</td>
<td>8</td>
<td>RW</td>
<td>08h</td>
</tr>
<tr>
<td>10Ch</td>
<td>Channel Priority Register (DCHPRI15)</td>
<td>8</td>
<td>RW</td>
<td>0Fh</td>
</tr>
<tr>
<td>10Dh</td>
<td>Channel Priority Register (DCHPRI14)</td>
<td>8</td>
<td>RW</td>
<td>0Eh</td>
</tr>
<tr>
<td>10 Eh</td>
<td>Channel Priority Register (DCHPRI13)</td>
<td>8</td>
<td>RW</td>
<td>0Dh</td>
</tr>
<tr>
<td>10Fh</td>
<td>Channel Priority Register (DCHPRI12)</td>
<td>8</td>
<td>RW</td>
<td>0Ch</td>
</tr>
<tr>
<td>110h</td>
<td>Channel Priority Register (DCHPRI19)</td>
<td>8</td>
<td>RW</td>
<td>13h</td>
</tr>
<tr>
<td>111h</td>
<td>Channel Priority Register (DCHPRI18)</td>
<td>8</td>
<td>RW</td>
<td>12h</td>
</tr>
<tr>
<td>112h</td>
<td>Channel Priority Register (DCHPRI17)</td>
<td>8</td>
<td>RW</td>
<td>11h</td>
</tr>
<tr>
<td>113h</td>
<td>Channel Priority Register (DCHPRI16)</td>
<td>8</td>
<td>RW</td>
<td>10h</td>
</tr>
<tr>
<td>114h</td>
<td>Channel Priority Register (DCHPRI23)</td>
<td>8</td>
<td>RW</td>
<td>17h</td>
</tr>
<tr>
<td>115h</td>
<td>Channel Priority Register (DCHPRI22)</td>
<td>8</td>
<td>RW</td>
<td>16h</td>
</tr>
<tr>
<td>116h</td>
<td>Channel Priority Register (DCHPRI21)</td>
<td>8</td>
<td>RW</td>
<td>15h</td>
</tr>
<tr>
<td>117h</td>
<td>Channel Priority Register (DCHPRI20)</td>
<td>8</td>
<td>RW</td>
<td>14h</td>
</tr>
<tr>
<td>118h</td>
<td>Channel Priority Register (DCHPRI27)</td>
<td>8</td>
<td>RW</td>
<td>1Bh</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## Offset | Register | Width (In bits) | Access | Reset value
--- | --- | --- | --- | ---
119h | Channel Priority Register (DCHPRI26) | 8 | RW | 1Ah
11Ah | Channel Priority Register (DCHPRI25) | 8 | RW | 19h
11Bh | Channel Priority Register (DCHPRI24) | 8 | RW | 18h
11Ch | Channel Priority Register (DCHPRI31) | 8 | RW | 1Fh
11Dh | Channel Priority Register (DCHPRI30) | 8 | RW | 1Eh
11Eh | Channel Priority Register (DCHPRI29) | 8 | RW | 1Dh
11Fh | Channel Priority Register (DCHPRI28) | 8 | RW | 1Ch
1000h - 13E0h | TCD Source Address (TCD0_SADDR - TCD31_SADDR) | 32 | RW | See description.
1004h - 13E4h | TCD Signed Source Address Offset (TCD0_SOFF - TCD31_SOFF) | 16 | RW | See description.
1006h - 13E6h | TCD Transfer Attributes (TCD0_ATTR - TCD31_ATTR) | 16 | RW | See description.
1008h - 13E8h | TCD Minor Byte Count (Minor Loop Mapping Disabled) (TCD0_NBYTES_MLNO - TCD31_NBYTES_MLNO) | 32 | RW | See description.
1008h - 13E8h | TCD Signed Minor Loop Offset (Minor Loop Mapping Enabled and Offset Disabled) (TCD0_NBYTES_MLOFFNO - TCD31_NBYTES_MLOFFNO) | 32 | RW | See description.
1008h - 13E8h | TCD Signed Minor Loop Offset (Minor Loop Mapping and Offset Enabled) (TCD0_NBYTES_MLOFFYES - TCD31_NBYTES_MLOFFYES) | 32 | RW | See description.
100Ch - 13ECh | TCD Last Source Address Adjustment (TCD0_SLAST - TCD31_SLAST) | 32 | RW | See description.
1010h - 13F0h | TCD Destination Address (TCD0_DADDR - TCD31_DADDR) | 32 | RW | See description.
1014h - 13F4h | TCD Signed Destination Address Offset (TCD0_DOFF - TCD31_DOFF) | 16 | RW | See description.
1016h - 13F6h | TCD Current Minor Loop Link, Major Loop Count (Channel Linking Disabled) (TCD0_CITER_ELINKNO - TCD31_CITER_ELINKNO) | 16 | RW | See description.
1016h - 13F6h | TCD Current Minor Loop Link, Major Loop Count (Channel Linking Enabled) (TCD0_CITER_ELINKYES - TCD31_CITER_ELINKYES) | 16 | RW | See description.
1018h - 13F8h | TCD Last Destination Address Adjustment/Scatter Gather Address (TCD0_DLASTSGA - TCD31_DLASTSGA) | 32 | RW | See description.
101Ch - 13FCCh | TCD Control and Status (TCD0_CSR - TCD31_CSR) | 16 | RW | See description.
101Eh - 13FEh | TCD Beginning Minor Loop Link, Major Loop Count (Channel Linking Disabled) (TCD0_BITER_ELINKNO - TCD31_BITER_ELINKNO) | 16 | RW | See description.
101Eh - 13FEh | TCD Beginning Minor Loop Link, Major Loop Count (Channel Linking Enabled) (TCD0_BITER_ELINKYES - TCD31_BITER_ELINKYES) | 16 | RW | See description.

### 6.6.5.2 Control Register (CR)
### 6.6.5.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CR</td>
<td>0h</td>
</tr>
</tbody>
</table>

### 6.6.5.2.2 Function

The CR defines the basic operating configuration of the DMA. The DMA arbitrates channel service requests in two groups of 16 channels each:

- Group 1 contains channels 31-16
- Group 0 contains channels 15-0

Arbitration within a group can be configured to use either a fixed-priority or a round-robin scheme. For fixed-priority arbitration, the highest priority channel requesting service is selected to execute. The channel priority registers assign the priorities; see the DCHPRIn registers. For round-robin arbitration, the channel priorities are ignored and channels within each group are cycled through (from high to low channel number) without regard to priority.

**NOTE**

For correct operation, writes to the CR register must be performed only when the DMA channels are inactive; that is, when TCDn_CSR[ACTIVE] bits are cleared.

The group priorities operate in a similar fashion. In group fixed priority arbitration mode, channel service requests in the highest priority group are executed first, where priority level 1 is the highest and priority level 0 is the lowest. The group priorities are assigned in the GRPnPRI fields of the DMA Control Register (CR). All group priorities must have unique values prior to any channel service requests occurring; otherwise, a configuration error will be reported. For group round robin arbitration, the group priorities are ignored and the groups are cycled through (from high to low group number) without regard to priority.

Minor loop offsets are address offset values added to the final source address (TCDn_SADDR) or destination address (TCDn_DADDR) upon minor loop completion. When minor loop offsets are enabled, the minor loop offset (MLOFF) is added to the final source address (TCDn_SADDR), to the final destination address (TCDn_DADDR), or to both prior to the addresses being written back into the TCD. If the major loop is complete, the minor loop offset is ignored and the major loop address offsets (TCDn_SLAST and TCDn_DLAST_SGA) are used to compute the next TCDn_SADDR and TCDn_DADDR values.
When minor loop mapping is enabled (EMLM is 1), TCDn word2 is redefined. A portion of TCDn word2 is used to specify multiple fields: a source enable bit (SMLOE) to specify the minor loop offset should be applied to the source address (TCDn_SADDR) upon minor loop completion, a destination enable bit (DMLOE) to specify the minor loop offset should be applied to the destination address (TCDn_DADDR) upon minor loop completion, and the sign extended minor loop offset value (MLOFF). The same offset value (MLOFF) is used for both source and destination minor loop offsets. When either minor loop offset is enabled (SMLOE set or DMLOE set), the NBYTES field is reduced to 10 bits. When both minor loop offsets are disabled (SMLOE cleared and DMLOE cleared), the NBYTES field is a 30-bit vector.

When minor loop mapping is disabled (EMLM is 0), all 32 bits of TCDn word2 are assigned to the NBYTES field.

### 6.6.5.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>ACTIVE</td>
<td>Reserved</td>
<td>0</td>
<td>CX</td>
<td>EC</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 6.6.5.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31    | DMA Active Status  
| ACTIVE| 0b - eDMA is idle.  
|       | 1b - eDMA is executing a channel. |
| 30-24 | eDMA version number  
|       | Reserved |
| 23-18 | Reserved |
| 17    | Cancel Transfer  
| CX    | 0b - Normal operation |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 16 ECX | Error Cancel Transfer  
0b - Normal operation  
1b - Cancel the remaining data transfer in the same fashion as the CX bit. Stop the executing channel and force the minor loop to finish. The cancel takes effect after the last write of the current read/write sequence. The ECX bit clears itself after the cancel is honored. In addition to cancelling the transfer, ECX treats the cancel as an error condition, thus updating the Error Status register (DMAx_ES) and generating an optional error interrupt. |
| 15-11 Reserved |
| 10 GRP1PRI | Channel Group 1 Priority  
Group 1 priority level when fixed priority group arbitration is enabled. |
| 9 Reserved |
| 8 GRP0PRI | Channel Group 0 Priority  
Group 0 priority level when fixed priority group arbitration is enabled. |
| 7 EMLM | Enable Minor Loop Mapping  
0b - Disabled. TCDn.word2 is defined as a 32-bit NBYTES field.  
1b - Enabled. TCDn.word2 is redefined to include individual enable fields, an offset field, and the NBYTES field. The individual enable fields allow the minor loop offset to be applied to the source address, the destination address, or both. The NBYTES field is reduced when either offset is enabled. |
| 6 CLM | Continuous Link Mode  
**NOTE:** Do not use continuous link mode with a channel linking to itself if there is only one minor loop iteration per service request, for example, if the channel's NBYTES value is the same as either the source or destination size. The same data transfer profile can be achieved by simply increasing the NBYTES value, which provides more efficient, faster processing.  
0b - A minor loop channel link made to itself goes through channel arbitration before being activated again.  
1b - A minor loop channel link made to itself does not go through channel arbitration before being activated again. Upon minor loop completion, the channel activates again if that channel has a minor loop channel link enabled and the link channel is itself. This effectively applies the minor loop offsets and restarts the next minor loop. |
| 5 HALT | Halt DMA Operations  
0b - Normal operation  
1b - Stall the start of any new channels. Executing channels are allowed to complete. Channel execution resumes when this bit is cleared. |
| 4 HOE | Halt On Error  
0b - Normal operation  
1b - Any error causes the HALT bit to set. Subsequently, all service requests are ignored until the HALT bit is cleared. |
| 3 ERGA | Enable Round Robin Group Arbitration  
0b - Fixed priority arbitration is used for selection among the groups.  
1b - Round robin arbitration is used for selection among the groups. |
| 2 ERCA | Enable Round Robin Channel Arbitration  
0b - Fixed priority arbitration is used for channel selection within each group.  
1b - Round robin arbitration is used for channel selection within each group. |

*Table continues on the next page...*
### 6.6.5.3 Error Status Register (ES)

#### 6.6.5.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ES</td>
<td>4h</td>
</tr>
</tbody>
</table>

#### 6.6.5.3.2 Function

The ES provides information concerning the last recorded channel error. Channel errors can be caused by:

- A configuration error, that is:
  - An illegal setting in the transfer-control descriptor, or
  - An illegal priority register setting in fixed-arbitration
- An error termination to a bus master read or write cycle
- A cancel transfer with error bit that will be set when a transfer is canceled via the corresponding cancel transfer control bit

See [Fault reporting and handling](#) for more details.
### 6.6.5.3.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>VLD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>GPE</td>
<td>CPE</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 6.6.5.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>VLD</td>
</tr>
<tr>
<td>VLD</td>
<td>Logical OR of all ERR status bits</td>
</tr>
<tr>
<td></td>
<td>0b - No ERR bits are set.</td>
</tr>
<tr>
<td></td>
<td>1b - At least one ERR bit is set indicating a valid error exists that has not been cleared.</td>
</tr>
<tr>
<td>30-17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>ECX</td>
</tr>
<tr>
<td>Transfer Canceled</td>
<td></td>
</tr>
<tr>
<td></td>
<td>0b - No canceled transfers</td>
</tr>
<tr>
<td></td>
<td>1b - The last recorded entry was a canceled transfer by the error cancel transfer input</td>
</tr>
<tr>
<td>15</td>
<td>GPE</td>
</tr>
<tr>
<td>Group Priority Error</td>
<td></td>
</tr>
<tr>
<td></td>
<td>0b - No group priority error</td>
</tr>
<tr>
<td></td>
<td>1b - The last recorded error was a configuration error among the group priorities. All group priorities are not unique.</td>
</tr>
<tr>
<td>14</td>
<td>CPE</td>
</tr>
<tr>
<td>Channel Priority Error</td>
<td></td>
</tr>
<tr>
<td></td>
<td>0b - No channel priority error</td>
</tr>
<tr>
<td></td>
<td>1b - The last recorded error was a configuration error in the channel priorities within a group. Channel priorities within a group are not unique.</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-8</td>
<td>ERRCHN</td>
</tr>
<tr>
<td>Error Channel Number or Canceled Channel Number</td>
<td></td>
</tr>
<tr>
<td></td>
<td>The channel number of the last recorded error, excluding GPE and CPE errors, or last recorded error canceled transfer.</td>
</tr>
<tr>
<td>7</td>
<td>SAE</td>
</tr>
<tr>
<td>Source Address Error</td>
<td></td>
</tr>
<tr>
<td></td>
<td>0b - No source address configuration error. TCDn_SADDR is inconsistent with TCDn_ATTR[SSIZE].</td>
</tr>
<tr>
<td></td>
<td>1b - The last recorded error was a configuration error detected in the TCDn_SADDR field. TCDn_SADDR is inconsistent with TCDn_ATTR[SSIZE].</td>
</tr>
<tr>
<td>6</td>
<td>SOE</td>
</tr>
<tr>
<td>Source Offset Error</td>
<td></td>
</tr>
<tr>
<td></td>
<td>0b - No source offset configuration error. TCDn_SOFF is inconsistent with TCDn_ATTR[SSIZE].</td>
</tr>
<tr>
<td></td>
<td>1b - The last recorded error was a configuration error detected in the TCDn_SOFF field. TCDn_SOFF is inconsistent with TCDn_ATTR[SSIZE].</td>
</tr>
<tr>
<td>5</td>
<td>Destination Address Error</td>
</tr>
</tbody>
</table>

*Table continues on the next page*
### 6.6.5.4 Enable Request Register (ERQ)

#### 6.6.5.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ERQ</td>
<td>Ch</td>
</tr>
</tbody>
</table>

#### 6.6.5.4.2 Function

The ERQ register provides a bit map for the 32 channels to enable the request signal for each channel. The state of any given channel enable is directly affected by writes to this register; it is also affected by writes to the SERQ and CERQ registers. These registers are provided so the request enable for a single channel can easily be modified without needing to perform a read-modify-write sequence to this register.
DMA request input signals and this enable request flag must be asserted before a channel's hardware service request is accepted. The state of the DMA enable request flag does not affect a channel service request made explicitly through software or a linked channel request.

**NOTE**

Disable a channel's hardware service request at the source before clearing the channel's ERQ bit.

### 6.6.5.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>ERQ31</td>
<td>ERQ30</td>
<td>ERQ29</td>
<td>ERQ28</td>
<td>ERQ27</td>
<td>ERQ26</td>
<td>ERQ25</td>
<td>ERQ24</td>
<td>ERQ23</td>
<td>ERQ22</td>
<td>ERQ21</td>
<td>ERQ20</td>
<td>ERQ19</td>
<td>ERQ18</td>
<td>ERQ17</td>
<td>ERQ16</td>
</tr>
<tr>
<td>W</td>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>ERQ15</td>
<td>ERQ14</td>
<td>ERQ13</td>
<td>ERQ12</td>
<td>ERQ11</td>
<td>ERQ10</td>
<td>ERQ9</td>
<td>ERQ8</td>
<td>ERQ7</td>
<td>ERQ6</td>
<td>ERQ5</td>
<td>ERQ4</td>
<td>ERQ3</td>
<td>ERQ2</td>
<td>ERQ1</td>
<td>ERQ0</td>
</tr>
<tr>
<td>W</td>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 6.6.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 ERQ31 | Enable DMA Request 31  
0b - The DMA request signal for the corresponding channel is disabled  
1b - The DMA request signal for the corresponding channel is enabled |
| 30 ERQ30 | Enable DMA Request 30  
0b - The DMA request signal for the corresponding channel is disabled  
1b - The DMA request signal for the corresponding channel is enabled |
| 29 ERQ29 | Enable DMA Request 29  
0b - The DMA request signal for the corresponding channel is disabled  
1b - The DMA request signal for the corresponding channel is enabled |
| 28 ERQ28 | Enable DMA Request 28  
0b - The DMA request signal for the corresponding channel is disabled  
1b - The DMA request signal for the corresponding channel is enabled |
| 27 ERQ27 | Enable DMA Request 27  
0b - The DMA request signal for the corresponding channel is disabled  
1b - The DMA request signal for the corresponding channel is enabled |
| 26 ERQ26 | Enable DMA Request 26  
0b - The DMA request signal for the corresponding channel is disabled  
1b - The DMA request signal for the corresponding channel is enabled |
| 25 ERQ25 | Enable DMA Request 25  
0b - The DMA request signal for the corresponding channel is disabled  
1b - The DMA request signal for the corresponding channel is enabled |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ERQ25</td>
<td>1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
</tbody>
</table>
| 24    | Enable DMA Request 24  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 23    | Enable DMA Request 23  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 22    | Enable DMA Request 22  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 21    | Enable DMA Request 21  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 20    | Enable DMA Request 20  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 19    | Enable DMA Request 19  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 18    | Enable DMA Request 18  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 17    | Enable DMA Request 17  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 16    | Enable DMA Request 16  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 15    | Enable DMA Request 15  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 14    | Enable DMA Request 14  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 13    | Enable DMA Request 13  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 12    | Enable DMA Request 12  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 11    | Enable DMA Request 11  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 10    | Enable DMA Request 10  
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 9     | Enable DMA Request 9   
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |
| 8     | Enable DMA Request 8   
          0b - The DMA request signal for the corresponding channel is disabled  
          1b - The DMA request signal for the corresponding channel is enabled |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ERQ8</td>
<td>0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>7 ERQ7</td>
<td>Enable DMA Request 7&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>6 ERQ6</td>
<td>Enable DMA Request 6&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>5 ERQ5</td>
<td>Enable DMA Request 5&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>4 ERQ4</td>
<td>Enable DMA Request 4&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>3 ERQ3</td>
<td>Enable DMA Request 3&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>2 ERQ2</td>
<td>Enable DMA Request 2&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>1 ERQ1</td>
<td>Enable DMA Request 1&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
<tr>
<td>0 ERQ0</td>
<td>Enable DMA Request 0&lt;br&gt;0b - The DMA request signal for the corresponding channel is disabled&lt;br&gt;1b - The DMA request signal for the corresponding channel is enabled</td>
</tr>
</tbody>
</table>

### 6.6.5.5 Enable Error Interrupt Register (EEI)

#### 6.6.5.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>EEI</td>
<td>14h</td>
</tr>
</tbody>
</table>

#### 6.6.5.5.2 Function

The EEI register provides a bit map for the 32 channels to enable the error interrupt signal for each channel. The state of any given channel's error interrupt enable is directly affected by writes to this register; it is also affected by writes to the SEEI and CEEI. These registers are provided so that the error interrupt enable for a single channel can easily be modified without the need to perform a read-modify-write sequence to the EEI register.
The DMA error indicator and the error interrupt enable flag must be asserted before an error interrupt request for a given channel is asserted to the interrupt controller.

### 6.6.5.5.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>EEI31</td>
<td>EEI30</td>
<td>EEI29</td>
<td>EEI28</td>
<td>EEI27</td>
<td>EEI26</td>
<td>EEI25</td>
<td>EEI24</td>
<td>EEI23</td>
<td>EEI22</td>
<td>EEI21</td>
<td>EEI20</td>
<td>EEI19</td>
<td>EEI18</td>
<td>EEI17</td>
<td>EEI16</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>EEI15</td>
<td>EEI14</td>
<td>EEI13</td>
<td>EEI12</td>
<td>EEI11</td>
<td>EEI10</td>
<td>EEI9</td>
<td>EEI8</td>
<td>EEI7</td>
<td>EEI6</td>
<td>EEI5</td>
<td>EEI4</td>
<td>EEI3</td>
<td>EEI2</td>
<td>EEI1</td>
<td>EEI0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 6.6.5.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 EEI31 | Enable Error Interrupt 31  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt |
| 30 EEI30 | Enable Error Interrupt 30  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 29 EEI29 | Enable Error Interrupt 29  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 28 EEI28 | Enable Error Interrupt 28  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 27 EEI27 | Enable Error Interrupt 27  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 26 EEI26 | Enable Error Interrupt 26  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 25 EEI25 | Enable Error Interrupt 25  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 24 EEI24 | Enable Error Interrupt 24  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 23 EEI23 | Enable Error Interrupt 23  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 22 EEI22 | Enable Error Interrupt 22  
0b - The error signal for corresponding channel does not generate an error interrupt  
1b - The assertion of the error signal for corresponding channel generates an error interrupt request |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| EEI22  | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| 21     | Enable Error Interrupt 21  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI20  | Enable Error Interrupt 20  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI19  | Enable Error Interrupt 19  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI18  | Enable Error Interrupt 18  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI17  | Enable Error Interrupt 17  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI16  | Enable Error Interrupt 16  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI15  | Enable Error Interrupt 15  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI14  | Enable Error Interrupt 14  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI13  | Enable Error Interrupt 13  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI12  | Enable Error Interrupt 12  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI11  | Enable Error Interrupt 11  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI10  | Enable Error Interrupt 10  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI9   | Enable Error Interrupt 9  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI8   | Enable Error Interrupt 8  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI7   | Enable Error Interrupt 7  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |
| EEI6   | Enable Error Interrupt 6  
|        | 0b - The error signal for corresponding channel does not generate an error interrupt  
|        | 1b - The assertion of the error signal for corresponding channel generates an error interrupt request |

_table continues on the next page..._
### 6.6.5.6 Clear Enable Error Interrupt Register (CEEI)

#### 6.6.5.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CEEI</td>
<td>18h</td>
</tr>
</tbody>
</table>

#### 6.6.5.6.2 Function

The CEEI provides a simple memory-mapped mechanism to clear a given bit in the EEI to disable the error interrupt for a given channel. The data value on a register write causes the corresponding bit in the EEI to be cleared. Setting the CAEE bit provides a global clear function, forcing the EEI contents to be cleared, disabling all DMA request inputs.

If the NOP bit is set, the command is ignored. This allows you to set a single, byte-wide register with a 32-bit write while not affecting the other registers addressed in the write. In such a case the other three bytes of the word would all have their NOP bit set so that these register will not be affected by the write.

Reads of this register return all zeroes.
6.6.5.6.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>NOP</td>
<td>CAE</td>
<td>0</td>
<td>CEE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

6.6.5.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 7 NOP | No Op enable  
0b - Normal operation  
1b - No operation, ignore the other bits in this register |
| 6 CAEE | Clear All Enable Error Interrupts  
0b - Clear only the EEI bit specified in the CEEI field  
1b - Clear all bits in EEI |
| 5 Reserved |
| 4-0 CEEI | Clear Enable Error Interrupt  
Clears the corresponding bit in EEI |

6.6.5.7 Set Enable Error Interrupt Register (SEEI)

6.6.5.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEEI</td>
<td>19h</td>
</tr>
</tbody>
</table>

6.6.5.7.2 Function

The SEEI provides a simple memory-mapped mechanism to set a given bit in the EEI to enable the error interrupt for a given channel. The data value on a register write causes the corresponding bit in the EEI to be set. Setting the SAEE bit provides a global set function, forcing the entire EEI contents to be set.
If the NOP bit is set, the command is ignored. This allows you to set a single, byte-wide register with a 32-bit write while not affecting the other registers addressed in the write. In such a case the other three bytes of the word would all have their NOP bit set so that that these register will not be affected by the write.

Reads of this register return all zeroes.

### 6.6.5.7.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>NOP</td>
<td>SAE</td>
<td>E</td>
<td>0</td>
<td>SE</td>
<td>EI</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

|   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### 6.6.5.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 7 NOP | No Op enable  
|       | 0b - Normal operation  
|       | 1b - No operation, ignore the other bits in this register |
| 6 SAE | Sets All Enable Error Interrupts  
|       | 0b - Set only the EEI bit specified in the SEEI field.  
|       | 1b - Sets all bits in EEI |
| 5     | Reserved |
| 4-0 SEEI | Set Enable Error Interrupt  
|       | Sets the corresponding bit in EEI |

### 6.6.5.8 Clear Enable Request Register (CERQ)

#### 6.6.5.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CERQ</td>
<td>1Ah</td>
</tr>
</tbody>
</table>
6.6.5.8.2  Function

The CERQ provides a simple memory-mapped mechanism to clear a given bit in the ERQ to disable the DMA request for a given channel. The data value on a register write causes the corresponding bit in the ERQ to be cleared. Setting the CAER bit provides a global clear function, forcing the entire contents of the ERQ to be cleared, disabling all DMA request inputs.

If the NOP bit is set, the command is ignored. This allows you to set a single, byte-wide register with a 32-bit write while not affecting the other registers addressed in the write. In such a case the other three bytes of the word would all have their NOP bit set so that that these register will not be affected by the write.

Reads of this register return all zeroes.

NOTE
Disable a channel's hardware service request at the source before clearing the channel's ERQ bit.

6.6.5.8.3  Diagram

6.6.5.8.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 7 NOP | No Op enable  
       | 0b - Normal operation  
       | 1b - No operation, ignore the other bits in this register |
| 6 CAER | Clear All Enable Requests  
        | 0b - Clear only the ERQ bit specified in the CERQ field  
        | 1b - Clear all bits in ERQ |
| 5 — | Reserved |
| 4-0 CERQ | Clear Enable Request  
           | Clears the corresponding bit in ERQ. |
6.6.5.9 Set Enable Request Register (SERQ)

6.6.5.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SERQ</td>
<td>1Bh</td>
</tr>
</tbody>
</table>

6.6.5.9.2 Function

The SERQ provides a simple memory-mapped mechanism to set a given bit in the ERQ to enable the DMA request for a given channel. The data value on a register write causes the corresponding bit in the ERQ to be set. Setting the SAER bit provides a global set function, forcing the entire contents of ERQ to be set.

If the NOP bit is set, the command is ignored. This allows you to set a single, byte-wide register with a 32-bit write while not affecting the other registers addressed in the write. In such a case the other three bytes of the word would all have their NOP bit set so that these register will not be affected by the write.

Reads of this register return all zeroes.

6.6.5.9.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>NOP</td>
<td>SAE</td>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0

6.6.5.9.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 NOP</td>
<td>No Op enable</td>
</tr>
<tr>
<td></td>
<td>0b - Normal operation</td>
</tr>
<tr>
<td></td>
<td>1b - No operation, ignore the other bits in this register</td>
</tr>
<tr>
<td>6 SAER</td>
<td>Set All Enable Requests</td>
</tr>
<tr>
<td></td>
<td>0b - Set only the ERQ bit specified in the SERQ field</td>
</tr>
<tr>
<td></td>
<td>1b - Set all bits in ERQ</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>4-0</td>
<td>Set Enable Request</td>
</tr>
<tr>
<td>SERQ</td>
<td>Sets the corresponding bit in ERQ.</td>
</tr>
</tbody>
</table>

### 6.6.5.10 Clear DONE Status Bit Register (CDNE)

#### 6.6.5.10.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDNE</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

#### 6.6.5.10.2 Function

The CDNE provides a simple memory-mapped mechanism to clear the DONE bit in the TCD of the given channel. The data value on a register write causes the DONE bit in the corresponding transfer control descriptor to be cleared. Setting the CADN bit provides a global clear function, forcing all DONE bits to be cleared.

If the NOP bit is set, the command is ignored. This allows you to set a single, byte-wide register with a 32-bit write while not affecting the other registers addressed in the write. In such a case the other three bytes of the word would all have their NOP bit set so that that these register will not be affected by the write.

Reads of this register return all zeroes.

#### 6.6.5.10.3 Diagram

![Diagram of CDNE register]

#### 6.6.5.10.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>No Op enable</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
6.6.5.11 Set START Bit Register (SSRT)

6.6.5.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSRT</td>
<td>1Dh</td>
</tr>
</tbody>
</table>

6.6.5.11.2 Function

The SSRT provides a simple memory-mapped mechanism to set the START bit in the TCD of the given channel. The data value on a register write causes the START bit in the corresponding transfer control descriptor to be set. Setting the SAST bit provides a global set function, forcing all START bits to be set.

If the NOP bit is set, the command is ignored. This allows you to set a single, byte-wide register with a 32-bit write while not affecting the other registers addressed in the write. In such a case the other three bytes of the word would all have their NOP bit set so that these register will not be affected by the write.

Reads of this register return all zeroes.

6.6.5.11.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>NOP</td>
<td>SAS</td>
<td>T</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>SSRT</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```
6.6.5.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 7 NOP | No Op enable  
|       | 0b - Normal operation  
|       | 1b - No operation, ignore the other bits in this register |
| 6 SAST | Set All START Bits (activates all channels)  
|       | 0b - Set only the TCDn_CSR[START] bit specified in the SSRT field  
|       | 1b - Set all bits in TCDn_CSR[START] |
| 5 | Reserved |
| 4-0 SSRT | Set START Bit |
|          | Sets the corresponding bit in TCDn_CSR[START] |

6.6.5.12 Clear Error Register (CERR)

6.6.5.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CERR</td>
<td>1Eh</td>
</tr>
</tbody>
</table>

6.6.5.12.2 Function

The CERR provides a simple memory-mapped mechanism to clear a given bit in the ERR to disable the error condition flag for a given channel. The given value on a register write causes the corresponding bit in the ERR to be cleared. Setting the CAEI bit provides a global clear function, forcing the ERR contents to be cleared, clearing all channel error indicators. If the NOP bit is set, the command is ignored. This allows you to write multiple-byte registers as a 32-bit word. Reads of this register return all zeroes.

6.6.5.12.3 Diagram

```
+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+  
|        | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |        |        |        |
+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+  
| R      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |        |        |        |
| W      | NOP    | CAEI   | 0      | CER    | R      |        |        |        |        |        |        |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |        |        |        |
```
6.6.5.12.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>NOP</td>
</tr>
<tr>
<td>NOP</td>
<td>No Op enable</td>
</tr>
<tr>
<td></td>
<td>0b - Normal operation</td>
</tr>
<tr>
<td></td>
<td>1b - No operation, ignore the other bits in this register</td>
</tr>
<tr>
<td>6</td>
<td>CAEI</td>
</tr>
<tr>
<td>CAEI</td>
<td>Clear All Error Indicators</td>
</tr>
<tr>
<td></td>
<td>0b - Clear only the ERR bit specified in the CERR field</td>
</tr>
<tr>
<td></td>
<td>1b - Clear all bits in ERR</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-0</td>
<td>CERR</td>
</tr>
<tr>
<td>CERR</td>
<td>Clear Error Indicator</td>
</tr>
<tr>
<td></td>
<td>Clears the corresponding bit in ERR</td>
</tr>
</tbody>
</table>

6.6.5.13  Clear Interrupt Request Register (CINT)

6.6.5.13.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CINT</td>
<td>1Fh</td>
</tr>
</tbody>
</table>

6.6.5.13.2  Function

The CINT provides a simple, memory-mapped mechanism to clear a given bit in the INT to disable the interrupt request for a given channel. The given value on a register write causes the corresponding bit in the INT to be cleared. Setting the CAIR bit provides a global clear function, forcing the entire contents of the INT to be cleared, disabling all DMA interrupt requests.

If the NOP bit is set, the command is ignored. This allows you to set a single, byte-wide register with a 32-bit write while not affecting the other registers addressed in the write. In such a case the other three bytes of the word would all have their NOP bit set so that these register will not be affected by the write.

Reads of this register return all zeroes.
6.6.5.13.3 Diagram

Bits

<table>
<thead>
<tr>
<th></th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

6.6.5.13.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 7 NOP | No Op enable  
|       | 0b - Normal operation  
|       | 1b - No operation, ignore the other bits in this register |
| 6 CAIR | Clear All Interrupt Requests  
|        | 0b - Clear only the INT bit specified in the CINT field  
|        | 1b - Clear all bits in INT |
| 5 —  | Reserved |
| 4-0 CINT | Clear Interrupt Request  
|         | Clears the corresponding bit in INT |

6.6.5.14 Interrupt Request Register (INT)

6.6.5.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT</td>
<td>24h</td>
</tr>
</tbody>
</table>

6.6.5.14.2 Function

The INT register provides a bit map for the 32 channels signaling the presence of an interrupt request for each channel. Depending on the appropriate bit setting in the transfer-control descriptors, the eDMA engine generates an interrupt on data transfer completion. The outputs of this register are directly routed to the interrupt controller. During the interrupt-service routine associated with any given channel, it is the software's responsibility to clear the appropriate bit, negating the interrupt request. Typically, a write to the CINT register in the interrupt service routine is used for this purpose.
The state of any given channel's interrupt request is directly affected by writes to this register; it is also affected by writes to the CINT register. On writes to INT, a 1 in any bit position clears the corresponding channel's interrupt request. A zero in any bit position has no affect on the corresponding channel's current interrupt status. The CINT register is provided so the interrupt request for a single channel can easily be cleared without the need to perform a read-modify-write sequence to the INT register.

### 6.6.5.14.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>INT31</td>
<td>INT30</td>
<td>INT29</td>
<td>INT28</td>
<td>INT27</td>
<td>INT26</td>
<td>INT25</td>
<td>INT24</td>
<td>INT23</td>
<td>INT22</td>
<td>INT21</td>
<td>INT20</td>
<td>INT19</td>
<td>INT18</td>
<td>INT17</td>
<td>INT16</td>
</tr>
<tr>
<td>W</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>INT15</td>
<td>INT14</td>
<td>INT13</td>
<td>INT12</td>
<td>INT11</td>
<td>INT10</td>
<td>INT9</td>
<td>INT8</td>
<td>INT7</td>
<td>INT6</td>
<td>INT5</td>
<td>INT4</td>
<td>INT3</td>
<td>INT2</td>
<td>INT1</td>
<td>INT0</td>
</tr>
<tr>
<td>W</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
<td>WIC</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 6.6.5.14.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 INT31 | Interrupt Request 31  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 30 INT30 | Interrupt Request 30  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 29 INT29 | Interrupt Request 29  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 28 INT28 | Interrupt Request 28  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 27 INT27 | Interrupt Request 27  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 26 INT26 | Interrupt Request 26  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 25 INT25 | Interrupt Request 25  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 24 INT24 | Interrupt Request 24  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 23 INT23 | Interrupt Request 23  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 22 INT22 | Interrupt Request 22  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 21 INT21 | Interrupt Request 21  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 20 INT20 | Interrupt Request 20  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 19 INT19 | Interrupt Request 19  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 18 INT18 | Interrupt Request 18  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 17 INT17 | Interrupt Request 17  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 16 INT16 | Interrupt Request 16  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 15 INT15 | Interrupt Request 15  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 14 INT14 | Interrupt Request 14  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 13 INT13 | Interrupt Request 13  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 12 INT12 | Interrupt Request 12  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 11 INT11 | Interrupt Request 11  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 10 INT10 | Interrupt Request 10  
0b - The interrupt request for corresponding channel is cleared  
1b - The interrupt request for corresponding channel is active |
| 9 INT9 | Interrupt Request 9  
0b - The interrupt request for corresponding channel is cleared |

Table continues on the next page...
### 6.6.5.15 Error Register (ERR)

#### 6.6.5.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ERR</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

#### 6.6.5.15.2 Function

The ERR register provides a bit map for the 32 channels, signaling the presence of an error for each channel. The eDMA engine signals the occurrence of an error condition by setting the appropriate bit in this register. The outputs of this register are enabled by the contents of the EEI register, then logically summed across groups of 16 and 32 channels to form several group error interrupt requests, which are then routed to the interrupt.
controller. During the execution of the interrupt-service routine associated with any DMA errors, it is software's responsibility to clear the appropriate bit, negating the error-interrupt request. Typically, a write to the CERR in the interrupt-service routine is used for this purpose. The normal DMA channel completion indicators (setting the transfer control descriptor DONE flag and the possible assertion of an interrupt request) are not affected when an error is detected.

The contents of this register can also be polled because a non-zero value indicates the presence of a channel error regardless of the state of the EEI fields. The state of any given channel's error indicators is affected by writes to this register; it is also affected by writes to the CERR. On writes to the ERR, a one in any bit position clears the corresponding channel's error status. A zero in any bit position has no affect on the corresponding channel's current error status. The CERR is provided so the error indicator for a single channel can easily be cleared.

### 6.6.5.15.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>ERR3</td>
<td>ERR3</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
<td>ERR2</td>
</tr>
<tr>
<td>W</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
<td>ERR1</td>
</tr>
<tr>
<td>W</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 6.6.5.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>ERR31</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 31</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>30</td>
<td>ERR30</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 30</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>29</td>
<td>Error In Channel 29</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ERR29</td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>28</td>
<td>ERR28</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 28</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>27</td>
<td>ERR27</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 27</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>26</td>
<td>ERR26</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 26</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>25</td>
<td>ERR25</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 25</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>24</td>
<td>ERR24</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 24</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>23</td>
<td>ERR23</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 23</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>22</td>
<td>ERR22</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 22</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>21</td>
<td>ERR21</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 21</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>20</td>
<td>ERR20</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 20</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>19</td>
<td>ERR19</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 19</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>18</td>
<td>ERR18</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 18</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>17</td>
<td>ERR17</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 17</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>16</td>
<td>ERR16</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 16</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>15</td>
<td>ERR15</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 15</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>14</td>
<td>ERR14</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 14</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>13</td>
<td>ERR13</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 13</td>
</tr>
<tr>
<td></td>
<td>0b - An error in this channel has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>12</td>
<td>ERR12</td>
</tr>
<tr>
<td></td>
<td>Error In Channel 12</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ERR12</td>
<td>0b - An error in this channel has not occurred । 1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>11</td>
<td>Error In Channel 11 । 0b - An error in this channel has not occurred । 1b - An error in this channel has occurred</td>
</tr>
<tr>
<td>ERR11</td>
<td>10</td>
</tr>
<tr>
<td>9</td>
<td>ERR9</td>
</tr>
<tr>
<td>8</td>
<td>ERR8</td>
</tr>
<tr>
<td>7</td>
<td>ERR7</td>
</tr>
<tr>
<td>6</td>
<td>ERR6</td>
</tr>
<tr>
<td>5</td>
<td>ERR5</td>
</tr>
<tr>
<td>4</td>
<td>ERR4</td>
</tr>
<tr>
<td>3</td>
<td>ERR3</td>
</tr>
<tr>
<td>2</td>
<td>ERR2</td>
</tr>
<tr>
<td>1</td>
<td>ERR1</td>
</tr>
<tr>
<td>0</td>
<td>ERR0</td>
</tr>
</tbody>
</table>

### 6.6.5.16 Hardware Request Status Register (HRS)

#### 6.6.5.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HRS</td>
<td>34h</td>
</tr>
</tbody>
</table>
6.6.5.16.2 Function

The HRS register provides a bit map for the DMA channels, signaling the presence of a hardware request for each channel. The hardware request status bits reflect the current state of the register and qualified (via the ERQ fields) DMA request signals as seen by the DMA's arbitration logic. This view into the hardware request signals may be used for debug purposes.

**NOTE**

These bits reflect the state of the request as seen by the arbitration logic. Therefore, this status is affected by the ERQ bits.

6.6.5.16.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>HRS31</td>
<td>HRS30</td>
<td>HRS29</td>
<td>HRS28</td>
<td>HRS27</td>
<td>HRS26</td>
<td>HRS25</td>
<td>HRS24</td>
<td>HRS23</td>
<td>HRS22</td>
<td>HRS21</td>
<td>HRS20</td>
<td>HRS19</td>
<td>HRS18</td>
<td>HRS17</td>
<td>HRS16</td>
</tr>
<tr>
<td>W</td>
<td><img src="image" alt="Diagram" /></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### Table continues on the next page...

6.6.5.16.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 HRS31 | Hardware Request Status Channel 31  
|       | The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
|       | 0b - A hardware service request for channel 31 is not present  
|       | 1b - A hardware service request for channel 31 is present |
| 30 HRS30 | Hardware Request Status Channel 30  
|       | The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
|       | 0b - A hardware service request for channel 30 is not present  
|       | 1b - A hardware service request for channel 30 is present |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| **29** | Hardware Request Status Channel 29  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 29 is not present  
1b - A hardware service request for channel 29 is present |
| **28** | Hardware Request Status Channel 28  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 28 is not present  
1b - A hardware service request for channel 28 is present |
| **27** | Hardware Request Status Channel 27  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 27 is not present  
1b - A hardware service request for channel 27 is present |
| **26** | Hardware Request Status Channel 26  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 26 is not present  
1b - A hardware service request for channel 26 is present |
| **25** | Hardware Request Status Channel 25  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 25 is not present  
1b - A hardware service request for channel 25 is present |
| **24** | Hardware Request Status Channel 24  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 24 is not present  
1b - A hardware service request for channel 24 is present |
| **23** | Hardware Request Status Channel 23  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 23 is not present  
1b - A hardware service request for channel 23 is present |
| **22** | Hardware Request Status Channel 22  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 22 is not present  
1b - A hardware service request for channel 22 is present |
| **21** | Hardware Request Status Channel 21  
Table continues on the next page... |
## Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| HRS21 | The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 21 is not present  
1b - A hardware service request for channel 21 is present |
| HRS20 | Hardware Request Status Channel 20  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 20 is not present  
1b - A hardware service request for channel 20 is present |
| HRS19 | Hardware Request Status Channel 19  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 19 is not present  
1b - A hardware service request for channel 19 is present |
| HRS18 | Hardware Request Status Channel 18  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 18 is not present  
1b - A hardware service request for channel 18 is present |
| HRS17 | Hardware Request Status Channel 17  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 17 is not present  
1b - A hardware service request for channel 17 is present |
| HRS16 | Hardware Request Status Channel 16  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 16 is not present  
1b - A hardware service request for channel 16 is present |
| HRS15 | Hardware Request Status Channel 15  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 15 is not present  
1b - A hardware service request for channel 15 is present |
| HRS14 | Hardware Request Status Channel 14  
The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.  
0b - A hardware service request for channel 14 is not present  
1b - A hardware service request for channel 14 is present |
| HRS13 | Hardware Request Status Channel 13  
Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.</td>
</tr>
<tr>
<td>12</td>
<td>Hardware Request Status Channel 12</td>
</tr>
<tr>
<td>HRS12</td>
<td>0b - A hardware service request for channel 13 is not present</td>
</tr>
<tr>
<td></td>
<td>1b - A hardware service request for channel 13 is present</td>
</tr>
<tr>
<td>11</td>
<td>Hardware Request Status Channel 11</td>
</tr>
<tr>
<td>HRS11</td>
<td>0b - A hardware service request for channel 12 is not present</td>
</tr>
<tr>
<td></td>
<td>1b - A hardware service request for channel 12 is present</td>
</tr>
<tr>
<td>10</td>
<td>Hardware Request Status Channel 10</td>
</tr>
<tr>
<td>HRS10</td>
<td>0b - A hardware service request for channel 11 is not present</td>
</tr>
<tr>
<td></td>
<td>1b - A hardware service request for channel 11 is present</td>
</tr>
<tr>
<td>9</td>
<td>Hardware Request Status Channel 9</td>
</tr>
<tr>
<td>HRS9</td>
<td>0b - A hardware service request for channel 10 is not present</td>
</tr>
<tr>
<td></td>
<td>1b - A hardware service request for channel 10 is present</td>
</tr>
<tr>
<td>8</td>
<td>Hardware Request Status Channel 8</td>
</tr>
<tr>
<td>HRS8</td>
<td>0b - A hardware service request for channel 9 is not present</td>
</tr>
<tr>
<td></td>
<td>1b - A hardware service request for channel 9 is present</td>
</tr>
<tr>
<td>7</td>
<td>Hardware Request Status Channel 7</td>
</tr>
<tr>
<td>HRS7</td>
<td>0b - A hardware service request for channel 8 is not present</td>
</tr>
<tr>
<td></td>
<td>1b - A hardware service request for channel 8 is present</td>
</tr>
<tr>
<td>6</td>
<td>Hardware Request Status Channel 6</td>
</tr>
<tr>
<td>HRS6</td>
<td>0b - A hardware service request for channel 7 is not present</td>
</tr>
<tr>
<td></td>
<td>1b - A hardware service request for channel 7 is present</td>
</tr>
<tr>
<td>5</td>
<td>Hardware Request Status Channel 5</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>Hardware Request Status Channel 4</td>
</tr>
<tr>
<td>3</td>
<td>Hardware Request Status Channel 3</td>
</tr>
<tr>
<td>2</td>
<td>Hardware Request Status Channel 2</td>
</tr>
<tr>
<td>1</td>
<td>Hardware Request Status Channel 1</td>
</tr>
<tr>
<td>0</td>
<td>Hardware Request Status Channel 0</td>
</tr>
</tbody>
</table>

The HRS bit for its respective channel remains asserted for the period when a Hardware Request is Present on the Channel. After the Request is completed and Channel is free, the HRS bit is automatically cleared by hardware.

- 0b - A hardware service request for channel 5 is not present
- 1b - A hardware service request for channel 5 is present

- 0b - A hardware service request for channel 4 is not present
- 1b - A hardware service request for channel 4 is present

- 0b - A hardware service request for channel 3 is not present
- 1b - A hardware service request for channel 3 is present

- 0b - A hardware service request for channel 2 is not present
- 1b - A hardware service request for channel 2 is present

- 0b - A hardware service request for channel 1 is not present
- 1b - A hardware service request for channel 1 is present

- 0b - A hardware service request for channel 0 is not present
- 1b - A hardware service request for channel 0 is present

### 6.6.5.17 Enable Asynchronous Request in Stop Register (EARS)

#### 6.6.5.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>EARS</td>
<td>44h</td>
</tr>
</tbody>
</table>
6.6.5.17.2 Function
The EARS register is used to enable or disable the DMA requests in Enable Request Register (ERQ) by AND'ing the bits of these two registers.

6.6.5.17.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

6.6.5.17.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 EDREQ_31 | Enable asynchronous DMA request in stop mode for channel 31  
0b - Disable asynchronous DMA request for channel 31  
1b - Enable asynchronous DMA request for channel 31 |
| 30 EDREQ_30 | Enable asynchronous DMA request in stop mode for channel 30  
0b - Disable asynchronous DMA request for channel 30  
1b - Enable asynchronous DMA request for channel 30 |
| 29 EDREQ_29 | Enable asynchronous DMA request in stop mode for channel 29  
0b - Disable asynchronous DMA request for channel 29  
1b - Enable asynchronous DMA request for channel 29 |
| 28 EDREQ_28 | Enable asynchronous DMA request in stop mode for channel 28  
0b - Disable asynchronous DMA request for channel 28  
1b - Enable asynchronous DMA request for channel 28 |
| 27 EDREQ_27 | Enable asynchronous DMA request in stop mode for channel 27  
0b - Disable asynchronous DMA request for channel 27  
1b - Enable asynchronous DMA request for channel 27 |
| 26 EDREQ_26 | Enable asynchronous DMA request in stop mode for channel 26  
0b - Disable asynchronous DMA request for channel 26  
1b - Enable asynchronous DMA request for channel 26 |
| 25 EDREQ_25 | Enable asynchronous DMA request in stop mode for channel 25  
0b - Disable asynchronous DMA request for channel 25  
1b - Enable asynchronous DMA request for channel 25 |
| 24 EDREQ_24 | Enable asynchronous DMA request in stop mode for channel 24  
0b - Disable asynchronous DMA request for channel 24 |
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>EDREQ_24</td>
<td>1b - Enable asynchronous DMA request for channel 24</td>
</tr>
<tr>
<td>23</td>
<td>Enable asynchronous DMA request in stop mode for channel 23</td>
</tr>
<tr>
<td>EDREQ_23</td>
<td>0b - Disable asynchronous DMA request for channel 23</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 23</td>
</tr>
<tr>
<td>22</td>
<td>Enable asynchronous DMA request in stop mode for channel 22</td>
</tr>
<tr>
<td>EDREQ_22</td>
<td>0b - Disable asynchronous DMA request for channel 22</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 22</td>
</tr>
<tr>
<td>21</td>
<td>Enable asynchronous DMA request in stop mode for channel 21</td>
</tr>
<tr>
<td>EDREQ_21</td>
<td>0b - Disable asynchronous DMA request for channel 21</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 21</td>
</tr>
<tr>
<td>20</td>
<td>Enable asynchronous DMA request in stop mode for channel 20</td>
</tr>
<tr>
<td>EDREQ_20</td>
<td>0b - Disable asynchronous DMA request for channel 20</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 20</td>
</tr>
<tr>
<td>19</td>
<td>Enable asynchronous DMA request in stop mode for channel 19</td>
</tr>
<tr>
<td>EDREQ_19</td>
<td>0b - Disable asynchronous DMA request for channel 19</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 19</td>
</tr>
<tr>
<td>18</td>
<td>Enable asynchronous DMA request in stop mode for channel 18</td>
</tr>
<tr>
<td>EDREQ_18</td>
<td>0b - Disable asynchronous DMA request for channel 18</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 18</td>
</tr>
<tr>
<td>17</td>
<td>Enable asynchronous DMA request in stop mode for channel 17</td>
</tr>
<tr>
<td>EDREQ_17</td>
<td>0b - Disable asynchronous DMA request for channel 17</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 17</td>
</tr>
<tr>
<td>16</td>
<td>Enable asynchronous DMA request in stop mode for channel 16</td>
</tr>
<tr>
<td>EDREQ_16</td>
<td>0b - Disable asynchronous DMA request for channel 16</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 16</td>
</tr>
<tr>
<td>15</td>
<td>Enable asynchronous DMA request in stop mode for channel 15</td>
</tr>
<tr>
<td>EDREQ_15</td>
<td>0b - Disable asynchronous DMA request for channel 15.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 15.</td>
</tr>
<tr>
<td>14</td>
<td>Enable asynchronous DMA request in stop mode for channel 14</td>
</tr>
<tr>
<td>EDREQ_14</td>
<td>0b - Disable asynchronous DMA request for channel 14.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 14.</td>
</tr>
<tr>
<td>13</td>
<td>Enable asynchronous DMA request in stop mode for channel 13</td>
</tr>
<tr>
<td>EDREQ_13</td>
<td>0b - Disable asynchronous DMA request for channel 13.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 13.</td>
</tr>
<tr>
<td>12</td>
<td>Enable asynchronous DMA request in stop mode for channel 12</td>
</tr>
<tr>
<td>EDREQ_12</td>
<td>0b - Disable asynchronous DMA request for channel 12.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 12.</td>
</tr>
<tr>
<td>11</td>
<td>Enable asynchronous DMA request in stop mode for channel 11</td>
</tr>
<tr>
<td>EDREQ_11</td>
<td>0b - Disable asynchronous DMA request for channel 11.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 11.</td>
</tr>
<tr>
<td>10</td>
<td>Enable asynchronous DMA request in stop mode for channel 10</td>
</tr>
<tr>
<td>EDREQ_10</td>
<td>0b - Disable asynchronous DMA request for channel 10.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 10.</td>
</tr>
<tr>
<td>9</td>
<td>Enable asynchronous DMA request in stop mode for channel 9</td>
</tr>
<tr>
<td>EDREQ_9</td>
<td>0b - Disable asynchronous DMA request for channel 9.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 9.</td>
</tr>
<tr>
<td>8</td>
<td>Enable asynchronous DMA request in stop mode for channel 8</td>
</tr>
<tr>
<td>EDREQ_8</td>
<td>0b - Disable asynchronous DMA request for channel 8.</td>
</tr>
<tr>
<td></td>
<td>1b - Enable asynchronous DMA request for channel 8.</td>
</tr>
<tr>
<td>7</td>
<td>Enable asynchronous DMA request in stop mode for channel 7</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>EDREQ_7</td>
<td>0b - Disable asynchronous DMA request for channel 7. 1b - Enable asynchronous DMA request for channel 7.</td>
</tr>
<tr>
<td>EDREQ_6</td>
<td>Enable asynchronous DMA request in stop mode for channel 6 0b - Disable asynchronous DMA request for channel 6. 1b - Enable asynchronous DMA request for channel 6.</td>
</tr>
<tr>
<td>EDREQ_5</td>
<td>Enable asynchronous DMA request in stop mode for channel 5 0b - Disable asynchronous DMA request for channel 5. 1b - Enable asynchronous DMA request for channel 5.</td>
</tr>
<tr>
<td>EDREQ_4</td>
<td>Enable asynchronous DMA request in stop mode for channel 4 0b - Disable asynchronous DMA request for channel 4. 1b - Enable asynchronous DMA request for channel 4.</td>
</tr>
<tr>
<td>EDREQ_3</td>
<td>Enable asynchronous DMA request in stop mode for channel 3. 0b - Disable asynchronous DMA request for channel 3. 1b - Enable asynchronous DMA request for channel 3.</td>
</tr>
<tr>
<td>EDREQ_2</td>
<td>Enable asynchronous DMA request in stop mode for channel 2. 0b - Disable asynchronous DMA request for channel 2. 1b - Enable asynchronous DMA request for channel 2.</td>
</tr>
<tr>
<td>EDREQ_1</td>
<td>Enable asynchronous DMA request in stop mode for channel 1. 0b - Disable asynchronous DMA request for channel 1. 1b - Enable asynchronous DMA request for channel 1.</td>
</tr>
<tr>
<td>EDREQ_0</td>
<td>Enable asynchronous DMA request in stop mode for channel 0. 0b - Disable asynchronous DMA request for channel 0. 1b - Enable asynchronous DMA request for channel 0.</td>
</tr>
</tbody>
</table>

### 6.6.5.18 Channel Priority Register (DCHPRI0 - DCHPRI31)

#### 6.6.5.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DCHPRI3</td>
<td>100h</td>
</tr>
<tr>
<td>DCHPRI2</td>
<td>101h</td>
</tr>
<tr>
<td>DCHPRI1</td>
<td>102h</td>
</tr>
<tr>
<td>DCHPRI0</td>
<td>103h</td>
</tr>
<tr>
<td>DCHPRI7</td>
<td>104h</td>
</tr>
<tr>
<td>DCHPRI6</td>
<td>105h</td>
</tr>
<tr>
<td>DCHPRI5</td>
<td>106h</td>
</tr>
<tr>
<td>DCHPRI4</td>
<td>107h</td>
</tr>
<tr>
<td>DCHPRI11</td>
<td>108h</td>
</tr>
<tr>
<td>DCHPRI10</td>
<td>109h</td>
</tr>
<tr>
<td>DCHPRI9</td>
<td>10Ah</td>
</tr>
<tr>
<td>DCHPRI8</td>
<td>10Bh</td>
</tr>
<tr>
<td>DCHPRI15</td>
<td>10Ch</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 6.6.5.18.2 Function

When fixed-priority channel arbitration is enabled (CR[ERCA] = 0), the contents of these registers define the unique priorities associated with each channel within a group. The channel priorities are evaluated by numeric value; for example, 0 is the lowest priority, 1 is the next higher priority, then 2, 3, etc. Software must program the channel priorities with unique values; otherwise, a configuration error is reported. The range of the priority value is limited to the values of 0 through 15. When read, the GRPPRI bits of the DCHPRIIn register reflect the current priority level of the group of channels in which the corresponding channel resides. GRPPRI bits are not affected by writes to the DCHPRIIn registers. The group priority is assigned in the DMA control register.

### 6.6.5.18.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>ECP</td>
<td>DPA</td>
<td>GRPPRI</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>See Register reset values.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
NXP Semiconductors
### 6.6.5.18.4 Register reset values

<table>
<thead>
<tr>
<th>Register</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>DCHPRI0</td>
<td>00h</td>
</tr>
<tr>
<td>DCHPRI1</td>
<td>01h</td>
</tr>
<tr>
<td>DCHPRI2</td>
<td>02h</td>
</tr>
<tr>
<td>DCHPRI3</td>
<td>03h</td>
</tr>
<tr>
<td>DCHPRI4</td>
<td>04h</td>
</tr>
<tr>
<td>DCHPRI5</td>
<td>05h</td>
</tr>
<tr>
<td>DCHPRI6</td>
<td>06h</td>
</tr>
<tr>
<td>DCHPRI7</td>
<td>07h</td>
</tr>
<tr>
<td>DCHPRI8</td>
<td>08h</td>
</tr>
<tr>
<td>DCHPRI9</td>
<td>09h</td>
</tr>
<tr>
<td>DCHPRI10</td>
<td>0Ah</td>
</tr>
<tr>
<td>DCHPRI11</td>
<td>0Bh</td>
</tr>
<tr>
<td>DCHPRI12</td>
<td>0Ch</td>
</tr>
<tr>
<td>DCHPRI13</td>
<td>0Dh</td>
</tr>
<tr>
<td>DCHPRI14</td>
<td>0Eh</td>
</tr>
<tr>
<td>DCHPRI15</td>
<td>0Fh</td>
</tr>
<tr>
<td>DCHPRI16</td>
<td>10h</td>
</tr>
<tr>
<td>DCHPRI17</td>
<td>11h</td>
</tr>
<tr>
<td>DCHPRI18</td>
<td>12h</td>
</tr>
<tr>
<td>DCHPRI19</td>
<td>13h</td>
</tr>
<tr>
<td>DCHPRI20</td>
<td>14h</td>
</tr>
<tr>
<td>DCHPRI21</td>
<td>15h</td>
</tr>
<tr>
<td>DCHPRI22</td>
<td>16h</td>
</tr>
<tr>
<td>DCHPRI23</td>
<td>17h</td>
</tr>
<tr>
<td>DCHPRI24</td>
<td>18h</td>
</tr>
<tr>
<td>DCHPRI25</td>
<td>19h</td>
</tr>
<tr>
<td>DCHPRI26</td>
<td>1Ah</td>
</tr>
<tr>
<td>DCHPRI27</td>
<td>1Bh</td>
</tr>
<tr>
<td>DCHPRI28</td>
<td>1Ch</td>
</tr>
<tr>
<td>DCHPRI29</td>
<td>1Dh</td>
</tr>
<tr>
<td>DCHPRI30</td>
<td>1Eh</td>
</tr>
<tr>
<td>DCHPRI31</td>
<td>1Fh</td>
</tr>
</tbody>
</table>
6.6.5.18.5 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 7 ECP | Enable Channel Preemption. This field resets to 0.  
0b - Channel n cannot be suspended by a higher priority channel's service request.  
1b - Channel n can be temporarily suspended by the service request of a higher priority channel. |
| 6 DPA | Disable Preempt Ability. This field resets to 0.  
0b - Channel n can suspend a lower priority channel.  
1b - Channel n cannot suspend any channel, regardless of channel priority. |
| 5-4 GRPPRI | Channel n Current Group Priority  
Group priority assigned to this channel group when fixed-priority arbitration is enabled. This field is read-only; writes are ignored. |
| 3-0 CHPRI | Channel n Arbitration Priority  
Channel priority when fixed-priority arbitration is enabled |

6.6.5.19 TCD Source Address (TCD0_SADDR - TCD31_SADDR)

6.6.5.19.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_SADDR</td>
<td>1000h + (n × 20h)</td>
</tr>
</tbody>
</table>

6.6.5.19.2 Function

This register contains the source address of the transfer.

6.6.5.19.3 Diagram

```
  Bits  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16  
  R  W  SADDR
  Reset u  u  u  u  u  u  u  u  u  u  u  u  u  u  u

  Bits  15  14  13  12  11  10  9  8 |  7  6  5  4  3  2  1  0  
  R  W  SADDR
  Reset u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  
```
6.6.5.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Source Address</td>
</tr>
<tr>
<td>SADDR</td>
<td>Memory address pointing to the source data.</td>
</tr>
</tbody>
</table>

6.6.5.20 TCD Signed Source Address Offset (TCD0_SOFF - TCD31_SOFF)

6.6.5.20.1 Offset

For \( n = 0 \) to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_SOFF</td>
<td>( 1004h + (n \times 20h) )</td>
</tr>
</tbody>
</table>

6.6.5.20.2 Diagram

![Diagram showing bits 15 to 0 with SOFF highlighted.]

6.6.5.20.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Source address signed offset</td>
</tr>
<tr>
<td>SOFF</td>
<td>Sign-extended offset applied to the current source address to form the next-state value as each source read is completed.</td>
</tr>
</tbody>
</table>

6.6.5.21 TCD Transfer Attributes (TCD0_ATTR - TCD31_ATTR)
6.6.5.21.1 Offset

For \( n = 0 \) to \( 31 \):

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_ATTR</td>
<td>( 1006h + (n \times 20h) )</td>
</tr>
</tbody>
</table>

6.6.5.21.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-11</td>
<td>SMOD</td>
</tr>
<tr>
<td>10-8</td>
<td>SSIZE</td>
</tr>
<tr>
<td>7-3</td>
<td>DMOD</td>
</tr>
<tr>
<td>2-0</td>
<td>DSIZE</td>
</tr>
</tbody>
</table>

SMOD: Source Address Modulo

- 00000b - Source address modulo feature is disabled
- 00001-11111b - This value defines a specific address range specified to be the value after \( \text{SADDR} + \text{SOFF} \) calculation is performed on the original register value. Setting this field provides the ability to implement a circular data queue easily. For data queues requiring power-of-2 size bytes, the queue should start at a 0-modulo-size address and the SMOD field should be set to the appropriate value for the queue, freezing the desired number of upper address bits. The value programmed into this field specifies the number of lower address bits allowed to change. For a circular queue application, the SOFF is typically set to the transfer size to implement post-increment addressing with the SMOD function constraining the addresses to a 0-modulo-size range.

SSIZE: Source data transfer size

- **NOTE:** Using a Reserved value causes a configuration error.
- **NOTE:** The eDMA defaults to privileged data access for all transactions.

- 000b - 8-bit
- 001b - 16-bit
- 010b - 32-bit
- 011b - 64-bit
- 100b - Reserved
- 101b - 32-byte burst (4 beats of 64 bits)
- 110b - Reserved
- 111b - Reserved

DMOD: Destination Address Modulo

See the SMOD definition

DSIZE: Destination data transfer size

See the SSIZE definition
6.6.5.22 TCD Minor Byte Count (Minor Loop Mapping Disabled)  
(TCD0_NBYTES_MLNO - TCD31_NBYTES_MLNO)

6.6.5.22.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_NBYTES_MLNO</td>
<td>1008h + (n x 20h)</td>
</tr>
</tbody>
</table>

6.6.5.22.2 Function

This register, or one of the next two registers (TCD_NBYTES_MLOFFNO, TCD_NBYTES_MLOFFYES), defines the number of bytes to transfer per request. Which register to use depends on whether minor loop mapping is disabled, enabled but not used for this channel, or enabled and used.

TCD word 2 is defined as follows if:
- Minor loop mapping is disabled ([EMLM] = 0)

If minor loop mapping is enabled, see the TCD_NBYTES_MLOFFNO and TCD_NBYTES_MLOFFYES register descriptions for the definition of TCD word 2.

6.6.5.22.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u u u u u u u u u u u u u u u u</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u u u u u u u u u u u u u u u u</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

6.6.5.22.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Minor Byte Transfer Count</td>
</tr>
<tr>
<td>NBYTES</td>
<td></td>
</tr>
</tbody>
</table>
Field | Function
---|---
Number of bytes to be transferred in each service request of the channel. As a channel activates, the appropriate TCD contents load into the eDMA engine, and the appropriate reads and writes perform until the minor byte transfer count has transferred. This is an indivisible operation and cannot be halted. It can, however, be stalled by using the bandwidth control field, or via preemption. After the minor count is exhausted, the SADDR and DADDR values are written back into the TCD memory, the major iteration count is decremented and restored to the TCD memory. If the major iteration count is completed, additional processing is performed.

**NOTE:** An NBYTES value of 0x0000_0000 is interpreted as a 4 GB transfer.

### 6.6.5.23 TCD Signed Minor Loop Offset (Minor Loop Mapping Enabled and Offset Disabled) (TCD0_NBYTES_MLOFFNO - TCD31_NBYTES_MLOFFNO)

#### 6.6.5.23.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_NBYTES_MLOFFNO</td>
<td>1008h + (n × 20h)</td>
</tr>
</tbody>
</table>

#### 6.6.5.23.2 Function

One of three registers (this register, TCD_NBYTES_MLNO, or TCD_NBYTES_MLOFFYES), defines the number of bytes to transfer per request. Which register to use depends on whether minor loop mapping is disabled, enabled but not used for this channel, or enabled and used.

TCD word 2 is defined as follows if:

- Minor loop mapping is enabled (CR[EMLM] = 1) and
- SMLOE = 0 and DMLOE = 0

If minor loop mapping is enabled and SMLOE or DMLOE is set, then refer to the TCD_NBYTES_MLOFFYES register description. If minor loop mapping is disabled, then refer to the TCD_NBYTES_MLNO register description.
6.6.5.23.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>SMLOE</td>
<td>DMLOE</td>
<td>NBYTES</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>
```

6.6.5.23.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>SMLOE</td>
</tr>
<tr>
<td>30</td>
<td>DMLOE</td>
</tr>
<tr>
<td>29-0</td>
<td>NBYTES</td>
</tr>
</tbody>
</table>

- **SMLOE (Source Minor Loop Offset Enable)**
  - Selects whether the minor loop offset is applied to the source address upon minor loop completion.
  - 0b - The minor loop offset is not applied to the SADDR
  - 1b - The minor loop offset is applied to the SADDR

- **DMLOE (Destination Minor Loop Offset enable)**
  - Selects whether the minor loop offset is applied to the destination address upon minor loop completion.
  - 0b - The minor loop offset is not applied to the DADDR
  - 1b - The minor loop offset is applied to the DADDR

- **NBYTES (Minor Byte Transfer Count)**
  - Number of bytes to be transferred in each service request of the channel.
  - As a channel activates, the appropriate TCD contents load into the eDMA engine, and the appropriate reads and writes perform until the minor byte transfer count has transferred. This is an indivisible operation and cannot be halted. It can, however, be stalled by using the bandwidth control field, or via preemption. After the minor count is exhausted, the SADDR and DADDR values are written back into the TCD memory, the major iteration count is decremented and restored to the TCD memory. If the major iteration count is completed, additional processing is performed.

6.6.5.24  TCD Signed Minor Loop Offset (Minor Loop Mapping and Offset Enabled) (TCD0_NBYTES_MLOFFYES - TCD31_NBYTES_MLOFFYES)

6.6.5.24.1  Offset

For n = 0 to 31:
6.6.5.24.2 Function

One of three registers (this register, TCD_NBYTES_MLNO, or TCD_NBYTES_MLOFFNO), defines the number of bytes to transfer per request. Which register to use depends on whether minor loop mapping is disabled, enabled but not used for this channel, or enabled and used.

TCD word 2 is defined as follows if:

- Minor loop mapping is enabled (CR[EMLM] = 1) and
- Minor loop offset is enabled (SMLOE or DMLOE = 1)

If minor loop mapping is enabled and SMLOE and DMLOE are cleared, then refer to the TCD_NBYTES_MLOFFNO register description. If minor loop mapping is disabled, then refer to the TCD_NBYTES_MLNO register description.

6.6.5.24.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>SMLOE</td>
<td>DMLOE</td>
<td>MLOFF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>MLOFF</td>
<td>NBYTES</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

6.6.5.24.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>SMLOE</td>
</tr>
<tr>
<td>30</td>
<td>Destination Minor Loop Offset enable</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMLOE</td>
<td>Selects whether the minor loop offset is applied to the destination address upon minor loop completion.</td>
</tr>
<tr>
<td></td>
<td>0b - The minor loop offset is not applied to the DADDR</td>
</tr>
<tr>
<td></td>
<td>1b - The minor loop offset is applied to the DADDR</td>
</tr>
<tr>
<td>29-10 MLOFF</td>
<td>If SMLOE or DMLOE is set, this field represents a sign-extended offset applied to the source or destination address to form the next-state value after the minor loop completes.</td>
</tr>
<tr>
<td>9-0 NBYTES</td>
<td>Minor Byte Transfer Count</td>
</tr>
<tr>
<td></td>
<td>Number of bytes to be transferred in each service request of the channel.</td>
</tr>
<tr>
<td></td>
<td>As a channel activates, the appropriate TCD contents load into the eDMA engine, and the appropriate reads and writes perform until the minor byte transfer count has transferred. This is an indivisible operation and cannot be halted. It can, however, be stalled by using the bandwidth control field, or via preemption. After the minor count is exhausted, the SADDR and DADDR values are written back into the TCD memory, the major iteration count is decremented and restored to the TCD memory. If the major iteration count is completed, additional processing is performed.</td>
</tr>
</tbody>
</table>

6.6.5.25  TCD Last Source Address Adjustment (TCD0_SLAST - TCD3_1_SLAST)

6.6.5.25.1  Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_SLAST</td>
<td>100Ch + (n × 20h)</td>
</tr>
</tbody>
</table>

6.6.5.25.2  Diagram

```
R  W
-----
SLAST

Reset
u  u  u  u  u  u  u  u  u  u  u  u  u  u  u

R  W
-----
SLAST

Reset
u  u  u  u  u  u  u  u  u  u  u  u  u  u  u
```
6.6.5.25.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Last Source Address Adjustment</td>
</tr>
<tr>
<td>SLAST</td>
<td>Adjustment value added to the source address at the completion of the major iteration count. This value can be applied to restore the source address to the initial value, or adjust the address to reference the next data structure. This register uses two's complement notation; the overflow bit is discarded.</td>
</tr>
</tbody>
</table>

6.6.5.26 TCD Destination Address (TCD0_DADDR - TCD31_DADDR)

6.6.5.26.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_DADDR</td>
<td>1010h + (n × 20h)</td>
</tr>
</tbody>
</table>

6.6.5.26.2 Function

This register contains the destination address of the transfer.

6.6.5.26.3 Diagram

6.6.5.26.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Destination Address</td>
</tr>
<tr>
<td>Field</td>
<td>Function</td>
</tr>
<tr>
<td>--------</td>
<td>-----------------------------------------------</td>
</tr>
<tr>
<td>DADDR</td>
<td>Memory address pointing to the destination data.</td>
</tr>
</tbody>
</table>

6.6.5.27  TCD Signed Destination Address Offset (TCD0_DOFF - TCD31_DOFF)

6.6.5.27.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_DOFF</td>
<td>1014h + (n × 20h)</td>
</tr>
</tbody>
</table>

6.6.5.27.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

6.6.5.27.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Destination Address Signed Offset</td>
</tr>
<tr>
<td>DOFF</td>
<td>Sign-extended offset applied to the current destination address to form the next-state value as each destination write is completed.</td>
</tr>
</tbody>
</table>

6.6.5.28  TCD Current Minor Loop Link, Major Loop Count (Channel Linking Disabled) (TCD0_CITER_ELINKNO - TCD31_CITER_ELINKNO)

6.6.5.28.1 Offset

For n = 0 to 31:
### 6.6.5.28.2 Function

This register contains the minor-loop channel-linking configuration and the channel's current iteration count. It is the same register as TCD Current Minor Loop Link, Major Loop Count (Channel Linking Enabled) (TCD0_CITER_ELINKYES - TCD31_CITER_ELINKYES), but its fields are defined differently based on the state of the ELINK field. If the ELINK field is cleared, this register is defined as follows.

### 6.6.5.28.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>ELINK</td>
<td>CITER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td></td>
</tr>
</tbody>
</table>
```

### 6.6.5.28.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 ELINK</td>
<td>Enable channel-to-channel linking on minor-loop complete</td>
</tr>
<tr>
<td></td>
<td>As the channel completes the minor loop, this flag enables linking to another channel, defined by the LINKCH field. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] bit of the specified channel.</td>
</tr>
<tr>
<td></td>
<td>If channel linking is disabled, the CITER value is extended to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJORELINK channel linking.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> This bit must be equal to the BITER[ELINK] bit; otherwise, a configuration error is reported.</td>
</tr>
<tr>
<td></td>
<td>0b - The channel-to-channel linking is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - The channel-to-channel linking is enabled</td>
</tr>
<tr>
<td>14-0 CITER</td>
<td>Current Major Iteration Count</td>
</tr>
<tr>
<td></td>
<td>This field is the current major loop count for the channel. It is decremented each time the minor loop is completed and updated in the transfer control descriptor memory. After the major iteration count is exhausted, the channel performs a number of operations, for example, final source and destination address calculations, optionally generating an interrupt to signal channel completion before reloading the CITER field from the Beginning Iteration Count (BITER) field.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> When the CITER field is initially loaded by software, it must be set to the same value as that contained in the BITER field.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> If the channel is configured to execute a single service request, the initial values of BITER and CITER should be 0x0001.</td>
</tr>
</tbody>
</table>
6.6.5.29 TCD Current Minor Loop Link, Major Loop Count (Channel Linking Enabled) (TCD0_CITER_ELINKYES - TCD31_CITER_ELINKYES)

6.6.5.29.1 Offset
For \( n = 0 \) to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_CITER_ELINKYES</td>
<td>( 1016h + (n \times 20h) )</td>
</tr>
</tbody>
</table>

6.6.5.29.2 Function
This register contains the minor-loop channel-linking configuration and the channel's current iteration count. It is the same register as TCD Current Minor Loop Link, Major Loop Count (Channel Linking Disabled) (TCD0_CITER_ELINKNO - TCD31_CITER_ELINKNO), but its fields are defined differently based on the state of the ELINK field. If the ELINK field is set, this register is defined as follows.

6.6.5.29.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
<tr>
<td>W</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>0</td>
<td>LINKCH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CITER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

6.6.5.29.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Enable channel-to-channel linking on minor-loop complete</td>
</tr>
</tbody>
</table>
| ELINK | As the channel completes the minor loop, this flag enables linking to another channel, defined by the LINKCH field. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] bit of the specified channel.  
  If channel linking is disabled, the CITER value is extended to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJORELINK channel linking.  
  **NOTE:** This bit must be equal to the BITER[ELINK] bit; otherwise, a configuration error is reported. |

Table continues on the next page...
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13-9</td>
<td>Minor Loop Link Channel Number</td>
</tr>
</tbody>
</table>

If channel-to-channel linking is enabled (ELINK = 1), then after the minor loop is exhausted, the eDMA engine initiates a channel service request to the channel defined by this field by setting that channel's TCDn_CSR[START] bit.

**8-0 CITER**

Current Major Iteration Count

This field is the current major loop count for the channel. It is decremented each time the minor loop is completed and updated in the transfer control descriptor memory. After the major iteration count is exhausted, the channel performs a number of operations, for example, final source and destination address calculations, optionally generating an interrupt to signal channel completion before reloading the CITER field from the Beginning Iteration Count (BITER) field.

**NOTE:** When the CITER field is initially loaded by software, it must be set to the same value as that contained in the BITER field.

**NOTE:** If the channel is configured to execute a single service request, the initial values of BITER and CITER should be 0x0001.

---

### 6.6.5.30 TCD Last Destination Address Adjustment/Scatter Gather Address (TCD0_DLASTSGA - TCD31_DLASTSGA)

#### 6.6.5.30.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_DLASTSGA</td>
<td>1018h + (n × 20h)</td>
</tr>
</tbody>
</table>

#### 6.6.5.30.2 Diagram

```
 Bits 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
R     W
Reset u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u

DLASTSGA
```

```
 Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     W
Reset u  u  u  u  u  u  u  u  u  u  u  u  u  u  u  u

DLASTSGA
```
6.6.5.30.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>DLASTSGA</td>
</tr>
</tbody>
</table>

DLASTSGA
Destination last address adjustment or the memory address for the next transfer control descriptor to be loaded into this channel (scatter/gather).

If (TCDn_CSR[ESG] = 0) then:
- Adjustment value added to the destination address at the completion of the major iteration count. This value can apply to restore the destination address to the initial value or adjust the address to reference the next data structure.
- This field uses two's complement notation for the final destination address adjustment.

Otherwise:
- This address points to the beginning of a 0-modulo-32-byte region containing the next transfer control descriptor to be loaded into this channel. This channel reload is performed as the major iteration count completes. The scatter/gather address must be 0-modulo-32-byte, otherwise a configuration error is reported.

6.6.5.31 TCD Control and Status (TCD0_CSR - TCD31_CSR)

6.6.5.31.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_CSR</td>
<td>101Ch + (n × 20h)</td>
</tr>
</tbody>
</table>

6.6.5.31.2 Diagram

![Diagram of TCD Control and Status Register](image-url)
### Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-14</td>
<td>Bandwidth Control</td>
</tr>
<tr>
<td>BWC</td>
<td>Throttles the amount of bus bandwidth consumed by the eDMA. Generally, as the eDMA processes the minor loop, it continuously generates read/write sequences until the minor count is exhausted. This field forces the eDMA to stall after the completion of each read/write access to control the bus request bandwidth seen by the crossbar switch.</td>
</tr>
<tr>
<td>NOTE: If the source and destination sizes are equal, this field is ignored between the first and second transfers and after the last write of each minor loop. This behavior is a side effect of reducing start-up latency.</td>
<td></td>
</tr>
<tr>
<td>00b - No eDMA engine stalls.</td>
<td></td>
</tr>
<tr>
<td>01b - Reserved</td>
<td></td>
</tr>
<tr>
<td>10b - eDMA engine stalls for 4 cycles after each R/W.</td>
<td></td>
</tr>
<tr>
<td>11b - eDMA engine stalls for 8 cycles after each R/W.</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-8</td>
<td>Major Loop Link Channel Number</td>
</tr>
<tr>
<td>MAJORELINKCH</td>
<td>If (MAJORELINK = 0) then:</td>
</tr>
<tr>
<td></td>
<td>• No channel-to-channel linking, or chaining, is performed after the major loop counter is exhausted.</td>
</tr>
<tr>
<td>Otherwise:</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• After the major loop counter is exhausted, the eDMA engine initiates a channel service request at the channel defined by this field by setting that channel's TCDn_CSR[START] bit.</td>
</tr>
<tr>
<td>7</td>
<td>Channel Done</td>
</tr>
<tr>
<td>DONE</td>
<td>This flag indicates the eDMA has completed the major loop. The eDMA engine sets it as the CITER count reaches zero. The software clears it, or the hardware when the channel is activated.</td>
</tr>
<tr>
<td>NOTE: This bit must be cleared to write the MAJORELINK or ESG bits.</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Channel Active</td>
</tr>
<tr>
<td>ACTIVE</td>
<td>This flag signals the channel is currently in execution. It is set when channel service begins, and is cleared by the eDMA as the minor loop completes or when any error condition is detected.</td>
</tr>
<tr>
<td>5</td>
<td>Enable channel-to-channel linking on major loop complete</td>
</tr>
<tr>
<td>MAJORELINK</td>
<td>As the channel completes the major loop, this flag enables the linking to another channel, defined by MAJORELINKCH. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] bit of the specified channel.</td>
</tr>
<tr>
<td>NOTE: To support the dynamic linking coherency model, this field is forced to zero when written to while the TCDn_CSR[DONE] bit is set.</td>
<td></td>
</tr>
<tr>
<td>0b - The channel-to-channel linking is disabled.</td>
<td></td>
</tr>
<tr>
<td>1b - The channel-to-channel linking is enabled.</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>Enable Scatter/Gather Processing</td>
</tr>
<tr>
<td>ESG</td>
<td>As the channel completes the major loop, this flag enables scatter/gather processing in the current channel. If enabled, the eDMA engine uses DLASTSGA as a memory pointer to a 0-modulo-32 address containing a 32-byte data structure loaded as the transfer control descriptor into the local memory.</td>
</tr>
<tr>
<td>NOTE: To support the dynamic scatter/gather coherency model, this field is forced to zero when written to while the TCDn_CSR[DONE] bit is set.</td>
<td></td>
</tr>
<tr>
<td>0b - The current channel's TCD is normal format.</td>
<td></td>
</tr>
<tr>
<td>1b - The current channel's TCD specifies a scatter gather format. The DLASTSGA field provides a memory pointer to the next TCD to be loaded into this channel after the major loop completes its execution.</td>
<td></td>
</tr>
</tbody>
</table>
### Field Function

<table>
<thead>
<tr>
<th>3</th>
<th>Disable Request</th>
</tr>
</thead>
<tbody>
<tr>
<td>DREQ</td>
<td>If this flag is set, the eDMA hardware automatically clears the corresponding ERQ bit when the current major iteration count reaches zero.</td>
</tr>
<tr>
<td></td>
<td>0b - The channel’s ERQ bit is not affected.</td>
</tr>
<tr>
<td></td>
<td>1b - The channel’s ERQ bit is cleared when the major loop is complete.</td>
</tr>
</tbody>
</table>

| 2  | Enable an interrupt when major counter is half complete. |
| INTHALF | If this flag is set, the channel generates an interrupt request by setting the appropriate bit in the INT register when the current major iteration count reaches the halfway point. Specifically, the comparison performed by the eDMA engine is (CITER == (BITER >> 1)). This halfway point interrupt request is provided to support double-buffered, also known as ping-pong, schemes or other types of data movement where the processor needs an early indication of the transfer’s progress. |
|     | NOTE: If BITER = 1, do not use INTHALF. Use INTMAJOR instead. |
|     | 0b - The half-point interrupt is disabled. |
|     | 1b - The half-point interrupt is enabled. |

| 1  | Enable an interrupt when major iteration count completes. |
| INTMAJOR | If this flag is set, the channel generates an interrupt request by setting the appropriate bit in the INT when the current major iteration count reaches zero. |
|     | 0b - The end-of-major loop interrupt is disabled. |
|     | 1b - The end-of-major loop interrupt is enabled. |

| 0  | Channel Start |
| START | If this flag is set, the channel is requesting service. The eDMA hardware automatically clears this flag after the channel begins execution. |
|     | 0b - The channel is not explicitly started. |
|     | 1b - The channel is explicitly started via a software initiated service request. |

### 6.6.5.32 TCD Beginning Minor Loop Link, Major Loop Count (Channel Linking Disabled) (TCD0_BITER_ELINKNO - TCD31_BITER_ELINKNO)

#### 6.6.5.32.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_BITER_ELINKNO</td>
<td>101Eh + (n × 20h)</td>
</tr>
</tbody>
</table>

#### 6.6.5.32.2 Function

If the TCDn_BITER[ELINK] bit is cleared, the TCDn_BITER register is defined as follows.
### 6.6.5.32.3 Diagram

#### Bits

<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>ELINK</td>
<td>BITER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

| u | u | u | u | u | u | u | u | u | u | u | u | u | u | u | u |

### 6.6.5.32.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 ELINK</td>
<td>Enables channel-to-channel linking on minor loop complete</td>
</tr>
<tr>
<td></td>
<td>As the channel completes the minor loop, this flag enables the linking to another channel, defined by BITER[LINKCH]. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] bit of the specified channel. If channel linking is disabled, the BITER value extends to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJORELINK channel linking.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, the contents of this field are reloaded into the CITER field.</td>
</tr>
<tr>
<td>14-0 BITER</td>
<td>Starting Major Iteration Count</td>
</tr>
<tr>
<td></td>
<td>As the transfer control descriptor is first loaded by software, this 9-bit (ELINK = 1) or 15-bit (ELINK = 0) field must be equal to the value in the CITER field. As the major iteration count is exhausted, the contents of this field are reloaded into the CITER field.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, the contents of this field is reloaded into the CITER field. If the channel is configured to execute a single service request, the initial values of BITER and CITER should be 0x0001.</td>
</tr>
</tbody>
</table>

### 6.6.5.33 TCD Beginning Minor Loop Link, Major Loop Count (Channel Linking Enabled) (TCD0_BITER_ELINKYES - TCD31_BITER_ELINKYES)

#### 6.6.5.33.1 Offset

For n = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCDn_BITER_ELINKYES</td>
<td>101Eh + (n × 20h)</td>
</tr>
</tbody>
</table>
6.6.5.33.2 Function
If the TCDn_BITER[ELINK] bit is set, the TCDn_BITER register is defined as follows.

6.6.5.33.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ELINK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LINKCH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BITE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>
```

6.6.5.33.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15 ELINK | Enables channel-to-channel linking on minor loop complete  
As the channel completes the minor loop, this flag enables the linking to another channel, defined by BITER[LINKCH]. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] bit of the specified channel. If channel linking disables, the BITER value extends to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJORELINK channel linking.  
**NOTE:** When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, the contents of this field are reloaded into the CITER field.  
0b - The channel-to-channel linking is disabled  
1b - The channel-to-channel linking is enabled |
| 14 | Reserved |
| 13-9 LINKCH | Link Channel Number  
If channel-to-channel linking is enabled (ELINK = 1), then after the minor loop is exhausted, the eDMA engine initiates a channel service request at the channel defined by this field by setting that channel's TCDn_CSR[START] bit.  
**NOTE:** When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, the contents of this field are reloaded into the CITER field. |
| 8-0 BITER | Starting major iteration count  
As the transfer control descriptor is first loaded by software, this 9-bit (ELINK = 1) or 15-bit (ELINK = 0) field must be equal to the value in the CITER field. As the major iteration count is exhausted, the contents of this field are reloaded into the CITER field.  
**NOTE:** When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, the contents of this field are reloaded into the CITER field. If the channel is configured to execute a single service request, the initial values of BITER and CITER should be 0x0001. |
Chapter 7
System Security

7.1 Chapter overview
This chapter provides an overview of the following chip security components, explaining the purpose and features of each of them.

- High Assurance Boot (HAB)
- Secure Non-Volatile Storage (SNVS) with the security monitor, key storage, and real-time clock
- Data co-processor (DCP) with cryptographic acceleration, with Cryptographic Hash Engine
- Hardware encryption and hash algorithm engine for AES128 and SHA-1/256
- True Random Number Generator (TRNG)
- On-chip One-Time Programmable Element Controller (OCOTP_CTRL) with on-chip electrical fuse arrays
- Central Security Unit (CSU)
- System JTAG Controller (SJC) with secure debug
- Bus Encryption Engine (BEE) for on-the-fly FlexSPI(QSPI) Flash decryption

7.2 Feature summary
This figure shows a simplified diagram of the security subsystem:
All platforms built using this chip share a general need for security, though the specific security requirements vary greatly from platform to platform. For example, portable consumer devices need to protect a different type and cost of assets than automotive or industrial platforms. Each market must be protected against different kinds of attacks. The platform designers need an appropriate set of counter measures to meet the security needs of their specific platform.

To help the platform designers to meet the requirements of each market, the chip incorporates a range of security features. Most of these features provide protection against specific kinds of attack, and can be configured for different levels according to the required degree of protection. These features are designed to work together or independently. They can be also integrated with the appropriate software to create defensive layers. In addition, the chip includes a general-purpose accelerator that enhances the performance of selected industry-standard cryptographic algorithms.

The security features include:

- Secure High-Assurance Boot
  - Security library embedded in the tamper-proof on-chip ROM
  - Authenticated boot, which protects against unauthorized software
    - Verification of the code signature during boot
    - RSA-1024/2048/3072/4096 keys anchored to the OTP fingerprint (SHA-256)
  - Encrypted boot which protects the software confidentiality
• Runs every time the chip is reset
• Image version control/image revocation (on-chip OTP-based)
• Secure storage
  • Off-chip storage protection using AES-128 and the chip's unique hardware-only key
• Hardware cryptographic accelerators
  • Symmetric: AES-128,
  • Hash message digest: SHA-1, SHA-256,
• Standalone True Random Number Generator (SA-TRNG) to act as entropy generator
• On-chip secure real-time clock with autonomous power domain
• Secure debugging
  • Configurable protection against unauthorized JTAG manipulation
  • Three security levels + a complete JTAG disable
  • Support for JTAG port secure reopening for field return debugging
• Universal unique ID
• Electrical fuses (OTP Memory)
• Hardware bus encryption
  • AES-128 encryption, supporting ECB and CTR modes
  • Non-secured access filtering

7.3 High-Assurance Boot (HAB)

The HAB, which is the high-assurance boot feature in the system boot ROM, detects and prevents the execution of unauthorized software (malware) during the boot sequence.

When the unauthorized software is permitted to gain control of the boot sequence, it can be used for a variety of goals, such as exposing stored secrets, circumventing access controls to sensitive data, services, or networks, or for re-purposing the platform. The unauthorized software can enter the platform during upgrades or re-provisioning, or when booting from the USB connections or removable devices.

The HAB protects against unauthorized software by:

• Using digital signatures to recognize the authentic software. This enables you to boot the device to a known initial state and run the software signed by the device manufacturer.
• Using code encryption to protect the confidential software during off-chip storage. When activated, the HAB decrypts the software loaded into the RAM before execution.
7.3.1 HAB process flow

The following figure shows the flow for creating and verifying digital signatures. The top half of this figure shows the signing process, which is performed off-chip. The bottom half shows the verification process performed on-chip during every system boot.
Figure 7-2. Code signing and authentication processes

The original software is programmed into the flash memory (or any other boot device) along with the signature. The HAB uses a public key to recover the reference hash value from the signature; it then compares the reference hash value to the current hash value.
calculated from the software in the flash. If the contents of the flash are modified either intentionally or unintentionally, the two hash values do not match and the verification fails.

### 7.3.2 HAB feature summary

The HAB features:

- Enforced internal boot via on-chip masked ROM
- Authentication of software loaded from any boot device (including the USB download)
- Authenticated decryption of software loaded from any boot device (including USB download) using the AES keys (128-bit)
- CMS PKCS#1 signature verification using the RSA public keys (from 1024-bit to 4096-bit), and the SHA-256 hash algorithm
- Public Key Infrastructure (PKI) support using X.509v3 certificates
- Root public key fingerprint in the manufacturer-programmable on-chip fuses
- Multiple root public keys with revocation by fuses
- Initialization of other security components
- Authenticated USB download fall-over on any security failure
- Open configuration for development purposes and non-secure platforms
- Closed configuration for shipping secure platforms

On the chip, the HAB is integrated with these security features:

- The HAB initializes the SNVS security monitor state machine. A successful secure boot with the HAB is required for the platform software to gain access to use the DCP master secret key selected by SNVS.
- The HAB reads the root public key fingerprint, revocation mask, and security configuration from the OCOTP_CTRL.
- The HAB initializes the CSU.
- The HAB can use the DCP to accelerate hash calculations.

### 7.4 Secure Non-Volatile Storage (SNVS) module

- Provides a non-volatile real-time clock maintained by a coin-cell battery during system power down for use in both the secure and non-secure.
- Protects the secure real-time clock against rollback attacks in time-sensitive protocols such as DRM and PKI
- Deters replay attacks in time-independent protocols such as certificate or firmware revocations
• Handles security violation detection and reporting, to defend sensitive data and operations against compromise, both at run-time and during system power-down
• Controls the access to the OTP master secret key used by the DCP to protect confidential data in the off-chip storage
• Provides non-volatile highly protected storage for an alternative master secret key

7.4.1 SNVS architecture

The SNVS is partitioned into two sections: a low-power part (SNVS_LP) and a high-power part (SNVS_HP).

The SNVS_LP block is in the always-powered-up domain. It is isolated from the rest of the logic by isolation cells which are library-instantiated cells that insure that the powered-up logic is not corrupted when the power goes down in the rest of the chip.

The SNVS_LP has these functional units:
• Zeroizable Master Key
• Secure non-rollover real-time counter with alarm
• Non-rollover monotonic counter
• Power glitch detector
• General-purpose register
• Control and status registers

The SNVS_HP is in the chip power-supply domain. The SNVS_HP provides an interface between the SNVS_LP and the rest of the system. The access to the SNVS_LP registers can be gained through the SNVS_HP only when it is powered up according to the access permission policy.

The SNVS_HP has these functional units:
• IP bus interface
• SNVS_LP interface
• System Security Monitor (SSM)
• Zeroizable Master Key programming mechanism
• Master Key control block
• Non-secure real-time counter with alarm
• Control and status registers
7.5 Data Co-Processor (DCP)

For security purposes, the Data Co-Processor (DCP) provides hardware acceleration for the cryptographic algorithms. The features of DCP include:

- Encryption Algorithms: AES-128 (ECB and CBC modes)
- Hashing Algorithms: SHA-1 and SHA-256
- CRC-32
- Key selection from the SNVS, DCP internal key storage, or general memory
- Internal Memory for storing up to four AES-128 keys—when a key is written to a key slot it can be read only by the DCP AES-128 engine
- IP slave interface
- DMA

7.6 Standalone True Random Number Generator (TRNG)

The SA-TRNG is hardware accelerator module that generates a 512-bit entropy as needed by an entropy consuming module or by other post processing functions. A typical entropy consumer is a pseudo random number generator (PRNG) which can be implemented to achieve both true randomness and cryptographic strength random numbers using the SA-TRNG output as its entropy seed. The PRNG is not part of this module.

7.7 On-Chip OTP Controller (OCOTP_CTRL)

The OCOTP_CTRL provides the primary user-visible mechanism for interfacing with the on-chip fuses. These fuses' uses include:

- Unique chip identifiers
- Mask revision numbers
- Cryptographic keys
- Security configuration
- Boot characteristics
- Various control signals requiring permanent non-volatility

The OCOTP_CTRL provides:

- Shadow cache of fuse values, loaded at reset, before the system boot
- Ability to read and override the fuse values in the shadow cache (does not affect the fuse element)
• Ability to read the fuses directly (ignoring the shadow cache)
• Ability to write (program) the fuses by software or JTAG
• Fuses and shadow cache bits enforce read-protect, override-protect, and write-protect
• Lock fuses for selected fuse fields
• Scan protection
• Volatile software-accessible signals which can be used for software control of hardware elements (not requiring non-volatility).

7.8 Central Security Unit (CSU)

Central Security Unit (CSU) sets access control policies between the bus masters and bus slaves, enabling the peripherals to be separated into distinct security domains. This protects against the indirect unauthorized access to data which occurs when the software programs a DMA bus master to access addresses that the software itself is prohibited from accessing directly. Configuring the DMA bus master privileges in the CSU consistently with the software privileges defends against such indirect unauthorized access.

The CSU provides:

• Configuration of peripheral access permissions for peripherals that are unable to control their own access permissions
• Configuration of bus master privileges for bus masters that are unable to control their own privileges
• Optional locking of the individual CSU settings until the next power-on reset

7.9 System JTAG Controller (SJC)

The JTAG port provides debug access to hardware blocks, including the Arm processor and the system bus. This enables program control and manipulation as well as visibility to the chip peripherals and memory.

The JTAG port must be accessible during initial platform development, manufacturing tests, and general troubleshooting. Given its capabilities, JTAG manipulation is a known attack vector for accessing sensitive data and gaining control over software execution. The System JTAG Controller (SJC) protects against the whole range of attacks based on unauthorized JTAG manipulation. It also provides a JTAG port that conforms to the IEEE 1149.1 and IEEE 1149.6 (AC) standards for BSR (boundary-scan) testing.

The SJC provides these security levels:
• The JTAG Disabled-JTAG use is permanently blocked.
• The No-Debug-All security sensitive JTAG features are permanently blocked.
• The Secure JTAG-JTAG use is restricted (as in the No-Debug level) unless a secret-key challenge/response protocol is successfully executed.
• The JTAG Enabled-JTAG use is unrestricted.

The security levels are selected via the e-fuse configuration.

### 7.9.1 Scan protection

The chip includes further scan protection logic for those SJC modes where the JTAG use is allowed. This ensures that the access to critical security values is protected as follows:

• The chip is reset when entering the scan mode.
• All modules are reset two clock cycles before receiving the scan-enable indication.
• The chip cannot exit the scan mode without a reset.
• The security modules (including SNVS, CSU, and OCOTP_CTRL) have an additional scan-protection logic to protect the sensitive internal data and functionality.

See the "System JTAG Controller (SJC)" chapter in the Security Reference Manual for more information on the SJC.

### 7.10 Bus Encryption Engine (BEE)

The Bus Encryption Engine (BEE) is implemented as an on-the-fly decryption engine, which is used for decrypting cypher context of FlexSPI. The main features of the BEE are:

• Standard AXI interconnection
• On-the-fly AES-128 decryption, supporting ECB and CTR modes
• Aliased memory space support. Address remapping for up to two individual regions
• Independent AES Key management for those two individual regions
• Bus access pattern optimization with the aid of the local store and forward buffer
• Non-secured access filtering based on the security label of the access
• Illegal access check and filtering

See the "Bus Encryption Engine (BEE)" chapter in the Security Reference Manual for more information on BEE.
Chapter 8
System Debug

8.1 Overview

This section describes the hardware and software debug and application development features and resources of the chip. It describes the following:

- Core/platform-specific resources
- Resources associated with complex IP blocks
- Chip-wide resources
- Interface to the external debug and development tools

The debug and trace architecture is designed around the following:

- Arm CoreSight architecture, adapted to SoC (for core debug), including a cross-trigger subsystem for cross-domain triggering of debug resources
- JTAG port used to interact with core under the debug by means of SJC, the system JTAG controller port
- DAP, the debug access port that supports the interface to the Arm RealView Debugging tools and other third-party tools
- TPIU, a trace port interface unit that efficiently accesses the program trace information from the system
- Various chip-wide resources, such as debug features built into the IP blocks and critical signal visibility available through alternate pin functions or observability muxes

8.2 Chip and Arm Platform Debug Architecture

The Arm Debug architecture is based on the CoreSight architecture by Arm. The CoreSight architecture provides a system-wide solution to real-time debug and trace.
The CoreSight architecture is embodied in a set of CoreSight components and compliant processors that form the CoreSight systems. Its architecture maintains the traditional requirements of debug and trace:

- To access the debug functionality without software interaction
- To connect to a running system without performing a reset

Full access to the processor debug capability is available by the Arm debug register map through the Advanced Peripheral Bus (APB) slave port. The core includes a Processor Debug Unit which stops program execution, examines and alters the processor and coprocessor state, examines and alters the memory and input/output peripheral state, and restarts the processor core.

### 8.2.1 Debug Features

- EmbeddedICE-RT logic
  - Support for both the monitor-mode and halt-mode debugging:
    - Core run/halt control, debug status/control
    - Breakpoint/watchpoint control
    - Core-mapped and memory-mapped resource examination/modification
  - Data communication channel between the Arm core and the host debugger via JTAG or SWD and the Debug Access Port (DAP) module

The chip includes Arm CoreSight components for debug and trace solutions.

### 8.2.2 Debug system components

The CoreSight components include:

- ETM (Embedded Trace Macrocell) supporting instruction trace
- ITM (Instrumentation Trace Macrocell)
- TPIU (Trace Port Interface)
- Cross Triggering logic for event routing, including CTIs

Other related IPs and functionality:

- Flash Patch and Breakpoint unit (FPB)
8.2.2.1 AMBA Trace Bus (ATB)

ATB transfers trace data though the chip CoreSight infrastructure. The trace sources are ATB masters and the sinks are ATB slaves. The Arm (via PTM) cores are the data generators. Link components such as the Trace Funnel and Replicator provide both the master and slave interfaces.

The ATB protocol supports:

- Stalling of trace sources to enable the CoreSight components to funnel and combine the sources into a single trace stream
- Association of the trace data with the generating source using trace source IDs. The CoreSight system can trace up to 111 different items at any time
- Capture and transfer of multiple byte bus widths, currently to 32 bits
- A flushing mechanism to force the historic trace to drain from any sources, links, or sinks up to the point that the request is initiated

8.2.2.2 CoreSight trace port interface (TPIU)

TPIU (Cortex-M7)

TPIU is one of the CoreSight trace sink components. It acts as a bridge between the on-chip trace data and a data stream that is then driven out the trace port.

TPIU uses the ATB interface to accept trace data from a trace source, either directly or by using a trace funnel. TPIU has 4 bit port connected to the chip pad.

The APB interface is the programming interface for the TPIU configuration.

The features of the sub-blocks are as follows:

- Formatter—Inserts source ID signals into the data packet stream so that the trace data can be re-associated with the trace source.
- Asynchronous FIFO—Enables trace data to be driven out at a speed that is not dependent on the on-chip bus clock.
- Register Bank—Contains the management, control and status registers for triggers, flushing behavior and external control.
- Trace out—The Trace out block serializes the formatted data before it goes off-chip.
- Pattern Generator—The Pattern Generator unit provides a simple set of defined bit sequences or patterns that can be output over the Trace Port and be detected by the TPA or other associated Trace Capture Device (TCD). The TCD can use these patterns to indicate if it is possible to increase or decrease the trace port clock speed.
The TPIU accepts trace data from a trace source, either direct from a trace source or using a Trace Funnel. The APB interface is the programming interface for the TPIU. The Trace Clock driving the data out to external pins can be obtained from either an on chip or off chip source, selectable via a mux.

The output of the TPIU is connected via external pins (MPS of TRACEDATA (ARM_TRACEEn), which can be 1, 2, or 4 bits). The system may utilize double data rate pins to either use a lower clock speed than that of the 32-bit ATB interface, or use fewer than 4 data pins for the output, based on the ability of the technology used. Given the speed of the ATB, 4 data pins with double data rate is recommended, with the external interface running at half the speed of the ATB. The speed of the external interface is from TRACECLKIN (TRACE_CLK_ROOT), and should be selectable via an on chip or off chip clock. TRACECLK (ARM_TRACE_CLK) is equal to TRACECLKIN / 2, and is divided in the TPIU to clock trace data at the trace capture unit.

TPIU used to be part of the Arm platform sub blocks in previous versions of i.MX products, placing the TPIU off platform allows future debug trace sources from the chip level to connect to the TPIU by means of a funnel.

For more information, see Arm Cortex M7 Integration and Implementation Manual.

### 8.2.2.3 Coresight Embedded Trace Buffer (ETB)

The ETB provides on-chip storage of trace data using 32-bit RAM. The ETB accepts trace data from any CoreSight-compliant component trace source with an ATB master port, such as a trace source or a trace funnel. It is included in this device to remove dependencies from the trace pin pad speed, and enable low cost trace solutions. The TraceRAM size is 2 KB.
The ETB contains the following blocks:

- **Formatter**—Inserts source ID signals into the data packet stream so that trace data can be re-associated with its trace source after the data is read back out of the ETB.
- **Control**—Control registers for trace capture and flushing.
- **APB interface**—Read, write, and data pointers provide access to ETB registers. In addition, the APB interface supports wait states through the use of a PREADYDBG signal output by the ETB. The APB interface is synchronous to the ATB domain.
- **Register bank**—Contains the management, control, and status registers for triggers, flushing behavior, and external control.
- **Trace RAM interface**—Controls reads and writes to the Trace RAM.

### 8.2.2.3.1 Performance Profiling with the ETB

To create a performance profile (for example, gprof) for the target application, a means to collect trace over a long period of time is needed. The ETB buffer is too small to capture a meaningful profile in just one take. What is needed is to collect and concatenate data from the ETB buffer for multiple sequential runs. Using the ETB packet counter, the trace analysis tool can capture multiple sequential runs by executing code until the ETB is almost full, and halting or executing an interrupt handler to allow the buffer to be emptied, and then continuing executing code. The target halts or executes an interrupt handler when the buffer is almost full to empty the data and then the debugger runs the target again.

### 8.2.2.3.2 ETB Counter Control

The ETB packet counter is controlled by the ETB counter control register, ETB reload register, and ETB counter value register implemented in the Miscellaneous Control Module (MCM) accessible via the Private Peripheral Bus. Via the ETB counter control register the ETB control logic can be configured to cause an MCM Alert Interrupt, an NMI Interrupt, or cause a Debug halt when the down counter reaches 0. Other features of the ETB control logic include:

- Down counter to count as many as 512 x 32-bit packets.
- Reload request transfers reload value to counter.
- ATB valid and ready signals used to form counter decrement.
- The counter disarms itself when the count reaches 0.

The counter decrement enable will allow the counter to decrement at the rising edge of ATCLK when,

- The counter enable bit is set.
- The counter is armed.
- ATVALID and ATREADY are asserted.
### 8.2.2.4 Embedded Trace Macrocell (ETM)

Instruction trace, also known as ETM (Embedded Trace Macrocell) trace, is a continuously collected sequence of every executed instruction for a selected portion of the application. ETM generates trace packets and sends them to the trace bus. ETM does not actually output every address or instruction that the processor has reached or executed; it usually generates compressed information about the program flow and outputs full addresses only if needed (for example, if a branch has taken place). Because the debugger knows the application code image, the debugger can then reconstruct the full instruction sequence from the trace data.

For more information about ETM, refer to *Arm® CoreSight™ ETM-M7 Revision r0p1 Technical Reference Manual*.

### 8.2.2.5 Instrumentation Trace Macrocell

The ITM (Instrumentation Trace Macrocell) generates trace information as packets. There are four sources that can generate packets. If multiple sources generate packets at the same time, the ITM arbitrates the order in which packets are output. The four sources in decreasing order of priority are:
• Synchronization: DWT provides periodic requests to make ITM generate synchronization packet. Trace capture hardware uses it to identify the alignment of packet bytes in the bit-stream.
• Software Trace: Application software can write console messages directly to ITM stimulus ports, and output them to the host as trace packets.
• Hardware trace: The DWT generates these packets, and the ITM outputs them.
• Timestamping: ITM can generate timestamp packets that are inserted in to the trace stream, to help the host debugger to find out the timing of events. Timestamps are generated relative to packets. The ITM receives a 64-bit counter to generate the timestamp.

Trace data from ITM will be forwarded to TPIU and streamed out via the trace port.

For more information about ITM, refer to *Armv7-M Architecture Reference Manual.

### 8.2.3 Chip-Specific SJC Features

**NOTE**
The application note AN12419: Secure JTAG for i.MXRT10xx describes how the Secure JTAG on the i.MX RT10xx MCU family can be used.

#### 8.2.3.1 JTAG Disable Mode

In addition to different JTAG security modes that are implemented internally in the JTAG Controller, there is an option to disable the SJC functionality by e-fuse configuration.

This creates additional JTAG mode "JTAG Disabled" with highest level of JTAG protection. In this mode all JTAG features are disabled. Specifically, the following debug features are disabled in addition to the features that were already disabled in "No Debug" JTAG mode:

• Non-Secure JTAG control registers (PLL configuration, Deterministic Reset, PLL bypass)
• Non-Secure JTAG status registers (Core status)
• Chip Identification Code (IDCODE)
8.2.3.2 JTAG ID

Table 8-1. i.MX JTAG ID

<table>
<thead>
<tr>
<th>Device</th>
<th>Silicon revision</th>
<th>JTAG ID</th>
</tr>
</thead>
<tbody>
<tr>
<td>i.MX RT1060</td>
<td>Rev 1.0</td>
<td>088C_501Dh</td>
</tr>
</tbody>
</table>

8.2.4 System JTAG controller main features

- IEEE P1149.1, 1149.6 (standard JTAG) interface to off-chip test and development equipment
  - Includes an SJC-only mode for true IEEE P1149.1 compliance, used primarily for board-level implementation of boundary scan.
  - Supports IEEE P1149.6 extensions to the JTAG standard for AC testing of selected I/O signals.
- Debug-related control and status; putting selected cores into reset and/or debug mode and monitoring individual core status signals by means of JTAG
- System status, such as the state of the PLLs (locked or not locked)
- Levels of security, ranging from no security to no JTAG accessibility to the chip

8.2.5 TAP Port

The SJC supports the following standard JTAG pins:

- TRSTB
- TDI
- TDO
- TCK
- TMS

8.2.6 SJC main blocks

- Interface to the outside world via the standard JTAG pins
- Interface to the external Debug_Event pin
- A master TAP controller which implements the standard JTAG state machine
- Implementation of the mandatory and optional IEEE P1149.1 (JTAG) instructions
  - Mandatory: "EXTEST", "SAMPLE/PRELOAD", and "BYPASS"
  - Optional: "ID_CODE" (SOC JTAG ID register), "HIGHZ"
- The ExtraDebug registers, which implement a variety of control and status features
  - Three 32-bit insecure general purpose status registers
• Two 32-bit secure status registers - one predefined, one general purpose.
• Control and status registers for debug, core, charge pump, and PLL.
• Four levels of fuse-defined security, ranging from no security to no access.

Both predefined and user-defined control and status functions are supported by the SJC.

8.3 Miscellaneous

The Miscellaneous function described in this section provide useful general capabilities.

8.3.1 Clock/Reset/Power

CDBGPPWRUPREQ and CDBGPPWRUPACK are the handshake signals between the DAP and the clock control module to ensure debug power and clocks are turned on. If the debug components are always powered on, the handshake becomes a mechanism to turn debug clocks on. Similarly, there is a register bit in the CCM which allows internal software to turn debug clocks on as well because the CDBGPPWRUPREQ is in the TCLK domain and is inaccessible to software.

The debug components can receive resets from the following sources:
• Debug Reset (CDBGPRSTREQ bit within the SWJ-DP CTRL/STAT register of the DAP) in the TCLK domain. This allows the debug tools to reset the debug logic.
• System POR reset
Chapter 9
System Boot

9.1 Chip-specific Boot Information

This device has various peripherals supported by the ROM bootloader.

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>Instance</th>
<th>Port (IO function)</th>
<th>PAD</th>
<th>Mode</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPUART</td>
<td>1</td>
<td>LPUART1_TX</td>
<td>GPIO_AD_B0_12</td>
<td>ALT2</td>
<td>Can be used for serial downloader mode. Refer to Serial Downloader for more information.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPUART1_RX</td>
<td>GPIO_AD_B0_13</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td>LPSPI</td>
<td>1</td>
<td>LPSPI1_SCK</td>
<td>GPIO_SD_B0_00</td>
<td>ALT4</td>
<td>Serial NOR/EEPROM connected to one of the LPSPI ports can be used as a recovery device. Refer to Recovery devices for more information.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI1_SDO</td>
<td>GPIO_SD_B0_02</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI1_SDI</td>
<td>GPIO_SD_B0_03</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI1_PCS0</td>
<td>GPIO_SD_B0_01</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td></td>
<td>2</td>
<td>LPSPI2_SCK</td>
<td>GPIO_SD_B1_07</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI2_SDO</td>
<td>GPIO_SD_B1_08</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI2_SDI</td>
<td>GPIO_SD_B1_09</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI2_PCS0</td>
<td>GPIO_SD_B1_06</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td></td>
<td>3</td>
<td>LPSPI3_SCK</td>
<td>GPIO_AD_B0_00</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI3_SDO</td>
<td>GPIO_AD_B0_01</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI3_SDI</td>
<td>GPIO_AD_B0_02</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI3_PCS0</td>
<td>GPIO_AD_B0_03</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td></td>
<td>4</td>
<td>LPSPI4_SCK</td>
<td>GPIO_B0_03</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI4_SDO</td>
<td>GPIO_B0_02</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI4_SDI</td>
<td>GPIO_B0_01</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPSPI4_PCS0</td>
<td>GPIO_B0_00</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>SEMC NAND</td>
<td>N/A</td>
<td>SEMC_DATA00</td>
<td>GPIO_EMC_00</td>
<td>ALT0</td>
<td>Parallel NAND flash connected to the SEMC is a primary boot option. Refer to Parallel NAND flash Boot over SEMC for more information.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SEMC_DATA01</td>
<td>GPIO_EMC_01</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>SEMC_DATA02</td>
<td>GPIO_EMC_02</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>SEMC_DATA03</td>
<td>GPIO_EMC_03</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>SEMC_DATA04</td>
<td>GPIO_EMC_04</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>SEMC_DATA05</td>
<td>GPIO_EMC_05</td>
<td>ALT0</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 9-1. ROM Bootloader Peripheral PinMux (continued)

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>Instance</th>
<th>Port (IO function)</th>
<th>PAD</th>
<th>Mode</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC_DATA06</td>
<td></td>
<td></td>
<td>GPIO_EMC_06</td>
<td>ALT0</td>
<td>By default SEMC_CSX0 is used as the chip select. Other chip selects can be used, but fuses must be blown to select these configurations (GPIO overrides cannot be used to configure this option).</td>
</tr>
<tr>
<td>SEMC_DATA07</td>
<td></td>
<td></td>
<td>GPIO_EMC_07</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA08</td>
<td></td>
<td></td>
<td>GPIO_EMC_30</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA09</td>
<td></td>
<td></td>
<td>GPIO_EMC_31</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA10</td>
<td></td>
<td></td>
<td>GPIO_EMC_32</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA11</td>
<td></td>
<td></td>
<td>GPIO_EMC_33</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA12</td>
<td></td>
<td></td>
<td>GPIO_EMC_34</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA13</td>
<td></td>
<td></td>
<td>GPIO_EMC_35</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA14</td>
<td></td>
<td></td>
<td>GPIO_EMC_36</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA15</td>
<td></td>
<td></td>
<td>GPIO_EMC_37</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR09</td>
<td></td>
<td></td>
<td>GPIO_EMC_18</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR11</td>
<td></td>
<td></td>
<td>GPIO_EMC_19</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR12</td>
<td></td>
<td></td>
<td>GPIO_EMC_20</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_BA1</td>
<td></td>
<td></td>
<td>GPIO_EMC_22</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_RDY</td>
<td></td>
<td></td>
<td>GPIO_EMC_40</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX0</td>
<td></td>
<td></td>
<td>GPIO_EMC_41</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX1</td>
<td></td>
<td></td>
<td>GPIO_B0_00</td>
<td>ALT6</td>
<td>Parallel NOR flash connected to the SEMC is a primary boot option. Refer to Parallel NOR flash Boot over SEMC for more information.</td>
</tr>
<tr>
<td>SEMC_CSX2</td>
<td></td>
<td></td>
<td>GPIO_B0_01</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX3</td>
<td></td>
<td></td>
<td>GPIO_B0_02</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR08</td>
<td></td>
<td></td>
<td>GPIO_EMC_17</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA00</td>
<td></td>
<td></td>
<td>GPIO_EMC_00</td>
<td>ALT0</td>
<td>Note: By default SEMC_CSX0 is used as the chip select. Other chip selects can be used, but fuses must be blown to select these configurations (GPIO overrides cannot be used to configure this option).</td>
</tr>
<tr>
<td>SEMC_DATA01</td>
<td></td>
<td></td>
<td>GPIO_EMC_01</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA02</td>
<td></td>
<td></td>
<td>GPIO_EMC_02</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA03</td>
<td></td>
<td></td>
<td>GPIO_EMC_03</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA04</td>
<td></td>
<td></td>
<td>GPIO_EMC_04</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA05</td>
<td></td>
<td></td>
<td>GPIO_EMC_05</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA06</td>
<td></td>
<td></td>
<td>GPIO_EMC_06</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA07</td>
<td></td>
<td></td>
<td>GPIO_EMC_07</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA08</td>
<td></td>
<td></td>
<td>GPIO_EMC_30</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA09</td>
<td></td>
<td></td>
<td>GPIO_EMC_31</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA10</td>
<td></td>
<td></td>
<td>GPIO_EMC_32</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA11</td>
<td></td>
<td></td>
<td>GPIO_EMC_33</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA12</td>
<td></td>
<td></td>
<td>GPIO_EMC_34</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA13</td>
<td></td>
<td></td>
<td>GPIO_EMC_35</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA14</td>
<td></td>
<td></td>
<td>GPIO_EMC_36</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA15</td>
<td></td>
<td></td>
<td>GPIO_EMC_37</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR00</td>
<td></td>
<td></td>
<td>GPIO_EMC_09</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR01</td>
<td></td>
<td></td>
<td>GPIO_EMC_10</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR02</td>
<td></td>
<td></td>
<td>GPIO_EMC_11</td>
<td>ALT0</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Peripheral</th>
<th>Instance</th>
<th>Port (IO function)</th>
<th>PAD</th>
<th>Mode</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC_ADDR03</td>
<td>GPIO_EMC_12</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR04</td>
<td>GPIO_EMC_13</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR05</td>
<td>GPIO_EMC_14</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR06</td>
<td>GPIO_EMC_15</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR07</td>
<td>GPIO_EMC_16</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR11</td>
<td>GPIO_EMC_19</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR12</td>
<td>GPIO_EMC_20</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_BA0</td>
<td>GPIO_EMC_21</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_BA1</td>
<td>GPIO_EMC_22</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX0</td>
<td>GPIO_EMC_41</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX1</td>
<td>GPIO_B0_00</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX2</td>
<td>GPIO_B0_01</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX3</td>
<td>GPIO_B0_02</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR08</td>
<td>GPIO_EMC_17</td>
<td>ALTO</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SD</td>
<td>1</td>
<td>USDHC1_CD_B</td>
<td>GPIO_SD_B1_12</td>
<td>ALTO</td>
<td>eMMC/MMC or SD/eSD connected to one of the USDHC ports is a primary boot option. Refer to Expansion device for more information on USDHC boot.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_VSELECT</td>
<td>GPIO_B1_14</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_RESET_B</td>
<td>GPIO_B1_15</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_CMD</td>
<td>GPIO_SD_B0_00</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_CLK</td>
<td>GPIO_SD_B0_01</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_DATA0</td>
<td>GPIO_SD_B0_02</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_DATA1</td>
<td>GPIO_SD_B0_03</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_DATA2</td>
<td>GPIO_SD_B0_04</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC1_DATA3</td>
<td>GPIO_SD_B0_05</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td>2</td>
<td>USDHC2_RESET_B</td>
<td>GPIO_SD_B1_06</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_CMD</td>
<td>GPIO_SD_B1_05</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_CLK</td>
<td>GPIO_SD_B1_04</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA0</td>
<td>GPIO_SD_B1_03</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA1</td>
<td>GPIO_SD_B1_02</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA2</td>
<td>GPIO_SD_B1_01</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA3</td>
<td>GPIO_SD_B1_00</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA4</td>
<td>GPIO_SD_B1_08</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA5</td>
<td>GPIO_SD_B1_09</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA6</td>
<td>GPIO_SD_B1_10</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>USDHC2_DATA7</td>
<td>GPIO_SD_B1_11</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td>FlexSPI NOR Flash - QSPI</td>
<td>1</td>
<td>FLEXSPI_B_DATA3</td>
<td>GPIO_SD_B1_00</td>
<td>ALTO</td>
<td>QSPI memory attached to FlexSPI is a primary boot option. Refer to Serial NOR Flash Boot via FlexSPI for more information. The ROM will read the 512-byte FlexSPI NOR configuration parameters</td>
</tr>
<tr>
<td></td>
<td></td>
<td>FLEXSPI_B_DATA2</td>
<td>GPIO_SD_B1_01</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>FLEXSPI_B_DATA1</td>
<td>GPIO_SD_B1_02</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>FLEXSPI_B_DATA0</td>
<td>GPIO_SD_B1_03</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>FLEXSPI_B_SCLK</td>
<td>GPIO_SD_B1_01</td>
<td>ALTO</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-1. ROM Bootloader Peripheral PinMux (continued)

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>Instance</th>
<th>Port (IO function)</th>
<th>PAD</th>
<th>Mode</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXSPI_B_DQS</td>
<td></td>
<td>GPIO_SD_B0_05</td>
<td>ALT4</td>
<td></td>
<td>described in FlexSPI Serial NOR Flash Boot Operation using the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>non-italicized pins.</td>
</tr>
<tr>
<td>FLEXSPI_B_SS0_B</td>
<td></td>
<td>GPIO_SD_B0_04</td>
<td>ALT4</td>
<td></td>
<td>Note: ROM can configure the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>italicized signals based on the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>FlexSPI NOR configuration</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>parameters provided.</td>
</tr>
<tr>
<td>FLEXSPI_B_SS1_B</td>
<td></td>
<td>GPIO_SD_B0_01</td>
<td>ALT6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DQS</td>
<td></td>
<td>GPIO_SD_B1_05</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_SS0_B</td>
<td></td>
<td>GPIO_SD_B1_06</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_SS1_B</td>
<td></td>
<td>GPIO_SD_B0_00</td>
<td>ALT6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_SCLK</td>
<td></td>
<td>GPIO_SD_B1_07</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA0</td>
<td></td>
<td>GPIO_SD_B1_08</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA1</td>
<td></td>
<td>GPIO_SD_B1_09</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA2</td>
<td></td>
<td>GPIO_SD_B1_10</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA3</td>
<td></td>
<td>GPIO_SD_B1_11</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FlexSPI_B_DATA3</td>
<td>1</td>
<td>GPIO_AD_B1_15</td>
<td>ALT0</td>
<td></td>
<td>QSPI memory attached to FlexSPI is a primary boot option. Refer to</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Serial NOR Flash Boot via FlexSPI for more information. The ROM</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>will read the 512-byte FlexSPI NOR configuration parameters</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>described in FlexSPI Serial NOR Flash Boot Operation using the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>non-italicized pins.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Note: These pins are a secondary pinout option for FlexSPI serial</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>NOR flash boot.</td>
</tr>
<tr>
<td>FLEXSPI_B_DATA2</td>
<td></td>
<td>GPIO_AD_B1_14</td>
<td>ALT0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_DATA1</td>
<td></td>
<td>GPIO_AD_B1_09</td>
<td>ALT0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_DATA0</td>
<td></td>
<td>GPIO_AD_B1_13</td>
<td>ALT0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_SCLK</td>
<td></td>
<td>GPIO_AD_B1_12</td>
<td>ALT0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_DQS</td>
<td></td>
<td>GPIO_AD_B1_11</td>
<td>ALT0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_SS0_B</td>
<td></td>
<td>GPIO_AD_B1_10</td>
<td>ALT0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_SS1_B</td>
<td></td>
<td>GPIO_AD_B1_00</td>
<td>ALT1</td>
<td></td>
<td>Octal serial NOR flash memory</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>attached to FlexSPI is a primary boot option. Refer to Serial NOR</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Flash Boot via FlexSPI for more information. The ROM will read the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>512-byte FlexSPI NOR configuration parameters described in FlexSPI</td>
</tr>
<tr>
<td>FlexSPI_B_DATA3</td>
<td>1</td>
<td>GPIO_SD_B1_00</td>
<td>ALT1</td>
<td></td>
<td>Octal serial NOR flash memory</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>attached to FlexSPI is a primary boot option. Refer to Serial NOR</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Flash Boot via FlexSPI for more information. The ROM will read the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>512-byte FlexSPI NOR configuration parameters described in FlexSPI</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Serial NOR Flash Boot Operation using the non-italicized pins. For</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>8-bit wide memories the FLEXSPI_B_DATA[3:0] pins are combined with the</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>FLEXSPI_A_DATA[3:0] lines to get the full 8-bit port. Note: ROM can</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>configure the italicized signals based on the FlexSPI NOR configuration</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>parameters provided.</td>
</tr>
<tr>
<td>FLEXSPI_B_DATA2</td>
<td></td>
<td>GPIO_SD_B1_01</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_DATA0</td>
<td></td>
<td>GPIO_SD_B1_02</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_SCLK</td>
<td></td>
<td>GPIO_SD_B1_03</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_DQS</td>
<td></td>
<td>GPIO_SD_B1_04</td>
<td>ALT4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_SS0_B</td>
<td></td>
<td>GPIO_SD_B1_05</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_SS1_B</td>
<td></td>
<td>GPIO_SD_B1_06</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DQS</td>
<td></td>
<td>GPIO_SD_B0_00</td>
<td>ALT6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_SS0_B</td>
<td></td>
<td>GPIO_SD_B1_00</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_SS1_B</td>
<td></td>
<td>GPIO_SD_B1_05</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_SCLK</td>
<td></td>
<td>GPIO_SD_B1_06</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA0</td>
<td></td>
<td>GPIO_SD_B1_08</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA1</td>
<td></td>
<td>GPIO_SD_B1_09</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA2</td>
<td></td>
<td>GPIO_SD_B1_10</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA3</td>
<td></td>
<td>GPIO_SD_B1_11</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FlexSPI NAND Flash</td>
<td>1</td>
<td>GPIO_SD_B1_05</td>
<td>ALT1</td>
<td></td>
<td>Serial NAND memory attached to FlexSPI is a primary boot option.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Refer to Serial NAND Flash Boot over FlexSPI for more information.</td>
</tr>
<tr>
<td>FLEXSPI_A_DQS</td>
<td></td>
<td>GPIO_SD_B1_06</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_SCLK</td>
<td></td>
<td>GPIO_SD_B1_07</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-1. ROM Bootloader Peripheral PinMux (continued)

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>Instance</th>
<th>Port (IO function)</th>
<th>PAD</th>
<th>Mode</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>FLEXSPI_A_DATA0</td>
<td>GPIO_SD_B1_08</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>FLEXSPI_A_DATA1</td>
<td>GPIO_SD_B1_09</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>FLEXSPI_A_DATA2</td>
<td>GPIO_SD_B1_10</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>FLEXSPI_A_DATA3</td>
<td>GPIO_SD_B1_11</td>
<td>ALT1</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>FlexSPI RESET</td>
<td>GPIO1_IO29</td>
<td>GPIO_AD_B1_13</td>
<td>ALT5</td>
<td></td>
</tr>
</tbody>
</table>

This device configures the clock to the following state during boot.

Table 9-2. ROM Clock Setting

<table>
<thead>
<tr>
<th>Register</th>
<th>Setting</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_CACRR</td>
<td>0x00000001</td>
</tr>
<tr>
<td>CCM_CBCDR</td>
<td>0x000A8200</td>
</tr>
<tr>
<td></td>
<td>(core clock = 396MHz, default boot frequency)</td>
</tr>
<tr>
<td>CCM_CSCDR1</td>
<td>0x06490B03</td>
</tr>
<tr>
<td>CCM_CBCMR</td>
<td>0x75AE8104</td>
</tr>
<tr>
<td>CCM_CSCMR1</td>
<td>0x67930001</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_ARM</td>
<td>0x80002042</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_SYS</td>
<td>0x80002001</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_USB1</td>
<td>0x80003040</td>
</tr>
</tbody>
</table>

**NOTE**

1. The boot ROM enables MPU protection under HAB-closed mode, to prevent execution of any other supported memory regions than the ROM region, during boot code execution. This feature puts restrictions on the SW debug on the RT106x chip. The debug tool needs to disable the MPU first, before executing the code on the device under HAB-closed mode.

2. The boot ROM enables LUART1 and USB1 interrupts in serial downloader mode, and it disables these interrupts before jumping to user applications. However, if the boot ROM execution is interrupted by the debug tool, it cannot disable these interrupts; the user application needs to disable these interrupts in the startup codes.
3. The boot ROM configures the PIT channel 0 and channel 1 registers but does not restore them before jumping to boot image. The user application needs to re-configure the PIT channels explicitly instead of relying on the default register values.

4. The PFD_480_PFD1 is selected as the FLEXSPI clock source. The user application needs to take special care on adjusting the PFD_480_PFD1 setting in the XiP boot case because the clock update impacts the FLEXSPI timing.

**NOTE**
ROM does not support boot from FLEXSPI_B port directly. ROM always seeks a valid Flash Configuration Block from the FLEXSPI_A port and then re-configures the FLEXSPI controller using the valid parameters in the block read-out. This reconfiguration can include, but is not limited to, FLEXSPI_B port support.

### 9.2 Overview

The boot process begins at any Reset where the hardware reset logic forces the Arm core to begin execution starting from the on-chip boot ROM.

The boot ROM code uses the state of the internal register BOOT_MODE[1:0] as well as the state of various eFUSEs and/or GPIO settings to determine the boot flow behavior of the device.

The main features of the ROM include:

- Support for booting from various boot devices
- Serial downloader support (USB OTG and UART)
- Device Configuration Data (DCD) and plugin
- Digital signature and encryption based High-Assurance Boot (HAB)
- Wake-up from the low-power modes
- Encrypted XIP on Serial NOR via FlexSPI interface powered by Bus Encryption Engine (BEE) and Data Co-Processor (DCP) controller

The boot ROM supports boot device as below:

- Serial NOR Flash via FlexSPI
- Serial NAND Flash via FlexSPI
- Parallel NOR Flash via SEMC
- RAWNAND Flash via SEMC
- SD/MMC
- SPI NOR/Eeprom via LPSPI

The boot ROM uses the state of the BOOT_MODE and eFUSEs to determine the boot device. For development purposes, the eFUSEs used to determine the boot device may be overridden using the GPIO pin inputs.

The boot ROM code also allows to download the programs to be run on the device. An example is a provisioning program that can make further use of the serial connection to provide a boot device with a new image. Typically, the provisioning program is downloaded to the internal RAM and allows to program the boot devices, such as the FlexSPI NOR flash. The ROM serial downloader uses a high-speed USB in a non-stream mode connection.

The boot ROM allows waking up from the low-power modes. On reset, the ROM checks the power gating status register. When waking from the low-power mode, the core skips loading an image from the boot device and jumps to the address saved in PERSISTENT_ENTRY0.

The Device Configuration Data (DCD) feature allows the boot ROM code to obtain the SOC configuration data from an external program image residing on the boot device. As an example, the DCD can be used to program the SDRAM controller for optimal settings, improving the boot performance. The DCD is restricted to the memory areas and peripheral addresses that are considered essential for the boot purposes (see Write data command).

A key feature of the boot ROM is the ability to perform a secure boot, also known as a High-Assurance Boot (HAB). This is supported by the HAB security library which is a subcomponent of the ROM code. The HAB uses a combination of hardware and software together with the Public Key Infrastructure (PKI) protocol to protect the system from executing unauthorized programs. Before the HAB allows the user image to execute, the image must be signed. The signing process is done during the image build process by the private key holder and the signatures are then included as a part of the final program image. If configured to do so, the ROM verifies the signatures using the public keys included in the program image. In addition to supporting the digital signature verification to authenticate the program images, the encrypted boot is also supported. The encrypted boot can be used to prevent the cloning of the program image directly off the boot device. A secure boot with HAB can be performed on all boot devices supported on the chip in addition to the serial downloader. The HAB library in the boot ROM also provides the API functions, allowing the additional boot chain components (bootloaders) to extend the secure boot chain. The out-of-fab setting for the SEC_CONFIG is the open configuration, in which the ROM/HAB performs the image authentication, but all authentication errors are ignored and the image is still allowed to execute.
9.3 Boot modes

During reset, the chip checks the power gating controller status register.

During boot, the core's behavior is defined by the boot mode pin settings, as described in Boot mode pin settings. When waking up from the low-power boot mode, the core skips the clock settings. The boot ROM checks that the PERSISTENT_ENTRY0 (see Persistent bits) is a pointer to a valid address space (OCRAM). If the PERSISTENT_ENTRY0 is a pointer to a valid range, it starts the execution using the entry point from the PERSISTENT_ENTRY0 register. If the PERSISTENT_ENTRY0 is a pointer to an invalid range, the core performs the system reset.

9.3.1 Boot mode pin settings

The device has four boot modes (one is reserved for NXP use). The boot mode is selected based on the binary value stored in the internal BOOT_MODE register.

The BOOT_MODE is initialized by sampling the BOOT_MODE0 and BOOT_MODE1 inputs on the rising edge of the POR_B. After these inputs are sampled, their subsequent state does not affect the contents of the BOOT_MODE internal register. The state of the internal BOOT_MODE register may be read from the BMOD[1:0] field of the SRC Boot Mode Register (SRC_SBMR2). The available boot modes are: Boot From Fuses, serial boot via USB, and Internal Boot. See this table for settings:

<table>
<thead>
<tr>
<th>BOOT_MODE[1:0]</th>
<th>Boot Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Boot From Fuses</td>
</tr>
<tr>
<td>01</td>
<td>Serial Downloader</td>
</tr>
<tr>
<td>10</td>
<td>Internal Boot</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table 9-3. Boot MODE pin settings
9.3.2  High-level boot sequence

The figure found here show the high-level boot ROM code flow.

![Diagram of boot flow]

**Figure 9-1. Boot flow**

9.3.3  Boot From Fuses mode (BOOT_MODE[1:0] = 00b)

A value of 00b in the BOOT_MODE[1:0] register selects the Boot From Fuses mode.

This mode is similar to the Internal Boot mode described in Internal Boot mode (BOOT_MODE[1:0] = 0b10) with one difference. In this mode, the GPIO boot override pins are ignored. The boot ROM code uses the boot eFUSE settings only. This mode also supports a secure boot using HAB.
If set to Boot From Fuses, the boot flow is controlled by the BT_FUSE_SEL eFUSE value. If BT_FUSE_SEL = 0, indicating that the boot device (for example, flash) was not programmed yet, the boot flow jumps directly to the Serial Downloader. If BT_FUSE_SEL = 1, the normal boot flow is followed, where the ROM attempts to boot from the selected boot device.

The first time a board is used, the default eFUSEs may be configured incorrectly for the hardware on the platform. In such case, the Boot ROM code may try to boot from a device that does not exist. This may cause an electrical/logic violation on some pads. Using the Boot From Fuses mode addresses this problem.

Setting the BT_FUSE_SEL=0 forces the ROM code to jump directly to the Serial Downloader. This allows a bootloader to be downloaded which can then provision the boot device with a program image and blow the BT_FUSE_SEL and the other boot configuration eFUSEs. After the reset, the boot ROM code determines that the BT_FUSE_SEL is blown (BT_FUSE_SEL = 1) and the ROM code performs an internal boot according to the new eFUSE settings. This allows the user to set BOOT_MODE[1:0]=00b on a production device and burn the fuses on the same device (by forcing the entry to the Serial Downloader), without changing the value of the BOOT_MODE[1:0] or the pullups/pulldowns on the BOOT_MODE pins.

### 9.3.4 Serial Downloader (BOOT_MODE[1:0] = 01b)

The Serial Downloader provides a means to download a Program Image to the chip over USB or UART serial connection. In this mode, typically a host PC can communicate to the ROM bootloader using serial download protocol. Serial downloader and the protocol are discussed in Serial Downloader.

### 9.3.5 Internal Boot mode (BOOT_MODE[1:0] = 0b10)

A value of 0b10 in the BOOT_MODE[1:0] register selects the Internal Boot mode. In this mode, the processor continues to execute the boot code from the internal boot ROM.

The boot code performs the hardware initialization, loads the program image from the chosen boot device, performs the image validation using the HAB library (see Boot security settings), and then jumps to an address derived from the program image. If an error occurs during the internal boot, the boot code jumps to the Serial Downloader (see Serial Downloader (BOOT_MODE[1:0] = 01b)). A secure boot using the HAB is possible in all the three boot modes.
When set to the Internal Boot, the boot flow may be controlled by a combination of eFUSE settings with an option of overriding the fuse settings using the General Purpose I/O (GPIO) pins. The GPIO Boot Select FUSE (BT_FUSE_SEL) determines whether the ROM uses the GPIO pins for a selected number of configuration parameters or eFUSEs in this mode.

- If BT_FUSE_SEL = 1, all boot options are controlled by the eFUSEs described in Boot eFUSE descriptions.
- If BT_FUSE_SEL = 0, the specific boot configuration parameters may be set using the GPIO pins rather than eFUSEs. The fuses that can be overridden when in this mode are indicated in the GPIO column of Boot eFUSE descriptions. GPIO boot overrides provides the details of the GPIO pins.

The use of the GPIO overrides is intended for development since these pads are used for other purposes in the deployed products. NXP recommends controlling the boot configuration by the eFUSEs in the deployed products and reserving the use of the GPIO mode for the development and testing purposes only.

### 9.3.6 Boot security settings

The internal boot modes use one of three security configurations.

- Closed: This level is intended for use with shipping-secure products. All HAB functions are executed and the security hardware is initialized (the Security Controller or SNVS enters the Secure state), the DCD is processed if present, and the program image is authenticated by the HAB before its execution. All detected errors are logged, and the boot flow is aborted with the control being passed to the serial downloader. At this level, the execution does not leave the internal ROM unless the target executable image is authenticated.

- Open: This level is intended for use in non-secure products or during the development phases of a secure product. All HAB functions are executed as for a closed device. The security hardware is initialized (except for the SNVS which is left in the Non-Secure state), the DCD is processed if present, and the program image is authenticated by the HAB before its execution. All detected errors are logged, but have no influence on the boot flow which continues as if the errors did not occur. This configuration is useful for a secure product development because the program image runs even if the authentication data is missing or incorrect, and the error log can be examined to determine the cause of the authentication failure.

- Field Return: This level is intended for the parts returned from the shipped products.
9.4 Device configuration

This section describes the external inputs that control the behavior of the Boot ROM code.

This includes the boot device selection (FlexSPI NOR, FlexSPI NAND, Parallel NOR, SD, MMC, and so on), boot device configuration (SD bus width, speed, and so on), and other. In general, the source for this configuration comes from the eFUSEs embedded inside the chip. However, certain configuration parameters can be sourced from the GPIO pins, allowing further flexibility during the development process.

9.4.1 Boot eFUSE descriptions

This table is a comprehensive list of the configuration parameters that the ROM uses.

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Configuration</th>
<th>Definition</th>
<th>GPIO¹</th>
<th>Shipped value</th>
<th>Settings²</th>
</tr>
</thead>
</table>
| BT_FUSE_SEL     | OEM           | In the Internal Boot mode \texttt{BOOT\_MODE[1:0] = 10}, the BT\_FUSE\_SEL fuse determines whether the boot settings indicated by a Yes in the GPIO column are controlled by the GPIO pins or the eFUSE settings in the On-Chip OTP Controller (OCOTP). In the Boot From Fuse mode \texttt{BOOT\_MODE[1:0] = 00}, the BT\_FUSE\_SEL fuse indicates whether the bit configuration eFuses are programmed. | NA    | 0             | If \texttt{BOOT\_MODE[1:0] = 0b10}:  
  - 0—The bits of the SBMR are overridden by the GPIO pins.  
  - 1—The specific bits of the SBMR are controlled by the eFUSE settings.  
If \texttt{BOOT\_MODE[1:0] = 0b00}  
  - 0—The BOOT configuration eFuses are not programmed yet. The boot flow jumps to the serial downloader.  
  - 1—The BOOT configuration eFuses are programmed. The regular boot flow is performed. |
| FIELD_RETURN    | OEM           | Enables the NXP reserved modes.                                           |       | 0             | 0—The NXP reserved modes are disabled.  
1—The NXP reserved modes are enabled. |
| UNIQUE_ID[63:0] | NXP           | Device Unique ID, 64-bit UID                                               | NA    | Unique ID     | Settings vary—used by HAB |
| BOOT_CFG1[7:0]  | OEM           | Boot configuration 1                                                       | Yes   | 0             | Specific to the selected boot mode |
| BOOT_CFG2[2:0]  | OEM           | Boot configuration 2                                                       | Yes   | 0             | Specific to the selected boot mode |
| LPB_BOOT        | OEM           | Low-Power Boot                                                             | No    | 0             |                                      |
| WDOG_ENABLE     | OEM           | Watchdog reset counter enable                                              | No    | 0             | 0—The watchdog reset counter is disabled during the serial downloader. |

Table continues on the next page...
### Table 9-4. Boot eFUSE descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Configuratio n</th>
<th>Definition</th>
<th>GPIO¹</th>
<th>Shipped value</th>
<th>Settings²</th>
</tr>
</thead>
<tbody>
<tr>
<td>PAD_SETTINGS</td>
<td>OEM</td>
<td>Override values for the SD/MMC and NAND boot modes</td>
<td>No</td>
<td>0</td>
<td>1—The watchdog reset counter is enabled during the serial downloader.</td>
</tr>
</tbody>
</table>

1. This setting can be overridden by the GPIO settings when the BT_FUSE_SEL fuse is intact. See GPIO Boot Overrides for the corresponding GPIO pin.
2. 0 = intact fuse and 1= blown fuse

#### 9.4.2 GPIO boot overrides

This table provides a list of the GPIO boot overrides:

<table>
<thead>
<tr>
<th>Package Pin</th>
<th>Direction on reset</th>
<th>eFuse</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_AD_B0_04/BOOT_MODE0</td>
<td>Input</td>
<td>Boot Mode selection</td>
</tr>
<tr>
<td>GPIO_AD_B0_05/BOOT_MODE1</td>
<td>Input</td>
<td></td>
</tr>
<tr>
<td>GPIO_B0_04</td>
<td>Input</td>
<td>BOOT_CFG1[0]</td>
</tr>
<tr>
<td>GPIO_B0_05</td>
<td>Input</td>
<td>BOOT_CFG1[1]</td>
</tr>
<tr>
<td>GPIO_B0_06</td>
<td>Input</td>
<td>BOOT_CFG1[2]</td>
</tr>
<tr>
<td>GPIO_B0_07</td>
<td>Input</td>
<td>BOOT_CFG1[3]</td>
</tr>
<tr>
<td>GPIO_B0_08</td>
<td>Input</td>
<td>BOOT_CFG1[4]</td>
</tr>
<tr>
<td>GPIO_B0_09</td>
<td>Input</td>
<td>BOOT_CFG1[5]</td>
</tr>
<tr>
<td>GPIO_B0_10</td>
<td>Input</td>
<td>BOOT_CFG1[6]</td>
</tr>
<tr>
<td>GPIO_B0_11</td>
<td>Input</td>
<td>BOOT_CFG1[7]</td>
</tr>
<tr>
<td>GPIO_B0_12</td>
<td>Input</td>
<td>BOOT_CFG2[0]</td>
</tr>
<tr>
<td>GPIO_B0_13</td>
<td>Input</td>
<td>BOOT_CFG2[1]</td>
</tr>
<tr>
<td>GPIO_B0_14</td>
<td>Input</td>
<td>BOOT_CFG2[2]</td>
</tr>
<tr>
<td>GPIO_B0_15</td>
<td>Input</td>
<td>BOOT_CFG2[3]</td>
</tr>
</tbody>
</table>
NOTE
Refer to the Fusemap chapter for more information on fuses mapped to the GPIO pins.

The input pins provided are sampled at boot, and can be used to override the corresponding eFUSE values, depending on the setting of the BT_FUSE_SEL fuse.

9.4.3 Device Configuration Data (DCD)

The DCD is the configuration information contained in the program image (external to the ROM) that the ROM interprets to configure various on-chip peripherals. See Device Configuration Data (DCD) for more details on DCD.

9.5 Device initialization

This section describes the details of the ROM and provides the initialization details.

This includes details on:

- The ROM memory map
- The RAM memory map
- On-chip blocks that the ROM must use or change the POR register default values
- Clock initialization
- Enabling the L1 I/D cache
- Exception handling and interrupt handling

9.5.1 Internal ROM/RAM memory map

These figures show the internal ROM and RAM memory map:
NOTE
The entire OCRAM region can be used freely after the boot.

9.5.2 Boot block activation

The boot ROM affects a number of different hardware blocks which are activated and play a vital role in the boot flow.

The ROM configures and uses the following blocks (listed in an alphabetical order) during the boot process. Note that the blocks actually used depend on the boot mode and the boot device selection:

<table>
<thead>
<tr>
<th>Block</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM</td>
<td>Clock Control Module</td>
</tr>
<tr>
<td>FlexSPI</td>
<td>Flexible SPI Interface which supports serial NOR, Serial NAND and serial RAM devices</td>
</tr>
<tr>
<td>OCOTP</td>
<td>On Chip One Time Programmable Controller containing the eFUSEs</td>
</tr>
<tr>
<td>IOMUXC</td>
<td>I/O Multiplexer Control which allows the GPIO use to override the eFUSE boot settings</td>
</tr>
<tr>
<td>IOMUX GPR</td>
<td>I/O Multiplexer control General Purpose Registers</td>
</tr>
<tr>
<td>LPSPI</td>
<td>Low Power SPI interface which supports serial NOR/EEPROM devices</td>
</tr>
<tr>
<td>SEMC</td>
<td>Smart External Memory Controller which supports parallel NOR and RAWNAND (SLC) devices</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Block Description

- **SNVS**: Secure Non-Volatile Storage
- **SRC**: System Reset Controller
- **USB**: Used for Serial download of a boot device provisioning program
- **uSDHC**: Ultra-Secure Digital Host Controller
- **WDOG 1**: WatchDog Timer
- **TRNG**: True Random Number Generator
- **PIT**: Periodic Interrupt Timer

#### 9.5.3 Clocks at boot time

The table below shows the various clocks and their sources used by the ROM.

**Table 9-6. Normal Frequency Clock Configurations**

<table>
<thead>
<tr>
<th>BOOT_FREQ(0x460[2])</th>
<th>LPB_BOOT(0x470[22:21])</th>
<th>Core Clock Frequency(MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>396</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>198</td>
</tr>
<tr>
<td></td>
<td>2</td>
<td>99</td>
</tr>
<tr>
<td></td>
<td>3</td>
<td>49.5</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>528</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>264</td>
</tr>
<tr>
<td></td>
<td>2</td>
<td>132</td>
</tr>
<tr>
<td></td>
<td>3</td>
<td>66</td>
</tr>
</tbody>
</table>

Following reset, the Arm core has access to all peripherals. The ROM code will disable the clocks associated with the following Clock Gate Enables. See the CCM Chapter's System Clocks section for information about the CCM output clocks' system-level connectivity.

**Table 9-7. List of Disabled Clock Gate Enables**

<table>
<thead>
<tr>
<th>Clock Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_CCGR0.CG6</td>
</tr>
<tr>
<td>CCM_CCGR0.CG7</td>
</tr>
<tr>
<td>CCM_CCGR0.CG8</td>
</tr>
<tr>
<td>CCM_CCGR0.CG9</td>
</tr>
<tr>
<td>CCM_CCGR0.CG10</td>
</tr>
<tr>
<td>CCM_CCGR0.CG12</td>
</tr>
<tr>
<td>CCM_CCGR0.CG13</td>
</tr>
<tr>
<td>CCM_CCGR0.CG14</td>
</tr>
</tbody>
</table>
Table 9-7. List of Disabled Clock Gate Enables (continued)

<table>
<thead>
<tr>
<th>Clock Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_CCGR1_CG0</td>
</tr>
<tr>
<td>CCM_CCGR1_CG1</td>
</tr>
<tr>
<td>CCM_CCGR1_CG2</td>
</tr>
<tr>
<td>CCM_CCGR1_CG3</td>
</tr>
<tr>
<td>CCM_CCGR1_CG4</td>
</tr>
<tr>
<td>CCM_CCGR1_CG5</td>
</tr>
<tr>
<td>CCM_CCGR1_CG6</td>
</tr>
<tr>
<td>CCM_CCGR1_CG8</td>
</tr>
<tr>
<td>CCM_CCGR1_CG12</td>
</tr>
<tr>
<td>CCM_CCGR2_CG1</td>
</tr>
<tr>
<td>CCM_CCGR2_CG3</td>
</tr>
<tr>
<td>CCM_CCGR2_CG4</td>
</tr>
<tr>
<td>CCM_CCGR2_CG5</td>
</tr>
<tr>
<td>CCM_CCGR2_CG14</td>
</tr>
<tr>
<td>CCM_CCGR2_CG15</td>
</tr>
<tr>
<td>CCM_CCGR3_CG0</td>
</tr>
<tr>
<td>CCM_CCGR3_CG1</td>
</tr>
<tr>
<td>CCM_CCGR3_CG3</td>
</tr>
<tr>
<td>CCM_CCGR3_CG5</td>
</tr>
<tr>
<td>CCM_CCGR3_CG10</td>
</tr>
<tr>
<td>CCM_CCGR3_CG11</td>
</tr>
<tr>
<td>CCM_CCGR3_CG12</td>
</tr>
<tr>
<td>CCM_CCGR3_CG13</td>
</tr>
<tr>
<td>CCM_CCGR4_CG8</td>
</tr>
<tr>
<td>CCM_CCGR4_CG9</td>
</tr>
<tr>
<td>CCM_CCGR4_CG10</td>
</tr>
<tr>
<td>CCM_CCGR4_CG11</td>
</tr>
<tr>
<td>CCM_CCGR4_CG12</td>
</tr>
<tr>
<td>CCM_CCGR4_CG13</td>
</tr>
<tr>
<td>CCM_CCGR4_CG14</td>
</tr>
<tr>
<td>CCM_CCGR4_CG15</td>
</tr>
<tr>
<td>CCM_CCGR5_CG1</td>
</tr>
<tr>
<td>CCM_CCGR5_CG3</td>
</tr>
<tr>
<td>CCM_CCGR5_CG4</td>
</tr>
<tr>
<td>CCM_CCGR5_CG7</td>
</tr>
<tr>
<td>CCM_CCGR5_CG9</td>
</tr>
<tr>
<td>CCM_CCGR5_CG10</td>
</tr>
<tr>
<td>CCM_CCGR5_CG11</td>
</tr>
<tr>
<td>CCM_CCGR5_CG12</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-7. List of Disabled Clock Gate Enables (continued)

<table>
<thead>
<tr>
<th>Clock Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_CCGR5_CG13</td>
</tr>
<tr>
<td>CCM_CCGR6_CG0</td>
</tr>
<tr>
<td>CCM_CCGR6_CG1</td>
</tr>
<tr>
<td>CCM_CCGR6_CG2</td>
</tr>
<tr>
<td>CCM_CCGR6_CG5</td>
</tr>
<tr>
<td>CCM_CCGR6_CG6</td>
</tr>
<tr>
<td>CCM_CCGR6_CG7</td>
</tr>
<tr>
<td>CCM_CCGR6_CG8</td>
</tr>
<tr>
<td>CCM_CCGR6_CG12</td>
</tr>
<tr>
<td>CCM_CCGR6_CG13</td>
</tr>
<tr>
<td>CCM_CCGR6_CG14</td>
</tr>
<tr>
<td>CCM_CCGR6_CG15</td>
</tr>
</tbody>
</table>

The boot ROM configures critical clock-related registers as follows, boot at 396 MHz by default:

<table>
<thead>
<tr>
<th>Clock Name</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_ANALOG_PLL_ARM</td>
<td>0x80002402</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_SYS</td>
<td>0x80002001</td>
</tr>
<tr>
<td>CCM_ANALOG_PLL_USB1</td>
<td>0x80003040</td>
</tr>
<tr>
<td>CCM_ANALOG_PFD_528</td>
<td>0x18131818</td>
</tr>
<tr>
<td>CCM_ANALOG_PFD_480</td>
<td>0x1F1A2323</td>
</tr>
<tr>
<td>CCM_CACRR</td>
<td>0x00000001</td>
</tr>
<tr>
<td>CCM_CBCDR</td>
<td>0x000A8200</td>
</tr>
<tr>
<td>CCM_CSCDR1</td>
<td>0x06490B0C</td>
</tr>
<tr>
<td>CCM_CBCMR</td>
<td>0x35AE8304</td>
</tr>
<tr>
<td>CCM_CSCMR1</td>
<td>0x67830001</td>
</tr>
</tbody>
</table>

9.5.4 Enabling Caches

The boot ROM includes a feature that enables the caches to improve the boot speed.

L1 instruction cache is enabled at the start of image download. And, the L1 data cache is enabled at the start of image authentication.

By default, the L1-ICache and DCache are enabled by ROM. However, there are fuse bits that can be programmed for ROM not to enable the L1 I/DCache at boot.
The Cache features are controlled by the BT_ICACHE_DISABLE fuse and BT_DCACHE_DISABLE fuses. By default, both fuses are not blown meaning the ROM uses the L1-ICache and L1-DCache of the Arm core. This improves the performance of the HAB signature verification software.

### 9.5.5 Exception handling

The exception vectors (interrupt vectors/vector table) are located at the start of ROM. During the boot phase, CPU loads the SP and PC from exception vectors and then boot to ROM.

After booting, the program image can relocate the vectors as required.

### 9.5.6 Interrupt handling during boot

No special interrupt-handling routines are required during the boot process. The interrupts are disabled during the boot ROM execution and may be enabled in a later boot stage.

### 9.5.7 Persistent bits

Some modes of the boot ROM require the registers that keep their values after a warm reset. The SRC General-Purpose registers are used for this purpose.

See this table for persistent bits list and description:

<table>
<thead>
<tr>
<th>Table 9-8. Persistent bits</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Bit name</strong></td>
</tr>
<tr>
<td>---------------</td>
</tr>
<tr>
<td>PERSIST_SECONDARY_BOOT</td>
</tr>
<tr>
<td>PERSISTENT_ENTRY0[31:0]</td>
</tr>
<tr>
<td>PERSISTENT_ARG0[31:0]</td>
</tr>
<tr>
<td>PERSIST_REDUNDANT_BOOT</td>
</tr>
</tbody>
</table>
9.6 Boot devices

The chip supports the following boot flash devices:

- Serial NOR flash via FlexSPI Interface
- Serial NAND Flash via FlexSPI Interface
- Parallel NOR flash with the Smart External Memory Controller (SEMC), located on CS0, 16-bit bus width.
- NAND Flash with SEMC interface, located on CS0, 8-bit/16-bit bus width.
- SD/MMC/eSD/SDXC/eMMC4.4 via uSDHC interface, supporting high capacity cards
- Serial NOR/EEPROM boot via LPSPI

The selection of the external boot device type is controlled by the BOOT_CFG1[7:4] eFUSEs. See this table for more details:

<table>
<thead>
<tr>
<th>BOOT_CFG1[7:4]</th>
<th>Boot device</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000b</td>
<td>Serial NOR boot via FlexSPI</td>
</tr>
<tr>
<td>01xxb</td>
<td>SD Boot via uSDHC</td>
</tr>
<tr>
<td>10xxb</td>
<td>eMMC/MMC boot via uSDHC</td>
</tr>
<tr>
<td>001xb</td>
<td>SLC NAND boot via SEMC</td>
</tr>
<tr>
<td>0001b</td>
<td>Parallel NOR boot via SEMC</td>
</tr>
<tr>
<td>11xxb</td>
<td>Serial NAND boot via FlexSPI</td>
</tr>
</tbody>
</table>

**NOTE**

A user can use the LPSPI to boot from Serial NOR/EEPROM. Booting from Serial NOR/EEPROM via an LPSPI port is not intended as the primary device, but as a recovery boot device if the primary boot device fails.

In order to enable a recovery boot device, EEPROM_RECOVERY_EN fuse must be set to 1, and other fuses listed in Serial NOR/EEPROM eFUSE configuration must be properly set.

9.6.1 Serial NOR Flash Boot via FlexSPI
### 9.6.1.1 Serial NOR eFUSE Configuration

#### Table 9-10. Fuse definition for Serial NOR over FlexSPI

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>BOOT_CFG1[0]</td>
<td>OEM</td>
<td>xSPI FLASH Auto Probe</td>
<td>Yes</td>
<td>0</td>
<td>0 – Disabled, 1 – Enabled</td>
</tr>
<tr>
<td>BOOT_CFG1[1]</td>
<td>OEM</td>
<td>Encrypted XIP</td>
<td>Yes</td>
<td>0</td>
<td>0 – Disabled, 1 – Enabled</td>
</tr>
<tr>
<td>BOOT_CFG1[3:2]</td>
<td>OEM</td>
<td>xSPI FLASH Auto Probe Type</td>
<td>Yes</td>
<td>0</td>
<td>0 – QuadSPI NOR, 1 – MXIC Octal, 2 – Micron Octal, 3 – Adesto Octal</td>
</tr>
<tr>
<td>BOOT_CFG1[7:4]</td>
<td>OEM</td>
<td>Boot device selection</td>
<td>Yes</td>
<td>0</td>
<td>0 – Serial NOR device is selected as boot device</td>
</tr>
<tr>
<td>BOOT_CFG2[2:0]</td>
<td>OEM</td>
<td>Flash Type</td>
<td>Yes</td>
<td>0</td>
<td>000b–Device supports 3B (0x03 + 24-bit Address) read by default (command: 0x03, SPI mode), 001b–Device supports 4B (0x13 + 24-bit Address) read by default (command: 0x13, SPI mode), 010b–HyperFlash 1V8 (HyperBus Protocol), 011b–HyperFlash 3V3 (HyperBus protocol), 100b–MXIC Octal DDR (command: 0xEE,0x11, OPI mode), 101b–Micron Octal DDR (command: 0xFD, OPI mode), 110b–Reserved, 111b–QSPI device supports 3B read by default (on secondary pinmux option) (command: 0x03, SPI mode)</td>
</tr>
<tr>
<td>0x6E0[3:1]</td>
<td>OEM</td>
<td>xSPI FLASH Frequency</td>
<td>No</td>
<td>0</td>
<td>0 – 100MHz, 1 – 120MHz, 2 – 133MHz, 3 – 166MHz, 5 – 80MHz, 6 – 60MHz, Others – Reserved</td>
</tr>
<tr>
<td>(BOOT_CONFIG_MISC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x6E0[5:4]</td>
<td>OEM</td>
<td>Hold time before access the Flash device</td>
<td>No</td>
<td>0</td>
<td>0 – 500us, 1 – 1ms, 2 – 3ms</td>
</tr>
<tr>
<td>(BOOT_CONFIG_MISC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 9-10. Fuse definition for Serial NOR over FlexSPI (continued)

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x6E0[11:8]</td>
<td>OEM</td>
<td>xSPI FLASH Dummy Cycle</td>
<td>No</td>
<td>0</td>
<td>3 – 10ms</td>
</tr>
<tr>
<td>(BOOT_CONFIG_MISC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 – Dummy cycles is auto-probed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Others – Actual dummy cycles for Read command</td>
</tr>
<tr>
<td>0x6E0[15:12]</td>
<td>OEM</td>
<td>xSPI FLASH image size</td>
<td>No</td>
<td>0</td>
<td>0 – Image size equals to Secondary Image offset</td>
</tr>
<tr>
<td>(BOOT_CONFIG_MISC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 – 1MB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>2 – 2MB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>... – ...</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>12 – 12MB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>13 – 256KB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>14 – 512KB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>15 – 768KB</td>
</tr>
<tr>
<td>0x6E0[23:16]</td>
<td>OEM</td>
<td>xSPI_FLASH_SEC_IMAGE_OF_FSET</td>
<td>No</td>
<td>0</td>
<td>Offset = 256KB × fuse value</td>
</tr>
<tr>
<td>(BOOT_CONFIG_MISC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTE**

If the xSPI FLASH Auto Probe feature is enabled, the following is the logic how this feature works with other fuse combinations:

- Flash Type - If Flash type is 0, the "xSPI FLASH Auto Probe Type" takes effect for the Flash type selection. If Flash Type is greater than 1, the "Flash Type" Fuse is used for Flash type selection, ROM will issue specific command to probe the presence of Serial NOR FLASH.
- xSPI FLASH Frequency - This field is used for specifying the Flash working frequency.

#### 9.6.1.2 FlexSPI Serial NOR Flash Boot Operation

The Boot ROM attempts to boot from Serial NOR flash if the BOOT_CFG1 [7:4] fuses are programmed to 0b’0000 as shown in the Serial NOR eFUSE Configuration table, then the ROM will initialize FlexSPI interface. FlexSPI interface initialization is a two-step process.

1. The ROM expects the 512-byte FlexSPI NOR configuration parameters (as explained in the next section) to be present at offset 0x400 in Serial NOR flash attached to
FLEXSPI_A_SS0_B. The ROM can probe the presence of Serial NOR Flash and generate these configuration parameters accordingly via the combination of Fuses in the table above, or reads these configuration parameters using the read command specified by BOOT_CFG2[2:0] with serial clock operating at 30 MHz.

2. ROM configures FlexSPI interface with the parameters provided in configuration block read from Serial NOR flash and starts the boot procedure. Refer to Table 9-18 for details regarding FlexSPI configuration parameters and to the FlexSPI NOR boot flow chart for detailed boot flow chart of FlexSPI NOR.

Both booting an XIP and non XIP image are supported from Serial NOR Flash. For XIP boot, the image has to be built for FlexSPI address space; and for non XIP, the image can be built to execute from internal RAM.

**NOTE**

A non-XIP image's execute address space should NOT be overlapped with the reserved OCRAM region described in the section "Internal ROM/RAM memory map". And it is also highly recommended to avoid using address space near 0x00000000, typically up to 0x00000003.
9.6.1.3 FlexSPI NOR boot flow chart

Start

Configure FlexSPI Pinmux and Clock to 30MHz to perform basic read operation or flash probe operation

Get Configuration parameter

Configure IOMUXC, LUT, controller and clock based on the configuration parameter read from Flash device

Configure Flash device to desired mode based on configuration parameter

Set boot device parameter (initial image address, memory range, etc).

Image == XIP

Yes

Execute the image from FlexSPI address space

No

Copy image to OCRAM

End

Figure 9-3. FlexSPI NOR boot flow

9.6.2 Serial NAND Flash Boot over FlexSPI

The boot ROM supports a number of Serial NAND Flash devices from different vendors. The Embedded Error Correction and Control (ECC) module in SPI NAND devices are used to detect and correct the errors.
9.6.2.1 Serial NAND eFUSE Configuration

The boot ROM determines the configuration of external Serial NAND flash by parameters, either provided by eFUSE, or sampled on GPIO pins during boot. See below table for parameters details.

Table 9-11. Fuse definition for Serial NAND over FlexSPI

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>BOOT_CFG1[1:0]</td>
<td>OEM</td>
<td>Search Stride for FCB and DBBT Search strides in terms of page</td>
<td>Yes</td>
<td>0</td>
<td>0 - 64&lt;br&gt;1 - 128&lt;br&gt;2 - 256&lt;br&gt;3 - 32</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>OEM</td>
<td>Hold Time before access to Serial NAND</td>
<td>Yes</td>
<td>0</td>
<td>0 - Hold time determined by Read Status command&lt;br&gt;1 - 500us&lt;br&gt;2 - 1ms&lt;br&gt;3 - 3ms</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>OEM</td>
<td>Column address width</td>
<td>Yes</td>
<td>0</td>
<td>0 - 12 bits&lt;br&gt;1 - 13 bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>OEM</td>
<td>Default safe communication frequency</td>
<td>Yes</td>
<td>0</td>
<td>0 – High Speed (50MHz)&lt;br&gt;1 – Low Speed (30MHz)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>OEM</td>
<td>Primary boot device selection</td>
<td>Yes</td>
<td>0</td>
<td>00 – Serial NOR&lt;br&gt;11 – Serial NAND</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>OEM</td>
<td>Boot Search Count of FCB and DBBT</td>
<td>Yes</td>
<td>0</td>
<td>0 – 1&lt;br&gt;1 – 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>OEM</td>
<td>CS de-asserted interval between two commands</td>
<td>Yes</td>
<td>0</td>
<td>0 – 100ns&lt;br&gt;1 – 200ns&lt;br&gt;2 – 400ns&lt;br&gt;3 – 50ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0xE0[7]</td>
<td>OEM</td>
<td>SPI NAND BOOT - Override Busy Offset</td>
<td>No</td>
<td>0</td>
<td>0 – Use default busy bit offset 0&lt;br&gt;1 – Override default busy bit offset using Busy bit offset</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0xE0[3:0]</td>
<td>OEM</td>
<td>SPI NAND BOOT - Busy Bit offset</td>
<td>No</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0xE0[13:8]</td>
<td>OEM</td>
<td>SPI NAND Boot - Page Read Time (in terms of micro seconds)</td>
<td>No</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-11. Fuse definition for Serial NAND over FlexSPI (continued)

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x6E0[23:16]</td>
<td>OEM</td>
<td>Page Read Command</td>
<td>No</td>
<td>0</td>
<td>Available only if it is not 0</td>
</tr>
<tr>
<td>0x6F0[31:24]</td>
<td>OEM</td>
<td>Cache Read command</td>
<td>No</td>
<td>0</td>
<td>Available only if it is not 0</td>
</tr>
</tbody>
</table>

NOTE

BOOT_CFGx sampled on GPIO pins depends on BT_FUSE_SEL setting.

9.6.2.2 FlexSPI NAND Flash Boot Flow and Boot Control Blocks (BCB)

There are two BCB data structures:

- FCB
- DBBT

As part of the NAND media initialization, the ROM driver uses safe NAND timings to search for a Firmware Configuration Block (FCB) that contains the optimum NAND timings, page address of Discovered Bad Block Table (DBBT) Search Area and start page address of primary and secondary firmware.

The built-in HW ECC in Serial NAND device is used during data read, the FCB data structure is protected using CRC checksum. Driver reads raw 2048 bytes of first sector and runs through CRC check that determines whether FCB data is valid or not.

If the FCB is found, the optimum NAND timings are loaded for further reads. If the ECC fails, or the fingerprints do not match, the Block Search state machine increments page number to Search Stride number of pages to read for the next BCB until SearchCount pages have been read.

If search fails to find a valid FCB, the NAND driver responds with an error and the boot ROM enters into serial download mode.

The FCB contains the page address of DBBT Search Area, and the page address for primary and secondary boot images. DBBT is searched in DBBT Search Area just like how FCB is searched. After the FCB is read, the DBBT is loaded, and the primary or secondary boot image is loaded using starting page address from FCB.

Figure 9-4 shows the state diagram of FCB search.
Figure 9-4. FCB Search Flow

After FCB is found, the boot ROM searches for the Discovered Bad Blocks Table (DBBT). If DBBTSearchStartPage is 0 in the FCB, then ROM assumes that there are no bad blocks in the NAND device boot area. See Figure 9-5 for the DBBT search flow.
Figure 9-5. DBBT Search Flow

The BCB search and load function also monitors the ECC correction threshold and sets the PERSIST_BLOCK_REWRITE persistent bit if the threshold exceeds the maximum ECC correction ability.

If during primary image read there is a page with a number of errors higher than ECC can correct, the boot ROM will turn on PERSISTSECONDARY_BOOT bit and perform SW reset (After SW reset, secondary image is used).
If during secondary image read there is a page with number of errors higher than ECC can correct, the boot ROM goes to serial loader.

### 9.6.2.3 Firmware Configuration Block

The FCB is at the first page in the first good block. The FCB should be present at each search stride of the search area.

The search area contains copies of the FCB at each stride distance, in case the first Serial NAND block becomes corrupted, the ROM will find its copy in the next Serial NAND block. The search area should span over at least two Serial NAND blocks. The location information for DBBT search area and images are all specified in the FCB. The following table shows the Flash Control Block Structure.

**Table 9-12. Flash Control Block Structure**

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size Bytes</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>crcChecksum</td>
<td>0x000</td>
<td>4</td>
<td>Checksum</td>
</tr>
<tr>
<td>fingerprint</td>
<td>0x004</td>
<td>4</td>
<td>0x4E46_4342 ASCII: “NFCB”</td>
</tr>
<tr>
<td>version</td>
<td>0x008</td>
<td>4</td>
<td>0x0000_0001</td>
</tr>
<tr>
<td>DBBTSearchStartPage</td>
<td>0x00C</td>
<td>4</td>
<td>Start Page address for bad block table search area</td>
</tr>
<tr>
<td>searchStride</td>
<td>0x010</td>
<td>2</td>
<td>Search stride for DBBT and FCB search. Not used by ROM Max value is 8.</td>
</tr>
<tr>
<td>searchCount</td>
<td>0x012</td>
<td>2</td>
<td>Copies of DBBT and FCB. Not used by ROM, max value is 8.</td>
</tr>
<tr>
<td>firmwareCopies</td>
<td>0x014</td>
<td>4</td>
<td>Firmware copies</td>
</tr>
<tr>
<td>Reserved</td>
<td>0x018</td>
<td>40</td>
<td>Reserved for future use Must be set to 0.</td>
</tr>
<tr>
<td>firmwareInfoTable</td>
<td>0x40</td>
<td>64</td>
<td>This table consists of (up to 8 entries):</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Size</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>StartPage</td>
<td>4</td>
<td>Start page of this firmware</td>
</tr>
<tr>
<td>pageCount</td>
<td>4</td>
<td>Pages in this firmware</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 9-12. Flash Control Block Structure (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size Bytes</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td>0x080</td>
<td>128</td>
<td>Reserved</td>
</tr>
<tr>
<td>spiNandConfigBlock</td>
<td>0x100</td>
<td>512</td>
<td>Serial NAND configuration block over FlexSPI</td>
</tr>
<tr>
<td>Reserved</td>
<td>0x300</td>
<td>256</td>
<td>Must be set to 0</td>
</tr>
</tbody>
</table>

NOTE:

1. The “crcChecksum” is calculated with an MPEG2 variant of CRC-32. See Table 9-13 for more details.
2. The “crcChecksum” calculation starts from fingerprint to the end of FCB, 1020 bytes in total.
3. The “spiNandConfigBlock” is FlexSPI NAND configuration block which consists of common FlexSPI memory configuration block and Serial NAND specified configuration parameters.

Table 9-13. CRC-32 variant algorithm

<table>
<thead>
<tr>
<th>Property</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Width</td>
<td>32 bits</td>
</tr>
<tr>
<td>Polynomial</td>
<td>0x04C11DB7</td>
</tr>
<tr>
<td>Init Value</td>
<td>0xFFFFFFFF</td>
</tr>
<tr>
<td>Reflect in</td>
<td>False</td>
</tr>
<tr>
<td>Reflect Out</td>
<td>False</td>
</tr>
<tr>
<td>XOR Out</td>
<td>0x00000000</td>
</tr>
</tbody>
</table>

9.6.2.4 Discovered Bad Blocks Table (DBBT)

Table 9-14. DBBT Structure

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size in Bytes</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>crcChecksum</td>
<td>0x000</td>
<td>4</td>
<td>Checksum</td>
</tr>
<tr>
<td>Fingerprint</td>
<td>0x004</td>
<td>4</td>
<td>32-bit word with a value of 0x4442_4254, in ASCII “DBBT”</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 9-14. DBBT Structure (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size in Bytes</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Version</td>
<td>0x008</td>
<td>4</td>
<td>32-bit version number, this version of DBBT is 0x00000001</td>
</tr>
<tr>
<td>-</td>
<td>0x00C</td>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>badBlockNumber</td>
<td>0x010</td>
<td>4</td>
<td>Number of bad blocks</td>
</tr>
<tr>
<td>Reserved</td>
<td>0x014</td>
<td>12</td>
<td>Must be filled with 0x00s</td>
</tr>
<tr>
<td>Bad Block entries</td>
<td>0x020</td>
<td>1024 (256*4)</td>
<td>Each bad block entry is a 32-bit value specifying the number of a found bad block. The number of valid bad block entries is specified by the badBlockNumber field, where valid bad block entries are stored sequentially starting at the beginning of the bad block entries segment. Unused bad block entries (those beyond the badBlockNumber) should be filled with 0xFs.</td>
</tr>
</tbody>
</table>

**NOTE**

1. Maximum badBlockNumber is 256.
2. The "crcChecksum" is calculated with the same algorithm as the one in FCB, from Fingerprint to the end of DBBT, 1052 bytes in total.

### 9.6.2.5 Bad block handling in ROM

During the firmware boot, at the block boundary, the Bad Block table is searched for a match to the next block.

If no match is found, the next block can be loaded. If a match is found, the block must be skipped and the next block checked.

### 9.6.3 Serial NOR and NAND configuration based on FlexSPI interface

The ROM SW supports Serial NOR and Serial NAND based on FlexSPI module, using a 448-bytes common FlexSPI configuration block and several specified parameters for Serial NOR and Serial NAND respectively. See the following sections for more details.
### 9.6.3.1 FlexSPI Configuration Block

FlexSPI Configuration block consists of parameters regarding specific Flash devices including read command sequence, quad mode enablement sequence (optional), etc.

Table 9-15. FlexSPI Configuration block

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size(bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tag</td>
<td>0x000</td>
<td>4</td>
<td>0x42464346, ascii: 'FCFB'</td>
</tr>
<tr>
<td>Version</td>
<td>0x004</td>
<td>4</td>
<td>0x56010000 / 0x56010100 [07:00] bugfix = 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[15:08] minor [23:16] major = 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[31:24] ascii 'V'</td>
</tr>
<tr>
<td>-</td>
<td>0x008</td>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>readSampleClkSrc</td>
<td>0x00C</td>
<td>1</td>
<td>0 – internal loopback 1 – loopback from DQS pad 3 – Flash provided DQS</td>
</tr>
<tr>
<td>csHoldTime</td>
<td>0x00D</td>
<td>1</td>
<td>Serial Flash CS Hold Time Recommend default value is 0x03</td>
</tr>
<tr>
<td>csSetupTime</td>
<td>0x00E</td>
<td>1</td>
<td>Serial Flash CS setup time Recommend default value is 0x03</td>
</tr>
<tr>
<td>columnAdressWidth</td>
<td>0x00F</td>
<td>1</td>
<td>3 – For HyperFlash 12/13 – For Serial NAND, see datasheet to find correct value 0 – Other devices</td>
</tr>
<tr>
<td>deviceModeCfgEnable</td>
<td>0x010</td>
<td>1</td>
<td>Device Mode Configuration Enable feature</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 – Disabled 1 – Enabled</td>
</tr>
<tr>
<td>-</td>
<td>0x011</td>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>waitTimeCfgCommands</td>
<td>0x013</td>
<td>2</td>
<td>Wait time for all configuration commands, unit 100us. Available for device that support v1.1.0 FlexSPI configuration block. If it is greater than 0, ROM will wait waitTimeCfgCommands * 100us for all device memory configuration commands instead of using read status to wait until these commands complete.</td>
</tr>
<tr>
<td>deviceModeSeq</td>
<td>0x014</td>
<td>4</td>
<td>Sequence parameter for device mode configuration Bit[7:0] - number of LUT sequences for Device mode configuration command Bit[15:8] - starting LUT index of Device mode configuration command Bit[31:16] - must be 0</td>
</tr>
<tr>
<td>deviceModeArg</td>
<td>0x018</td>
<td>4</td>
<td>Device Mode argument, effective only when deviceModeCfgEnable = 1</td>
</tr>
<tr>
<td>configCmdEnable</td>
<td>0x01C</td>
<td>1</td>
<td>Config Command Enable feature</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size(bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 – Disabled</td>
<td>0x01D</td>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>configCmdSeqs</td>
<td>0x020</td>
<td>12</td>
<td>Sequences for Config Command, allow 3 separate configuration command sequences.</td>
</tr>
<tr>
<td>0 – Enabled</td>
<td>0x02C</td>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>cfgCmdArgs</td>
<td>0x030</td>
<td>12</td>
<td>Arguments for each separate configuration command sequence.</td>
</tr>
<tr>
<td>0 – Reserved</td>
<td>0x03C</td>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>controllerMiscOption</td>
<td>0x040</td>
<td>4</td>
<td>Bit0 – differential clock enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bit1 – CK2 enable, must set to 0 in this silicon</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bit2 – ParallelModeEnable, must set to 0 for this silicon</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bit3 – wordAddressableEnable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bit4 – Safe Configuration Frequency enable set to 1 for the devices that support DDR Read instructions</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bit5 – Pad Setting Override Enable</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Bit6 – DDR Mode Enable, set to 1 for device supports DDR read command</td>
</tr>
<tr>
<td>deviceType</td>
<td>0x044</td>
<td>1</td>
<td>1 – Serial NOR</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – Serial NAND</td>
</tr>
<tr>
<td>sflashPadType</td>
<td>0x045</td>
<td>1</td>
<td>1 – Single pad</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – Dual pads</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – Quad pads</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>8 – Octal pads</td>
</tr>
<tr>
<td>serialClkFreq</td>
<td>0x046</td>
<td>1</td>
<td>Chip specific value, for this silicon</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – 30 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – 50 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3 – 60 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – 75 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>5 – 80 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>6 – 100 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>7 – 120 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>8 – 133 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>9 – 166 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Other value: 30 MHz</td>
</tr>
<tr>
<td>lutCustomSeqEnable</td>
<td>0x047</td>
<td>1</td>
<td>0 – Use pre-defined LUT sequence index and number</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 - Use LUT sequence parameters provided in this block</td>
</tr>
<tr>
<td>0 – Reserved</td>
<td>0x048</td>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>sflashA1Size</td>
<td>0x050</td>
<td>4</td>
<td>For SPI NOR, need to fill with actual size</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 9-15. FlexSPI Configuration block (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size(bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>sflashA2Size</td>
<td>0x054</td>
<td>4</td>
<td>For SPI NAND, need to fill with actual size * 2</td>
</tr>
<tr>
<td>sflashB1Size</td>
<td>0x058</td>
<td>4</td>
<td>The same as above</td>
</tr>
<tr>
<td>sflashB2Size</td>
<td>0x05C</td>
<td>4</td>
<td>The same as above</td>
</tr>
<tr>
<td>csPadSettingOverride</td>
<td>0x060</td>
<td>4</td>
<td>Set to 0 if it is not supported</td>
</tr>
<tr>
<td>sclkPadSettingOverride</td>
<td>0x064</td>
<td>4</td>
<td>Set to 0 if it is not supported</td>
</tr>
<tr>
<td>dataPadSettingOverride</td>
<td>0x068</td>
<td>4</td>
<td>Set to 0 if it is not supported</td>
</tr>
<tr>
<td>dqspadSettingOverride</td>
<td>0x06C</td>
<td>4</td>
<td>Set to 0 if it is not supported</td>
</tr>
<tr>
<td>timeoutInMs</td>
<td>0x070</td>
<td>0</td>
<td>Maximum wait time during read busy status</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 – Disabled timeout checking feature</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Other value – Timeout if the wait time exceeds this value.</td>
</tr>
<tr>
<td>commandInterval</td>
<td>0x074</td>
<td>4</td>
<td>Unit: ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Currently, it is used for SPI NAND only at high frequency</td>
</tr>
<tr>
<td>dataValidTime</td>
<td>0x078</td>
<td>4</td>
<td>Time from clock edge to data valid edge, unit ns.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>This field is used when the FlexSPI Root clock is less than 100 MHz and</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>the read sample clock source is device provided DQS signal without CK2 support.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[31:16] data valid time for DLLB in terms of 0.1 ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[15:0] data valid time for DLLA in terms of 0.1 ns</td>
</tr>
<tr>
<td>busyOffset</td>
<td>0x07C</td>
<td>2</td>
<td>busy bit offset, valid range :0-31</td>
</tr>
<tr>
<td>busyBitPolarity</td>
<td>0x07E</td>
<td>2</td>
<td>0 – busy bit is 1 if device is busy</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – busy bit is 0 if device is busy</td>
</tr>
<tr>
<td>lookupTable</td>
<td>0x080</td>
<td>256</td>
<td>Lookup table</td>
</tr>
<tr>
<td>lutCustomSeq</td>
<td>0x180</td>
<td>48</td>
<td>Customized LUT sequence, see below table for details.</td>
</tr>
<tr>
<td></td>
<td>0x1B0</td>
<td>16</td>
<td>Reserved for future use</td>
</tr>
</tbody>
</table>

**Note:**

1. To customize the LUT sequence for some specific device, users need to enable “lutCustomSeqEnable” and fill in corresponding “lutCustomSeq” field specified by command index below.

2. For Serial (SPI) NOR, the pre-defined LUT index is as follows:

#### Table 9-16. LUT sequence definition for Serial NOR

<table>
<thead>
<tr>
<th>Command Index</th>
<th>Name</th>
<th>Index in lookup table</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Read</td>
<td>0</td>
<td>Read command Sequence</td>
</tr>
<tr>
<td>1</td>
<td>ReadStatus</td>
<td>1</td>
<td>Read Status command</td>
</tr>
<tr>
<td>2</td>
<td>WriteEnable</td>
<td>3</td>
<td>Write Enable command sequence</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 9-16. LUT sequence definition for Serial NOR (continued)

<table>
<thead>
<tr>
<th>Command Index</th>
<th>Name</th>
<th>Index in lookup table</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>EraseSector</td>
<td>5</td>
<td>Erase Sector Command</td>
</tr>
<tr>
<td>4</td>
<td>PageProgram</td>
<td>9</td>
<td>Page Program Command</td>
</tr>
<tr>
<td>5</td>
<td>ChipErase</td>
<td>11</td>
<td>Full Chip Erase</td>
</tr>
<tr>
<td>6</td>
<td>Dummy</td>
<td>15</td>
<td>Dummy Command as needed</td>
</tr>
<tr>
<td>7-12</td>
<td>Reserved</td>
<td>2,4,6,7,8,10,12,13,14</td>
<td>All reserved indexes can be freely used for other purpose</td>
</tr>
<tr>
<td>13</td>
<td>NOR_CMD_LUT_SEQ_IDX_READ_SFDP</td>
<td>13</td>
<td>Read SFDP sequence in lookupTable id stored in config block</td>
</tr>
<tr>
<td>14</td>
<td>NOR_CMD_LUT_SEQ_IDX_RESTORE_NOCMD</td>
<td>14</td>
<td>Restore 0-4-4/0-8-8 mode sequence id in lookupTable stored in config block</td>
</tr>
</tbody>
</table>

3. For Serial (SPI) NAND, the pre-defined LUT index is as follows:

Table 9-17. LUT sequence definition for Serial NAND

<table>
<thead>
<tr>
<th>Command Index</th>
<th>Name</th>
<th>Index in lookup table</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ReadFromCache</td>
<td>0</td>
<td>Read from cache</td>
</tr>
<tr>
<td>1</td>
<td>ReadStatus</td>
<td>1</td>
<td>Read Status</td>
</tr>
<tr>
<td>2</td>
<td>WriteEnable</td>
<td>3</td>
<td>Write Enable</td>
</tr>
<tr>
<td>3</td>
<td>BlockErase</td>
<td>5</td>
<td>Erase block</td>
</tr>
<tr>
<td>4</td>
<td>ProgramLoad</td>
<td>9</td>
<td>Program Load</td>
</tr>
<tr>
<td>5</td>
<td>ReadPage</td>
<td>11</td>
<td>Read page to cache</td>
</tr>
<tr>
<td>6</td>
<td>ReadEccStatus</td>
<td>13</td>
<td>Read ECC Status</td>
</tr>
<tr>
<td>7</td>
<td>ProgramExecute</td>
<td>14</td>
<td>Program Execute</td>
</tr>
<tr>
<td>8</td>
<td>ReadFromCacheOdd</td>
<td>4</td>
<td>Read from Cache while page in odd plane</td>
</tr>
<tr>
<td>9</td>
<td>ProgramLoadOdd</td>
<td>10</td>
<td>Program Load for pages within odd blocks</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td>2,6,7,8,12,15</td>
<td>All reserved indexes can be freely used for other purposes</td>
</tr>
</tbody>
</table>
NOTE
1. All the pre-defined LUT indexes are only applicable to boot stage. User application can use the whole 16 LUT entries freely based on their requirement.
2. The FlexSPI NOR ROM APIs occupy LUT index 0-5. User application should **NOT** use these LUT indexes if the ROM API is called in their application frequently.

### 9.6.3.2 Serial NOR configuration block (512 bytes)

**Table 9-18. Serial NOR configuration block**

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>memCfg</td>
<td>0</td>
<td>448</td>
<td>The common memory configuration block, see FlexSPI configuration block for more details</td>
</tr>
<tr>
<td>pageSize</td>
<td>0x1C0</td>
<td>4</td>
<td>Page size in terms of bytes, not used by ROM</td>
</tr>
<tr>
<td>sectorSize</td>
<td>0x1C4</td>
<td>4</td>
<td>Sector size in terms of bytes, not used by ROM</td>
</tr>
<tr>
<td>ipCmdSerialClkFreq</td>
<td>0x1C8</td>
<td>4</td>
<td>Chip specific value, not used by ROM</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0 – No change, keep current serial clock unchanged</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – 30 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – 50 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3 – 60 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – 75 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>5 – 80 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>6 – 100 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>7 – 120 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>8 – 133 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>9 – 166 MHz</td>
</tr>
<tr>
<td>Reserved</td>
<td>0x1CC</td>
<td>52</td>
<td>Reserved for future use</td>
</tr>
</tbody>
</table>
### 9.6.3.3 Serial NAND configuration block (512 bytes)

**Table 9-19. Serial NAND configuration block**

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>memCfg</td>
<td>0</td>
<td>448</td>
<td>The common memory configuration block, see FlexSPI configuration block for more details</td>
</tr>
<tr>
<td>pageDataSize</td>
<td>0x1C0</td>
<td>4</td>
<td>Page size in terms of bytes, usually, it is 2048 or 4096</td>
</tr>
<tr>
<td>pageTotalSize</td>
<td>0x1C4</td>
<td>4</td>
<td>It equals to $2^w$ width of column address</td>
</tr>
<tr>
<td>pagesPerBlock</td>
<td>0x1C8</td>
<td>4</td>
<td>Pages in one block</td>
</tr>
<tr>
<td>bypassReadStatus</td>
<td>0x1CC</td>
<td>1</td>
<td>0 – Read Status Register 1 – Bypass Read status register</td>
</tr>
<tr>
<td>bypassEccRead</td>
<td>0x1CD</td>
<td>1</td>
<td>0 – Perform ECC read 1 – Bypass ECC read</td>
</tr>
<tr>
<td>hasMultiPlanes</td>
<td>0x1CE</td>
<td>1</td>
<td>0 – Only 1 plane 1 – Has two planes</td>
</tr>
<tr>
<td>skippOddBlocks</td>
<td>0x1CF</td>
<td>1</td>
<td>0 – Read Odd blocks 1 – Skip Odd blocks</td>
</tr>
<tr>
<td>eccCheckCustomEnable</td>
<td>0x1D0</td>
<td>1</td>
<td>0 – Use the common ECC check command and ECC related masks 1 - Use ECC check related masks provided in this configuration block</td>
</tr>
<tr>
<td>ipCmdSerialClkFreq</td>
<td>0x1D1</td>
<td>1</td>
<td>Chip specific value, not used by ROM 0 – No change, keep current serial clock unchanged 1 – 30 MHz 2 – 50 MHz 3 – 60 MHz 4 – 75 MHz 5 – 80 MHz 6 – 100 MHz 7 – 120 MHz 8 – 133 MHz 9 – 166 MHz</td>
</tr>
<tr>
<td>readPageTimeUs</td>
<td>0x1D2</td>
<td>2</td>
<td>Wait time during page read, this field will take effect on if the bypassReadStatus is set to 1.</td>
</tr>
</tbody>
</table>
Table 9-19. Serial NAND configuration block (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>eccStatusMask</td>
<td>0x1D4</td>
<td>4</td>
<td>ECC Status Mask</td>
</tr>
<tr>
<td>eccFailureMask</td>
<td>0x1D8</td>
<td>4</td>
<td>ECC Check Failure mask</td>
</tr>
<tr>
<td>blocksPerDevice</td>
<td>0x1DC</td>
<td>4</td>
<td>Blocks in a Serial NAND</td>
</tr>
<tr>
<td>Reserved</td>
<td>0x1ED</td>
<td>32</td>
<td>Reserved for future use</td>
</tr>
</tbody>
</table>

NOTE: Only applicable to ROM.

Below is an example of Serial NAND configuration block for Winbond W25N01GVZEIG:

```c
const flexspi_nand_config_t kSerialNandCfgBlk =
{
    .memConfig =
    {
        .tag = FLEXSPI_CFG_BLK_TAG,
        .version = FLEXSPI_CFG_BLK_VERSION,
        .readSampleClkSrc = kFlexSPIReadSampleClk_LoopbackInternally,
        .dataHoldTime = 3,
        .dataSetupTime = 3,
        .columnAddressWidth = 12,
        .deviceModeCfgEnable = 1,
        .deviceModeSeq = { 1, 2 },
        .deviceType = kFlexSpiDeviceType_SerialNAND,
        .sflashPadType = kSerialFlash_4Pads,
        .serialClkFreq = kFlexSpiSerialClk_50MHz,
        .lutCustomSeqEnable = 0,
        .sflashAlSize = 128 * 1024 * 1024U * 2, // Flash size = 2 * actual data size (exclude spare space)
    },
    .lookupTable =
    {
        // Read cache 4 I/O
        [4 * NOR_CMD_LUT_SEQ_IDX_READ] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0xEB, CADDR_SDR, FLEXSPI_4PAD, 0x10),
        [4 * NOR_CMD_LUT_SEQ_IDX_READ + 1] = FLEXSPI_LUT_SEQ(DUMMY_SDR, FLEXSPI_4PAD, 0x04, READ_SDR, FLEXSPI_1PAD, 0x80),
        // Clear Status1 flag
        [4 * 2] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0x1F, CMD_SDR, FLEXSPI_1PAD, 0xA0),
        [4 * 2 + 1] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0x00, STOP, FLEXSPI_1PAD, 0x00),
        // Read Page
        [4 * NAND_CMD_LUT_SEQ_IDX_READPAGE] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0x13, RADDR_SDR, FLEXSPI_1PAD, 0x18),
        // Read Status
        [4 * NAND_CMD_LUT_SEQ_IDX_READSTATUS] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0x0F, CMD_SDR, FLEXSPI_1PAD, 0x00),
        [4 * NAND_CMD_LUT_SEQ_IDX_READSTATUS + 1] = FLEXSPI_LUT_SEQ(READ_SDR, FLEXSPI_1PAD, 0x01, STOP, FLEXSPI_1PAD, 0),
        // Write Enable
        [4 * NAND_CMD_LUT_SEQ_IDX_WRITEENABLE] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0x06, STOP, FLEXSPI_1PAD, 0),
        // Page Program Load 4x
        [4 * NAND_CMD_LUT_SEQ_IDX_PROGRAMLOAD] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0x32, CADDR_SDR, FLEXSPI_1PAD, 0x10),
        [4 * NAND_CMD_LUT_SEQ_IDX_PROGRAMLOAD + 1] = FLEXSPI_LUT_SEQ(WRITE_SDR, FLEXSPI_4PAD, 0x40, STOP, FLEXSPI_1PAD, 0),
        // Page Program Execute
        [4 * NAND_CMD_LUT_SEQ_IDX_PROGRAMEXECUTE] = FLEXSPI_LUT_SEQ(CMD_SDR, 
```
FLEXSPI_1PAD, 0x10, RADDR_SDR, FLEXSPI_1PAD, 0x18),
    // Erase Sector
    [4 * NAND_CMD_LUT_SEQ_IDX_ERASEBLOCK] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD,
    0xD8, RADDR_SDR, FLEXSPI_1PAD, 0x18),
    // Read ECC status
    [4 * NAND_CMD_LUT_SEQ_IDX_READECCSTAT] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD,
    0x0F, CMD_SDR, FLEXSPI_1PAD, 0xC0),
    [4 * NAND_CMD_LUT_SEQ_IDX_READECCSTAT + 1] = FLEXSPI_LUT_SEQ(READ_SDR,
    FLEXSPI_1PAD, 0x01, STOP, FLEXSPI_1PAD, 0),
};

.pageDataSize = 2048,
.pageTotalSize = 4096,
.pagesPerBlock = 64,

### 9.6.4 Parallel NOR flash Boot over SEMC

The Smart External Memory Controller (SEMC) works in an asynchronous mode, and supports Muxed Address/Data scheme.

#### 9.6.4.1 Parallel NOR eFUSE Configuration

The boot ROM determines the configuration of external Parallel NOR flash by parameters, either provided by eFUSE, or sampled on GPIO pins during boot. See below table for parameters details.

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>BOOT_CFG [7:4]</td>
<td>OEM</td>
<td>Primary boot device selection</td>
<td>Yes</td>
<td>0000</td>
<td>0001 – Parallel NOR</td>
</tr>
<tr>
<td>BOOT_CFG [2:0]</td>
<td>OEM</td>
<td>SEMC Clock frequency</td>
<td>Yes</td>
<td>000</td>
<td>000 – 33MHz&lt;br&gt;001 – 66MHz&lt;br&gt;010 – 108MHz&lt;br&gt;011 – 133MHz&lt;br&gt;1xx – 166MHz</td>
</tr>
<tr>
<td>BOOT_CFG [8]</td>
<td>OEM</td>
<td>AC timing parameter configuration</td>
<td>Yes</td>
<td>0</td>
<td>0 – Default configuration&lt;br&gt;1 – Configured by Fuse</td>
</tr>
<tr>
<td>BOOT_CFG [9]</td>
<td>OEM</td>
<td>Data port size</td>
<td>Yes</td>
<td>0</td>
<td>0 – 16 bits&lt;br&gt;1 – 8 bits</td>
</tr>
<tr>
<td>BOOT_CFG [10]</td>
<td>OEM</td>
<td>DQS pin pad enablement</td>
<td>Yes</td>
<td>0</td>
<td>0 – Disabled&lt;br&gt;1 – Enabled</td>
</tr>
<tr>
<td>0x6E0[2:0]</td>
<td>OEM</td>
<td>PCS pin selection</td>
<td>No</td>
<td>000</td>
<td>000 – CSX0&lt;br&gt;001 – CSX1&lt;br&gt;010 – CSX2</td>
</tr>
</tbody>
</table>

*Table continues on the next page*
Table 9-20. Fuse definition for Parallel NOR over SEMC (continued)

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x6E0[5:3]</td>
<td>OEM</td>
<td>Address port size</td>
<td>No</td>
<td>000</td>
<td>011 – CSX3&lt;br&gt;1xx – A8&lt;br&gt;0xx – &lt;= 24 bits&lt;br&gt;100 – 25 bits&lt;br&gt;101 – 26 bits&lt;br&gt;110 – 27 bits&lt;br&gt;111 – 28 bits</td>
</tr>
<tr>
<td>0x6E0[6]</td>
<td>OEM</td>
<td>ADV pin polarity</td>
<td>No</td>
<td>0</td>
<td>0 – Low active&lt;br&gt;1 – High active</td>
</tr>
<tr>
<td>0x6E0[7]</td>
<td>OEM</td>
<td>RDY pin polarity</td>
<td>No</td>
<td>0</td>
<td>0 – High active&lt;br&gt;1 – Low active</td>
</tr>
<tr>
<td>0x6E0[9:8]</td>
<td>OEM</td>
<td>AC timing parameter - CES</td>
<td>No</td>
<td>00</td>
<td>Value = (CES*5 + 1) cycle</td>
</tr>
<tr>
<td>0x6E0[11:10]</td>
<td>OEM</td>
<td>AC timing parameter - CEH</td>
<td>No</td>
<td>00</td>
<td>Value = (CEH*5 + 1) cycle</td>
</tr>
<tr>
<td>0x6E0[13:12]</td>
<td>OEM</td>
<td>AC timing parameter - CEITV</td>
<td>No</td>
<td>00</td>
<td>Value = (CEITV*5 + 1) cycle</td>
</tr>
<tr>
<td>0x6E0[15:14]</td>
<td>OEM</td>
<td>AC timing parameter - TA</td>
<td>No</td>
<td>00</td>
<td>Value = (TA*5 + 1) cycle</td>
</tr>
<tr>
<td>0x6E0[19:16]</td>
<td>OEM</td>
<td>AC timing parameter - AS</td>
<td>No</td>
<td>0000</td>
<td>Value = (AS + 1) cycle</td>
</tr>
<tr>
<td>0x6E0[23:20]</td>
<td>OEM</td>
<td>AC timing parameter - AH</td>
<td>No</td>
<td>0000</td>
<td>Value = (AH + 1) cycle</td>
</tr>
<tr>
<td>0x6E0[27:24]</td>
<td>OEM</td>
<td>AC timing parameter - REL</td>
<td>No</td>
<td>0000</td>
<td>Value = (REL + 1) cycle</td>
</tr>
<tr>
<td>0x6E0[31:28]</td>
<td>OEM</td>
<td>AC timing parameter - REH</td>
<td>No</td>
<td>0000</td>
<td>Value = (REH + 1) cycle</td>
</tr>
</tbody>
</table>

9.6.4.2 SEMC Parallel NOR Flash Boot Operation

The Boot ROM attempts to boot from Parallel NOR flash if the BOOT_CFG [7:4] fuses are programmed to 0b’0000 as shown in the Parallel NOR eFUSE Configuration table. ROM supports booting from both XIP and non-XIP images from Parallel NOR Flash. For XIP boot, the image has to be built for SEMC address space and for non XIP the image can be built to execute from Internal RAM.
9.6.5 Parallel NAND flash Boot over SEMC

The boot ROM supports a number of Parallel SLC NAND flash devices from different vendors. Both the Error Correction and Control (ECC) module in NAND device and software ECC algorithm (SECDED) in boot ROM can be used to detect the errors, based on the fuse settings.

9.6.5.1 Parallel NAND eFUSE Configuration

The boot ROM determines the configuration of external Parallel NAND flash by parameters, either provided by eFUSE, or sampled on GPIO pins, during boot. See below table for parameters details:

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
</table>
| BOOT_CFG [0]  | OEM    | Boot Search count of FCB and DBBT                | Yes  | 0             | 0 - 1
|               |        |                                                  |      |               | 1 – 2                     |
| BOOT_CFG [4:1]| OEM    | Search stride for FCB and DBBT in terms of pages | Yes  | 0000          | 0000 – 64
|               |        |                                                  |      |               | Others – 2 ^              |
|               |        |                                                  |      |               | BOOT_SEARCH_STRIDE        |
| BOOT_CFG [7:5]| OEM    | Primary boot device selection                    | Yes  | 000           | 001 – Parallel NAND       |
| BOOT_CFG [8]  | OEM    | NAND ONFI compliant                              | Yes  | 0             | 0 – ONFI 1.0              |
|               |        |                                                  |      |               | 1 – Non-ONFI              |
| BOOT_CFG [9]  | OEM    | ECC selection                                    | Yes  | 0             | 0 – Software ECC (SECDED) |
|               |        |                                                  |      |               | 1 – Device ECC            |
|               |        |                                                  |      |               | NOTE: For “ECC selection” option, it can only be set as Device ECC. When NAND device has built-in ECC module and the ECC module is enabled by default. |
| BOOT_CFG [10]| OEM    | DQS pin pad enablement                           | Yes  | 0             | 0 – Disabled              |
|               |        |                                                  |      |               | 1 – Enabled               |
| 0x6E0[2:0]    | OEM    | PCS pin selection                                | No   | 000           | 000 – CSX0                |
|               |        |                                                  |      |               | 001 – CSX1                |
|               |        |                                                  |      |               | 010 – CSX2                |
|               |        |                                                  |      |               | 011 – CSX3                |
|               |        |                                                  |      |               | 1xx – A8                  |
| 0x6E0[4]      | OEM    | EDO mode                                         | No   | 0             | 0 – Disabled              |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
</table>
| 0x6E0[5] | OEM | RDY pin polarity | No | 0 | 0 – High active  
1 – Low active |
| 0x6E0[6] | OEM | Ready check type | No | 0 | 0 – R/B# pin  
1 – Status Register |
| 0x6E0[10:8] | OEM | Row Column address mode | No | 000 | Applicable only for Non-ONFI device  
00x – 5 bytes (CA2+RA3)  
010 – 4 bytes (CA2+RA2)  
011 – 3 bytes (CA2+RA1)  
10x – 4 bytes (CA1+RA3)  
110 – 3 bytes (CA1+RA2)  
111 – 2 bytes (CA1+RA1) |
| 0x6E0[13:11] | OEM | Column address width | No | 000 | Applicable only for Non-ONFI device  
000 – 12 bits  
001 – 09 bits  
010 – 10 bits  
011 – 11 bits  
100 – 13 bits  
101 – 14 bits  
110 – 15 bits  
111 – 16 bits |
| 0x6E0[14] | OEM | Status command type | No | 0 | Applicable only for Non-ONFI device  
0 – Common (0x70)  
1 – Enhanced (0x78) |
| 0x6E0[18:16] | OEM | Pages in block | No | 000 | Applicable only for Non-ONFI device  
000 – 128 pages  
001 – 8 pages  
010 – 16 pages  
011 – 32 pages  
100 – 64 pages  
101 – 256 pages  
110 – 512 pages  
111 – 1024 pages |
| 0x6E0[24] | OEM | Device ECC initial status | No | 0 | Applicable only for ONFI 1.0 device |
Table 9-21. Fuse definition for Parallel NAND over SEMC

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definitions</th>
<th>GPIO</th>
<th>Shipped Value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 – Enabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 – Disabled</td>
</tr>
</tbody>
</table>

9.6.5.2 Parallel NAND Flash Boot Control Blocks (BCB)

There are two BCB data structures:
- Firmware Configuration Block (FCB)
- Discovered Bad Blocks Table (DBBT)

As part of the Parallel NAND media initialization, the ROM driver uses proper Parallel NAND parameters specified by FUSE to search for an FCB that contains the complete Parallel NAND parameters, page address of DBBT Search Area and Image info, including image copies, start page address and image size in terms of pages for each image.

FCB data structure is protected using Embedded ECC module in Parallel NAND devices or software ECC in ROM. The ROM driver reads 2048 bytes of first sector and checks the ECC check status to determine whether FCB data is valid or not.

If the FCB is found, the complete NAND parameters (Parallel NAND configuration block) are loaded for further reads, if the ECC fails, or the fingerprint does not match, or the CRC checksum does not match, the Block Search state machine increments page number to Search Stride number of pages to read for the next FCB until Search Count pages have been read.

If search fails to find a valid FCB, the Parallel NAND driver responds with an error and the boot ROM enters into Recovery boot mode (Secondary boot, if it is enabled, or Serial download mode).

The FCB contains the page address of DBBT Search Area, and the info for images. DBBT is searched in DBBT Search area just like how FCB is searched. After the FCB is read, the DBBT is loaded, then the boot image is loaded using starting page address from FCB.

9.6.5.3 Firmware Configuration Block (FCB)

The FCB is at the first page in the first good block. The FCB should be present at each search stride of the search area.
The search area contains copies of the FCB at each stride distance, in case the first Serial NAND block becomes corrupted, the ROM will find its copy in the next Parallel NAND block. The search area should span over at least two Parallel NAND blocks. The location information for DBBT search area and images are all specified in the FCB. Below Table shows the FCB Structure.

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>bcbHeader</td>
<td>0x000</td>
<td>12</td>
<td>See Table 9-22 for details</td>
</tr>
<tr>
<td>DBBTSerachAreaStartPage</td>
<td>0x00c</td>
<td>4</td>
<td>Start Page address for bad block table search area</td>
</tr>
<tr>
<td>searchStride</td>
<td>0x010</td>
<td>2</td>
<td>Search stride for DBBT and FCB search. Not used by ROM Max value is 8.</td>
</tr>
<tr>
<td>searchCount</td>
<td>0x012</td>
<td>2</td>
<td>Copies of DBBT and FCB. Not used by ROM, max value is 8.</td>
</tr>
<tr>
<td>firmwareCopies</td>
<td>0x014</td>
<td>4</td>
<td>Firmware copies Valid range 1-4.</td>
</tr>
<tr>
<td>-</td>
<td>0x018</td>
<td>40</td>
<td>Reserved</td>
</tr>
<tr>
<td>firmwareTable</td>
<td>0x040</td>
<td>64</td>
<td>For details see Table 9-23</td>
</tr>
<tr>
<td>-</td>
<td>0x080</td>
<td>128</td>
<td>Reserved</td>
</tr>
<tr>
<td>nandConfig</td>
<td>0x100</td>
<td>256</td>
<td>Parallel NAND configuration block over SEMC</td>
</tr>
<tr>
<td>-</td>
<td>0x200</td>
<td>512</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Table 9-22.** Header Description

<table>
<thead>
<tr>
<th>Field</th>
<th>Size</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>crcChecksum</td>
<td>4</td>
<td>Checksum</td>
</tr>
<tr>
<td>fingerprint</td>
<td>4</td>
<td>0x4E46_4342</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ASCII: &quot;NFCB&quot;</td>
</tr>
<tr>
<td>version</td>
<td>4</td>
<td>0x0000_0001</td>
</tr>
</tbody>
</table>

**Table 9-23.** Table Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Size</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>startPage</td>
<td>4</td>
<td>Start page of this firmware</td>
</tr>
<tr>
<td>pagesInFirmware</td>
<td>4</td>
<td>Pages in this firmware</td>
</tr>
</tbody>
</table>

**NOTE**
- The “crcChecksum” is calculated with an MPEG2 variant of CRC-32.
• The “crcChecksum” calculation starts from fingerprint to the end of FCB, 1020 bytes in total.
• The “nandConfig” is SEMC NAND configuration block which consists of common SEMC memory configuration block and Parallel NAND specified configuration parameters. See Parallel NAND eFUSE Configuration for more details.

9.6.5.4 Discovered Bad Blocks Table (DBBT)

Table 9-24. DBBT Structure

<table>
<thead>
<tr>
<th>Name</th>
<th>offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>bcbHeader</td>
<td>0x000</td>
<td>12</td>
<td>See Table 9-25 for details</td>
</tr>
<tr>
<td>-</td>
<td>0x00C</td>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>badBlockNumber</td>
<td>0x010</td>
<td>4</td>
<td>Number of bad blocks</td>
</tr>
<tr>
<td>-</td>
<td>0x014</td>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>badBlockTable</td>
<td>0x020</td>
<td>1024 (256*4)</td>
<td>Each bad block entry is a 32-bit value specifying the number of a found bad block. The number of valid bad block entries is specified by the badBlockNumber field, where valid bad block entries are stored sequentially starting at the beginning of the bad block entries segment. Unused bad block entries (those beyond the badBlockNumber) should be filled with 0xFs.</td>
</tr>
</tbody>
</table>

Table 9-25. Header Description

<table>
<thead>
<tr>
<th>Field</th>
<th>Size</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>crcChecksum</td>
<td>4</td>
<td>Checksum</td>
</tr>
<tr>
<td>fingerprint</td>
<td>4</td>
<td>0x4442_4254 ASCII: “DBBT”</td>
</tr>
<tr>
<td>version</td>
<td>4</td>
<td>0x0000_0001</td>
</tr>
</tbody>
</table>

**NOTE**

• Maximum bad block number is 256.
• The "crcChecksum" is calculated with the same algorithm as the one in FCB, from Fingerprint to the end of DBBT, 1052 bytes in total.
9.6.5.5  Bad block handling in ROM

During firmware boot, at the block boundary, the Bad Block table is searched for a match to the next block.

If no match is found, the next block can be loaded. If a match is found, the block must be skipped and the next block is checked.

9.6.6  Parallel NOR and NAND configuration based on SEMC interface

The ROM SW supports Parallel NOR and Parallel NAND based on SEMC module, using an 80-bytes common SEMC configuration block and several specified parameters for Parallel NOR and Parallel NAND respectively. See below sections for more details.

9.6.6.1  SEMC Configuration Block

SEMC Configuration block consists of all parameters related to specific Flash devices.

Table 9-26. SEMC control block structure

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>tag</td>
<td>0x000</td>
<td>4</td>
<td>0x434D4553, ascii:&quot;SEMC&quot;</td>
</tr>
<tr>
<td>version</td>
<td>0x004</td>
<td>4</td>
<td>0x00010000</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[07:00] bugfix = 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[15:08] minor = 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>[31:16] major = 1</td>
</tr>
<tr>
<td>deviceMemType</td>
<td>0x008</td>
<td>1</td>
<td>0 – NOR Flash</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – NAND Flash</td>
</tr>
<tr>
<td>accessCommandType</td>
<td>0x009</td>
<td>1</td>
<td>0 – IPG bus command</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – AXI32 command</td>
</tr>
<tr>
<td>-</td>
<td>0x00A</td>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>asyncClkFreq</td>
<td>0x00C</td>
<td>1</td>
<td>0 – 33MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – 40MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – 50MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3 – 66MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – 108MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>5 – 133MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>6 – 166MHz</td>
</tr>
<tr>
<td>busTimeoutCycles</td>
<td>0x00D</td>
<td>1</td>
<td>0 – 255 * 1024 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>n – n * 1024 cycles</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 9-26. SEMC control block structure (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>commandExecutionTimeoutCycles</td>
<td>0x00E</td>
<td>1</td>
<td>0 – 256 * 1024 cycles</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>n – n * 1024 cycles</td>
</tr>
<tr>
<td>readStrobeMode</td>
<td>0x00F</td>
<td>1</td>
<td>0 – Dummy read strobe loopbacked internally</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – Dummy read strobe loopbacked from DQS pad</td>
</tr>
<tr>
<td>norMemConfig</td>
<td>0x010</td>
<td>64</td>
<td>See detail in Table SEMC NOR control block structure</td>
</tr>
<tr>
<td>nandMemConfig</td>
<td>0x010</td>
<td>64</td>
<td>See detail in Table SEMC NAND control block structure</td>
</tr>
</tbody>
</table>

### Table 9-27. SEMC NOR control block structure

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>comMemBaseAddress</td>
<td>0x00</td>
<td>4</td>
<td>SoC level Base Address for NAND AXI and IPG command</td>
</tr>
<tr>
<td>comMemSizeInByte</td>
<td>0x04</td>
<td>4</td>
<td>SoC level Memory size for NAND AXI and IPG command</td>
</tr>
<tr>
<td></td>
<td>0x08</td>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>addressMode</td>
<td>0x10</td>
<td>1</td>
<td>0 – Address/Data MUX mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – Advanced Address/Data MUX mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – Address/Data non-MUX mode</td>
</tr>
<tr>
<td>addressPortWidth</td>
<td>0x11</td>
<td>1</td>
<td>Address Port bit number</td>
</tr>
<tr>
<td>dataPortWidth</td>
<td>0x12</td>
<td>1</td>
<td>Data Port bit number</td>
</tr>
<tr>
<td>columnAddressWidth</td>
<td>0x13</td>
<td>1</td>
<td>Column Address bit width</td>
</tr>
<tr>
<td>burstLengthInBytes</td>
<td>0x14</td>
<td>1</td>
<td>Burst Length</td>
</tr>
<tr>
<td></td>
<td>0x15</td>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>cePortOutputSelection</td>
<td>0x18</td>
<td>1</td>
<td>0 – CSX0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – CSX1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – CSX2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3 – CSX3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – A8</td>
</tr>
<tr>
<td>rdyPortPolarity</td>
<td>0x19</td>
<td>1</td>
<td>0 – Low active</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – High active</td>
</tr>
<tr>
<td>advPortPolarity</td>
<td>0x1A</td>
<td>1</td>
<td>0 – Low active</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – High active</td>
</tr>
<tr>
<td></td>
<td>0x1B</td>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>ceSetupTime</td>
<td>0x28</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>ceMinHoldTime</td>
<td>0x29</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
</tbody>
</table>

*Table continues on the next page*
### Table 9-27. SEMC NOR control block structure (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ceMinIntervalTime</td>
<td>0x2A</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>addressSetupTime</td>
<td>0x2B</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>addressHoldTime</td>
<td>0x2C</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>asyncWeLowTime</td>
<td>0x2D</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>asyncWeHighTime</td>
<td>0x2E</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>asyncOeLowTime</td>
<td>0x2F</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>asyncOeHighTime</td>
<td>0x30</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>asyncTurnaroundTime</td>
<td>0x31</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>asyncAddressToDataHoldTime</td>
<td>0x32</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>syncDataSetupTime</td>
<td>0x33</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>syncDataHoldTime</td>
<td>0x34</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>syncLatencyCount</td>
<td>0x35</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>syncReadCycleTime</td>
<td>0x36</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>-</td>
<td>0x37</td>
<td>9</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### Table 9-28. SEMC NAND control block structure

<table>
<thead>
<tr>
<th>Name</th>
<th>offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>axiMemBaseAddress</td>
<td>0x00</td>
<td>4</td>
<td>SoC level Base Address for NAND AXI command</td>
</tr>
<tr>
<td>axiMemSizeInByte</td>
<td>0x04</td>
<td>4</td>
<td>SoC level Memory size for NAND AXI command</td>
</tr>
<tr>
<td>ipgMemBaseAddress</td>
<td>0x08</td>
<td>4</td>
<td>SoC level Base Address for NAND IPG command</td>
</tr>
<tr>
<td>ipgMemSizeInByte</td>
<td>0x0c</td>
<td>4</td>
<td>SoC level Memory size for NAND IPG command</td>
</tr>
<tr>
<td>edoMode</td>
<td>0x10</td>
<td>1</td>
<td>0 - EDO mode disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 - EDO mode enabled</td>
</tr>
<tr>
<td>ioPortWidth</td>
<td>0x11</td>
<td>1</td>
<td>IO Port bit number</td>
</tr>
<tr>
<td>arrayAddressOption</td>
<td>0x12</td>
<td>1</td>
<td>0 – 5 bytes (CA2+RA3)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – 4 bytes (CA1+RA3)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – 4 bytes (CA2+RA2)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3 – 3 bytes (CA1+RA2)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – 3 bytes (CA2+RA1)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>7 – 2 bytes (CA1+RA1)</td>
</tr>
<tr>
<td>columnAddressWidth</td>
<td>0x13</td>
<td>1</td>
<td>Column address bit number</td>
</tr>
<tr>
<td>burstLengthInBytes</td>
<td>0x14</td>
<td>1</td>
<td>Burst Length</td>
</tr>
<tr>
<td>-</td>
<td>0x15</td>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>cePortOutputSelection</td>
<td>0x20</td>
<td>1</td>
<td>0 – CSX0</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 9-28. SEMC NAND control block structure (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>rdyPortPolarity</td>
<td>0x21</td>
<td>1</td>
<td>0 – Low active</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – High active</td>
</tr>
<tr>
<td>ceSetupTime</td>
<td>0x30</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>ceMinHoldTime</td>
<td>0x31</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>ceMinIntervalTime</td>
<td>0x32</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>weLowTime</td>
<td>0x33</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>weHighTime</td>
<td>0x34</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>reLowTime</td>
<td>0x35</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>reHighTime</td>
<td>0x36</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td>weHighToReLowTime</td>
<td>0x37</td>
<td>1</td>
<td>value[5:0] + 1 cycles</td>
</tr>
<tr>
<td>reHighToWeLowTime</td>
<td>0x38</td>
<td>1</td>
<td>value[5:0] + 1 cycles</td>
</tr>
<tr>
<td>aleToDataStartTime</td>
<td>0x39</td>
<td>1</td>
<td>value[5:0] + 1 cycles</td>
</tr>
<tr>
<td>readyToReLowTime</td>
<td>0x3a</td>
<td>1</td>
<td>value[5:0] + 1 cycles</td>
</tr>
<tr>
<td>weHighToBusyTime</td>
<td>0x3b</td>
<td>1</td>
<td>value[5:0] + 1 cycles</td>
</tr>
<tr>
<td>asyncTurnaroundTime</td>
<td>0x3c</td>
<td>1</td>
<td>value[3:0] + 1 cycles</td>
</tr>
<tr>
<td></td>
<td>0x3d</td>
<td>3</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

9.6.6.2 Parallel NOR Configuration Block (80 bytes)
Table 9-29. Parallel NOR control block structure

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>memConfig</td>
<td>0x000</td>
<td>80</td>
<td>See SEMC control block structure for more details</td>
</tr>
</tbody>
</table>

9.6.6.3 Parallel NAND Configuration Block (256 bytes)
Table 9-30. Parallel NAND control block structure

<table>
<thead>
<tr>
<th>Name</th>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>memConfig</td>
<td>0x000</td>
<td>80</td>
<td>See SEMC control block structure for more details</td>
</tr>
<tr>
<td>vendorType</td>
<td>0x050</td>
<td>1</td>
<td>0 – Micron</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Name</th>
<th>offset</th>
<th>Size (Bytes)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>cellTechnology</td>
<td>0x051</td>
<td>1</td>
<td>0 – SLC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – MLC</td>
</tr>
<tr>
<td>onfiVersion</td>
<td>0x052</td>
<td>1</td>
<td>0 – Non-ONFI</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – ONFI 1.0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – ONFI 2.0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3 – ONFI 3.0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – ONFI 4.0</td>
</tr>
<tr>
<td>acTimingTableIndex</td>
<td>0x053</td>
<td>1</td>
<td>0 – User Defined</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – ONFI 1.0 Mode0 10MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2 – ONFI 1.0 Mode1 20MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3 – ONFI 1.0 Mode2 28MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>4 – ONFI 1.0 Mode3 33MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>5 – ONFI 1.0 Mode4 40MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>6 – ONFI 1.0 Mode5 50MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>7 – Auto Detection</td>
</tr>
<tr>
<td>enableEccCheck</td>
<td>0x054</td>
<td>1</td>
<td>0 – Enabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – Disabled</td>
</tr>
<tr>
<td>eccCheckType</td>
<td>0x055</td>
<td>1</td>
<td>0 – Software ECC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – Device ECC</td>
</tr>
<tr>
<td>deviceEccStatus</td>
<td>0x056</td>
<td>1</td>
<td>0 – Enabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – Disabled</td>
</tr>
<tr>
<td>swEccAlgorithm</td>
<td>0x057</td>
<td>1</td>
<td>0 – SEC Hamming Code</td>
</tr>
<tr>
<td>swEccBlockBytes</td>
<td>0x058</td>
<td>4</td>
<td>Software ECC block bytes (256, 512)</td>
</tr>
<tr>
<td>readyCheckOption</td>
<td>0x05c</td>
<td>1</td>
<td>0 – Via Status Register</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – Via R/B# signal</td>
</tr>
<tr>
<td>statusCommandType</td>
<td>0x05d</td>
<td>1</td>
<td>0 – Common (0x70)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1 – Enhanced (0x78)</td>
</tr>
<tr>
<td>readyCheckTimeoutInMs</td>
<td>0x05e</td>
<td>2</td>
<td>Ready Check timeout</td>
</tr>
<tr>
<td>readyCheckIntervalUs</td>
<td>0x060</td>
<td>2</td>
<td>Ready Check interval</td>
</tr>
<tr>
<td></td>
<td>0x062</td>
<td>62</td>
<td>Reserved</td>
</tr>
<tr>
<td>bytesReadPageDataArea</td>
<td>0x0a0</td>
<td>4</td>
<td>Page Main data size</td>
</tr>
</tbody>
</table>

Table 9-30. Parallel NAND control block structure (continued)
9.6.7 Expansion device

The ROM supports booting from the MMC/eMMC and SD/eSD compliant devices.

9.6.7.1 Expansion device eFUSE configuration

The SD/MMC/eSD/eMMC/SDXC boot can be performed using the USDHC ports. The port can be configured based on either the setting of the BOOT_CFG1[1] (Port Select) fuse or its corresponding GPIO overrides.

All USDHC ports support the fast boot. See this table for details:

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definition</th>
<th>GPIO</th>
<th>Shipped value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[0]</td>
<td>OEM</td>
<td>Fast boot support</td>
<td>Yes</td>
<td>0</td>
<td>MMC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 - Normal boot</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Fast boot</td>
</tr>
<tr>
<td>0x450[1]</td>
<td>OEM</td>
<td>USDHC port selection</td>
<td>Yes</td>
<td>0</td>
<td>0 - USDHC-1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - USDHC-2</td>
</tr>
<tr>
<td>0x450[2]</td>
<td>OEM</td>
<td>SD loopback clock source sel (for SDR50 and SDR104 only)</td>
<td>Yes</td>
<td>0</td>
<td>0 - through the SD pad</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - direct</td>
</tr>
<tr>
<td>0x450[3]</td>
<td>OEM</td>
<td>SD power cycle enable</td>
<td>Yes</td>
<td>0</td>
<td>0 - No power cycle</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Power cycle enabled via the SD_RST pad</td>
</tr>
<tr>
<td>0x450[5:4]</td>
<td>OEM</td>
<td>SD/MMC speed mode, and eMMC acknowledge enabled selection</td>
<td>Yes</td>
<td>00</td>
<td>MMC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0x - Normal speed mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1x - High-speed mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>x0 - eMMC fast boot acknowledge disable</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-31. USDHC eFuse Descriptions (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>OEM</th>
<th>Description</th>
<th>Yes/No</th>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[7:6]</td>
<td>OEM</td>
<td>Boot device selection</td>
<td>Yes</td>
<td>00</td>
<td>01 - SD/eSD/SDXC boot from the USDHC interface</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - MMC/eMMC boot from the USDHC interface</td>
</tr>
<tr>
<td>0x450[8]</td>
<td>OEM</td>
<td>USDHC1 voltage selection</td>
<td>Yes</td>
<td>0</td>
<td>0 - 3.3 V</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - 1.8 V</td>
</tr>
<tr>
<td>0x450[10:9]</td>
<td>OEM</td>
<td>SD MMC bus width selection</td>
<td>Yes</td>
<td>00</td>
<td>SD</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>x0 - 1-bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>x1 - 4-bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MMC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00 - 4-bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - 8-bit</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - 4-bit DDR (MMC 4.4)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11 - 8-bit DDR (MMC 4.4)</td>
</tr>
<tr>
<td>0x470[14]</td>
<td>OEM</td>
<td>eMMC4.4 pre-idle enabled selection</td>
<td>Yes</td>
<td>0</td>
<td>0 - Issue pre-idle command</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Do not issue</td>
</tr>
<tr>
<td>0x470[6]</td>
<td>OEM</td>
<td>USDHC1 reset polarity selection</td>
<td>Yes</td>
<td>0</td>
<td>0 - Reset active low</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Reset active high</td>
</tr>
<tr>
<td>0x460[29]</td>
<td>OEM</td>
<td>Power stable cycle selection</td>
<td>Yes</td>
<td>0</td>
<td>0 - 5 ms</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - 2.5 ms</td>
</tr>
<tr>
<td>0x460[31:30]</td>
<td>OEM</td>
<td>Power cycle selection</td>
<td>Yes</td>
<td>00</td>
<td>00 - 20 ms</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - 10 ms</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - 5 ms</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11 - 2.5 ms</td>
</tr>
<tr>
<td>0x460[24]</td>
<td>OEM</td>
<td>SD/MMC DLL enable selection</td>
<td>Yes</td>
<td>0</td>
<td>0 - Disable DLL for SD/eMMC</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Enable DLL for SD/Emm</td>
</tr>
<tr>
<td>0x470[7]</td>
<td>OEM</td>
<td>DLL override selection</td>
<td>Yes</td>
<td>0</td>
<td>0 - No override</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - DLL override mode for SD/eMMC</td>
</tr>
<tr>
<td></td>
<td></td>
<td>(Override by MMC_DLL_DLY, 0x470[19:16])</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x6D0[31:30]</td>
<td>OEM</td>
<td>SD calibration step</td>
<td>Yes</td>
<td>00</td>
<td>SD</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00 - 1 delay cell</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - 2 delay cells</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - 4 delay cells</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-31. USDHC eFuse Descriptions (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>Manufacturer</th>
<th>Description</th>
<th>Enable</th>
<th>Override Number</th>
</tr>
</thead>
</table>
| 0x470[0] | OEM | SD/MMC pad settings override selection | Yes | 0 | 0 - No override
1 - Override (override by PAD_SETTINGS, 0x6d0[5:0]) |
| 0x470[3] | OEM | Disable SDMMC Manufacture mode | Yes | 0 | 0 - Enable
1 - Disable |
| 0x470[5] | OEM | USDHC2 voltage selection | Yes | 0 | 0 - 3.3 V
1 - 1.8 V |
| 0x470[8] | OEM | USDHC_IOMUX_SRE_ENABLE | Yes | 0 | 0 - Disable
1 - Enable |
| 0x470[9] | OEM | USDHC_IOMUX_SION_BIT_ENABLE | Yes | 0 | 0 - Disable
1 - Enable |
| 0x470[11] | OEM | ENABLE_EMMC_22K_PULLUP | Yes | 0 | MMC 0 - 47K pullup
1 - 22K pullup |
| 0x470[12] | OEM | USDHC_PAD_PULL_DOWN | Yes | 0 | SD
0 - no action
1 - pull down |
| 0x470[13] | OEM | Override HYS bit for SD/MMC pads | Yes | 0 | 0 - No override
1 - Override HYS bit with 1 |
| 0x470[15] | OEM | USDHC2 reset polarity selection | Yes | 0 | 0 - Reset active-low
1 - Reset active-high |
| 0X470[30:24] | OEM | MMC_DLL_DLY | Yes | 0000000 | Override number |
| 0X6D0[5:0] | OEM | PAD_SETTINGS | Yes | 0000000 | Override number |

The boot code supports these standards:

- MMCv4.4 or less
- eMMCv4.4 or less
- SDv2.0 or less
- eSDv2.10 rev-0.9, with or without FAST_BOOT
- SDXCv3.0

The MMC/SD/eSD/SDXC/eMMC can be connected to any of the USDHC blocks and can be booted by copying 4 KB of data from the MMC/SD/eSD/eMMC device to the internal RAM. After checking the Image Vector Table header value (0xD1) from program image, the ROM code performs a DCD check. After a successful DCD extraction, the ROM code extracts from the Boot Data Structure the destination pointer and length of image to be copied to the RAM device from where the code execution occurs.
The maximum image size to load into the SD/MMC boot is 32 MB. This is due to a limited number of uSDHC ADMA Buffer Descriptors allocated by the ROM.

**NOTE**
The initial 4 KB of the program image must contain the IVT, DCD, and the Boot Data structures.

### Table 9-32. SD/MMC frequencies

<table>
<thead>
<tr>
<th>Frequency Type</th>
<th>SD</th>
<th>MMC</th>
<th>MMC (DDR mode)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Identification (KHz)</td>
<td>347.22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Normal-speed mode (MHz)</td>
<td>25</td>
<td>20</td>
<td>25</td>
</tr>
<tr>
<td>High-speed mode (MHz)</td>
<td>50</td>
<td>40</td>
<td>50</td>
</tr>
<tr>
<td>UHSI SDR50 (MHz)</td>
<td>100</td>
<td></td>
<td></td>
</tr>
<tr>
<td>UHSI SDR104 (MHz)</td>
<td>200</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTE**
The boot ROM code reads the application image length and the application destination pointer from the image.

### 9.6.7.2 MMC and eMMC boot

This table provides the MMC and eMMC boot details.

### Table 9-33. MMC and eMMC boot details

<table>
<thead>
<tr>
<th>Boot Mode</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Normal boot mode</td>
<td>During the initialization (normal boot mode), the MMC frequency is set to 347.22 KHz. When the MMC card enters the identification portion of the initialization, the voltage validation is performed, and the ROM boot code checks the high-voltage settings and the card capacity. The ROM boot code supports both the high-capacity and low-capacity MMC/eMMC cards. After the initialization phase is complete, the ROM boot code switches to a higher frequency (20 MHz in the normal boot mode or 40 MHz in the high-speed mode). The eMMC is also interfaced via the USDHC and follows the same flow as the MMC. The boot partition can be selected for an MMC4.x card after the card initialization is complete. The ROM code reads the BOOT_PARTITION_ENABLE field in the Ext_CSD[179] to get the boot partition to be set. If there is no boot partition mentioned in the BOOT_PARTITION_ENABLE field or the user partition was mentioned, the ROM boots from the user partition.</td>
</tr>
<tr>
<td>eMMC4.3 or eMMC4.4 device supporting special boot mode</td>
<td>If using an eMMC4.3 or eMMC4.4 device that supports the special boot mode, it can be initiated by pulling the CMD line low. If the BOOT ACK is enabled, the eMMC4.3/eMMC4.4 device sends the BOOT ACK via the DATA lines and the...</td>
</tr>
</tbody>
</table>
Table 9-33. MMC and eMMC boot details (continued)

| eMMC4.4 device | ROM can read the BOOT ACK [S010E] to identify the eMMC4.3/eMMC4.4 device. The eMMC4.3/eMMC4.4 device with the "boot mode" feature can only be supported via the ESDHCv3-3 and with or without the BOOT ACK. If the BOOT ACK is enabled, the ROM waits 50 ms to get the BOOT ACK and if the BOOT ACK is received by the ROM. If BOOT ACK is disabled ROM waits 1 second for data. If the BOOT ACK or data was received, the eMMC4.3/eMMC4.4 is booted in the "boot mode", otherwise the eMMC4.3/eMMC4.4 boots as a normal MMC card from the selected boot partition. This boot mode can be selected by the BOOT_CFG[1][4] (fast boot) fuse. The BOOT ACK is selected by the BOOT_CFG[2][1]. |
| If using the eMMC4.4 device, the Double Data Rate (DDR) mode can be used. This mode can be selected by the BOOT_CFG[7:5] (bus width) fuse. |

Figure 9-6. Expansion device boot flow (1 of 6)
Figure 9-7. Expansion device (MMC) boot flow (2 of 6)
Figure 9-8. Expansion device (SD/eSD/SDXC) boot flow (3 of 6) part 1
Figure 9-9. Expansion device (SD/eSD/SDXC) boot flow (3 of 6) part 2
Figure 9-10. Expansion device (MMCSD/eSD/SDXC) boot flow (4 of 6)

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
Figure 9-11. Expansion device (SD/eSD) boot flow (5 of 6)
Figure 9-12. Expansion device boot flow (6 of 6)

Chapter 9 System Boot

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors

255
9.6.7.3  SD, eSD, and SDXC

After the normal boot mode initialization begins, the SD/eSD/SDXC frequency is set to 347.22 kHz. During the identification phase, the SD/eSD/SDXC card voltage validation is performed. During the voltage validation, the boot code first checks with the high-voltage settings; if that fails, it checks with the low-voltage settings.

The capacity of the card is also checked. The boot code supports the high-capacity and low-capacity SD/eSD/SDXC cards after the voltage validation card initialization is done.

During the card initialization, the ROM boot code attempts to set the boot partition for all SD, eSD, and SDXC devices. If this fails, the boot code assumes that the card is a normal SD or SDXC card. If it does not fail, the boot code assumes it is an eSD card. After the initialization phase is over, the boot code switches to a higher frequency (25 MHz in the normal-speed mode or 50 MHz in the high-speed mode). The ROM also supports the FAST_BOOT mode booting from the eSD card. This mode can be selected by the BOOT_CFG1[0] (Fast Boot).

For the UHSI cards, the clock speed fuses can be set to SDR50 or SDR104 on USDHC1, USDHC2 ports. This enables the voltage switch process to set the signaling voltage to 1.8 V during the voltage validation. The bus width is fixed at a 4-bit width and a sampling point tuning process is needed to calibrate the number of the delay cells. If the SD Loopback Clock eFuse is set, the feedback clock comes directly from the loopback SD clock, instead of the card clock (by default). The SD clock speed can be selected by the BOOT_CFG1[5:4], and the SD Loopback Clock is selected by the BOOT_CFG1[2].

The UHSI calibration start value (MMC_DLL_DLY[6:0]) and the step value SD_CALIBRATION_STEP[1:0] can be set to optimize the sample point tuning process.

If the SD Power Cycle Enable eFuse is 1, the ROM sets the SD_RST pad low, waits for 5 ms, and then sets the SD_RST pad high. If the SD_RST pad is connected to the SD power supply enable logic on board, it enables the power cycle of the SD card. This may be crucial in case the SD logic is in the 1.8 V states and must be reset to the 3.3 V states.

The SDR50 and SDR104 boots are not supported on the USDHC1 and USDHC2 ports because there are no reset signals for those ports when connected in the IOMUX.
9.6.7.4 IOMUX configuration for SD/MMC

Table 9-34. IOMUX configuration for SD/MMC

<table>
<thead>
<tr>
<th>Signal</th>
<th>USDHC1</th>
<th>USDHC2</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK</td>
<td>GPIO_SD_B0_01.alt0</td>
<td>GPIO_SD_B1_04.alt0</td>
</tr>
<tr>
<td>CMD</td>
<td>GPIO_SD_B0_00.alt0</td>
<td>GPIO_SD_B1_05.alt0</td>
</tr>
<tr>
<td>DATA0</td>
<td>GPIO_SD_B0_02.alt0</td>
<td>GPIO_SD_B1_03.alt0</td>
</tr>
<tr>
<td>DATA1</td>
<td>GPIO_SD_B0_03.alt0</td>
<td>GPIO_SD_B1_02.alt0</td>
</tr>
<tr>
<td>DATA2</td>
<td>GPIO_SD_B0_04.alt0</td>
<td>GPIO_SD_B1_01.alt0</td>
</tr>
<tr>
<td>DATA3</td>
<td>GPIO_SD_B0_05.alt0</td>
<td>GPIO_SD_B1_00.alt0</td>
</tr>
<tr>
<td>DATA4</td>
<td>—</td>
<td>GPIO_SD_B1_08.alt0</td>
</tr>
<tr>
<td>DATA5</td>
<td>—</td>
<td>GPIO_SD_B1_09.alt0</td>
</tr>
<tr>
<td>DATA6</td>
<td>—</td>
<td>GPIO_SD_B1_10.alt0</td>
</tr>
<tr>
<td>DATA7</td>
<td>—</td>
<td>GPIO_SD_B1_11.alt0</td>
</tr>
<tr>
<td>VSELECT</td>
<td>GPIO_B1_14.alt6</td>
<td>GPIO_EMC_38.alt6</td>
</tr>
<tr>
<td>RESET_B</td>
<td>GPIO_B1_15.alt6</td>
<td>GPIO_SD_B1_06.alt0</td>
</tr>
<tr>
<td>CD_B</td>
<td>GPIO_B1_12.alt6</td>
<td>—</td>
</tr>
</tbody>
</table>

9.6.7.5 Redundant boot support for expansion device

The ROM supports the redundant boot for an expansion device. The primary or secondary image is selected, depending on the PERSIST_SECONDARY_BOOT setting. (see Table 9-8).

If the PERSIST_SECONDARY_BOOT is 0, the boot ROM uses address 0x0 for the primary image.

If the PERSIST_SECONDARY_BOOT is 1, the boot ROM reads the secondary image table from address 0x200 on the boot media and uses the address specified in the table.

Table 9-35. Secondary image table format

<table>
<thead>
<tr>
<th>Field</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved (chipNum)</td>
<td></td>
</tr>
<tr>
<td>Reserved (driveType)</td>
<td></td>
</tr>
<tr>
<td>tag</td>
<td></td>
</tr>
<tr>
<td>firstSectorNumber</td>
<td></td>
</tr>
<tr>
<td>Reserved (sectorCount)</td>
<td></td>
</tr>
</tbody>
</table>

Where:

- The tag is used as an indication of the valid secondary image table. It must be 0x00112233.
- The firstSectorNumber is the first 512-byte sector number of the secondary image.
For the secondary image support, the primary image must reserve the space for the secondary image table. See this figure for the typical structures layout on an expansion device.

<table>
<thead>
<tr>
<th>Structure</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved For MBR (optional)</td>
<td>0x00000000</td>
</tr>
<tr>
<td>Reserved for Secondary Image Table (optional)</td>
<td>0x00000200</td>
</tr>
<tr>
<td>Program Image (Starting From IVT)</td>
<td>0x00000400</td>
</tr>
<tr>
<td>Media Partitions</td>
<td></td>
</tr>
</tbody>
</table>

**Figure 9-13. Expansion device structures layout**

For the Closed mode, if there are failures during primary image authentication, the boot ROM turns on the PERSIST_SECONDARY_BOOT bit (see Table 9-8) and performs the software reset. (After the software reset, the secondary image is used.)
9.6.8 Serial NOR/EEPROM through LPSPI

The chip supports booting from serial memory devices, such as EEPROM and serial flash, using the LPSPI.

These ports are available for serial boot: LPSPI interfaces.

9.6.8.1 Serial NOR/EEPROM eFUSE configuration

The boot ROM code determines the type of device using the following parameters, provided by the eFUSE settings, during boot.

<table>
<thead>
<tr>
<th>Fuse</th>
<th>Config</th>
<th>Definition</th>
<th>GPIO</th>
<th>Shipped value</th>
<th>Settings</th>
</tr>
</thead>
<tbody>
<tr>
<td>EEPROM_RECOVRY_EN(0x6D0[24])</td>
<td>OEM</td>
<td>EEPROM recovery enable</td>
<td>No</td>
<td>0</td>
<td>0 - Disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Enabled</td>
</tr>
<tr>
<td>LPSPI_PORT_SEL(0x6D0[26:25])</td>
<td>OEM</td>
<td>Port select</td>
<td>No</td>
<td>00</td>
<td>00 - LPSPI1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - LPSPI2</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - LPSPI3 (if applicable in the device)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11 - LPSPI4 (if applicable in the device)</td>
</tr>
<tr>
<td>LPSPI_ADDR(0x6D0[27])</td>
<td>OEM</td>
<td>SPI addressing (SPI only)</td>
<td>No</td>
<td>0</td>
<td>0 - 3B (24-bit)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - 2B (16-bit)</td>
</tr>
<tr>
<td>LPSPI_SPEED (0x6D0[29:28])</td>
<td>OEM</td>
<td>LPSPi Speed select</td>
<td>No</td>
<td>00</td>
<td>00 - 20 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - 10 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - 5 MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11 - 2 MHz</td>
</tr>
</tbody>
</table>

The LPSPI\(n\) block can be used as a boot device using the LPSPI interface for the serial ROM boot. The SPI interface is configured to operate at speed specified by LPSPI_SPEED_SEL fuse field.

The boot ROM copies 4 KB of data from the serial ROM device to the internal RAM. After checking the Image Vector Table header value (0xD1) from the program image, the ROM code performs a DCD check. After a successful DCD extraction, the ROM code extracts the destination pointer and length of image from the Boot Data Structure to be copied to the RAM device from where the code execution occurs.
Program image

NOTE
The Initial 4 KB of program image must contain the IVT, DCD, and the Boot Data Structures.

9.7 Program image

This section describes the data structures that are required to be included in the user's program image. The program image consists of:

- Image vector table—a list of pointers located at a fixed address that the ROM examines to determine where the other components of the program image are located.
- Boot data—a table that indicates the program image location, program image size in bytes, and the plugin flag.
- Device configuration data—IC configuration data.
- User code and data.

9.7.1 Image Vector Table and Boot Data

The Image Vector Table (IVT) is the data structure that the ROM reads from the boot device supplying the program image containing the required data components to perform a successful boot.

The IVT includes the program image entry point, a pointer to Device Configuration Data (DCD) and other pointers used by the ROM during the boot process. The ROM locates the IVT at a fixed address that is determined by the boot device connected to the Chip. The IVT offset from the base address for each boot device type is defined in the table below. The location of the IVT is the only fixed requirement by the ROM. The remainder or the image memory map is flexible and is determined by the contents of the IVT.

<table>
<thead>
<tr>
<th>Boot Device Type</th>
<th>Image Vector Table Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FlexSPI NOR/SEMC NOR</td>
<td>4 Kbyte = 0x1000 bytes</td>
</tr>
<tr>
<td>SD/MMC/eSD/eMMC/SDXC</td>
<td>1 Kbyte = 0x400 bytes</td>
</tr>
<tr>
<td>SPI NOR/EEPROM/SEMC NAND/ FlexSPI NAND</td>
<td>1 Kbyte = 0x400 bytes</td>
</tr>
</tbody>
</table>
9.7.1.1 Image vector table structure

The IVT has the following format where each entry is a 32-bit word:

Table 9-38. IVT format

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>header</td>
<td>Absolute address of the first instruction to execute from the image</td>
</tr>
<tr>
<td>entry</td>
<td>Reserved and should be zero</td>
</tr>
<tr>
<td>reserved1</td>
<td>Absolute address of the image DCD. The DCD is optional so this field may be set to NULL if no DCD is required. See Device Configuration Data (DCD) for further details on the DCD.</td>
</tr>
<tr>
<td>dcd</td>
<td>After DCD</td>
</tr>
<tr>
<td>boot_data</td>
<td>Absolute address of the boot data</td>
</tr>
<tr>
<td>self</td>
<td>Absolute address of the IVT. Used internally by the ROM</td>
</tr>
<tr>
<td>csf</td>
<td>Absolute address of the Command Sequence File (CSF) used by the HAB library. See High-Assurance Boot (HAB) for details on the secure boot using HAB. This field must be set to NULL if a CSF is not provided in the image</td>
</tr>
<tr>
<td>reserved2</td>
<td>Reserved and should be zero</td>
</tr>
</tbody>
</table>
NOTE

The DCD is not supported in the BootROM, in this device. It must be set to 0x00.

Figure 9-15 shows the IVT header format:

<table>
<thead>
<tr>
<th>Tag</th>
<th>Length</th>
<th>Version</th>
</tr>
</thead>
</table>

Figure 9-15. IVT header format

where:

Tag: A single byte field set to 0xD1
Length: a two byte field in big endian format containing the overall length of the IVT, in bytes, including the header. (the length is fixed and must have a value of 32 bytes)
Version: A single byte field set to 0x40 or 0x41

9.7.1.2 Boot data structure

The boot data must follow the format defined in the table found here, each entry is a 32-bit word.

Table 9-39. Boot data format

<table>
<thead>
<tr>
<th>start</th>
<th>Absolute address of the image</th>
</tr>
</thead>
<tbody>
<tr>
<td>length</td>
<td>Size of the program image</td>
</tr>
<tr>
<td>plugin</td>
<td>Plugin flag (see Plugin image)</td>
</tr>
</tbody>
</table>

9.7.2 Device Configuration Data (DCD)

Upon reset, the chip uses the default register values for all peripherals in the system. However, these settings typically are not ideal for achieving the optimal system performance and there are even some peripherals that must be configured before they can be used.

The DCD is a configuration information contained in the program image (external to the ROM) that the ROM interprets to configure various peripherals on the chip.
For example, some components (such as SDRAM) require some sequence of register programming as a part of the configuration before it is ready to be used. The DCD feature can be used to program the SEMC register to the optimal settings.

The ROM determines the location of the DCD table based on the information located in the Image Vector Table (IVT). See Image Vector Table and Boot Data for more details. The DCD table shown below is a big-endian byte array of the allowable DCD commands. The maximum size of the DCD is limited to 1768 B.

<table>
<thead>
<tr>
<th>Header</th>
</tr>
</thead>
<tbody>
<tr>
<td>[CMD]</td>
</tr>
<tr>
<td>[CMD]</td>
</tr>
<tr>
<td>...</td>
</tr>
</tbody>
</table>

**Figure 9-16. DCD data format**

The DCD header is 4 B with the following format:

<table>
<thead>
<tr>
<th>Tag</th>
<th>Length</th>
<th>Version</th>
</tr>
</thead>
</table>

**Figure 9-17. DCD header format**

where:

- **Tag**: A single-byte field set to 0xD2
- **Length**: a two-byte field in the big-endian format containing the overall length of the DCD (in bytes) including the header
- **Version**: A single-byte field set to 0x41

### 9.7.2.1 Write data command

The write data command is used to write a list of given 1-, 2- or 4-byte values (or bitmasks) to a corresponding list of target addresses.

The Value/Mask fields are always 32-bits. If the parameter field specifies a smaller size, then the extra bytes must be zero.
The format of the write data command (in a big-endian byte array) is shown in this table:

**Table 9-40. Write data command format**

<table>
<thead>
<tr>
<th>Tag</th>
<th>Length</th>
<th>Parameter</th>
</tr>
</thead>
<tbody>
<tr>
<td>Address</td>
<td>Value/Mask</td>
<td></td>
</tr>
<tr>
<td>[Address]</td>
<td>[Value/Mask]</td>
<td></td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td></td>
</tr>
<tr>
<td>[Address]</td>
<td>[Value/Mask]</td>
<td></td>
</tr>
</tbody>
</table>

where:

- **Tag**: a single-byte field set to 0xCC
- **Length**: a two-byte field in a big-endian format, containing the length of the Write Data Command (in bytes) including the header
- **Address**: the target address to which the data must be written
- **Value/Mask**: the data value (or bitmask) to be written to the preceding address

The parameter field is a single byte divided into the bitfields, as follows:

**Table 9-41. Write data command parameter field**

<table>
<thead>
<tr>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>flags</td>
<td>bytes</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

where

- **bytes**: the width of the target locations in bytes (either 1, 2, or 4)
- **flags**: control flags for the command behavior
  - **Data Mask**: bit 3: if set, only specific bits may be overwritten at the target address (otherwise all bits may be overwritten)
  - **Data Set**: bit 4: if set, the bits at the target address are overwritten with this flag (otherwise it is ignored)

One or more target address and value/bitmask pairs can be specified. The same bytes' and flags' parameters apply to all locations in the command.

When successful, this command writes to each target address in accordance with the flags as follows:

**Table 9-42. Interpretation of write data command flags**

<table>
<thead>
<tr>
<th>&quot;Mask&quot;</th>
<th>&quot;Set&quot;</th>
<th>Action</th>
<th>Interpretation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>address = val_msk</td>
<td>Write value</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>address = val_msk</td>
<td>Write value</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>address &amp;= ~val_msk</td>
<td>Clear bitmask</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>address</td>
<td>= val_msk</td>
</tr>
</tbody>
</table>
NOTE

If any of the target addresses does not have the same alignment as the data width indicated in the parameter field, none of the values are written.

If any of the values are larger or any of the bitmasks are wider than permitted by the data width indicated in the parameter field, none of the values are written.

If any of the target addresses do not lie within the allowed region, none of the values are written. The list of allowable blocks and target addresses for the chip are provided below.

Table 9-43. Valid DCD address ranges

<table>
<thead>
<tr>
<th>Address range</th>
<th>Start address</th>
<th>Last address</th>
</tr>
</thead>
<tbody>
<tr>
<td>IOMUX Control SNVS GPR(IOMUXC_SNVS_GPR) registers</td>
<td>0x400A_4000</td>
<td>0x400A_7FFF</td>
</tr>
<tr>
<td>IOMUX Control SNVS (IOMUXC_SNVS) registers</td>
<td>0x400A_8000</td>
<td>0x400A_BFFF</td>
</tr>
<tr>
<td>IOMUX Control GPR(IOMUXC_GPR) registers</td>
<td>0x400A_C000</td>
<td>0x400A_FFFF</td>
</tr>
<tr>
<td>CCM Analog (ANATOP) registers</td>
<td>0x400D_8000</td>
<td>0x400D_BFFF</td>
</tr>
<tr>
<td>CCM registers</td>
<td>0x400F_C000</td>
<td>0x400F_FFFF</td>
</tr>
<tr>
<td>SEMC registers</td>
<td>0x402F_0000</td>
<td>0x402F_3FFF</td>
</tr>
</tbody>
</table>

9.7.2.2 Check data command

The check data command is used to test for a given 1-, 2-, or 4-byte bitmasks from a source address.

The check data command is a big-endian byte array with the format shown in this table:

Table 9-44. Check data command format

<table>
<thead>
<tr>
<th>Tag</th>
<th>Length</th>
<th>Parameter</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Address</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Mask</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[Count]</td>
<td></td>
</tr>
</tbody>
</table>

where:
- **Tag**: a single-byte field set to 0xCF
- **Length**: a two-byte field in the big-endian format containing the length of the check data command (in bytes) including the header
- **Address**: the source address to test
- **Mask**: the bit mask to test
Count: an optional poll count; If the count is not specified, this command polls indefinitely until the exit condition is met. If count = 0, this command behaves as for the NOP.

The parameter field is a single byte divided into bitfields, as follows:

**Table 9-45. Check data command parameter field**

<table>
<thead>
<tr>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>flags</td>
<td>bytes</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

where

- **bytes**: the width of target locations in bytes (either 1, 2, or 4)
- **flags**: control flags for the command behavior
  - Data Mask = bit 3: if set, only the specific bits may be overwritten at a target address (otherwise all bits may be overwritten)
  - Data Set = bit 4: if set, the bits at the target address are overwritten with this flag (otherwise it is ignored)

This command polls the source address until either the exit condition is satisfied, or the poll count is reached. The exit condition is determined by the flags as follows:

**Table 9-46. Interpretation of check data command flags**

<table>
<thead>
<tr>
<th>&quot;Mask&quot;</th>
<th>&quot;Set&quot;</th>
<th>Action</th>
<th>Interpretation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>(*address &amp; mask) == 0</td>
<td>All bits clear</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>(*address &amp; mask) == mask</td>
<td>All bits set</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>(*address &amp; mask) != mask</td>
<td>Any bit clear</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>(*address &amp; mask) != 0</td>
<td>Any bit set</td>
</tr>
</tbody>
</table>

**NOTE**

If the source address does not have the same alignment as the data width indicated in the parameter field, the value is not read.

If the bitmask is wider than permitted by the data width indicated in the parameter field, the value is not read.

### 9.7.2.3 NOP command

This command has no effect.

The format of the NOP command is a big-endian four-byte array, as shown in this table:

**Table 9-47. NOP command format**

<table>
<thead>
<tr>
<th>Tag</th>
<th>Length</th>
<th>Undefined</th>
</tr>
</thead>
</table>

where:

Tag: a single-byte field set to 0xC0
Length: a two-byte field in big endian containing the length of the NOP command in bytes (fixed to a value of 4)
Undefined: this byte is ignored and can be set to any value.

9.8 Plugin image

The ROM supports a limited number of boot devices. When using other devices as a boot source (for example, Ethernet or USB), the supported boot device must be used (typically serial flash) as a firmware to provide the missing boot drivers. Additionally, the plugin can be customized to support boot drivers, which is more flexible when performing the device initialization, such as condition judging, delay assertion, or to apply custom settings to the boot device and memory system.

In addition to the standard images, the chip also supports plugin images. The plugin images return the execution to the ROM whereas the standard image does not.

The boot ROM detects the image type using the plugin flag of the boot data structure (see Boot data structure). If the plugin flag is 1, then the ROM uses the image as a plugin function. The function must initialize the boot device and copy the program image to the final location. At the end, the plugin function must return with the program image parameters. (See High-level boot sequence for details about the boot flow).

The boot ROM authenticates the plugin image before running the plugin function and then authenticates the program image.

The plugin function must follow the API described below:

typedef BOOLEAN (*plugin_download_f)(void **start, size_t *bytes, UINT32 *ivt_offset);

ARGUMENTS PASSED:

- start - the image load address on exit.
- bytes - the image size on exit.
- ivt_offset - the offset (in bytes) of the IVT from the image start address on exit.

RETURN VALUE:

- 1 - success
- 0 - failure
9.9 Serial Downloader

The Serial Downloader provides a means to download a program image to the chip over the USB and UART serial connection.

In this mode, the ROM programs the WDOG1 for a time-out specified by the fuse WDOG Time-out Select (See the Fusemap chapter for details) if the WDOG_ENABLE eFuse is 1 and continuously polls for the USB and UART connection. If no activity is found on the USB OTG1 and UART and the watchdog timer expires, the Arm core is reset.

**NOTE**

After the downloaded image is loaded, it is responsible for managing the watchdog resets properly.

This figure shows the USB and UART boot flow:
Figure 9-18. Serial Downloader boot flow
9.9.1 USB

The USB support is composed of the USB1 (USB OTG1 core controller, compliant with the USB 2.0 specification) and the USBPHY (HS USB transceiver).

The ROM supports the USB1 port for boot purposes. The other USB ports on the chip are not supported for boot purposes.

The USB Driver is implemented as a USB HID class. A collection of four HID reports are used to implement the SDP protocol for data transfers, as described in Table 9-48.

<table>
<thead>
<tr>
<th>Report ID (first byte)</th>
<th>Transfer endpoint</th>
<th>Direction</th>
<th>Length</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>control OUT</td>
<td>Host to device</td>
<td>17 B</td>
<td>SDP command from the host to the device.</td>
</tr>
<tr>
<td>2</td>
<td>control OUT</td>
<td>Host to device</td>
<td>Up to 1025 B</td>
<td>Data associated with the report 1 SDP command.</td>
</tr>
<tr>
<td>3</td>
<td>interrupt</td>
<td>Device to host</td>
<td>5 B</td>
<td>HAB security configuration. The device sends 0x12343412 in the closed mode and 0x56787856 in the open mode.</td>
</tr>
<tr>
<td>4</td>
<td>interrupt</td>
<td>Device to host</td>
<td>Up to 65 B</td>
<td>Data in response to the SDP command in report 1.</td>
</tr>
</tbody>
</table>

9.9.1.1 USB configuration details

The USB OTG function device driver supports a high speed (HS for UTMI) non-stream mode with a maximal packet size of 512 B and a low-level USB OTG function.

The VID/PID and strings for the USB device driver are listed in the following table.

<table>
<thead>
<tr>
<th>Descriptor</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>VID</td>
<td>0x1FC9 (NXP vendor ID)</td>
</tr>
<tr>
<td>PID¹</td>
<td>0x0135</td>
</tr>
<tr>
<td>String Descriptor1 (manufacturer)</td>
<td>NXP Semiconductors</td>
</tr>
<tr>
<td>String Descriptor2 (product)</td>
<td>S Blank</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-49. VID/PID and strings for USB device driver (continued)

<table>
<thead>
<tr>
<th>Descriptor</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>String Descriptor4</td>
<td>NXP Flash</td>
</tr>
<tr>
<td>String Descriptor5</td>
<td>NXP Flash</td>
</tr>
</tbody>
</table>

1. Allocation based on the BPN (Before Part Number)

### 9.9.1.2 IOMUX configuration for USB

The interface signals of the UTMI PHY are not configured in the IOMUX. The UTMI PHY interface uses the dedicated contacts on the IC. See the chip data sheet for details.

### 9.9.2 Serial Download Protocol (SDP)

The 16-byte SDP command from the host to device is sent using the HID report 1. This table describes the 16-byte SDP command data structure:

Table 9-50. 16-byte SDP command data structure

<table>
<thead>
<tr>
<th>BYTE offset</th>
<th>Size</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>2</td>
<td>COMMAND TYPE</td>
<td>These commands are supported for the ROM:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• 0x0101 READ_REGISTER</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• 0x0202 WRITE_REGISTER</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• 0x0404 WRITE_FILE</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• 0x0505 ERROR_STATUS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• 0x0A0A DCD_WRITE</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• 0x0B0B JUMP_ADDRESS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• 0x0D0D SET_BAUDRATE (only applicable to UART)</td>
</tr>
<tr>
<td>2</td>
<td>4</td>
<td>ADDRESS</td>
<td>Only relevant for these commands:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>READ_REGISTER, WRITE_REGISTER, WRITE_FILE, DCD_WRITE, and JUMP_ADDRESS.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>For the READ_REGISTER and WRITE_REGISTER commands, this field is the address to a register. For the WRITE_FILE and JUMP_ADDRESS commands, this field is an address to the internal or external memory address.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td><strong>NOTE:</strong> For SET_BAUDRATE command, this word is the baudrate value in big-endian format.</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>FORMAT</td>
<td>Format of access, 0x8 for an 8-bit access, 0x10 for a 16-bit access, and 0x20 for a 32-bit access. Only relevant for the READ_REGISTER and WRITE_REGISTER commands.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 9-50. 16-byte SDP command data structure (continued)

<table>
<thead>
<tr>
<th>BYTE offset</th>
<th>Size</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>4</td>
<td>DATA COUNT</td>
<td>Size of the data to read or write in bytes. Only relevant for the WRITE_FILE, READ_REGISTER, WRITE_REGISTER, and DCD_WRITE commands. For the WRITE_FILE and DCD_WRITE commands, the DATA COUNT is in the byte units.</td>
</tr>
<tr>
<td>11</td>
<td>4</td>
<td>DATA</td>
<td>The value to write. Only relevant for the WRITE_REGISTER command.</td>
</tr>
<tr>
<td>15</td>
<td>1</td>
<td>RESERVED</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 9.9.2.1 SDP commands

The SDP commands are described in the following sections.

#### 9.9.2.1.1 READ_REGISTER

The transaction for the READ_REGISTER command consists of these reports: Report1 for the command, Report3 for the security configuration, and Report4 for the response or the register value.

The register to read is specified in the ADDRESS field of the SDP command. The first device sends Report3 with the security configuration followed by the Report4 with the bytes read at a given address. If the count is greater than 64, multiple reports with the report id 4 are sent until the entire data requested by the host is sent. The STATUS is either 0x12343412 for the closed parts and 0x56787856 for the open or field return parts.

**Report1, Command, Host to Device:**

1

| 1 | Valid values for the READ_REGISTER COMMAND, ADDRESS, FORMAT, DATA_COUNT |

**ID 16-byte SDP command**

**Report3, Response, Device to Host:**

3

| 3 | Four bytes indicating the security configuration |

**ID 4 bytes status**

**Report4, Response, Device to Host: first response report**

4

| 4 | Register value |
ID 4 bytes of data containing the register value. If the number of bytes requested is less than 4, the remaining bytes must be ignored by the host.

Multiple reports of the report id 4 are sent until the entire requested data is sent. Report4, Response, Device to Host: last response report

<table>
<thead>
<tr>
<th></th>
<th>Register value</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td></td>
</tr>
</tbody>
</table>

ID 64 bytes of data containing the register value. If the number of bytes requested is less than 64, the remaining bytes must be ignored by the host.

### 9.9.2.1.2 WRITE_REGISTER

The transaction for the WRITE_REGISTER command consists of these reports: Report1 for the command, Report3 for the security configuration and Report4 for the write status.

The host sends Report1 with the WRITEREGISTER command. The register to write is specified in the ADDRESS field of the SDP command of Report1, with the FORMAT field set to the data type (number of bits to write, either 8, 16, or 32) and the value to write in the DATA field of the SDP command. The device writes the DATA to the register address and returns the WRITE_COMPLETE code using Report4 and the security configuration using Report3 to complete the transaction.

Report1, Command, Host to Device:

<table>
<thead>
<tr>
<th></th>
<th>Valid values for WRITE_REGISTER COMMAND, ADDRESS, FORMAT, DATA_COUNT and DATA</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

ID 16-byte SDP command

Report3, Response, Device to Host:

<table>
<thead>
<tr>
<th></th>
<th>4 bytes indicating the security configuration</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td></td>
</tr>
</tbody>
</table>

ID 4 bytes status

Report4, Response, Device to Host:

<table>
<thead>
<tr>
<th></th>
<th>WRITE_COMPLETE (0x128A8A12) status</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td></td>
</tr>
</tbody>
</table>

ID 64 bytes data with the first 4 bytes to indicate that the write is completed with code 0x128A8A12. On failure, the device reports the HAB error status.
9.9.2.1.3 WRITE_FILE

The transaction for the WRITE_FILE command consists of these reports: Report1 for the command phase, Report2 for the data phase, Report3 for the HAB mode, and Report4 to indicate that the data are received in full.

The size of each Report2 is limited to 1024 bytes (limitation of the USB HID protocol). Hence, multiple Report2 packets are sent by the host in the data phase until the entire data is transferred to the device. When the entire data (DATA_COUNT bytes) is received, the device sends Report3 with the HAB mode and Report4 with 0x88888888, indicating that the file download completed.

Report1, Host to Device:

| 1 | Valid values for WRITE_FILE COMMAND, ADDRESS, DATA_COUNT |

ID 16-byte SDP command

Optional Begin

Host sends the ERROR_STATUS command to query if the HAB rejected the address

Optional End

Report2, Host to Device:

| 2 | File data |

ID Max 1024 bytes data per report

Report2, Host to Device:

| 2 | File data |

ID Max 1024 bytes data per report

Report3, Device to Host:

| 3 | 4 bytes indicating security configuration |

ID 4 bytes status

Report4, Response, Device to Host:
ID 64 bytes data with the first four bytes to indicate that the file download completed with code 0x88888888. On failure, the device reports the HAB error status.

### 9.9.2.1.4 ERROR_STATUS

The transaction for the SDP command ERROR_STATUS consists of three reports.

Report1 is used by the host to send the command; the device sends global error status in four bytes of Report4 after returning the security configuration in Report3. When the device receives the ERROR_STATUS command, it returns the global error status that is updated for each command. This command is useful to find out whether the last command resulted in a device error or succeeded.

**Report1, Command, Host to Device:**

<table>
<thead>
<tr>
<th>ID</th>
<th>1</th>
<th>ERROR_STATUS COMMAND</th>
</tr>
</thead>
</table>

ID 16-byte SDP Command

**Report3, Response, Device to Host:**

<table>
<thead>
<tr>
<th>ID</th>
<th>3</th>
<th>Four bytes indicating the security configuration</th>
</tr>
</thead>
</table>

ID 4 bytes status

**Report4, Response, Device to Host:**

<table>
<thead>
<tr>
<th>ID</th>
<th>4</th>
<th>Four bytes Error status</th>
</tr>
</thead>
</table>

ID first 4 bytes status in 64 bytes Report4

### 9.9.2.1.5 DCD_WRITE

The SDP command DCD_WRITE is used by the host to send multiple register writes in one shot. This command is provided to speed up the process of programming the register writes (such as to configure an external RAM device).

The command goes with Report1 from the host with COMMAND TYPE set to DCD_WRITE, ADDRESS which is used as a temporary location of the DCD data, and DATA_COUNT to the number of bytes sent in the data out phase. In the data phase, the
host sends the data for a number of registers using Report2. The device completes the transaction with Report3 indicating the security configuration and Report4 with the WRITE_COMPLETE code 0x12828212.

Report1, Command, Host to Device:

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>DCD_WRITE COMMAND, ADDRESS, DATA_COUNT</td>
</tr>
</tbody>
</table>

ID 16-byte SDP Command

Report2, Data, Host to Device:

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>DCD binary data</td>
</tr>
</tbody>
</table>

ID Max 1024 bytes per report

Report3, Response, Device to Host:

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>Four bytes indicating the security configuration</td>
</tr>
</tbody>
</table>

ID 4 bytes status

Report4, Response, Device to Host:

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>WRITE_COMPLETE (0x128A8A12) status</td>
</tr>
</tbody>
</table>

ID 64 bytes report with the first four bytes to indicate that the write completed with the code 0x128A8A12. On failure, the device reports the HAB error status.

See **Device Configuration Data (DCD)** for the DCD format description.

### 9.9.2.1.6 JUMP_ADDRESS

The SDP command JUMP_ADDRESS is the last command that the host can send to the device. After this command, the device jumps to the address specified in the ADDRESS field of the SDP command and starts to execute.

This command usually follows after the WRITE_FILE command. The command is sent by the host in the command-phase of the transaction using Report1. There is no data phase for this command, but the device sends the status Report3 to complete the transaction. If the authentication fails, it also sends Report4 with the HAB error status.

Report1, Command, Host to Device:
ID 16-byte SDP Command

Report3, Response, Device to Host:

3 Four bytes indicating the security configuration

ID 4 bytes status

This report is sent by the device only in case of an error jumping to the given address, or if the device reports error in Report4, Response, Device to Host:

4 Four bytes HAB error status

ID 4 bytes status, 64 bytes report length

9.9.2.1.7 SET_BAUDRATE

The SDP command SET_BAUDRATE is used by the host to configure the UART baudrate on the device side. The default baudrate is 115200.

The transaction for SET_BAUDRATE command consists of 2 stages.

Stage 1, Command, Host to Device:

<table>
<thead>
<tr>
<th>Byte 0</th>
<th>Byte 1</th>
<th>Byte 2</th>
<th>Byte 3</th>
<th>Byte 4</th>
<th>Byte 5</th>
<th>Byte 6 to 15</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0d</td>
<td>0x0d</td>
<td>baudrate [31:24]</td>
<td>baudrate [23:16]</td>
<td>baudrate [15:8]</td>
<td>baudrate [7:0]</td>
<td>All 0x00</td>
</tr>
</tbody>
</table>

Stage 2, Response, Device to Host:

<table>
<thead>
<tr>
<th>Byte 0</th>
<th>Byte 1</th>
<th>Byte 2</th>
<th>Byte 3</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x09</td>
<td>0xd0</td>
<td>0x0d</td>
<td>0x90</td>
</tr>
</tbody>
</table>

After receiving the Response, the host needs to wait about 100 μs until the device is ready for accepting a new command using the specified baudrate.
9.10 Recovery devices

The chip supports recovery devices. If the primary boot device fails, the boot ROM tries to boot from the recovery device using one of the LP SPI ports.

To enable the recovery device, the EEPROM_RECOVERY_EN fuse must be set. Additionally, the serial EEPROM fuses must be set as described in Serial NOR/EEPROM through LP SPI.

9.11 SD/MMC manufacture mode

When the internal boot and recover boot (if enabled) failed, the boot goes to the SD/MMC manufacture mode before the serial download mode. In the manufacture mode, one bit bus width is used despite of the fuse setting.

![Flowchart of SD/MMC manufacture boot flow](image-url)

**Figure 9-19. SD/MMC manufacture boot flow**
9.12 High-Assurance Boot (HAB)

The High Assurance Boot (HAB) component of the ROM protects against the potential threat of attackers modifying the areas of code or data in the programmable memory to make it behave in an incorrect manner. The HAB also prevents the attempts to gain access to features which must not be available.

The integration of the HAB feature with the ROM code ensures that the chip does not enter an operational state if the existing hardware security blocks detected a condition that may be a security threat or if the areas of memory deemed to be important were modified. The HAB uses the RSA digital signatures to enforce these policies.

Figure 9-20. Secure boot components

The figure above illustrates the components used during a secure boot using HAB. The HAB interfaces with the SNVS to make sure that the system security state is as expected. The HAB also uses the hardware block to accelerate the SHA-256 message digest operations performed during the signature verifications. The HAB also includes a software implementation of SHA-256 for cases where a hardware accelerator cannot be used. The RSA key sizes supported are 1024, 2048, 3072 and 4096 bits. The RSA signature verification operations are performed by a software implementation contained in the HAB library. The main features supported by the HAB are:

- X.509 public key certificate support
- CMS signature format support
NOTE
NXP provides the reference Code Signing Tool (CST) for key
generation and code signing for use with the HAB library. The
CST can be found by searching for "IMX_CST_TOOL" at

NOTE
For further details on using the secure boot feature using HAB,
contact your local NXP representative.

9.12.1 HAB API vector table addresses

For devices that perform a secure boot, the HAB library may be called by the boot stages
that execute after the ROM code.

The HAB API vector table for this device is at address 0x0020_0300.

NOTE
For additional information on the secure boot including the
HAB API, contact your local NXP representative.

9.13 ROM APIs

9.13.1 Introduction

The ROM bootloader provides a set of ROM APIs to simply the In-Application
Programming (IAP) and WDOG operation.

The ROM bootloader supports the following APIs:
• runBootloader API
• FlexSPI NOR Flash Driver API
• RTWDOG Driver API
• WDOG Driver API

The ROM API root pointer is located at address 0x0020001c. See the following figure for
details of the ROM API layout.
The ROM API structure definitions are as below:

1. RTWDOG driver API structure

```c
typedef struct
{
    void (*RTWDOG_GetDefaultConfig)(rtwdog_config_t *config);
    void (*RTWDOG_Init)(RTWDOG_Type *base, const rtwdog_config_t *config);
    void (*RTWDOG_Deinit)(RTWDOG_Type *base);
    void (*RTWDOG_Enable)(RTWDOG_Type *base);
    void (*RTWDOG_Disable)(RTWDOG_Type *base);
    void (*RTWDOG_EnableInterrupts)(RTWDOG_Type *base, uint32_t mask);
    void (*RTWDOG_DisableInterrupts)(RTWDOG_Type *base, uint32_t mask);
    uint32_t (*RTWDOG_GetStatusFlags)(RTWDOG_Type *base);
    void (*RTWDOG_ClearStatusFlags)(RTWDOG_Type *base, uint32_t mask);
    void (*RTWDOG_SetTimeoutValue)(RTWDOG_Type *base, uint16_t timeoutCount);
    void (*RTWDOG_SetWindowValue)(RTWDOG_Type *base, uint16_t windowValue);
    void (*RTWDOG_Unlock)(RTWDOG_Type *base);
    void (*RTWDOG_Refresh)(RTWDOG_Type *base);
    uint16_t (*RTWDOG_GetCounterValue)(RTWDOG_Type *base);
} rtwdog_driver_interface_t;
```

2. WDOG driver API structure

```c
typedef struct
{
    void (*WDOG_GetDefaultConfig)(wdog_config_t *config);
    void (*WDOG_Init)(WDOG_Type *base, const wdog_config_t *config);
    void (*WDOG_Deinit)(WDOG_Type *base);
    void (*WDOG_Enable)(WDOG_Type *base);
    void (*WDOG_Disable)(WDOG_Type *base);
    void (*WDOG_EnableInterrupts)(WDOG_Type *base, uint16_t mask);
    uint16_t (*WDOG_GetStatusFlags)(WDOG_Type *base);
    void (*WDOG_ClearStatusFlags)(WDOG_Type *base, uint16_t mask);
    void (*WDOG_SetWindowValue)(WDOG_Type *base, uint16_t windowValue);
    void (*WDOG_Unlock)(WDOG_Type *base);
    void (*WDOG_Refresh)(WDOG_Type *base);
    uint16_t (*WDOG_GetCounterValue)(WDOG_Type *base);
} wdog_driver_interface_t;
```
void (*WDOG_ClearInterruptStatus)(WDOG_Type *base, uint16_t mask);
void (*WDOG_SetTimeoutValue)(WDOG_Type *base, uint16_t timeoutCount);
void (*WDOG_SetInterruptTimeoutValue)(WDOG_Type *base, uint16_t timeoutCount);
void (*WDOG_DisablePowerDownEnable)(WDOG_Type *base);
void (*WDOG_Refresh)(WDOG_Type *base);
} wdog_driver_interface_t;

3. Bootloader API Entry Structure

typedef struct
{
    const uint32_t version;                               //!< Bootloader version number
    const char *copyright;                                 //!< Bootloader Copyright
    void (*runBootloader)(void *arg);                      //!< Function to start the bootloader executing
    const uint32_t *reserved0;                             //!< Reserved
    const flexspi_nor_driver_interface_t *flexSpiNorDriver; //!< FlexSPI NOR Flash API
    const uint32_t *reserved1;                             //!< Reserved
    const rtwdog_driver_interface_t *rtwdogDriver;         //!< RTWDOG Driver Interface
    const uint32_t *reserved2;
} bootloader_api_entry_t;
#define g_bootloaderTree (*(bootloader_api_entry_t**)(0x0020001c))

4. FlexSPI NOR Driver API structure

typedef struct
{
    uint32_t version;
    status_t (*init)(uint32_t instance, flexspi_nor_config_t *config);
    status_t (*program)(uint32_t instance, flexspi_nor_config_t *config, uint32_t
    dst_addr, const uint32_t *src);
    status_t (*erase_all)(uint32_t instance, flexspi_nor_config_t *config);
    status_t (*erase)(uint32_t instance, flexspi_nor_config_t *config, uint32_t start,
    uint32_t lengthInBytes);
    status_t (*read)(uint32_t instance, flexspi_nor_config_t *config, uint32_t *dst, uint32_t addr,
    uint32_t lengthInBytes);
    void (*clear_cache)(uint32_t instance);
    status_t (*xfer)(uint32_t instance, flexspi_xfer_t *xfer);
    status_t (*update_lut)(uint32_t instance, serial_nor_config_option_t *option);
} flexspi_nor_driver_interface_t;

9.13.2 FlexSPI NOR APIs

The ROM bootloader provides a set of Serial NOR FLASH API to simplify the external
FLASH enablement on RT1060 chip. The version of the FlexSPI NOR API in RT1060
ROM bootloader is version 1.5.0.

• See the API structure shown in section "FlexSPI NOR Driver API structure"
• See the possible status codes listed in section "Status codes for the FlexSPI NOR
API"
• See the flexspi_nor_config_t defined in table "Serial NOR configuration block"
**FlexSPI NOR prototypes**

1. `flexspi_nor_flash_init`
   Initialize the Serial NOR device via FLEXSPI
   ```c
   status_t flexspi_nor_flash_init(uint32_t instance, flexspi_nor_config_t *config) {
       return g_bootloaderTree->flexSpiNorDriver->init(instance, config);
   }
   ```
   See example code in section "FLASH API example on RT1060-EVK board".

2. `flexspi_nor_flash_page_program`
   Program data to specified Flash address
   ```c
   status_t flexspi_nor_flash_page_program(uint32_t instance, flexspi_nor_config_t *config, uint32_t dstAddr, const uint32_t *src) {
       return g_bootloaderTree->flexSpiNorDriver->program(instance, config, dstAddr, src);
   }
   ```
   See example code in section "FLASH API example on RT1060-EVK board".

3. `flexspi_nor_flash_erase_all`
   Erase the whole Flash array via FLEXSPI
   ```c
   status_t flexspi_nor_flash_erase_all(uint32_t instance, flexspi_nor_config_t *config) {
       return g_bootloaderTree->flexSpiNorDriver->erase_all(instance, config);
   }
   ```
   Example code:
   ```c
   flexspi_nor_flash_erase_all(0, config);
   ```

4. `flexspi_nor_get_config`
   Get the Flash configuration block via the serial_nor_config_option_t block, see section "serial_nor_config_t definition ".
   ```c
   status_t flexspi_nor_get_config(uint32_t instance, flexspi_nor_config_t *config, serial_nor_config_option_t *option) {
       return g_bootloaderTree->flexSpiNorDriver->get_config(instance, config, option);
   }
   ```
   See example code in section "FLASH API example on RT1060-EVK board".

5. `flexspi_nor_flash_erase`
   Erase specified Flash region, the minimum erase unit is one sector.
   ```c
   status_t flexspi_nor_flash_erase(uint32_t instance, flexspi_nor_config_t *config, uint32_t start, uint32_t length) {
       return g_bootloaderTree->flexSpiNorDriver->erase(instance, config, start, length);
   }
   ```
   See example code in section "FLASH API example on RT1060-EVK board".

6. `flexspi_nor_flash_read`
Read the FLASH via FLEXSPI using IP read command

```c
status_t flexspi_nor_flash_read(uint32_t instance, flexspi_nor_config_t *config,
uint32_t *dst, uint32_t start, uint32_t bytes)
{
    return g_bootloaderTree->flexSpiNorDriver->read(instance, config, dst, start,
    bytes);
}
```

Example code:

```c
uint32_t pageBuffer[256/sizeof(uint32_t)];
flexspi_nor_flash_read(0, config, pageBuffer, 0, sizeof(pageBuffer));
```

7. flexspi_update_lut
Update the specified LUT entries

```c
status_t flexspi_update_lut(uint32_t instance, uint32_t seqIndex, const uint32_t
*lutBase, uint32_t numberOfSeq)
{
    return g_bootloaderTree->flexSpiNorDriver->update_lut(instance, seqIndex, lutBase,
    numberOfSeq);
}
```

Example code:

```c
uint32_t chipEraseLUT[4] = {0x0460, 0, 0, 0};
flexspi_update_lut(0, 1, chipEraseLUT, 1);
```

8. flexspi_command_xfer
Execute LUT sequence specified by xfer

```c
status_t flexspi_command_xfer(uint32_t instance, flexspi_xfer_t *xfer)
{
    return g_bootloaderTree->flexSpiNorDriver->xfer(instance, xfer);
}
```

```c
definition is as below:

:///brief FlexSPI Transfer Context
typedef struct _FlexSpiXfer
{
    flexspi_operation_t operation;  // FlexSPI operation
    uint32_t baseAddress;           // FlexSPI operation base address
    uint32_t seqId;                 // Sequence Id
    uint32_t seqNum;                // Sequence Number
    bool isParallelModeEnable;      // Is a parallel transfer
    uint32_t *txBuffer;             // Tx buffer
    uint32_t txSize;                // Tx size in bytes
    uint32_t *rxBuffer;             // Rx buffer
    uint32_t rxSize;                // Rx size in bytes
} flexspi_xfer_t;
```

```c
definition is as below:

typedef enum _FlexSPIOperationType
{
    kFlexSpiOperation_Command,  // FlexSPI operation: Only command, both TX and
                                // RX buffer are ignored.
    kFlexSpiOperation_Config,   // FlexSPI operation: Configure device mode, the
                                // TX FIFO size is fixed in LUT.
    kFlexSpiOperation_Write,    // FlexSPI operation: Write, only TX buffer is
                                // effective
    kFlexSpiOperation_Read      // FlexSPI operation: Read, only Rx Buffer is
};
```
#include "fspi.h"

kFlexSpiOperation_End = kFlexSpiOperation_Read,
} flexspi_operation_t;

Example code, assuming the LUT index 1 is the Flash WriteEnable command.

flexspi_xfer_t flashXfer =
{
    kFlexSpiOperation_Command, 0, 1, 1, false, NULL, 0, NULL, 0
};
flexspi_command_xfer(0, &flashXfer);

9. flexspi_clear_cache

Clear the AHB buffer in FLEXSPI module.

void flexspi_clear_cache(uint32_t instance)
{
    g_bootloaderTree->flexSpiNorDriver->clear_cache(instance);
}

Example code:

flexspi_clear_cache(0);

10. serial_nor_config_t definition

serial_nor_config_t is defined as below.

typedef struct _serial_nor_config_option
{
    union
    {
        struct
        {
            uint32_t max_freq : 4;          //!< Maximum supported Frequency
            uint32_t misc_mode : 4;         //!< miscellaneous mode
            uint32_t quad_mode_setting : 4; //!< Quad mode setting
            uint32_t cmd_pads : 4;          //!< Command pads
            uint32_t query_pads : 4;        //!< SFDP read pads
            uint32_t device_type : 4;       //!< Device type
            uint32_t option_size : 4;       //!< Option size, in terms of uint32_t,
            size = (option_size + 1) * 4
            uint32_t tag : 4;               //!< Tag, must be 0x0E
        } B;
        uint32_t U;
    } option0;

    union
    {
        struct
        {
            uint32_t dummy_cycles : 8;     //!< Dummy cycles before read
            uint32_t reserved0 : 8;        //!< Reserved for future use
            uint32_t pinmux_group : 4;     //!< The pinmux group selection
            uint32_t reserved1 : 8;        //!< Reserved for future use
            uint32_t flash_connection : 4; //!< Flash connection option: 0 - Single
        } B;
        uint32_t U;
    } option1;

} serial_nor_config_option_t;
Detailed information of `serial_nor_config_option_t` structure is shown in the following table.

### Table 9-51. `serial_nor_config_option_t` definition

<table>
<thead>
<tr>
<th>Offset</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Option0</td>
<td>See option0 definition for more details</td>
</tr>
<tr>
<td>4</td>
<td>Option1</td>
<td>Optional, effective only if the Option Size field in Option0 is non-zero</td>
</tr>
<tr>
<td></td>
<td></td>
<td>See option1 definition for more details.</td>
</tr>
</tbody>
</table>

### Table 9-52. Option0 definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Bits</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>tag</td>
<td>31:28</td>
<td>The tag of the config option, fixed to 0x0C</td>
</tr>
<tr>
<td>option_size</td>
<td>27:24</td>
<td>Size in bytes = (Option Size + 1) × 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>It is 0 if only <code>option0</code> is required</td>
</tr>
<tr>
<td>device_type</td>
<td>23:20</td>
<td>Device Detection Type</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - Read SFDP for SDR commands</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 - Read SFDP for DDR Read commands</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 - HyperFLASH 1V8</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3 - HyperFLASH 3V</td>
</tr>
<tr>
<td></td>
<td></td>
<td>4 - Macronix Octal DDR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>6 - Micron Octal DDR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>8 - Adesto EcoXiP DDR</td>
</tr>
<tr>
<td>query_pad</td>
<td>19:16</td>
<td>Data pads during Query command (read SFDP or read MID)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 - 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3 – 8</td>
</tr>
<tr>
<td>cmd_pad</td>
<td>15:12</td>
<td>Data pads during Flash access command</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 - 4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3 – 8</td>
</tr>
<tr>
<td>quad_mode_sett</td>
<td>ing</td>
<td>11:8  Quad Mode Enable Setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - Not configure</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 - Set bit 6 in Status Register 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 - Set bit 1 in Status Register 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3 - Set bit 7 in Status Register 2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 9-52. Option0 definition (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Bits</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>misc_mode</td>
<td>7:4</td>
<td>Miscellaneous Mode</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - Not enabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 - Enable 0-4-4 mode for High Random Read performance</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3 - Data Order Swapped mode (for MXIC OctaFlash only)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>NOTE: Experimental feature, do not use in products, keep it as 0.</td>
</tr>
<tr>
<td>max_freq</td>
<td>3:0</td>
<td>Max Flash Operation speed</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - Don't change FlexSPI clock setting</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Others - See System Boot chapter for more details.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>NOTE: The field has a restriction that the FlexSPI clock source must be PLL480_PFD0, keep it as 0 and manually configure the FLEXSPI clock if another clock source is selected in user application.</td>
</tr>
</tbody>
</table>

4 - Set bit 1 in Status Register 2 vis 0x31 command

NOTE: This field will be effective only if device is compliant with JESD216 only (9 longword SDFP table).

Table 9-53. Option1 definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Bits</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>flash_connectin</td>
<td>31:28</td>
<td>Flash connection selection</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - Only Port A</td>
</tr>
<tr>
<td>reserved</td>
<td>27:20</td>
<td>Reserved</td>
</tr>
<tr>
<td>pin_group</td>
<td>19:16</td>
<td>PinMux group</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - Primary pin group</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 - Secondary pin group</td>
</tr>
<tr>
<td>reserved</td>
<td>15:8</td>
<td>Reserved for future use</td>
</tr>
<tr>
<td>dummy_cycles</td>
<td>7:0</td>
<td>Dummy cycles for read command</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 - Use detected dummy cycle</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Others - dummy cycles provided in flash data sheet</td>
</tr>
</tbody>
</table>

NOTE

a. These APIs only support 1 single FLASH device connected to PORTA and FLEXSPIA_SS0.
b. Parallel mode is NOT supported.
c. The APIs always use 30 MHz clock for the programming option. Users need to change the "ipcmdSerialClkFreq" field in flexspi_nor_config_t field after flexspi_nor_get_config option if a higher programming speed is expected.
d. User application needs to set "max_freq" to 0 and manually configure the FLEXSPI clock prior to calling the flexspi_nor_get_config API, if the expected FLEXSPI clock source is not the default clock source configured by the ROM bootloader.
e. The pad drive strength is configured to "R0/6" (See IOMUXC chapter for more details). Users can change the "dataPadOverride" and "sclkPadOverride" setting in flexspi_nor_config_t structure after calling flexspi_nor_get_config if it is necessary.

11. Status codes for the FlexSPI NOR API

The following table lists all the error and status codes for the FlexSPI NOR API.

<table>
<thead>
<tr>
<th>Status</th>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>kStatus_Success</td>
<td>0</td>
<td>Operation succeeded without error</td>
</tr>
<tr>
<td>kStatus_Fail</td>
<td>1</td>
<td>Operation failed with a generic error</td>
</tr>
<tr>
<td>kStatus_InvalidArgument</td>
<td>4</td>
<td>The requested argument is invalid</td>
</tr>
<tr>
<td>kStatus_Timeout</td>
<td>5</td>
<td>A timeout occurred</td>
</tr>
<tr>
<td>kStatus_FLEXSPI_SequenceExecutionTimeout</td>
<td>7000</td>
<td>The command timed out</td>
</tr>
<tr>
<td>kStatus_FLEXSPI_InvalidSequence</td>
<td>7001</td>
<td>Invalid LUT sequence</td>
</tr>
<tr>
<td>kStatus_FLEXSPI_DeviceTimeout</td>
<td>7002</td>
<td>The busy time exceeded provided timeout value</td>
</tr>
<tr>
<td>kStatus_FLEXSPINOR_ProgramFail</td>
<td>20100</td>
<td>Program Command failed</td>
</tr>
<tr>
<td>kStatus_FLEXSPINOR_EraseSectorFail</td>
<td>20101</td>
<td>Erase sector command failed</td>
</tr>
<tr>
<td>kStatus_FLEXSPINOR_EraseAllFail</td>
<td>20102</td>
<td>Erase All command failed</td>
</tr>
<tr>
<td>kStatus_FLEXSPINOR_WaitTimeout</td>
<td>20103</td>
<td>The wait time exceeded provided timeout value</td>
</tr>
<tr>
<td>kStatus_FlexSPINOR_NotSupported</td>
<td>20104</td>
<td>The operation is not supported</td>
</tr>
<tr>
<td>kStatus_FlexSPINOR_WriteAlignmentError</td>
<td>20105</td>
<td>Write address is unaligned to page size</td>
</tr>
<tr>
<td>kStatus_FlexSPINOR_CommandFailure</td>
<td>20106</td>
<td>Command failed</td>
</tr>
<tr>
<td>kStatus_FlexSPINOR_SFDP_NotFound</td>
<td>20107</td>
<td>SFDP table was not found, used for flexspi_nor_flash_get_config API</td>
</tr>
<tr>
<td>kStatus_FLEXSPINOR_Flash_NotFound</td>
<td>20109</td>
<td>Cannot detect a FLASH device</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 9-54. Status and error codes for the FlexSPI NOR API (continued)

<table>
<thead>
<tr>
<th>Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>kStatus_FLEXSPINOR_DTRRead_Dum</td>
<td>The dummy cycle for DDR/DTR read cannot be probed.</td>
</tr>
<tr>
<td>myProbeFailed</td>
<td></td>
</tr>
</tbody>
</table>

Typical options for the Serial NOR devices in the market
The following list provides typical options for the serial NOR flash devices in the market.

- QuadSPI NOR - Quad SDR Read: option0 = 0xc0000008 (133MHz)
- QuadSPI NOR - Quad DDR Read: option0 = 0xc0100003 (60MHz)
- HyperFLASH 1V8: option0 = 0xc0233009 (166MHz)
- HyperFLASH 3V0: option0 = 0xc0333006 (100MHz)
- MXIC OPI DDR (OPI DDR enabled by default): option=0xc0433008(133MHz)
- Micron Octal DDR: option0=0xc0600006 (100MHz)
- Micron OPI DDR: option0=0xc0603008 (133MHz), SPI->OPI DDR
- Micron OPI DDR (DDR read enabled by default): option0 = 0xc0633008 (133MHz)
- Adesto OPI DDR: option0=0xc0803008(133MHz)

FLASH API example on RT1060-EVK board
The following is a typical use case of the FlexSPI NOR API.

```c
flexspi_nor_config_t config;
serial_nor_config_option_t option;
status_t status;
uint32_t address = 0x40000; // 256KB
uint32_t sector_size = 0x1000; // 4KB
uint32_t page_buffer[256/ sizeof(uint32_t)];
uint32_t instance = 0;

option.option0.U = 0xC0000008; // QuadSPI NOR, Frequency: 133MHz

status = flexspi_nor_get_config(instance, &config, &option);
if (status != kStatus_Success)
{
    return status;
}

status = flexspi_nor_flash_init(instance, &config);
if (status != kStatus_Success)
{
    return status;
}

status = flexspi_nor_flash_erase(instance, &config, address , sector_size); // Erase 1 sector
if (status != kStatus_Success)
{
    return status;
}

// Fill data into the page_buffer;
for (uint32_t i=0; i<sizeof(page_buffer)/sizeof(page_buffer[0]); i++)
{
    page_buffer[i] = (i << 24) | (i << 16) | (i << 8) | i;
}

// Program data to destination
status = flexspi_nor_flash_page_program(instance, &config, address, page_buffer); // program 1 page
```
if (status != kStatus_Success)
{
    return status;
}

// Do cache maintenance here if the D-Cache is enabled
// Use memory mapped access to verify whether data are programmed into Flash correctly
uint32_t mem_address = 0x6000_0000 + address;
if (0 == memcmp((void*)mem_address, page_buffer, sizeof(page_buffer))){
    // Success
}
else{
    // Report error
}

9.13.3 Enter Bootloader API

The ROM bootloader provides an API for the user application to boot from a new updated application safely after In-Application Programming (IAP) or re-enter serial downloader mode for image update. See more details in the next section.

API prototype

void runBootloader(void* arg)
{
    g_bootloaderTree->runBootloader(arg);
}

ARG definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tag</td>
<td>[31:24]</td>
<td>Fixed value: 0xEB (Enter Boot)</td>
</tr>
<tr>
<td>boot mode</td>
<td>[23:20]</td>
<td>0 - Determined by BMODE in SMBR2 or other Fuse combinations</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 - Serial downloader</td>
</tr>
<tr>
<td>Serial downloader media</td>
<td>[19:16]</td>
<td>0 - Auto detection</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 - USB</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 - UART</td>
</tr>
<tr>
<td>Reserved</td>
<td>[15:04]</td>
<td></td>
</tr>
<tr>
<td>Boot image selection</td>
<td>[03:00]</td>
<td>0 - Image 0 (Primary image)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 - Image 1 (Redundant image, with primary image bypassed)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 - Image 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3 - Image 3</td>
</tr>
<tr>
<td>NOTE:</td>
<td></td>
<td>It takes effect only if the boot mode is 0.</td>
</tr>
</tbody>
</table>

Typical use cases

1. Enter Serial downloader mode and select USB as the communication peripheral.

    uint32_t arg = 0xeb100000;
    runBootloader (&arg);
2. Select Image1 (Redundant image) as the boot image after reliable update in user application.

```c
uint32_t arg = 0xeb000001;
runBootloader (&arg);
```

## 9.13.4 Watchdog API

The Watchdog API definition is identical to the SDK driver, see the SDK driver for more details.
Chapter 10
External Signals and Pin Multiplexing

10.1 Overview

The chip contains a limited number of pins, most of which have multiple signal options. These signal-to-pin and pin-to-signal options are selected by the input-output multiplexer called IOMUX. The IOMUX is also used to configure other pin characteristics, such as voltage level, drive strength, and hysteresis.

The muxing options table lists the external signals grouped by the module instance, the muxing options for each signal, and the registers used to route the signal to the chosen pad.

10.1.1 Muxing Options

NOTE
System STOP/WAIT status can be observed on pin. See CCM_WAIT and CCM_STOP in the table below.

Table 10-1. Muxing Options

<table>
<thead>
<tr>
<th>Instance</th>
<th>Port</th>
<th>Pad</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC1</td>
<td>ADC1_IN0</td>
<td>GPIO_AD_B1_11</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN1</td>
<td>GPIO_AD_B0_12</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN2</td>
<td>GPIO_AD_B0_13</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN3</td>
<td>GPIO_AD_B0_14</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN4</td>
<td>GPIO_AD_B0_15</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN5</td>
<td>GPIO_AD_B1_00</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN6</td>
<td>GPIO_AD_B1_01</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN7</td>
<td>GPIO_AD_B1_02</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN8</td>
<td>GPIO_AD_B1_03</td>
<td>-</td>
</tr>
<tr>
<td>ADC1</td>
<td>ADC1_IN9</td>
<td>GPIO_AD_B1_04</td>
<td>-</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Muxing Options (continued)</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC1_IN10</td>
<td>GPIO_AD_B1_05</td>
<td>-</td>
</tr>
<tr>
<td>ADC1_IN11</td>
<td>GPIO_AD_B1_06</td>
<td>-</td>
</tr>
<tr>
<td>ADC1_IN12</td>
<td>GPIO_AD_B1_07</td>
<td>-</td>
</tr>
<tr>
<td>ADC1_IN13</td>
<td>GPIO_AD_B1_08</td>
<td>-</td>
</tr>
<tr>
<td>ADC1_IN14</td>
<td>GPIO_AD_B1_09</td>
<td>-</td>
</tr>
<tr>
<td>ADC1_IN15</td>
<td>GPIO_AD_B1_10</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN0</td>
<td>GPIO_AD_B1_11</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN1</td>
<td>GPIO_AD_B1_12</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN2</td>
<td>GPIO_AD_B1_13</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN3</td>
<td>GPIO_AD_B1_14</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN4</td>
<td>GPIO_AD_B1_15</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN5</td>
<td>GPIO_AD_B1_00</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN6</td>
<td>GPIO_AD_B1_01</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN7</td>
<td>GPIO_AD_B1_02</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN8</td>
<td>GPIO_AD_B1_03</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN9</td>
<td>GPIO_AD_B1_04</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN10</td>
<td>GPIO_AD_B1_05</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN11</td>
<td>GPIO_AD_B1_06</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN12</td>
<td>GPIO_AD_B1_07</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN13</td>
<td>GPIO_AD_B1_08</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN14</td>
<td>GPIO_AD_B1_09</td>
<td>-</td>
</tr>
<tr>
<td>ADC2_IN15</td>
<td>GPIO_AD_B1_10</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_IN0</td>
<td>GPIO_AD_B1_01</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_IN1</td>
<td>GPIO_AD_B1_06</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_IN2</td>
<td>GPIO_AD_B0_13</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_IN3</td>
<td>GPIO_AD_B1_02</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_IN4</td>
<td>GPIO_AD_B0_00</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_IN5</td>
<td>GPIO_AD_B1_07</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_IN6</td>
<td>GPIO_AD_B1_11</td>
<td>-</td>
</tr>
<tr>
<td>ACMP1_OUT</td>
<td>GPIO_AD_B1_12</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_IN0</td>
<td>GPIO_AD_B1_01</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_IN1</td>
<td>GPIO_AD_B1_06</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_IN2</td>
<td>GPIO_AD_B0_14</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_IN3</td>
<td>GPIO_AD_B1_03</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_IN4</td>
<td>GPIO_AD_B0_01</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_IN5</td>
<td>GPIO_AD_B1_08</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_IN6</td>
<td>GPIO_AD_B1_12</td>
<td>-</td>
</tr>
<tr>
<td>ACMP2_OUT</td>
<td>GPIO_AD_B1_13</td>
<td>-</td>
</tr>
<tr>
<td>ACMP3_IN0</td>
<td>GPIO_AD_B1_01</td>
<td>-</td>
</tr>
<tr>
<td>ACMP3_IN1</td>
<td>GPIO_AD_B1_06</td>
<td>-</td>
</tr>
<tr>
<td>Pin</td>
<td>GPIO Address</td>
<td>Muxing Options</td>
</tr>
<tr>
<td>----------------</td>
<td>----------------</td>
<td>----------------</td>
</tr>
<tr>
<td>ACMP3_IN2</td>
<td>GPIO_AD_B0_15</td>
<td></td>
</tr>
<tr>
<td>ACMP3_IN3</td>
<td>GPIO_AD_B1_04</td>
<td></td>
</tr>
<tr>
<td>ACMP3_IN4</td>
<td>GPIO_AD_B0_02</td>
<td></td>
</tr>
<tr>
<td>ACMP3_IN5</td>
<td>GPIO_AD_B1_09</td>
<td></td>
</tr>
<tr>
<td>ACMP3_IN6</td>
<td>GPIO_AD_B1_13</td>
<td></td>
</tr>
<tr>
<td>ACMP3_OUT</td>
<td>GPIO_AD_B1_14</td>
<td></td>
</tr>
<tr>
<td>ACMP4_IN0</td>
<td>GPIO_AD_B1_01</td>
<td></td>
</tr>
<tr>
<td>ACMP4_IN1</td>
<td>GPIO_AD_B1_06</td>
<td></td>
</tr>
<tr>
<td>ACMP4_IN2</td>
<td>GPIO_AD_B1_00</td>
<td></td>
</tr>
<tr>
<td>ACMP4_IN3</td>
<td>GPIO_AD_B1_05</td>
<td></td>
</tr>
<tr>
<td>ACMP4_IN4</td>
<td>GPIO_AD_B0_03</td>
<td></td>
</tr>
<tr>
<td>ACMP4_IN5</td>
<td>GPIO_AD_B1_10</td>
<td></td>
</tr>
<tr>
<td>ACMP4_IN6</td>
<td>GPIO_AD_B1_14</td>
<td></td>
</tr>
<tr>
<td>ACMP4_OUT</td>
<td>GPIO_AD_B1_15</td>
<td></td>
</tr>
<tr>
<td>ARM_EVENT0</td>
<td>GPIO_BO_14</td>
<td>ALT2</td>
</tr>
<tr>
<td>ARM_EVENT1</td>
<td>GPIO_B0_15</td>
<td>ALT2</td>
</tr>
<tr>
<td>CCM_PMIC_STBY_REQ</td>
<td>GPIO_AD_B0_12</td>
<td>ALT1</td>
</tr>
<tr>
<td>CCM_PMIC_READY</td>
<td>GPIO_EMCC_32</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_08</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_01</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_03</td>
<td>ALT6</td>
</tr>
<tr>
<td>CCM_CLKO1</td>
<td>GPIO_SD_B0_04</td>
<td>ALT6</td>
</tr>
<tr>
<td>CCM_CLKO2</td>
<td>GPIO_SD_B0_05</td>
<td>ALT6</td>
</tr>
<tr>
<td>CCM_WAIT</td>
<td>GPIO_SD_B1_02</td>
<td>ALT6</td>
</tr>
<tr>
<td>CCM_STOP</td>
<td>GPIO_SD_B1_04</td>
<td>ALT6</td>
</tr>
<tr>
<td>CCM_CLK1_P</td>
<td>CCM_CLK1_P</td>
<td>No Muxing</td>
</tr>
<tr>
<td>CCM_CLK1_N</td>
<td>CCM_CLK1_N</td>
<td>No Muxing</td>
</tr>
<tr>
<td>CSI_DATA00</td>
<td>GPIO_B1_10</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA01</td>
<td>GPIO_B1_11</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA02</td>
<td>GPIO_AD_B1_15</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_11</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA03</td>
<td>GPIO_AD_B1_14</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_10</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA04</td>
<td>GPIO_AD_B1_13</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_09</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA05</td>
<td>GPIO_AD_B1_12</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_08</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA06</td>
<td>GPIO_AD_B1_11</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_07</td>
<td>ALT4</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>CSI_DATA07</th>
<th>GPIO_AD_B1_10</th>
<th>ALT4</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>GPIO_AD_B0_06</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA08</td>
<td>GPIO_AD_B1_09</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_05</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA09</td>
<td>GPIO_AD_B1_08</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_04</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA10</td>
<td>GPIO_B1_09</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA11</td>
<td>GPIO_B1_08</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA12</td>
<td>GPIO_B1_07</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA13</td>
<td>GPIO_B1_06</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA14</td>
<td>GPIO_B1_05</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA15</td>
<td>GPIO_B1_04</td>
<td>ALT2</td>
</tr>
<tr>
<td>CSI_DATA16</td>
<td>GPIO_EMC_37</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA17</td>
<td>GPIO_EMC_36</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA18</td>
<td>GPIO_EMC_35</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA19</td>
<td>GPIO_EMC_34</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA20</td>
<td>GPIO_EMC_33</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA21</td>
<td>GPIO_EMC_32</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA22</td>
<td>GPIO_EMC_31</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_DATA23</td>
<td>GPIO_EMC_30</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_PIXCLK</td>
<td>GPIO_B1_12</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_04</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_VSYNC</td>
<td>GPIO_B1_13</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_06</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_14</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_HSYNC</td>
<td>GPIO_B1_14</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_07</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_15</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_MCLK</td>
<td>GPIO_B1_15</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_05</td>
<td>ALT4</td>
</tr>
<tr>
<td>CSI_FIELD</td>
<td>GPIO_EMC_38</td>
<td>ALT4</td>
</tr>
</tbody>
</table>

ENET

| ENET_MDC   | GPIO_B1_14     | ALT0 |
|           | GPIO_AD_B1_04  | ALT1 |
|           | GPIO_EMC_40    | ALT4 |
| ENET_MDIO  | GPIO_B1_15     | ALT0 |
|           | GPIO_AD_B1_05  | ALT1 |
|           | GPIO_EMC_41    | ALT4 |
| ENET_TX_DATA0 | GPIO_EMC_22   | ALT3 |
|           | GPIO_B1_07     | ALT3 |
| ENET_TX_DATA1 | GPIO_EMC_21   | ALT3 |

*Table continues on the next page...*
Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>GPIO_pin</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET2_MDC</td>
<td>GPIO_EMC_38</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_MDIO</td>
<td>GPIO_EMC_39</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TDATA0</td>
<td>GPIO_EMC_30</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_MDC</td>
<td>GPIO_B0_00</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_MDIO</td>
<td>GPIO_B0_01</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TDATA0</td>
<td>GPIO_B0_02</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_MDC</td>
<td>GPIO_B0_03</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_MDIO</td>
<td>GPIO_B0_04</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TDATA0</td>
<td>GPIO_B0_05</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_MDC</td>
<td>GPIO_B0_06</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_MDIO</td>
<td>GPIO_B0_07</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TDATA0</td>
<td>GPIO_B0_08</td>
<td>ALT8</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th></th>
<th>GPIO</th>
<th>ALT</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET2_TDATA1</td>
<td>GPIO_EMC_31</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TDATA2</td>
<td>GPIO_B0_05</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TDATA3</td>
<td>GPIO_B0_04</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TX_CLK</td>
<td>GPIO_EMC_33</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TX_EN</td>
<td>GPIO_EMC_32</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_TX_ER</td>
<td>GPIO_B0_07</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_RDATA0</td>
<td>GPIO_EMC_35</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_RDATA1</td>
<td>GPIO_EMC_36</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_RDATA2</td>
<td>GPIO_B0_09</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_RDATA3</td>
<td>GPIO_B0_08</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_RX_CLK</td>
<td>GPIO_B0_06</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_RX_EN</td>
<td>GPIO_EMC_37</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_RX_ER</td>
<td>GPIO_EMC_34</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_REF_CLK2</td>
<td>GPIO_EMC_33</td>
<td>ALT9</td>
</tr>
<tr>
<td>ENET2_1588_EVENT0_IN</td>
<td>GPIO_AD_B1_01</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_COL</td>
<td>GPIO_B0_11</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_CRS</td>
<td>GPIO_B0_10</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_1588_EVENT1_IN</td>
<td>GPIO_AD_B1_11</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_1588_EVENT2_IN</td>
<td>GPIO_AD_B1_13</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_1588_EVENT3_IN</td>
<td>GPIO_AD_B1_15</td>
<td>ALT8</td>
</tr>
<tr>
<td>ENET2_1588_EVENT0_OUT</td>
<td>GPIO_AD_B1_00</td>
<td>ALT8</td>
</tr>
</tbody>
</table>
### Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>Muxing Options</th>
<th>GPIO pin</th>
<th>Port</th>
<th>Module</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET2_1588_EVENT1_OUT</td>
<td>GPIO_AD_B1_10</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>ENET2_1588_EVENT2_OUT</td>
<td>GPIO_AD_B1_12</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>ENET2_1588_EVENT3_OUT</td>
<td>GPIO_AD_B1_14</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>EWM</td>
<td>EWM_OUT_B</td>
<td>GPIO_AD_B0_01</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_13</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_11</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXIO1</td>
<td>FLEXIO1_D00</td>
<td>GPIO_EMC_00</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D01</td>
<td>GPIO_EMC_01</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D02</td>
<td>GPIO_EMC_02</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D03</td>
<td>GPIO_EMC_03</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D04</td>
<td>GPIO_EMC_04</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D05</td>
<td>GPIO_EMC_05</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D06</td>
<td>GPIO_EMC_06</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D07</td>
<td>GPIO_EMC_07</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D08</td>
<td>GPIO_EMC_08</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D09</td>
<td>GPIO_EMC_09</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D10</td>
<td>GPIO_EMC_10</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D11</td>
<td>GPIO_EMC_11</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D12</td>
<td>GPIO_EMC_26</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D13</td>
<td>GPIO_EMC_27</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D14</td>
<td>GPIO_EMC_28</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO1_D15</td>
<td>GPIO_EMC_29</td>
<td>ALT4</td>
</tr>
<tr>
<td>FLEXIO2</td>
<td>FLEXIO2_D00</td>
<td>GPIO_B0_00</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D01</td>
<td>GPIO_B0_01</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D02</td>
<td>GPIO_B0_02</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D03</td>
<td>GPIO_B0_03</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D04</td>
<td>GPIO_B0_04</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D05</td>
<td>GPIO_B0_05</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D06</td>
<td>GPIO_B0_06</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D07</td>
<td>GPIO_B0_07</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D08</td>
<td>GPIO_B0_08</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D09</td>
<td>GPIO_B0_09</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D10</td>
<td>GPIO_B0_10</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D11</td>
<td>GPIO_B0_11</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D12</td>
<td>GPIO_B0_12</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D13</td>
<td>GPIO_B0_13</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D14</td>
<td>GPIO_B0_14</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D15</td>
<td>GPIO_B0_15</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXIO2_D16</td>
<td>GPIO_B1_00</td>
<td>ALT4</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 10-1. Muxing Options (continued)

| FLEXIO2_D17 | GPIO_B1_01 | ALT4 |
| FLEXIO2_D18 | GPIO_B1_02 | ALT4 |
| FLEXIO2_D19 | GPIO_B1_03 | ALT4 |
| FLEXIO2_D20 | GPIO_B1_04 | ALT4 |
| FLEXIO2_D21 | GPIO_B1_05 | ALT4 |
| FLEXIO2_D22 | GPIO_B1_06 | ALT4 |
| FLEXIO2_D23 | GPIO_B1_07 | ALT4 |
| FLEXIO2_D24 | GPIO_B1_08 | ALT4 |
| FLEXIO2_D25 | GPIO_B1_09 | ALT4 |
| FLEXIO2_D26 | GPIO_B1_10 | ALT4 |
| FLEXIO2_D27 | GPIO_B1_11 | ALT4 |
| FLEXIO2_D28 | GPIO_B1_12 | ALT4 |
| FLEXIO2_D29 | GPIO_B1_13 | ALT4 |
| FLEXIO2_D30 | GPIO_B1_14 | ALT4 |
| FLEXIO2_D31 | GPIO_B1_15 | ALT4 |
| FLEXIO3_D00 | GPIO_AD_B1_00 | ALT9 |
| FLEXIO3_D01 | GPIO_AD_B1_01 | ALT9 |
| FLEXIO3_D02 | GPIO_AD_B1_02 | ALT9 |
| FLEXIO3_D03 | GPIO_AD_B1_03 | ALT9 |
| FLEXIO3_D04 | GPIO_AD_B1_04 | ALT9 |
| FLEXIO3_D05 | GPIO_AD_B1_05 | ALT9 |
| FLEXIO3_D06 | GPIO_AD_B1_06 | ALT9 |
| FLEXIO3_D07 | GPIO_AD_B1_07 | ALT9 |
| FLEXIO3_D08 | GPIO_AD_B1_08 | ALT9 |
| FLEXIO3_D09 | GPIO_AD_B1_09 | ALT9 |
| FLEXIO3_D10 | GPIO_AD_B1_10 | ALT9 |
| FLEXIO3_D11 | GPIO_AD_B1_11 | ALT9 |
| FLEXIO3_D12 | GPIO_AD_B1_12 | ALT9 |
| FLEXIO3_D13 | GPIO_AD_B1_13 | ALT9 |
| FLEXIO3_D14 | GPIO_AD_B1_14 | ALT9 |
| FLEXIO3_D15 | GPIO_AD_B1_15 | ALT9 |
| FLEXIO3_D16 | GPIO_B1_00 | ALT9 |
| FLEXIO3_D17 | GPIO_B1_01 | ALT9 |
| FLEXIO3_D18 | GPIO_B1_02 | ALT9 |
| FLEXIO3_D19 | GPIO_B1_03 | ALT9 |
| FLEXIO3_D20 | GPIO_B1_04 | ALT9 |
| FLEXIO3_D21 | GPIO_B1_05 | ALT9 |
| FLEXIO3_D22 | GPIO_B1_06 | ALT9 |
| FLEXIO3_D23 | GPIO_B1_07 | ALT9 |
| FLEXIO3_D24 | GPIO_B1_08 | ALT9 |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Muxing Options (continued)</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXIO3_D25</td>
<td>GPIO_B1_09</td>
<td>ALT9</td>
</tr>
<tr>
<td>FLEXIO3_D26</td>
<td>GPIO_B1_10</td>
<td>ALT9</td>
</tr>
<tr>
<td>FLEXIO3_D27</td>
<td>GPIO_B1_11</td>
<td>ALT9</td>
</tr>
<tr>
<td>FLEXIO3_D28</td>
<td>GPIO_B1_12</td>
<td>ALT9</td>
</tr>
<tr>
<td>FLEXIO3_D29</td>
<td>GPIO_B1_13</td>
<td>ALT9</td>
</tr>
<tr>
<td>FLEXIO3_D30</td>
<td>GPIO_B1_14</td>
<td>ALT9</td>
</tr>
<tr>
<td>FLEXIO3_D31</td>
<td>GPIO_B1_15</td>
<td>ALT9</td>
</tr>
<tr>
<td>FLEXPWM1</td>
<td>FLEXPWM1_PWM0_A</td>
<td>GPIO_EMC_23</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_00</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM0_B</td>
<td>GPIO_SD_B0_01</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMCC_24</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM1_A</td>
<td>GPIO_EMCC_25</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_02</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM1_B</td>
<td>GPIO_EMCC_26</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_03</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM2_A</td>
<td>GPIO_SD_B0_04</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMCC_27</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM2_B</td>
<td>GPIO_SD_B0_05</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMCC_28</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM3_A</td>
<td>GPIO_EMCC_38</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_00</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_10</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMCC_12</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_01</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM3_B</td>
<td>GPIO_EMCC_39</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_01</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_11</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_01</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMCC_13</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM0_X</td>
<td>GPIO_AD_B0_02</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM1_X</td>
<td>GPIO_AD_B0_03</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM2_X</td>
<td>GPIO_AD_B0_12</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM1_PWM3_X</td>
<td>GPIO_AD_B0_13</td>
</tr>
<tr>
<td>FLEXPWM2</td>
<td>FLEXPWM2_PWM0_A</td>
<td>GPIO_B0_06</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMCC_06</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM2_PWM0_B</td>
<td>GPIO_B0_07</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMCC_07</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM2_PWM1_A</td>
<td>GPIO_EMCC_08</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_08</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM2_PWM1_B</td>
<td>GPIO_EMCC_09</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Module</th>
<th>GPIO</th>
<th>Multiplexing</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_B0_09</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_A</td>
<td>GPIO_EMC_10</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_10</td>
<td>ALT2</td>
</tr>
<tr>
<td>FLEXPWM2_PWM2_B</td>
<td>GPIO_EMC_11</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_11</td>
<td>ALT2</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_A</td>
<td>GPIO_AD_B0_09</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_02</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_19</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_02</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_00</td>
<td>ALT0</td>
</tr>
<tr>
<td>FLEXPWM2_PWM3_B</td>
<td>GPIO_AD_B0_01</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_03</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_03</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_20</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXPWM3</td>
<td>FLEXPWM3_PWM0_A</td>
<td>GPIO_EMC_29</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM0_B</td>
<td>GPIO_EMC_30</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM1_A</td>
<td>GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM1_B</td>
<td>GPIO_EMC_32</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM2_A</td>
<td>GPIO_EMC_33</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM2_B</td>
<td>GPIO_EMC_34</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM3_A</td>
<td>GPIO_EMC_21</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM3_PWM3_B</td>
<td>GPIO_EMC_22</td>
</tr>
<tr>
<td>FLEXPWM4</td>
<td>FLEXPWM4_PWM0_A</td>
<td>GPIO_AD_B1_08</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_00</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM0_B</td>
<td>GPIO_EMC_01</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM1_A</td>
<td>GPIO_AD_B1_09</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_02</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM1_B</td>
<td>GPIO_EMC_03</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM2_A</td>
<td>GPIO_B1_14</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_04</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM2_B</td>
<td>GPIO_EMC_05</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM3_A</td>
<td>GPIO_B1_15</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_17</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>FLEXPWM4_PWM3_B</td>
<td>GPIO_EMC_18</td>
</tr>
<tr>
<td>FLEXCAN1</td>
<td>FLEXCAN1_TX</td>
<td>GPIO_AD_B1_08</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_02</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_17</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_02</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_09</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_03</td>
<td>ALT2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Muxing Options (continued)</th>
<th>GPIO_EMC_18</th>
<th>ALT3</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>GPIO_SD_B1_03</td>
<td>ALT4</td>
</tr>
<tr>
<td><strong>FLEXCAN2</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXCAN2_TX</td>
<td>GPIO_AD_B0_02</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_09</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_08</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_14</td>
<td>ALT6</td>
</tr>
<tr>
<td><strong>FLEXCAN2_RX</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXCAN2_RX</td>
<td>GPIO_AD_B0_03</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_10</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_15</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_09</td>
<td>ALT6</td>
</tr>
<tr>
<td><strong>FLEXCAN3</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXCAN3_RX</td>
<td>GPIO_AD_B0_11</td>
<td>ALT8</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_15</td>
<td>ALT8</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_37</td>
<td>ALT9</td>
</tr>
<tr>
<td><strong>FLEXCAN3_TX</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXCAN3_TX</td>
<td>GPIO_AD_B0_10</td>
<td>ALT8</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_14</td>
<td>ALT8</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_36</td>
<td>ALT9</td>
</tr>
<tr>
<td><strong>FLEXSPI A</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_A_DATA0</td>
<td>GPIO_AD_B1_13</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_08</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_A_DATA1</td>
<td>GPIO_AD_B1_12</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_09</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_A_DATA2</td>
<td>GPIO_AD_B1_11</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_10</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_A_DATA3</td>
<td>GPIO_AD_B1_10</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_11</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_A_DQS</td>
<td>GPIO_AD_B1_09</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_05</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_A_SCLK</td>
<td>GPIO_AD_B1_14</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_07</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_A_SS0_B</td>
<td>GPIO_AD_B1_15</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_06</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_A_SS1_B</td>
<td>GPIO_AD_B1_08</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_00</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_04</td>
<td>ALT4</td>
</tr>
<tr>
<td><strong>FLEXSPI B</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXSPI_B_DATA0</td>
<td>GPIO_AD_B1_07</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_03</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_B_DATA1</td>
<td>GPIO_AD_B1_06</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_02</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_B_DATA2</td>
<td>GPIO_AD_B1_05</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_01</td>
<td>ALT1</td>
</tr>
<tr>
<td>FLEXSPI_B_DATA3</td>
<td>GPIO_AD_B1_04</td>
<td>ALT0</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>FlexSPI (A/B)</th>
<th>Pin</th>
<th>Configuration</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXSPI2_A</td>
<td>FLEXSPI2_A_DATA0</td>
<td>GPIO_EMC_26</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_A_DATA1</td>
<td>GPIO_EMC_27</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_A_DATA2</td>
<td>GPIO_EMC_28</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_A_DATA3</td>
<td>GPIO_EMC_29</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_A_DQS</td>
<td>GPIO_EMC_23</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_A_SCLK</td>
<td>GPIO_EMC_25</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_A_SS0_B</td>
<td>GPIO_EMC_24</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_A_SS1_B</td>
<td>GPIO_EMC_22</td>
</tr>
<tr>
<td>FLEXSPI2_B</td>
<td>FLEXSPI2_B_DATA0</td>
<td>GPIO_EMC_13</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_B_DATA1</td>
<td>GPIO_EMC_14</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_B_DATA2</td>
<td>GPIO_EMC_15</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_B_DATA3</td>
<td>GPIO_EMC_16</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_B_DQS</td>
<td>GPIO_EMC_11</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_B_SCLK</td>
<td>GPIO_EMC_12</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_B_SS0_B</td>
<td>GPIO_EMC_10</td>
</tr>
<tr>
<td></td>
<td>FLEXSPI2_B_SS1_B</td>
<td>GPIO_EMC_09</td>
</tr>
<tr>
<td>GPIO1</td>
<td>GPIO1_IO00</td>
<td>GPIO_AD_B0_00</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO01</td>
<td>GPIO_AD_B0_01</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO02</td>
<td>GPIO_AD_B0_02</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO03</td>
<td>GPIO_AD_B0_03</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO04</td>
<td>GPIO_AD_B0_04</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO05</td>
<td>GPIO_AD_B0_05</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO06</td>
<td>GPIO_AD_B0_06</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO07</td>
<td>GPIO_AD_B0_07</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO08</td>
<td>GPIO_AD_B0_08</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO09</td>
<td>GPIO_AD_B0_09</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO10</td>
<td>GPIO_AD_B0_10</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO11</td>
<td>GPIO_AD_B0_11</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO12</td>
<td>GPIO_AD_B0_12</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO13</td>
<td>GPIO_AD_B0_13</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO14</td>
<td>GPIO_AD_B0_14</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO15</td>
<td>GPIO_AD_B0_15</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO16</td>
<td>GPIO_AD_B1_00</td>
</tr>
<tr>
<td></td>
<td>GPIO1_IO17</td>
<td>GPIO_AD_B1_01</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>GPIO1_IO18</th>
<th>GPIO_AD_B1_02</th>
<th>ALT5</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO1_IO19</td>
<td>GPIO_AD_B1_03</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO20</td>
<td>GPIO_AD_B1_04</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO21</td>
<td>GPIO_AD_B1_05</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO22</td>
<td>GPIO_AD_B1_06</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO23</td>
<td>GPIO_AD_B1_07</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO24</td>
<td>GPIO_AD_B1_08</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO25</td>
<td>GPIO_AD_B1_09</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO26</td>
<td>GPIO_AD_B1_10</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO27</td>
<td>GPIO_AD_B1_11</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO28</td>
<td>GPIO_AD_B1_12</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO29</td>
<td>GPIO_AD_B1_13</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO30</td>
<td>GPIO_AD_B1_14</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO1_IO31</td>
<td>GPIO_AD_B1_15</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO00</td>
<td>GPIO_B0_00</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO01</td>
<td>GPIO_B0_01</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO02</td>
<td>GPIO_B0_02</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO03</td>
<td>GPIO_B0_03</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO04</td>
<td>GPIO_B0_04</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO05</td>
<td>GPIO_B0_05</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO06</td>
<td>GPIO_B0_06</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO07</td>
<td>GPIO_B0_07</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO08</td>
<td>GPIO_B0_08</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO09</td>
<td>GPIO_B0_09</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO10</td>
<td>GPIO_B0_10</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO11</td>
<td>GPIO_B0_11</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO12</td>
<td>GPIO_B0_12</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO13</td>
<td>GPIO_B0_13</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO14</td>
<td>GPIO_B0_14</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO15</td>
<td>GPIO_B0_15</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO16</td>
<td>GPIO_B1_00</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO17</td>
<td>GPIO_B1_01</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO18</td>
<td>GPIO_B1_02</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO19</td>
<td>GPIO_B1_03</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO20</td>
<td>GPIO_B1_04</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO21</td>
<td>GPIO_B1_05</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO22</td>
<td>GPIO_B1_06</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO23</td>
<td>GPIO_B1_07</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO24</td>
<td>GPIO_B1_08</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO2_IO25</td>
<td>GPIO_B1_09</td>
<td>ALT5</td>
</tr>
</tbody>
</table>

Table continues on the next page...
| GPIO2_IO26 | GPIO_B1_10  | ALT5 |
| GPIO2_IO27 | GPIO_B1_11  | ALT5 |
| GPIO2_IO28 | GPIO_B1_12  | ALT5 |
| GPIO2_IO29 | GPIO_B1_13  | ALT5 |
| GPIO2_IO30 | GPIO_B1_14  | ALT5 |
| GPIO2_IO31 | GPIO_B1_15  | ALT5 |
| GPIO3     | GPIO3_IO00  | GPIO_SD_B1_00 | ALT5 |
| GPIO3_IO01 | GPIO_SD_B1_01 | ALT5 |
| GPIO3_IO02 | GPIO_SD_B1_02 | ALT5 |
| GPIO3_IO03 | GPIO_SD_B1_03 | ALT5 |
| GPIO3_IO04 | GPIO_SD_B1_04 | ALT5 |
| GPIO3_IO05 | GPIO_SD_B1_05 | ALT5 |
| GPIO3_IO06 | GPIO_SD_B1_06 | ALT5 |
| GPIO3_IO07 | GPIO_SD_B1_07 | ALT5 |
| GPIO3_IO08 | GPIO_SD_B1_08 | ALT5 |
| GPIO3_IO09 | GPIO_SD_B1_09 | ALT5 |
| GPIO3_IO10 | GPIO_SD_B1_10 | ALT5 |
| GPIO3_IO11 | GPIO_SD_B1_11 | ALT5 |
| GPIO3_IO12 | GPIO_SD_B0_00 | ALT5 |
| GPIO3_IO13 | GPIO_SD_B0_01 | ALT5 |
| GPIO3_IO14 | GPIO_SD_B0_02 | ALT5 |
| GPIO3_IO15 | GPIO_SD_B0_03 | ALT5 |
| GPIO3_IO16 | GPIO_SD_B0_04 | ALT5 |
| GPIO3_IO17 | GPIO_SD_B0_05 | ALT5 |
| GPIO3_IO18 | GPIO_EMC_32  | ALT5 |
| GPIO3_IO19 | GPIO_EMC_33  | ALT5 |
| GPIO3_IO20 | GPIO_EMC_34  | ALT5 |
| GPIO3_IO21 | GPIO_EMC_35  | ALT5 |
| GPIO3_IO22 | GPIO_EMC_36  | ALT5 |
| GPIO3_IO23 | GPIO_EMC_37  | ALT5 |
| GPIO3_IO24 | GPIO_EMC_38  | ALT5 |
| GPIO3_IO25 | GPIO_EMC_39  | ALT5 |
| GPIO3_IO26 | GPIO_EMC_40  | ALT5 |
| GPIO3_IO27 | GPIO_EMC_41  | ALT5 |
| GPIO4     | GPIO4_IO00  | GPIO_EMC_00 | ALT5 |
| GPIO4_IO01 | GPIO_EMC_01  | ALT5 |
| GPIO4_IO02 | GPIO_EMC_02  | ALT5 |
| GPIO4_IO03 | GPIO_EMC_03  | ALT5 |
| GPIO4_IO04 | GPIO_EMC_04  | ALT5 |
| GPIO4_IO05 | GPIO_EMC_05  | ALT5 |

Table continues on the next page...
Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>GPIO4_IO6</th>
<th>GPIO_EMC_06</th>
<th>ALT5</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO4_IO7</td>
<td>GPIO_EMC_07</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO8</td>
<td>GPIO_EMC_08</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO9</td>
<td>GPIO_EMC_09</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO10</td>
<td>GPIO_EMC_10</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO11</td>
<td>GPIO_EMC_11</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO12</td>
<td>GPIO_EMC_12</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO13</td>
<td>GPIO_EMC_13</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO14</td>
<td>GPIO_EMC_14</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO15</td>
<td>GPIO_EMC_15</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO16</td>
<td>GPIO_EMC_16</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO17</td>
<td>GPIO_EMC_17</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO18</td>
<td>GPIO_EMC_18</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO19</td>
<td>GPIO_EMC_19</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO20</td>
<td>GPIO_EMC_20</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO21</td>
<td>GPIO_EMC_21</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO22</td>
<td>GPIO_EMC_22</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO23</td>
<td>GPIO_EMC_23</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO24</td>
<td>GPIO_EMC_24</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO25</td>
<td>GPIO_EMC_25</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO26</td>
<td>GPIO_EMC_26</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO27</td>
<td>GPIO_EMC_27</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO28</td>
<td>GPIO_EMC_28</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO29</td>
<td>GPIO_EMC_29</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO30</td>
<td>GPIO_EMC_30</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO4_IO31</td>
<td>GPIO_EMC_31</td>
<td>ALT5</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>GPIO5</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO5_IO00</td>
<td>WAKEUP</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO5_IO01</td>
<td>PMIC_ON_REQ</td>
<td>ALT5</td>
</tr>
<tr>
<td>GPIO5_IO02</td>
<td>PMIC_STBY_REQ</td>
<td>ALT5</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>GPT1</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>GPT1_CLK</td>
<td>GPIO_AD_B0_13</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_04</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT1_CAPTURE1</td>
<td>GPIO_EMC_24</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_05</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT1_CAPTURE2</td>
<td>GPIO_EMC_23</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_06</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT1_COMPARE1</td>
<td>GPIO_EMC_35</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_07</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT1_COMPARE2</td>
<td>GPIO_EMC_36</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_08</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT1_COMPARE3</td>
<td>GPIO_EMC_37</td>
<td>ALT2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<p>| | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>GPT2</td>
<td>GPT2_CLK</td>
<td>GPIO_AD_B0_09</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_02</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT2</td>
<td>GPT2_CAPTURE1</td>
<td>GPIO_EMC_41</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_03</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT2</td>
<td>GPT2_CAPTURE2</td>
<td>GPIO_EMC_40</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_04</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT2</td>
<td>GPT2COMPARE1</td>
<td>GPIO_AD_B0_06</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_05</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT2</td>
<td>GPT2COMPARE2</td>
<td>GPIO_AD_B0_07</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_06</td>
<td>ALT8</td>
</tr>
<tr>
<td>GPT2</td>
<td>GPT2COMPARE3</td>
<td>GPIO_AD_B0_08</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_07</td>
<td>ALT8</td>
</tr>
<tr>
<td>JTAG</td>
<td>JTAG_TMS</td>
<td>GPIO_AD_B0_06</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_07</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_08</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_09</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_10</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_11</td>
<td>ALT0</td>
</tr>
<tr>
<td>SWD</td>
<td>SWD_DIO</td>
<td>GPIO_AD_B0_06</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_07</td>
<td>ALT0</td>
</tr>
<tr>
<td>TPIU</td>
<td>ARM_TRACE0</td>
<td>GPIO_B0_04</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_05</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_06</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_07</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_12</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_13</td>
<td>ALT2</td>
</tr>
<tr>
<td>KPP</td>
<td>KPP_ROW0</td>
<td>GPIO_AD_B1_14</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_15</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_12</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_13</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_10</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_11</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_08</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_09</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_06</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_07</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_04</td>
<td>ALT7</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_05</td>
<td>ALT7</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>KPP_ROW6</th>
<th>GPIO_AD_B1_02</th>
<th>ALT7</th>
</tr>
</thead>
<tbody>
<tr>
<td>KPP_COL6</td>
<td>GPIO_AD_B1_03</td>
<td>ALT7</td>
</tr>
<tr>
<td>KPP_ROW7</td>
<td>GPIO_AD_B1_00</td>
<td>ALT7</td>
</tr>
<tr>
<td>KPP_COL7</td>
<td>GPIO_AD_B1_01</td>
<td>ALT7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LCD</th>
<th>GPIO_B0_00</th>
<th>ALT0</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCD_ENABLE</td>
<td>GPIO_B0_01</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_HSYNC</td>
<td>GPIO_B0_02</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_VSYNC</td>
<td>GPIO_B0_03</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA00</td>
<td>GPIO_B0_04</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA01</td>
<td>GPIO_B0_05</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA02</td>
<td>GPIO_B0_06</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA03</td>
<td>GPIO_B0_07</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA04</td>
<td>GPIO_B0_08</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA05</td>
<td>GPIO_B0_09</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA06</td>
<td>GPIO_B0_10</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA07</td>
<td>GPIO_B0_11</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA08</td>
<td>GPIO_B0_12</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA09</td>
<td>GPIO_B0_13</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA10</td>
<td>GPIO_B0_14</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA11</td>
<td>GPIO_B0_15</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA12</td>
<td>GPIO_B1_00</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA13</td>
<td>GPIO_B1_01</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA14</td>
<td>GPIO_B1_02</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA15</td>
<td>GPIO_B1_03</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA16</td>
<td>GPIO_B1_04</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA17</td>
<td>GPIO_B1_05</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA18</td>
<td>GPIO_B1_06</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA19</td>
<td>GPIO_B1_07</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA20</td>
<td>GPIO_B1_08</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA21</td>
<td>GPIO_B1_09</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA22</td>
<td>GPIO_B1_10</td>
<td>ALT0</td>
</tr>
<tr>
<td>LCD_DATA23</td>
<td>GPIO_B1_11</td>
<td>ALT0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LPI2C1</th>
<th>GPIO_AD_B1_00</th>
<th>ALT3</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPI2C1_SCL</td>
<td>GPIO_AD_B1_04</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPI2C1_SDA</td>
<td>GPIO_AD_B1_05</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPI2C1_SCLS</td>
<td>GPIO_AD_B1_01</td>
<td>ALT3</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>LPI2C2</th>
<th>GPIO_B0_04</th>
<th>ALT2</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPI2C2_SCL</td>
<td>GPIO_AD_B0_00</td>
<td>ALT4</td>
</tr>
<tr>
<td>LPI2C2_SDA</td>
<td>GPIO_AD_B0_01</td>
<td>ALT4</td>
</tr>
<tr>
<td>LPI2C2_HREQ</td>
<td>GPIO_AD_B0_02</td>
<td>ALT6</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>ALPI</th>
<th>Muxing Options (continued)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>GPIO_SD_B1_11</td>
</tr>
<tr>
<td>LPI2C2</td>
<td>GPIO_B0_05</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_10</td>
</tr>
<tr>
<td>LPI2C3</td>
<td>GPIO_AD_B1_07</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C22</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_00</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_06</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C21</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_01</td>
</tr>
<tr>
<td>LPI2C4</td>
<td>GPIO_AD_B0_12</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C12</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_13</td>
</tr>
<tr>
<td>LPSPI1</td>
<td>GPIO_EM_C30</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_01</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C31</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C40</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C41</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_00</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C27</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_02</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C28</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C29</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_03</td>
</tr>
<tr>
<td>LPSPI2</td>
<td>GPIO_SD_B1_06</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C01</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C14</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_10</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_11</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_07</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C00</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_08</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_09</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C03</td>
</tr>
<tr>
<td>LPSPI3</td>
<td>GPIO_AD_B1_12</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_03</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_04</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_05</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_06</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Pin Name</th>
<th>GPIO Name</th>
<th>GPIO Port</th>
<th>GPIO Alt</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPSPI3_SCK</td>
<td>GPIO_AD_B1_15</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_00</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td>LPSPI3_SOUT</td>
<td>GPIO_AD_B0_01</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_14</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td>LPSPI3_SIN</td>
<td>GPIO_AD_B1_13</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_02</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td>LPSPI4</td>
<td>LPSPI4_PCS0</td>
<td>GPIO_B1_04</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_00</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_03</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_02</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_11</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_07</td>
<td>ALT1</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_03</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_06</td>
<td>ALT1</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_02</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_05</td>
<td>ALT1</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_01</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>LPUART1</td>
<td>LPUART1_TXD</td>
<td>GPIO_AD_B0_12</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART1_RXD</td>
<td>GPIO_AD_B0_13</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART1_CTS_B</td>
<td>GPIO_AD_B0_14</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART1_RTS_B</td>
<td>GPIO_AD_B0_15</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART2</td>
<td>LPUART2_TXD</td>
<td>GPIO_SD_B1_11</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART2_RXD</td>
<td>GPIO_AD_B1_02</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART2_CTS_B</td>
<td>GPIO_AD_B1_03</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART2_RTS_B</td>
<td>GPIO_SD_B1_10</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART2_CTS_B</td>
<td>GPIO_AD_B1_04</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART2_RTS_B</td>
<td>GPIO_AD_B1_05</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART3</td>
<td>LPUART3_TXD</td>
<td>GPIO_AD_B1_06</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART3_RXD</td>
<td>GPIO_B0_08</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>LPUART3_RXD</td>
<td>GPIO_EMCC13</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART3_CTS_B</td>
<td>GPIO_EMCC14</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART3_CTS_B</td>
<td>GPIO_B0_09</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>LPUART3_CTS_B</td>
<td>GPIO_AD_B1_07</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART3_RTS_B</td>
<td>GPIO_EMCC15</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART3_RTS_B</td>
<td>GPIO_AD_B1_04</td>
<td>ALT2</td>
</tr>
<tr>
<td>lPUART4</td>
<td>LPUART4_TXD</td>
<td>GPIO_SD_B1_00</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>LPUART4_TXD</td>
<td>GPIO_B1_00</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>LPUART4_TXD</td>
<td>GPIO_EMCC16</td>
<td>ALT2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>Description</th>
<th>GPIO</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPUART4_RXD</td>
<td>GPIO_SD_B1_01</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_20</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_01</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART4_CTS_B</td>
<td>GPIO_EMC_17</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART4_RTS_B</td>
<td>GPIO_EMC_18</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART5_TXD</td>
<td>GPIO_EMC_23</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_12</td>
<td>ALT1</td>
</tr>
<tr>
<td>LPUART5_RXD</td>
<td>GPIO_B1_13</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_24</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART5_CTS_B</td>
<td>GPIO_EMC_28</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART5_RTS_B</td>
<td>GPIO_EMC_27</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART6_TXD</td>
<td>GPIO_EMC_25</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_02</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART6_RXD</td>
<td>GPIO_AD_B0_03</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_26</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART6_CTS_B</td>
<td>GPIO_EMC_30</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART6_RTS_B</td>
<td>GPIO_EMC_29</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART7_TXD</td>
<td>GPIO_SD_B1_08</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_31</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART7_RXD</td>
<td>GPIO_EMC_32</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_09</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART7_CTS_B</td>
<td>GPIO_SD_B1_06</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART7_RTS_B</td>
<td>GPIO_SD_B1_07</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART8_TXD</td>
<td>GPIO_EMC_38</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_10</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B0_04</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART8_RXD</td>
<td>GPIO_SD_B0_05</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_11</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_39</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART8_CTS_B</td>
<td>GPIO_SD_B0_02</td>
<td>ALT2</td>
</tr>
<tr>
<td>LPUART8_RTS_B</td>
<td>GPIO_SD_B0_03</td>
<td>ALT2</td>
</tr>
<tr>
<td>MQS_RIGHT</td>
<td>GPIO_AD_B0_04</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_00</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_13</td>
<td>ALT3</td>
</tr>
<tr>
<td>MQS_LEFT</td>
<td>GPIO_EMC_14</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_01</td>
<td>ALT2</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_05</td>
<td>ALT1</td>
</tr>
<tr>
<td>PIT_TRIGGER0</td>
<td>GPIO_AD_B0_04</td>
<td>ALT6</td>
</tr>
<tr>
<td>TMR1_TIMER0</td>
<td>GPIO_B0_00</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR1_TIMER1</td>
<td>GPIO_B0_01</td>
<td>ALT1</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th></th>
<th>GPIO</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>TMR1_TIMER2</td>
<td>GPIO_B0_02</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR1_TIMER3</td>
<td>GPIO_B1_08</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR2 (QUAD TIMER)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TMR2_TIMER0</td>
<td>GPIO_EM_C_19</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_03</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR2_TIMER1</td>
<td>GPIO_EM_C_20</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_04</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR2_TIMER2</td>
<td>GPIO_EM_C_21</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_05</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR2_TIMER3</td>
<td>GPIO_EM_C_22</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_09</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR3 (QUAD TIMER)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TMR3_TIMER0</td>
<td>GPIO_AD_B1_00</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C_15</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_06</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR3_TIMER1</td>
<td>GPIO_AD_B1_01</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C_16</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_07</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR3_TIMER2</td>
<td>GPIO_EM_C_17</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_02</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_B0_08</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR3_TIMER3</td>
<td>GPIO_B1_10</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_03</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_EM_C_18</td>
<td>ALT4</td>
</tr>
<tr>
<td>TMR4 (QUAD TIMER)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TMR4_TIMER0</td>
<td>GPIO_B0_09</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR4_TIMER1</td>
<td>GPIO_B0_10</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR4_TIMER2</td>
<td>GPIO_B0_11</td>
<td>ALT1</td>
</tr>
<tr>
<td>TMR4_TIMER3</td>
<td>GPIO_B1_11</td>
<td>ALT1</td>
</tr>
<tr>
<td>SAI1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAI1_TX_DATA0</td>
<td>GPIO_AD_B1_13</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_01</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_SD_B1_07</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_TX_DATA1 and SAI1_RX_DATA3</td>
<td>GPIO_B0_12</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_TX_DATA2 and SAI1_RX_DATA2</td>
<td>GPIO_B0_11</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_TX_DATA3 and SAI1_RX_DATA1</td>
<td>GPIO_B0_10</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_TX_BCLK</td>
<td>GPIO_SD_B1_08</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_02</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_14</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_TX_SYNC</td>
<td>GPIO_AD_B1_15</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_03</td>
<td>ALT3</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>PIN</th>
<th>GPIO</th>
<th>ALT</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_RX_DATA0</td>
<td>GPIO_SD_B1_09</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_RX_BCLK</td>
<td>GPIO_AD_B1_11</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_RX_SYNC</td>
<td>GPIO_AD_B1_10</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI1_MCLK</td>
<td>GPIO_B0_13</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI2_TX_DATA</td>
<td>GPIO_EMV_04</td>
<td>ALT2</td>
</tr>
<tr>
<td>SAI2_TX_BCLK</td>
<td>GPIO_AD_B0_05</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI2_TX_SYNC</td>
<td>GPIO_AD_B0_04</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI2_MCLK</td>
<td>GPIO_EMV_07</td>
<td>ALT2</td>
</tr>
<tr>
<td>SAI3_TX_DATA</td>
<td>GPIO_EMV_36</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI3_TX_BCLK</td>
<td>GPIO_AD_B1_01</td>
<td>ALT8</td>
</tr>
<tr>
<td>SAI3_TX_SYNC</td>
<td>GPIO_EMV_38</td>
<td>ALT3</td>
</tr>
<tr>
<td>SAI3_MCLK</td>
<td>GPIO_EMV_37</td>
<td>ALT3</td>
</tr>
</tbody>
</table>
Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th></th>
<th>GPIO_SD_B1_04</th>
<th>ALT8</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA00</td>
<td>GPIO_EMC_00</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA01</td>
<td>GPIO_EMC_01</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA02</td>
<td>GPIO_EMC_02</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA03</td>
<td>GPIO_EMC_03</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA04</td>
<td>GPIO_EMC_04</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA05</td>
<td>GPIO_EMC_05</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA06</td>
<td>GPIO_EMC_06</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA07</td>
<td>GPIO_EMC_07</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA08</td>
<td>GPIO_EMC_30</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA09</td>
<td>GPIO_EMC_31</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA10</td>
<td>GPIO_EMC_32</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA11</td>
<td>GPIO_EMC_33</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA12</td>
<td>GPIO_EMC_34</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA13</td>
<td>GPIO_EMC_35</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA14</td>
<td>GPIO_EMC_36</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DATA15</td>
<td>GPIO_EMC_37</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR00</td>
<td>GPIO_EMC_00</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR01</td>
<td>GPIO_EMC_10</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR02</td>
<td>GPIO_EMC_11</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR03</td>
<td>GPIO_EMC_12</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR04</td>
<td>GPIO_EMC_13</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR05</td>
<td>GPIO_EMC_14</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR06</td>
<td>GPIO_EMC_15</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR07</td>
<td>GPIO_EMC_16</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR08</td>
<td>GPIO_EMC_17</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR09</td>
<td>GPIO_EMC_18</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR10</td>
<td>GPIO_EMC_23</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR11</td>
<td>GPIO_EMC_19</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_ADDR12</td>
<td>GPIO_EMC_20</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DM0</td>
<td>GPIO_EMC_08</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_DM1</td>
<td>GPIO_EMC_38</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_BA0</td>
<td>GPIO_EMC_21</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_BA1</td>
<td>GPIO_EMC_22</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_CAS</td>
<td>GPIO_EMC_24</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_RAS</td>
<td>GPIO_EMC_25</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_CLK</td>
<td>GPIO_EMC_26</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_CKE</td>
<td>GPIO_EMC_27</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_WE</td>
<td>GPIO_EMC_28</td>
<td>ALT0</td>
</tr>
<tr>
<td>SEMC_CS0</td>
<td>GPIO_EMC_29</td>
<td>ALT0</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Pin Name</th>
<th>GPIO</th>
<th>ALT</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC_DQS</td>
<td>GPIO_EMC_39</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_RDY</td>
<td>GPIO_EMC_40</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX0</td>
<td>GPIO_EMC_41</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX1</td>
<td>GPIO_SD_B1_07</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX1</td>
<td>GPIO_B0_00</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX2</td>
<td>GPIO_SD_B1_08</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX2</td>
<td>GPIO_B0_01</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX3</td>
<td>GPIO_B0_02</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td>SNVS</td>
<td>SNVS_PMIC_ON_REQ</td>
<td>PMIC_ON_REQ</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>SNVS_VIO_5_CTL</td>
<td>GPIO_EMC_18</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>SNVS_VIO_5_B</td>
<td>GPIO_EMC_19</td>
<td>ALT6</td>
</tr>
<tr>
<td>SPDIF</td>
<td>SPDIF_OUT</td>
<td>GPIO_EMC_15</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_05</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_02</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td>SPDIF_IN</td>
<td>GPIO_EMC_16</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_03</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td>SPDIF_SR_CLK</td>
<td>GPIO_AD_B1_04</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>SPDIF_LOCK</td>
<td>GPIO_AD_B1_06</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>SPDIF_EXT_CLK</td>
<td>GPIO_AD_B1_07</td>
<td>ALT3</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_POR_B</td>
<td>POR_B</td>
<td>ALT0 (No Muxing)</td>
</tr>
<tr>
<td></td>
<td>SRC_RESET_B</td>
<td>ONOFF</td>
<td>ALT0 (No Muxing)</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BOOT_MODE0</td>
<td>GPIO_AD_B0_04</td>
<td>ALT0</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BOOT_MODE1</td>
<td>GPIO_AD_B0_05</td>
<td>ALT0</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG00</td>
<td>GPIO_B0_04</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG01</td>
<td>GPIO_B0_05</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG02</td>
<td>GPIO_B0_06</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG03</td>
<td>GPIO_B0_07</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG04</td>
<td>GPIO_B0_08</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG05</td>
<td>GPIO_B0_09</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG06</td>
<td>GPIO_B0_10</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG07</td>
<td>GPIO_B0_11</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG08</td>
<td>GPIO_B0_12</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG09</td>
<td>GPIO_B0_13</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG10</td>
<td>GPIO_B0_14</td>
<td>ALT6</td>
</tr>
<tr>
<td>SRC</td>
<td>SRC_BT_CFG11</td>
<td>GPIO_B0_15</td>
<td>ALT6</td>
</tr>
<tr>
<td>USB</td>
<td>USB_OTG1_PWR</td>
<td>GPIO_AD_B0_02</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_01</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>USB</td>
<td>USB_OTG1_OC</td>
<td>GPIO_AD_B0_02</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_01</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>USB</td>
<td>USB_OTG1_ID</td>
<td>GPIO_AD_B0_01</td>
<td>ALT3</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>GPIO Name</th>
<th>Port</th>
<th>Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB_OTG2_PWR</td>
<td>GPIO_AD_B1_02</td>
<td>ALTO</td>
<td></td>
</tr>
<tr>
<td>USB_OTG2_OC</td>
<td>GPIO_EMC_41</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>USB_OTG2_OC</td>
<td>GPIO_AD_B0_15</td>
<td>ALT0</td>
<td></td>
</tr>
<tr>
<td>USB_OTG2_ID</td>
<td>GPIO_AD_B0_00</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>USB_PHY 1</td>
<td>USB_PHY1_TSTI_TX_LS_MODE</td>
<td>GPIO_EMC_00</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTI_TX_HS_MODE</td>
<td>GPIO_EMC_01</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTI_TX_DN</td>
<td>GPIO_EMC_02</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTO_RX_SQELCH</td>
<td>GPIO_EMC_03</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTO_RX_DISCONDET</td>
<td>GPIO_EMC_04</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTO_RX_HS_RXD</td>
<td>GPIO_EMC_05</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTO_RX_FS_RXD</td>
<td>GPIO_EMC_07</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTI_TX_DP</td>
<td>GPIO_EMC_08</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTI_TX_EN</td>
<td>GPIO_EMC_09</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTI_TX_HIZ</td>
<td>GPIO_EMC_10</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY1_TSTO_PLL_CLK_20DIV</td>
<td>GPIO_EMC_12</td>
<td>ALT6</td>
</tr>
<tr>
<td>USB_PHY 2</td>
<td>USB_PHY2_TSTO_RX_FS_RXD</td>
<td>GPIO_EMC_06</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY2_TSTO_RX_HS_RXD</td>
<td>GPIO_EMC_11</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY2_TSTO_PLL_CLK_20DIV</td>
<td>GPIO_EMC_13</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY2_TSTO_RX_SQELCH</td>
<td>GPIO_EMC_14</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>USB_PHY2_TSTO_RX_DISCONDET</td>
<td>GPIO_EMC_15</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC1</td>
<td>USDHC1_CMD</td>
<td>GPIO_SD_B0_00</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>USDHC1_CLK</td>
<td>GPIO_SD_B0_01</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>USDHC1_DATA0</td>
<td>GPIO_SD_B0_02</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>USDHC1_DATA1</td>
<td>GPIO_SD_B0_03</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>USDHC1_DATA2</td>
<td>GPIO_SD_B0_04</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>USDHC1_DATA3</td>
<td>GPIO_SD_B0_05</td>
<td>ALT0</td>
</tr>
<tr>
<td></td>
<td>USDHC1_RESET_B</td>
<td>GPIO_AD_B0_00</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_15</td>
<td>GPIO_B1_15</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_33</td>
<td>GPIO_EMC_33</td>
<td>ALT2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>USDHC1_VSELECT</th>
<th>GPIO_EMC_41</th>
<th>ALT6</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>GPIO_AD_B1_01</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_14</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_34</td>
<td>ALT2</td>
</tr>
<tr>
<td>USDHC1_WP</td>
<td>GPIO_EMC_36</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_00</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_13</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_12</td>
<td>ALT3</td>
</tr>
<tr>
<td>USDHC1_CD_B</td>
<td>GPIO_AD_B1_02</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_35</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_B1_12</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2</td>
<td>GPIO_AD_B1_08</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_CMD</td>
<td>GPIO_SD_B1_05</td>
<td>ALT0</td>
</tr>
<tr>
<td>USDHC2_CLK</td>
<td>GPIO_AD_B1_09</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_DATA0</td>
<td>GPIO_SD_B1_04</td>
<td>ALT0</td>
</tr>
<tr>
<td>USDHC2_DATA1</td>
<td>GPIO_AD_B1_04</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_DATA2</td>
<td>GPIO_SD_B1_03</td>
<td>ALT0</td>
</tr>
<tr>
<td>USDHC2_DATA3</td>
<td>GPIO_AD_B1_05</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_DATA4</td>
<td>GPIO_SD_B1_02</td>
<td>ALT0</td>
</tr>
<tr>
<td>USDHC2_DATA5</td>
<td>GPIO_AD_B1_06</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_DATA6</td>
<td>GPIO_SD_B1_01</td>
<td>ALT0</td>
</tr>
<tr>
<td>USDHC2_DATA7</td>
<td>GPIO_AD_B1_07</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_RESET_B</td>
<td>GPIO_SD_B1_00</td>
<td>ALT0</td>
</tr>
<tr>
<td>USDHC2_WP</td>
<td>GPIO_AD_B1_12</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_VSELECT</td>
<td>GPIO_EMC_37</td>
<td>ALT6</td>
</tr>
<tr>
<td>USDHC2_CD_B</td>
<td>GPIO_EMC_38</td>
<td>ALT6</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 10-1. Muxing Options (continued)

<table>
<thead>
<tr>
<th>WDOG1</th>
<th>WDOG1_B</th>
<th>GPIO_B1_13</th>
<th>ALT0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_10</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMTC_39</td>
<td>ALT4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_11</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_00</td>
<td>ALT4</td>
</tr>
<tr>
<td>WDOG1_RESET_B_DEB</td>
<td>GPIO_AD_B0_15</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td>WDOG1_ANY</td>
<td>GPIO_AD_B0_14</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td>WDOG2</td>
<td>WDOG2_B</td>
<td>GPIO_AD_B0_12</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>WDOG2_RESET_B_DEB</td>
<td>GPIO_B0_03</td>
<td>ALT6</td>
</tr>
<tr>
<td>XBAR1</td>
<td>XBAR_INOUT02</td>
<td>GPIO_EMTC_00</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_14</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT03</td>
<td>GPIO_EMTC_01</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_15</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT04</td>
<td>GPIO_SD_B0_00</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMTC_02</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT05</td>
<td>GPIO_EMTC_03</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_SD_B0_01</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT06</td>
<td>GPIO_SD_B0_02</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMTC_04</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT07</td>
<td>GPIO_EMTC_05</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_SD_B0_03</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT08</td>
<td>GPIO_SD_B0_04</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMTC_06</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT09</td>
<td>GPIO_EMTC_07</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_SD_B0_05</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT10</td>
<td>GPIO_B0_12</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT11</td>
<td>GPIO_B0_13</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT12</td>
<td>GPIO_B0_14</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT13</td>
<td>GPIO_B0_15</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT14</td>
<td>GPIO_B1_00</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_00</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT15</td>
<td>GPIO_AD_B0_01</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_01</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT16</td>
<td>GPIO_B1_02</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_02</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT17</td>
<td>GPIO_AD_B0_03</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMTC_08</td>
<td>ALT3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_05</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_03</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>XBAR_INOUT18</td>
<td>GPIO_EMTC_35</td>
<td>ALT1</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th></th>
<th>GPIO_AD_B0_06</th>
<th>ALT6</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR_INOUT19</td>
<td>GPIO_EMC_14</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_07</td>
<td>ALT6</td>
</tr>
<tr>
<td>XBAR_INOUT20</td>
<td>GPIO_AD_B0_08</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_15</td>
<td>ALT1</td>
</tr>
<tr>
<td>XBAR_INOUT21</td>
<td>GPIO_EMC_16</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_09</td>
<td>ALT6</td>
</tr>
<tr>
<td>XBAR_INOUT22</td>
<td>GPIO_AD_B0_10</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_36</td>
<td>ALT1</td>
</tr>
<tr>
<td>XBAR_INOUT23</td>
<td>GPIO_EMC_37</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_11</td>
<td>ALT6</td>
</tr>
<tr>
<td>XBAR_INOUT24</td>
<td>GPIO_AD_B0_14</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_12</td>
<td>ALT1</td>
</tr>
<tr>
<td>XBAR_INOUT25</td>
<td>GPIO_AD_B0_15</td>
<td>ALT1</td>
</tr>
<tr>
<td></td>
<td>GPIO_EMC_13</td>
<td>ALT1</td>
</tr>
<tr>
<td>XTALOSC</td>
<td>GPIO_AD_B0_00</td>
<td>ALT2</td>
</tr>
<tr>
<td>REF_CLK_32K</td>
<td>GPIO_AD_B0_01</td>
<td>ALT2</td>
</tr>
<tr>
<td>REF_CLK_24M</td>
<td>GPIO_AD_B0_03</td>
<td>ALT6</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B0_13</td>
<td>ALT7</td>
</tr>
<tr>
<td>XTALI</td>
<td>XTALI</td>
<td>No Muxing</td>
</tr>
<tr>
<td>XTALO</td>
<td>XTALO</td>
<td>No Muxing</td>
</tr>
</tbody>
</table>
Chapter 11
IOMUX Controller (IOMUXC)

11.1 Overview

The IOMUX Controller (IOMUXC), together with the IOMUX, enables the IC to share one pad to several functional blocks. This sharing is done by multiplexing the pad's input and output signals.

Every module requires a specific pad setting (such as pull up or keeper), and for each pad, there are up to 8 muxing options (called ALT modes). The pad settings parameters are controlled by the IOMUXC.

The IOMUX consists only of combinatorial logic combined from several basic IOMUX cells. Each basic IOMUX cell handles only one pad signal's muxing.

Figure 11-1 illustrates the IOMUX/IOMUXC connectivity in the system.
Figure 11-1. IOMUX SoC Level Block Diagram
11.1.1 Features

The IOMUXC features are:

- 32-bit software mux control registers (IOMUXC_SW_MUX_CTL_PAD_<PAD NAME> or IOMUXC_SW_MUX_CTL_GRP_<GROUP NAME>) to configure 1 of 8 alternate (ALT) MUX_MODE fields of each pad or a predefined group of pads and to enable the forcing of an input path of the pad(s) (SION bit).
- 32-bit software pad control registers (IOMUXC_SW_PAD_CTL_PAD_<PAD_NAME> or IOMUXC_SW_PAD_CTL_GRP_<GROUP NAME>) to configure specific pad settings of each pad, or a predefined group of pads.
- 32-bit general purpose registers - several (GPR0 to GPRn) 32-bit registers according to SoC requirements for any usage.
- 32-bit input select control registers to control the input path to a module when more than one pad drives this module input.

Each SW MUX/PAD CTL IOMUXC register handles only one pad or one pad's group.

Only the minimum number of registers required by software are implemented by hardware. For example, if only ALT0 and ALT1 modes are used on Pad x then only one bit register will be generated as the MUX_MODE control field in the software mux control register of Pad x.

The software mux control registers may allow the forcing of pads to become input (input path enabled) regardless of the functional direction driven. This may be useful for loopback and GPIO data capture.

11.2 Clocks

The table found here describes the clock sources for IOMUXC.

Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
</tbody>
</table>
11.3 Functional description

This section provides a complete functional description of the block.

The IOMUXC consists of two sub-blocks:

- IOMUXC_REGISTERS includes all of the IOMUXC registers (see Features).
- IOMUXC_LOGIC includes all of the IOMUXC combinatorial logic (IP interface controls, address decoder, observability muxes).

The IOMUX consists of a number (about the number of pads in the SoC) of basic iomux_cell units. If only one functional mode is required for a specific pad, there is no need for IOMUX and the signals can be connected directly from the module to the I/O. The IOMUX cell is required whenever two or more functional modes are required for a specific pad or when one functional mode and the one test mode are required.

The basic iomux_cell design, which allows two levels of HW signal control (in ALT6 and ALT7 modes - ALT7 gets highest priority) is shown in Figure 11-2.

![Figure 11-2. IOMUX Cell Block Diagram](image-url)
11.3.1 ALT6 and ALT7 extended muxing modes

The ALT7 and ALT6 extended muxing modes allow any signal in the system (such as fuse, pad input, JTAG, or software register) to override any software configuration and to force the ALT6/ALT7 muxing mode.

It also allows an IOMUX software register to control a group of pads.

11.3.2 SW Loopback through SION bit

A limited option exists to override the default pad functionality and force the input path to be active (ipp_ibe==1'b1) regardless of the value driven by the corresponding module. This can be done by setting the SION (Software Input On) bit in the IOMUXC_SW_MUX_CTL register (when available) to "1".

Uses include:

- LoopBack - Module x drives the pad and also receives pad value as an input.
11.3.3 Daisy chain - multi pads driving same module input pin

In some cases, more than one pad may drive a single module input pin. Such cases require the addition of one more level of IOMUXing; all of these input signals are muxed, and a dedicated software controlled register controls the mux in order to select the required input path.

A module port involved in "daisy chain" requires two software configuration commands, one for selecting the mode for this pad (programable via the IOMUXC_SW_MUX_CTL_<PAD> registers) and one for defining it as the input path (via the daisy chain registers).

This means that a module port involved in "daisy chain" requires two software configuration commands, one for selecting the mode for this pad (programable via the IOMUXC_SW_MUX_CTL_<PAD> registers) and one for defining it as the input path (via the daisy chain registers). The daisy chain is illustrated in the figure below.

![Figure 11-3. Daisy chain illustration](image-url)
## 11.4 IOMUXC GPR Memory Map/Register Definition

**IOMUXC_GPR memory map**

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400A_C000</td>
<td>GPR0 General Purpose Register (IOMUXC_GPR_GPR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.1/328</td>
</tr>
<tr>
<td>400A_C004</td>
<td>GPR1 General Purpose Register (IOMUXC_GPR_GPR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.2/328</td>
</tr>
<tr>
<td>400A_C008</td>
<td>GPR2 General Purpose Register (IOMUXC_GPR_GPR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.3/331</td>
</tr>
<tr>
<td>400A_C00C</td>
<td>GPR3 General Purpose Register (IOMUXC_GPR_GPR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_F0F0h</td>
<td>11.4.4/334</td>
</tr>
<tr>
<td>400A_C010</td>
<td>GPR4 General Purpose Register (IOMUXC_GPR_GPR4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.5/338</td>
</tr>
<tr>
<td>400A_C014</td>
<td>GPR5 General Purpose Register (IOMUXC_GPR_GPR5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.6/342</td>
</tr>
<tr>
<td>400A_C018</td>
<td>GPR6 General Purpose Register (IOMUXC_GPR_GPR6)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.7/344</td>
</tr>
<tr>
<td>400A_C01C</td>
<td>GPR7 General Purpose Register (IOMUXC_GPR_GPR7)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.8/348</td>
</tr>
<tr>
<td>400A_C020</td>
<td>GPR8 General Purpose Register (IOMUXC_GPR_GPR8)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.9/352</td>
</tr>
<tr>
<td>400A_C024</td>
<td>GPR9 General Purpose Register (IOMUXC_GPR_GPR9)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.10/355</td>
</tr>
<tr>
<td>400A_C028</td>
<td>GPR10 General Purpose Register (IOMUXC_GPR_GPR10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.11/356</td>
</tr>
<tr>
<td>400A_C030</td>
<td>GPR11 General Purpose Register (IOMUXC_GPR_GPR11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.12/358</td>
</tr>
<tr>
<td>400A_C034</td>
<td>GPR12 General Purpose Register (IOMUXC_GPR_GPR12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.13/359</td>
</tr>
<tr>
<td>400A_C038</td>
<td>GPR13 General Purpose Register (IOMUXC_GPR_GPR13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.14/361</td>
</tr>
<tr>
<td>400A_C03C</td>
<td>GPR14 General Purpose Register (IOMUXC_GPR_GPR14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.15/363</td>
</tr>
<tr>
<td>400A_C040</td>
<td>GPR15 General Purpose Register (IOMUXC_GPR_GPR15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.16/365</td>
</tr>
<tr>
<td>400A_C044</td>
<td>GPR16 General Purpose Register (IOMUXC_GPR_GPR16)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.17/366</td>
</tr>
<tr>
<td>400A_C048</td>
<td>GPR17 General Purpose Register (IOMUXC_GPR_GPR17)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.18/367</td>
</tr>
<tr>
<td>400A_C04C</td>
<td>GPR18 General Purpose Register (IOMUXC_GPR_GPR18)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.19/367</td>
</tr>
<tr>
<td>400A_C050</td>
<td>GPR19 General Purpose Register (IOMUXC_GPR_GPR19)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.20/368</td>
</tr>
<tr>
<td>400A_C054</td>
<td>GPR20 General Purpose Register (IOMUXC_GPR_GPR20)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.21/369</td>
</tr>
<tr>
<td>400A_C058</td>
<td>GPR21 General Purpose Register (IOMUXC_GPR_GPR21)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.22/370</td>
</tr>
<tr>
<td>400A_C05C</td>
<td>GPR22 General Purpose Register (IOMUXC_GPR_GPR22)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.23/371</td>
</tr>
<tr>
<td>400A_C060</td>
<td>GPR23 General Purpose Register (IOMUXC_GPR_GPR23)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.24/372</td>
</tr>
<tr>
<td>400A_C064</td>
<td>GPR24 General Purpose Register (IOMUXC_GPR_GPR24)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.25/373</td>
</tr>
<tr>
<td>400A_C068</td>
<td>GPR25 General Purpose Register (IOMUXC_GPR_GPR25)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.26/374</td>
</tr>
<tr>
<td>400A_C06C</td>
<td>GPR26 General Purpose Register (IOMUXC_GPR_GPR26)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.27/375</td>
</tr>
<tr>
<td>400A_C070</td>
<td>GPR27 General Purpose Register (IOMUXC_GPR_GPR27)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.28/375</td>
</tr>
<tr>
<td>400A_C074</td>
<td>GPR28 General Purpose Register (IOMUXC_GPR_GPR28)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.29/376</td>
</tr>
<tr>
<td>400A_C078</td>
<td>GPR29 General Purpose Register (IOMUXC_GPR_GPR29)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.30/376</td>
</tr>
<tr>
<td>400A_C07C</td>
<td>GPR30 General Purpose Register (IOMUXC_GPR_GPR30)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.31/377</td>
</tr>
<tr>
<td>400A_C080</td>
<td>GPR31 General Purpose Register (IOMUXC_GPR_GPR31)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.32/377</td>
</tr>
<tr>
<td>400A_C084</td>
<td>GPR32 General Purpose Register (IOMUXC_GPR_GPR32)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.33/378</td>
</tr>
<tr>
<td>400A_C088</td>
<td>GPR33 General Purpose Register (IOMUXC_GPR_GPR33)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.4.34/378</td>
</tr>
</tbody>
</table>
11.4.1  GPR0 General Purpose Register (IOMUXC_GPR_GPR0)

GPR Register

Address: 400A_C000h base + 0h offset = 400A_C000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_GPR_GPR0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved. General</td>
<td>Reserved. General purpose bits to be used by SoC integration. Bit field type:DEFAULT</td>
</tr>
</tbody>
</table>

11.4.2  GPR1 General Purpose Register (IOMUXC_GPR_GPR1)

GPR Register

Address: 400A_C000h base + 4h offset = 400A_C004h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Reserved</th>
<th>ENET1_CLK_DIR</th>
<th>ENET2_CLK_DIR</th>
<th>ENET2_TX_CLK_DIR</th>
<th>ENET1_TX_CLK_DIR</th>
<th>SAI1_MCLK1_SEL</th>
<th>SAI1_MCLK2_SEL</th>
<th>SAI1_MCLK3_SEL</th>
<th>SAI2_MCLK3_SEL</th>
<th>SAI3_MCLK3_SEL</th>
<th>SAI3_MCLK_DIR</th>
<th>SAI2_MCLK_DIR</th>
<th>SAI1_MCLK_DIR</th>
<th>ENET_IPG_CLK_S_EN</th>
<th>EXC_MON</th>
<th>CM7_FORCE_HCLK_EN</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### IOMUXC_GPR_GPR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>CM7_FORCE_HCLK_EN</td>
</tr>
<tr>
<td></td>
<td>Arm CM7 platform AHB clock enable</td>
</tr>
<tr>
<td></td>
<td>This bitfield determines whether or not the AHB clock is running when CM7 is sleeping. If the AHB clock is not enabled with this bit, the TCM is not accessible.</td>
</tr>
<tr>
<td></td>
<td>0  AHB clock is not running (gated) when CM7 is sleeping and TCM is not accessible.</td>
</tr>
<tr>
<td></td>
<td>1  AHB clock is running (enabled) when CM7 is sleeping and TCM is accessible.</td>
</tr>
<tr>
<td>30–24</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>ENET_IPG_CLK_S_EN</td>
</tr>
<tr>
<td></td>
<td>ENET and ENET2 ipg_clk_s clock gating enable</td>
</tr>
<tr>
<td></td>
<td>0  ipg_clk_s is gated when there is no IPS access</td>
</tr>
<tr>
<td></td>
<td>1  ipg_clk_s is always on</td>
</tr>
<tr>
<td>22</td>
<td>EXC_MON</td>
</tr>
<tr>
<td></td>
<td>Exclusive monitor response select of illegal command</td>
</tr>
<tr>
<td></td>
<td>This bit sets the bus response value when CM7 exclusive access fails.</td>
</tr>
<tr>
<td></td>
<td>0  OKAY response</td>
</tr>
<tr>
<td></td>
<td>1  SLVError response (default)</td>
</tr>
<tr>
<td>21</td>
<td>SAI3_MCLK_DIR</td>
</tr>
<tr>
<td></td>
<td>sai3.MCLK signal direction control</td>
</tr>
<tr>
<td></td>
<td>This bitfield controls the sai3.MCLK signal direction.</td>
</tr>
<tr>
<td></td>
<td>0  sai3.MCLK is input signal</td>
</tr>
<tr>
<td></td>
<td>1  sai3.MCLK is output signal</td>
</tr>
<tr>
<td>20</td>
<td>SAI2_MCLK_DIR</td>
</tr>
<tr>
<td></td>
<td>sai2.MCLK signal direction control</td>
</tr>
<tr>
<td></td>
<td>This bitfield controls the sai2.MCLK signal direction.</td>
</tr>
<tr>
<td></td>
<td>0  sai2.MCLK is input signal</td>
</tr>
<tr>
<td></td>
<td>1  sai2.MCLK is output signal</td>
</tr>
<tr>
<td>19</td>
<td>SAI1_MCLK_DIR</td>
</tr>
<tr>
<td></td>
<td>sai1.MCLK signal direction control</td>
</tr>
<tr>
<td></td>
<td>This bitfield controls the sai1.MCLK signal direction.</td>
</tr>
<tr>
<td></td>
<td>0  sai1.MCLK is input signal</td>
</tr>
<tr>
<td></td>
<td>1  sai1.MCLK is output signal</td>
</tr>
<tr>
<td>18</td>
<td>ENET2_TX_CLK_DIR</td>
</tr>
<tr>
<td></td>
<td>ENET2_TX_CLK data direction control</td>
</tr>
<tr>
<td></td>
<td>0  ENET2_TX_CLK output driver is disabled</td>
</tr>
<tr>
<td></td>
<td>1  ENET2_TX_CLK output driver is enabled</td>
</tr>
<tr>
<td>17</td>
<td>ENET1_TX_CLK_DIR</td>
</tr>
<tr>
<td></td>
<td>ENET1_TX_CLK data direction control</td>
</tr>
<tr>
<td></td>
<td>0  ENET1_TX_CLK output driver is disabled</td>
</tr>
<tr>
<td></td>
<td>1  ENET1_TX_CLK output driver is enabled</td>
</tr>
<tr>
<td>16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_GPR_GPR1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14 ENET2_CLK_SEL</td>
<td>ENET2 reference clock mode select.</td>
</tr>
<tr>
<td></td>
<td>0 ENET2 TX reference clock driven by ref_enetpll. This clock is also output to pins via the IOMUX. ENET2_REF_CLK function.</td>
</tr>
<tr>
<td></td>
<td>1 Gets ENET2 TX reference clock from the ENET2_TX_CLK pin. In this use case, an external OSC provides the clock for both the external PHY and the internal controller.</td>
</tr>
<tr>
<td>13 ENET1_CLK_SEL</td>
<td>ENET1 reference clock mode select.</td>
</tr>
<tr>
<td></td>
<td>0 ENET1 TX reference clock driven by ref_enetpll. This clock is also output to pins via the IOMUX. ENET_REF_CLK1 function.</td>
</tr>
<tr>
<td></td>
<td>1 Gets ENET1 TX reference clock from the ENET1_TX_CLK pin. In this use case, an external OSC provides the clock for both the external PHY and the internal controller.</td>
</tr>
<tr>
<td>12 GINT</td>
<td>Global Interrupt</td>
</tr>
<tr>
<td></td>
<td>This is the global interrupt &quot;0&quot; bit (connected to Arm M7 IRQ#0 and GPC)</td>
</tr>
<tr>
<td></td>
<td>0 Global interrupt request is not asserted.</td>
</tr>
<tr>
<td></td>
<td>1 Global interrupt request is asserted.</td>
</tr>
<tr>
<td>11–10 SAI3_MCLK3_SEL</td>
<td>SAI3 MCLK3 source select</td>
</tr>
<tr>
<td></td>
<td>00 ccm.spdif0_clk_root</td>
</tr>
<tr>
<td></td>
<td>01 iomux.spdif_tx_clk2</td>
</tr>
<tr>
<td></td>
<td>10 spdif.spdif_srcclk</td>
</tr>
<tr>
<td></td>
<td>11 spdif.spdif_outclock</td>
</tr>
<tr>
<td>9–8 SAI2_MCLK3_SEL</td>
<td>SAI2 MCLK3 source select</td>
</tr>
<tr>
<td></td>
<td>00 ccm.spdif0_clk_root</td>
</tr>
<tr>
<td></td>
<td>01 iomux.spdif_tx_clk2</td>
</tr>
<tr>
<td></td>
<td>10 spdif.spdif_srcclk</td>
</tr>
<tr>
<td></td>
<td>11 spdif.spdif_outclock</td>
</tr>
<tr>
<td>7–6 SAI1_MCLK3_SEL</td>
<td>SAI1 MCLK3 source select</td>
</tr>
<tr>
<td></td>
<td>00 ccm.spdif0_clk_root</td>
</tr>
<tr>
<td></td>
<td>01 iomux.spdif_tx_clk2</td>
</tr>
<tr>
<td></td>
<td>10 spdif.spdif_srcclk</td>
</tr>
<tr>
<td></td>
<td>11 spdif.spdif_outclock</td>
</tr>
<tr>
<td>5–3 SAI1_MCLK2_SEL</td>
<td>SAI1 MCLK2 source select</td>
</tr>
<tr>
<td></td>
<td>000 ccm.ssi1_clk_root</td>
</tr>
<tr>
<td></td>
<td>001 ccm.ssi2_clk_root</td>
</tr>
<tr>
<td></td>
<td>010 ccm.ssi3_clk_root</td>
</tr>
<tr>
<td></td>
<td>011 iomux.sai1_ipg_clk_sai_mclk</td>
</tr>
<tr>
<td></td>
<td>100 iomux.sai2_ipg_clk_sai_mclk</td>
</tr>
<tr>
<td></td>
<td>101 iomux.sai3_ipg_clk_sai_mclk</td>
</tr>
<tr>
<td></td>
<td>110 Reserved</td>
</tr>
<tr>
<td></td>
<td>111 Reserved</td>
</tr>
<tr>
<td>SAI1_MCLK1_SEL</td>
<td>SAI1 MCLK1 source select</td>
</tr>
<tr>
<td></td>
<td>000 ccm.ssi1_clk_root</td>
</tr>
</tbody>
</table>

Table continues on the next page...
11.4.3 GPR2 General Purpose Register (IOMUXC_GPR_GPR2)

GPR Register

Address: 400A_C000h base + 8h offset = 400A_C008h

IOMUXC_GPR_GPR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>QTIMER4_TMR_CNTS_FREEZE</td>
</tr>
<tr>
<td>30</td>
<td>RAM.AUTO_CLK_GATING_EN</td>
</tr>
<tr>
<td>29</td>
<td>L2_MEM.EN_POWERSAVING</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>MOS.OVERSAMPLE</td>
</tr>
<tr>
<td>25</td>
<td>MOS.EN</td>
</tr>
<tr>
<td>24</td>
<td>MQS_EN</td>
</tr>
<tr>
<td>23 16</td>
<td>MQS_SW_RST</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_GPR_GPR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>001</td>
<td>ccm.ssi2_clk_root</td>
</tr>
<tr>
<td>010</td>
<td>ccm.ssi3_clk_root</td>
</tr>
<tr>
<td>011</td>
<td>iomux.sai1_ipg_clk_sai_mclk</td>
</tr>
<tr>
<td>100</td>
<td>iomux.sai2_ipg_clk_sai_mclk</td>
</tr>
<tr>
<td>101</td>
<td>iomux.sai3_ipg_clk_sai_mclk</td>
</tr>
<tr>
<td>110</td>
<td>Reserved</td>
</tr>
<tr>
<td>111</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_GPR_GPR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>30</td>
<td>QTIMER3_TMR_CNTS_FREEZE&lt;br&gt;QTIMER3 timer counter freeze&lt;br&gt;0 timer counter work normally&lt;br&gt;1 reset counter and output flags</td>
</tr>
<tr>
<td>29</td>
<td>QTIMER2_TMR_CNTS_FREEZE&lt;br&gt;QTIMER2 timer counter freeze&lt;br&gt;0 timer counter work normally&lt;br&gt;1 reset counter and output flags</td>
</tr>
<tr>
<td>28</td>
<td>QTIMER1_TMR_CNTS_FREEZE&lt;br&gt;QTIMER1 timer counter freeze&lt;br&gt;0 timer counter work normally&lt;br&gt;1 reset counter and output flags</td>
</tr>
<tr>
<td>27</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>26</td>
<td>MQSOVERSAMPLE&lt;br&gt;Used to control the PWM oversampling rate compared with mclk.&lt;br&gt;0 32&lt;br&gt;1 64</td>
</tr>
<tr>
<td>25</td>
<td>MQS_EN&lt;br&gt;MQS enable.&lt;br&gt;0 Disable MQS&lt;br&gt;1 Enable MQS</td>
</tr>
<tr>
<td>24</td>
<td>MQS_SW_RST&lt;br&gt;MQS software reset&lt;br&gt;0 Exit software reset for MQS&lt;br&gt;1 Enable software reset for MQS</td>
</tr>
<tr>
<td>23–16</td>
<td>MQS_CLK_DIV&lt;br&gt;Divider ratio control for mclk from hmclk. mclk frequency = 1/(n+1) * hmclk frequency.&lt;br&gt;00000000 mclk frequency = hmclk frequency&lt;br&gt;00000001 mclk frequency = 1/2 * hmclk frequency&lt;br&gt;00000010 mclk frequency = 1/3 * hmclk frequency&lt;br&gt;11111111 mclk frequency = 1/256 * hmclk frequency</td>
</tr>
<tr>
<td>15</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>14</td>
<td>L2_MEM_DEEPSLEEP&lt;br&gt;control how memory enter Deep Sleep mode (shutdown periphery power, but maintain memory contents, outputs of memory are pulled low)&lt;br&gt;0 no force sleep control supported, memory deep sleep mode only entered when whole system in stop mode&lt;br&gt;1 force memory into deep sleep mode</td>
</tr>
<tr>
<td>13</td>
<td>RAM_AUTO_CLK_GATING_EN&lt;br&gt;Automatically gate off RAM clock when RAM is not accessed.&lt;br&gt;0 disable automatically gate off RAM clock&lt;br&gt;1 enable automatically gate off RAM clock</td>
</tr>
<tr>
<td>12</td>
<td>L2_MEM_EN POWERSAVING&lt;br&gt;enable power saving features on L2 memory</td>
</tr>
</tbody>
</table>
### IOMUXC_GPR_GPR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>none memory power saving features enabled, SHUTDOWN/DEEPSLEEP/LIGHTSLEEP will have no effect</td>
</tr>
<tr>
<td>1</td>
<td>memory power saving features enabled, set SHUTDOWN/DEEPSLEEP/LIGHTSLEEP (priority high to low) to enable power saving levels</td>
</tr>
<tr>
<td>11–7</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>6</td>
<td>CANFD_FILTER_BYPASS Disable CANFD filter</td>
</tr>
<tr>
<td>0</td>
<td>enable CANFD filter</td>
</tr>
<tr>
<td>1</td>
<td>disable CANFD filter</td>
</tr>
<tr>
<td>5</td>
<td>AXBS_P_FORCE_ROUND_ROBIN Force Round Robin in AXBS_P. This bit can override master M0 M1 high priority configuration.</td>
</tr>
<tr>
<td>0</td>
<td>AXBS_P masters are not arbitrated in round robin, depending on M0/M1 master priority settings.</td>
</tr>
<tr>
<td>1</td>
<td>AXBS_P masters are arbitrated in round robin</td>
</tr>
<tr>
<td>4</td>
<td>AXBS_P_M1_HIGH_PRIORITY AXBS_P M1 master has higher priority.</td>
</tr>
<tr>
<td>0</td>
<td>AXBS_P M1 master does not have high priority</td>
</tr>
<tr>
<td>1</td>
<td>AXBS_P M1 master has high priority</td>
</tr>
<tr>
<td>3</td>
<td>AXBS_P_M0_HIGH_PRIORITY AXBS_P M0 master has higher priority.</td>
</tr>
<tr>
<td>0</td>
<td>AXBS_P M0 master doesn't have high priority</td>
</tr>
<tr>
<td>1</td>
<td>AXBS_P M0 master has high priority</td>
</tr>
<tr>
<td>2</td>
<td>AXBS_L_FORCE_ROUND_ROBIN Force Round Robin in AXBS_L. This bit can override master DMA and AHBXL high priority configuration.</td>
</tr>
<tr>
<td>0</td>
<td>AXBS_L masters are not arbitrated in round robin, depending on DMA and AHBXL master priority settings.</td>
</tr>
<tr>
<td>1</td>
<td>AXBS_L masters are arbitrated in round robin</td>
</tr>
<tr>
<td>1</td>
<td>AXBS_L_DMA_HIGH_PRIORITY AXBS_L DMA master has higher priority.</td>
</tr>
<tr>
<td>0</td>
<td>AXBS_L DMA master does not have high priority</td>
</tr>
<tr>
<td>1</td>
<td>AXBS_L DMA master has high priority</td>
</tr>
<tr>
<td>0</td>
<td>AXBS_L_AHBXL_HIGH_PRIORITY AXBS_L AHBXL master has higher priority.</td>
</tr>
<tr>
<td>0</td>
<td>AXBS_L_AHBXL master does not have high priority</td>
</tr>
<tr>
<td>1</td>
<td>AXBS_P AHBXL master has high priority</td>
</tr>
</tbody>
</table>
11.4.4  GPR3 General Purpose Register (IOMUXC_GPR_GPR3)

GPR Register

Address: 400A_C000h base + Ch offset = 400A_C00Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>AXBS_L_HALTED</td>
<td>Reserved</td>
<td>OCRAM2_STATUS</td>
<td>OCRAM_STATUS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>AXBS_L_HALT_REQ</td>
<td>Reserved</td>
<td>OCRAM2_CTL</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>AXBS_L_HALTED</td>
<td>Reserved</td>
<td>OCRAM2_CTL</td>
<td>Reserved</td>
<td>DCP_KEY_SEL</td>
<td>OCRAM_CTL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>AXBS_L_HALT_REQ</td>
<td>Reserved</td>
<td>OCRAM2_CTL</td>
<td>Reserved</td>
<td>DCP_KEY_SEL</td>
<td>OCRAM_CTL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>AXBS_L_HALTED</td>
<td>Reserved</td>
<td>OCRAM2_CTL</td>
<td>Reserved</td>
<td>DCP_KEY_SEL</td>
<td>OCRAM_CTL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>AXBS_L_HALT_REQ</td>
<td>Reserved</td>
<td>OCRAM2_CTL</td>
<td>Reserved</td>
<td>DCP_KEY_SEL</td>
<td>OCRAM_CTL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 1 1 1 1 0 0 0 0 0 1 1 1 1 0 0 0

**IOMUXC_GPR_GPR3 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31 AXBS_L_HALTED       | This bit shows the status of axbs_l  
|                        | 0  axbs_l is not halted  
|                        | 1  axbs_l is in halted status                                               |
| 30–28 -                | This field is reserved.  
|                        | Reserved                                                                   |
| 27–24 OCGRAM2_STATUS   | This field shows the OCRAM2 pipeline settings status, controlled by OCRAM2_CTL bits respectively.  
|                        | When the control bit is changed, the corresponding status bit goes high and keeps high until this new configuration is applied the internal logic. This provides a way for software to detect that the configuration has become valid. The suggested flow for changing the configuration in software is:  

*Table continues on the next page...*
IOMUXC_GPR_GPR3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>23–20</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>19–16</td>
<td>This field shows the OCRAM pipeline settings status, controlled by OCRAM_CTL bits respectively. When the control bit is changed, the corresponding status bit goes high and keeps high until this new configuration is applied the internal logic. This provides a way for software to detect that the configuration has become valid. The suggested flow for changing the configuration in software is:</td>
</tr>
<tr>
<td></td>
<td>• set/clear the control bit</td>
</tr>
<tr>
<td></td>
<td>• poll the status bit until it goes to 0</td>
</tr>
<tr>
<td>15</td>
<td>Request to halt axbs_l</td>
</tr>
<tr>
<td></td>
<td>0  axbs_l normal run</td>
</tr>
<tr>
<td></td>
<td>1  request to halt axbs_l</td>
</tr>
<tr>
<td>14–12</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>When this feature is enabled, the write address from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM. This can avoid setup time issue for the write access on the memory cell at high frequency. Enabling this feature would cost at most 1 more clock cycle for each AXI write transaction, i.e., at most 1 more clock cycle for each write burst with multiple beats of data. When this feature is disabled, the write address from the AXI master can be accepted by the on-chip RAM without delay, and data can be written to memory at this cycle (if no other access and write data is also ready at this cycle).</td>
</tr>
<tr>
<td></td>
<td>• 0: write address pipeline is disabled</td>
</tr>
<tr>
<td></td>
<td>• 1: write address pipeline is enabled</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_GPR_GPR3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>OCRAM2_CTL[2]</td>
<td>write data pipeline control bit</td>
</tr>
<tr>
<td></td>
<td>When this feature is enabled, the write data from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM. This can avoid setup time issue for the write access on the memory cell at high frequency. Enabling this feature would cost at most 1 more clock cycle for each AXI write transaction, i.e., at most 1 more clock cycle for each write burst with multiple beats of data. When this feature is disabled, the write data from the AXI master can be accepted by the on-chip RAM without delay, and data can be written to memory at this cycle (if no other access and write address is also ready at this cycle).&lt;br&gt;• 0: write data pipeline is disabled&lt;br&gt;• 1: write data pipeline is enabled</td>
</tr>
<tr>
<td></td>
<td>When this feature is enabled, the read address from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM. This can avoid setup time issue for the read access on the memory cell at high frequency. Enabling this feature would cost at most 1 more clock cycle for each AXI read transaction, i.e., at most 1 more clock cycle for each read burst with multiple beats of data. When this feature is disabled, the read address from the AXI master can be accepted by the on-chip RAM without delay, and data can become ready for master at next clock cycle (if no other access and no read data wait).&lt;br&gt;• 0: read address pipeline is disabled&lt;br&gt;• 1: read address pipeline is enabled</td>
</tr>
<tr>
<td></td>
<td>OCRAM2_CTL[0] - read data wait state control bit.</td>
</tr>
<tr>
<td></td>
<td>When thread data wait state is enabled, it will cost 2 cycles for each read access, (each beat of a read burst). This can avoid the potential timing problem caused by the relatively longer memory access time at higher frequency. When this feature is disabled, it only costs 1 clock cycle to finish a read transaction, i.e., get read data back in the next cycle of read request becomes valid on the bus.&lt;br&gt;• 0: read data pipeline is disabled&lt;br&gt;• 1: read data pipeline is enabled</td>
</tr>
<tr>
<td>7–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4 DCP_KEY_SEL</td>
<td>Select 128-bit dcp key from 256-bit key from SNVS Master Key</td>
</tr>
<tr>
<td>0</td>
<td>Select [127:0] from SNVS Master Key as dcp key</td>
</tr>
<tr>
<td>1</td>
<td>Select [255:128] from SNVS Master Key as dcp key</td>
</tr>
<tr>
<td></td>
<td>When this feature is enabled, the write address from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM. This can avoid setup time issue for the write access on the memory cell at high frequency. Enabling this feature would cost at most 1 more clock cycle for each AXI write transaction, i.e., at most 1 more clock cycle for each write burst with multiple beats of data. When this feature is disabled, the write address from the AXI master can be accepted by the on-chip RAM without delay, and data can be written to memory at this cycle (if no other access and write data is also ready at this cycle).&lt;br&gt;• 0: write address pipeline is disabled&lt;br&gt;• 1: write address pipeline is enabled</td>
</tr>
<tr>
<td></td>
<td>OCRM_CTL[2] - write data pipeline control bit</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## IOMUXC_GPR_GPR3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>When this feature is enabled, the write data from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM. This can avoid setup time issue for the write access on the memory cell at high frequency. Enabling this feature would cost at most 1 more clock cycle for each AXI write transaction, i.e., at most 1 more clock cycle for each write burst with multiple beats of data. When this feature is disabled, the write data from the AXI master can be accepted by the on-chip RAM without delay, and data can be written to memory at this cycle (if no other access and write address is also ready at this cycle).</td>
</tr>
</tbody>
</table>
|                            | • 0: write data pipeline is disabled          
|                            | • 1: write data pipeline is enabled          |
| OCRAM_CTL[1]               | read address pipeline control bit.            |
|                            | When this feature is enabled, the read address from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM. This can avoid setup time issue for the read access on the memory cell at high frequency. Enabling this feature would cost at most 1 more clock cycle for each AXI read transaction, i.e., at most 1 more clock cycle for each read burst with multiple beats of data. When this feature is disabled, the read address from the AXI master can be accepted by the on-chip RAM without delay, and data can become ready for master at next clock cycle (if no other access and no read data wait). |
|                            | • 0: read address pipeline is disabled       |
|                            | • 1: read address pipeline is enabled        |
| OCRAM_CTL[0]               | read data wait state control bit             |
|                            | When thread data wait state is enabled, it will cost 2 cycles for each read access, (each beat of a read burst). This can avoid the potential timing problem caused by the relatively longer memory access time at higher frequency. When this feature is disabled, it only costs 1 clock cycle to finish a read transaction, i.e., get read data back in the next cycle of read request becomes valid on the bus. |
|                            | • 0: read data pipeline is disabled          |
|                            | • 1: read data pipeline is enabled           |
### 11.4.5 GPR4 General Purpose Register (IOMUXC_GPR_GPR4)

**GPR Register**

Address: 400A_C000h base + 10h offset = 400A_C010h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>FLEXSPI2_STOP_ACK</td>
<td>FLEXIO3_STOP_ACK</td>
<td>FLEXIO2_STOP_ACK</td>
<td>FLEXIO1_STOP_ACK</td>
<td>PIT_STOP_ACK</td>
<td>SEMC_STOP_ACK</td>
<td>ENET2_STOP_ACK</td>
<td>SA3_STOP_ACK</td>
<td>SA2_STOP_ACK</td>
<td>SA1_STOP_ACK</td>
<td>ENET1_STOP_ACK</td>
<td>TRNG_STOP_ACK</td>
<td>CAN2_STOP_ACK</td>
<td>CAN1_STOP_REQ</td>
<td>EDMA_STOP_ACK</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>FLEXSPI2_STOP_REQ</td>
<td>FLEXIO3_STOP_REQ</td>
<td>FLEXIO2_STOP_REQ</td>
<td>FLEXIO1_STOP_REQ</td>
<td>PIT_STOP_REQ</td>
<td>SEMC_STOP_REQ</td>
<td>ENET2_STOP_REQ</td>
<td>SA3_STOP_REQ</td>
<td>SA2_STOP_REQ</td>
<td>SA1_STOP_REQ</td>
<td>ENET1_STOP_REQ</td>
<td>TRNG_STOP_REQ</td>
<td>CAN2_STOP_REQ</td>
<td>CAN1_STOP_REQ</td>
<td>EDMA_STOP_REQ</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

---

---
### IOMUXC_GPR_GPR4 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>FLEXSPI2 stop acknowledge</td>
</tr>
<tr>
<td>FLEXSPI2_</td>
<td>0 FLEXSPI2 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 FLEXSPI2 stop acknowledge is asserted</td>
</tr>
<tr>
<td>30</td>
<td>On-platform FLEXIO3 stop acknowledge</td>
</tr>
<tr>
<td>FLEXIO3_</td>
<td>0 FLEXIO3 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 FLEXIO3 stop acknowledge is asserted</td>
</tr>
<tr>
<td>29</td>
<td>FLEXIO2 stop acknowledge</td>
</tr>
<tr>
<td>FLEXIO2_</td>
<td>0 FLEXIO2 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 FLEXIO2 stop acknowledge is asserted (FLEXIO2 is in STOP mode)</td>
</tr>
<tr>
<td>28</td>
<td>FLEXIO1 stop acknowledge</td>
</tr>
<tr>
<td>FLEXIO1_</td>
<td>0 FLEXIO1 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 FLEXIO1 stop acknowledge is asserted</td>
</tr>
<tr>
<td>27</td>
<td>FLEXSPI stop acknowledge</td>
</tr>
<tr>
<td>FLEXSPI_</td>
<td>0 FLEXSPI stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 FLEXSPI stop acknowledge is asserted</td>
</tr>
<tr>
<td>26</td>
<td>PIT stop acknowledge</td>
</tr>
<tr>
<td>PIT_STOP_</td>
<td>0 PIT stop acknowledge is not asserted</td>
</tr>
<tr>
<td>ACK</td>
<td>1 PIT stop acknowledge is asserted</td>
</tr>
<tr>
<td>25</td>
<td>SEMC stop acknowledge</td>
</tr>
<tr>
<td>SEMC_STOP_</td>
<td>0 SEMC stop acknowledge is not asserted</td>
</tr>
<tr>
<td>ACK</td>
<td>1 SEMC stop acknowledge is asserted</td>
</tr>
<tr>
<td>24</td>
<td>ENET2 stop acknowledge</td>
</tr>
<tr>
<td>ENET2_</td>
<td>0 ENET2 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 ENET2 stop acknowledge is asserted</td>
</tr>
<tr>
<td>23</td>
<td>SAI3 stop acknowledge</td>
</tr>
<tr>
<td>SAI3_</td>
<td>0 SAI3 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 SAI3 stop acknowledge is asserted</td>
</tr>
<tr>
<td>22</td>
<td>SAI2 stop acknowledge</td>
</tr>
<tr>
<td>SAI2_</td>
<td>0 SAI2 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 SAI2 stop acknowledge is asserted</td>
</tr>
<tr>
<td>21</td>
<td>SAI1 stop acknowledge</td>
</tr>
<tr>
<td>SAI1_</td>
<td>0 SAI1 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>STOP_ACK</td>
<td>1 SAI1 stop acknowledge is asserted</td>
</tr>
<tr>
<td>20</td>
<td>ENET stop acknowledge</td>
</tr>
<tr>
<td>ENET_STOP_</td>
<td>0 ENET1 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>ACK</td>
<td>1 ENET1 stop acknowledge is asserted</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_GPR_GPR4 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>19  TRNG_STOP_ACK</td>
<td>TRNG stop acknowledge</td>
</tr>
<tr>
<td>19 0</td>
<td>TRNG stop acknowledge is not asserted</td>
</tr>
<tr>
<td>19 1</td>
<td>TRNG stop acknowledge is asserted</td>
</tr>
<tr>
<td>18  CAN2_STOP_ACK</td>
<td>CAN2 stop acknowledge.</td>
</tr>
<tr>
<td>18 0</td>
<td>CAN2 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>18 1</td>
<td>CAN2 stop acknowledge is asserted</td>
</tr>
<tr>
<td>17  CAN1_STOP_ACK</td>
<td>CAN1 stop acknowledge.</td>
</tr>
<tr>
<td>17 0</td>
<td>CAN1 stop acknowledge is not asserted</td>
</tr>
<tr>
<td>17 1</td>
<td>CAN1 stop acknowledge is asserted</td>
</tr>
<tr>
<td>16  EDMA_STOP_ACK</td>
<td>EDMA stop acknowledge. This is a status (read-only) bit</td>
</tr>
<tr>
<td>16 0</td>
<td>EDMA stop acknowledge is not asserted</td>
</tr>
<tr>
<td>16 1</td>
<td>EDMA stop acknowledge is asserted (EDMA is in STOP mode).</td>
</tr>
<tr>
<td>15  FLEXSPI2_STOP_REQ</td>
<td>FlexSPI2 stop request.</td>
</tr>
<tr>
<td>15 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>15 1</td>
<td>stop request on</td>
</tr>
<tr>
<td>14  FLEXIO3_STOP_REQ</td>
<td>On-platform flexio3 stop request.</td>
</tr>
<tr>
<td>14 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>14 1</td>
<td>stop request on</td>
</tr>
<tr>
<td>13  FLEXIO2_STOP_REQ</td>
<td>FlexIO2 stop request.</td>
</tr>
<tr>
<td>13 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>13 1</td>
<td>stop request on</td>
</tr>
<tr>
<td>12  FLEXIO1_STOP_REQ</td>
<td>FlexIO1 stop request.</td>
</tr>
<tr>
<td>12 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>12 1</td>
<td>stop request on</td>
</tr>
<tr>
<td>11  FLEXSPI_STOP_REQ</td>
<td>FlexSPI stop request.</td>
</tr>
<tr>
<td>11 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>11 1</td>
<td>stop request on</td>
</tr>
<tr>
<td>10  PIT_STOP_REQ</td>
<td>PIT stop request.</td>
</tr>
<tr>
<td>10 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>10 1</td>
<td>stop request on</td>
</tr>
<tr>
<td>9  SEMC_STOP_REQ</td>
<td>SEMC stop request.</td>
</tr>
<tr>
<td>9 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>9 1</td>
<td>stop request on</td>
</tr>
<tr>
<td>8  ENET2_STOP_REQ</td>
<td>ENET2 stop request.</td>
</tr>
<tr>
<td>8 0</td>
<td>stop request off</td>
</tr>
<tr>
<td>8 1</td>
<td>stop request on</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_GPR_GPR4 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 SAI3_STOP_REQ</td>
<td>SAI3 stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
<tr>
<td>6 SAI2_STOP_REQ</td>
<td>SAI2 stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
<tr>
<td>5 SAI1_STOP_REQ</td>
<td>SAI1 stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
<tr>
<td>4 ENET_STOP_REQ</td>
<td>ENET stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
<tr>
<td>3 TRNG_STOP_REQ</td>
<td>TRNG stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
<tr>
<td>2 CAN2_STOP_REQ</td>
<td>CAN2 stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
<tr>
<td>1 CAN1_STOP_REQ</td>
<td>CAN1 stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
<tr>
<td>0 EDMA_STOP_REQ</td>
<td>EDMA stop request.</td>
</tr>
<tr>
<td></td>
<td>0 stop request off</td>
</tr>
<tr>
<td></td>
<td>1 stop request on</td>
</tr>
</tbody>
</table>
### 11.4.6 GPR5 General Purpose Register (IOMUXC_GPR_GPR5)

**GPR Register**

Address: 400A_C000h base + 14h offset = 400A_C014h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>GPT2 1 MHz clock source select</td>
</tr>
<tr>
<td>28</td>
<td>GPT1 1 MHz clock source select</td>
</tr>
<tr>
<td>27</td>
<td>ENET2 input timer event3 source select</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>GPT2 1 MHz clock source select</td>
</tr>
<tr>
<td>0</td>
<td>GPT2 ipg_clk_highfreq driven by IPG_PERCLK</td>
</tr>
<tr>
<td>1</td>
<td>GPT2 ipg_clk_highfreq driven by anatop 1 MHz clock</td>
</tr>
<tr>
<td>28</td>
<td>GPT1 1 MHz clock source select</td>
</tr>
<tr>
<td>0</td>
<td>GPT1 ipg_clk_highfreq driven by IPG_PERCLK</td>
</tr>
<tr>
<td>1</td>
<td>GPT1 ipg_clk_highfreq driven by anatop 1 MHz clock</td>
</tr>
<tr>
<td>27</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>ENET2 input timer event3 source select</td>
</tr>
<tr>
<td>0</td>
<td>event3 source input from ENET2_1588_EVENT3_IN</td>
</tr>
<tr>
<td>1</td>
<td>event3 source input from GPT2.GPT_COMPARE2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC_GPR_GPR5 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>25 ENET_EVENT3IN_SEL</td>
<td>ENET input timer event3 source select</td>
</tr>
<tr>
<td>0</td>
<td>event3 source input from ENET_1588_EVENT3_IN</td>
</tr>
<tr>
<td>1</td>
<td>event3 source input from GPT2.GPT_COMPARE1</td>
</tr>
<tr>
<td>24 GPT2_CAPIN2_SEL</td>
<td>GPT2 input capture channel 2 source select</td>
</tr>
<tr>
<td>0</td>
<td>source from GPT2_CAPTURE2</td>
</tr>
<tr>
<td>1</td>
<td>source from ENET2_1588_EVENT3_OUT (channel 3 of IEEE 1588 timer)</td>
</tr>
<tr>
<td>23 GPT2_CAPIN1_SEL</td>
<td>GPT2 input capture channel 1 source select</td>
</tr>
<tr>
<td>0</td>
<td>source from GPT2_CAPTURE1</td>
</tr>
<tr>
<td>1</td>
<td>source from ENET_1588_EVENT3_OUT (channel 3 of IEEE 1588 timer)</td>
</tr>
<tr>
<td>22–12</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>11–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7 WDOG2_MASK</td>
<td>WDOG2 Timeout Mask</td>
</tr>
<tr>
<td>0</td>
<td>WDOG2 Timeout behaves normally</td>
</tr>
<tr>
<td>1</td>
<td>WDOG2 Timeout is masked</td>
</tr>
<tr>
<td>6 WDOG1_MASK</td>
<td>WDOG1 Timeout Mask</td>
</tr>
<tr>
<td>0</td>
<td>WDOG1 Timeout behaves normally</td>
</tr>
<tr>
<td>1</td>
<td>WDOG1 Timeout is masked</td>
</tr>
<tr>
<td>5–4</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
11.4.7 GPR6 General Purpose Register (IOMUXC_GPR_GPR6)

GPR Register

Address: 400A_C000h base + 18h offset = 400A_C018h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>IOMUXC_XBAR_DIR_SEL_19</td>
</tr>
<tr>
<td>30</td>
<td>IOMUXC_XBAR_DIR_SEL_18</td>
</tr>
<tr>
<td>29</td>
<td>IOMUXC_XBAR_DIR_SEL_17</td>
</tr>
<tr>
<td>28</td>
<td>IOMUXC_XBAR_DIR_SEL_16</td>
</tr>
<tr>
<td>27</td>
<td>IOMUXC_XBAR_DIR_SEL_15</td>
</tr>
<tr>
<td>26</td>
<td>IOMUXC_XBAR_DIR_SEL_14</td>
</tr>
<tr>
<td>25</td>
<td>IOMUXC_XBAR_DIR_SEL_13</td>
</tr>
<tr>
<td>24</td>
<td>IOMUXC_XBAR_DIR_SEL_12</td>
</tr>
<tr>
<td>23</td>
<td>IOMUXC_XBAR_DIR_SEL_11</td>
</tr>
<tr>
<td>22</td>
<td>IOMUXC_XBAR_DIR_SEL_10</td>
</tr>
<tr>
<td>21</td>
<td>IOMUXC_XBAR_DIR_SEL_9</td>
</tr>
<tr>
<td>20</td>
<td>IOMUXC_XBAR_DIR_SEL_8</td>
</tr>
<tr>
<td>19</td>
<td>IOMUXC_XBAR_DIR_SEL_7</td>
</tr>
<tr>
<td>18</td>
<td>IOMUXC_XBAR_DIR_SEL_6</td>
</tr>
<tr>
<td>17</td>
<td>IOMUXC_XBAR_DIR_SEL_5</td>
</tr>
<tr>
<td>16</td>
<td>IOMUXC_XBAR_DIR_SEL_4</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>26 IOMUXC_XBAR_DIR_SEL_14</td>
<td>IOMUXC XBAR_INOUT14 function direction select</td>
</tr>
<tr>
<td>25 IOMUXC_XBAR_DIR_SEL_13</td>
<td>IOMUXC XBAR_INOUT13 function direction select</td>
</tr>
<tr>
<td>24 IOMUXC_XBAR_DIR_SEL_12</td>
<td>IOMUXC XBAR_INOUT12 function direction select</td>
</tr>
<tr>
<td>23 IOMUXC_XBAR_DIR_SEL_11</td>
<td>IOMUXC XBAR_INOUT11 function direction select</td>
</tr>
<tr>
<td>22 IOMUXC_XBAR_DIR_SEL_10</td>
<td>IOMUXC XBAR_INOUT10 function direction select</td>
</tr>
<tr>
<td>21 IOMUXC_XBAR_DIR_SEL_9</td>
<td>IOMUXC XBAR_INOUT9 function direction select</td>
</tr>
<tr>
<td>20 IOMUXC_XBAR_DIR_SEL_8</td>
<td>IOMUXC XBAR_INOUT8 function direction select</td>
</tr>
<tr>
<td>19 IOMUXC_XBAR_DIR_SEL_7</td>
<td>IOMUXC XBAR_INOUT7 function direction select</td>
</tr>
<tr>
<td>18 IOMUXC_XBAR_DIR_SEL_6</td>
<td>IOMUXC XBAR_INOUT6 function direction select</td>
</tr>
<tr>
<td>17 IOMUXC_XBAR_DIR_SEL_5</td>
<td>IOMUXC XBAR_INOUT5 function direction select</td>
</tr>
<tr>
<td>16 IOMUXC_XBAR_DIR_SEL_4</td>
<td>IOMUXC XBAR_INOUT4 function direction select</td>
</tr>
<tr>
<td>15 QTIMER4_TRM3_INPUT_SEL</td>
<td>QTIMER4 TMR3 input select</td>
</tr>
</tbody>
</table>

0 XBAR_INOUT as input  
1 XBAR_INOUT as output
IOMUXC GPR Memory Map/Register Definition

IOMUXC_GPR_GPR6 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14 QTIMER4_TRM2_INPUT_SEL</td>
<td>QTIMER4 TMR2 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>13 QTIMER4_TRM1_INPUT_SEL</td>
<td>QTIMER4 TMR1 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>12 QTIMER4_TRM0_INPUT_SEL</td>
<td>QTIMER4 TMR0 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>11 QTIMER3_TRM3_INPUT_SEL</td>
<td>QTIMER3 TMR3 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>10 QTIMER3_TRM2_INPUT_SEL</td>
<td>QTIMER3 TMR2 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>9 QTIMER3_TRM1_INPUT_SEL</td>
<td>QTIMER3 TMR1 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>8 QTIMER3_TRM0_INPUT_SEL</td>
<td>QTIMER3 TMR0 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>7 QTIMER2_TRM3_INPUT_SEL</td>
<td>QTIMER2 TMR3 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>6 QTIMER2_TRM2_INPUT_SEL</td>
<td>QTIMER2 TMR2 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>5 QTIMER2_TRM1_INPUT_SEL</td>
<td>QTIMER2 TMR1 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>4 QTIMER2_TRM0_INPUT_SEL</td>
<td>QTIMER2 TMR0 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
<tr>
<td>3 QTIMER1_TRM3_INPUT_SEL</td>
<td>QTIMER1 TMR3 input select</td>
</tr>
<tr>
<td></td>
<td>0 input from IOMUX</td>
</tr>
<tr>
<td></td>
<td>1 input from XBAR</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2 QTIMER1_TRM2_INPUT_SEL</td>
<td>QTIMER1 TMR2 input select</td>
</tr>
<tr>
<td>1 QTIMER1_TRM1_INPUT_SEL</td>
<td>QTIMER1 TMR1 input select</td>
</tr>
<tr>
<td>0 QTIMER1_TRM0_INPUT_SEL</td>
<td>QTIMER1 TMR0 input select</td>
</tr>
<tr>
<td>0</td>
<td>input from IOMUX</td>
</tr>
<tr>
<td>1</td>
<td>input from XBAR</td>
</tr>
</tbody>
</table>
## 11.4.8 GPR7 General Purpose Register (IOMUXC_GPR_GPR7)

GPR Register

Address: 400A_C000h base + 1Ch offset = 400A_C01Ch

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>Bit 30</th>
<th>Bit 29</th>
<th>Bit 28</th>
<th>Bit 27</th>
<th>Bit 26</th>
<th>Bit 25</th>
<th>Bit 24</th>
<th>Bit 23</th>
<th>Bit 22</th>
<th>Bit 21</th>
<th>Bit 20</th>
<th>Bit 19</th>
<th>Bit 18</th>
<th>Bit 17</th>
<th>Bit 16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPUART8_STOP_ACK</td>
<td>LPUART7_STOP_ACK</td>
<td>LPUART6_STOP_ACK</td>
<td>LPUART5_STOP_ACK</td>
<td>LPUART4_STOP_ACK</td>
<td>LPUART3_STOP_ACK</td>
<td>LPUART2_STOP_ACK</td>
<td>LPUART1_STOP_ACK</td>
<td>LPSPI4_STOP_ACK</td>
<td>LPSPI3_STOP_ACK</td>
<td>LPSPI2_STOP_ACK</td>
<td>LPSPI1_STOP_ACK</td>
<td>LPI2C4_STOP_ACK</td>
<td>LPI2C3_STOP_ACK</td>
<td>LPI2C2_STOP_ACK</td>
<td>LPI2C1_STOP_ACK</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPUART8_STOP_REQ</td>
<td>LPUART7_STOP_REQ</td>
<td>LPUART6_STOP_REQ</td>
<td>LPUART5_STOP_REQ</td>
<td>LPUART4_STOP_REQ</td>
<td>LPUART3_STOP_REQ</td>
<td>LPUART2_STOP_REQ</td>
<td>LPUART1_STOP_REQ</td>
<td>LPSPI4_STOP_REQ</td>
<td>LPSPI3_STOP_REQ</td>
<td>LPSPI2_STOP_REQ</td>
<td>LPSPI1_STOP_REQ</td>
<td>LPI2C4_STOP_REQ</td>
<td>LPI2C3_STOP_REQ</td>
<td>LPI2C2_STOP_REQ</td>
<td>LPI2C1_STOP_REQ</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPUART8_STOP_REQ</td>
<td>LPUART7_STOP_REQ</td>
<td>LPUART6_STOP_REQ</td>
<td>LPUART5_STOP_REQ</td>
<td>LPUART4_STOP_REQ</td>
<td>LPUART3_STOP_REQ</td>
<td>LPUART2_STOP_REQ</td>
<td>LPUART1_STOP_REQ</td>
<td>LPSPI4_STOP_REQ</td>
<td>LPSPI3_STOP_REQ</td>
<td>LPSPI2_STOP_REQ</td>
<td>LPSPI1_STOP_REQ</td>
<td>LPI2C4_STOP_REQ</td>
<td>LPI2C3_STOP_REQ</td>
<td>LPI2C2_STOP_REQ</td>
<td>LPI2C1_STOP_REQ</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPUART8_STOP_REQ</td>
<td>LPUART7_STOP_REQ</td>
<td>LPUART6_STOP_REQ</td>
<td>LPUART5_STOP_REQ</td>
<td>LPUART4_STOP_REQ</td>
<td>LPUART3_STOP_REQ</td>
<td>LPUART2_STOP_REQ</td>
<td>LPUART1_STOP_REQ</td>
<td>LPSPI4_STOP_REQ</td>
<td>LPSPI3_STOP_REQ</td>
<td>LPSPI2_STOP_REQ</td>
<td>LPSPI1_STOP_REQ</td>
<td>LPI2C4_STOP_REQ</td>
<td>LPI2C3_STOP_REQ</td>
<td>LPI2C2_STOP_REQ</td>
<td>LPI2C1_STOP_REQ</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_GPR_GPR7 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31 LPUART8_STOP_ACK | LPUART8 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted (the module is in Stop mode) |
| 30 LPUART7_STOP_ACK | LPUART7 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 29 LPUART6_STOP_ACK | LPUART6 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 28 LPUART5_STOP_ACK | LPUART5 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 27 LPUART4_STOP_ACK | LPUART4 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 26 LPUART3_STOP_ACK | LPUART3 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 25 LPUART2_STOP_ACK | LPUART1 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 24 LPUART1_STOP_ACK | LPUART1 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 23 LPSPI4_STOP_ACK | LPSPI4 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 22 LPSPI3_STOP_ACK | LPSPI3 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 21 LPSPI2_STOP_ACK | LPSPI2 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |
| 20 LPSPI1_STOP_ACK | LPSPI1 stop acknowledge  
0 stop acknowledge is not asserted  
1 stop acknowledge is asserted |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>19 LPI2C4_STOP_ACK</td>
<td>LPI2C4 stop acknowledge</td>
</tr>
<tr>
<td>18 LPI2C3_STOP_ACK</td>
<td>LPI2C3 stop acknowledge</td>
</tr>
<tr>
<td>17 LPI2C2_STOP_ACK</td>
<td>LPI2C2 stop acknowledge</td>
</tr>
<tr>
<td>16 LPI2C1_STOP_ACK</td>
<td>LPI2C1 stop acknowledge</td>
</tr>
<tr>
<td>15 LPUART8_STOP_REQ</td>
<td>LPUART8 stop request</td>
</tr>
<tr>
<td>14 LPUART7_STOP_REQ</td>
<td>LPUART7 stop request</td>
</tr>
<tr>
<td>13 LPUART6_STOP_REQ</td>
<td>LPUART6 stop request</td>
</tr>
<tr>
<td>12 LPUART5_STOP_REQ</td>
<td>LPUART5 stop request</td>
</tr>
<tr>
<td>11 LPUART4_STOP_REQ</td>
<td>LPUART4 stop request</td>
</tr>
<tr>
<td>10 LPUART3_STOP_REQ</td>
<td>LPUART3 stop request</td>
</tr>
<tr>
<td>9 LPUART2_STOP_REQ</td>
<td>LPUART1 stop request</td>
</tr>
<tr>
<td>8 LPUART1_STOP_REQ</td>
<td>LPUART1 stop request</td>
</tr>
</tbody>
</table>

0 stop acknowledge is not asserted  
1 stop acknowledge is asserted

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

0 stop request off  
1 stop request on

Table continues on the next page...
### IOMUXC_GPR_GPR7 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 LPSPI4_STOP_REQ</td>
<td>LPSPI4 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
<tr>
<td>6 LPSPI3_STOP_REQ</td>
<td>LPSPI3 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
<tr>
<td>5 LPSPI2_STOP_REQ</td>
<td>LPSPI2 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
<tr>
<td>4 LPSPI1_STOP_REQ</td>
<td>LPSPI1 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
<tr>
<td>3 LPI2C4_STOP_REQ</td>
<td>LPI2C4 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
<tr>
<td>2 LPI2C3_STOP_REQ</td>
<td>LPI2C3 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
<tr>
<td>1 LPI2C2_STOP_REQ</td>
<td>LPI2C2 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
<tr>
<td>0 LPI2C1_STOP_REQ</td>
<td>LPI2C1 stop request</td>
</tr>
<tr>
<td>0</td>
<td>stop request off</td>
</tr>
<tr>
<td>1</td>
<td>stop request on</td>
</tr>
</tbody>
</table>
11.4.9 GPR8 General Purpose Register (IOMUXC_GPR_GPR8)

GPR Register

Address: 400A_C000h base + 20h offset = 400A_C020h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>LPUART8 ipg_doze mode</td>
</tr>
<tr>
<td></td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
<tr>
<td>30</td>
<td>LPUART8 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td></td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>29</td>
<td>LPUART7 ipg_doze mode</td>
</tr>
<tr>
<td></td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
<tr>
<td>28</td>
<td>LPUART7 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td></td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>27</td>
<td>LPUART6 ipg_doze mode</td>
</tr>
<tr>
<td></td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_GPR_GPR8 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 26 LPUART6_IPG_STOP_MODE | LPUART6 stop mode selection, cannot change when ipg_stop is asserted.  
0  the module is functional in Stop mode  
1  the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |
| 25 LPUART5_IPG_DOZE | LPUART5 ipg_doze mode  
0  not in doze mode  
1  in doze mode |
| 24 LPUART5_IPG_STOP_MODE | LPUART5 stop mode selection, cannot change when ipg_stop is asserted.  
0  the module is functional in Stop mode  
1  the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |
| 23 LPUART4_IPG_DOZE | LPUART4 ipg_doze mode  
0  not in doze mode  
1  in doze mode |
| 22 LPUART4_IPG_STOP_MODE | LPUART4 stop mode selection, cannot change when ipg_stop is asserted.  
0  the module is functional in Stop mode  
1  the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |
| 21 LPUART3_IPG_DOZE | LPUART3 ipg_doze mode  
0  not in doze mode  
1  in doze mode |
| 20 LPUART3_IPG_STOP_MODE | LPUART3 stop mode selection, cannot change when ipg_stop is asserted.  
0  the module is functional in Stop mode  
1  the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |
| 19 LPUART2_IPG_DOZE | LPUART2 ipg_doze mode  
0  not in doze mode  
1  in doze mode |
| 18 LPUART2_IPG_STOP_MODE | LPUART2 stop mode selection, cannot change when ipg_stop is asserted.  
0  the module is functional in Stop mode  
1  the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |
| 17 LPUART1_IPG_DOZE | LPUART1 ipg_doze mode  
0  not in doze mode  
1  in doze mode |
| 16 LPUART1_IPG_STOP_MODE | LPUART1 stop mode selection, cannot change when ipg_stop is asserted.  
0  the module is functional in Stop mode  
1  the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |
| 15 LPSPI4_IPG_DOZE | LPSPI4 ipg_doze mode  
0  not in doze mode  
1  in doze mode |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14 LPSPI4_IPG_</td>
<td>LPSPI4 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>STOP_MODE</td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>13 LPSPI3_IPG_</td>
<td>LPSPI3 ipg_doze mode</td>
</tr>
<tr>
<td>DOZE</td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
<tr>
<td>12 LPSPI3_IPG_</td>
<td>LPSPI3 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>STOP_MODE</td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>11 LPSPI2_IPG_</td>
<td>LPSPI2 ipg_doze mode</td>
</tr>
<tr>
<td>DOZE</td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
<tr>
<td>10 LPSPI2_IPG_</td>
<td>LPSPI2 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>STOP_MODE</td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>9  LPSPI1_IPG_</td>
<td>LPSPI1 ipg_doze mode</td>
</tr>
<tr>
<td>DOZE</td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
<tr>
<td>8  LPSPI1_IPG_</td>
<td>LPSPI1 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>STOP_MODE</td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>7  LPI2C4_IPG_</td>
<td>LPI2C4 ipg_doze mode</td>
</tr>
<tr>
<td>DOZE</td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
<tr>
<td>6  LPI2C4_IPG_</td>
<td>LPI2C4 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>STOP_MODE</td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>5  LPI2C3_IPG_</td>
<td>LPI2C3 ipg_doze mode</td>
</tr>
<tr>
<td>DOZE</td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
<tr>
<td>4  LPI2C3_IPG_</td>
<td>LPI2C3 stop mode selection, cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>STOP_MODE</td>
<td>0 the module is functional in Stop mode</td>
</tr>
<tr>
<td></td>
<td>1 the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted</td>
</tr>
<tr>
<td>3  LPI2C2_IPG_</td>
<td>LPI2C2 ipg_doze mode</td>
</tr>
<tr>
<td>DOZE</td>
<td>0 not in doze mode</td>
</tr>
<tr>
<td></td>
<td>1 in doze mode</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_GPR_GPR8 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 2     | LPI2C2 stop mode selection, cannot change when ipg_stop is asserted.  
0 | the module is functional in Stop mode  
1 | the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |
| 1     | LPI2C1 ipg_doze mode  
0 | not in doze mode  
1 | in doze mode |
| 0     | LPI2C1 stop mode selection, cannot change when ipg_stop is asserted.  
0 | the module is functional in Stop mode  
1 | the module is NOT functional in Stop mode, when this bit is equal to 1 and ipg_stop is asserted |

### 11.4.10 GPR9 General Purpose Register (IOMUXC_GPR_GPR9)

**GPR Register**

Address: 400A_C000h base + 24h offset = 400A_C024h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**IOMUXC_GPR_GPR9 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
|       | This field is reserved.  
|       | General purpose bits to be used by SoC integration. Bit field type: STICKY |
11.4.11 GPR10 General Purpose Register (IOMUXC_GPR_GPR10)

GPR Register

Address: 400A_C000h base + 28h offset = 400A_C028h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>LOCK_OCRAM_TZ_ADDR</td>
<td>LOCK_OCRAM_TZ_ADDR</td>
<td>LOCK_OCRAM_TZ_EN</td>
<td>LOCK_OCRAM_TZ_EN</td>
<td>LOCK_DCPKEY_OCOTP_OR_KEYMUX</td>
<td>LOCK_DCPKEY_OCOTP_OR_KEYMUX</td>
<td>LOCK_DCPKEY_OCOTP_OR_KEYMUX</td>
<td>LOCK_SEC_ERR_RESP</td>
<td>LOCK_DBG_EN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>LOCK_OCRAM_TZ_ADDR</td>
<td>LOCK_OCRAM_TZ_ADDR</td>
<td>LOCK_OCRAM_TZ_EN</td>
<td>LOCK_OCRAM_TZ_EN</td>
<td>LOCK_DCPKEY_OCOTP_OR_KEYMUX</td>
<td>LOCK_DCPKEY_OCOTP_OR_KEYMUX</td>
<td>LOCK_DCPKEY_OCOTP_OR_KEYMUX</td>
<td>LOCK_SEC_ERR_RESP</td>
<td>LOCK_DBG_EN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td>LOCK_NIDEN</td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
</table>

IOMUXC_GPR_GPR10 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–25 LOCK_OCRAM_TZ_ADDR</td>
<td>Lock OCRAM_TZ_ADDR field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td>0  Field is not locked</td>
<td>1  Field is locked (read access only)</td>
</tr>
<tr>
<td>24 LOCK_OCRAM_TZ_EN</td>
<td>Lock OCRAM_TZ_EN field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td>0  Field is not locked</td>
<td>1  Field is locked (read access only)</td>
</tr>
<tr>
<td>23–21 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>20 LOCK_DCPKEY_OCOTP_OR_KEYMUX</td>
<td>Lock DCP Key OCOTP/Key MUX selection bit. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td>0  Field is not locked</td>
<td>1  Field is locked (read access only)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>19</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>
| 18      | LOCK_SEC_ERR_RESP  
Lock SEC_ERR_RESP field for changes. This is a sticky field, once set it cannot be cleared (only by reset).  
0 Field is not locked  
1 Field is locked (read access only)                                                                                                                                                                                                                                  |
| 17      | LOCK_DBG_EN  
Lock DBG_EN field for changes. This is a sticky field, once set it cannot be cleared (only by reset).  
0 Field is not locked  
1 Field is locked (read access only)                                                                                                                                                                                                                                  |
| 16      | LOCK_NIDEN  
Lock NIDEN field for changes. This is a sticky field, once set it cannot be cleared (only by reset).  
0 Field is not locked  
1 Field is locked (read access only)                                                                                                                                                                                                                                  |
| 15–9    | OCRAM_TZ_ADDR  
OCRAM TrustZone (TZ) start address. This is the start address of the secure memory region within the OCRAM memory space is 4 KB granularity. The start address affects the OCRAM transactions only if OCRAM_TZ_EN bit is set. The OCRAM TZ ENDADDR is not configurable and is set to the end of OCRAM memory space.                                                                 |
| 8       | OCRAM_TZ_EN  
OCRAM TrustZone (TZ) enable.  
0 The TrustZone feature is disabled. Entire OCRAM space is available for all access types (secure/non-secure/user/supervisor).  
1 The TrustZone feature is enabled. Access to address in the range specified by [ENDADDR:STARTADDR] follows the execution mode access policy described in CSU chapter.                                                                                                                                 |
| 7–5     | This field is reserved.  
Reserved                                                                                                                                                                                                                                                                                                                                 |
| 4       | DCPKEY_OCOTP_OR_KEYMUX  
DCP Key selection bit.  
0 Select key from SNVS Master Key.  
1 Select key from OCOTP (SW_GP2).                                                                                                                                                                                                                                                                                  |
| 3       | This field is reserved.  
Reserved                                                                                                                                                                                                                                                                                                                                 |
| 2       | SEC_ERR_RESP  
Security error response enable for all security gaskets (on both AHB and AXI buses)  
0 OKEY response  
1 SLVError (default)                                                                                                                                                                                                                                                                                      |
| 1       | DBG_EN  
Arm invasive debug enable  
0 Debug turned off.  
1 Debug enabled (default).                                                                                                                                                                                                                                                                                  |
| 0       | NIDEN  
Arm non-secure (non-invasive) debug enable  
0 Debug turned off.  
1 Debug enabled (default).                                                                                                                                                                                                                                                                                  |
### GPR11 General Purpose Register (IOMUXC_GPR_GPR11)

#### GPR Register

Address: 400A_C000h base + 2Ch offset = 400A_C02Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset:**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_GPR_GPR11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>15–12</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>11–8</td>
<td>BEE data decryption of memory region-(n) ((n=3) to 0).</td>
</tr>
<tr>
<td>BEE_DE_RX_EN</td>
<td>• 0: FlexSPI data decryption disabled</td>
</tr>
<tr>
<td></td>
<td>• 1: FlexSPI data decryption enabled</td>
</tr>
<tr>
<td>7–6</td>
<td>Access control of memory region-3</td>
</tr>
<tr>
<td>M7_APC_AC_R3_CTRL</td>
<td>00: No access protection</td>
</tr>
<tr>
<td></td>
<td>01: M7 debug protection enabled</td>
</tr>
<tr>
<td></td>
<td>10: Reserved</td>
</tr>
<tr>
<td></td>
<td>11: Reserved</td>
</tr>
<tr>
<td>5–4</td>
<td>Access control of memory region-2</td>
</tr>
<tr>
<td>M7_APC_AC_R2_CTRL</td>
<td>00: No access protection</td>
</tr>
<tr>
<td></td>
<td>01: M7 debug protection enabled</td>
</tr>
<tr>
<td></td>
<td>10: Reserved</td>
</tr>
<tr>
<td></td>
<td>11: Reserved</td>
</tr>
<tr>
<td>3–2</td>
<td>Access control of memory region-1</td>
</tr>
<tr>
<td>M7_APC_AC_R1_CTRL</td>
<td>00: No access protection</td>
</tr>
<tr>
<td></td>
<td>01: M7 debug protection enabled</td>
</tr>
<tr>
<td></td>
<td>10: Reserved</td>
</tr>
<tr>
<td></td>
<td>11: Reserved</td>
</tr>
<tr>
<td>M7_APC_AC_R0_CTRL</td>
<td>Access control of memory region-0</td>
</tr>
<tr>
<td></td>
<td>00: No access protection</td>
</tr>
<tr>
<td></td>
<td>01: M7 debug protection enabled</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_GPR_GPR11 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 11.4.13 GPR12 General Purpose Register (IOMUXC_GPR_GPR12)

**GPR Register**

Address: 400A_C000h base + 30h offset = 400A_C030h

---

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–7</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–0</td>
<td>Reserved</td>
<td>FLEXIO3_IPG_DOZE, FLEXIO3_IPG_STOP_MODE, ACMP_IPG_DOZE, ACMP_IPG_STOP_MODE, FLEXIO2_IPG_DOZE, FLEXIO2_IPG_STOP_MODE, FLEXIO1_IPG_DOZE, FLEXIO1_IPG_STOP_MODE, FLEXIO0_IPG_DOZE, FLEXIO0_IPG_STOP_MODE</td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

---

### IOMUXC_GPR_GPR12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–7-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>6 FLEXIO3_IPG_DOZE</td>
<td>FLEXIO3 ipg_doze mode</td>
</tr>
<tr>
<td>0</td>
<td>FLEXIO3 is not in doze mode</td>
</tr>
<tr>
<td>1</td>
<td>FLEXIO3 is in doze mode</td>
</tr>
<tr>
<td>5 FLEXIO3_IPG_STOP_MODE</td>
<td>FlexIo3 stop mode selection. Cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>FlexIO3 is functional in Stop mode.</td>
</tr>
<tr>
<td>1</td>
<td>When this bit is equal to 1'b1 and ipg_stop is asserted, FlexIO3 is not functional in Stop mode.</td>
</tr>
<tr>
<td>4 ACMP_IPG_STOP_MODE</td>
<td>ACMP stop mode selection. Cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>ACMP is functional in Stop mode.</td>
</tr>
<tr>
<td>1</td>
<td>When this bit is equal to 1'b1 and ipg_stop is asserted, ACMP is not functional in Stop mode.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_GPR_GPR12 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3 FLEXIO2_IPG_DOZE</td>
<td>FLEXIO2 ipg_doze mode</td>
</tr>
<tr>
<td>0</td>
<td>FLEXIO2 is not in doze mode</td>
</tr>
<tr>
<td>1</td>
<td>FLEXIO2 is in doze mode</td>
</tr>
<tr>
<td>2 FLEXIO2_IPG_STOP_MODE</td>
<td>FlexIO2 stop mode selection. Cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>FlexIO2 is functional in Stop mode.</td>
</tr>
<tr>
<td>1</td>
<td>When this bit is equal to 1'b1 and ipg_stop is asserted, FlexIO2 is not functional in Stop mode.</td>
</tr>
<tr>
<td>1 FLEXIO1_IPG_DOZE</td>
<td>FLEXIO1 ipg_doze mode</td>
</tr>
<tr>
<td>0</td>
<td>FLEXIO1 is not in doze mode</td>
</tr>
<tr>
<td>1</td>
<td>FLEXIO1 is in doze mode</td>
</tr>
<tr>
<td>0 FLEXIO1_IPG_STOP_MODE</td>
<td>FlexIO1 stop mode selection. Cannot change when ipg_stop is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>FlexIO1 is functional in Stop mode.</td>
</tr>
<tr>
<td>1</td>
<td>When this bit is equal to 1'b1 and ipg_stop is asserted, FlexIO1 is not functional in Stop mode.</td>
</tr>
</tbody>
</table>
11.4.14  GPR13 General Purpose Register (IOMUXC_GPR_GPR13)

GPR Register

Address: 400A_C000h base + 34h offset = 400A_C034h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset  0  0  0  0  0  0  0  0  0  0  0  0  0  0  0  0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset  0  0  0  0  0  0  0  0  0  0  0  0  0  0  0  0

- **Reserved**
- **CACHE_USB**
- **CACHE_ENET**
- **CANFD_STOP_REQ**
- **AWCACHE_USDHC**
- **ARCACHE_USDHC**

**Bit descriptions:**
- R: Readable
- W: Writable
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–21</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>CANFD stop acknowledge.</td>
</tr>
<tr>
<td>CANFD_STOP_ACK</td>
<td>0  CANFD stop acknowledge is not asserted</td>
</tr>
<tr>
<td></td>
<td>1  CANFD stop acknowledge is asserted</td>
</tr>
<tr>
<td>19–14</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>USB block cacheable attribute value of AXI transactions</td>
</tr>
<tr>
<td>CACHE_USB</td>
<td>0  Cacheable attribute is off for read/write transactions.</td>
</tr>
<tr>
<td></td>
<td>1  Cacheable attribute is on for read/write transactions.</td>
</tr>
<tr>
<td>12–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>ENET block cacheable attribute value of AXI transactions</td>
</tr>
<tr>
<td>CACHE_ENET</td>
<td>0  Cacheable attribute is off for read/write transactions.</td>
</tr>
<tr>
<td></td>
<td>1  Cacheable attribute is on for read/write transactions.</td>
</tr>
<tr>
<td>6–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>CANFD stop request.</td>
</tr>
<tr>
<td>CANFD_STOP_REQ</td>
<td>0  stop request off</td>
</tr>
<tr>
<td></td>
<td>1  stop request on</td>
</tr>
<tr>
<td>3–2</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>uSDHC block cacheable attribute value of AXI write transactions</td>
</tr>
<tr>
<td>AWCACHE_USDH</td>
<td>0  Cacheable attribute is off for write transactions.</td>
</tr>
<tr>
<td></td>
<td>1  Cacheable attribute is on for write transactions.</td>
</tr>
<tr>
<td>0</td>
<td>uSDHC block cacheable attribute value of AXI read transactions</td>
</tr>
<tr>
<td>ARCACHE_USDH</td>
<td>0  Cacheable attribute is off for read transactions.</td>
</tr>
<tr>
<td></td>
<td>1  Cacheable attribute is on for read transactions.</td>
</tr>
</tbody>
</table>
11.4.15 GPR14 General Purpose Register (IOMUXC_GPR_GPR14)

GPR Register

Address: 400A_C000h base + 38h offset = 400A_C038h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>23–20 CM7_CFGDTCMSZ</td>
<td>DTCM total size configuration</td>
</tr>
<tr>
<td>0000</td>
<td>0 KB (No DTCM)</td>
</tr>
<tr>
<td>0011</td>
<td>4 KB</td>
</tr>
<tr>
<td>0100</td>
<td>8 KB</td>
</tr>
<tr>
<td>0101</td>
<td>16 KB</td>
</tr>
<tr>
<td>0110</td>
<td>32 KB</td>
</tr>
<tr>
<td>0111</td>
<td>64 KB</td>
</tr>
<tr>
<td>1000</td>
<td>128 KB</td>
</tr>
<tr>
<td>1001</td>
<td>256 KB</td>
</tr>
<tr>
<td>1010</td>
<td>512 KB</td>
</tr>
<tr>
<td>other</td>
<td>reserved</td>
</tr>
<tr>
<td>19–16 CM7_CFGITCMSZ</td>
<td>ITCM total size configuration</td>
</tr>
<tr>
<td>0000</td>
<td>0 KB (No ITCM)</td>
</tr>
<tr>
<td>0011</td>
<td>4 KB</td>
</tr>
<tr>
<td>0100</td>
<td>8 KB</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0101</td>
<td>16 KB</td>
</tr>
<tr>
<td>0110</td>
<td>32 KB</td>
</tr>
<tr>
<td>0111</td>
<td>64 KB</td>
</tr>
<tr>
<td>1000</td>
<td>128 KB</td>
</tr>
<tr>
<td>1001</td>
<td>256 KB</td>
</tr>
<tr>
<td>1010</td>
<td>512 KB</td>
</tr>
<tr>
<td>other</td>
<td>reserved</td>
</tr>
<tr>
<td>15–12</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>11</td>
<td>ACMP4 sample lv source select</td>
</tr>
<tr>
<td>0</td>
<td>select XBAR output</td>
</tr>
<tr>
<td>1</td>
<td>select synced sample lv</td>
</tr>
<tr>
<td>10</td>
<td>ACMP3 sample lv source select</td>
</tr>
<tr>
<td>0</td>
<td>select XBAR output</td>
</tr>
<tr>
<td>1</td>
<td>select synced sample lv</td>
</tr>
<tr>
<td>9</td>
<td>ACMP2 sample lv source select</td>
</tr>
<tr>
<td>0</td>
<td>select XBAR output</td>
</tr>
<tr>
<td>1</td>
<td>select synced sample lv</td>
</tr>
<tr>
<td>8</td>
<td>ACMP1 sample lv source select</td>
</tr>
<tr>
<td>0</td>
<td>select XBAR output</td>
</tr>
<tr>
<td>1</td>
<td>select synced sample lv</td>
</tr>
<tr>
<td>7</td>
<td>increases ACMP4 internal bias current by 30%</td>
</tr>
<tr>
<td>0</td>
<td>no increase</td>
</tr>
<tr>
<td>1</td>
<td>increases</td>
</tr>
<tr>
<td>6</td>
<td>increases ACMP3 internal bias current by 30%</td>
</tr>
<tr>
<td>0</td>
<td>no increase</td>
</tr>
<tr>
<td>1</td>
<td>increases</td>
</tr>
<tr>
<td>5</td>
<td>increases ACMP2 internal bias current by 30%</td>
</tr>
<tr>
<td>0</td>
<td>no increase</td>
</tr>
<tr>
<td>1</td>
<td>increases</td>
</tr>
<tr>
<td>4</td>
<td>increases ACMP1 internal bias current by 30%</td>
</tr>
<tr>
<td>0</td>
<td>no increase</td>
</tr>
<tr>
<td>1</td>
<td>increases</td>
</tr>
<tr>
<td>3</td>
<td>reduces ACMP4 internal bias current by 30%</td>
</tr>
<tr>
<td>0</td>
<td>no reduce</td>
</tr>
<tr>
<td>1</td>
<td>reduces</td>
</tr>
<tr>
<td>2</td>
<td>reduces ACMP3 internal bias current by 30%</td>
</tr>
<tr>
<td>0</td>
<td>no reduce</td>
</tr>
<tr>
<td>1</td>
<td>reduces</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
IOMUXC_GPR_GPR14 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 ACMP2_CMP_IGEN_TRIM_DN, 0 no reduce, 1 reduces</td>
<td>reduces ACMP2 internal bias current by 30%</td>
</tr>
<tr>
<td>0 ACMP1_CMP_IGEN_TRIM_DN, 0 no reduce, 1 reduces</td>
<td>reduces ACMP1 internal bias current by 30%</td>
</tr>
</tbody>
</table>

11.4.16 GPR15 General Purpose Register (IOMUXC_GPR_GPR15)

GPR Register

Address: 400A_C000h base + 3Ch offset = 400A_C03Ch

IOMUXC_GPR_GPR15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

This field is reserved.
General purpose bits to be used by SoC integration. Bit field type: DEFAULT
11.4.17 GPR16 General Purpose Register (IOMUXC_GPR_GPR16)

GPR Register

Address: 400A_C000h base + 40h offset = 400A_C040h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–7 CM7_INIT_VTOR</td>
<td>Vector table offset register out of reset. See the Arm v7-M Architecture Reference Manual for more information about the vector table offset register (VTOR).</td>
</tr>
<tr>
<td>6–3 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>2 FLEXRAM_BANK_CFG_SEL</td>
<td>FlexRAM bank config source select</td>
</tr>
<tr>
<td></td>
<td>0 use fuse value to config</td>
</tr>
<tr>
<td></td>
<td>1 use FLEXRAM_BANK_CFG to config</td>
</tr>
<tr>
<td>1 INIT_DTCM_EN</td>
<td>DTCM enable initialization out of reset.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> When a TCM is enabled, the corresponding CFG*TCMSZ register must NOT be set to 0'b0000</td>
</tr>
<tr>
<td></td>
<td>0 DTCM is disabled</td>
</tr>
<tr>
<td></td>
<td>1 DTCM is enabled</td>
</tr>
<tr>
<td>0 INIT_ITCM_EN</td>
<td>ITCM enable initialization out of reset.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> When a TCM is enabled, the corresponding CFG*TCMSZ register must NOT be set to 0'b0000</td>
</tr>
<tr>
<td></td>
<td>0 ITCM is disabled</td>
</tr>
<tr>
<td></td>
<td>1 ITCM is enabled</td>
</tr>
</tbody>
</table>
11.4.18  GPR17 General Purpose Register  
(IOMUXC_GPR_GPR17)

GPR Register

Address: 400A_C000h base + 44h offset = 400A_C044h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXRAM_BANK_CFG</td>
<td>FlexRAM bank config value</td>
</tr>
<tr>
<td>GPR_FLEXRAM_BANK_CFG[2n+1 : 2n], where n = 0, 1, ..., 15</td>
<td></td>
</tr>
<tr>
<td>• 00: RAM bank n is not used</td>
<td></td>
</tr>
<tr>
<td>• 01: RAM bank n is OCRAM</td>
<td></td>
</tr>
<tr>
<td>• 10: RAM bank n is DTCM</td>
<td></td>
</tr>
<tr>
<td>• 11: RAM bank n is ITCM</td>
<td></td>
</tr>
</tbody>
</table>

11.4.19  GPR18 General Purpose Register  
(IOMUXC_GPR_GPR18)

GPR Register

Address: 400A_C000h base + 48h offset = 400A_C048h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M7_APC_AC_R0_BOT</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M7_APC_AC_R0_BOT</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
NXPs
### IOMUXC GPR GPR18 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>APC end address of memory region-0</td>
</tr>
</tbody>
</table>
| 2–1   | This field is reserved.  
|       | Reserved |
| 0     | lock M7_APC_AC_R0_BOT field for changes. This is a sticky field, once set it cannot be cleared (only by reset).  
|       | 0 Register field [31:1] is not locked  
|       | 1 Register field [31:1] is locked (read access only) |

### 11.4.20 GPR19 General Purpose Register (IOMUXC_GPR_GPR19)

#### GPR Register

Address: 400A_C000h base + 4Ch offset = 400A_C04Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_GPR_GPR19 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>APC start address of memory region-0</td>
</tr>
</tbody>
</table>
| 2–1   | This field is reserved.  
|       | Reserved |

Table continues on the next page...
IOMUXC_GPR_GPR19 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>-lock M7_APC_AC_R0_TOP field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td>0</td>
<td>Register field [31:1] is not locked</td>
</tr>
<tr>
<td>1</td>
<td>Register field [31:1] is locked (read access only)</td>
</tr>
</tbody>
</table>

11.4.21 GPR20 General Purpose Register
(IOMUXC_GPR_GPR20)

GPR Register

Address: 400A_C000h base + 50h offset = 400A_C050h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>M7_APC_AC_R1_BOT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>LOCK_M7_APC_AC_R1_BOT</td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_GPR_GPR20 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>APC end address of memory region-1</td>
</tr>
<tr>
<td>M7_APC_AC_R1_BOT</td>
<td></td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>-</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>lock M7_APC_AC_R1_BOT field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td>LOCK_M7_APC_AC_R1_BOT</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Register field [31:1] is not locked</td>
</tr>
<tr>
<td>1</td>
<td>Register field [31:1] is locked (read access only)</td>
</tr>
</tbody>
</table>
11.4.22  GPR21 General Purpose Register
(IOMUXC_GPR_GPR21)

GPR Register

Address: \( 400A\_C000h \) base + 54h offset = 400A_C054h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>M7_APC_AC_R1_TOP</td>
<td>APC start address of memory region-1</td>
</tr>
<tr>
<td>15-1</td>
<td>LOCK_M7_APC_AC_R1_TOP</td>
<td>lock M7_APC_AC_R1_TOP field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
</tbody>
</table>
| 0   |           | 0: Register field [31:1] is not locked  
      |           | 1: Register field [31:1] is locked (read access only) |

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16-0</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
11.4.23 GPR22 General Purpose Register (IOMUXC_GPR_GPR22)

GPR Register

Address: 400A_C000h base + 58h offset = 400A_C058h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_GPR_GPR22 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>APC end address of memory region-2</td>
</tr>
<tr>
<td>M7_APC_AC_R2_BOT</td>
<td>Reserved</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>lock M7_APC_AC_R2_BOT field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td>LOCK_M7_APC_AC_R2_BOT</td>
<td>0: Register field [31:1] is not locked</td>
</tr>
<tr>
<td></td>
<td>1: Register field [31:1] is locked (read access only)</td>
</tr>
</tbody>
</table>
11.4.24  GPR23 General Purpose Register  
(IOMUXC_GPR_GPR23)

GPR Register

Address: 400A_C000h base + 5Ch offset = 400A_C05Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>M7_APC_AC_R2_TOP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>LOCK_M7_APC_AC_R2_TOP</td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_GPR_GPR23 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3 M7_APC_AC_R2_TOP</td>
<td>APC start address of memory region-2</td>
</tr>
<tr>
<td>2–1 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0 LOCK_M7_APC_AC_R2_TOP</td>
<td>lock M7_APC_AC_R2_TOP field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td>0 Register field [31:1] is not locked</td>
<td></td>
</tr>
<tr>
<td>1 Register field [31:1] is locked (read access only)</td>
<td></td>
</tr>
</tbody>
</table>
11.4.25 GPR24 General Purpose Register (IOMUXC_GPR_GPR24)

GPR Register

Address: 400A_C000h base + 60h offset = 400A_C060h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3 M7_APC_AC_R3_BOT</td>
<td>APC end address of memory region-3</td>
</tr>
<tr>
<td>2–1 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0 LOCK_M7_APC_AC_R3_BOT</td>
<td>lock M7_APC_AC_R3_BOT field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td></td>
<td>0 Register field [31:1] is not locked</td>
</tr>
<tr>
<td></td>
<td>1 Register field [31:1] is locked (read access only)</td>
</tr>
</tbody>
</table>

IOMUXC_GPR_GPR24 field descriptions
11.4.26  GPR25 General Purpose Register  
(IOMUXC_GPR_GPR25)

GPR Register

Address: 400A_C000h base + 64h offset = 400A_C064h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>M7_APC_AC_R3_TOP</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>M7_APC_AC_R3_TOP</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>LOCK_M7_APC_AC_R3_TOP</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_GPR_GPR25 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3 M7_APC_AC_R3_TOP</td>
<td>APC start address of memory region-3</td>
</tr>
<tr>
<td>2–1 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0 LOCK_M7_APC_AC_R3_TOP</td>
<td>lock M7_APC_AC_R3_TOP field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td></td>
<td>0 Register field [31:1] is not locked</td>
</tr>
<tr>
<td></td>
<td>1 Register field [31:1] is locked (read access only)</td>
</tr>
</tbody>
</table>
11.4.27 GPR26 General Purpose Register
(IOMUXC_GPR_GPR26)

GPR Register

Address: 400A_C000h base + 68h offset = 400A_C068h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | W  | GPIO_MUX1_GPIO_SEL |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

IOMUXC_GPR_GPR26 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_MUX1_GPIO_SEL    | GPIO1 and GPIO6 share same IO MUX function, GPIO_MUX1 selects one GPIO function. This register controls GPIO_MUX1 to select GPIO1 or GPIO6. For bit \( n \),  
|                       | • 0: GPIO1\([n]\) is selected;  
|                       | • 1: GPIO6\([n]\) is selected.                                                                                                                                                                                                                                                                                                           |

11.4.28 GPR27 General Purpose Register
(IOMUXC_GPR_GPR27)

GPR Register

Address: 400A_C000h base + 6Ch offset = 400A_C06Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | W  | GPIO_MUX2_GPIO_SEL |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

IOMUXC_GPR_GPR27 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_MUX2_GPIO_SEL    | GPIO2 and GPIO7 share same IO MUX function, GPIO_MUX2 selects one GPIO function. This register controls GPIO_MUX2 to select GPIO2 or GPIO7. For bit \( n \),  
|                       | • 0: GPIO2\([n]\) is selected;  
|                       | • 1: GPIO7\([n]\) is selected.                                                                                                                                                                                                                                                                                                           |
11.4.29 GPR28 General Purpose Register  
(IOMUXC_GPR_GPR28)

GPR Register

Address: 400A_C000h base + 70h offset = 400A_C070h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W   | GPIO_MUX3_GPIO_SEL |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**IOMUXC_GPR_GPR28 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_MUX3_GPIO_SEL | GPIO3 and GPIO8 share same IO MUX function, GPIO_MUX3 selects one GPIO function. This register controls GPIO_MUX3 to select GPIO3 or GPIO8. For bit n,  
• 0: GPIO3[n] is selected;  
• 1: GPIO8[n] is selected. |

11.4.30 GPR29 General Purpose Register  
(IOMUXC_GPR_GPR29)

GPR Register

Address: 400A_C000h base + 74h offset = 400A_C074h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W   | GPIO_MUX4_GPIO_SEL |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**IOMUXC_GPR_GPR29 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| GPIO_MUX4_GPIO_SEL | GPIO4 and GPIO9 share same IO MUX function, GPIO_MUX4 selects one GPIO function. This register controls GPIO_MUX4 to select GPIO4 or GPIO9. For bit n,  
• 0: GPIO4[n] is selected;  
• 1: GPIO9[n] is selected. |
11.4.31  GPR30 General Purpose Register  
(IOMUXC_GPR_GPR30)

GPR Register

Address: 400A_C000h base + 78h offset = 400A_C078h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R/W | R  | FLEXSPI_REMAP_ADDR_START | Reserved |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_GPR_GPR30 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12</td>
<td>FLEXSPI_REMAP_ADDR_START</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

11.4.32  GPR31 General Purpose Register  
(IOMUXC_GPR_GPR31)

GPR Register

Address: 400A_C000h base + 7Ch offset = 400A_C07Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R/W | R  | FLEXSPI_REMAP_ADDR_END  | Reserved |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_GPR_GPR31 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12</td>
<td>FLEXSPI_REMAP_ADDR_END</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>
11.4.33  GPR32 General Purpose Register  
(IOMUXC_GPR_GPR32)

GPR Register

Address: 400A_C000h base + 80h offset = 400A_C080h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| W   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_GPR_GPR32 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12 FLEXSPI_REMAP_ADDR_</td>
<td>Offset address of flexspi1 and flexspi2. When ADDR_START[31:12] ≦ Addr_i[31:12] ≦ ADDR_END[31:12], remapped address Addr_o = Addr_i[31:12] + {OFFSET[31:12],12'h0}; Otherwise Addr_o = Addr_i.</td>
</tr>
<tr>
<td>OFFSET</td>
<td></td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

11.4.34  GPR33 General Purpose Register  
(IOMUXC_GPR_GPR33)

GPR Register

Address: 400A_C000h base + 84h offset = 400A_C084h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| W   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1

**IOMUXC GPR Memory Map/Register Definition**
i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
## IOMUXC_GPR_GPR33 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–17</td>
<td>Lock OCRAM2_TZ_ADDR field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td></td>
<td>0 Field is not locked</td>
</tr>
<tr>
<td></td>
<td>1 Field is locked (read access only)</td>
</tr>
<tr>
<td>16</td>
<td>Lock OCRAM2_TZ_EN field for changes. This is a sticky field, once set it cannot be cleared (only by reset).</td>
</tr>
<tr>
<td></td>
<td>0 Field is not locked</td>
</tr>
<tr>
<td></td>
<td>1 Field is locked (read access only)</td>
</tr>
<tr>
<td>15–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–1</td>
<td>OCRAM2 TrustZone (TZ) start address. This is the start address of the secure memory region within the OCRAM2 memory space is 4 KB granularity. The start address affects the OCRAM2 transactions only if OCRAM2_TZ_EN bit is set. The OCRAMe TZ ENDADDR is not configurable and is set to the end of OCRAM2 memory space.</td>
</tr>
<tr>
<td>0</td>
<td>OCRAM2 TrustZone (TZ) enable.</td>
</tr>
<tr>
<td></td>
<td>0 The TrustZone feature is disabled. Entire OCRAM2 space is available for all access types (secure/non-secure/user/supervisor).</td>
</tr>
<tr>
<td></td>
<td>1 The TrustZone feature is enabled. Access to address in the range specified by [ENDADDR:STARTADDR] follows the execution mode access policy described in CSU chapter.</td>
</tr>
</tbody>
</table>
11.4.35  GPR34 General Purpose Register  
(IOMUXC_GPR_GPR34)

GPR Register

Address: 400A_C000h base + 88h offset = 400A_C088h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>SIP_TEST_MUX_QSPI_SIP_EN</td>
</tr>
<tr>
<td>7–0</td>
<td>SIP_TEST_MUX_BOOT_PIN_SEL</td>
</tr>
</tbody>
</table>

IOMUXC_GPR_GPR34 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>SIP_TEST_MUX_QSPI_SIP_EN</td>
</tr>
<tr>
<td>7–0</td>
<td>SIP_TEST_MUX_BOOT_PIN_SEL</td>
</tr>
</tbody>
</table>
| 8 | Enable SIP_TEST_MUX  
| 0 | SIP_TEST_MUX is disabled  
| 1 | SIP_TEST_MUX is enabled |
| 7–0 | Boot Pin select in SIP_TEST_MUX  
| This field is active only when SIP_TEST_MUX_QSPI_SIP_EN is 1. |

11.5  IOMUXC SNVS Memory Map/Register Definition
## IOMUXC_SNVS memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400A_8000</td>
<td>SW_MUX_CTL_PAD_WAKEUP SW MUX Control Register (IOMUXC_SNVS_SW_MUX_CTL_PAD_WAKEUP)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.5.1/382</td>
</tr>
<tr>
<td>400A_8004</td>
<td>SW_MUX_CTL_PAD_PMIC_ON_REQ SW MUX Control Register (IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_ON_REQ)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.5.2/383</td>
</tr>
<tr>
<td>400A_8008</td>
<td>SW_MUX_CTL_PAD_PMIC_STBY_REQ SW MUX Control Register (IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_STBY_REQ)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.5.3/384</td>
</tr>
<tr>
<td>400A_800C</td>
<td>SW_PAD_CTL_PAD_TEST_MODE SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_TEST_MODE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_30A0h</td>
<td>11.5.4/385</td>
</tr>
<tr>
<td>400A_8010</td>
<td>SW_PAD_CTL_PAD_POR_B SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_POR_B)</td>
<td>32</td>
<td>R/W</td>
<td>0001_B0A0h</td>
<td>11.5.5/388</td>
</tr>
<tr>
<td>400A_8014</td>
<td>SW_PAD_CTL_PAD_ONOFF SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_ONOFF)</td>
<td>32</td>
<td>R/W</td>
<td>0001_B0A0h</td>
<td>11.5.6/390</td>
</tr>
<tr>
<td>400A_8018</td>
<td>SW_PAD_CTL_PAD_WAKEUP SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_WAKEUP)</td>
<td>32</td>
<td>R/W</td>
<td>0001_B0A0h</td>
<td>11.5.7/392</td>
</tr>
<tr>
<td>400A_801C</td>
<td>SW_PAD_CTL_PAD_PMIC_ON_REQ SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_ON_REQ)</td>
<td>32</td>
<td>R/W</td>
<td>0000_B8A0h</td>
<td>11.5.8/395</td>
</tr>
<tr>
<td>400A_8020</td>
<td>SW_PAD_CTL_PAD_PMIC_STBY_REQ SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_STBY_REQ)</td>
<td>32</td>
<td>R/W</td>
<td>0000_A0A0h</td>
<td>11.5.9/397</td>
</tr>
</tbody>
</table>
11.5.1 SW_MUX_CTL_PAD_WAKEUP SW MUX Control Register (IOMUXC_SNVS_SW_MUX_CTL_PAD_WAKEUP)

SW_MUX_CTL Register

Address: 400A_8000h base + 0h offset = 400A_8000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1

IOMUXC_SNVS_SW_MUX_CTL_PAD_WAKEUP field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>4 SION</td>
<td>Software Input On Field. Force the selected mux mode to Input path no matter</td>
</tr>
<tr>
<td></td>
<td>what the MUX_MODE functionality is.</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode to Input path no matter what the MUX_MODE</td>
</tr>
<tr>
<td></td>
<td>functionality is.</td>
</tr>
<tr>
<td></td>
<td>It is used when the direction of a pin defined by the selected alternative</td>
</tr>
<tr>
<td></td>
<td>function is an output, but the real logic value on a pin is needed.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad WAKEUP</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select 1 of 2 iomux modes to be used for pad: WAKEUP.</td>
</tr>
<tr>
<td></td>
<td>Note: Some functions are available on multiple pins. A given function</td>
</tr>
<tr>
<td></td>
<td>should not be selected for more than one pin.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SNVS_SW_MUX_CTL_PAD_WAKEUP field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO5_IO00 of instance: gpio5</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: NMI of instance: CM7</td>
</tr>
</tbody>
</table>

11.5.2 SW_MUX_CTL_PAD_PMIC_ON_REQ SW MUX Control Register
(IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_ON_REQ)

SW_MUX_CTL Register

Address: 400A_8000h base + 4h offset = 400A_8004h

Table continues on the next page...

IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_ON_REQ field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode to Input path no matter what the MUX_MODE functionality is. It is used when the direction of a pin defined by the selected alternative function is an output, but the real logic value on a pin is needed.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_ON_REQ field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad PMIC_ON_REQ</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

#### MUX_MODE

MUX Mode Select Field.

Select 1 of 2 iOMUX modes to be used for pad: PMIC_ON_REQ.

**Note:** Some functions are available on multiple pins. A given function should not be selected for more than one pin.

- **000** ALT0 — Select mux mode: ALT0 mux port: SNVS_PMIC_ON_REQ of instance: snvs
- **101** ALT5 — Select mux mode: ALT5 mux port: GPIO5_IO01 of instance: gpio5

---

### 11.5.3 SW_MUX_CTL_PAD_PMIC_STBY_REQ SW MUX Control Register

( IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_STBY_REQ )

**SW_MUX_CTL Register**

Address: 400A_8000h base + 8h offset = 400A_8008h

---

```
<table>
<thead>
<tr>
<th>Bit 31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bit 15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

Reserved

Reserved

SION

Reserved

MUX_MODE
### IOMUXC_SNVS_SWMUX_CTL_PAD_PMIC_STBY_REQ field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 4 SION | Software Input On Field. Force the selected mux mode to Input path no matter what the MUX_MODE functionality is. It is used when the direction of a pin defined by the selected alternative function is an output, but the real logic value on a pin is needed.  
1 ENABLED — Force input path of pad PMIC_STBY_REQ  
0 DISABLED — Input Path is determined by functionality |
| 3 | This field is reserved. Reserved |

#### MUX_MODE

MUX Mode Select Field. 
Select 1 of 2 iomux modes to be used for pad: PMIC_STBY_REQ.

**Note:** Some functions are available on multiple pins. A given function should not be selected for more than one pin.

- 000 ALT0 — Select mux mode: ALT0 mux port: CCM_PMIC_STBY_REQ of instance: ccm
- 101 ALT5 — Select mux mode: ALT5 mux port: GPIO5_IO02 of instance: gpio5

### 11.5.4 SW_PAD_CTL_PAD_TEST_MODE SW Pad Control Register (IOMUXC_SNVS_SWMUX_CTL_PAD_TEST_MODE)

**SW_PAD_CTL Register**

Address: 400A_8000h base + Ch offset = 400A_800Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset:** 0 0 1 1 0 0 0 0 1 0 1 0 0 0 0 0

#### IOMUXC_SNVS_SWMUX_CTL_PAD_TEST_MODE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
### IOMUXC_SNVS_SW_PAD_CTL_PAD_TEST_MODE field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>16</strong> HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: TEST_MODE</td>
</tr>
<tr>
<td></td>
<td>The hysteresis (HYS) bit controls whether a pin acts as a Schmitt trigger, which is a comparator remembering its last input state (hysteresis).</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled (CMOS input)</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled (Schmitt Trigger input)</td>
</tr>
<tr>
<td><strong>15–14</strong> PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Controls signals to select pull-up or pull-down internal resistance strength.</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: TEST_MODE</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td><strong>13</strong> PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Control signal to enable internal pull-up/down resistors or pad keeper functionality.</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: TEST_MODE</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keep the previous output value when the output driver is disabled.</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull-up or pull-down (determined by PUS field).</td>
</tr>
<tr>
<td><strong>12</strong> PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: TEST_MODE</td>
</tr>
<tr>
<td></td>
<td>The pull/keeper function for a given pin is controlled by the PKE, PUE and PUS bits. The pull/keeper can be enabled by the pull/keep enable (PKE) bit. When the pull/keeper is enabled, the PUE (pull-up enable) bit selects either a pull-up/pull-down resistor on the output or a keeper device (keep the previous output value).</td>
</tr>
<tr>
<td></td>
<td>When the pull/keeper is disabled, PUE and PUS have no functionality.</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_PullKeeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_PullKeeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td><strong>11</strong> ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: TEST_MODE</td>
</tr>
<tr>
<td></td>
<td>If set to 1, the output driver drives only logic 0. The drain of the internal transistor is open. It means that logic 1 has to be driven by an external component. This option is essential if connection between the pad and an external component is bi-directional. If ODE = 0, then the output driver drives logic 1 and logic 0.</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled (Output is CMOS)</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled (Output is Open Drain)</td>
</tr>
<tr>
<td><strong>10–8</strong></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td><strong>7–6</strong> SPEED</td>
<td>Speed Field</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SNVS_SW_PAD_CTL_PAD_TEST_MODE field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>SPEED</strong></td>
<td>is a selectable bit field that sets electrical characteristics of a pin in a given frequency range. This field provides additional 2-bit slew rate control. These options can either increase the output driver current in the higher frequency range, or reduce the switching noise in the lower frequency range. The operational frequency on GPIO pads is dependent on slew rate (SRE), speed (SPEED), and supply voltage (OVDD). See Operating Frequency table in the GPIO block guide for more details.</td>
</tr>
<tr>
<td><strong>10 Medium</strong></td>
<td>100MHz</td>
</tr>
<tr>
<td><strong>5–3 DSE</strong></td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: TEST_MODE</td>
</tr>
<tr>
<td></td>
<td>The drive strength enable (DSE) can be explained as series resistance between an ideal driver’s output and its load. To achieve maximal transferred power, the impedance of the driver has to match the load impedance.</td>
</tr>
<tr>
<td></td>
<td>Note: Typical values provided, please see GPIO spec for full impedance range.</td>
</tr>
<tr>
<td><strong>000 DSE_0</strong></td>
<td>HI-Z</td>
</tr>
<tr>
<td><strong>001 DSE_1</strong></td>
<td>Dual/Single voltage: 262/260 Ohm @ 1.8V, 247/157 Ohm @ 3.3V</td>
</tr>
<tr>
<td><strong>010 DSE_2</strong></td>
<td>Dual/Single voltage: 134/130 Ohm @ 1.8V, 126/78 Ohm @ 3.3V</td>
</tr>
<tr>
<td><strong>011 DSE_3</strong></td>
<td>Dual/Single voltage: 88/88 Ohm @ 1.8V, 84/53 Ohm @ 3.3V</td>
</tr>
<tr>
<td><strong>100 DSE_4</strong></td>
<td>Dual/Single voltage: 62/65 Ohm @ 1.8V, 57/39 Ohm @ 3.3V</td>
</tr>
<tr>
<td><strong>101 DSE_5</strong></td>
<td>Dual/Single voltage: 51/52 Ohm @ 1.8V, 47/32 Ohm @ 3.3V</td>
</tr>
<tr>
<td><strong>110 DSE_6</strong></td>
<td>Dual/Single voltage: 43/43 Ohm @ 1.8V, 40/26 Ohm @ 3.3V</td>
</tr>
<tr>
<td><strong>111 DSE_7</strong></td>
<td>Dual/Single voltage: 37/37 Ohm @ 1.8V, 34/23 Ohm @ 3.3V</td>
</tr>
<tr>
<td><strong>2–1 -</strong></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td><strong>0 SRE</strong></td>
<td>Reserved</td>
</tr>
<tr>
<td><strong>SRE_0_Slow_Slew_Rate</strong></td>
<td>Slow Slew Rate</td>
</tr>
<tr>
<td><strong>SRE_1_Fast_Slew_Rate</strong></td>
<td>Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.5.5 SW_PAD_CTL_PAD_POR_B SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_POR_B)

SW_PAD_CTL Register

Address: 400A_8000h base + 10h offset = 400A_8010h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-17</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: POR_B</td>
</tr>
<tr>
<td></td>
<td></td>
<td>The hysteresis (HYS) bit controls whether a pin acts as a Schmitt trigger, which is a comparator remembering its last input state (hysteresis).</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled (CMOS input)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 HYS_1_Hysteresis_ENABLED — Hysteresis Enabled (Schmitt Trigger input)</td>
</tr>
<tr>
<td>15-14</td>
<td></td>
<td>PUS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Controls signals to select pull-up or pull-down internal resistance strength.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: POR_B</td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td>PUE</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Control signal to enable internal pull-up/down resistors or pad keeper functionality.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: POR_B</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 PUE_0_Keeper — Keep the previous output value when the output driver is disabled.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 PUE_1_Pull — Pull-up or pull-down (determined by PUS field).</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td>PKE</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: POR_B</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC_SNVS_SW_PAD_CTL_PAD_POR_B field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PKE_0_Pull_Keeper_Disabled</td>
<td>— Pull/Keeper Disabled</td>
</tr>
<tr>
<td>PKE_1_Pull_Keeper_Enabled</td>
<td>— Pull/Keeper Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ODE</th>
<th>Open Drain Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>ODE_0_Open_Drain_Disabled</td>
<td>— Open Drain Disabled (Output is CMOS)</td>
</tr>
<tr>
<td>ODE_1_Open_Drain_Enabled</td>
<td>— Open Drain Enabled (Output is Open Drain)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SPEED</th>
<th>Speed Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>Medium</td>
<td>— 100MHz</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>DSE</th>
<th>Drive Strength Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>DSE_0</td>
<td>— HI-Z</td>
</tr>
<tr>
<td>DSE_1</td>
<td>— Dual/Single voltage: 262/260 Ohm @ 1.8V, 247/157 Ohm @ 3.3V</td>
</tr>
<tr>
<td>DSE_2</td>
<td>— Dual/Single voltage: 134/130 Ohm @ 1.8V, 126/78 Ohm @ 3.3V</td>
</tr>
<tr>
<td>DSE_3</td>
<td>— Dual/Single voltage: 88/88 Ohm @ 1.8V, 84/53 Ohm @ 3.3V</td>
</tr>
<tr>
<td>DSE_4</td>
<td>— Dual/Single voltage: 62/65 Ohm @ 1.8V, 57/39 Ohm @ 3.3V</td>
</tr>
<tr>
<td>DSE_5</td>
<td>— Dual/Single voltage: 51/52 Ohm @ 1.8V, 47/32 Ohm @ 3.3V</td>
</tr>
<tr>
<td>DSE_6</td>
<td>— Dual/Single voltage: 43/43 Ohm @ 1.8V, 40/26 Ohm @ 3.3V</td>
</tr>
<tr>
<td>DSE_7</td>
<td>— Dual/Single voltage: 37/37 Ohm @ 1.8V, 34/23 Ohm @ 3.3V</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>Slew Rate Field</td>
<td>Select one out of next values for pad: POR_B</td>
</tr>
</tbody>
</table>

Note: Typical values provided, please see GPIO spec for full impedance range.
IOMUXC_SNVS_SW_PAD_CTL_PAD_POR_B field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

11.5.6 SW_PAD_CTL_PAD_ONOFF SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_ONOFF)

SW_PAD_CTL Register

Address: 400A_8000h base + 14h offset = 400A_8014h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SNVS_SW_PAD_CTL_PAD_ONOFF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: ONOFF</td>
</tr>
<tr>
<td></td>
<td>The hysteresis (HYS) bit controls whether a pin acts as a Schmitt trigger, which is a comparator remembering its last input state (hysteresis).</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled (CMOS input)</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled (Schmitt Trigger input)</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Controls signals to select pull-up or pull-down internal resistance strength.</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: ONOFF</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SNVS_SW_PAD_CTL_PAD_ONOFF field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
</tbody>
</table>
| 13 PUE | Pull / Keep Select Field  
Control signal to enable internal pull-up/down resistors or pad keeper functionality.  
Select one out of next values for pad: ONOFF  
0  **PUE_0_Keeper** — Keep the previous output value when the output driver is disabled.  
1  **PUE_1_Pull** — Pull-up or pull-down (determined by PUS field). |
| 12 PKE | Pull / Keep Enable Field  
Select one out of next values for pad: ONOFF  
The pull/keeper function for a given pin is controlled by the PKE, PUE and PUS bits. The pull/keeper can be enabled by the pull/keep enable (PKE) bit. When the pull/keeper is enabled, the PUE (pull-up enable) bit selects either a pull-up/pull-down resistor on the output or a keeper device (keep the previous output value).  
When the pull/keeper is disabled, PUE and PUS have no functionality.  
0  **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled  
1  **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled |
| 11 ODE | Open Drain Enable Field  
Select one out of next values for pad: ONOFF  
If set to 1, the output driver drives only logic 0. The drain of the internal transistor is open. It means that logic 1 has to be driven by an external component. This option is essential if connection between the pad and an external component is bi-directional. If ODE = 0, then the output driver drives logic 1 and logic 0.  
0  **ODE_0_Open_Drain_Disabled** — Open Drain Disabled (Output is CMOS)  
1  **ODE_1_Open_Drain_Enabled** — Open Drain Enabled (Output is Open Drain) |
| 10–8 - | This field is reserved.  
Reserved |
| 7–6 SPEED | Speed Field  
SPEED is a selectable bit field that sets electrical characteristics of a pin in a given frequency range. This field provides additional 2-bit slew rate control. These options can either increase the output driver current in the higher frequency range, or reduce the switching noise in the lower frequency range.  
The operational frequency on GPIO pads is dependent on slew rate (SRE), speed (SPEED), and supply voltage (OVDD). See Operating Frequency table in the GPIO block guide for more details.  
10  **Medium** — 100MHz |
| 5–3 DSE | Drive Strength Field  
Select one out of next values for pad: ONOFF  
The drive strength enable (DSE) can be explained as series resistance between an ideal driver’s output and its load. To achieve maximal transferred power, the impedance of the driver has to match the load impedance.  
Note: Typical values provided, please see GPIO spec for full impedance range.  
000  **DSE_0** — HI-Z  
001  **DSE_1** — Dual/Single voltage: 262/260 Ohm @ 1.8V, 247/157 Ohm @ 3.3V |

*Table continues on the next page...*
IOMUXC_SNVS_SW_PAD_CTL_PAD_ONOFF field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>DSE_2 — Dual/Single voltage: 134/130 Ohm @ 1.8V, 126/78 Ohm @ 3.3V</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3 — Dual/Single voltage: 88/88 Ohm @ 1.8V, 84/53 Ohm @ 3.3V</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4 — Dual/Single voltage: 62/65 Ohm @ 1.8V, 57/39 Ohm @ 3.3V</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5 — Dual/Single voltage: 51/52 Ohm @ 1.8V, 47/32 Ohm @ 3.3V</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6 — Dual/Single voltage: 43/43 Ohm @ 1.8V, 40/26 Ohm @ 3.3V</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7 — Dual/Single voltage: 37/37 Ohm @ 1.8V, 34/23 Ohm @ 3.3V</td>
</tr>
</tbody>
</table>

This field is reserved.
Reserved

0
SRE
Slew Rate Field
Select one out of next values for pad: ONOFF
This bitfield controls how fast the pin toggles between the two logic states. Since rapidly changing states consume more power and generate spikes, it should be enabled only when necessary.
The operational frequency on GPIO pads is dependent on slew rate (SRE), speed (SPEED), and supply voltage (OVDD). See Operating Frequency table in the GPIO block guide for more details.

0  SRE_0_Slow_Slew_Rate — Slow Slew Rate
1  SRE_1_Fast_Slew_Rate — Fast Slew Rate

11.5.7 SW_PAD_CTL_PAD_WAKEUP SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_WAKEUP)

SW_PAD_CTL Register

Address: 400A_8000h base + 18h offset = 400A_8018h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SPEED</td>
<td>DSE</td>
<td></td>
<td>SRE</td>
</tr>
<tr>
<td>W</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

16
HYS
Hyst. Enable Field
Select one out of next values for pad: WAKEUP

Table continues on the next page...
### IOMUXC_SNVS_SW_PAD_CTL_PAD_WAKEUP field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled (CMOS input)</td>
<td></td>
</tr>
<tr>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled (Schmitt Trigger input)</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>Controls signals to select pull-up or pull-down internal resistance strength.</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: WAKEUP</td>
<td></td>
</tr>
<tr>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
<td></td>
</tr>
<tr>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>Control signal to enable internal pull-up/down resistors or pad keeper functionality.</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: WAKEUP</td>
<td></td>
</tr>
<tr>
<td>0 PUE_0_Keeper — Keep the previous output value when the output driver is disabled.</td>
<td></td>
</tr>
<tr>
<td>1 PUE_1_Pull — Pull-up or pull-down (determined by PUS field).</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: WAKEUP</td>
<td></td>
</tr>
<tr>
<td>The pull/keeper function for a given pin is controlled by the PKE, PUE and PUS bits. The pull/keeper can be enabled by the pull/keep enable (PKE) bit. When the pull/keeper is enabled, the PUE (pull-up enable) bit selects either a pull-up/pull-down resistor on the output or a keeper device (keep the previous output value).</td>
<td></td>
</tr>
<tr>
<td>When the pull/keeper is disabled, PUE and PUS have no functionality.</td>
<td></td>
</tr>
<tr>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
<td></td>
</tr>
<tr>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: WAKEUP</td>
<td></td>
</tr>
<tr>
<td>If set to 1, the output driver drives only logic 0. The drain of the internal transistor is open. It means that logic 1 has to be driven by an external component. This option is essential if connection between the pad and an external component is bi-directional. If ODE = 0, then the output driver drives logic 1 and logic 0.</td>
<td></td>
</tr>
<tr>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled (Output is CMOS)</td>
<td></td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled (Output is Open Drain)</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td>SPEED is a selectable bit field that sets electrical characteristics of a pin in a given frequency range. This field provides additional 2-bit slew rate control. These options can either increase the output driver current in the higher frequency range, or reduce the switching noise in the lower frequency range.</td>
<td></td>
</tr>
<tr>
<td>The operational frequency on GPIO pads is dependent on slew rate (SRE), speed (SPEED), and supply voltage (OVDD). See Operating Frequency table in the GPIO block guide for more details.</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SNVS_SW_PAD_CTL_PAD_WAKEUP field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>Medium — 100MHz</td>
</tr>
</tbody>
</table>

#### Drive Strength Field

The drive strength enable (DSE) can be explained as series resistance between an ideal driver's output and its load. To achieve maximal transferred power, the impedance of the driver has to match the load impedance.

Note: Typical values provided, please see GPIO spec for full impedance range.

<table>
<thead>
<tr>
<th>DSE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>DSE.0 — HI-Z</td>
</tr>
<tr>
<td>001</td>
<td>DSE.1 — Dual/Single voltage: 262/260 Ohm @ 1.8V, 247/157 Ohm @ 3.3V</td>
</tr>
<tr>
<td>010</td>
<td>DSE.2 — Dual/Single voltage: 134/130 Ohm @ 1.8V, 126/78 Ohm @ 3.3V</td>
</tr>
<tr>
<td>011</td>
<td>DSE.3 — Dual/Single voltage: 88/88 Ohm @ 1.8V, 84/53 Ohm @ 3.3V</td>
</tr>
<tr>
<td>100</td>
<td>DSE.4 — Dual/Single voltage: 62/65 Ohm @ 1.8V, 57/39 Ohm @ 3.3V</td>
</tr>
<tr>
<td>101</td>
<td>DSE.5 — Dual/Single voltage: 51/52 Ohm @ 1.8V, 47/32 Ohm @ 3.3V</td>
</tr>
<tr>
<td>110</td>
<td>DSE.6 — Dual/Single voltage: 43/43 Ohm @ 1.8V, 40/26 Ohm @ 3.3V</td>
</tr>
<tr>
<td>111</td>
<td>DSE.7 — Dual/Single voltage: 37/37 Ohm @ 1.8V, 34/23 Ohm @ 3.3V</td>
</tr>
</tbody>
</table>

#### Slew Rate Field

This bitfield controls how fast the pin toggles between the two logic states. Since rapidly changing states consume more power and generate spikes, it should be enabled only when necessary.

The operational frequency on GPIO pads is dependent on slew rate (SRE), speed (SPEED), and supply voltage (OVDD). See Operating Frequency table in the GPIO block guide for more details.

<table>
<thead>
<tr>
<th>SRE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE.0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE.1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.5.8 SW_PAD_CTL_PAD_PMIC_ON_REQ SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_ON_REQ)

SW_PAD_CTL Register

Address: 400A_8000h base + 1Ch offset = 400A_801Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

| Bit | R | W | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|---|---|----|----|----|----|----|----|--|--|--|--|--|--|--|--|--|--|--|
|     | PUS | PUE | PKE | ODE | Reserved | SPEED | DSE | Reserved | SRE |
| Reset | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |

IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_ON_REQ field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: PMIC_ON_REQ</td>
</tr>
<tr>
<td></td>
<td>The hysteresis (HYS) bit controls whether a pin acts as a Schmitt trigger, which is a comparator remembering its last input state (hysteresis).</td>
</tr>
<tr>
<td>0 HYS_0_Hysteresis_Disabled</td>
<td>Hysteresis Disabled (CMOS input)</td>
</tr>
<tr>
<td>1 HYS_1_Hysteresis_Enabled</td>
<td>Hysteresis Enabled (Schmitt Trigger input)</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Controls signals to select pull-up or pull-down internal resistance strength.</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: PMIC_ON_REQ</td>
</tr>
<tr>
<td>00 PUS_0_100K_Ohm_Pull_Down</td>
<td>100K Ohm Pull Down</td>
</tr>
<tr>
<td>01 PUS_1_47K_Ohm_Pull_Up</td>
<td>47K Ohm Pull Up</td>
</tr>
<tr>
<td>10 PUS_2_100K_Ohm_Pull_Up</td>
<td>100K Ohm Pull Up</td>
</tr>
<tr>
<td>11 PUS_3_22K_Ohm_Pull_Up</td>
<td>22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Control signal to enable internal pull-up/down resistors or pad keeper functionality.</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: PMIC_ON_REQ</td>
</tr>
<tr>
<td>0 PUE_0_Keeper</td>
<td>Keep the previous output value when the output driver is disabled.</td>
</tr>
<tr>
<td>1 PUE_1_Pull</td>
<td>Pull-up or pull-down (determined by PUS field).</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: PMIC_ON_REQ</td>
</tr>
<tr>
<td></td>
<td>The pull/keeper function for a given pin is controlled by the PKE, PUE and PUS bits. The pull/keeper can be enabled by the pull/keep enable (PKE) bit. When the pull/keeper is enabled, the PUE (pull-up enable) bit selects either a pull-up/pull-down resistor on the output or a keeper device (keep the previous output value).</td>
</tr>
<tr>
<td></td>
<td>When the pull/keeper is disabled, PUE and PUS have no functionality.</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0.Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1.Pull_Keeper_E nabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: PMIC_ON_REQ</td>
</tr>
<tr>
<td></td>
<td>If set to 1, the output driver drives only logic 0. The drain of the internal transistor is open. It means that logic 1 has to be driven by an external component. This option is essential if connection between the pad and an external component is bi-directional. If ODE = 0, then the output driver drives logic 1 and logic 0.</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0.Open_Drain_Disabled — Open Drain Disabled (Output is CMOS)</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1.Open_Drain_E nabled — Open Drain Enabled (Output is Open Drain)</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>SPEED is a selectable bit field that sets electrical characteristics of a pin in a given frequency range. This field provides additional 2-bit slew rate control. These options can either increase the output driver current in the higher frequency range, or reduce the switching noise in the lower frequency range.</td>
</tr>
<tr>
<td>10</td>
<td>Medium — 100MHz</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: PMIC_ON_REQ</td>
</tr>
<tr>
<td></td>
<td>The drive strength enable (DSE) can be explained as series resistance between an ideal driver’s output and its load. To achieve maximal transferred power, the impedance of the driver has to match the load impedance.</td>
</tr>
<tr>
<td></td>
<td>Note: Typical values provided, please see GPIO spec for full impedance range.</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0 — HI-Z</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1 — Dual/Single voltage: 262/260 Ohm @ 1.8V, 247/157 Ohm @ 3.3V</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2 — Dual/Single voltage: 134/130 Ohm @ 1.8V, 126/78 Ohm @ 3.3V</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3 — Dual/Single voltage: 88/88 Ohm @ 1.8V, 84/53 Ohm @ 3.3V</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4 — Dual/Single voltage: 62/65 Ohm @ 1.8V, 57/39 Ohm @ 3.3V</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5 — Dual/Single voltage: 51/52 Ohm @ 1.8V, 47/32 Ohm @ 3.3V</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6 — Dual/Single voltage: 43/43 Ohm @ 1.8V, 40/26 Ohm @ 3.3V</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7 — Dual/Single voltage: 37/37 Ohm @ 1.8V, 34/23 Ohm @ 3.3V</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_ON_REQ field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td>SRE</td>
<td>Select one out of next values for pad: PMIC_ON_REQ</td>
</tr>
<tr>
<td></td>
<td>This bitfield controls how fast the pin toggles between the two logic states. Since rapidly changing states consume more power and generate spikes, it should be enabled only when necessary.</td>
</tr>
<tr>
<td></td>
<td>The operational frequency on GPIO pads is dependent on slew rate (SRE), speed (SPEED), and supply voltage (OVDD). See Operating Frequency table in the GPIO block guide for more details.</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.5.9  SW_PAD_CTL_PAD_PMIC_STBY_REQ SW PAD Control Register (IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_STBY_REQ)

#### SW_PAD_CTL Register

Address: 400A_8000h base + 20h offset = 400A_8020h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>HYS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
</tr>
<tr>
<td>PUS</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>PUE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PKE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SPEED</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DSE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_STBY_REQ field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>HYS</td>
<td>Select one out of next values for pad: PMIC_STBY_REQ</td>
</tr>
<tr>
<td></td>
<td>The hysteresis (HYS) bit controls whether a pin acts as a Schmitt trigger, which is a comparator remembering its last input state (hysteresis).</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled (CMOS input)</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled (Schmitt Trigger input)</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>PUS</td>
<td>Controls signals to select pull-up or pull-down internal resistance strength.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SNVS_SWM_PAD_CTL_PAD_PMIC_STBY_REQ field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>PUE</td>
<td>Control signal to enable internal pull-up/down resistors or pad keeper functionality.</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keep the previous output value when the output driver is disabled.</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull-up or pull-down (determined by PUS field).</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>PKE</td>
<td>Select one out of next values for pad: PMIC_STBY_REQ</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>ODE</td>
<td>Select one out of next values for pad: PMIC_STBY_REQ</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled (Output is CMOS)</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled (Output is Open Drain)</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>SPEED</td>
<td>SPEED is a selectable bit field that sets electrical characteristics of a pin in a given frequency range. This field provides additional 2-bit slew rate control. These options can either increase the output driver current in the higher frequency range, or reduce the switching noise in the lower frequency range.</td>
</tr>
<tr>
<td>0</td>
<td>Medium — 100MHz</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>DSE</td>
<td>The drive strength enable (DSE) can be explained as series resistance between an ideal driver’s output and its load. To achieve maximal transferred power, the impedance of the driver has to match the load impedance.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC SNVS_GPR Memory Map/Register Definition

#### IOMUXC_SNVS_GPR memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400A_4000</td>
<td>GPR0 General Purpose Register (IOMUXC_SNVS_GPR_GPR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.6.1/400</td>
</tr>
<tr>
<td>400A_4004</td>
<td>GPR1 General Purpose Register (IOMUXC_SNVS_GPR_GPR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.6.2/400</td>
</tr>
<tr>
<td>400A_4008</td>
<td>GPR2 General Purpose Register (IOMUXC_SNVS_GPR_GPR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.6.3/400</td>
</tr>
<tr>
<td>400A_400C</td>
<td>GPR3 General Purpose Register (IOMUXC_SNVS_GPR_GPR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.6.4/402</td>
</tr>
</tbody>
</table>
11.6.1 GPR0 General Purpose Register  
(IOMUXC_SNVS_GPR_GPR0)

GPR Register

Address: 400A_4000h base + 0h offset = 400A_4000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
</tr>
<tr>
<td>30</td>
<td>W</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_SNVS_GPR_GPR0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

11.6.2 GPR1 General Purpose Register  
(IOMUXC_SNVS_GPR_GPR1)

GPR Register

Address: 400A_4000h base + 4h offset = 400A_4004h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
</tr>
<tr>
<td>30</td>
<td>W</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_SNVS_GPR_GPR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

11.6.3 GPR2 General Purpose Register  
(IOMUXC_SNVS_GPR_GPR2)

GPR Register

Address: 400A_4000h base + 8h offset = 400A_4008h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
</tr>
<tr>
<td>30</td>
<td>W</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Reserved

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_SNV_S_GPR_GPR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| -     | This field is reserved.  
       | Reserved     |
11.6.4 GPR3 General Purpose Register (IOMUXC_SNVS_GPR_GPR3)

GPR Register

Address: 400A_4000h base + Ch offset = 400A_400Ch

![Register Diagram]

- **Bits 31-24**: Reserved
- **Bits 23-19**: DCDC_STS_DC_OK
- **Bits 18-17**: DCDC_OVER_VOL, DCDC_OVER_CUR
- **Bits 16**: DCDC_IN_LOW_VOL
- **Bits 15-8**: POR_PULL_TYPE, DCDC_STATUS_CAPT_CLR
- **Bits 7-0**: LPSR_MODE_ENABLE

**Reset Values**

<table>
<thead>
<tr>
<th>Bit 31-24</th>
<th>Bit 23-19</th>
<th>Bit 18-17</th>
<th>Bit 16</th>
<th>Bit 15-8</th>
<th>Bit 7-0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

402

NXP Semiconductors
# IOMUXC_SNVS_GPR_GPR3 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–20</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>19 DCDC_STS_DC_OK</td>
<td>DCDC status OK 0 DCDC is ramping up and not ready 1 DCDC is ready</td>
</tr>
<tr>
<td>18 DCDC_OVER_VOL</td>
<td>DCDC output over voltage alert 0 No over voltage detected 1 Over voltage detected</td>
</tr>
<tr>
<td>17 DCDC_OVER_CUR</td>
<td>DCDC output over current alert 0 No over current detected 1 Over current detected</td>
</tr>
<tr>
<td>16 DCDC_IN_LOW_VOL</td>
<td>DCDC_IN low voltage detect. 0 DCDC_IN is ok 1 DCDC_IN is too low</td>
</tr>
<tr>
<td>15–4</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>3–2 POR_PULL_TYPE</td>
<td>POR_B pad control 00 100 Ohm pull up enabled for POR_B always 01 Disable pull in SNVS mode, 100 Ohm pull up enabled otherwise 10 Disable pull of POR_B always 11 100 Ohm pull down enabled in SNVS mode, 100 Ohm pull up enabled otherwise</td>
</tr>
<tr>
<td>1 DCDC_STATUS_CAPT_CLR</td>
<td>DCDC captured status clear Write logic 1 to clear the 3 bits of DCDC captured status: DCDC_OVER_VOL, DCDC_OVER_CUR, and DCDC_IN_LOW_VOL. Then write 0 to re-enable the 3 bits for status capture.</td>
</tr>
<tr>
<td>0 LPSR_MODE_ENABLE</td>
<td>Set to enable LPSR mode. 0 SNVS domain will reset when system reset happens 1 SNVS domain will only reset with SNVS POR</td>
</tr>
</tbody>
</table>

## 11.7 IOMUXC Memory Map/Register Definition

### IOMUXC memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8014</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.1/427</td>
</tr>
<tr>
<td>401F_8018</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.2/428</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_801C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.3/429</td>
</tr>
<tr>
<td>401F_8020</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.4/431</td>
</tr>
<tr>
<td>401F_8024</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.5/432</td>
</tr>
<tr>
<td>401F_8028</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.6/433</td>
</tr>
<tr>
<td>401F_802C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.7/435</td>
</tr>
<tr>
<td>401F_8030</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.8/436</td>
</tr>
<tr>
<td>401F_8034</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.9/437</td>
</tr>
<tr>
<td>401F_8038</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.10/438</td>
</tr>
<tr>
<td>401F_803C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.11/439</td>
</tr>
<tr>
<td>401F_8040</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.12/440</td>
</tr>
<tr>
<td>401F_8044</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.13/441</td>
</tr>
<tr>
<td>401F_8048</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.14/442</td>
</tr>
<tr>
<td>401F_804C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.15/443</td>
</tr>
<tr>
<td>401F_8050</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.16/444</td>
</tr>
<tr>
<td>401F_8054</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_16 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_16)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.17/445</td>
</tr>
<tr>
<td>401F_8058</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_17 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_17)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.18/446</td>
</tr>
<tr>
<td>401F_805C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_18 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_18)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.19/447</td>
</tr>
<tr>
<td>401F_8060</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_19 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_19)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.20/448</td>
</tr>
<tr>
<td>401F_8064</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_20 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_20)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.21/450</td>
</tr>
<tr>
<td>401F_8068</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_21 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_21)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.22/451</td>
</tr>
<tr>
<td>401F_806C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_22 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_22)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.23/452</td>
</tr>
<tr>
<td>401F_8070</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_23 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_23)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.24/453</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8074</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_24 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_24)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.25/454</td>
</tr>
<tr>
<td>401F_8078</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_25 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_25)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.26/455</td>
</tr>
<tr>
<td>401F_807C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_26 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_26)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.27/456</td>
</tr>
<tr>
<td>401F_8080</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_27 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_27)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.28/457</td>
</tr>
<tr>
<td>401F_8084</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_28 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_28)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.29/458</td>
</tr>
<tr>
<td>401F_8088</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_29 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_29)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.30/459</td>
</tr>
<tr>
<td>401F_808C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_30 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_30)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.31/460</td>
</tr>
<tr>
<td>401F_8090</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_31 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_31)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.32/461</td>
</tr>
<tr>
<td>401F_8094</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_32 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_32)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.33/462</td>
</tr>
<tr>
<td>401F_8098</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_33 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_33)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.34/463</td>
</tr>
<tr>
<td>401F_809C</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_34 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_34)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.35/464</td>
</tr>
<tr>
<td>401F_80A0</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_35 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_35)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.36/465</td>
</tr>
<tr>
<td>401F_80A4</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_36 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_36)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.37/466</td>
</tr>
<tr>
<td>401F_80A8</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_37 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_37)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.38/467</td>
</tr>
<tr>
<td>401F_80AC</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_38 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_38)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.39/468</td>
</tr>
<tr>
<td>401F_80B0</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_39 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_39)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.40/469</td>
</tr>
<tr>
<td>401F_80B4</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_40 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_40)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.41/470</td>
</tr>
<tr>
<td>401F_80B8</td>
<td>SW_MUX_CTL_PAD_GPIO_EMC_41 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_41)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.42/471</td>
</tr>
<tr>
<td>401F_80BC</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.43/472</td>
</tr>
<tr>
<td>401F_80C0</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.44/473</td>
</tr>
<tr>
<td>401F_80C4</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.45/475</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_80C8</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.46/476</td>
</tr>
<tr>
<td>401F_80CC</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.47/478</td>
</tr>
<tr>
<td>401F_80D0</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.48/479</td>
</tr>
<tr>
<td>401F_80D4</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.49/481</td>
</tr>
<tr>
<td>401F_80D8</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.50/482</td>
</tr>
<tr>
<td>401F_80DC</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.51/484</td>
</tr>
<tr>
<td>401F_80E0</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.52/485</td>
</tr>
<tr>
<td>401F_80E4</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.53/486</td>
</tr>
<tr>
<td>401F_80E8</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.54/487</td>
</tr>
<tr>
<td>401F_80EC</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.55/488</td>
</tr>
<tr>
<td>401F_80F0</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.56/489</td>
</tr>
<tr>
<td>401F_80F4</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.57/490</td>
</tr>
<tr>
<td>401F_80F8</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B0_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.58/491</td>
</tr>
<tr>
<td>401F_80FC</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.59/492</td>
</tr>
<tr>
<td>401F_8100</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.60/493</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8104</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.61/494</td>
</tr>
<tr>
<td>401F_8108</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.62/495</td>
</tr>
<tr>
<td>401F_810C</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.63/496</td>
</tr>
<tr>
<td>401F_8110</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.64/497</td>
</tr>
<tr>
<td>401F_8114</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.65/498</td>
</tr>
<tr>
<td>401F_8118</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.66/499</td>
</tr>
<tr>
<td>401F_811C</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.67/500</td>
</tr>
<tr>
<td>401F_8120</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.68/501</td>
</tr>
<tr>
<td>401F_8124</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.69/502</td>
</tr>
<tr>
<td>401F_8128</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.70/503</td>
</tr>
<tr>
<td>401F_812C</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.71/504</td>
</tr>
<tr>
<td>401F_8130</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.72/505</td>
</tr>
<tr>
<td>401F_8134</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.73/506</td>
</tr>
<tr>
<td>401F_8138</td>
<td>SW_MUX_CTL_PAD_GPIO_AD_B1_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.74/507</td>
</tr>
<tr>
<td>401F_813C</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.75/508</td>
</tr>
<tr>
<td>401F_8140</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.76/509</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC Memory Map/Register Definition

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8144</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.77/510</td>
</tr>
<tr>
<td>401F_8148</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.78/511</td>
</tr>
<tr>
<td>401F_814C</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.79/512</td>
</tr>
<tr>
<td>401F_8150</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.80/513</td>
</tr>
<tr>
<td>401F_8154</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.81/514</td>
</tr>
<tr>
<td>401F_8158</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.82/515</td>
</tr>
<tr>
<td>401F_815C</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.83/516</td>
</tr>
<tr>
<td>401F_8160</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.84/517</td>
</tr>
<tr>
<td>401F_8164</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.85/518</td>
</tr>
<tr>
<td>401F_8168</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.86/519</td>
</tr>
<tr>
<td>401F_816C</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.87/520</td>
</tr>
<tr>
<td>401F_8170</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.88/521</td>
</tr>
<tr>
<td>401F_8174</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.89/522</td>
</tr>
<tr>
<td>401F_8178</td>
<td>SW_MUX_CTL_PAD_GPIO_B0_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.90/523</td>
</tr>
<tr>
<td>401F_817C</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.91/524</td>
</tr>
<tr>
<td>401F_8180</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.92/525</td>
</tr>
<tr>
<td>401F_8184</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.93/526</td>
</tr>
<tr>
<td>401F_8188</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.94/527</td>
</tr>
<tr>
<td>401F_818C</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.95/528</td>
</tr>
<tr>
<td>401F_8190</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.96/529</td>
</tr>
<tr>
<td>401F_8194</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.97/530</td>
</tr>
<tr>
<td>401F_8198</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.98/531</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_819C</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.99/532</td>
</tr>
<tr>
<td>401F_81A0</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.100/533</td>
</tr>
<tr>
<td>401F_81A4</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.101/534</td>
</tr>
<tr>
<td>401F_81A8</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.102/535</td>
</tr>
<tr>
<td>401F_81AC</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.103/536</td>
</tr>
<tr>
<td>401F_81B0</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.104/537</td>
</tr>
<tr>
<td>401F_81B4</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.105/538</td>
</tr>
<tr>
<td>401F_81B8</td>
<td>SW_MUX_CTL_PAD_GPIO_B1_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.106/539</td>
</tr>
<tr>
<td>401F_81BC</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B0_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.107/540</td>
</tr>
<tr>
<td>401F_81C0</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B0_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.108/541</td>
</tr>
<tr>
<td>401F_81C4</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B0_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.109/542</td>
</tr>
<tr>
<td>401F_81C8</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B0_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.110/543</td>
</tr>
<tr>
<td>401F_81CC</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B0_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.111/544</td>
</tr>
<tr>
<td>401F_81D0</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B0_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.112/545</td>
</tr>
<tr>
<td>401F_81D4</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.113/546</td>
</tr>
<tr>
<td>401F_81D8</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.114/547</td>
</tr>
<tr>
<td>401F_81DC</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.115/548</td>
</tr>
<tr>
<td>401F_81E0</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.116/549</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_81E4</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.117/550</td>
</tr>
<tr>
<td>401F_81E8</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.118/551</td>
</tr>
<tr>
<td>401F_81EC</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.119/552</td>
</tr>
<tr>
<td>401F_81F0</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.120/553</td>
</tr>
<tr>
<td>401F_81F4</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.121/554</td>
</tr>
<tr>
<td>401F_81F8</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.122/555</td>
</tr>
<tr>
<td>401F_81FC</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.123/557</td>
</tr>
<tr>
<td>401F_8200</td>
<td>SW_MUX_CTL_PAD_GPIO_SD_B1_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0005h</td>
<td>11.7.124/558</td>
</tr>
<tr>
<td>401F_8204</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.125/559</td>
</tr>
<tr>
<td>401F_8208</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.126/561</td>
</tr>
<tr>
<td>401F_820C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.127/563</td>
</tr>
<tr>
<td>401F_8210</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.128/564</td>
</tr>
<tr>
<td>401F_8214</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.129/566</td>
</tr>
<tr>
<td>401F_8218</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.130/568</td>
</tr>
<tr>
<td>401F_821C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.131/569</td>
</tr>
<tr>
<td>401F_8220</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.132/571</td>
</tr>
<tr>
<td>401F_8224</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.133/573</td>
</tr>
<tr>
<td>401F_8228</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.134/574</td>
</tr>
<tr>
<td>401F_822C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.135/576</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8230</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.136/578</td>
</tr>
<tr>
<td>401F_8234</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.137/579</td>
</tr>
<tr>
<td>401F_8238</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.138/581</td>
</tr>
<tr>
<td>401F_823C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.139/583</td>
</tr>
<tr>
<td>401F_8240</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.140/584</td>
</tr>
<tr>
<td>401F_8244</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_16 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_16)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.141/586</td>
</tr>
<tr>
<td>401F_8248</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_17 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_17)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.142/588</td>
</tr>
<tr>
<td>401F_824C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_18 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_18)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.143/589</td>
</tr>
<tr>
<td>401F_8250</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_19 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_19)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.144/591</td>
</tr>
<tr>
<td>401F_8254</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_20 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_20)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.145/593</td>
</tr>
<tr>
<td>401F_8258</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_21 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_21)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.146/594</td>
</tr>
<tr>
<td>401F_825C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_22 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_22)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.147/596</td>
</tr>
<tr>
<td>401F_8260</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_23 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_23)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.148/598</td>
</tr>
<tr>
<td>401F_8264</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_24 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_24)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.149/599</td>
</tr>
<tr>
<td>401F_8268</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_25 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_25)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.150/601</td>
</tr>
<tr>
<td>401F_826C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_26 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_26)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.151/603</td>
</tr>
<tr>
<td>401F_8270</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_27 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_27)</td>
<td>32</td>
<td>R/W</td>
<td>0000_30B0h</td>
<td>11.7.152/604</td>
</tr>
<tr>
<td>401F_8274</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_28 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_28)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.153/606</td>
</tr>
<tr>
<td>401F_8278</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_29 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_29)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.154/608</td>
</tr>
<tr>
<td>401F_827C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_30 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_30)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.155/609</td>
</tr>
<tr>
<td>401F_8280</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_31 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_31)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.156/611</td>
</tr>
<tr>
<td>401F_8284</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_32 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_32)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.157/613</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC Memory Map/Register Definition

#### IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8288</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_33 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_33)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.158/614</td>
</tr>
<tr>
<td>401F_828C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_34 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_34)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.159/616</td>
</tr>
<tr>
<td>401F_8290</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_35 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_35)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.160/618</td>
</tr>
<tr>
<td>401F_8294</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_36 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_36)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.161/619</td>
</tr>
<tr>
<td>401F_8298</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_37 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_37)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.162/621</td>
</tr>
<tr>
<td>401F_829C</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_38 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_38)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.163/623</td>
</tr>
<tr>
<td>401F_82A0</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_39 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_39)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.164/624</td>
</tr>
<tr>
<td>401F_82A4</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_40 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_40)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.165/626</td>
</tr>
<tr>
<td>401F_82A8</td>
<td>SW_PAD_CTL_PAD_GPIO_EMC_41 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_41)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.166/628</td>
</tr>
<tr>
<td>401F_82AC</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.167/630</td>
</tr>
<tr>
<td>401F_82B0</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.168/632</td>
</tr>
<tr>
<td>401F_82B4</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.169/634</td>
</tr>
<tr>
<td>401F_82B8</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.170/636</td>
</tr>
<tr>
<td>401F_82BC</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_30B0h</td>
<td>11.7.171/638</td>
</tr>
<tr>
<td>401F_82C0</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_30B0h</td>
<td>11.7.172/640</td>
</tr>
<tr>
<td>401F_82C4</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_70A0h</td>
<td>11.7.173/642</td>
</tr>
<tr>
<td>401F_82C8</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_30A0h</td>
<td>11.7.174/644</td>
</tr>
<tr>
<td>401F_82CC</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_30A0h</td>
<td>11.7.175/646</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_82D0</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_70A0h</td>
<td>11.7.176/648</td>
</tr>
<tr>
<td>401F_82D4</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_90B1h</td>
<td>11.7.177/650</td>
</tr>
<tr>
<td>401F_82D8</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_70A0h</td>
<td>11.7.178/652</td>
</tr>
<tr>
<td>401F_82DC</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.179/654</td>
</tr>
<tr>
<td>401F_82E0</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.180/656</td>
</tr>
<tr>
<td>401F_82E4</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.181/658</td>
</tr>
<tr>
<td>401F_82E8</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B0_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.182/660</td>
</tr>
<tr>
<td>401F_82EC</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.183/662</td>
</tr>
<tr>
<td>401F_82F0</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.184/664</td>
</tr>
<tr>
<td>401F_82F4</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.185/666</td>
</tr>
<tr>
<td>401F_82F8</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.186/668</td>
</tr>
<tr>
<td>401F_82FC</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.187/670</td>
</tr>
<tr>
<td>401F_8300</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.188/672</td>
</tr>
<tr>
<td>401F_8304</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.189/674</td>
</tr>
<tr>
<td>401F_8308</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.190/676</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC Memory Map/Register Definition

#### IOMUXC Memory Map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_830C</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.191/678</td>
</tr>
<tr>
<td>401F_8310</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.192/680</td>
</tr>
<tr>
<td>401F_8314</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.193/682</td>
</tr>
<tr>
<td>401F_8318</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.194/684</td>
</tr>
<tr>
<td>401F_831C</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.195/686</td>
</tr>
<tr>
<td>401F_8320</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.196/688</td>
</tr>
<tr>
<td>401F_8324</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.197/690</td>
</tr>
<tr>
<td>401F_8328</td>
<td>SW_PAD_CTL_PAD_GPIO_AD_B1_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.198/692</td>
</tr>
<tr>
<td>401F_832C</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.199/693</td>
</tr>
<tr>
<td>401F_8330</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.200/695</td>
</tr>
<tr>
<td>401F_8334</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.201/697</td>
</tr>
<tr>
<td>401F_8338</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.202/698</td>
</tr>
<tr>
<td>401F_833C</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.203/700</td>
</tr>
<tr>
<td>401F_8340</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.204/702</td>
</tr>
<tr>
<td>401F_8344</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.205/703</td>
</tr>
<tr>
<td>401F_8348</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.206/705</td>
</tr>
<tr>
<td>401F_834C</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.207/707</td>
</tr>
<tr>
<td>401F_8350</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.208/708</td>
</tr>
<tr>
<td>401F_8354</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.209/710</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8358</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.210/712</td>
</tr>
<tr>
<td>401F_835C</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.211/713</td>
</tr>
<tr>
<td>401F_8360</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.212/715</td>
</tr>
<tr>
<td>401F_8364</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.213/717</td>
</tr>
<tr>
<td>401F_8368</td>
<td>SW_PAD_CTL_PAD_GPIO_B0_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.214/718</td>
</tr>
<tr>
<td>401F_836C</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.215/720</td>
</tr>
<tr>
<td>401F_8370</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.216/722</td>
</tr>
<tr>
<td>401F_8374</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.217/723</td>
</tr>
<tr>
<td>401F_8378</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.218/725</td>
</tr>
<tr>
<td>401F_837C</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.219/727</td>
</tr>
<tr>
<td>401F_8380</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.220/728</td>
</tr>
<tr>
<td>401F_8384</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.221/730</td>
</tr>
<tr>
<td>401F_8388</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.222/732</td>
</tr>
<tr>
<td>401F_838C</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.223/733</td>
</tr>
<tr>
<td>401F_8390</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.224/735</td>
</tr>
<tr>
<td>401F_8394</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.225/737</td>
</tr>
<tr>
<td>401F_8398</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.226/738</td>
</tr>
<tr>
<td>401F_839C</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.227/740</td>
</tr>
<tr>
<td>401F_83A0</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.228/742</td>
</tr>
<tr>
<td>401F_83A4</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.229/743</td>
</tr>
<tr>
<td>401F_83A8</td>
<td>SW_PAD_CTL_PAD_GPIO_B1_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.230/745</td>
</tr>
<tr>
<td>401F_83AC</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B0_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.231/747</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_83B0</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B0_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.232/749</td>
</tr>
<tr>
<td>401F_83B4</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B0_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.233/751</td>
</tr>
<tr>
<td>401F_83B8</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B0_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.234/753</td>
</tr>
<tr>
<td>401F_83BC</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B0_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.235/755</td>
</tr>
<tr>
<td>401F_83C0</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B0_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.236/757</td>
</tr>
<tr>
<td>401F_83C4</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_00)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.237/759</td>
</tr>
<tr>
<td>401F_83C8</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_01)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.238/761</td>
</tr>
<tr>
<td>401F_83CC</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_02)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.239/763</td>
</tr>
<tr>
<td>401F_83D0</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_03)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.240/765</td>
</tr>
<tr>
<td>401F_83D4</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_04)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.241/767</td>
</tr>
<tr>
<td>401F_83D8</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_05)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.242/769</td>
</tr>
<tr>
<td>401F_83DC</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_06)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.243/771</td>
</tr>
<tr>
<td>401F_83E0</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_07)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.244/773</td>
</tr>
<tr>
<td>401F_83E4</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_08)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.245/775</td>
</tr>
<tr>
<td>401F_83E8</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_09)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.246/777</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_83EC</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.247/779</td>
</tr>
<tr>
<td>401F_83F0</td>
<td>SW_PAD_CTL_PAD_GPIO_SD_B1_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_10B0h</td>
<td>11.7.248/781</td>
</tr>
<tr>
<td>401F_83F4</td>
<td>ANATOP_USB_OTG1_ID_SELECT_INPUT DAISY Register (IOMUXC_ANATOP_USB_OTG1_ID_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.249/783</td>
</tr>
<tr>
<td>401F_83F8</td>
<td>ANATOP_USB_OTG2_ID_SELECT_INPUT DAISY Register (IOMUXC_ANATOP_USB_OTG2_ID_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.250/784</td>
</tr>
<tr>
<td>401F_83FC</td>
<td>CCM_PMIC_READY_SELECT_INPUT DAISY Register (IOMUXC_CCM_PMIC_READY_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.251/784</td>
</tr>
<tr>
<td>401F_8400</td>
<td>CSI_DATA02_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA02_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.252/785</td>
</tr>
<tr>
<td>401F_8404</td>
<td>CSI_DATA03_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA03_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.253/786</td>
</tr>
<tr>
<td>401F_8408</td>
<td>CSI_DATA04_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA04_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.254/787</td>
</tr>
<tr>
<td>401F_840C</td>
<td>CSI_DATA05_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA05_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.255/788</td>
</tr>
<tr>
<td>401F_8410</td>
<td>CSI_DATA06_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA06_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.256/789</td>
</tr>
<tr>
<td>401F_8414</td>
<td>CSI_DATA07_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA07_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.257/790</td>
</tr>
<tr>
<td>401F_8418</td>
<td>CSI_DATA08_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA08_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.258/791</td>
</tr>
<tr>
<td>401F_841C</td>
<td>CSI_DATA09_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA09_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.259/792</td>
</tr>
<tr>
<td>401F_8420</td>
<td>CSI_HSYNC_SELECT_INPUT DAISY Register (IOMUXC_CSI_HSYNC_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.260/792</td>
</tr>
<tr>
<td>401F_8424</td>
<td>CSI_PIXCLK_SELECT_INPUT DAISY Register (IOMUXC_CSI_PIXCLK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.261/793</td>
</tr>
<tr>
<td>401F_8428</td>
<td>CSI_VSYNC_SELECT_INPUT DAISY Register (IOMUXC_CSI_VSYNC_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.262/794</td>
</tr>
<tr>
<td>401F_842C</td>
<td>ENET_IPG_CLK_RMII_SELECT_INPUT DAISY Register (IOMUXC_ENET_IPG_CLK_RMII_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.263/795</td>
</tr>
<tr>
<td>401F_8430</td>
<td>ENET_MDIO_SELECT_INPUT DAISY Register (IOMUXC_ENET_MDIO_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.264/795</td>
</tr>
<tr>
<td>401F_8434</td>
<td>ENET0_RXDATA_SELECT_INPUT DAISY Register (IOMUXC_ENET0_RXDATA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.265/796</td>
</tr>
<tr>
<td>401F_8438</td>
<td>ENET1_RXDATA_SELECT_INPUT DAISY Register (IOMUXC_ENET1_RXDATA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.266/797</td>
</tr>
<tr>
<td>401F_843C</td>
<td>ENET_RXEN_SELECT_INPUT DAISY Register (IOMUXC_ENET_RXEN_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.267/798</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8440</td>
<td>ENET_RXERR_SELECT_INPUT DAISY Register (IOMUXC_ENET_RXERR_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.268/799</td>
</tr>
<tr>
<td>401F_8444</td>
<td>ENET0 TIMER_SELECT_INPUT DAISY Register (IOMUXC_ENET0_TIMER_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.269/799</td>
</tr>
<tr>
<td>401F_8448</td>
<td>ENET_TXCLK_SELECT_INPUT DAISY Register (IOMUXC_ENET_TXCLK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.270/800</td>
</tr>
<tr>
<td>401F_844C</td>
<td>FLEXCAN1_RX_SELECT_INPUT DAISY Register (IOMUXC_FLEXCAN1_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.271/801</td>
</tr>
<tr>
<td>401F_8450</td>
<td>FLEXCAN2_RX_SELECT_INPUT DAISY Register (IOMUXC_FLEXCAN2_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.272/801</td>
</tr>
<tr>
<td>401F_8454</td>
<td>FLEXPWM1_PWMA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMA3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.273/802</td>
</tr>
<tr>
<td>401F_8458</td>
<td>FLEXPWM1_PWMA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMA0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.274/803</td>
</tr>
<tr>
<td>401F_845C</td>
<td>FLEXPWM1_PWMA1_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMA1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.275/804</td>
</tr>
<tr>
<td>401F_8460</td>
<td>FLEXPWM1_PWMA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMA2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.276/805</td>
</tr>
<tr>
<td>401F_8464</td>
<td>FLEXPWM1_PWMB3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMB3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.277/805</td>
</tr>
<tr>
<td>401F_8468</td>
<td>FLEXPWM1_PWMB0_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMB0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.278/806</td>
</tr>
<tr>
<td>401F_846C</td>
<td>FLEXPWM1_PWMB1_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMB1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.279/807</td>
</tr>
<tr>
<td>401F_8470</td>
<td>FLEXPWM1_PWMB2_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMB2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.280/808</td>
</tr>
<tr>
<td>401F_8474</td>
<td>FLEXPWM2_PWMA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMA3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.281/808</td>
</tr>
<tr>
<td>401F_8478</td>
<td>FLEXPWM2_PWMA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMA0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.282/809</td>
</tr>
<tr>
<td>401F_847C</td>
<td>FLEXPWM2_PWMA1_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMA1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.283/810</td>
</tr>
<tr>
<td>401F_8480</td>
<td>FLEXPWM2_PWMA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMA2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.284/811</td>
</tr>
<tr>
<td>401F_8484</td>
<td>FLEXPWM2_PWMB3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMB3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.285/811</td>
</tr>
<tr>
<td>401F_8488</td>
<td>FLEXPWM2_PWMB0_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMB0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.286/812</td>
</tr>
<tr>
<td>401F_848C</td>
<td>FLEXPWM2_PWMB1_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMB1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.287/813</td>
</tr>
<tr>
<td>401F_8490</td>
<td>FLEXPWM2_PWMB2_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMB2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.288/814</td>
</tr>
<tr>
<td>401F_8494</td>
<td>FLEXPWM4_PWMA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM4_PWMA0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.289/815</td>
</tr>
</tbody>
</table>
## IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8498</td>
<td>FLEXPWM4_PWMA1_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM4_PWMA1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.290/816</td>
</tr>
<tr>
<td>401F_849C</td>
<td>FLEXPWM4_PWMA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM4_PWMA2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.291/817</td>
</tr>
<tr>
<td>401F_84A0</td>
<td>FLEXPWM4_PWMA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM4_PWMA3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.292/818</td>
</tr>
<tr>
<td>401F_84A4</td>
<td>FLEXSPIA_DQS_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DQS_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.293/819</td>
</tr>
<tr>
<td>401F_84A8</td>
<td>FLEXSPIA_DATA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DATA0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.294/820</td>
</tr>
<tr>
<td>401F_84AC</td>
<td>FLEXSPIA_DATA1_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DATA1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.295/821</td>
</tr>
<tr>
<td>401F_84B0</td>
<td>FLEXSPIA_DATA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DATA2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.296/822</td>
</tr>
<tr>
<td>401F_84B4</td>
<td>FLEXSPIA_DATA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DATA3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.297/823</td>
</tr>
<tr>
<td>401F_84B8</td>
<td>FLEXSPIB_DATA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIB_DATA0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.298/824</td>
</tr>
<tr>
<td>401F_84BC</td>
<td>FLEXSPIB_DATA1_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIB_DATA1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.299/825</td>
</tr>
<tr>
<td>401F_84C0</td>
<td>FLEXSPIB_DATA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIB_DATA2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.300/826</td>
</tr>
<tr>
<td>401F_84C4</td>
<td>FLEXSPIB_DATA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIB_DATA3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.301/827</td>
</tr>
<tr>
<td>401F_84C8</td>
<td>FLEXSPIA_SCK_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_SCK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.302/828</td>
</tr>
<tr>
<td>401F_84CC</td>
<td>LPI2C1_SCL_SELECT_INPUT DAISY Register (IOMUXC_LPI2C1_SCL_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.303/829</td>
</tr>
<tr>
<td>401F_84D0</td>
<td>LPI2C1_SDA_SELECT_INPUT DAISY Register (IOMUXC_LPI2C1_SDA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.304/830</td>
</tr>
<tr>
<td>401F_84D4</td>
<td>LPI2C2_SCL_SELECT_INPUT DAISY Register (IOMUXC_LPI2C2_SCL_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.305/831</td>
</tr>
<tr>
<td>401F_84D8</td>
<td>LPI2C2_SDA_SELECT_INPUT DAISY Register (IOMUXC_LPI2C2_SDA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.306/832</td>
</tr>
<tr>
<td>401F_84DC</td>
<td>LPI2C3_SCL_SELECT_INPUT DAISY Register (IOMUXC_LPI2C3_SCL_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.307/832</td>
</tr>
<tr>
<td>401F_84E0</td>
<td>LPI2C3_SDA_SELECT_INPUT DAISY Register (IOMUXC_LPI2C3_SDA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.308/833</td>
</tr>
<tr>
<td>401F_84E4</td>
<td>LPI2C4_SCL_SELECT_INPUT DAISY Register (IOMUXC_LPI2C4_SCL_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.309/834</td>
</tr>
<tr>
<td>401F_84E8</td>
<td>LPI2C4_SDA_SELECT_INPUT DAISY Register (IOMUXC_LPI2C4_SDA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.310/835</td>
</tr>
<tr>
<td>401F_84EC</td>
<td>LP SPI1_PCS0_SELECT_INPUT DAISY Register (IOMUXC_LPSPI1_PCS0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.311/836</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_84F0</td>
<td>LPSPI1_SCK_SELECT_INPUT DAISY Register (IOMUXC_LPSPI1_SCK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.312/837</td>
</tr>
<tr>
<td>401F_84F4</td>
<td>LPSPI1_SDI_SELECT_INPUT DAISY Register (IOMUXC_LPSPI1_SDI_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.313/838</td>
</tr>
<tr>
<td>401F_84F8</td>
<td>LPSPI1_SDO_SELECT_INPUT DAISY Register (IOMUXC_LPSPI1_SDO_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.314/839</td>
</tr>
<tr>
<td>401F_84FC</td>
<td>LPSPI2_PCS0_SELECT_INPUT DAISY Register (IOMUXC_LPSPI2_PCS0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.315/840</td>
</tr>
<tr>
<td>401F_8500</td>
<td>LPSPI2_SCK_SELECT_INPUT DAISY Register (IOMUXC_LPSPI2_SCK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.316/841</td>
</tr>
<tr>
<td>401F_8504</td>
<td>LPSPI2_SDI_SELECT_INPUT DAISY Register (IOMUXC_LPSPI2_SDI_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.317/842</td>
</tr>
<tr>
<td>401F_8508</td>
<td>LPSPI2_SDO_SELECT_INPUT DAISY Register (IOMUXC_LPSPI2_SDO_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.318/843</td>
</tr>
<tr>
<td>401F_850C</td>
<td>LPSPI3_PCS0_SELECT_INPUT DAISY Register (IOMUXC_LPSPI3_PCS0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.319/844</td>
</tr>
<tr>
<td>401F_8510</td>
<td>LPSPI3_SCK_SELECT_INPUT DAISY Register (IOMUXC_LPSPI3_SCK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.320/845</td>
</tr>
<tr>
<td>401F_8514</td>
<td>LPSPI3_SDI_SELECT_INPUT DAISY Register (IOMUXC_LPSPI3_SDI_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.321/846</td>
</tr>
<tr>
<td>401F_8518</td>
<td>LPSPI3_SDO_SELECT_INPUT DAISY Register (IOMUXC_LPSPI3_SDO_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.322/847</td>
</tr>
<tr>
<td>401F_851C</td>
<td>LPSPI4_PCS0_SELECT_INPUT DAISY Register (IOMUXC_LPSPI4_PCS0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.323/848</td>
</tr>
<tr>
<td>401F_8520</td>
<td>LPSPI4_SCK_SELECT_INPUT DAISY Register (IOMUXC_LPSPI4_SCK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.324/849</td>
</tr>
<tr>
<td>401F_8524</td>
<td>LPSPI4_SDI_SELECT_INPUT DAISY Register (IOMUXC_LPSPI4_SDI_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.325/850</td>
</tr>
<tr>
<td>401F_8528</td>
<td>LPSPI4_SDO_SELECT_INPUT DAISY Register (IOMUXC_LPSPI4_SDO_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.326/851</td>
</tr>
<tr>
<td>401F_852C</td>
<td>LPUART2_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART2_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.327/852</td>
</tr>
<tr>
<td>401F_8530</td>
<td>LPUART2_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART2_TX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.328/853</td>
</tr>
<tr>
<td>401F_8534</td>
<td>LPUART3_CTS_B_SELECT_INPUT DAISY Register (IOMUXC_LPUART3_CTS_B_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.329/854</td>
</tr>
<tr>
<td>401F_8538</td>
<td>LPUART3_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART3_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.330/854</td>
</tr>
<tr>
<td>401F_853C</td>
<td>LPUART3_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART3_TX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.331/855</td>
</tr>
<tr>
<td>401F_8540</td>
<td>LPUART4_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART4_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.332/856</td>
</tr>
<tr>
<td>401F_8544</td>
<td>LPUART4_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART4_TX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.333/856</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8548</td>
<td>LPURAT5_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART5_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.334/857</td>
</tr>
<tr>
<td>401F_854C</td>
<td>LPURAT5_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART5_TX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.335/858</td>
</tr>
<tr>
<td>401F_8550</td>
<td>LPURAT6_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART6_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.336/859</td>
</tr>
<tr>
<td>401F_8554</td>
<td>LPURAT6_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART6_TX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.337/860</td>
</tr>
<tr>
<td>401F_8558</td>
<td>LPURAT7_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART7_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.338/861</td>
</tr>
<tr>
<td>401F_855C</td>
<td>LPURAT7_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART7_TX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.339/862</td>
</tr>
<tr>
<td>401F_8560</td>
<td>LPURAT8_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART8_RX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.340/862</td>
</tr>
<tr>
<td>401F_8564</td>
<td>LPURAT8_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART8_TX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.341/863</td>
</tr>
<tr>
<td>401F_8568</td>
<td>NMI_GLUE_NMI_SELECT_INPUT DAISY Register (IOMUXC_NMI_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.342/864</td>
</tr>
<tr>
<td>401F_856C</td>
<td>QTIMER2_TIMER0_SELECT_INPUT DAISY Register (IOMUXC_QTIMER2_TIMER0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.343/865</td>
</tr>
<tr>
<td>401F_8570</td>
<td>QTIMER2_TIMER1_SELECT_INPUT DAISY Register (IOMUXC_QTIMER2_TIMER1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.344/866</td>
</tr>
<tr>
<td>401F_8574</td>
<td>QTIMER2_TIMER2_SELECT_INPUT DAISY Register (IOMUXC_QTIMER2_TIMER2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.345/867</td>
</tr>
<tr>
<td>401F_8578</td>
<td>QTIMER2_TIMER3_SELECT_INPUT DAISY Register (IOMUXC_QTIMER2_TIMER3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.346/868</td>
</tr>
<tr>
<td>401F_857C</td>
<td>QTIMER3_TIMER0_SELECT_INPUT DAISY Register (IOMUXC_QTIMER3_TIMER0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.347/868</td>
</tr>
<tr>
<td>401F_8580</td>
<td>QTIMER3_TIMER1_SELECT_INPUT DAISY Register (IOMUXC_QTIMER3_TIMER1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.348/869</td>
</tr>
<tr>
<td>401F_8584</td>
<td>QTIMER3_TIMER2_SELECT_INPUT DAISY Register (IOMUXC_QTIMER3_TIMER2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.349/870</td>
</tr>
<tr>
<td>401F_8588</td>
<td>QTIMER3_TIMER3_SELECT_INPUT DAISY Register (IOMUXC_QTIMER3_TIMER3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.350/870</td>
</tr>
<tr>
<td>401F_858C</td>
<td>SAI1_MCLK2_SELECT_INPUT DAISY Register (IOMUXC_SAI1_MCLK2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.351/871</td>
</tr>
<tr>
<td>401F_8590</td>
<td>SAI1_RX_BCLK_SELECT_INPUT DAISY Register (IOMUXC_SAI1_RX_BCLK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.352/872</td>
</tr>
<tr>
<td>401F_8594</td>
<td>SAI1_RX_DATA0_SELECT_INPUT DAISY Register (IOMUXC_SAI1_RX_DATA0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.353/872</td>
</tr>
<tr>
<td>401F_8598</td>
<td>SAI1_RX_DATA1_SELECT_INPUT DAISY Register (IOMUXC_SAI1_RX_DATA1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.354/873</td>
</tr>
<tr>
<td>401F_859C</td>
<td>SAI1_RX_DATA2_SELECT_INPUT DAISY Register (IOMUXC_SAI1_RX_DATA2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.355/874</td>
</tr>
</tbody>
</table>
### IOMUXC Memory Map/Register Definition

#### Absolute address (hex)

<table>
<thead>
<tr>
<th>Address</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_85A0</td>
<td>SAI1_RX_DATA3_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.356/875</td>
</tr>
<tr>
<td>401F_85A4</td>
<td>SAI1_RX_SYNC_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.357/875</td>
</tr>
<tr>
<td>401F_85A8</td>
<td>SAI1_TX_BCLK_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.358/876</td>
</tr>
<tr>
<td>401F_85AC</td>
<td>SAI1_TX_SYNC_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.359/877</td>
</tr>
<tr>
<td>401F_85B0</td>
<td>SAI2_MCLK2_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.360/878</td>
</tr>
<tr>
<td>401F_85B4</td>
<td>SAI2_RX_BCLK_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.361/879</td>
</tr>
<tr>
<td>401F_85B8</td>
<td>SAI2_RX_DATA0_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.362/880</td>
</tr>
<tr>
<td>401F_85BC</td>
<td>SAI2_RX_SYNC_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.363/881</td>
</tr>
<tr>
<td>401F_85C0</td>
<td>SAI2_TX_BCLK_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.364/882</td>
</tr>
<tr>
<td>401F_85C4</td>
<td>SAI2_TX_SYNC_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.365/883</td>
</tr>
<tr>
<td>401F_85CC</td>
<td>SPDIF_IN_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.366/884</td>
</tr>
<tr>
<td>401F_85CD</td>
<td>USB_OTG2_OC_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.367/885</td>
</tr>
<tr>
<td>401F_85D0</td>
<td>USB_OTG1_OC_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.368/886</td>
</tr>
<tr>
<td>401F_85D4</td>
<td>USDH1_CD_B_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.369/886</td>
</tr>
<tr>
<td>401F_85DC</td>
<td>USDH2_CLK_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.371/888</td>
</tr>
<tr>
<td>401F_85E0</td>
<td>USDH2_CD_B_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.372/889</td>
</tr>
<tr>
<td>401F_85E4</td>
<td>USDH2_CMD_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.373/890</td>
</tr>
<tr>
<td>401F_85E8</td>
<td>USDH2_DATA0_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.374/891</td>
</tr>
<tr>
<td>401F_85EC</td>
<td>USDH2_DATA1_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.375/892</td>
</tr>
<tr>
<td>401F_85F0</td>
<td>USDH2_DATA2_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.376/893</td>
</tr>
<tr>
<td>401F_85F4</td>
<td>USDH2_DATA3_SELECT_INPUT DAISY Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.377/894</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_85F8</td>
<td>USDHC2_DATA4_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_DATA4_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.378/895</td>
</tr>
<tr>
<td>401F_85FC</td>
<td>USDHC2_DATA5_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_DATA5_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.379/896</td>
</tr>
<tr>
<td>401F_8600</td>
<td>USDHC2_DATA6_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_DATA6_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.380/897</td>
</tr>
<tr>
<td>401F_8604</td>
<td>USDHC2_DATA7_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_DATA7_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.381/898</td>
</tr>
<tr>
<td>401F_8608</td>
<td>USDHC2_WP_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_WP_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.382/899</td>
</tr>
<tr>
<td>401F_860C</td>
<td>XBAR1_IN02_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN02_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.383/900</td>
</tr>
<tr>
<td>401F_8610</td>
<td>XBAR1_IN03_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN03_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.384/901</td>
</tr>
<tr>
<td>401F_8614</td>
<td>XBAR1_IN04_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN04_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.385/902</td>
</tr>
<tr>
<td>401F_8618</td>
<td>XBAR1_IN05_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN05_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.386/903</td>
</tr>
<tr>
<td>401F_861C</td>
<td>XBAR1_IN06_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN06_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.387/904</td>
</tr>
<tr>
<td>401F_8620</td>
<td>XBAR1_IN07_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN07_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.388/905</td>
</tr>
<tr>
<td>401F_8624</td>
<td>XBAR1_IN08_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN08_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.389/906</td>
</tr>
<tr>
<td>401F_8628</td>
<td>XBAR1_IN09_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN09_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.390/907</td>
</tr>
<tr>
<td>401F_862C</td>
<td>XBAR1_IN17_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN17_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.391/907</td>
</tr>
<tr>
<td>401F_8630</td>
<td>XBAR1_IN18_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN18_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.392/908</td>
</tr>
<tr>
<td>401F_8634</td>
<td>XBAR1_IN20_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN20_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.393/909</td>
</tr>
<tr>
<td>401F_8638</td>
<td>XBAR1_IN22_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN22_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.394/910</td>
</tr>
<tr>
<td>401F_863C</td>
<td>XBAR1_IN23_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN23_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.395/911</td>
</tr>
<tr>
<td>401F_8640</td>
<td>XBAR1_IN24_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN24_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.396/912</td>
</tr>
<tr>
<td>401F_8644</td>
<td>XBAR1_IN14_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN14_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.397/913</td>
</tr>
<tr>
<td>401F_8648</td>
<td>XBAR1_IN15_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN15_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.398/914</td>
</tr>
<tr>
<td>401F_864C</td>
<td>XBAR1_IN16_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN16_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.399/915</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC Memory Map/Register Definition

#### IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8650</td>
<td>XBAR1_IN25_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN25_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.400/916</td>
</tr>
<tr>
<td>401F_8654</td>
<td>XBAR1_IN19_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN19_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.401/917</td>
</tr>
<tr>
<td>401F_8658</td>
<td>XBAR1_IN23_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN21_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.402/918</td>
</tr>
<tr>
<td>401F_870C</td>
<td>ENET2_IPG_CLK_RMII_SELECT_INPUT DAISY Register (IOMUXC_ENET2_IPG_CLK_RMII_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.403/918</td>
</tr>
<tr>
<td>401F_8710</td>
<td>ENET2_IPP_IND_MAC0_MDIO_SELECT_INPUT DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_MDIO_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.404/919</td>
</tr>
<tr>
<td>401F_8714</td>
<td>ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_0 DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.405/920</td>
</tr>
<tr>
<td>401F_8718</td>
<td>ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_1 DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.406/920</td>
</tr>
<tr>
<td>401F_871C</td>
<td>ENET2_IPP_IND_MAC0_RXEN_SELECT_INPUT DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_RXEN_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.407/921</td>
</tr>
<tr>
<td>401F_8720</td>
<td>ENET2_IPP_IND_MAC0_RXERR_SELECT_INPUT DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_RXERR_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.408/922</td>
</tr>
<tr>
<td>401F_8724</td>
<td>ENET2_IPP_IND_MAC0_TIMER_SELECT_INPUT_0 DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_TIMER_SELECT_INPUT_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.409/923</td>
</tr>
<tr>
<td>401F_8728</td>
<td>ENET2_IPP_IND_MAC0_TXCLK_SELECT_INPUT DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_TXCLK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.410/924</td>
</tr>
<tr>
<td>401F_872C</td>
<td>FLEXSPI2_IPP_IND_DQS_FA_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_DQS_FA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.411/924</td>
</tr>
<tr>
<td>401F_8730</td>
<td>FLEXSPI2_IPP_IND_IO_FA_BIT0_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.412/925</td>
</tr>
<tr>
<td>401F_8734</td>
<td>FLEXSPI2_IPP_IND_IO_FA_BIT1_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.413/926</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## IOMUXC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8738</td>
<td>FLEXSPI2_IPP_IND_IO_FA_BIT2_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.414/926</td>
</tr>
<tr>
<td>401F_873C</td>
<td>FLEXSPI2_IPP_IND_IO_FA_BIT3_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.415/927</td>
</tr>
<tr>
<td>401F_8740</td>
<td>FLEXSPI2_IPP_IND_IO_FB_BIT0_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT0_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.416/928</td>
</tr>
<tr>
<td>401F_8744</td>
<td>FLEXSPI2_IPP_IND_IO_FB_BIT1_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.417/929</td>
</tr>
<tr>
<td>401F_8748</td>
<td>FLEXSPI2_IPP_IND_IO_FB_BIT2_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.418/930</td>
</tr>
<tr>
<td>401F_874C</td>
<td>FLEXSPI2_IPP_IND_IO_FB_BIT3_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT3_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.419/931</td>
</tr>
<tr>
<td>401F_8750</td>
<td>FLEXSPI2_IPP_IND_SCK_FA_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_SCK_FA_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.420/932</td>
</tr>
<tr>
<td>401F_8754</td>
<td>FLEXSPI2_IPP_IND_SCK_FB_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_SCK_FB_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.421/933</td>
</tr>
<tr>
<td>401F_8758</td>
<td>GPT1_IPP_IND_CAPIN1_SELECT_INPUT DAISY Register (IOMUXC_GPT1_IPP_IND_CAPIN1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.422/934</td>
</tr>
<tr>
<td>401F_875C</td>
<td>GPT1_IPP_IND_CAPIN2_SELECT_INPUT DAISY Register (IOMUXC_GPT1_IPP_IND_CAPIN2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.423/935</td>
</tr>
<tr>
<td>401F_8760</td>
<td>GPT1_IPP_IND_CLKIN_SELECT_INPUT DAISY Register (IOMUXC_GPT1_IPP_IND_CLKIN_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.424/936</td>
</tr>
<tr>
<td>401F_8764</td>
<td>GPT2_IPP_IND_CAPIN1_SELECT_INPUT DAISY Register (IOMUXC_GPT2_IPP_IND_CAPIN1_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.425/937</td>
</tr>
<tr>
<td>401F_8768</td>
<td>GPT2_IPP_IND_CAPIN2_SELECT_INPUT DAISY Register (IOMUXC_GPT2_IPP_IND_CAPIN2_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.426/938</td>
</tr>
<tr>
<td>401F_876C</td>
<td>GPT2_IPP_IND_CLKIN_SELECT_INPUT DAISY Register (IOMUXC_GPT2_IPP_IND_CLKIN_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.427/939</td>
</tr>
<tr>
<td>401F_8770</td>
<td>SAI3_IPG_CLK_SAI_MCLK_SELECT_INPUT_2 DAISY Register (IOMUXC_SAI3_IPG_CLK_SAI_MCLK_SELECT_INPUT_2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.428/940</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC Memory Map/Register Definition

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_8774</td>
<td>SAI3_IPP_IND_SAI_RXBCLK_SELECT_INPUT DAISY Register (IOMUXC_SAI3_IPP_IND_SAI_RXBCLK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.429/941</td>
</tr>
<tr>
<td>401F_8778</td>
<td>SAI3_IPP_IND_SAI_RXDATA_SELECT_INPUT_0 DAISY Register (IOMUXC_SAI3_IPP_IND_SAI_RXDATA_SELECT_INPUT_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.430/942</td>
</tr>
<tr>
<td>401F_877C</td>
<td>SAI3_IPP_IND_SAI_RXSYNC_SELECT_INPUT DAISY Register (IOMUXC_SAI3_IPP_IND_SAI_RXSYNC_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.431/943</td>
</tr>
<tr>
<td>401F_8780</td>
<td>SAI3_IPP_IND_SAI_TXBCLK_SELECT_INPUT DAISY Register (IOMUXC_SAI3_IPP_IND_SAI_TXBCLK_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.432/944</td>
</tr>
<tr>
<td>401F_8784</td>
<td>SAI3_IPP_IND_SAI_TXSYNC_SELECT_INPUT DAISY Register (IOMUXC_SAI3_IPP_IND_SAI_TXSYNC_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.433/945</td>
</tr>
<tr>
<td>401F_8788</td>
<td>SEMC_I_IPP_IND_DQS4_SELECT_INPUT DAISY Register (IOMUXC_SEMC_I_IPP_IND_DQS4_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.434/946</td>
</tr>
<tr>
<td>401F_878C</td>
<td>CANFD_IPP_IND_CANRX_SELECT_INPUT DAISY Register (IOMUXC_CANFD_IPP_IND_CANRX_SELECT_INPUT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>11.7.435/946</td>
</tr>
</tbody>
</table>
11.7.1 SW_MUX_CTL_PAD_GPIO_EMC_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_00)

SW_MUX_CTL Register

Address: 401F_8000h base + 14h offset = 401F_8014h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
</tbody>
</table>

- **SION (Software Input On Field)**
  - Force the selected mux mode input path no matter of MUX_MODE functionality.
  - **ENABLED** — Force input path of pad GPIO_EMC_00
  - **DISABLED** — Input Path is determined by functionality

- **MUX_MODE (MUX Mode Select Field)**
  - Select one of iOMUX modes to be used for pad: GPIO_EMC_00.
  - 000 **ALT0** — Select mux mode: ALT0 mux port: SEMC_DATA00 of instance: semc
  - 001 **ALT1** — Select mux mode: ALT1 mux port: FLEXPWM4_PWMA00 of instance: flexpwm4
  - 010 **ALT2** — Select mux mode: ALT2 mux port: LPSPi2_SCK of instance: lpspi2

Table continues on the next page...
IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_00 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: XBAR1_XBAR_IN02 of instance: xbar1</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO00 of instance: flexio1</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO4_IO00 of instance: gpio4</td>
</tr>
</tbody>
</table>

11.7.2 SW_MUX_CTL_PAD_GPIO_EMC_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_01)

SW_MUX_CTL Register

Address: 401F_8000h base + 18h offset = 401F_8018h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

_RESET|

Reserved

Reserved

 Reserved | SION | Reserved |

MUX_MODE

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td>SION</td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_EMC_01</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_01 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

MUX_MODE | MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_01. |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_DATA01 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM4_PWMB00 of instance: flexpwm4</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPSPI2_PCS0 of instance: lpspi2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: XBAR1_IN03 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO01 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO01 of instance: gpio4</td>
</tr>
</tbody>
</table>

11.7.3 SW_MUX_CTL_PAD_GPIO_EMC_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_02)

SW_MUX_CTL Register

Address: 401F_8000h base + 1Ch offset = 401F_801Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1
**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_02 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved.</td>
</tr>
<tr>
<td>4 SION</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>3</td>
<td>Reserved.</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_02.</td>
</tr>
<tr>
<td>000 ALT0</td>
<td>Select mux mode: ALT0 mux port: SEMC_DATA02 of instance: semc</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>Select mux mode: ALT1 mux port: FLEXPWM4_PWMA01 of instance: flexpwm4</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>Select mux mode: ALT2 mux port: LPSPI2_SDO of instance: lpspi2</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: XBAR1_INOUT04 of instance: xbar1</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO02 of instance: flexio1</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO4_IO02 of instance: gpio4</td>
</tr>
</tbody>
</table>
### 11.7.4 SW_MUX_CTL_PAD_GPIO_EMC_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_03)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 20h offset = 401F_8020h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>This field is reserved.</td>
<td>000</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>MUX_MODE</td>
<td>001</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved.</td>
<td>000</td>
</tr>
<tr>
<td>-</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
<td>0</td>
</tr>
<tr>
<td>SION</td>
<td>Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_03</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
<td>0</td>
</tr>
<tr>
<td>-</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
<td>001</td>
</tr>
<tr>
<td></td>
<td>Select one of iOMUX modes to be used for pad: GPIO_EMC_03.</td>
<td></td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_DATA03 of instance: semc</td>
<td></td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXPWM4_PWMB01 of instance: flexpwm4</td>
<td></td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: LPSPI2_SDI of instance: lpspi2</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC SW_MUX_CTL_PAD_GPIO EMC_03 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: XBAR1_INOUT05 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO03 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO03 of instance: gpio4</td>
</tr>
</tbody>
</table>

11.7.5 SW_MUX_CTL_PAD_GPIO EMC_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO EMC_04)

SW_MUX_CTL Register

Address: 401F_8000h base + 24h offset = 401F_8024h

IOMUXC SW_MUX_CTL_PAD_GPIO EMC_04 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO EMC_04</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**MUX_MODE**

MUX Mode Select Field.

Select one of iomux modes to be used for pad: GPIO_EMC_04.

- **000 ALT0** — Select mux mode: ALT0 mux port: SEMC_DATA04 of instance: semc
- **001 ALT1** — Select mux mode: ALT1 mux port: FLEXPWM4_PWMA02 of instance: flexpwm4
- **010 ALT2** — Select mux mode: ALT2 mux port: SAI2_TX_DATA of instance: sai2
- **011 ALT3** — Select mux mode: ALT3 mux port: XBAR1_INOUT06 of instance: xbar1
- **100 ALT4** — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO04 of instance: flexio1
- **101 ALT5** — Select mux mode: ALT5 mux port: GPIO4_IO04 of instance: gpio4

### 11.7.6 SW_MUX_CTL_PAD_GPIO_EMC_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_05)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 28h offset = 401F_8028h
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td>SION</td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_05</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>MUX_MODE</th>
<th>MUX Mode Select Field.</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_DATA05 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXPWM4_PWMB02 of instance: flexpwm4</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: SAI2_TX_SYNC of instance: sai2</td>
</tr>
<tr>
<td>011</td>
<td><strong>ALT3</strong> — Select mux mode: ALT3 mux port: XBAR1_INOUT07 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td><strong>ALT4</strong> — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO05 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td><strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO4_IO05 of instance: gpio4</td>
</tr>
</tbody>
</table>
11.7.7 SW_MUX_CTL_PAD_GPIO_EMC_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_06)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 2Ch offset = 401F_802Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>0</td>
<td>ENABLED — Force input path of pad GPIO_EMC_06 0</td>
</tr>
<tr>
<td>3-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_EMC_06.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_DATA06 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM2_PWMA00 of instance: flexpwm2</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: SAI2_TX_BCLK of instance: sai2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_06 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: XBAR1_INOUT08 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO06 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO06 of instance: gpio4</td>
</tr>
</tbody>
</table>

### 11.7.8 SW_MUX_CTL_PAD_GPIO_EMC_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_07)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 30h offset = 401F_8030h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>SION</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. [Reserved]</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. [SION]</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_EMC_07</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>This field is reserved. Resolved</td>
</tr>
<tr>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
</tbody>
</table>

Select one of iomux modes to be used for pad: GPIO_EMC_07.

- **000 ALT0** — Select mux mode: ALT0 mux port: SEMC_DATA07 of instance: semc
- **001 ALT1** — Select mux mode: ALT1 mux port: FLEXPWM2_PWMB00 of instance: flexpwm2
- **010 ALT2** — Select mux mode: ALT2 mux port: SAI2_MCLK of instance: sai2
- **011 ALT3** — Select mux mode: ALT3 mux port: XBAR1_INOUT09 of instance: xbar1
- **100 ALT4** — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO07 of instance: flexio1
- **101 ALT5** — Select mux mode: ALT5 mux port: GPIO4_IO07 of instance: gpio4

11.7.9 SW_MUX_CTL_PAD_GPIO_EMC_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_08)

SW_MUX_CTL Register

Address: 401F_8000h base + 34h offset = 401F_8034h
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_08 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_08</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_08.</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_DM00 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXPWM2_PWMA01 of instance: flexpwm2</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: SAI2_RX_DATA of instance: sai2</td>
</tr>
<tr>
<td>011</td>
<td><strong>ALT3</strong> — Select mux mode: ALT3 mux port: XBAR1_INOUT17 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td><strong>ALT4</strong> — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO08 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td><strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO4_IO08 of instance: gpio4</td>
</tr>
</tbody>
</table>

### 11.7.10 SW_MUX_CTL_PAD_GPIO_EMC_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_09)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 38h offset = 401F_8038h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>SION</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>MUX_MODE</td>
</tr>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_09 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

**MUX_MODE**

MUX Mode Select Field.

- Select one of iomux modes to be used for pad: GPIO_EMC_09.
- 000 **ALT0** — Select mux mode: ALT0 mux port: SEMC_ADDR00 of instance: semc
- 001 **ALT1** — Select mux mode: ALT1 mux port: FLEXPWM2_PWMB01 of instance: flexpwm2
- 010 **ALT2** — Select mux mode: ALT2 mux port: SAI2_RX_SYNC of instance: sai2
- 011 **ALT3** — Select mux mode: ALT3 mux port: FLEXCAN2_TX of instance: flexcan2
- 100 **ALT4** — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO09 of instance: flexio1
- 101 **ALT5** — Select mux mode: ALT5 mux port: GPIO4_IO09 of instance: gpio4
- 1000 **ALT8** — Select mux mode: ALT8 mux port: FLEXSPI2_B_SS1_B of instance: flexspi2

---

### 11.7.11 SW_MUX_CTL_PAD_GPIO_EMC_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_10)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 3Ch offset = 401F_803Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_10 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>4</td>
<td><strong>SION</strong> Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_10.</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_ADDR00 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXPWM2_PWMA02 of instance: flexpwm2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: SAI2_RX_BCLK of instance: sai2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: FLEXCAN2_RX of instance: flexcan2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO10 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO10 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_B_SS0_B of instance: flexspi2</td>
</tr>
</tbody>
</table>

### 11.7.12 SW_MUX_CTL_PAD_GPIO_EMC_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_11)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 40h offset = 401F_8040h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>Enables — Force input path of pad GPIO_EMC_11</td>
</tr>
<tr>
<td></td>
<td>Disables — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_11.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_ADDR02 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM2_PWMB02 of instance: flexpmw2</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPI2C4_SDA of instance: lpi2c4</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: USDHC2_RESET_B of instance: usdhc2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO11 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO11 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_B_DQS of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.13 SW_MUX_CTL_PAD_GPIO_EMC_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_12)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 44h offset = 401F_8044h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_EMC_12</td>
</tr>
<tr>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_12.</td>
</tr>
<tr>
<td></td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: SEMC_ADDR03 of instance: semc</td>
</tr>
<tr>
<td></td>
<td>001 ALT1 — Select mux mode: ALT1 mux port: XBAR1_IN24 of instance: xbar1</td>
</tr>
<tr>
<td></td>
<td>010 ALT2 — Select mux mode: ALT2 mux port: LPI2C4_SCL of instance: lpi2c4</td>
</tr>
<tr>
<td></td>
<td>011 ALT3 — Select mux mode: ALT3 mux port: USDHC1_WP of instance: usdhc1</td>
</tr>
<tr>
<td></td>
<td>100 ALT4 — Select mux mode: ALT4 mux port: FLEXPWM1_PWMA03 of instance: flexpwm1</td>
</tr>
<tr>
<td></td>
<td>101 ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO12 of instance: gpio4</td>
</tr>
<tr>
<td></td>
<td>1000 ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_B_SCLK of instance: flexspi2</td>
</tr>
</tbody>
</table>
### 11.7.14 SW_MUX_CTL_PAD_GPIO_EMC_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_13)

**SW_MUX_CTL Register**

Address: $401F_{8000h}$ base + 48h offset = $401F_{8048h}$

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>R/W</td>
<td>00000000</td>
</tr>
<tr>
<td>15–11</td>
<td>R/W</td>
<td>00000000</td>
</tr>
<tr>
<td>31–5</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>R/W</td>
<td>00000000</td>
</tr>
<tr>
<td>15–11</td>
<td>R/W</td>
<td>00000000</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_13 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_EMC_13</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_13.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_ADDR04 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: XBAR1_IN25 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART3_TX of instance: lpuart3</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: MQS_RIGHT of instance: mqs</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXPWM1_PWMB03 of instance: flexpwm1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO13 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_B_DATA00 of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.15 SW_MUX_CTL_PAD_GPIO_EMC_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_14)

SW_MUX_CTL Register

Address: 401F_8000h base + 4Ch offset = 401F_804Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
<td></td>
</tr>
<tr>
<td>1–0</td>
<td>MUX_MODE</td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4 SION</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1 ENABLED</td>
<td>— Force input path of pad GPIO_EMC_14</td>
</tr>
<tr>
<td>0 DISABLED</td>
<td>— Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_14.</td>
</tr>
<tr>
<td>000 ALT0</td>
<td>— Select mux mode: ALT0 mux port: SEMC_ADDR05 of instance: semc</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>— Select mux mode: ALT1 mux port: XBAR1_INOUT19 of instance: xbar1</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>— Select mux mode: ALT2 mux port: LPUART3_RX of instance: lpuart3</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>— Select mux mode: ALT3 mux port: MQS_LEFT of instance: mqs</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>— Select mux mode: ALT4 mux port: LPSPI2_PCS1 of instance: lpspi2</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>— Select mux mode: ALT5 mux port: GPIO4_IO14 of instance: gpio4</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>— Select mux mode: ALT8 mux port: FLEXSPI2_B_DATA01 of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.16 SW_MUX_CTL_PAD_GPIO_EMC_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_15)

SW_MUX_CTL Register

Address: 401F_8000h base + 50h offset = 401F_8050h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
<th>SION</th>
<th>MUX_MODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0</td>
<td>0 0</td>
<td>1 0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_EMC_15</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>Select one of iomux modes to be used for pad: GPIO_EMC_15.</td>
</tr>
<tr>
<td>ALT0</td>
<td>Select mux mode: ALT0 mux port: SEMC_ADDR06 of instance: semc</td>
</tr>
<tr>
<td>ALT1</td>
<td>Select mux mode: ALT1 mux port: XBAR1_IN20 of instance: xbar1</td>
</tr>
<tr>
<td>ALT2</td>
<td>Select mux mode: ALT2 mux port: LPUART3_CTS_B of instance: luart3</td>
</tr>
<tr>
<td>ALT3</td>
<td>Select mux mode: ALT3 mux port: SPDIF_OUT of instance: spdif</td>
</tr>
<tr>
<td>ALT4</td>
<td>Select mux mode: ALT4 mux port: QTIMER3_TIMER0 of instance: qtimer3</td>
</tr>
<tr>
<td>ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO4_IO15 of instance: gpio4</td>
</tr>
<tr>
<td>ALT8</td>
<td>Select mux mode: ALT8 mux port: FLEXSPI2_B_DATA02 of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.17  SW_MUX_CTL_PAD_GPIO_EMC_16 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_16)

SW_MUX_CTL Register

Address: 401F_8000h base + 54h offset = 401F_8054h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_16 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_EMC_16</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_16.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_ADDR07 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: XBAR1_IN21 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART3_RTS_B of instance: lpuart3</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SPDIF_IN of instance: spdif</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: QTIMER3_TIMER1 of instance: qtimer3</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO16 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_B_DATA03 of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.18 SW_MUX_CTL_PAD_GPIO_EMC_17 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_17)

SW_MUX_CTL Register

Address: 401F_8000h base + 58h offset = 401F_8058h

<table>
<thead>
<tr>
<th>Bit 31–5</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 4</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td></td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_17</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 3</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 0</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>MUX_MODE</td>
</tr>
<tr>
<td></td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iOMUX modes to be used for pad: GPIO_EMC_17.</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_ADDR08 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXPWM4_PWMA03 of instance: flexpwm4</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: LPUART4_CTS_B of instance: lpuart4</td>
</tr>
</tbody>
</table>

*Table continues on the next page*...
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_18 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: FLEXCAN1_TX of instance: flexcan1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: QTIMER3_TIMER2 of instance: qtimer3</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO17 of instance: gpio4</td>
</tr>
</tbody>
</table>

---

### 11.7.19 SW_MUX_CTL_PAD_GPIO_EMC_18 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_18)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 5Ch offset = 401F_805Ch

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_18 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 4     | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.  
| SION  | 1 ENABLED — Force input path of pad GPIO_EMC_18  
|       | 0 DISABLED — Input Path is determined by functionality |

*Table continues on the next page...*
IOMUXC SW_MUX_CTL_PAD_GPIO_EMC_18 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

MUX_MODE | MUX Mode Select Field.
Select one of iomux modes to be used for pad: GPIO_EMC_18.

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_ADDR09 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM4_PWMB03 of instance: flexpwm4</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART4_RTS_B of instance: lpuart4</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: FLEXCAN1_RX of instance: flexcan1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: QTIMER3_TIMER3 of instance: qtimer3</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO18 of instance: gpio4</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SNVS_VIO_5_CTL of instance: snvs_hp</td>
</tr>
</tbody>
</table>

11.7.20 SW_MUX_CTL_PAD_GPIO_EMC_19 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_19)

SW_MUX_CTL Register

Address: 401F_8000h base + 60h offset = 401F_8060h

```
+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+
| Bit         | 15          | 14          | 13          | 12          | 11          | 10          | 9           | 8           | 7           | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
| R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           |
| W           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           |
| Reset       | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 1           | 0           | 1           |
+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+
```
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_19 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| SION    | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.  
1 | **ENABLED** — Force input path of pad GPIO_EMC_19  
0 | **DISABLED** — Input Path is determined by functionality |
| MUX_MODE| MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_19.  
000 | **ALT0** — Select mux mode: ALT0 mux port: SEMC_ADDR11 of instance: semc  
001 | **ALT1** — Select mux mode: ALT1 mux port: FLEXPWM2_PWMA03 of instance: flexpwm2  
010 | **ALT2** — Select mux mode: ALT2 mux port: LPUART4_TX of instance: lpuart4  
011 | **ALT3** — Select mux mode: ALT3 mux port: ENET_RDATA01 of instance: enet  
100 | **ALT4** — Select mux mode: ALT4 mux port: QTIMER2_TIMER0 of instance: qtimer2  
101 | **ALT5** — Select mux mode: ALT5 mux port: GPIO4_IO19 of instance: gpio4  
110 | **ALT6** — Select mux mode: ALT6 mux port: SNVS_VIO_5 of instance: snvs_hp |
11.7.21 SW_MUX_CTL_PAD_GPIO_EMC_20 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_20)

SW_MUX_CTL Register

Address: 401F_8000h base + 64h offset = 401F_8064h

- **Bit 31–5**
  - This field is reserved.
  - Reserved

- **Bit 4**
  - SION
  - Software Input On Field.
  - Force the selected mux mode input path no matter of MUX_MODE functionality.
  - 1 ENABLED — Force input path of pad GPIO_EMC_20
  - 0 DISABLED — Input Path is determined by functionality

- **Bit 3**
  - This field is reserved.
  - Reserved

- **Bit 31–5**
  - MUX_MODE
  - MUX Mode Select Field.
  - Select one of iOMUX modes to be used for pad: GPIO_EMC_20.
  - 000 ALT0 — Select mux mode: ALT0 mux port: SEMC_ADDR12 of instance: semc
  - 001 ALT1 — Select mux mode: ALT1 mux port: FLEXPWM2_PWMB03 of instance: flexpwm2
  - 010 ALT2 — Select mux mode: ALT2 mux port: LPUART4_RX of instance: luart4

*Table continues on the next page...*
# IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_20 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_RDATA00 of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: QTIMER2_TIMER1 of instance: qtimer2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO20 of instance: gpio4</td>
</tr>
</tbody>
</table>

## 11.7.22 SW_MUX_CTL_PAD_GPIO_EMC_21 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_21)

### SW_MUX_CTL Register

Address: 401F_8000h base + 68h offset = 401F_8068h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

## IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_21 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td></td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_EMC_21</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_21 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

**MUX_MODE**

MUX Mode Select Field.

Select one of iomux modes to be used for pad: GPIO_EMC_21.

- **000 ALT0** — Select mux mode: ALT0 mux port: SEMC_BA0 of instance: semc
- **001 ALT1** — Select mux mode: ALT1 mux port: FLEXPWM3_PWMA03 of instance: flexpwm3
- **010 ALT2** — Select mux mode: ALT2 mux port: LPI2C3_SDA of instance: lpi2c3
- **011 ALT3** — Select mux mode: ALT3 mux port: ENET_TDATA01 of instance: enet
- **100 ALT4** — Select mux mode: ALT4 mux port: QTIMER2_TIMER2 of instance: qtimer2
- **101 ALT5** — Select mux mode: ALT5 mux port: GPIO4_IO21 of instance: gpio4

### 11.7.23 SW_MUX_CTL_PAD_GPIO_EMC_22 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_22)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 6Ch offset = 401F_806Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_22 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

**4 SION**

Software Input On Field.

Force the selected mux mode Input path no matter of MUX_MODE functionality.

- **1 ENABLED** — Force input path of pad GPIO_EMC_22
- **0 DISABLED** — Input Path is determined by functionality

**MUX_MODE**

MUX Mode Select Field.

Select one of iomux modes to be used for pad: GPIO_EMC_22.

- **000 ALT0** — Select mux mode: ALT0 mux port: SEMC_BA1 of instance: semc
- **001 ALT1** — Select mux mode: ALT1 mux port: FLEXPWM3_PWMB03 of instance: flexpwm3
- **010 ALT2** — Select mux mode: ALT2 mux port: LPI2C3_SCL of instance: lpi2c3

*Table continues on the next page...*
IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_22 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_TDATA00 of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: QTIMER2_TIMER3 of instance: qtimer2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO22 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_A_SS1_B of instance: flexspi2</td>
</tr>
</tbody>
</table>

11.7.24 SW_MUX_CTL_PAD_GPIO_EMC_23 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_23)

SW_MUX_CTL Register

Address: 401F_8000h base + 70h offset = 401F_8070h

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_23 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_EMC_23</td>
</tr>
<tr>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_23.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_ADDR10 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMA00 of instance: flexpwm1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART5_TX of instance: lpuart5</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_RX_EN of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: GPT1_CAPTURE2 of instance: gpt1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO23 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_A_DQS of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.25  SW_MUX_CTL_PAD_GPIO_EMC_24 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_24)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 74h offset = 401F_8074h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
<th>SION</th>
<th>MUX_MODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>SION</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15–0</td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td>SION</td>
<td></td>
<td>MUX_MODE</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_24 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_24</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_EMC_24</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_CAS of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXPWM1_PWMB00 of instance: flexpwm1</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: LPUART5_RX of instance: lpuart5</td>
</tr>
<tr>
<td>011</td>
<td><strong>ALT3</strong> — Select mux mode: ALT3 mux port: ENET_TX_EN of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td><strong>ALT4</strong> — Select mux mode: ALT4 mux port: GPT1_CAPTURE1 of instance: gpt1</td>
</tr>
<tr>
<td>101</td>
<td><strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO4_IO24 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td><strong>ALT8</strong> — Select mux mode: ALT8 mux port: FLEXSPI2_A_SS0_B of instance: flexspi2</td>
</tr>
</tbody>
</table>
### 11.7.26 SW_MUX_CTL_PAD_GPIO_EMC_25 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_25)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 78h offset = 401F_8078h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_25 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
| SION  | 1 ENABLED — Force input path of pad GPIO_EMC_25  
      | 0 DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field. Select one ofiomux modes to be used for pad: GPIO_EMC_25. |
| 000   | ALT0 — Select mux mode: ALT0 mux port: SEMC_RAS of instance: semc |
| 001   | ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMA01 of instance: flexpwm1 |
| 010   | ALT2 — Select mux mode: ALT2 mux port: LPUART6_TX of instance: lpuart6 |
| 011   | ALT3 — Select mux mode: ALT3 mux port: ENET_TX_CLK of instance: enet |
| 100   | ALT4 — Select mux mode: ALT4 mux port: ENET_REF_CLK of instance: enet |
| 101   | ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO25 of instance: gpio4 |
| 1000  | ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_A_SCLK of instance: flexspi2 |
### 11.7.27 SW_MUX_CTL_PAD_GPIO_EMC_26 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_26)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 7Ch offset = 401F_807Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- **Reserved**
- **SION**

**Field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td><strong>SION</strong></td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMC_26</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_26.</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_CLK of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXPWM1_PWMB01 of instance: flexpwm1</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: LPUART6_RX of instance: lpuart6</td>
</tr>
<tr>
<td>011</td>
<td><strong>ALT3</strong> — Select mux mode: ALT3 mux port: ENET_RX_ER of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td><strong>ALT4</strong> — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO12 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td><strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO4_IO26 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td><strong>ALT8</strong> — Select mux mode: ALT8 mux port: FLEXSPI2_A_DATA00 of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.28 SW_MUX_CTL_PAD_GPIO_EMC_27 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_27)

SW_MUX_CTL Register

Address: 401F_8000h base + 80h offset = 401F_8080h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>SION</th>
<th>MUX_MODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_EMC_27</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_27.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_CKE of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMA02 of instance: flexpwm1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART5_RTS_B of instance: lpuart5</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPSPI1_SCK of instance: lpspi1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO13 of instance: flexio1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO27 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXSPI2_A_DATA01 of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.29 SW_MUX_CTL_PAD_GPIO_EMC_28 SW MUX Control
Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_28)

SW_MUX_CTL Register

Address: 401F_8000h base + 84h offset = 401F_8084h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
</tr>
<tr>
<td>14</td>
</tr>
<tr>
<td>13</td>
</tr>
<tr>
<td>12</td>
</tr>
<tr>
<td>11</td>
</tr>
<tr>
<td>10</td>
</tr>
<tr>
<td>9</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>7</td>
</tr>
<tr>
<td>6</td>
</tr>
<tr>
<td>5</td>
</tr>
<tr>
<td>4</td>
</tr>
<tr>
<td>3</td>
</tr>
<tr>
<td>2</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_28 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_EMC_28 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_28.</td>
</tr>
<tr>
<td>000 ALT0</td>
<td>Select mux mode: ALT0 mux port: SEMC_WE of instance: semc</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>Select mux mode: ALT1 mux port: FLEXPWM1_PWMB02 of instance: flexpwm1</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>Select mux mode: ALT2 mux port: LPUART5_CTS_B of instance: lpuart5</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: LPSPI1_SDO of instance: lpspi1</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO14 of instance: flexio1</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO4_IO28 of instance: gpio4</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>Select mux mode: ALT8 mux port: FLEXSPI2_A_DATA02 of instance: flexspi2</td>
</tr>
</tbody>
</table>
11.7.30 SW_MUX_CTL_PAD_GPIO_EMC_29 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_29)

SW_MUX_CTL Register

Address: 401F_8000h base + 88h offset = 401F_8088h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>SION</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>MUX_MODE</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset values:

- Bit 31–5: Reserved
- Bit 4: SION
- Bit 5–0: MUX_MODE

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_29 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_EMC_29 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_EMC_29.</td>
</tr>
<tr>
<td>000 ALT0</td>
<td>Select mux mode: ALT0 mux port: SEMC_CS0 of instance: semc</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>Select mux mode: ALT1 mux port: FLEXPWM3_PWMA00 of instance: flexpwm3</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>Select mux mode: ALT2 mux port: LPUART6_RTS_B of instance: luart6</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: LPSPI1_SDI of instance: lpspi1</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: FLEXIO1_FLEXIO15 of instance: flexio1</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO4_IO29 of instance: gpio4</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>Select mux mode: ALT8 mux port: FLEXSPI2_A_DATA03 of instance: flexspi2</td>
</tr>
</tbody>
</table>
### 11.7.31 SW_MUX_CTL_PAD_GPIO_EMC_30 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_30)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 8Ch offset = 401F_808Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>SION</td>
</tr>
<tr>
<td>7</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>MUX_MODE</td>
</tr>
<tr>
<td>3</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Reserved**

**SION**

- **Force the selected mux mode Input path no matter of MUX_MODE functionality.**

  - **1** **ENABLED** — Force input path of pad GPIO_EMC_30
  - **0** **DISABLED** — Input Path is determined by functionality

**MUX_MODE**

- **MUX Mode Select Field.**

- Select one of iOMUX modes to be used for pad: GPIO_EMC_30.

  - **000** **ALT0** — Select mux mode: ALT0 mux port: SEMC_DATA08 of instance: semc
  - **001** **ALT1** — Select mux mode: ALT1 mux port: FLEXPWM3_PWMB00 of instance: flexpwm3
  - **010** **ALT2** — Select mux mode: ALT2 mux port: LPUART6_CTS_B of instance: lpuart6
  - **011** **ALT3** — Select mux mode: ALT3 mux port: LPSPI1_PCS0 of instance: lpspi1
  - **100** **ALT4** — Select mux mode: ALT4 mux port: CSI_DATA23 of instance: csi
  - **101** **ALT5** — Select mux mode: ALT5 mux port: GPIO4_IO30 of instance: gpio4
  - **1000** **ALT8** — Select mux mode: ALT8 mux port: ENET2_TDATA00 of instance: enet2
11.7.32 SW_MUX_CTL_PAD_GPIO_EMC_31 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_31)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 90h offset = 401F_8090h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
<td>R W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_31 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_31.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_DATA09 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM3_PWMA01 of instance: flexpwm3</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART7_TX of instance: luart7</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPSPI1_PCS1 of instance: lspi1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA22 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO4_IO31 of instance: gpio4</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_TDATA01 of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.33 SW_MUX_CTL_PAD_GPIO_EMC_32 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_32)

SW_MUX_CTL Register

Address: 401F_8000h base + 94h offset = 401F_8094h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 4    | SION |    | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.  
1 ENABLED — Force input path of pad GPIO_EMC_32  
0 DISABLED — Input Path is determined by functionality |
| MUX_MODE |    |    | MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_EMC_32.  
000 ALT0 — Select mux mode: ALT0 mux port: SEMC_DATA10 of instance: semc  
001 ALT1 — Select mux mode: ALT1 mux port: FLEXPWM3_PWMB01 of instance: flexpwm3  
010 ALT2 — Select mux mode: ALT2 mux port: LPUART7_RX of instance: lpuart7  
011 ALT3 — Select mux mode: ALT3 mux port: CCM_PMIC_RDY of instance: ccm  
100 ALT4 — Select mux mode: ALT4 mux port: CSI_DATA21 of instance: csi  
101 ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO18 of instance: gpio3  
1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_TX_EN of instance: enet2 |
11.7.34  SW_MUX_CTL_PAD_GPIO_EMC_33 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_33)

SW_MUX_CTL Register

Address: 401F_8000h base + 98h offset = 401F_8098h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_33 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_EMC_33</td>
</tr>
<tr>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>MUX_MODE</th>
<th>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_33.</th>
</tr>
</thead>
<tbody>
<tr>
<td>000 ALT0</td>
<td>— Select mux mode: ALT0 mux port: SEMC_DATA11 of instance: semc</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>— Select mux mode: ALT1 mux port: FLEXPWM3_PWMA02 of instance: flexpwm3</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>— Select mux mode: ALT2 mux port: USDHC1_RESET_B of instance: usdhc1</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>— Select mux mode: ALT3 mux port: SAI3_RX_DATA of instance: sai3</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>— Select mux mode: ALT4 mux port: CSI_DATA20 of instance: csi</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>— Select mux mode: ALT5 mux port: GPIO3_IO19 of instance: gpio3</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>— Select mux mode: ALT8 mux port: ENET2_TX_CLK of instance: enet2</td>
</tr>
<tr>
<td>1001 ALT9</td>
<td>— Select mux mode: ALT9 mux port: ENET2_REF_CLK2 of instance: enet2</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL_PAD_GPIO_EMC_34 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_34)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 9Ch offset = 401F_809Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>15-0</td>
<td>MUX_MODE MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_EMC_34.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000 ALT0</td>
<td>Select mux mode: ALT0 mux port: SEMC_DATA12 of instance: semc</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>Select mux mode: ALT1 mux port: FLEXPWM3_PWMB02 of instance: flexpwm3</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>Select mux mode: ALT2 mux port: USDHC1_VSELECT of instance: usdhc1</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: SAI3_RX_SYNC of instance: sai3</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: CSI_DATA19 of instance: csi</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO3_IO20 of instance: gpio3</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>Select mux mode: ALT8 mux port: ENET2_RX_ER of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.36 SW_MUX_CTL_PAD_GPIO_EMC_35 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_35)

SW_MUX_CTL Register

Address: 401F_8000h base + A0h offset = 401F_80A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_35 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_EMCE_35</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMCE_35.</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_DATA13 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: XBAR1_INOUT18 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: GPT1_COMPARE1 of instance: gpt1</td>
</tr>
<tr>
<td>011</td>
<td><strong>ALT3</strong> — Select mux mode: ALT3 mux port: SAI3_RX_BCLK of instance: sai3</td>
</tr>
<tr>
<td>100</td>
<td><strong>ALT4</strong> — Select mux mode: ALT4 mux port: CSI_DATA18 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td><strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO3_IO21 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td><strong>ALT6</strong> — Select mux mode: ALT6 mux port: USBHC1_CD_B of instance: usdhc1</td>
</tr>
<tr>
<td>1000</td>
<td><strong>ALT8</strong> — Select mux mode: ALT8 mux port: ENET2_RDATA00 of instance: enet2</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL_PAD_GPIO_EMC_36 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_36)

**SW_MUX_CTL Register**

Address: 401F_8000h base + A4h offset = 401F_80A4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_36 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_EMC_36</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_36.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_DATA14 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: XBAR1_IN22 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: GPT1_COMPARE2 of instance: gpt1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI3_TX_DATA of instance: sai3</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA17 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO22 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC1_WP of instance: usdhc1</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_RDATA01 of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXCAN3_TX of instance: flexcan3/canfd</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL_PAD_GPIO_EMC_37 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_37)

**SW_MUX_CTL Register**

Address: 401F_8000h base + A8h offset = 401F_80A8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_EMC_37</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_DATA15 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: XBAR1_IN23 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: GPT1_COMPARE3 of instance: gpt1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI3_MCLK of instance: sai3</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA16 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO23 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC2_WP of instance: usdhc2</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_RX_EN of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXCAN3_RX of instance: flexcan3/canfd</td>
</tr>
</tbody>
</table>
11.7.39 SW_MUX_CTL_PAD_GPIO_EMC_38 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_38)

SW_MUX_CTL Register

Address: 401F_8000h base + ACh offset = 401F_80ACh

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>4</td>
<td>W</td>
<td>SION</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>16-0</td>
<td>R/W</td>
<td>MUX_MODE</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_EMC_38.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT0 mux port: SE METH01 of instance: semc</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT1 mux port: FLEXPWM1_PWMA03 of instance: flexpm1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT2 mux port: LPUART8_TX of instance: lpuart8</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT3 mux port: SAI3_TX_BCLK of instance: sai3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT4 mux port: CSI_FIELD of instance: csi</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT5 mux port: GPIO3_I024 of instance: gpio3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT6 mux port: USDHC2_VSELECT of instance: usdhc2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select the mux mode: ALT8 mux port: ENET2_MDC of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.40 SW_MUX_CTL_PAD_GPIO_EMC_39 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_39)

SW_MUX_CTL Register

Address: 401F_8000h base + B0h offset = 401F_80B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R W</th>
<th>Reserved</th>
<th>R W</th>
<th>SION</th>
<th>MUX_MODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_39 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_EMC_39</td>
</tr>
<tr>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_39.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SEMC_DQS of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMB03 of instance: flexpwm1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART8_RX of instance: lpuart8</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI3_TX_SYNC of instance: sai3</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: WDOG1_WDOG_B of instance: wdog1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO25 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC2_CD_B of instance: usdhc2</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_MDIO of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: SEMC_DQS4 of instance: semc</td>
</tr>
</tbody>
</table>
11.7.41 SW_MUX_CTL_PAD_GPIO_EMC_40 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_40)

SW_MUX_CTL Register

Address: 401F_8000h base + B4h offset = 401F_80B4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- **Reserved**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

- **SION**

  - **SINP**
    - Software Input On Field.
    - Force the selected mux mode Input path no matter of MUX_MODE functionality.
    - 1 **ENABLED** — Force input path of pad GPIO_EMC_40
    - 0 **DISABLED** — Input Path is determined by functionality

- **MUX_MODE**

  - MUX Mode Select Field.
  - Select one of iomux modes to be used for pad: GPIO_EMC_40.
  - 000 **ALT0** — Select mux mode: ALT0 mux port: SEMC_RDY of instance: semc
  - 001 **ALT1** — Select mux mode: ALT1 mux port: GPT2_CAPTURE2 of instance: gpt2
  - 010 **ALT2** — Select mux mode: ALT2 mux port: LPSPI1_PCS2 of instance: lpspi1
  - 011 **ALT3** — Select mux mode: ALT3 mux port: USB_OTG2_OC of instance: usb
  - 100 **ALT4** — Select mux mode: ALT4 mux port: ENET_MDC of instance: enet
  - 101 **ALT5** — Select mux mode: ALT5 mux port: GPIO3_IO26 of instance: gpio3
  - 110 **ALT6** — Select mux mode: ALT6 mux port: USDHC2_RESET_B of instance: usdhc2
  - 1001 **ALT9** — Select mux mode: ALT9 mux port: SEMC_CLK5 of instance: semc
### 11.7.42 SW_MUX_CTL_PAD_GPIO_EMC_41 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_41)

**SW_MUX_CTL Register**

Address: 401F_8000h base + B8h offset = 401F_80B8h

```markdown
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

```markdown
<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1
```

**IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_41 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>Force input path of pad GPIO_EMC_41.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Input Path is determined by functionality.</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality.</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_EMC_41.</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SEMC_CSX00 of instance: semc</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: GPT2_CAPTURE1 of instance: gpt2</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: LPSPI1_PCS3 of instance: lpspi1</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_41 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: USB_OTG2_PWR of instance: usb</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: ENET_MDIO of instance: enet</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO27 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC1_VSELECT of instance: usdhc1</td>
</tr>
</tbody>
</table>

### 11.7.43 SW_MUX_CTL_PAD_GPIO_AD_B0_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_00)

**SW_MUX_CTL Register**

Address: 401F_8000h base + BCh offset = 401F_80BCh

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td>SION</td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_00 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_AD_B0_00</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

- **MUX_MODE**
  - MUX Mode Select Field.
  - Select one of iOMUX modes to be used for pad: GPIO_AD_B0_00.
  - 000 **ALT0** — Select mux mode: ALT0 mux port: FLEXPWM2_PWMA03 of instance: flexpwm2
  - 001 **ALT1** — Select mux mode: ALT1 mux port: XBAR1_INOUT14 of instance: xbar1
  - 010 **ALT2** — Select mux mode: ALT2 mux port: REF_CLK_32K of instance: xtalosc
  - 011 **ALT3** — Select mux mode: ALT3 mux port: USB_OTG2_ID of instance: usb
  - 100 **ALT4** — Select mux mode: ALT4 mux port: LPI2C1_SCLS of instance: lpi2c1
  - 101 **ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO00 of instance: gpio1
  - 110 **ALT6** — Select mux mode: ALT6 mux port: USDHCI_RESET_B of instance: usdhc1
  - 111 **ALT7** — Select mux mode: ALT7 mux port: LPSPI3_SCK of instance: lpspi3

### 11.7.44 SW_MUX_CTL_PAD_GPIO_AD_B0_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_01)

#### SW_MUX_CTL Register

Address: 401F_8000h base + C0h offset = 401F_80C0h

![SW_MUX_CTL Register Diagram]

- **MUX_MODE**
  - MUX Mode Select Field.
  - Select one of iOMUX modes to be used for pad: GPIO_AD_B0_00.
  - 000 **ALT0** — Select mux mode: ALT0 mux port: FLEXPWM2_PWMA03 of instance: flexpwm2
  - 001 **ALT1** — Select mux mode: ALT1 mux port: XBAR1_INOUT14 of instance: xbar1
  - 010 **ALT2** — Select mux mode: ALT2 mux port: REF_CLK_32K of instance: xtalosc
  - 011 **ALT3** — Select mux mode: ALT3 mux port: USB_OTG2_ID of instance: usb
  - 100 **ALT4** — Select mux mode: ALT4 mux port: LPI2C1_SCLS of instance: lpi2c1
  - 101 **ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO00 of instance: gpio1
  - 110 **ALT6** — Select mux mode: ALT6 mux port: USDHCI_RESET_B of instance: usdhc1
  - 111 **ALT7** — Select mux mode: ALT7 mux port: LPSPI3_SCK of instance: lpspi3
## IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4 SION</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1 ENABLED</td>
<td>Force input path of pad GPIO_AD_B0_01</td>
</tr>
<tr>
<td>0 DISABLED</td>
<td>Input Path is determined by functionality</td>
</tr>
<tr>
<td>3 -</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

### MUX_MODE

MUX Mode Select Field.

Select one of iomux modes to be used for pad: GPIO_AD_B0_01.

- 000 **ALT0** — Select mux mode: ALT0 mux port: FLEXPWM2_PWMB03 of instance: flexpwm2
- 001 **ALT1** — Select mux mode: ALT1 mux port: XBAR1_INOUT15 of instance: xbar1
- 010 **ALT2** — Select mux mode: ALT2 mux port: REF_CLK_24M of instance: anatop
- 011 **ALT3** — Select mux mode: ALT3 mux port: USB_OTG1_ID of instance: anatop
- 100 **ALT4** — Select mux mode: ALT4 mux port: LPI2C1_SDAS of instance: lpi2c1
- 101 **ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO01 of instance: gpio1
- 110 **ALT6** — Select mux mode: ALT6 mux port: EWM_OUT_B of instance: ewm
- 111 **ALT7** — Select mux mode: ALT7 mux port: LPSPI3_SDO of instance: lpspi3
### 11.7.45 SW_MUX_CTL_PAD_GPIO_AD_B0_02 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_02)

**SW_MUX_CTL Register**

Address: 401F_8000h base + C4h offset = 401F_80C4h

#### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>MUX_MODE</td>
</tr>
</tbody>
</table>

- **SION**
  - Software Input On Field.
  - Force the selected mux mode Input path no matter of MUX_MODE functionality.
  - 1 **ENABLED** — Force input path of pad GPIO_AD_B0_02
  - 0 **DISABLED** — Input Path is determined by functionality

- **MUX_MODE**
  - MUX Mode Select Field.
  - Select one of iomux modes to be used for pad: GPIO_AD_B0_02.
  - 000 **ALT0** — Select mux mode: ALT0 mux port: FLEXCAN2_TX of instance: flexcan2
  - 001 **ALT1** — Select mux mode: ALT1 mux port: XBAR1_INOUT16 of instance: xbar1

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_02 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART6_TX of instance: lpuart6</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: USB_OTG1_PWR of instance: usb</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXPWM1_PWMX00 of instance: flexpwm1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO02 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: LPI2C1_HREQ of instance: lpi2c1</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: LPSPI3_SDI of instance: lpspi3</td>
</tr>
</tbody>
</table>

### 11.7.46 SW_MUX_CTL_PAD_GPIO_AD_B0_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_03)

**SW_MUX_CTL Register**

Address: 401F_8000h base + C8h offset = 401F_80C8h

#### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_03 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_AD_B0_03</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td><strong>MUX_MODE</strong></td>
<td>MUX Mode Select Field.</td>
</tr>
</tbody>
</table>

Select one of iomux modes to be used for pad: GPIO_AD_B0_03.

- **000 ALT0** — Select mux mode: ALT0 mux port: FLEXCAN2_RX of instance: flexcan2
- **001 ALT1** — Select mux mode: ALT1 mux port: XBAR1_INOUT17 of instance: xbar1
- **010 ALT2** — Select mux mode: ALT2 mux port: LPUART6_RX of instance: lpuart6
- **011 ALT3** — Select mux mode: ALT3 mux port: USB_OTG1_OC of instance: usb
- **100 ALT4** — Select mux mode: ALT4 mux port: FLEXPWM1_PWMX01 of instance: flexpwm1
- **101 ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO03 of instance: gpio1
- **110 ALT6** — Select mux mode: ALT6 mux port: REF_CLK_24M of instance: anatop
- **111 ALT7** — Select mux mode: ALT7 mux port: LPSPI3_PCS0 of instance: lspi3
11.7.47 SW_MUX_CTL_PAD_GPIO_AD_B0_04 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_04)

SW_MUX_CTL Register

Address: 401F_8000h base + CCh offset = 401F_80CCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>This field is reserved.</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Software Input On Field.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_AD_B0_04</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_AD_B0_04.</td>
<td></td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: SRC_BOOT_MODE00 of instance: src</td>
<td></td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: MQS_RIGHT of instance: mqs</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: ENET_TX_DATA03 of instance: enet</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI2_TX_SYNC of instance: sai2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA09 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO04 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: PIT_TRIGGER00 of instance: pit</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: LPSPI3_PCS1 of instance: lpspi3</td>
</tr>
</tbody>
</table>

### 11.7.48 SW_MUX_CTL_PAD_GPIO_AD_B0_05 SW MUX Control Register

(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_05)

**SW_MUX_CTL Register**

Address: 401F_8000h base + D0h offset = 401F_80D0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_05 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION Software Input On Field.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC SW_MUX_CTL_PAD_GPIO_AD_B0_05 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_AD_B0_05</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td><strong>Reserved</strong></td>
</tr>
</tbody>
</table>

### MUX_MODE

MUX Mode Select Field.

Select one of iomux modes to be used for pad: GPIO_AD_B0_05.

<table>
<thead>
<tr>
<th>MUX_MODE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: SRC_BOOT_MODE01 of instance: src</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: MQS_LEFT of instance: mqs</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: ENET_TX_DATA02 of instance: enet</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI2_TX_BCLK of instance: sai2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA08 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO05 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: XBAR1_INOUT17 of instance: xbar1</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: LPSPI3_PCS2 of instance: lpspi3</td>
</tr>
</tbody>
</table>
11.7.49  **SW_MUX_CTL_PAD_GPIO_AD_B0_06 SW MUX Control Register**  
*IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_06*

**SW_MUX_CTL Register**

Address: 401F_8000h base + D4h offset = 401F_80D4h

---

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_06 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 4      | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.  
| SION   | 1 **ENABLED** — Force input path of pad GPIO_AD_B0_06  
|        | 0 **DISABLED** — Input Path is determined by functionality |
| 3      | This field is reserved. Reserved |
| MUX_MODE | MUX Mode Select Field.  
|        | Select one of iOMUX modes to be used for pad: GPIO_AD_B0_06.  
|        | 000 **ALT0** — Select mux mode: ALT0 mux port: JTAG_TMS of instance: jtag_mux  
|        | 001 **ALT1** — Select mux mode: ALT1 mux port: GPT2COMPARE1 of instance: gpt2 |

*Table continues on the next page...*
IOMUXC Memory Map/Register Definition

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_06 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: ENET_RX_CLK of instance: enet</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI2_RX_BCLK of instance: sai2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA07 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO06 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: XBAR1_INOUT18 of instance: xbar1</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: LPSPI3_PCS3 of instance: lpspi3</td>
</tr>
</tbody>
</table>

11.7.50 SW_MUX_CTL_PAD_GPIO_AD_B0_07 SW MUX Control Register

(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_07)

SW_MUX_CTL Register

Address: 401F_8000h base + D8h offset = 401F_80D8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>SION</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MUX_MODE</td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_AD_B0_07</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**MUX_MODE**

MUX Mode Select Field.

Select one of iomux modes to be used for pad: GPIO_AD_B0_07.

- **000 ALT0** — Select mux mode: ALT0 mux port: JTAG_TCK of instance: jtag_mux
- **001 ALT1** — Select mux mode: ALT1 mux port: GPT2_COMPARE2 of instance: gpt2
- **010 ALT2** — Select mux mode: ALT2 mux port: ENET_TX_ER of instance: enet
- **011 ALT3** — Select mux mode: ALT3 mux port: SAI2_RX_SYNC of instance: sai2
- **100 ALT4** — Select mux mode: ALT4 mux port: CSI_DATA06 of instance: csi
- **101 ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO07 of instance: gpio1
- **110 ALT6** — Select mux mode: ALT6 mux port: XBAR1_INOUT19 of instance: xbar1
- **111 ALT7** — Select mux mode: ALT7 mux port: ENET_1588_EVENT3_OUT of instance: enet
11.7.51 SW_MUX_CTL_PAD_GPIO_AD_B0_08 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_08)

SW_MUX_CTL Register

Address: 401F_8000h base + DCh offset = 401F_80DCh

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_08 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B0_08 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_AD_B0_08.</td>
</tr>
<tr>
<td></td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: JTAG_MOD of instance: jtag_mux 001 ALT1 — Select mux mode: ALT1 mux port: GPT2_COMPARE3 of instance: gpt2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_08 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: ENET_RX_DATA03 of instance: enet</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI2_RX_DATA of instance: sai2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA05 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO08 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: XBAR1_IN20 of instance: xbar1</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: ENET_1588_EVENT3_IN of instance: enet</td>
</tr>
</tbody>
</table>

11.7.52 SW_MUX_CTL_PAD_GPIO_AD_B0_09 SW MUX Control Register  
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_09)

SW_MUX_CTL Register

Address: 401F_8000h base + E0h offset = 401F_80E0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>- Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
</tbody>
</table>
|       | Software Input On Field.  
Force the selected mux mode Input path no matter of MUX_MODE functionality. |
| 1     | ENABLED — Force input path of pad GPIO_AD_B0_09 |
| 0     | DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field.  
Select one of iomux modes to be used for pad: GPIO_AD_B0_09. |
| 000   | ALT0 — Select mux mode: ALT0 mux port: JTAG_TDI of instance: jtag_mux |
| 001   | ALT1 — Select mux mode: ALT1 mux port: FLEXPWM2_PWMA03 of instance: flexpwm2 |
| 010   | ALT2 — Select mux mode: ALT2 mux port: ENET_RX_DATA02 of instance: enet |
| 011   | ALT3 — Select mux mode: ALT3 mux port: SAI2_TX_DATA of instance: csi |
| 100   | ALT4 — Select mux mode: ALT4 mux port: XBAR1_IN20 of instance: xbar1 |
| 101   | ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO09 of instance: gpio1 |
| 110   | ALT6 — Select mux mode: ALT6 mux port: XBAR1_IN21 of instance: xbar1 |

Table continues on the next page...
### IOMUXC SW_MUX_CTL_PAD_GPIO_AD_B0_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: GPT2_CLK of instance: gpt2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: SEMC_DQS4 of instance: semc</td>
</tr>
</tbody>
</table>

### 11.7.53 SW_MUX_CTL_PAD_GPIO_AD_B0_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_10)

#### SW_MUX_CTL Register

Address: 401F_8000h base + E4h offset = 401F_80E4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_10 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 4     | Software Input On Field.  
Force the selected mux mode Input path no matter of MUX_MODE functionality.  
1 **ENABLED** — Force input path of pad GPIO_AD_B0_10  
0 **DISABLED** — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field.  
Select one of iomux modes to be used for pad: GPIO_AD_B0_10.  
000 **ALT0** — Select mux mode: ALT0 mux port: JTAG_TDO of instance: jtag_mux  
001 **ALT1** — Select mux mode: ALT1 mux port: FLEXPWM1_PWMA03 of instance: flexpwm1  
010 **ALT2** — Select mux mode: ALT2 mux port: ENET_CRS of instance: enet  
011 **ALT3** — Select mux mode: ALT3 mux port: SAI2_MCLK of instance: sai2  
100 **ALT4** — Select mux mode: ALT4 mux port: CSI_DATA03 of instance: csi  
101 **ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO10 of instance: gpio1  
110 **ALT6** — Select mux mode: ALT6 mux port: XBAR1_IN22 of instance: xbar1  
111 **ALT7** — Select mux mode: ALT7 mux port: ENET_1588_EVENT0_OUT of instance: enet  
1000 **ALT8** — Select mux mode: ALT8 mux port: FLEXCAN3_TX of instance: flexcan3/canfd  
1001 **ALT9** — Select mux mode: ALT9 mux port: ARM_TRACE_SWO of instance: cm7_rnx6rt |
11.7.54 SW_MUX_CTL_PAD_GPIO_AD_B0_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_11)

SW_MUX_CTL Register

Address: 401F_8000h base + E8h offset = 401F_80E8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SION</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MUX_MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_AD_B0_11</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_AD_B0_11.</td>
</tr>
</tbody>
</table>

000 ALT0 — Select mux mode: ALT0 mux port: JTAG_TRSTB of instance: jtag_mux
001 ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMB03 of instance: flexpwm1
010 ALT2 — Select mux mode: ALT2 mux port: ENET_COL of instance: enet
011 ALT3 — Select mux mode: ALT3 mux port: WDOG1_WDOG_B of instance: wdog1
100 ALT4 — Select mux mode: ALT4 mux port: CSI_DATA02 of instance: csi
101 ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO11 of instance: gpio1
110 ALT6 — Select mux mode: ALT6 mux port: XBAR1_IN23 of instance: xbar1
111 ALT7 — Select mux mode: ALT7 mux port: ENET_1588_EVENT0_IN of instance: enet
1000 ALT8 — Select mux mode: ALT8 mux port: FLEXCAN3_RX of instance: flexcan3/canfd
1001 ALT9 — Select mux mode: ALT9 mux port: SEMC_CLK6 of instance: semc
11.7.55  **SW_MUX_CTL_PAD_GPIO_AD_B0_12** SW MUX Control Register

**(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_12)**

**SW_MUX_CTL Register**

Address: 401F_8000h base + ECh offset = 401F_80ECh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>SION</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>MUX_MODE</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 0

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_12 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
| SION  | 1  **ENABLED** — Force input path of pad GPIO_AD_B0_12  
0  **DISABLED** — Input Path is determined by functionality |
| 3     | This field is reserved. Reserved |
| MUX_MODE | MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_AD_B0_12.  
000  **ALT0** — Select mux mode: ALT0 mux port: LPi2C4_SCL of instance: lpi2c4  
001  **ALT1** — Select mux mode: ALT1 mux port: CCM_PMIC_READY of instance: ccm |

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_12 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART1_TX of instance: lpuart1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: WDOG2_WDOG_B of instance: wdog2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXPWM1_PWMX02 of instance: flexpwm1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO12 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: ENET_1588_EVENT1_OUT of instance: enet</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: NMI_GLUE_NMI of instance: nmi_glue</td>
</tr>
</tbody>
</table>

### 11.7.56 SW_MUX_CTL_PAD_GPIO_AD_B0_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_13)

**SW_MUX_CTL Register**

Address: 401F_8000h base + F0h offset = 401F_80F0h

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_13 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. SION</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_13 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B0_13.</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
</tbody>
</table>

### 11.7.57 SW_MUX_CTL_PAD_GPIO_AD_B0_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_14)

**SW_MUX_CTL Register**

Address: 401F_8000h base + F4h offset = 401F_80F4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_14 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_14 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B0_14.</td>
</tr>
<tr>
<td></td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: USB_OTG2_OC of instance: usb</td>
</tr>
<tr>
<td></td>
<td>001 ALT1 — Select mux mode: ALT1 mux port: XBAR1_IN24 of instance: xbar1</td>
</tr>
<tr>
<td></td>
<td>010 ALT2 — Select mux mode: ALT2 mux port: LPUART1_CTS_B of instance: lpuart1</td>
</tr>
<tr>
<td></td>
<td>011 ALT3 — Select mux mode: ALT3 mux port: ENET_1588_EVENT0_OUT of instance: enet</td>
</tr>
<tr>
<td></td>
<td>100 ALT4 — Select mux mode: ALT4 mux port: CSI_VSYNC of instance: csi</td>
</tr>
<tr>
<td></td>
<td>101 ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO14 of instance: gpio1</td>
</tr>
<tr>
<td></td>
<td>110 ALT6 — Select mux mode: ALT6 mux port: FLEXCAN2_TX of instance: flexcan2</td>
</tr>
<tr>
<td></td>
<td>1000 ALT8 — Select mux mode: ALT8 mux port: FLEXCAN3_TX of instance: flexcan3/canfd</td>
</tr>
</tbody>
</table>

### 11.7.58 SW_MUX_CTL_PAD_GPIO_AD_B0_15 SW MUX Control Register  
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_15)

**SW_MUX_CTL Register**

Address: 401F_8000h base + F8h offset = 401F_80F8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0000000000000000

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0000000000000000

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_15 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION — Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B0_15</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B0_15.</td>
</tr>
<tr>
<td></td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: USB_OTG2_PWR of instance: usb</td>
</tr>
<tr>
<td></td>
<td>001 ALT1 — Select mux mode: ALT1 mux port: XBAR1_IN25 of instance: xbar1</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
IOMUXC Memory Map/Register Definition

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_15 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART1_RTS_B of instance: lpuart1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_1588_EVENT0_IN of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_HSYNC of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO15 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: FLEXCAN2_RX of instance: flexcan2</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: WDOG1_WDOG_RST_B_DEB of instance: wdog1</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: FLEXCAN3_RX of instance: flexcan3/canfd</td>
</tr>
</tbody>
</table>

11.7.59 SW_MUX_CTL_PAD_GPIO_AD_B1_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_00)

SW_MUX_CTL Register

Address: 401F_8000h base + FCh offset = 401F_80FCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_AD_B1_00</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_00.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USB_OTG2_ID of instance: anatop</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER3_TIMER0 of instance: qtimer3</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART2_CTS_B of instance: lpuart2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPI2C1_SCL of instance: lpi2c1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: WDOG1_B of instance: wdog1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO16 of instance: gpio1</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_00 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC1_WP of instance: usdhc1</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: KPP_ROW07 of instance: kpp</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_1588_EVENT0_OUT of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO00 of instance: flexio3</td>
</tr>
</tbody>
</table>

### 11.7.60 SW_MUX_CTL_PAD_GPIO_AD_B1_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_01)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 100h offset = 401F_8100h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td></td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_AD_B1_01</td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_01.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USB_OTG1_PWR of instance: usb</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER3_TIMER1 of instance: qtimer3</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART2_RTS_B of instance: lpuart2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPI2C1_SDA of instance: lpi2c1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CCM_PMIC_READY of instance: ccm</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO17 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC1_VSELECT of instance: usdhc1</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: KPP_COL07 of instance: kpp</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_1588_EVENT0_IN of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO001 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.61  SW_MUX_CTL_PAD_GPIO_AD_B1_02 SW MUX Control Register
       (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_02)

SW_MUX_CTL Register

Address: 401F_8000h base + 104h offset = 401F_8104h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_02 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B1_02 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_02.</td>
</tr>
<tr>
<td></td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: USB_OTG1_ID of instance: anatop</td>
</tr>
<tr>
<td></td>
<td>001 ALT1 — Select mux mode: ALT1 mux port: QTIMER3_TIMER2 of instance: qtimer3</td>
</tr>
<tr>
<td></td>
<td>010 ALT2 — Select mux mode: ALT2 mux port: LPUART2_TX of instance: lpuart2</td>
</tr>
<tr>
<td></td>
<td>011 ALT3 — Select mux mode: ALT3 mux port: SPDIF_OUT of instance: spdif</td>
</tr>
<tr>
<td></td>
<td>100 ALT4 — Select mux mode: ALT4 mux port: ENET_1588_EVENT2_OUT of instance: enet</td>
</tr>
<tr>
<td></td>
<td>101 ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO18 of instance: gpio1</td>
</tr>
<tr>
<td></td>
<td>110 ALT6 — Select mux mode: ALT6 mux port: USDHC1_CD_B of instance: usdhc1</td>
</tr>
<tr>
<td></td>
<td>111 ALT7 — Select mux mode: ALT7 mux port: KPP_ROW06 of instance: kpp</td>
</tr>
<tr>
<td></td>
<td>1000 ALT8 — Select mux mode: ALT8 mux port: GPT2_CLK of instance: gpt2</td>
</tr>
<tr>
<td></td>
<td>1001 ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO02 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.62  SW_MUX_CTL_PAD_GPIO_AD_B1_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_03)

SW_MUX_CTL Register

Address: 401F_8000h base + 108h offset = 401F_8108h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_AD_B1_03</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_03.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USB_OTG1_OC of instance: usb</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER3_TIMER3 of instance: qtimer3</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART2_RX of instance: lpuart2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SPDIF_IN of instance: spdif</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: ENET_1588_EVENT2_IN of instance: enet</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO19 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC2_CD_B of instance: usdhc2</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: KPP_COL06 of instance: kpp</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: GPT2_CAPTURE1 of instance: gpt2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO03 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.63 SW_MUX_CTL_PAD_GPIO_AD_B1_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_04)

SW_MUX_CTL Register

Address: 401F_8000h base + 10Ch offset = 401F_810Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>Reserved</td>
<td>SION</td>
<td>MUX_MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_04 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B1_04 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_04.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: FLEXSPIB_DATA03 of instance: flexspi</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: ENET_MDC of instance: enet</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART3_CTS_B of instance: lpuart3</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SPDIF_SR_CLK of instance: spdif</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_PIXCLK of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO20 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC2_DATA0 of instance: usdhc2</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: KPP_ROW05 of instance: kpp</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: GPT2_CAPTURE2 of instance: gpt2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO04 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.64 SW_MUX_CTL_PAD_GPIO_AD_B1_05 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_05)

SW_MUX_CTL Register

Address: 401F_8000h base + 110h offset = 401F_8110h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>SION</td>
<td>MUX_MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>FORCE 1 ENABED — Force input path of pad GPIO_AD_B1_05, DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_05.</td>
</tr>
</tbody>
</table>

0000 _ALT0_ — Select mux mode: ALT0 mux port: FLEXSPIB_DATA02 of instance: flexspi
0001 _ALT1_ — Select mux mode: ALT1 mux port: ENET_MDIOf instance: enet
0010 _ALT2_ — Select mux mode: ALT2 mux port: LPUART3_RTS_B of instance: lpuart3
0011 _ALT3_ — Select mux mode: ALT3 mux port: SPDIF_OUT of instance: spdif
1000 _ALT4_ — Select mux mode: ALT4 mux port: CSI_MCLK of instance: csi
1001 _ALT5_ — Select mux mode: ALT5 mux port: GPIO1_IO21 of instance: gpio1
1100 _ALT6_ — Select mux mode: ALT6 mux port: USDHC2_DATA1 of instance: usdhc2
1101 _ALT7_ — Select mux mode: ALT7 mux port: KPP_COL05 of instance: kpp
10000 _ALT8_ — Select mux mode: ALT8 mux port: GPT2_COMPARE1 of instance: gpt2
10001 _ALT9_ — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO05 of instance: flexio3
11.7.65 **SW_MUX_CTL_PAD_GPIO_AD_B1_06 SW MUX Control Register**  
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_06)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 114h offset = 401F_8114h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td>SION</td>
</tr>
<tr>
<td>8</td>
<td>R/W</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td>MUX_MODE</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_06 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
| SION  | 1 ENABLED — Force input path of pad GPIO_AD_B1_06  
|       | 0 DISABLED — Input path is determined by functionality |
| MUX_MODE | MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_06. |

000 **ALT0** — Select mux mode: ALT0 mux port: FLEXSPIB_DATA01 of instance: flexspi  
001 **ALT1** — Select mux mode: ALT1 mux port: LPI2C3_SDA of instance: lpi2c3  
010 **ALT2** — Select mux mode: ALT2 mux port: LPUART3_TX of instance: lpuart3  
011 **ALT3** — Select mux mode: ALT3 mux port: SPDIF_LOCK of instance: spdif  
100 **ALT4** — Select mux mode: ALT4 mux port: CSI_VSYNC of instance: csi  
101 **ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO22 of instance: gpio1  
110 **ALT6** — Select mux mode: ALT6 mux port: USDHC2_DATA2 of instance: usdhc2  
111 **ALT7** — Select mux mode: ALT7 mux port: KPP_ROW04 of instance: kpp  
1000 **ALT8** — Select mux mode: ALT8 mux port: GPT2_COMPARE2 of instance: gpt2  
1001 **ALT9** — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO06 of instance: flexio3
11.7.66  SW_MUX_CTL_PAD_GPIO_AD_B1_07 SW MUX Control
Register  
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_07)

SW_MUX_CTL Register

Address: 401F_8000h base + 118h offset = 401F_8118h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
| SION  | **ENABLED** — Force input path of pad GPIO_AD_B1_07  
|       | **DISABLED** — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_07.  
|        | **ALT0** — Select mux mode: ALT0 mux port: FLEXSPIB_DATA00 of instance: flexspi  
|        | **ALT1** — Select mux mode: ALT1 mux port: LPI2C3_SCL of instance: lpi2c3  
|        | **ALT2** — Select mux mode: ALT2 mux port: LPUART3_RX of instance: lpuart3  
|        | **ALT3** — Select mux mode: ALT3 mux port: SPDIF_EXT_CLK of instance: spdif  
|        | **ALT4** — Select mux mode: ALT4 mux port: CSI_HSYNC of instance: csi  
|        | **ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO23 of instance: gpio1  
|        | **ALT6** — Select mux mode: ALT6 mux port: USDHC2_DATA3 of instance: usdhc2  
|        | **ALT7** — Select mux mode: ALT7 mux port: KPP_COL04 of instance: kpp  
|        | **ALT8** — Select mux mode: ALT8 mux port: GPT2_COMPARE3 of instance: gpt2  
|        | **ALT9** — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO07 of instance: flexio3 |
11.7.67  SW_MUX_CTL_PAD_GPIO_AD_B1_08 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_08)

SW_MUX_CTL Register

Address: 401F_8000h base + 11Ch offset = 401F_811Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

Field descriptions for IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_08:

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td></td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B1_08</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_AD_B1_08.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: FLEXSPIA_SS1_B of instance: flexspi</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM4_PWMA00 of instance: flexpwm4</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXCAN1_TX of instance: flexcan1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: CCM_PMIC_READY of instance: ccm</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA09 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO24 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC2_CMD of instance: usdhc2</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: KPP_ROW03 of instance: kpp</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO08 of instance: flexio3</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL_PAD_GPIO_AD_B1_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_09)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 120h offset = 401F_8120h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_09 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B1_09 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_09.</td>
</tr>
</tbody>
</table>

- 000 **ALT0** — Select mux mode: ALT0 mux port: FLEXSPIA_DQS of instance: flexspi
- 001 **ALT1** — Select mux mode: ALT1 mux port: FLEXPWM4_PWMA01 of instance: flexpwm4
- 010 **ALT2** — Select mux mode: ALT2 mux port: FLEXCAN1_RX of instance: flexcan1
- 011 **ALT3** — Select mux mode: ALT3 mux port: SAI1_MCLK of instance: sai1
- 100 **ALT4** — Select mux mode: ALT4 mux port: CSI_DATA08 of instance: csi
- 101 **ALT5** — Select mux mode: ALT5 mux port: GPIO1_IO25 of instance: gpio1
- 110 **ALT6** — Select mux mode: ALT6 mux port: USDHC2_CLK of instance: usdhc2
- 111 **ALT7** — Select mux mode: ALT7 mux port: KPP_COL03 of instance: kpp
- 1001 **ALT9** — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO09 of instance: flexio3
11.7.69 SW_MUX_CTL_PAD_GPIO_AD_B1_10 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_10)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 124h offset = 401F_8124h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_10 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 4     | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.  
1 ENABLED — Force input path of pad GPIO_AD_B1_10  
0 DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field.  
Select one of iomux modes to be used for pad: GPIO_AD_B1_10.  
000 ALT0 — Select mux mode: ALT0 mux port: FLEXSPIA_DATA03 of instance: flexspi  
001 ALT1 — Select mux mode: ALT1 mux port: WDOG1_B of instance: wdog1  
010 ALT2 — Select mux mode: ALT2 mux port: LPUART8_TX of instance: lputa8  
011 ALT3 — Select mux mode: ALT3 mux port: SAI1_RX_SYNC of instance: sai1  
100 ALT4 — Select mux mode: ALT4 mux port: CSI_DATA07 of instance: csi  
101 ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO26 of instance: gpio1  
110 ALT6 — Select mux mode: ALT6 mux port: USDH2_WP of instance: usdhc2  
111 ALT7 — Select mux mode: ALT7 mux port: KPP_ROW02 of instance: kpp  
1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_1588_EVENT1_OUT of instance: enet2  
1001 ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO10 of instance: flexio3 |
11.7.70   **SW_MUX_CTL_PAD_GPIO_AD_B1_11 SW MUX Control Register**  
(\texttt{IOMUXC\_SW\_MUX\_CTL\_PAD\_GPIO\_AD\_B1\_11})

**SW_MUX_CTL Register**

Address: 401F\_8000h base + 128h offset = 401F\_8128h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC\_SW\_MUX\_CTL\_PAD\_GPIO\_AD\_B1\_11 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4 SION</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 \textbf{ENABLED} — Force input path of pad GPIO_AD_B1_11</td>
</tr>
<tr>
<td></td>
<td>0 \textbf{DISABLED} — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_11.</td>
</tr>
<tr>
<td>000</td>
<td>\textbf{ALT0} — Select mux mode: ALT0 mux port: FLEXSPIA_DATA02 of instance: flexspi</td>
</tr>
<tr>
<td>001</td>
<td>\textbf{ALT1} — Select mux mode: ALT1 mux port: EWM_OUT_B of instance: ewm</td>
</tr>
<tr>
<td>010</td>
<td>\textbf{ALT2} — Select mux mode: ALT2 mux port: LPUART8_RX of instance: lpuart8</td>
</tr>
<tr>
<td>011</td>
<td>\textbf{ALT3} — Select mux mode: ALT3 mux port: SAI1_RX_BCLK of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>\textbf{ALT4} — Select mux mode: ALT4 mux port: CSI_DATA06 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>\textbf{ALT5} — Select mux mode: ALT5 mux port: GPIO1_IO27 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>\textbf{ALT6} — Select mux mode: ALT6 mux port: USDHC2_RESET_B of instance: usdhc2</td>
</tr>
<tr>
<td>111</td>
<td>\textbf{ALT7} — Select mux mode: ALT7 mux port: KPP_COL02 of instance: kpp</td>
</tr>
<tr>
<td>1000</td>
<td>\textbf{ALT8} — Select mux mode: ALT8 mux port: ENET2_1588_EVENT1_IN of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>\textbf{ALT9} — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO11 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.71  SW_MUX_CTL_PAD_GPIO_AD_B1_12 SW MUX Control Register  
(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_12)

SW_MUX_CTL Register

Address: 401F_8000h base + 12Ch offset = 401F_812Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B1_12</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iOMUX modes to be used for pad: GPIO_AD_B1_12.</td>
</tr>
<tr>
<td>000 ALT0</td>
<td>Select mux mode: ALT0 mux port: FLEXSPIA_DATA01 of instance: flexspi</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>Select mux mode: ALT1 mux port: ACMP_OUT00 of instance: acmp</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>Select mux mode: ALT2 mux port: LPSPI3_PCS0 of instance: lpspi3</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: SAI1_RX_DATA00 of instance: sai1</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: CSI_DATA05 of instance: csi</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO1_IO28 of instance: gpio1</td>
</tr>
<tr>
<td>110 ALT6</td>
<td>Select mux mode: ALT6 mux port: USDHHC2_DATA4 of instance: usdhc2</td>
</tr>
<tr>
<td>111 ALT7</td>
<td>Select mux mode: ALT7 mux port: KPP_ROW01 of instance: kpp</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>Select mux mode: ALT8 mux port: ENET2_1588_EVENT2_OUT of instance: enet2</td>
</tr>
<tr>
<td>1001 ALT9</td>
<td>Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO12 of instance: flexio3</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL_PAD_GPIO_AD_B1_13 SW MUX Control Register

**(IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_13)**

#### SW_MUX_CTL Register

Address: 401F_8000h base + 130h offset = 401F_8130h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_13 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 <strong>ENABLED</strong> — Force input path of pad GPIO_AD_B1_13 0 <strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_AD_B1_13. 000 <strong>ALT0</strong> — Select mux mode: ALT0 mux port: FLEXSPIA_DATA00 of instance: flexspi 001 <strong>ALT1</strong> — Select mux mode: ALT1 mux port: ACMP_OUT01 of instance: acmp 010 <strong>ALT2</strong> — Select mux mode: ALT2 mux port: LPSPI3_SDI of instance: lpspi3 011 <strong>ALT3</strong> — Select mux mode: ALT3 mux port: SAI1_TX_DATA00 of instance: sai1 100 <strong>ALT4</strong> — Select mux mode: ALT4 mux port: CSI_DATA04 of instance: csi 101 <strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO1_IO29 of instance: gpio1 110 <strong>ALT6</strong> — Select mux mode: ALT6 mux port: USDHC2_DATA5 of instance: usdhc2 111 <strong>ALT7</strong> — Select mux mode: ALT7 mux port: KPP_COL01 of instance: kpp 1000 <strong>ALT8</strong> — Select mux mode: ALT8 mux port: ENET2_1588_EVENT2_IN of instance: enet2 1001 <strong>ALT9</strong> — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO13 of instance: flexio3</td>
</tr>
</tbody>
</table>
### 11.7.73 SW_MUX_CTL_PAD_GPIO_AD_B1_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_14)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 134h offset = 401F_8134h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>30</td>
<td>29</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>14</td>
<td>13</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>Enable/disabling of SION input path.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_AD_B1_14</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_AD_B1_14.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: FLEXSPIA_SCLK of instance: flexspi</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: ACMP_OUT02 of instance: acmp</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPSPI3_SDO of instance: lspi3</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_BCLK of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA03 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO30 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC2_DATA6 of instance: usdhc2</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: KPP_ROW00 of instance: kpp</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_1588_EVENT3_OUT of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO14 of instance: flexio3</td>
</tr>
</tbody>
</table>
## 11.7.74 SW_MUX_CTL_PAD_GPIO_AD_B1_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_15)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 138h offset = 401F_8138h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td>SION</td>
<td>Force the selected mux modeInput path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_AD_B1_15</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_AD_B1_15.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: FLEXSPIA_SS0_B of instance: flexspi</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: ACMP_OUT03 of instance: acmp</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPSPI3_SCK of instance: lspi3</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_SYNC of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: CSI_DATA02 of instance: csi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO1_IO31 of instance: gpio1</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC2_DATA7 of instance: usdhc2</td>
</tr>
<tr>
<td>111</td>
<td>ALT7 — Select mux mode: ALT7 mux port: KPP_COL00 of instance: kpp</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_1588_EVENT3_IN of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO15 of instance: flexio3</td>
</tr>
</tbody>
</table>
### 11.7.75 SW_MUX_CTL_PAD_GPIO_B0_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_00)

**SW_MUX_CTL Register**

Address: \(401F_{\text{h}}\_8000\)h base + 13Ch offset = 401F\_813Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>24</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>22</td>
<td>21</td>
</tr>
<tr>
<td>20</td>
<td>19</td>
<td>18</td>
</tr>
<tr>
<td>17</td>
<td>16</td>
<td>15</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_00 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
| SION  | 1 ENABLED — Force input path of pad GPIO_B0_00  
0 DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field.  
Select one of iomux modes to be used for pad: GPIO_B0_00.  
000 ALT0 — Select mux mode: ALT0 mux port: LCD_CLK of instance: lcdif  
001 ALT1 — Select mux mode: ALT1 mux port: QTIMER1_TIMER0 of instance: qtimer1  
010 ALT2 — Select mux mode: ALT2 mux port: MQS_RIGHT of instance: mqs  
011 ALT3 — Select mux mode: ALT3 mux port: LPSPI4_PCS0 of instance: lpspi4  
100 ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO00 of instance: flexio2  
101 ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO00 of instance: gpio2  
110 ALT6 — Select mux mode: ALT6 mux port: SEMC_CSX01 of instance: semc  
1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_MDC of instance: enet2 |
### SW_MUX_CTL_REG Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_01)

**Address:** 401F_8000h base + 140h offset = 401F_8140h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 4 | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.  
   1 ENABLED — Force input path of pad GPIO_B0_01  
   0 DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_B0_01.  
   000 ALT0 — Select mux mode: ALT0 mux port: LCD_ENABLE of instance: lcdif  
   001 ALT1 — Select mux mode: ALT1 mux port: QTIMER1_TIMER1 of instance: qtimer1  
   010 ALT2 — Select mux mode: ALT2 mux port: MQS_LEFT of instance: mqs  
   011 ALT3 — Select mux mode: ALT3 mux port: LPSPI4_SDI of instance: lpspi4  
   100 ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO01 of instance: flexio2  
   101 ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO01 of instance: gpio2  
   110 ALT6 — Select mux mode: ALT6 mux port: SEMC_CSX02 of instance: semc  
   1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_MDIO of instance: enet2 |
### 11.7.77 SW_MUX_CTL_PAD_GPIO_B0_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_02)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 144h offset = 401F_8144h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>31-5</th>
<th>4</th>
<th>15-11</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_02 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
</tbody>
</table>

- **Reserved**: This field is reserved.
- **SION**: Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_B0_02</td>
</tr>
</tbody>
</table>

- **MUX_MODE**: Select one of iomux modes to be used for pad: GPIO_B0_02

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_HSYNC of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER1_TIMER2 of instance: qtimer1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXCAN1_TX of instance: flexcan1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPSPI4_SDO of instance: lpspi4</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO02 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO02 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SEMC_CSX03 of instance: semc</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_1588_EVENT0_OUT of instance: enet2</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL_PAD_GPIO_B0_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_03)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 148h offset = 401F_8148h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_03 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_B0_03</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B0_03.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_VSYNC of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER2_TIMER0 of instance: qtimer2</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXCAN1_RX of instance: flexcan1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPSPI4_SCK of instance: lpspi4</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO03 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO03 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: WDOG2_RESET_B_DEB of instance: wdog2</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_1588_EVENT0_IN of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.79  SW_MUX_CTL_PAD_GPIO_B0_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_04)

SW_MUX_CTL Register

Address: 401F_8000h base + 14Ch offset = 401F_814Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td>SION</td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1  ENABLED — Force input path of pad GPIO_B0_04</td>
</tr>
<tr>
<td></td>
<td>0  DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_B0_04.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA00 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER2_TIMER1 of instance: qtimer2</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPI2C2_SCL of instance: lpi2c2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ARM_TRACE0 of instance: cm7_mx6rt</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO04 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO04 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG00 of instance: src</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_TDATA03 of instance: enet2</td>
</tr>
</tbody>
</table>
### 11.7.80 SW_MUX_CTL_PAD_GPIO_B0_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_05)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 150h offset = 401F_8150h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>R/W</td>
<td>SION</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_B0_05</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>MUX_MODE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000 ALT0 — Select mux mode: ALT0 mux port: LCD_DATA01 of instance: lcdif</td>
<td></td>
</tr>
<tr>
<td>001 ALT1 — Select mux mode: ALT1 mux port: QTIMER2_TIMER2 of instance: qtimer2</td>
<td></td>
</tr>
<tr>
<td>010 ALT2 — Select mux mode: ALT2 mux port: LPI2C2_SDA of instance: lpi2c2</td>
<td></td>
</tr>
<tr>
<td>011 ALT3 — Select mux mode: ALT3 mux port: ARM_TRACE1 of instance: cm7_mx6rt</td>
<td></td>
</tr>
<tr>
<td>100 ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO05 of instance: flexio2</td>
<td></td>
</tr>
<tr>
<td>101 ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO05 of instance: gpio2</td>
<td></td>
</tr>
<tr>
<td>110 ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG01 of instance: src</td>
<td></td>
</tr>
<tr>
<td>1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_TDATA02 of instance: enet2</td>
<td></td>
</tr>
</tbody>
</table>
11.7.81 SW_MUX_CTL_PAD_GPIO_B0_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_06)

SW_MUX_CTL Register

Address: 401F_8000h base + 154h offset = 401F_8154h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_06 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>Force input path of pad GPIO_B0_06</td>
</tr>
<tr>
<td></td>
<td>Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_B0_06.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA02 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER3_TIMER0 of instance: qtimer3</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXPWM2_PWMA00 of instance: flexpwm2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ARM_TRACE2 of instance: cm7_mx6rt</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO06 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO06 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG02 of instance: src</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_RX_CLK of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.82  SW_MUX_CTL_PAD_GPIO_B0_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_07)

SW_MUX_CTL Register

Address: 401F_8000h base + 158h offset = 401F_8158h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1  ENABLED — Force input path of pad GPIO_B0_07</td>
</tr>
<tr>
<td></td>
<td>0  DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B0_07.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA03 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER3_TIMER1 of instance: qtimer3</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXPWM2_PWMB00 of instance: flexpwm2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ARM_TRACE3 of instance: cm7_mx6rt</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO07 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO07 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG03 of instance: src</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_TX_ER of instance: enet2</td>
</tr>
</tbody>
</table>
### 11.7.83 SW_MUX_CTL_PAD_GPIO_B0_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_08)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 15Ch offset = 401F_815Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31-5 | This field is reserved.  
|      | Reserved   |
| 4   | Software Input On Field.  
| SION | Force the selected mux mode Input path no matter of MUX_MODE functionality.  
|      | 1 ENABLED — Force input path of pad GPIO_B0_08  
|      | 0 DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field.  
| | Select one of iomux modes to be used for pad: GPIO_B0_08.  
| 000 | ALT0 — Select mux mode: ALT0 mux port: LCD_DATA04 of instance: lcdif  
| 001 | ALT1 — Select mux mode: ALT1 mux port: QTIMER3_TIMER2 of instance: qtimer3  
| 010 | ALT2 — Select mux mode: ALT2 mux port: FLEXPWM2_PWMA01 of instance: flexpwm2  
| 011 | ALT3 — Select mux mode: ALT3 mux port: LPUART3_TX of instance: lpuart3  
| 100 | ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO08 of instance: flexio2  
| 101 | ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO08 of instance: gpio2  
| 110 | ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG04 of instance: src  
| 1000 | ALT8 — Select mux mode: ALT8 mux port: ENET2_RDATA03 of instance: enet2 |
11.7.84 SW_MUX_CTL_PAD_GPIO_B0_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_09)

SW_MUX_CTL Register

Address: 401F_8000h base + 160h offset = 401F_8160h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_B0_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>0-16</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B0_09.</td>
</tr>
</tbody>
</table>

- **ALT0** — Select mux mode: ALT0 mux port: LCD_DATA05 of instance: lcdif
- **ALT1** — Select mux mode: ALT1 mux port: QTIMER4_TIMER0 of instance: qtimer4
- **ALT2** — Select mux mode: ALT2 mux port: FLEXPWM2_PWMB01 of instance: flexpwm2
- **ALT3** — Select mux mode: ALT3 mux port: LPUART3_RX of instance: lpuart3
- **ALT4** — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO09 of instance: flexio2
- **ALT5** — Select mux mode: ALT5 mux port: GPIO2_IO09 of instance: gpio2
- **ALT6** — Select mux mode: ALT6 mux port: SRC_BOOT_CFG05 of instance: src
- **ALT8** — Select mux mode: ALT8 mux port: ENET2_RDATA02 of instance: enet2
11.7.85  SW_MUX_CTL_PAD_GPIO_B0_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_10)

SW_MUX_CTL Register

Address: 401F_8000h base + 164h offset = 401F_8164h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td></td>
<td></td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>R</td>
<td>W</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td>ENABLED — Force input path of pad GPIO_B0_10</td>
</tr>
<tr>
<td></td>
<td>0</td>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_B0_10</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA06 of instance: lcdif</td>
<td></td>
<td></td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER4_TIMER1 of instance: qtimer4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXPWM2_PWMA02 of instance: flexpwm2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_DATA03 of instance: sai1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO10 of instance: flexio2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO10 of instance: gpio2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG06 of instance: src</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_CRS of instance: enet2</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
11.7.86 SW_MUX_CTL_PAD_GPIO_B0_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_11)

SW_MUX_CTL Register

Address: 401F_8000h base + 168h offset = 401F_8168h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_B0_11</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_B0_11.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA07 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER4_TIMER2 of instance: qtimer4</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXPWM2_PWMB02 of instance: flexpwm2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_DATA02 of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO11 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO11 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG07 of instance: src</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_COL of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.87 SW_MUX_CTL_PAD_GPIO_B0_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_12)

SW_MUX_CTL Register

Address: 401F_8000h base + 16Ch offset = 401F_816Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td></td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td></td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA08 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: XBAR1_INOUT10 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: ARM_TRACE_CLK of instance: cm7_mx6rt</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_DATA01 of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO12 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO12 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG08 of instance: src</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_TDATA00 of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.88  SW_MUX_CTL_PAD_GPIO_B0_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_13)

SW_MUX_CTL Register

Address: 401F_8000h base + 170h offset = 401F_8170h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>15</td>
<td>14</td>
<td>13</td>
</tr>
<tr>
<td>Bit</td>
<td>R</td>
<td>W</td>
<td>Reset</td>
</tr>
<tr>
<td>-----</td>
<td>---</td>
<td>---</td>
<td>-------</td>
</tr>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_13 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>enabled --- Force input path of pad GPIO_B0_13</td>
</tr>
<tr>
<td></td>
<td>0   DISABLED --- Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B0_13.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0  --- Select mux mode: ALT0 mux port: LCD_DATA09 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1  --- Select mux mode: ALT1 mux port: XBAR1_INOUT11 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2  --- Select mux mode: ALT2 mux port: ARM_TRACE_SWO of instance: cm7_mx6rt</td>
</tr>
<tr>
<td>011</td>
<td>ALT3  --- Select mux mode: ALT3 mux port: SAI1_MCLK of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4  --- Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO13 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5  --- Select mux mode: ALT5 mux port: GPIO2_IO13 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6  --- Select mux mode: ALT6 mux port: SRC_BOOT_CFG09 of instance: src</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8  --- Select mux mode: ALT8 mux port: ENET2_TDATA01 of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.89 SW_MUX_CTL_PAD_GPIO_B0_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_14)

SW_MUX_CTL Register

Address: 401F_8000h base + 174h offset = 401F_8174h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_B0_14</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B0_14.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA10 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: XBAR1_INOUT12 of instance: xbar1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: ARM_TXEV of instance: cm7_mx6rt</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_RX_SYNC of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO14 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO14 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG10 of instance: src</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_TX_EN of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.90 SW_MUX_CTL_PAD_GPIO_B0_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_15)

SW_MUX_CTL Register

Address: 401F_8000h base + 178h offset = 401F_8178h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_B0_15</td>
</tr>
<tr>
<td></td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B0_15.</td>
</tr>
<tr>
<td></td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: LCD_DATA11 of instance: lcdif</td>
</tr>
<tr>
<td></td>
<td>001 ALT1 — Select mux mode: ALT1 mux port: XBAR1_INOUT13 of instance: xbar1</td>
</tr>
<tr>
<td></td>
<td>010 ALT2 — Select mux mode: ALT2 mux port: ARM_RXEV of instance: cm7_mx6rt</td>
</tr>
<tr>
<td></td>
<td>011 ALT3 — Select mux mode: ALT3 mux port: SAI1_RX_BCLK of instance: sai1</td>
</tr>
<tr>
<td></td>
<td>100 ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO15 of instance: flexio2</td>
</tr>
<tr>
<td></td>
<td>101 ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO15 of instance: gpio2</td>
</tr>
<tr>
<td></td>
<td>110 ALT6 — Select mux mode: ALT6 mux port: SRC_BOOT_CFG11 of instance: src</td>
</tr>
<tr>
<td></td>
<td>1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_TX_CLK of instance: enet2</td>
</tr>
<tr>
<td></td>
<td>1001 ALT9 — Select mux mode: ALT9 mux port: ENET2_REF_CLK of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.91  SW_MUX_CTL_PAD_GPIO_B1_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_00)

SW_MUX_CTL Register

Address: 401F_8000h base + 17Ch offset = 401F_817Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>16384</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4 SION</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_B1_00</td>
</tr>
<tr>
<td>SION</td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_00.</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: LCD_DATA12 of instance: lcdif</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>001 ALT1 — Select mux mode: ALT1 mux port: XBAR1_INOUT14 of instance: xbar1</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>010 ALT2 — Select mux mode: ALT2 mux port: LPUART4_TX of instance: lpuart4</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>011 ALT3 — Select mux mode: ALT3 mux port: SAI1_RX_DATA00 of instance: sai1</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>100 ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO16 of instance: flexio2</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>101 ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO16 of instance: gpio2</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>110 ALT6 — Select mux mode: ALT6 mux port: FLEXPWM1_PWMA03 of instance: flexpwm1</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_RX_ER of instance: enet2</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>1001 ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO16 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.92  SW_MUX_CTL_PAD_GPIO_B1_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_01)

SW_MUX_CTL Register

Address: 401F_8000h base + 180h offset = 401F_8180h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–0</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>R/W</td>
<td>MUX_MODE</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td>SION</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_B1_01 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad GPIO_B1_01.</td>
</tr>
</tbody>
</table>

000 ALT0 — Select mux mode: ALT0 mux port: LCD_DATA13 of instance: lcdif
001 ALT1 — Select mux mode: ALT1 mux port: XBAR1_INOUT15 of instance: xbar1
010 ALT2 — Select mux mode: ALT2 mux port: LPUART4_RX of instance: lpuart4
011 ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_DATA00 of instance: sai1
100 ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO17 of instance: flexio2
101 ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO17 of instance: gpio2
110 ALT6 — Select mux mode: ALT6 mux port: FLEXPWM1_PWMB03 of instance: flexpwm1
1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_RDATA00 of instance: enet2
1001 ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO17 of instance: flexio3
### 11.7.93 SW_MUX_CTL_PAD_GPIO_B1_02 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_02)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 184h offset = 401F_8184h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_02 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 4     | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.  
| SION  | ENABLED — Force input path of pad GPIO_B1_02  
|       | DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field.  
|         | Select one of iOMUX modes to be used for pad: GPIO_B1_02  
| 000 ALT0 | — Select mux mode: ALT0 mux port: LCD_DATA14 of instance: lcdif  
| 001 ALT1 | — Select mux mode: ALT1 mux port: XBAR1_INOUT16 of instance: xbar1  
| 010 ALT2 | — Select mux mode: ALT2 mux port: LPSPI4_PCS2 of instance: lpspi4  
| 011 ALT3 | — Select mux mode: ALT3 mux port: SAI1_TX_BCLK of instance: sai1  
| 100 ALT4 | — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO18 of instance: flexio2  
| 101 ALT5 | — Select mux mode: ALT5 mux port: GPIO2_IO18 of instance: gpio2  
| 110 ALT6 | — Select mux mode: ALT6 mux port: FLEXPWM2_PWMA03 of instance: flexpwm2  
| 1000 ALT8 | — Select mux mode: ALT8 mux port: ENET2_RDATA01 of instance: enet2  
| 1001 ALT9 | — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO18 of instance: flexio3  

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
11.7.94 SW_MUX_CTL_PAD_GPIO_B1_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_03)

SW_MUX_CTL Register

Address: 401F_8000h base + 188h offset = 401F_8188h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td></td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_03.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALT0</td>
<td>Select mux mode: ALT0 mux port: LCD_DATA15 of instance: lcdif</td>
</tr>
<tr>
<td>ALT1</td>
<td>Select mux mode: ALT1 mux port: XBAR1_INOUT17 of instance: xbar1</td>
</tr>
<tr>
<td>ALT2</td>
<td>Select mux mode: ALT2 mux port: LPSPI4_PCS1 of instance: lpspi4</td>
</tr>
<tr>
<td>ALT3</td>
<td>Select mux mode: ALT3 mux port: SAI1_TX_SYNC of instance: sai1</td>
</tr>
<tr>
<td>ALT4</td>
<td>Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO19 of instance: flexio2</td>
</tr>
<tr>
<td>ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO2_IO19 of instance: gpio2</td>
</tr>
<tr>
<td>ALT6</td>
<td>Select mux mode: ALT6 mux port: FLEXPWM2_PWMB03 of instance: flexpwm2</td>
</tr>
<tr>
<td>ALT8</td>
<td>Select mux mode: ALT8 mux port: ENET2_RX_EN of instance: enet2</td>
</tr>
<tr>
<td>ALT9</td>
<td>Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO19 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.95  SW_MUX_CTL_PAD_GPIO_B1_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_04)

SW_MUX_CTL Register

Address: 401F_8000h base + 18Ch offset = 401F_818Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_04 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_B1_04 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_04. 000 ALT0 — Select mux mode: ALT0 mux port: LCD_DATA16 of instance: lcdif 001 ALT1 — Select mux mode: ALT1 mux port: LPSPI4_PCS0 of instance: lpspi4 010 ALT2 — Select mux mode: ALT2 mux port: CSI_DATA15 of instance: csi 011 ALT3 — Select mux mode: ALT3 mux port: ENET_RX_DATA00 of instance: enet 100 ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO20 of instance: flexio2 101 ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO20 of instance: gpio2 1000 ALT8 — Select mux mode: ALT8 mux port: GPT1_CLK of instance: gpt1 1001 ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO20 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.96 SW_MUX_CTL_PAD_GPIO_B1_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_05)

SW_MUX_CTL Register

Address: 401F_8000h base + 190h offset = 401F_8190h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**Field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
| SION  | 1 **ENABLED** — Force input path of pad GPIO_B1_05  
0 **DISABLED** — Input Path is determined by functionality |

**MUX_MODE** | MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_B1_05. |

| 000   | ALT0 — Select mux mode: ALT0 mux port: LCD_DATA17 of instance: lcdif |
| 001   | ALT1 — Select mux mode: ALT1 mux port: LPSPI4_SDI of instance: lpspi4 |
| 010   | ALT2 — Select mux mode: ALT2 mux port: CSI_DATA14 of instance: csi |
| 011   | ALT3 — Select mux mode: ALT3 mux port: ENET_RX_DATA01 of instance: enet |
| 100   | ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO21 of instance: flexio2 |
| 101   | ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO21 of instance: gpio2 |
| 1000  | ALT8 — Select mux mode: ALT8 mux port: GPT1_CAPTURE1 of instance: gpt1 |
| 1001  | ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO21 of instance: flexio3 |
11.7.97 SW_MUX_CTL_PAD_GPIO_B1_06 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_06)

SW_MUX_CTL Register

Address: 401F_8000h base + 194h offset = 401F_8194h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED</td>
</tr>
<tr>
<td>15–0</td>
<td>MUX_MODE</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_06 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED</td>
</tr>
<tr>
<td>15–0</td>
<td>MUX_MODE</td>
</tr>
</tbody>
</table>

Field            Description
31–5      - Reserved
4         SION Software Input On Field.
1         ENABLED — Force input path of pad GPIO_B1_06
0         DISABLED — Input Path is determined by functionality
MUX_MODE MUX Mode Select Field.
Select one of iomux modes to be used for pad: GPIO_B1_06.
000      ALT0 — Select mux mode: ALT0 mux port: LCD_DATA18 of instance: lcdif
001      ALT1 — Select mux mode: ALT1 mux port: LPSPi4_SDO of instance: lpspi4
010      ALT2 — Select mux mode: ALT2 mux port: CSI_DATA13 of instance: csi
011      ALT3 — Select mux mode: ALT3 mux port: ENET_RX_EN of instance: enet
100      ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO22 of instance: flexio2
101      ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO22 of instance: gpio2
1000     ALT8 — Select mux mode: ALT8 mux port: GPT1_CAPTURE2 of instance: gpt1
1001     ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO22 of instance: flexio3
11.7.98 SW_MUX_CTL_PAD_GPIO_B1_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_07)

SW_MUX_CTL Register

Address: 401F_8000h base + 198h offset = 401F_8198h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_B1_07</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA19 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: LPSPI4_SCK of instance: lpspi4</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: CSI_DATA12 of instance: csi</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_TX_DATA00 of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO23 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO23 of instance: gpio2</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: GPT1_COMPARE1 of instance: gpt1</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO23 of instance: flexio3</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL PAD_GPIO_B1_08 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_08)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 19Ch offset = 401F_819Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_08 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_B1_08  0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_08.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA20 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER1_TIMER3 of instance: qtimer1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: CSI_DATA11 of instance: csi</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_TX_DATA01 of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO24 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO24 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: FLEXCAN2_TX of instance: flexcan2</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: GPT1COMPARE2 of instance: gpt1</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO24 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.100 SW_MUX_CTL_PAD_GPIO_B1_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_09)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1A0h offset = 401F_81A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_09 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_B1_09 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_09.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA21 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER2_TIMER3 of instance: qtimer2</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: CSI_DATA10 of instance: csi</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_TX_EN of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO25 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO25 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: FLEXCAN2_RX of instance: flexcan2</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: GPT1_COMPARE3 of instance: gpt1</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO25 of instance: flexio3</td>
</tr>
</tbody>
</table>
## 11.7.101 SW_MUX_CTL_PAD_GPIO_B1_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_10)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1A4h offset = 401F_81A4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>31–5 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>15</td>
<td>SION</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>0</td>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_10</td>
</tr>
</tbody>
</table>

### Field Descriptions

#### SION

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_B1_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

#### MUX_MODE

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: LCD_DATA22 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: QTIMER3_TIMER3 of instance: qtimer3</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: CSI_DATA00 of instance: csi</td>
</tr>
<tr>
<td>011</td>
<td><strong>ALT3</strong> — Select mux mode: ALT3 mux port: ENET_TX_CLK of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td><strong>ALT4</strong> — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO26 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td><strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO2_IO26 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td><strong>ALT6</strong> — Select mux mode: ALT6 mux port: ENET_REF_CLK of instance: enet</td>
</tr>
<tr>
<td>1001</td>
<td><strong>ALT9</strong> — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO26 of instance: flexio3</td>
</tr>
</tbody>
</table>
## 11.7.102 SW_MUX_CTL_PAD_GPIO_B1_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_11)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1A8h offset = 401F_81A8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_B1_11</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>15–0</td>
<td>MUX_MODE MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_11.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: LCD_DATA23 of instance: lcdif</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: QTIMER4_TIMER3 of instance: qtimer4</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: CSI_DATA01 of instance: csi</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_RX_ER of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO27 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO27 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: LPSPI4_PCS3 of instance: lpspi4</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO27 of instance: flexio3</td>
</tr>
</tbody>
</table>
IOMUXC Memory Map/Register Definition

11.7.103 SW_MUX_CTL_PAD_GPIO_B1_12 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_12)

SW_MUX_CTL Register

Address: 401F_8000h base + 1ACh offset = 401F_81ACh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_12 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 4     | Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.
| SION  | ENABLED — Force input path of pad GPIO_B1_12  
|       | DISABLED — Input Path is determined by functionality |
| MUX_MODE | MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_12 |

- **ALT1** — Select mux mode: ALT1 mux port: LPUART5_TX of instance: lpuart5
- **ALT2** — Select mux mode: ALT2 mux port: CSI_PIXCLK of instance: csi
- **ALT3** — Select mux mode: ALT3 mux port: ENET_1588_EVENT0_IN of instance: enet
- **ALT4** — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO28 of instance: flexio2
- **ALT5** — Select mux mode: ALT5 mux port: GPIO2_IO28 of instance: gpio2
- **ALT6** — Select mux mode: ALT6 mux port: USDHC1_CD_B of instance: usdhc1
- **ALT9** — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO28 of instance: flexio3
11.7.104  **SW_MUX_CTL_PAD_GPIO_B1_13 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_13)**

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1B0h offset = 401F_81B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
<th>SION</th>
<th>MUX_MODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_13 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_B1_13 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_13.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: WDOG1_B of instance: wdog1</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: LPUART5_RX of instance: luart5</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: CSI_VSYNC of instance: csi</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: ENET_1588_EVENT0_OUT of instance: enet</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO29 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO29 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC1_WP of instance: usdhc1</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: SEMC_DQS4 of instance: semc</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO29 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.105 **SW_MUX_CTL_PAD_GPIO_B1_14 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_14)**

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1B4h offset = 401F_81B4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset:

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset:

**IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_14 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
| SION | 1 ENABLED — Force input path of pad GPIO_B1_14  
0 DISABLED — Input Path is determined by functionality |
| MUX_Mode | MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_B1_14. |
| 000 | ALT0 — Select mux mode: ALT0 mux port: ENET_MDC of instance: enet |
| 001 | ALT1 — Select mux mode: ALT1 mux port: FLEXPWM4_PWMA02 of instance: flexpwm4 |
| 010 | ALT2 — Select mux mode: ALT2 mux port: CSI_HSYNC of instance: csi |
| 011 | ALT3 — Select mux mode: ALT3 mux port: XBAR1_IN02 of instance: xbar1 |
| 100 | ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO30 of instance: flexio2 |
| 101 | ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO30 of instance: gpio2 |
| 110 | ALT6 — Select mux mode: ALT6 mux port: USDHC1_VSELECT of instance: usdhc1 |
| 1000 | ALT8 — Select mux mode: ALT8 mux port: ENET2_TDATA00 of instance: enet2 |
| 1001 | ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO30 of instance: flexio3 |
### 11.7.106 SW_MUX_CTL_PAD_GPIO_B1_15 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_15)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1B8h offset = 401F_81B8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_B1_15 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_B1_15.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: ENET_MDIO of instance: enet</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM4_PWMA03 of instance: flexpwm4</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: CSI_MCLK of instance: csi</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: XBAR1_IN03 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXIO2_FLEXIO31 of instance: flexio2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO2_IO31 of instance: gpio2</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: USDHC1_RESET_B of instance: usdhc1</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_TDATA01 of instance: enet2</td>
</tr>
<tr>
<td>1001</td>
<td>ALT9 — Select mux mode: ALT9 mux port: FLEXIO3_FLEXIO31 of instance: flexio3</td>
</tr>
</tbody>
</table>
11.7.107  SW_MUX_CTL_PAD_GPIO_SD_B0_00 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_00)

SW_MUX_CTL Register

Address: 401F_8000h base + 1BCh offset = 401F_81BCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31-5</th>
<th>4</th>
<th>15-11</th>
<th>8-0</th>
<th>15-11</th>
<th>8-0</th>
<th>31-5</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15-11</th>
<th>8-0</th>
<th>15-11</th>
<th>8-0</th>
<th>15-11</th>
<th>8-0</th>
<th>31-5</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Reserved</td>
<td>SION</td>
<td>MUX_MODE</td>
<td>Reserved</td>
<td>SION</td>
<td>MUX_MODE</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 1 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4 SION</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1 ENABLED</td>
<td>Force input path of pad GPIO_SD_B0_00</td>
</tr>
<tr>
<td>0 DISABLED</td>
<td>Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B0_00.</td>
</tr>
<tr>
<td>000 ALT0</td>
<td>Select mux mode: ALT0 mux port: USDHC1_CMD of instance: usdhc1</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>Select mux mode: ALT1 mux port: FLEXPWM1_PWMA00 of instance: flexpwm1</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>Select mux mode: ALT2 mux port: LPI2C3_SCL of instance: lpi2c3</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: XBAR1_INOUT04 of instance: xbar1</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: LPSPI1_SCK of instance: lpspi1</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO3_IO12 of instance: gpio3</td>
</tr>
<tr>
<td>110 ALT6</td>
<td>Select mux mode: ALT6 mux port: FLEXSPIA_SS1_B of instance: flexspi</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>Select mux mode: ALT8 mux port: ENET2_TX_EN of instance: enet2</td>
</tr>
<tr>
<td>1001 ALT9</td>
<td>Select mux mode: ALT9 mux port: SEMC_DQS4 of instance: semc</td>
</tr>
</tbody>
</table>
11.7.108 SW_MUX_CTL_PAD_GPIO_SD_B0_01 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_01)

SW_MUX_CTL Register

Address: 401F_8000h base + 1C0h offset = 401F_81C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Bit 15–1: Reserved

Bit 14–10: MUX_MODE

Bit 9–8: SION

Field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_SD_B0_01</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B0_01.</td>
</tr>
</tbody>
</table>

000 ALT0 — Select mux mode: ALT0 mux port: USDHC1_CLK of instance: usdhc1
001 ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMB00 of instance: flexpwm1
010 ALT2 — Select mux mode: ALT2 mux port: LPI2C3_SDA of instance: lpi2c3
011 ALT3 — Select mux mode: ALT3 mux port: XBAR1_INOUT05 of instance: xbar1
100 ALT4 — Select mux mode: ALT4 mux port: LPSPI1_PCS0 of instance: lpspi1
101 ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO13 of instance: gpio3
110 ALT6 — Select mux mode: ALT6 mux port: FLEXSPIB_SS1_B of instance: flexspi
1000 ALT8 — Select mux mode: ALT8 mux port: ENET2_TX_CLK of instance: enet2
1001 ALT9 — Select mux mode: ALT9 mux port: ENET2_REF_CLK2 of instance: enet2
IOMUXC Memory Map/Register Definition

11.7.109 SW_MUX_CTL_PAD_GPIO_SD_B0_02 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_02)

SW_MUX_CTL Register

Address: 401F_8000h base + 1C4h offset = 401F_81C4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>4</td>
<td>SION</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>ENABLED</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>MUX_MODE</th>
<th>MUX Mode Select Field.</th>
</tr>
</thead>
<tbody>
<tr>
<td>000 ALT0</td>
<td>Select mux mode: ALT0 mux port: USDHC1_DATA0 of instance: usdhc1</td>
</tr>
<tr>
<td>001 ALT1</td>
<td>Select mux mode: ALT1 mux port: FLEXPWM1_PWMA01 of instance: flexpwm1</td>
</tr>
<tr>
<td>010 ALT2</td>
<td>Select mux mode: ALT2 mux port: LPUART8_CTS_B of instance: lpuart8</td>
</tr>
<tr>
<td>011 ALT3</td>
<td>Select mux mode: ALT3 mux port: XBAR1_INOUT06 of instance: xbar1</td>
</tr>
<tr>
<td>100 ALT4</td>
<td>Select mux mode: ALT4 mux port: LPSPI1_SDO of instance: lpspi1</td>
</tr>
<tr>
<td>101 ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO3_IO14 of instance: gpio3</td>
</tr>
<tr>
<td>1000 ALT8</td>
<td>Select mux mode: ALT8 mux port: ENET2_RX_ER of instance: enet2</td>
</tr>
<tr>
<td>1001 ALT9</td>
<td>Select mux mode: ALT9 mux port: SEMC_CLK5 of instance: semc</td>
</tr>
</tbody>
</table>
### 11.7.110 SW_MUX_CTL_PAD_GPIO_SD_B0_03 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_03)

#### SW_MUX_CTL Register

Address: 401F_8000h base + 1C8h offset = 401F_81C8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_03 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B0_03.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALT0</td>
<td>Select mux mode: ALT0 mux port: USDHC1_DATA1 of instance: usdhc1</td>
</tr>
<tr>
<td>ALT1</td>
<td>Select mux mode: ALT1 mux port: FLEXPWM1_PWMB01 of instance: flexpwm1</td>
</tr>
<tr>
<td>ALT2</td>
<td>Select mux mode: ALT2 mux port: LPUART8_RTS_B of instance: lpuart8</td>
</tr>
<tr>
<td>ALT3</td>
<td>Select mux mode: ALT3 mux port: XBAR1_INOUT07 of instance: xbar1</td>
</tr>
<tr>
<td>ALT4</td>
<td>Select mux mode: ALT4 mux port: LPSPI1_SDI of instance: lpspi1</td>
</tr>
<tr>
<td>ALT5</td>
<td>Select mux mode: ALT5 mux port: GPIO3_IO15 of instance: gpio3</td>
</tr>
<tr>
<td>ALT8</td>
<td>Select mux mode: ALT8 mux port: ENET2_RDATA00 of instance: enet2</td>
</tr>
<tr>
<td>ALT9</td>
<td>Select mux mode: ALT9 mux port: SEMC_CLK6 of instance: semc</td>
</tr>
</tbody>
</table>
11.7.111 SW_MUX_CTL_PAD_GPIO_SD_B0_04 SW MUX Control Register  
(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_04)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1CCh offset = 401F_81CCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>N</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

---

**IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_04 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_SD_B0_04  0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_SD_B0_04.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USDHC1_DATA2 of instance: usdhc1</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMA02 of instance: flexpwm1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART8_TX of instance: lpuart8</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: XBAR1_INOUT08 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXSPIB_SS0_B of instance: flexspi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO16 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: CCM_CLKO1 of instance: ccm</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_RDATA01 of instance: enet2</td>
</tr>
</tbody>
</table>
### 11.7.112 SW_MUX_CTL_PAD_GPIO_SD_B0_05 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_05)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1D0h offset = 401F_81D0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_05 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_SD_B0_05 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_SD_B0_05.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USDHC1_DATA3 of instance: usdhc1</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXPWM1_PWMB02 of instance: flexpwm1</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART8_RX of instance: lpuart8</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: XBAR1_INOUT09 of instance: xbar1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXSPIB_DQS of instance: flexspi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO17 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: CCM_CLKO2 of instance: ccm</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: ENET2_RX_EN of instance: enet2</td>
</tr>
</tbody>
</table>
11.7.113 **SW_MUX_CTL_PAD_GPIO_SD_B1_00 SW MUX Control Register**

*(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_00)*

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1D4h offset = 401F_81D4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SION</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MUX_MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>Force input path of pad GPIO_SD_B1_00</td>
</tr>
<tr>
<td></td>
<td>Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B1_00.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USDHC2_DATA3 of instance: usdhc2</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXSPIB_DATA03 of instance: flexspi</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXPWM1_PWMA03 of instance: flexpwm1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_DATA03 of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: LPUART4_TX of instance: lpuart4</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO00 of instance: gpio3</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: SAI3_RX_DATA of instance: sai3</td>
</tr>
</tbody>
</table>
11.7.114 SW_MUX_CTL_PAD_GPIO_SD_B1_01 SW MUX Control Register

(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_01)

SW_MUX_CTL Register

Address: 401F_8000h base + 1D8h offset = 401F_81D8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_01 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION Software Input On Field. Force the selected mux mode input path no matter of MUX_MODE functionality. 1 <strong>ENABLED</strong> — Force input path of pad GPIO_SD_B1_01 0 <strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iOMUX modes to be used for pad: GPIO_SD_B1_01. 000 <strong>ALT0</strong> — Select mux mode: ALT0 mux port: USDHC2_DATA2 of instance: usdhc2 001 <strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXSPIB_DATA02 of instance: flexspi 010 <strong>ALT2</strong> — Select mux mode: ALT2 mux port: FLEXPWM1_PWMB03 of instance: flexpwm1 011 <strong>ALT3</strong> — Select mux mode: ALT3 mux port: SAI1_TX_DATA02 of instance: sai1 100 <strong>ALT4</strong> — Select mux mode: ALT4 mux port: LPUART4_RX of instance: lpurt4 101 <strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO3_IO01 of instance: gpio3 1000 <strong>ALT8</strong> — Select mux mode: ALT8 mux port: SAI3_TX_DATA of instance: sai3</td>
</tr>
</tbody>
</table>
11.7.115 SW_MUX_CTL_PAD_GPIO_SD_B1_02 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_02)

SW_MUX_CTL Register

Address: 401F_8000h base + 1DCh offset = 401F_81DCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>Reserved</td>
<td>SION</td>
<td>MUX_MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_02 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field.</td>
</tr>
<tr>
<td>SION</td>
<td>Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_SD_B1_02</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iomux modes to be used for pad: GPIO_SD_B1_02.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USDHC2_DATA1 of instance: usdhc2</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXSPIB_DATA01 of instance: flexspi</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXPWM2_PWMA03 of instance: flexpm2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_DATA01 of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXCAN1_TX of instance: flexcan1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO02 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: CCM_WAIT of instance: ccm</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: SAI3_TX_SYNC of instance: sai3</td>
</tr>
</tbody>
</table>
### SW_MUX_CTL_PAD_GPIO_SD_B1_03 SW MUX Control Register

#### (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_03)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1E0h offset = 401F_81E0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_03 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_SD_B1_03</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B1_03.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USDHC2_DATA0 of instance: usdhc2</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXSPIB_DATA00 of instance: flexspi</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: FLEXPWM2_PWMB03 of instance: flexpwm2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_MCLK of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXCAN1_RX of instance: flexcan1</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO03 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: CCM_PMIC_READY of instance: ccm</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: SAI3_TX_BCLK of instance: sai3</td>
</tr>
</tbody>
</table>
11.7.117  SW_MUX_CTL_PAD_GPIO_SD_B1_04 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_04)

SW_MUX_CTL Register

Address: 401F_8000h base + 1E4h offset = 401F_81E4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td>SION</td>
<td>MUX_MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_04 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_SD_B1_04</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B1_04.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USDHC2_CLK of instance: usdhc2</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXSPIB_SCLK of instance: flexspi</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPI2C1_SCL of instance: lpi2c1</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_RX_SYNC of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: FLEXSPIA_SS1_B of instance: flexspi</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO04 of instance: gpio3</td>
</tr>
<tr>
<td>110</td>
<td>ALT6 — Select mux mode: ALT6 mux port: CCM_STOP of instance: ccm</td>
</tr>
<tr>
<td>1000</td>
<td>ALT8 — Select mux mode: ALT8 mux port: SAI3_MCLK of instance: sai3</td>
</tr>
</tbody>
</table>
11.7.118  SW_MUX_CTL_PAD_GPIO_SD_B1_05 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_05)

SW_MUX_CTL Register

Address: 401F_8000h base + 1E8h offset = 401F_81E8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>Force selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td></td>
<td>1 ENABLED — Force input path of pad GPIO_SD_B1_05</td>
</tr>
<tr>
<td></td>
<td>0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B1_05.</td>
</tr>
</tbody>
</table>

000 ALT0 — Select mux mode: ALT0 mux port: USDHC2_CMD of instance: usdhc2
001 ALT1 — Select mux mode: ALT1 mux port: FLEXSPIA_DQS of instance: flexspi
010 ALT2 — Select mux mode: ALT2 mux port: LPI2C1_SDA of instance: lpi2c1
011 ALT3 — Select mux mode: ALT3 mux port: SAI1_RX_BCLK of instance: sai1
100 ALT4 — Select mux mode: ALT4 mux port: FLEXSPIB_SS0_B of instance: flexspi
101 ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO05 of instance: gpio3
100 ALT8 — Select mux mode: ALT8 mux port: SAI3_RX_SYNC of instance: sai3
11.7.119  SW_MUX_CTL_PAD_GPIO_SD_B1_06 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_06)

SW_MUX_CTL Register

Address: 401F_8000h base + 1ECh offset = 401F_81ECh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- **Reserved**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

- **SION**
- **MUX_MODE**

### IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_06 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>ENABLED — Force input path of pad GPIO_SD_B1_06</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
</tbody>
</table>

- **MUX_MODE**

Select one of iomux modes to be used for pad: GPIO_SD_B1_06.

- **ALT0** — Select mux mode: ALT0 mux port: USDHC2_RESET_B of instance: usdhc2
- **ALT1** — Select mux mode: ALT1 mux port: FLEXSPIA_SS0_B of instance: flexspi
- **ALT2** — Select mux mode: ALT2 mux port: LPUART7_CTS_B of instance: lpuart7
- **ALT3** — Select mux mode: ALT3 mux port: SAI1_RX_DATA00 of instance: sai1
- **ALT4** — Select mux mode: ALT4 mux port: LPSPI2_PCS0 of instance: lpspi2
- **ALT5** — Select mux mode: ALT5 mux port: GPIO3_IO06 of instance: gpio3
- **ALT8** — Select mux mode: ALT8 mux port: SAI3_RX_BCLK of instance: sai3
11.7.120 SW_MUX_CTL_PAD_GPIO_SD_B1_07 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_07)

SW_MUX_CTL Register

Address: 401F_8000h base + 1F0h offset = 401F_81F0h

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_SD_B1_07 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B1_07.</td>
</tr>
<tr>
<td></td>
<td>000 ALT0 — Select mux mode: ALT0 mux port: SEMC_CSX01 of instance: semc 001 ALT1 — Select mux mode: ALT1 mux port: FLEXSPIA_SCLK of instance: flexspi</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC Memory Map/Register Definition

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART7_RTS_B of instance: lpuart7</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: SAI1_TX_DATA00 of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: LPSPI2_SCK of instance: lpspi2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO07 of instance: gpio3</td>
</tr>
</tbody>
</table>

11.7.121 SW_MUX_CTL_PAD_GPIO_SD_B1_08 SW MUX Control Register
(IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_08)

SW_MUX_CTL Register

Address: 401F_8000h base + 1F4h offset = 401F_81F4h

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_08 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>SION — Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_08 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_SD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**MUX_MODE**

MUX Mode Select Field.

Select one of iOMUX modes to be used for pad: GPIO_SD_B1_08.

- **ALT0** — Select mux mode: ALT0 mux port: USDHC2_DATA4 of instance: usdhc2
- **ALT1** — Select mux mode: ALT1 mux port: FLEXSPIA_DATA00 of instance: flexspi
- **ALT2** — Select mux mode: ALT2 mux port: LPUART7_TX of instance: lpuart7
- **ALT3** — Select mux mode: ALT3 mux port: SAI1_TX_BCLK of instance: sai1
- **ALT4** — Select mux mode: ALT4 mux port: LPSPI2_SD0 of instance: lpspi2
- **ALT5** — Select mux mode: ALT5 mux port: GPIO3_IO08 of instance: gpio3
- **ALT6** — Select mux mode: ALT6 mux port: SEMC_CSX02 of instance: semc

### 11.7.122 SW_MUX_CTL_PAD_GPIO_SD_B1_09 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_09)

**SW_MUX_CTL Register**

Address: 401F_8000h base + 1F8h offset = 401F_81F8h

#### Bit 31 to Bit 24

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### Bit 23 to Bit 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SION</th>
<th>Reserved</th>
<th>MUX_MODE</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  |
## IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_09 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>1</td>
<td><strong>ENABLED</strong> — Force input path of pad GPIO_SD_B1_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>DISABLED</strong> — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>000</td>
<td><strong>ALT0</strong> — Select mux mode: ALT0 mux port: USDHC2_DATA5 of instance: usdhc2</td>
</tr>
<tr>
<td>001</td>
<td><strong>ALT1</strong> — Select mux mode: ALT1 mux port: FLEXSPIA_DATA01 of instance: flexspi</td>
</tr>
<tr>
<td>010</td>
<td><strong>ALT2</strong> — Select mux mode: ALT2 mux port: LPUART7_RX of instance: lpuart7</td>
</tr>
<tr>
<td>011</td>
<td><strong>ALT3</strong> — Select mux mode: ALT3 mux port: SAI1_TX_SYNC of instance: sai1</td>
</tr>
<tr>
<td>100</td>
<td><strong>ALT4</strong> — Select mux mode: ALT4 mux port: LPSPI2_IDI of instance: lpspi2</td>
</tr>
<tr>
<td>101</td>
<td><strong>ALT5</strong> — Select mux mode: ALT5 mux port: GPIO3_IO09 of instance: gpio3</td>
</tr>
</tbody>
</table>
11.7.123 SW_MUX_CTL_PAD_GPIO_SD_B1_10 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_10)

SW_MUX_CTL Register

Address: 401F_8000h base + 1FCh offset = 401F_81FCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SION</td>
<td>Reserved</td>
<td>MUX_MODE</td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_10 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
<tr>
<td>SION</td>
<td>1 ENABLED — Force input path of pad GPIO_SD_B1_10 0 DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field. Select one of iomux modes to be used for pad: GPIO_SD_B1_10. 000 ALT0 — Select mux mode: ALT0 mux port: USDHC2_DATA6 of instance: usdhc2 001 ALT1 — Select mux mode: ALT1 mux port: FLEXSPIA_DATA02 of instance: flexspi</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC Memory Map/Register Definition

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART2_RX of instance: lpuart2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPI2C2_SDA of instance: lpi2c2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: LPSPI2_PCS2 of instance: lpspi2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO10 of instance: gpio3</td>
</tr>
</tbody>
</table>

11.7.124 SW_MUX_CTL_PAD_GPIO_SD_B1_11 SW MUX Control Register (IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_11)

SW_MUX_CTL Register

Address: 401F_8000h base + 200h offset = 401F_8200h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1

IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Software Input On Field. Force the selected mux mode Input path no matter of MUX_MODE functionality.</td>
</tr>
</tbody>
</table>
### IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_11 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>ENABLED — Force input path of pad GPIO_SD_B1_11</td>
</tr>
<tr>
<td>0</td>
<td>DISABLED — Input Path is determined by functionality</td>
</tr>
<tr>
<td>3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>MUX_MODE</td>
<td>MUX Mode Select Field.</td>
</tr>
<tr>
<td></td>
<td>Select one of iOMUX modes to be used for pad: GPIO_SD_B1_11.</td>
</tr>
<tr>
<td>000</td>
<td>ALT0 — Select mux mode: ALT0 mux port: USDHC2_DATA7 of instance: usdhc2</td>
</tr>
<tr>
<td>001</td>
<td>ALT1 — Select mux mode: ALT1 mux port: FLEXSPIA_DATA03 of instance: flexspi</td>
</tr>
<tr>
<td>010</td>
<td>ALT2 — Select mux mode: ALT2 mux port: LPUART2_TX of instance: lpuart2</td>
</tr>
<tr>
<td>011</td>
<td>ALT3 — Select mux mode: ALT3 mux port: LPI2C2_SCL of instance: lpi2c2</td>
</tr>
<tr>
<td>100</td>
<td>ALT4 — Select mux mode: ALT4 mux port: LPSPI2_PCS3 of instance: lspi2</td>
</tr>
<tr>
<td>101</td>
<td>ALT5 — Select mux mode: ALT5 mux port: GPIO3_IO11 of instance: gpio3</td>
</tr>
</tbody>
</table>

### 11.7.125 SW_PAD_CTL_PAD_GPIO_EMC_00 SW Pad Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_00)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 204h offset = 401F_8204h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Reserved</td>
<td>HYS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

| Bit | R/W | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
|     |     | PUS | PUE | PKE | ODE | Reserved | SPEED | DSE | Reserved | SRE |
| Reset | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |

**IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_00 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_00</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_00 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.126 SW_PAD_CTL_PAD_GPIO_EMC_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_01)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 208h offset = 401F_8208h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>15–14</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>13–12</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>11–10</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>9–8</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>5–4</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>3–2</td>
<td>RW</td>
<td>Reserved</td>
</tr>
<tr>
<td>1–0</td>
<td>RW</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_01 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_01</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.127 SW_PAD_CTL_PAD_GPIO_EMC_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_02)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 20Ch offset = 401F_820Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-17</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled</td>
<td>— Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled</td>
<td>— Hysteresis Enabled</td>
</tr>
<tr>
<td>15-14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down</td>
<td>— 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up</td>
<td>— 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up</td>
<td>— 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up</td>
<td>— 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper</td>
<td>— Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull</td>
<td>— Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled</td>
<td>— Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled</td>
<td>— Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_02 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_02</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>

---

### 11.7.128 SW_PAD_CTL_PAD_GPIO_EMC_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_03)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 210h offset = 401F_8210h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td><strong>PUS</strong></td>
</tr>
<tr>
<td>30</td>
<td><strong>PUE</strong></td>
</tr>
<tr>
<td>29</td>
<td><strong>PKE</strong></td>
</tr>
<tr>
<td>28</td>
<td><strong>ODE</strong></td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td><strong>SPEED</strong></td>
</tr>
<tr>
<td>25</td>
<td><strong>DSE</strong></td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td><strong>SRE</strong></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_03</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_03</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_03</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_03</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_03</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_03</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_03</td>
</tr>
<tr>
<td>00</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
IOMUXC SW PAD CTL_PAD_GPIO EMC_03 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
</tbody>
</table>

2–1   This field is reserved.  
-     Reserved

0   SRE  

Slew Rate Field
Select one out of next values for pad: GPIO EMC_03

0   SRE_0_Slow_Slew_Rate — Slow Slew Rate
1   SRE_1_Fast_Slew_Rate — Fast Slew Rate

11.7.129  SW_PAD_CTL_PAD_GPIO EMC_04 SW PAD Control Register (IOMUXC SW PAD_CTL_PAD_GPIO EMC_04)

SW_PAD_CTL Register

Address: 401F_8000h base + 214h offset = 401F_8214h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO EMC_04 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.  
-     Reserved

16   HYS  

Hyst. Enable Field
Select one out of next values for pad: GPIO EMC_04

0   HYS_0_Hysteresis_Disabled — Hysteresis Disabled
1   HYS_1_Hysteresis_Enabled — Hysteresis Enabled

15–14   PUS  

Pull Up / Down Config. Field
Select one out of next values for pad: GPIO EMC_04

00   PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
01   PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

Table continues on the next page...
## IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td><strong>PUE</strong> Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_04</td>
</tr>
<tr>
<td>0</td>
<td><strong>PUE_0_Keeper</strong> — Keeper</td>
</tr>
<tr>
<td>1</td>
<td><strong>PUE_1_Pull</strong> — Pull</td>
</tr>
<tr>
<td>12</td>
<td><strong>PKE</strong> Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_04</td>
</tr>
<tr>
<td>0</td>
<td><strong>PKE_0_Pull_Keeper_Disabled</strong> — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>PKE_1_Pull_Keeper_Enabled</strong> — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td><strong>ODE</strong> Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_04</td>
</tr>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_04</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_04</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_04</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.130   SW_PAD_CTL_PAD_GPIO_EMC_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_05)

SW_PAD_CTL Register

Address: 401F_8000h base + 218h offset = 401F_8218h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>HYS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PUE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PKE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SPEED</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DSE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_05 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>10–8</td>
<td><strong>Reserved</strong></td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td>7–6</td>
<td>Select one out of next values for pad: GPIO_EMC_05</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Select one out of next values for pad: GPIO_EMC_05</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 Ohm @ 1.8V)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>2–1</td>
<td><strong>Reserved</strong></td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td>0</td>
<td>Select one out of next values for pad: GPIO_EMC_05</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>

#### 11.7.131 SW_PAD_CTL_PAD_GPIO_EMC_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_06)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 21Ch offset = 401F_821Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>PUS</th>
<th>PUE</th>
<th>PKE</th>
<th>ODE</th>
<th>SPEED</th>
<th>DSE</th>
<th>SRE</th>
<th>Reserved</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_06 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis.Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_06 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_06</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate  — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.132 SW_PAD_CTL_PAD_GPIO_EMC_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_07)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 220h offset = 401F_8220h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>HYS</th>
<th>Hyst. Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_07</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>PUS</th>
<th>Pull Up / Down Config. Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down     — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up        — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>13</th>
<th>PUE</th>
<th>Pull / Keep Select Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>PUE_0Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>PUE_1Pull — Pull</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>12</th>
<th>PKE</th>
<th>Pull / Keep Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>PKE_0Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>PKE_1Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>11</th>
<th>ODE</th>
<th>Open Drain Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>ODE_0Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>ODE_1Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

| 10–8 | Reserved |

<table>
<thead>
<tr>
<th>7–6</th>
<th>SPEED</th>
<th>Speed Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>5–3</th>
<th>DSE</th>
<th>Drive Strength Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>000</td>
<td>DSE_0output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001</td>
<td>DSE_1R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010</td>
<td>DSE_2R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011</td>
<td>DSE_3R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100</td>
<td>DSE_4R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101</td>
<td>DSE_5R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110</td>
<td>DSE_6R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111</td>
<td>DSE_7R0_7 — R0/7</td>
</tr>
</tbody>
</table>

| 2–1 | Reserved |

<table>
<thead>
<tr>
<th>0</th>
<th>SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_EMC_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_08)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 224h offset = 401F_8224h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_08</td>
</tr>
<tr>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_08</td>
</tr>
<tr>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_08</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_08</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_PullKeeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_PullKeeper_Enabled — Pull/Keeper Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_08</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_08 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 ODE_0_Open_Drain_Disabled</td>
<td>Open Drain Disabled</td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled</td>
<td>Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
</tbody>
</table>

#### 11.7.134 SW_PAD_CTL_PAD_GPIO_EMC_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_09)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 228h offset = 401F_8228h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>HYS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_09 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
</tbody>
</table>

#### Field Descriptions

**31–17** - This field is reserved. Reserved

**16**

- **HYS**
  - **Hyst. Enable Field**
  - Select one out of next values for pad: GPIO_EMC_09
    - 0 **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
    - 1 **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled

**15–14**

- **PUS**
  - **Pull Up / Down Config. Field**
  - Select one out of next values for pad: GPIO_EMC_09
    - 00 **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
    - 01 **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
    - 10 **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
    - 11 **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

**13**

- **PUE**
  - **Pull / Keep Select Field**
  - Select one out of next values for pad: GPIO_EMC_09
    - 0 **PUE_0_Keeper** — Keeper
    - 1 **PUE_1_Pull** — Pull

**12**

- **PKE**
  - **Pull / Keep Enable Field**
  - Select one out of next values for pad: GPIO_EMC_09
    - 0 **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
    - 1 **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled

**11**

- **ODE**
  - **Open Drain Enable Field**
  - Select one out of next values for pad: GPIO_EMC_09
    - 0 **ODE_0_Open_Drain_Disabled** — Open Drain Disabled
    - 1 **ODE_1_Open_Drain_Enabled** — Open Drain Enabled

**10–8** - This field is reserved. Reserved

**7–6**

- **SPEED**
  - **Speed Field**
  - Select one out of next values for pad: GPIO_EMC_09
    - 00 **SPEED_0_low_50MHz** — low(50MHz)
    - 01 **SPEED_1_medium_100MHz** — medium(100MHz)
    - 10 **SPEED_2_fast_150MHz** — fast(150MHz)
    - 11 **SPEED_3_max_200MHz** — max(200MHz)

**5–3**

- **DSE**
  - **Drive Strength Field**
  - Select one out of next values for pad: GPIO_EMC_09
    - 00 0 **DSE_0_output_driver_disabled** — output driver disabled;
    - 001 **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
    - 010 **DSE_2_R0_2** — R0/2

*Table continues on the next page...*
### IOMUXC SW_PAD_CTL_PAD_GPIO_EMC_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate   — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.135 SW_PAD_CTL_PAD_GPIO_EMC_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_10)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 22Ch offset = 401F_822Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_10 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_10</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis.Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>PUS</td>
<td>Select one out of next values for pad: GPIO_EMC_10</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
</tbody>
</table>

#### 13 PUE

Pull / Keep Select Field

Select one out of next values for pad: GPIO_EMC_10

| 0 | **PUE_0_Keeper** — Keeper |
| 1 | **PUE_1_Pull** — Pull |

#### 12 PKE

Pull / Keep Enable Field

Select one out of next values for pad: GPIO_EMC_10

| 0 | **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled |
| 1 | **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled |

#### 11 ODE

Open Drain Enable Field

Select one out of next values for pad: GPIO_EMC_10

| 0 | **ODE_0_Open_Drain_Disabled** — Open Drain Disabled |
| 1 | **ODE_1_Open_Drain_Enabled** — Open Drain Enabled |

#### 10–8

This field is reserved.

Reserved

#### 7–6 SPEED

Speed Field

Select one out of next values for pad: GPIO_EMC_10

| 00 | **SPEED_0_low_50MHz** — low(50MHz) |
| 01 | **SPEED_1_medium_100MHz** — medium(100MHz) |
| 10 | **SPEED_2_fast_150MHz** — fast(150MHz) |
| 11 | **SPEED_3_max_200MHz** — max(200MHz) |

#### 5–3 DSE

Drive Strength Field

Select one out of next values for pad: GPIO_EMC_10

| 000 | **DSE_0_output_driver_disabled** — output driver disabled; |
| 001 | **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V) |
| 010 | **DSE_2_R0_2** — R0/2 |
| 011 | **DSE_3_R0_3** — R0/3 |
| 100 | **DSE_4_R0_4** — R0/4 |
| 101 | **DSE_5_R0_5** — R0/5 |
| 110 | **DSE_6_R0_6** — R0/6 |
| 111 | **DSE_7_R0_7** — R0/7 |

#### 2–1

This field is reserved.

Reserved

#### 0 SRE

Slew Rate Field

Select one out of next values for pad: GPIO_EMC_10

| 0 | **SRE_0_Slow_Slew_Rate** — Slow Slew Rate |
| 1 | **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
### SW_PAD_CTL_PAD_GPIO_EMC_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_11)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 230h offset = 401F_8230h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R/W</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>R/W</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>R/W</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>R/W</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>R/W</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_11 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

10–8 - 
This field is reserved.
Reserved

7–6 SPEED 
Speed Field
Select one out of next values for pad: GPIO_EMC_11
00 SPEED_0_low_50MHz — low(50MHz)
01 SPEED_1_medium_100MHz — medium(100MHz)
10 SPEED_2_fast_150MHz — fast(150MHz)
11 SPEED_3_max_200MHz — max(200MHz)

5–3 DSE 
Drive Strength Field
Select one out of next values for pad: GPIO_EMC_11
000 DSE_0_output_driver_disabled — output driver disabled;
001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
010 DSE_2_R0_2 — R0/2
011 DSE_3_R0_3 — R0/3
100 DSE_4_R0_4 — R0/4
101 DSE_5_R0_5 — R0/5
110 DSE_6_R0_6 — R0/6
111 DSE_7_R0_7 — R0/7

2–1 - 
This field is reserved.
Reserved

0 SRE 
Slew Rate Field
Select one out of next values for pad: GPIO_EMC_11
0 SRE_0_Slow_Slew_Rate — Slow Slew Rate
1 SRE_1_Fast_Slew_Rate — Fast Slew Rate

---

11.7.137 SW_PAD_CTL_PAD_GPIO_EMC_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_12)

SW_PAD_CTL Register

Address: 401F_8000h base + 234h offset = 401F_8234h

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
</tr>
<tr>
<td>30</td>
<td>W</td>
</tr>
<tr>
<td>29</td>
<td>28 27 26 25 24</td>
</tr>
<tr>
<td>23</td>
<td>22 21 20 19 18 17 16</td>
</tr>
<tr>
<td>15</td>
<td>PUS</td>
</tr>
<tr>
<td>14</td>
<td>PUE</td>
</tr>
<tr>
<td>13</td>
<td>PKE</td>
</tr>
<tr>
<td>12</td>
<td>ODE</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>SPEED</td>
</tr>
<tr>
<td>9</td>
<td>DSE</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>SRE</td>
</tr>
</tbody>
</table>

```

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors

579
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_12 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>2–1</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0 SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_12</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.138 SW_PAD_CTL_PAD_GPIO_EMC_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_13)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 238h offset = 401F_8238h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_13 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>16 HYS</th>
<th>Hyst. Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_13</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>15–14 PUS</th>
<th>Pull Up / Down Config. Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_13</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_13 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
</tbody>
</table>

**PUE** Pull / Keep Select Field

Select one out of next values for pad: GPIO_EMC_13

- 0 **PUE_0_Keeper** — Keeper
- 1 **PUE_1_Pull** — Pull

**PKE** Pull / Keep Enable Field

Select one out of next values for pad: GPIO_EMC_13

- 0 **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
- 1 **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled

**ODE** Open Drain Enable Field

Select one out of next values for pad: GPIO_EMC_13

- 0 **ODE_0_Open_Drain_Disabled** — Open Drain Disabled
- 1 **ODE_1_Open_Drain_Enabled** — Open Drain Enabled

10–8 This field is reserved. Reserved

**SPEED** Speed Field

Select one out of next values for pad: GPIO_EMC_13

- 00 **SPEED_0_low_50MHz** — low(50MHz)
- 01 **SPEED_1_medium_100MHz** — medium(100MHz)
- 10 **SPEED_2_fast_150MHz** — fast(150MHz)
- 11 **SPEED_3_max_200MHz** — max(200MHz)

**DSE** Drive Strength Field

Select one out of next values for pad: GPIO_EMC_13

- 000 **DSE_0_output_driver_disabled** — output driver disabled;
- 001 **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
- 010 **DSE_2_R0_2** — R0/2
- 011 **DSE_3_R0_3** — R0/3
- 100 **DSE_4_R0_4** — R0/4
- 101 **DSE_5_R0_5** — R0/5
- 110 **DSE_6_R0_6** — R0/6
- 111 **DSE_7_R0_7** — R0/7

2–1 This field is reserved. Reserved

**SRE** Slew Rate Field

Select one out of next values for pad: GPIO_EMC_13

- 0 **SRE_0_Slow_Slew_Rate** — Slow Slew Rate
- 1 **SRE_1_Fast_Slew_Rate** — Fast Slew Rate
### 11.7.139 SW_PAD_CTL_PAD_GPIO_EMC_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_14)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 23Ch offset = 401F_823Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
<td>ODE</td>
</tr>
<tr>
<td>30–26</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_14 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>SPEED</td>
<td>Select one out of next values for pad: GPIO_EMC_14</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>DSE</td>
<td>Select one out of next values for pad: GPIO_EMC_14</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td>SRE</td>
<td>Select one out of next values for pad: GPIO_EMC_14</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.140 SW_PAD_CTL_PAD_GPIO_EMC_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_15)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 240h offset = 401F_8240h
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>16</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>16</td>
<td>HYS_1_Hysteresis.Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>13</td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>13</td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>12</td>
<td>0 PKE_0_Pull.Keeper.Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>12</td>
<td>1 PKE_1_Pull.Keeper.Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>0 ODE_0_Open.Drain.Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>11</td>
<td>1 ODE_1_Open.Drain.Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td>7–6</td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>7–6</td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>7–6</td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>7–6</td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>5–3</td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>5–3</td>
<td>001 DSE_1_R0_150_0hm_3_3v_260_0hm_1_8v — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>5–3</td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_15 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1  
-  
This field is reserved.  
Reserved

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_EMC_15

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.141 SW_PAD_CTL_PAD_GPIO_EMC_16 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_16)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 244h offset = 401F_8244h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>PUS</th>
<th>PUE</th>
<th>PKE</th>
<th>ODE</th>
<th>Reserved</th>
<th>SPEED</th>
<th>DSE</th>
<th>Reserved</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_16 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.  
Reserved |

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_EMC_16

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_EMC_16

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_16 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5-3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2-1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.142 SW_PAD_CTL_PAD_GPIO_EMC_17 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_17)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 248h offset = 401F_8248h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
<td></td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_17 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

**Field descriptions**

- **16 HYS**: Hyst. Enable Field
  - Select one out of next values for pad: GPIO_EMC_17
  - 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

- **15–14 PUS**: Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_EMC_17
  - 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **13 PUE**: Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_EMC_17
  - 0 PUE_0_Keeper — Keeper
  - 1 PUE_1_Pull — Pull

- **12 PKE**: Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_EMC_17
  - 0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

- **11 ODE**: Open Drain Enable Field
  - Select one out of next values for pad: GPIO_EMC_17

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_17 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field Select one out of next values for pad: GPIO_EMC_17</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field Select one out of next values for pad: GPIO_EMC_17</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field Select one out of next values for pad: GPIO_EMC_17</td>
</tr>
</tbody>
</table>

#### 11.7.143 SW_PAD_CTL_PAD_GPIO_EMC_18 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_18)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 24Ch offset = 401F_824Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>RW</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>RW</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
<td>HYS</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
</tbody>
</table>

**Field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
</tbody>
</table>

### Field Descriptions

**31–17**

- **Reserved**

**16**

- **HYS**
  - Hyst. Enable Field
  - Select one out of next values for pad: GPIO_EMC_18
  - 0 **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
  - 1 **HYS_1_Hysteresis.Enabled** — Hysteresis Enabled

**15–14**

- **PUS**
  - Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_EMC_18
  - 00 **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
  - 01 **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
  - 10 **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
  - 11 **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

**13**

- **PUE**
  - Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_EMC_18
  - 0 **PUE_0_Keeper** — Keeper
  - 1 **PUE_1_Pull** — Pull

**12**

- **PKE**
  - Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_EMC_18
  - 0 **PKE_0_PullKeeper_Disabled** — Pull/Keeper Disabled
  - 1 **PKE_1_PullKeeper.Enabled** — Pull/Keeper Enabled

**11**

- **ODE**
  - Open Drain Enable Field
  - Select one out of next values for pad: GPIO_EMC_18
  - 0 **ODE_0_Open_Drain_Disabled** — Open Drain Disabled
  - 1 **ODE_1_Open_Drain_Enabled** — Open Drain Enabled

**10–8**

- This field is reserved. Reserved

**7–6**

- **SPEED**
  - Speed Field
  - Select one out of next values for pad: GPIO_EMC_18
  - 00 **SPEED_0_low_50MHz** — low(50MHz)
  - 01 **SPEED_1_medium_100MHz** — medium(100MHz)
  - 10 **SPEED_2_fast_150MHz** — fast(150MHz)
  - 11 **SPEED_3_max_200MHz** — max(200MHz)

**5–3**

- **DSE**
  - Drive Strength Field
  - Select one out of next values for pad: GPIO_EMC_18
  - 000 **DSE_0_output_driver_disabled** — output driver disabled;
  - 001 **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
  - 010 **DSE_2_R0_2** — R0/2

---

_table continues on the next page..._
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_18 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
</tbody>
</table>

| 2–1   | This field is reserved.  |
|       | Reserved                |

<table>
<thead>
<tr>
<th>0</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td>Slew Rate Field</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_EMC_18</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

---

#### 11.7.144 SW_PAD_CTL_PAD_GPIO_EMC_19 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_19)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 250h offset = 401F_8250h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R W |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_19 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

| 16   | HYS |
| Hyst. Enable Field |
| Select one out of next values for pad: GPIO_EMC_19 |
| 0     | HYS_0_Hysteresis_Disabled — Hysteresis Disabled |
| 1     | HYS_1_Hysteresis.Enabled — Hysteresis Enabled |

| 15–14 | PUS |
| Pull Up / Down Config. Field |
| Select one out of next values for pad: GPIO_EMC_19 |
| 00     | PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down |
| 01     | PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_19</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_19</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_19</td>
</tr>
<tr>
<td></td>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_19</td>
</tr>
<tr>
<td></td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_19</td>
</tr>
<tr>
<td></td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_19</td>
</tr>
<tr>
<td></td>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_EMC_20 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_20)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 254h offset = 401F_8254h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_20 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_20</td>
</tr>
<tr>
<td></td>
<td>0  HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1  HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_20</td>
</tr>
<tr>
<td></td>
<td>00  PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01  PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10  PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11  PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_20</td>
</tr>
<tr>
<td></td>
<td>0  PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1  PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_20</td>
</tr>
<tr>
<td></td>
<td>0  PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1  PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_20</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_20 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

10–8 
- 
This field is reserved. 
Reserved

7–6 
SPEED 
Speed Field 
Select one out of next values for pad: GPIO_EMC_20 

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
</tbody>
</table>

5–3 
DSE 
Drive Strength Field 
Select one out of next values for pad: GPIO_EMC_20 

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_ohm_3_3V_260_ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1 
- 
This field is reserved. 
Reserved

0 
SRE 
Slew Rate Field 
Select one out of next values for pad: GPIO_EMC_20 

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

11.7.146 SW_PAD_CTL_PAD_GPIO_EMC_21 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_21)

SW_PAD_CTL Register

Address: 401F_8000h base + 258h offset = 401F_8258h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15–8</td>
<td>PUS PUE PKE ODE</td>
</tr>
<tr>
<td>7–4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3–2</td>
<td>SPEED DSE</td>
</tr>
<tr>
<td>1–0</td>
<td>Reserved SRE</td>
</tr>
</tbody>
</table>

Reset values:

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>00000</td>
</tr>
<tr>
<td>15–8</td>
<td>00000000</td>
</tr>
<tr>
<td>7–4</td>
<td>000</td>
</tr>
<tr>
<td>3–2</td>
<td>001</td>
</tr>
<tr>
<td>1–0</td>
<td>00000000</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_21</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_21</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_21</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_21</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_21</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_21</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_21</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150 Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
IOMUXC SW_PAD_CTL_PAD_GPIO_EMC_21 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
</tbody>
</table>

2–1
-  This field is reserved.
  Reserved

0
SRE
Slew Rate Field

Select one out of next values for pad: GPIO_EMC_21

<table>
<thead>
<tr>
<th></th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

11.7.147 SW_PAD_CTL_PAD_GPIO_EMC_22 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_22)

SW_PAD_CTL Register

Address: 401F_8000h base + 25Ch offset = 401F_825Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>R</td>
<td>SPEED</td>
</tr>
<tr>
<td>6</td>
<td>R</td>
<td>DSE</td>
</tr>
<tr>
<td>5</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>R</td>
<td>SRE</td>
</tr>
<tr>
<td>3</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>R</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_22</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_22</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_22</td>
</tr>
<tr>
<td></td>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_22</td>
</tr>
<tr>
<td></td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_22</td>
</tr>
<tr>
<td></td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_22</td>
</tr>
<tr>
<td></td>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_EMC_23 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_23)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 260h offset = 401F_8260h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td>Reserved</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td>Reserved</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td>HYS</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td>Reserved</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td>PUS</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td>PUE</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td>PKE</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td>ODE</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td>Reserved</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td>SPEED</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td>DSE</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td>Reserved</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td>SRE</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_23 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

- **HYS**
  - Hyst. Enable Field
  - Select one out of next values for pad: GPIO_EMC_23
  - 0: **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
  - 1: **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled

- **PUS**
  - Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_EMC_23
  - 00: **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
  - 01: **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
  - 10: **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
  - 11: **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

- **PUE**
  - Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_EMC_23
  - 0: **PUE_0_Keeper** — Keeper
  - 1: **PUE_1_Pull** — Pull

- **PKE**
  - Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_EMC_23
  - 0: **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
  - 1: **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_23 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 ODE_0_Open_Drain_Disabled</td>
<td>Open Drain Disabled</td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled</td>
<td>Open Drain Enabled</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>2–1 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
</tbody>
</table>

#### 7–6 SPEED

Select one out of next values for pad: GPIO_EMC_23

- **00**: SPEED_0_low_50MHz — low(50MHz)
- **01**: SPEED_1_medium_100MHz — medium(100MHz)
- **10**: SPEED_2_fast_150MHz — fast(150MHz)
- **11**: SPEED_3_max_200MHz — max(200MHz)

#### 5–3 DSE

Select one out of next values for pad: GPIO_EMC_23

- **000**: DSE_0_output_driver_disabled — output driver disabled;
- **001**: DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
- **010**: DSE_2_R0_2 — R0/2
- **011**: DSE_3_R0_3 — R0/3
- **100**: DSE_4_R0_4 — R0/4
- **101**: DSE_5_R0_5 — R0/5
- **110**: DSE_6_R0_6 — R0/6
- **111**: DSE_7_R0_7 — R0/7

#### 2–1 -

This field is reserved. |

#### 0 SRE

Select one out of next values for pad: GPIO_EMC_23

- **0**: SRE_0_Slow_Slew_Rate — Slow Slew Rate
- **1**: SRE_1_Fast_Slew_Rate — Fast Slew Rate

### 11.7.149 SW_PAD_CTL_PAD_GPIO_EMC_24 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_24)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 264h offset = 401F_8264h
## IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_24 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
</tbody>
</table>

**Field Descriptions**

- **Reserved**: Unavailable fields.
- **Hyst. Enable Field (HYS)**: Selects hysteresis enabled status (0: Hysteresis Disabled, 1: Hysteresis Enabled).
- **Pull Up / Down Config. Field (PUS)**: Configures pull up or pull down resistance.
- **Pull / Keep Select Field (PUE)**: Selects pull or keep option.
- **Pull / Keep Enable Field (PKE)**: Enables pull or keep function.
- **Open Drain Enable Field (ODE)**: Enables or disables open drain function.
- **Speed Field (SPEED)**: Configures the speed setting.
- **Drive Strength Field (DSE)**: Determines the drive strength configuration.

**Examples**

- **PUS_0_100K_Ohm_Pull_Down**: 100K Ohm Pull Down
- **SPEED_0_low_50MHz**: Low (50MHz)
- **DSE_0_output_driver_disabled**: Output driver disabled

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_24 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
</tbody>
</table>

2–1

This field is reserved.
Reserved

<table>
<thead>
<tr>
<th>0</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td>Slew Rate Field</td>
<td></td>
</tr>
</tbody>
</table>
Select one out of next values for pad: GPIO_EMC_24

| 0 | SRE_0_Slow_Slew_Rate  — Slow Slew Rate |
| 1 | SRE_1_Fast_Slew_Rate   — Fast Slew Rate |

---

### 11.7.150 SW_PAD_CTL_PAD_GPIO_EMC_25 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_25)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 268h offset = 401F_8268h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_25 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>16</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Hyst. Enable Field</td>
<td></td>
</tr>
</tbody>
</table>
Select one out of next values for pad: GPIO_EMC_25

| 0  | HYS_0_Hysteresis_Disabled  — Hysteresis Disabled |
| 1  | HYS_1_Hysteresis_Enabled    — Hysteresis Enabled |

<table>
<thead>
<tr>
<th>15–14</th>
<th>PUS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pull Up / Down Config. Field</td>
<td></td>
</tr>
</tbody>
</table>
Select one out of next values for pad: GPIO_EMC_25

| 00  | PUS_0_100K_Ohm_Pull_Down  — 100K Ohm Pull Down |
| 01  | PUS_1_47K_Ohm_Pull_Up      — 47K Ohm Pull Up |

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_25 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_25</td>
</tr>
<tr>
<td></td>
<td>0  PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1  PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_25</td>
</tr>
<tr>
<td></td>
<td>0  PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1  PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_25</td>
</tr>
<tr>
<td></td>
<td>0  ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1  ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_25</td>
</tr>
<tr>
<td></td>
<td>00  SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01  SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10  SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11  SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_25</td>
</tr>
<tr>
<td></td>
<td>000  DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001  DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010  DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011  DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100  DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101  DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110  DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111  DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_25</td>
</tr>
<tr>
<td></td>
<td>0  SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1  SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.151 SW_PAD_CTL_PAD_GPIO_EMC_26 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_26)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 26Ch offset = 401F_826Ch

![Register Address Table]

---

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_26 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

---

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_26 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_26</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_26</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_26</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.152 SW_PAD_CTL_PAD_GPIO_EMC_27 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_27)

**SW_PAD_CTL Register**

Address: `401F_8000h base + 270h offset = 401F_8270h`

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>PUS</td>
</tr>
<tr>
<td>14</td>
<td>PUE</td>
</tr>
<tr>
<td>13</td>
<td>PKE</td>
</tr>
<tr>
<td>12</td>
<td>ODE</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>SPEED</td>
</tr>
<tr>
<td>9</td>
<td>DSE</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>SRE</td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>1</td>
</tr>
<tr>
<td>13</td>
<td>1</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
## IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_27 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>31–17</strong> -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td><strong>16 HYS</strong></td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_27</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td><strong>15–14 PUS</strong></td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_27</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td><strong>13 PUE</strong></td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_27</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td><strong>12 PKE</strong></td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_27</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td><strong>11 ODE</strong></td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_27</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td><strong>10–8</strong> -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td><strong>7–6 SPEED</strong></td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_27</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td><strong>5–3 DSE</strong></td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_27</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_27 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

- This field is reserved.

<table>
<thead>
<tr>
<th>SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.153 SW_PAD_CTL_PAD_GPIO_EMC_28 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_28)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 274h offset = 401F_8274h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_28 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>16</th>
<th>HYS Hyst. Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>15–14</th>
<th>PUS Pull Up / Down Config. Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_28 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td><strong>PUE</strong></td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td></td>
<td>0 <strong>PUE_0_Keeper</strong> — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 <strong>PUE_1.Pull</strong> — Pull</td>
</tr>
<tr>
<td>12</td>
<td><strong>PKE</strong></td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td></td>
<td>0 <strong>PKE_0.Pull_Keeper_Disabled</strong> — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 <strong>PKE_1.Pull_Keeper_Enabled</strong> — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td><strong>ODE</strong></td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td></td>
<td>0 <strong>ODE_0.Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 <strong>ODE_1.Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td><strong>-</strong></td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong></td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td></td>
<td>00 <strong>SPEED_0.low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 <strong>SPEED_1.medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 <strong>SPEED_2.fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 <strong>SPEED_3.max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong></td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td></td>
<td>000 <strong>DSE_0.output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 <strong>DSE_1.R0.150_Ohm_3.3V_260_Ohm_1.8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 <strong>DSE_2.R0.2</strong> — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 <strong>DSE_3.R0.3</strong> — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 <strong>DSE_4.R0.4</strong> — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 <strong>DSE_5.R0.5</strong> — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 <strong>DSE_6.R0.6</strong> — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 <strong>DSE_7.R0.7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td><strong>-</strong></td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong></td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_28</td>
</tr>
<tr>
<td></td>
<td>0 <strong>SRE_0.Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 <strong>SRE_1.Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.154 SW_PAD_CTL_PAD_GPIO_EMC_29 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_29)

SW_PAD_CTL Register

Address: 401F_8000h base + 278h offset = 401F_8278h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>HYS</td>
</tr>
<tr>
<td>16–14</td>
<td>PUS, PUE, PKE, ODE</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

#### Field Descriptions

- **HYS**: Hyst. Enable Field
  - Select one out of next values for pad: GPIO_EMC_29
  - 0: HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1: HYS_1_Hysteresis_Enabled — Hysteresis Enabled

- **PUS**: Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_EMC_29
  - 00: PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01: PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10: PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11: PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **PUE**: Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_EMC_29
  - 0: PUE_0_Keeper — Keeper
  - 1: PUE_1_Pull — Pull

- **PKE**: Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_EMC_29
  - 0: PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1: PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

- **ODE**: Open Drain Enable Field
  - Select one out of next values for pad: GPIO_EMC_29

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
<td></td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>7–6 SPEED</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>This field is reserved. Reserved</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>5–3 DSE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Speed Field</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_EMC_29</td>
<td></td>
</tr>
<tr>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
<td></td>
</tr>
<tr>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
<td></td>
</tr>
<tr>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
<td></td>
</tr>
<tr>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>2–1</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0 SRE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Slew Rate Field</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_EMC_29</td>
<td></td>
</tr>
<tr>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
<td></td>
</tr>
<tr>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
<td></td>
</tr>
</tbody>
</table>

## 11.7.155 SW_PAD_CTL_PAD_GPIO_EMC_30 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_30)

**SW_PAD_CTL Register**

*Address: 401F_8000h base + 27Ch offset = 401F_827Ch*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 16 HYS | Hyst. Enable Field  
Select one out of next values for pad: GPIO_EMC_30  
0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled  
1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled |
| 15–14 | Pull Up / Down Config. Field  
Select one out of next values for pad: GPIO_EMC_30  
00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down  
01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up  
10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up  
11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
| 13 PUE | Pull / Keep Select Field  
Select one out of next values for pad: GPIO_EMC_30  
0 PUE_0_Keeper — Keeper  
1 PUE_1_Pull — Pull |
| 12 PKE | Pull / Keep Enable Field  
Select one out of next values for pad: GPIO_EMC_30  
0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled  
1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled |
| 11 ODE | Open Drain Enable Field  
Select one out of next values for pad: GPIO_EMC_30  
0 ODE_0_Open_Drain_Disabled — Open Drain Disabled  
1 ODE_1_Open_Drain_Enabled — Open Drain Enabled |
| 10–8 | This field is reserved. Reserved |
| 7–6 SPEED | Speed Field  
Select one out of next values for pad: GPIO_EMC_30  
00 SPEED_0_low_50MHz — low(50MHz)  
01 SPEED_1_medium_100MHz — medium(100MHz)  
10 SPEED_2_fast_150MHz — fast(150MHz)  
11 SPEED_3_max_200MHz — max(200MHz) |
| 5–3 DSE | Drive Strength Field  
Select one out of next values for pad: GPIO_EMC_30  
000 DSE_0_output_driver_disabled — output driver disabled;  
001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)  
010 DSE_2_R0_2 — R0/2 |

*Table continues on the next page...*
IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_30 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1
- This field is reserved.
Reserved

0 SRE
Slew Rate Field
Select one out of next values for pad: GPIO_EMC_30
0 SRE_0_Slow_Slew_Rate — Slow Slew Rate
1 SRE_1_Fast_Slew_Rate — Fast Slew Rate

11.7.156 SW_PAD_CTL_PAD_GPIO_EMC_31 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_31)

SW_PAD_CTL Register

Address: 401F_8000h base + 280h offset = 401F_8280h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bit</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_31 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.
Reserved |

16 HYS
Hyst. Enable Field
Select one out of next values for pad: GPIO_EMC_31
0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

15–14 PUS
Pull Up / Down Config. Field
Select one out of next values for pad: GPIO_EMC_31
00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>- This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>- This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_31</td>
</tr>
<tr>
<td></td>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.157 SW_PAD_CTL_PAD_GPIO_EMC_32 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_32)

SW_PAD_CTL Register

Address: 401F_8000h base + 284h offset = 401F_8284h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_32 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 16    | Hyst. Enable Field  
Select one out of next values for pad: GPIO_EMC_32  
0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled  
1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled |
| 15–14 | Pull Up / Down Config. Field  
Select one out of next values for pad: GPIO_EMC_32  
00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down  
01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up  
10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up  
11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
| 13    | Pull / Keep Select Field  
Select one out of next values for pad: GPIO_EMC_32  
0 PUE_0_Keeper — Keeper  
1 PUE_1_Pull — Pull |
| 12    | Pull / Keep Enable Field  
Select one out of next values for pad: GPIO_EMC_32  
0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled  
1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled |
| 11    | Open Drain Enable Field  
Select one out of next values for pad: GPIO_EMC_32 |

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_32 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_32</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_32</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_32</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.158 SW_PAD_CTL_PAD_GPIO_EMC_33 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_33)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 288h offset = 401F_8288h

<table>
<thead>
<tr>
<th>Bit</th>
<th>PUS</th>
<th>PUE</th>
<th>PKE</th>
<th>ODE</th>
<th>Reserved</th>
<th>SPEED</th>
<th>DSE</th>
<th>Reserved</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>RW</td>
<td>RW</td>
<td>RW</td>
<td>RW</td>
<td>RW</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
<td>1 0 0 0</td>
<td>1 0 1 0</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

---

_i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019_
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_33 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
<th>Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 16    | Hyst. Enable Field | Select one out of next values for pad: GPIO_EMC_33  
  0   HYS_0_Hysteresis_Disabled  — Hysteresis Disabled  
  1   HYS_1_Hysteresis_Enabled   — Hysteresis Enabled |
| 15–14 | Pull Up / Down Config. Field | Select one out of next values for pad: GPIO_EMC_33  
  00  PUS_0_100K_Ohm_Pull_Down   — 100K Ohm Pull Down  
  01  PUS_1_47K_Ohm_Pull_Up       — 47K Ohm Pull Up  
  10  PUS_2_100K_Ohm_Pull_Up      — 100K Ohm Pull Up  
  11  PUS_3_22K_Ohm_Pull_Up       — 22K Ohm Pull Up |
| 13    | Pull / Keep Select Field | Select one out of next values for pad: GPIO_EMC_33  
  0   PUE_0_Keeper  — Keeper  
  1   PUE_1_Pull    — Pull |
| 12    | Pull / Keep Enable Field | Select one out of next values for pad: GPIO_EMC_33  
  0   PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled  
  1   PKE_1_Pull_Keeper_Enabled  — Pull/Keeper Enabled |
| 11    | Open Drain Enable Field | Select one out of next values for pad: GPIO_EMC_33  
  0   ODE_0_Open_Drain_Disabled — Open Drain Disabled  
  1   ODE_1_Open_Drain_Enabled  — Open Drain Enabled |
| 10–8  | This field is reserved. | Reserved |
| 7–6   | Speed Field | Select one out of next values for pad: GPIO_EMC_33  
  00  SPEED_0_low_50MHz  — low(50MHz)  
  01  SPEED_1_medium_100MHz — medium(100MHz)  
  10  SPEED_2_fast_150MHz    — fast(150MHz)  
  11  SPEED_3_max_200MHz     — max(200MHz) |
| 5–3   | Drive Strength Field | Select one out of next values for pad: GPIO_EMC_33  
  000 DSE_0_output_driver_disabled — output driver disabled;  
  001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V   — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)  
  010 DSE_2_R0_2     — R0/2 |

*Table continues on the next page...*
## IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_33 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1
- This field is reserved.
- Reserved

<table>
<thead>
<tr>
<th>0 SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_33</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.159 SW_PAD_CTL_PAD_GPIO_EMC_34 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_34)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 28Ch offset = 401F_828Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–17</th>
<th>16</th>
<th>15–14</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0</td>
<td>0 0</td>
<td>0 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS  PUE  PKE  ODE  Reserved  SPEED  DSE  Reserved  SRE</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 1 0 0 0 0 1 0 1 1 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

## IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_34 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>16</th>
<th>Hyst. Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>15–14</th>
<th>Pull Up / Down Config. Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_34 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td></td>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td></td>
<td>00 SPEED_0_low_50MHz — low (50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium (100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast (150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max (200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td></td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_34</td>
</tr>
<tr>
<td></td>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.160  SW_PAD_CTL_PAD_GPIO_EMC_35 SW PAD Control
Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_35)

SW_PAD_CTL Register

Address: 401F_8000h base + 290h offset = 401F_8290h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>RW</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 1 0 0 0 0 0 1 0 1 1 0 0 0 0 0

IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_35 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_35</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_35</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_35</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_35</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_35</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_35 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

| 10–8  | This field is reserved. |
|       | Reserved |

| 7–6   | Speed Field |
| SPEED | Select one out of next values for pad: GPIO_EMC_35 |
| 00    | SPEED_0_low_50MHz — low (50MHz) |
| 01    | SPEED_1_medium_100MHz — medium (100MHz) |
| 10    | SPEED_2_fast_150MHz — fast (150MHz) |
| 11    | SPEED_3_max_200MHz — max (200MHz) |

| 5–3   | Drive Strength Field |
| DSE   | Select one out of next values for pad: GPIO_EMC_35 |
| 000   | DSE_0_output_driver_disabled — output driver disabled; |
| 001   | DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0 (150 Ohm @ 3.3V, 260 Ohm @ 1.8V) |
| 010   | DSE_2_R0_2 — R0/2 |
| 011   | DSE_3_R0_3 — R0/3 |
| 100   | DSE_4_R0_4 — R0/4 |
| 101   | DSE_5_R0_5 — R0/5 |
| 110   | DSE_6_R0_6 — R0/6 |
| 111   | DSE_7_R0_7 — R0/7 |

| 2–1   | This field is reserved. |
|       | Reserved |

| 0     | Slew Rate Field |
| SRE   | Select one out of next values for pad: GPIO_EMC_35 |
| 0     | SRE_0_Slow_Slew_Rate — Slow Slew Rate |
| 1     | SRE_1_Fast_Slew_Rate — Fast Slew Rate |

---

**11.7.161 SW_PAD_CTL_PAD_GPIO_EMC_36 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_36)**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 294h offset = 401F_8294h
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_36 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_36 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1  This field is reserved.  
-   Reserved

<table>
<thead>
<tr>
<th>0</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_36</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.162 SW_PAD_CTL_PAD_GPIO_EMC_37 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_37)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 298h offset = 401F_8298h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_37 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.  
-   Reserved

<table>
<thead>
<tr>
<th>16</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>15–14</th>
<th>PUS</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_37 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE — Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE — Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE — Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td></td>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED — Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td></td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE — Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td></td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE — Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_37</td>
</tr>
<tr>
<td></td>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.163 SW_PAD_CTL_PAD_GPIO_EMC_38 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_38)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 29Ch offset = 401F_829Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td></td>
<td>This field is reserved.</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td>Hyst. Enable Field</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>R</td>
<td>Pull Up / Down Config. Field</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>R</td>
<td>Pull / Keep Select Field</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>R</td>
<td>Pull / Keep Enable Field</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>R</td>
<td>Open Drain Enable Field</td>
<td>ODE</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_38 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>HYS</td>
<td>Hysteresis</td>
</tr>
<tr>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>ODE</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

- **HYS**: Hysteresis Enable Field
  - 0: HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1: HYS_1_Hysteresis_Enabled — Hysteresis Enabled

- **PUS**: Pull Up / Down Config. Field
  - 00: PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01: PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10: PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11: PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **PUE**: Pull / Keep Select Field
  - 0: PUE_0_Keeper — Keeper
  - 1: PUE_1_Pull — Pull

- **PKE**: Pull / Keep Enable Field
  - 0: PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1: PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_38 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0. ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>1. ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

| 10–8  | This field is reserved. |
|       | Reserved |

<table>
<thead>
<tr>
<th>7–6 SPEED</th>
<th>Speed Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_38</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>5–3 DSE</th>
<th>Drive Strength Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_38</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

| 2–1 | This field is reserved. |
|     | Reserved |

<table>
<thead>
<tr>
<th>0 SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_38</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

---

### 11.7.164 SW_PAD_CTL_PAD_GPIO_EMC_39 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_39)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2A0h offset = 401F_82A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Reserved</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>PUS</th>
<th>PUE</th>
<th>PKE</th>
<th>ODE</th>
<th>Reserved</th>
<th>SPEED</th>
<th>DSE</th>
<th>Reserved</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Reserved</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_39 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 16 HYS | Hyst. Enable Field  
Select one out of next values for pad: GPIO_EMC_39  
0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled  
1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled |
| 15–14 PUS | Pull Up / Down Config. Field  
Select one out of next values for pad: GPIO_EMC_39  
00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down  
01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up  
10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up  
11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
| 13 PUE | Pull / Keep Select Field  
Select one out of next values for pad: GPIO_EMC_39  
0 PUE_0_Keeper — Keeper  
1 PUE_1_Pull — Pull |
| 12 PKE | Pull / Keep Enable Field  
Select one out of next values for pad: GPIO_EMC_39  
0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled  
1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled |
| 11 ODE | Open Drain Enable Field  
Select one out of next values for pad: GPIO_EMC_39  
0 ODE_0_Open_Drain_Disabled — Open Drain Disabled  
1 ODE_1_Open_Drain_Enabled — Open Drain Enabled |
| 10–8 - | This field is reserved. Reserved |
| 7–6 SPEED | Speed Field  
Select one out of next values for pad: GPIO_EMC_39  
00 SPEED_0_low_50MHz — low(50MHz)  
01 SPEED_1_medium_100MHz — medium(100MHz)  
10 SPEED_2_fast_150MHz — fast(150MHz)  
11 SPEED_3_max_200MHz — max(200MHz) |
| 5–3 DSE | Drive Strength Field  
Select one out of next values for pad: GPIO_EMC_39  
000 DSE_0_output_driver_disabled — output driver disabled;  
001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)  
010 DSE_2_R0_2 — R0/2 |

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_39 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1
-  This field is reserved.
   Reserved

<table>
<thead>
<tr>
<th>0 SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>Select one out of next values for pad: GPIO_EMC_39</td>
<td></td>
</tr>
<tr>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
<td></td>
</tr>
<tr>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
<td></td>
</tr>
</tbody>
</table>

### 11.7.165 SW_PAD_CTL_PAD_GPIO_EMC_40 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_40)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2A4h offset = 401F_82A4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>PUS</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>PUE</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>PKE</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>ODE</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>SPEED</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>DSE</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_40 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.
   Reserved |

<table>
<thead>
<tr>
<th>16 HYS</th>
<th>Hyst. Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>Select one out of next values for pad: GPIO_EMC_40</td>
<td></td>
</tr>
<tr>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
<td></td>
</tr>
<tr>
<td>1 HYS_1_Hysteresis.Enabled — Hysteresis Enabled</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>15–14 PUS</th>
<th>Pull Up / Down Config. Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>Select one out of next values for pad: GPIO_EMC_40</td>
<td></td>
</tr>
<tr>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
<td></td>
</tr>
<tr>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_40 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
</tbody>
</table>
| 13 | **PUE** Pull / Keep Select Field  
Select one out of next values for pad: GPIO_EMC_40  
0 **PUE_0_Keeper** — Keeper  
1 **PUE_1_Pull** — Pull |
| 12 | **PKE** Pull / Keep Enable Field  
Select one out of next values for pad: GPIO_EMC_40  
0 **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled  
1 **PKE_1_Pull_Keeper_Enable** — Pull/Keeper Enabled |
| 11 | **ODE** Open Drain Enable Field  
Select one out of next values for pad: GPIO_EMC_40  
0 **ODE_0_Open_Drain_Disabled** — Open Drain Disabled  
1 **ODE_1_Open_Drain_Enable** — Open Drain Enabled |
| 10-8 | This field is reserved.  
Reserved |
| 7-6 | **SPEED** Speed Field  
Select one out of next values for pad: GPIO_EMC_40  
00 **SPEED_0_low_50MHz** — low(50MHz)  
01 **SPEED_1_medium_100MHz** — medium(100MHz)  
10 **SPEED_2_fast_150MHz** — fast(150MHz)  
11 **SPEED_3_max_200MHz** — max(200MHz) |
| 5-3 | **DSE** Drive Strength Field  
Select one out of next values for pad: GPIO_EMC_40  
000 **DSE_0_output_driver_disabled** — output driver disabled;  
001 **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)  
010 **DSE_2_R0_2** — R0/2  
011 **DSE_3_R0_3** — R0/3  
100 **DSE_4_R0_4** — R0/4  
101 **DSE_5_R0_5** — R0/5  
110 **DSE_6_R0_6** — R0/6  
111 **DSE_7_R0_7** — R0/7 |
| 2-1 | This field is reserved.  
Reserved |
| 0 | **SRE** Slew Rate Field  
Select one out of next values for pad: GPIO_EMC_40  
0 **SRE_0_Slow_Slew_Rate** — Slow Slew Rate  
1 **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
### 11.7.166 SW_PAD_CTL_PAD_GPIO_EMC_41 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_41)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2A8h offset = 401F_82A8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15–11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_41 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_EMC_41

| 0 | HYS_0_Hysteresis_Disabled — Hysteresis Disabled |
| 1 | HYS_1_Hysteresis_Enabled — Hysteresis Enabled |

| 15–14  | Pull Up / Down Config. Field |

Select one out of next values for pad: GPIO_EMC_41

| 00 | PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down |
| 01 | PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up |
| 10 | PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up |
| 11 | PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |

| 13     | Pull / Keep Select Field |

Select one out of next values for pad: GPIO_EMC_41

| 0 | PUE_0_Keeper — Keeper |
| 1 | PUE_1.Pull — Pull |

| 12     | Pull / Keep Enable Field |

Select one out of next values for pad: GPIO_EMC_41

| 0 | PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled |
| 1 | PKE_1_Pull_Keeper_Enable — Pull/Keeper Enabled |

| 11     | Open Drain Enable Field |

Select one out of next values for pad: GPIO_EMC_41

Table continues on the next page...
Field & Description

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain.Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_41</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_41</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_EMC_41</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.167  SW_PAD_CTL_PAD_GPIO_AD_B0_00 SW PAD Control Register
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_00)

SW_PAD_CTL Register

Address: 401F_8000h base + 2ACh offset = 401F_82ACh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserves</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>0</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>1</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>1</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_00 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_00</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
## SW_PAD_CTL_PAD_GPIO_AD_B0_01 SW PAD Control Register

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2B0h offset = 401F_82B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>HYS</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>PUS</th>
<th>PUE</th>
<th>PKE</th>
<th>ODE</th>
<th>Reserved</th>
<th>SPEED</th>
<th>DSE</th>
<th>Reserved</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 16    | Hyst. Enable Field  
Select one out of next values for pad: GPIO_AD_B0_01 |
| 0     | HYS_0_Hysteresis_Disabled — Hysteresis Disabled |
| 1     | HYS_1_Hysteresis_Enabled — Hysteresis Enabled |
| 15–14 | Pull Up / Down Config. Field  
Select one out of next values for pad: GPIO_AD_B0_01 |
| 00    | PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down |
| 01    | PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up |
| 10    | PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up |
| 11    | PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
| 13    | Pull / Keep Select Field  
Select one out of next values for pad: GPIO_AD_B0_01 |
| 0     | PUE_0_Keeper — Keeper |
| 1     | PUE_1_Pull — Pull |
| 12    | Pull / Keep Enable Field  
Select one out of next values for pad: GPIO_AD_B0_01 |
| 0     | PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled |
| 1     | PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled |
| 11    | Open Drain Enable Field  
Select one out of next values for pad: GPIO_AD_B0_01 |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_01</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_01</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_01</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.169 SW_PAD_CTL_PAD_GPIO_AD_B0_02 SW PAD Control Register

**(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_02)**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2B4h offset = 401F_82B4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_02 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
<tr>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
<tr>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_02 Field Descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> — Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> — Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> — Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_02</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
## 11.7.170 SW_PAD_CTL_PAD_GPIO_AD_B0_03 SW PAD Control Register

**(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_03)**

### SW_PAD_CTL Register

Address: 401F_8000h base + 2B8h offset = 401F_82B8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PUE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_03 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

- **HYS (Hyst. Enable Field)**
  - Select one out of next values for pad: GPIO_AD_B0_03
  - 0  **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
  - 1  **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled

- **PUS (Pull Up / Down Config. Field)**
  - Select one out of next values for pad: GPIO_AD_B0_03
  - 00  **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
  - 01  **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
  - 10  **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
  - 11  **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

- **PUE (Pull / Keep Select Field)**
  - Select one out of next values for pad: GPIO_AD_B0_03
  - 0  **PUE_0_Keeper** — Keeper
  - 1  **PUE_1_Pull** — Pull

- **PKE (Pull / Keep Enable Field)**
  - Select one out of next values for pad: GPIO_AD_B0_03
  - 0  **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
  - 1  **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled

- **ODE (Open Drain Enable Field)**
  - Select one out of next values for pad: GPIO_AD_B0_03

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> — Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_03</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> — Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_03</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> — Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_03</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_AD_B0_04 SW PAD Control Register

**Address:** 401F_8000h base + 2BCh offset = 401F_82BCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>RW</th>
<th>Reserved</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>-</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
<td></td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
<td>Open Drain Enable Field</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...

---

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**

638

NXP Semiconductors
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 ODE_0_Open_Drain_Disabled</td>
<td>Open Drain Disabled</td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled</td>
<td>Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
</tr>
<tr>
<td>00 SPEED_0_low_50MHz</td>
<td>low(50MHz)</td>
</tr>
<tr>
<td>01 SPEED_1_medium_100MHz</td>
<td>medium(100MHz)</td>
</tr>
<tr>
<td>10 SPEED_2_fast_150MHz</td>
<td>fast(150MHz)</td>
</tr>
<tr>
<td>11 SPEED_3_max_200MHz</td>
<td>max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
</tr>
<tr>
<td>000 DSE_0_output_driver_disabled</td>
<td>output driver disabled;</td>
</tr>
<tr>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</td>
<td>R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010 DSE_2_R0_2</td>
<td>R0/2</td>
</tr>
<tr>
<td>011 DSE_3_R0_3</td>
<td>R0/3</td>
</tr>
<tr>
<td>100 DSE_4_R0_4</td>
<td>R0/4</td>
</tr>
<tr>
<td>101 DSE_5_R0_5</td>
<td>R0/5</td>
</tr>
<tr>
<td>110 DSE_6_R0_6</td>
<td>R0/6</td>
</tr>
<tr>
<td>111 DSE_7_R0_7</td>
<td>R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_04</td>
</tr>
<tr>
<td>0 SRE_0_Slow_Slew_Rate</td>
<td>Slow Slew Rate</td>
</tr>
<tr>
<td>1 SRE_1_Fast_Slew_Rate</td>
<td>Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.172  SW_PAD_CTL_PAD_GPIO_AD_B0_05 SW PAD Control Register
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_05)

SW_PAD_CTL Register

Address: 401F_8000h base + 2C0h offset = 401F_82C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_05</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.173  SW_PAD_CTL_PAD_GPIO_AD_B0_06 SW PAD Control Register
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_06)

SW_PAD_CTL Register

Address: 401F_8000h base + 2C4h offset = 401F_82C4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_06 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
<tr>
<td></td>
<td>0  HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1  HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
<tr>
<td></td>
<td>00  PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01  PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10  PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11  PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
<tr>
<td></td>
<td>0  PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1  PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
<tr>
<td></td>
<td>0  PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1  PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_06 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>SPEED</td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>DSE</td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td>SRE</td>
<td>Select one out of next values for pad: GPIO_AD_B0_06</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.174 SW_PAD_CTL_PAD_GPIO_AD_B0_07 SW PAD Control Register
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_07)

SW_PAD_CTL Register

Address: 401F_8000h base + 2C8h offset = 401F_82C8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 16    | HYS
      | Hyst. Enable Field
      | Select one out of next values for pad: GPIO_AD_B0_07
      | 0  HYS_0_Hysteresis_Disabled — Hysteresis Disabled
      | 1  HYS_1_Hysteresis_Enabled — Hysteresis Enabled |
| 15–14 | PUS
      | Pull Up / Down Config. Field
      | Select one out of next values for pad: GPIO_AD_B0_07
      | 00  PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
      | 01  PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
      | 10  PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
      | 11  PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
| 13    | PUE
      | Pull / Keep Select Field
      | Select one out of next values for pad: GPIO_AD_B0_07
      | 0  PUE_0_Keeper — Keeper
      | 1  PUE_1_Pull — Pull |
| 12    | PKE
      | Pull / Keep Enable Field
      | Select one out of next values for pad: GPIO_AD_B0_07
      | 0  PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
      | 1  PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled |
| 11    | ODE
      | Open Drain Enable Field
      | Select one out of next values for pad: GPIO_AD_B0_07

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_07</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_07</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_07</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.175  SW_PAD_CTL_PAD_GPIO_AD_B0_08 SW PAD Control Register
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_08)

SW_PAD_CTL Register

Address: 401F_8000h base + 2CCh offset = 401F_82CCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_08 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>ODE</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_08 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

10–8  
-  
This field is reserved.  
Reserved

7–6   
SPEED  
Speed Field  
Select one out of next values for pad: GPIO_AD_B0_08  
00   
SPEED_0_low_50MHz — low(50MHz)  
01   
SPEED_1_medium_100MHz — medium(100MHz)  
10   
SPEED_2_fast_150MHz — fast(150MHz)  
11   
SPEED_3_max_200MHz — max(200MHz)  

5–3   
DSE  
Drive Strength Field  
Select one out of next values for pad: GPIO_AD_B0_08  
000   
DSE_0_output_driver_disabled — output driver disabled;  
001   
DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)  
010   
DSE_2_R0_2 — R0/2  
011   
DSE_3_R0_3 — R0/3  
100   
DSE_4_R0_4 — R0/4  
101   
DSE_5_R0_5 — R0/5  
110   
DSE_6_R0_6 — R0/6  
111   
DSE_7_R0_7 — R0/7  

2–1  
-  
This field is reserved.  
Reserved

0   
SRE  
Slew Rate Field  
Select one out of next values for pad: GPIO_AD_B0_08  
0   
SRE_0_Slow_Slew_Rate — Slow Slew Rate  
1   
SRE_1_Fast_Slew_Rate — Fast Slew Rate
11.7.176  SW_PAD_CTL_PAD_GPIO_AD_B0_09 SW PAD Control Register  
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_09)

SW_PAD_CTL Register

Address: 401F_8000h base + 2D0h offset = 401F_82D0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SRE</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_09 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field Select one out of next values for pad: GPIO_AD_B0_09</td>
</tr>
</tbody>
</table>

#### 0  **ODE_0_Open_Drain_Disabled** — Open Drain Disabled

#### 1  **ODE_1_Open_Drain_Enabled** — Open Drain Enabled

#### 7–6  **SPEED** Speed Field

- **00** SPEED_0_low_50MHz — low(50MHz)
- **01** SPEED_1_medium_100MHz — medium(100MHz)
- **10** SPEED_2_fast_150MHz — fast(150MHz)
- **11** SPEED_3_max_200MHz — max(200MHz)

#### 5–3  **DSE** Drive Strength Field

- **000** DSE_0_output_driver_disabled — output driver disabled;
- **001** DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
- **010** DSE_2_R0_2 — R0/2
- **011** DSE_3_R0_3 — R0/3
- **100** DSE_4_R0_4 — R0/4
- **101** DSE_5_R0_5 — R0/5
- **110** DSE_6_R0_6 — R0/6
- **111** DSE_7_R0_7 — R0/7

#### 2–1  This field is reserved. Reserved

#### 0  **SRE** Slew Rate Field

- **0** SRE_0_Slow_Slew_Rate — Slow Slew Rate
- **1** SRE_1_Fast_Slew_Rate — Fast Slew Rate
11.7.177 SW_PAD_CTL_PAD_GPIO_AD_B0_10 SW PAD Control
Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_10)

SW_PAD_CTL Register

Address: 401F_8000h base + 2D4h offset = 401F_82D4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_10</td>
</tr>
</tbody>
</table>

Table continues on the next page...

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
</tbody>
</table>

| 10–8  | This field is reserved. |
|       | Reserved |

| 7–6   | Speed Field |
|       | Select one out of next values for pad: GPIO_AD_B0_10 |
| 00    | **SPEED_0_low_50MHz** — low(50MHz) |
| 01    | **SPEED_1_medium_100MHz** — medium(100MHz) |
| 10    | **SPEED_2_fast_150MHz** — fast(150MHz) |
| 11    | **SPEED_3_max_200MHz** — max(200MHz) |

| 5–3   | Drive Strength Field |
|       | Select one out of next values for pad: GPIO_AD_B0_10 |
| 000   | **DSE_0_output_driver_disabled** — output driver disabled; |
| 001   | **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V) |
| 010   | **DSE_2_R0_2** — R0/2 |
| 011   | **DSE_3_R0_3** — R0/3 |
| 100   | **DSE_4_R0_4** — R0/4 |
| 101   | **DSE_5_R0_5** — R0/5 |
| 110   | **DSE_6_R0_6** — R0/6 |
| 111   | **DSE_7_R0_7** — R0/7 |

| 2–1   | This field is reserved. |
|       | Reserved |

| 0     | Slew Rate Field |
|       | Select one out of next values for pad: GPIO_AD_B0_10 |
| 0     | **SRE_0_Slow_Slew_Rate** — Slow Slew Rate |
| 1     | **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
11.7.178  **SW_PAD_CTL_PAD_GPIO_AD_B0_11 SW PAD Control Register**  
*(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_11)*

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2D8h offset = 401F_82D8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>PUS</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PUE</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_11 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_11</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_11</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_11</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_11</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_11</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_11 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
</tbody>
</table>

### Field Descriptions:

- **0** ODE_0_Open_Drain_Disabled — Open Drain Disabled
- **1** ODE_1_Open_Drain_Enabled — Open Drain Enabled
- **10–8** Reserved
- **7–6** SPEED
  - Select one out of next values for pad: GPIO_AD_B0_11
    - **00** SPEED_0_low_50MHz — low(50MHz)
    - **01** SPEED_1_medium_100MHz — medium(100MHz)
    - **10** SPEED_2_fast_150MHz — fast(150MHz)
    - **11** SPEED_3_max_200MHz — max(200MHz)
- **5–3** DSE
  - Select one out of next values for pad: GPIO_AD_B0_11
    - **000** DSE_0_output_driver_disabled — output driver disabled;
    - **001** DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm @ 1.8V)
    - **010** DSE_2_R0_2 — R0/2
    - **011** DSE_3_R0_3 — R0/3
    - **100** DSE_4_R0_4 — R0/4
    - **101** DSE_5_R0_5 — R0/5
    - **110** DSE_6_R0_6 — R0/6
    - **111** DSE_7_R0_7 — R0/7
- **2–1** Reserved
- **0** SRE
  - Select one out of next values for pad: GPIO_AD_B0_11
    - **0** SRE_0_Slow_Slew_Rate — Slow Slew Rate
    - **1** SRE_1_Fast_Slew_Rate — Fast Slew Rate
### 11.7.179 SW_PAD_CTL_PAD_GPIO_AD_B0_12 SW PAD Control Register
**(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_12)**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2DCh offset = 401F_82DCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
<td>R/R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### Field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_12</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_AD_B0_13 SW PAD Control Register

**Address:** 401F_8000h base + 2E0h offset = 401F_82E0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td></td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

#### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
<tr>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
<tr>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_13 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
</tbody>
</table>

| 10–8  | Reserved |

<table>
<thead>
<tr>
<th>7–6</th>
<th><strong>SPEED</strong> Speed Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>5–3</th>
<th><strong>DSE</strong> Drive Strength Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_3V_260_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
</tbody>
</table>

| 2–1   | Reserved |

<table>
<thead>
<tr>
<th>0</th>
<th><strong>SRE</strong> Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_13</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.181 SW_PAD_CTL_PAD_GPIO_AD_B0_14 SW PAD Control Register

#### (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_14)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2E4h offset = 401F_82E4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_14</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_14</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_14</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_14</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_14</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_14 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
</tbody>
</table>

#### Speed Field
Select one out of next values for pad: GPIO_AD_B0_14
- 00 **SPEED_0_low_50MHz** — low(50MHz)
- 01 **SPEED_1_medium_100MHz** — medium(100MHz)
- 10 **SPEED_2_fast_150MHz** — fast(150MHz)
- 11 **SPEED_3_max_200MHz** — max(200MHz)

#### Drive Strength Field
Select one out of next values for pad: GPIO_AD_B0_14
- 000 **DSE_0_output_driver_disabled** — output driver disabled;
- 001 **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
- 010 **DSE_2_R0_2** — R0/2
- 011 **DSE_3_R0_3** — R0/3
- 100 **DSE_4_R0_4** — R0/4
- 101 **DSE_5_R0_5** — R0/5
- 110 **DSE_6_R0_6** — R0/6
- 111 **DSE_7_R0_7** — R0/7

#### Slew Rate Field
Select one out of next values for pad: GPIO_AD_B0_14
- 0 **SRE_0_Slow_Slew_Rate** — Slow Slew Rate
- 1 **SRE_1_Fast_Slew_Rate** — Fast Slew Rate
11.7.182  SW_PAD_CTL_PAD_GPIO_AD_B0_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_15)

SW_PAD_CTL Register

Address: 401F_8000h base + 2E8h offset = 401F_82E8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>HYS</td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>PUS</td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>PUE</td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>PKE</td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>ODE</td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_15 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B0_15</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.183 SW_PAD_CTL_PAD_GPIO_AD_B1_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_00)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 2ECh offset = 401F_82ECh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. <strong>Reserved</strong></td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

- **HYS**
  - Hyst. Enable Field
  - Select one out of next values for pad: GPIO_AD_B1_00
  - 0 **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
  - 1 **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled

- **PUS**
  - Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_AD_B1_00
  - 00 **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
  - 01 **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
  - 10 **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
  - 11 **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

- **PUE**
  - Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_AD_B1_00
  - 0 **PUE_0_Keeper** — Keeper
  - 1 **PUE_1_Pull** — Pull

- **PKE**
  - Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_AD_B1_00
  - 0 **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
  - 1 **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_00</td>
</tr>
<tr>
<td>0</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_00</td>
</tr>
<tr>
<td>00</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_00</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.184 SW_PAD_CTL_PAD_GPIO_AD_B1_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_01)

SW_PAD_CTL Register

Address: 401F_8000h base + 2F0h offset = 401F_82F0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_01</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keep_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keep_Enable — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_01</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ODE_0_Open_Drain_Disabled</td>
<td>Open Drain Disabled</td>
</tr>
<tr>
<td>ODE_1_Open_Drain_Enabled</td>
<td>Open Drain Enabled</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SPEED_0_low_50MHz</td>
<td>low(50MHz)</td>
</tr>
<tr>
<td>SPEED_1_medium_100MHz</td>
<td>medium(100MHz)</td>
</tr>
<tr>
<td>SPEED_2_fast_150MHz</td>
<td>fast(150MHz)</td>
</tr>
<tr>
<td>SPEED_3_max_200MHz</td>
<td>max(200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DSE_0_output_driver_disabled</td>
<td>output driver disabled;</td>
</tr>
<tr>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</td>
<td>R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>DSE_2_R0_2</td>
<td>R0/2</td>
</tr>
<tr>
<td>DSE_3_R0_3</td>
<td>R0/3</td>
</tr>
<tr>
<td>DSE_4_R0_4</td>
<td>R0/4</td>
</tr>
<tr>
<td>DSE_5_R0_5</td>
<td>R0/5</td>
</tr>
<tr>
<td>DSE_6_R0_6</td>
<td>R0/6</td>
</tr>
<tr>
<td>DSE_7_R0_7</td>
<td>R0/7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRE_0_Slow_Slew_Rate</td>
<td>Slow Slew Rate</td>
</tr>
<tr>
<td>SRE_1_Fast_Slew_Rate</td>
<td>Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL PAD_GPIO_AD_B1_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_02)

**Address:** 401F_8000h base + 2F4h offset = 401F_82F4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Bit</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R/W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_02 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_02</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_02</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_02</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_02</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_02</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_02 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_AD_B1_02

| 00   | **SPEED_0_low_50MHz** — low(50MHz) |
| 01   | **SPEED_1_medium_100MHz** — medium(100MHz) |
| 10   | **SPEED_2_fast_150MHz** — fast(150MHz) |
| 11   | **SPEED_3_max_200MHz** — max(200MHz) |
| 5–3  | **DSE** Drive Strength Field |

Select one out of next values for pad: GPIO_AD_B1_02

| 000  | **DSE_0_output_driver_disabled** — output driver disabled; |
| 001  | **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V) |
| 010  | **DSE_2_R0_2** — R0/2 |
| 011  | **DSE_3_R0_3** — R0/3 |
| 100  | **DSE_4_R0_4** — R0/4 |
| 101  | **DSE_5_R0_5** — R0/5 |
| 110  | **DSE_6_R0_6** — R0/6 |
| 111  | **DSE_7_R0_7** — R0/7 |
| 2–1  | This field is reserved. Reserved |
| 0    | **SRE** Slew Rate Field |

Select one out of next values for pad: GPIO_AD_B1_02

| 0    | **SRE_0_Slow_Slew_Rate** — Slow Slew Rate |
| 1    | **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
11.7.186  SW_PAD_CTL_PAD_GPIO_AD_B1_03 SW PAD Control Register  
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_03)

SW_PAD_CTL Register

Address: 401F_8000h base + 2F8h offset = 401F_82F8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_03 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

- **31–17 -**
  - This field is reserved. Reserved

- **16 HYS**
  - Hyst. Enable Field
  - Select one out of next values for pad: GPIO_AD_B1_03
  - 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1 HYS_1_Hysteresis.Enabled — Hysteresis Enabled

- **15–14 PUS**
  - Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_AD_B1_03
  - 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **13 PUE**
  - Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_AD_B1_03
  - 0 PUE_0_Keeper — Keeper
  - 1 PUE_1_Pull — Pull

- **12 PKE**
  - Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_AD_B1_03
  - 0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

- **11 ODE**
  - Open Drain Enable Field
  - Select one out of next values for pad: GPIO_AD_B1_03

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_03 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field&lt;br&gt; Select one out of next values for pad: GPIO_AD_B1_03&lt;br&gt; 00 SPEED_0_low_50MHz — low(50MHz)&lt;br&gt; 01 SPEED_1_medium_100MHz — medium(100MHz)&lt;br&gt; 10 SPEED_2_fast_150MHz — fast(150MHz)&lt;br&gt; 11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field&lt;br&gt; Select one out of next values for pad: GPIO_AD_B1_03&lt;br&gt; 000 DSE_0_output_driver_disabled — output driver disabled;&lt;br&gt; 001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)&lt;br&gt; 010 DSE_2_R0_2 — R0/2&lt;br&gt; 011 DSE_3_R0_3 — R0/3&lt;br&gt; 100 DSE_4_R0_4 — R0/4&lt;br&gt; 101 DSE_5_R0_5 — R0/5&lt;br&gt; 110 DSE_6_R0_6 — R0/6&lt;br&gt; 111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field&lt;br&gt; Select one out of next values for pad: GPIO_AD_B1_03&lt;br&gt; 0 SRE_0_Slow_Slew_Rate — Slow Slew Rate&lt;br&gt; 1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.187 SW_PAD_CTL_PAD_GPIO_AD_B1_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_04)

SW_PAD_CTL Register

Address: 401F_8000h base + 2FCh offset = 401F_82FCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td>Reset</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td>HYS</td>
</tr>
<tr>
<td>15</td>
<td>R</td>
<td>PUS</td>
</tr>
<tr>
<td>14</td>
<td>R</td>
<td>PUE</td>
</tr>
<tr>
<td>13</td>
<td>R</td>
<td>PKE</td>
</tr>
<tr>
<td>12</td>
<td>R</td>
<td>ODE</td>
</tr>
<tr>
<td>11</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>R</td>
<td>SPEED</td>
</tr>
<tr>
<td>9</td>
<td>R</td>
<td>DSE</td>
</tr>
<tr>
<td>8</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>R</td>
<td>SRE</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td>HYS</td>
</tr>
<tr>
<td>15</td>
<td>R</td>
<td>PUS</td>
</tr>
<tr>
<td>14</td>
<td>R</td>
<td>PUE</td>
</tr>
<tr>
<td>13</td>
<td>R</td>
<td>PKE</td>
</tr>
<tr>
<td>12</td>
<td>R</td>
<td>ODE</td>
</tr>
<tr>
<td>11</td>
<td>R</td>
<td>ODE</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_04 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.188 SW_PAD_CTL_PAD_GPIO_AD_B1_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_05)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 300h offset = 401F_8300h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
<td>-</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. (Reserved)</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

- **HYS**: Hyst. Enable Field
  - 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1 HYS_1_Hysteresis_ENABLED — Hysteresis Enabled

- **PUS**: Pull Up / Down Config. Field
  - 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **PUE**: Pull / Keep Select Field
  - 0 PUE_0_Keeper — Keeper
  - 1 PUE_1_Pull — Pull

- **PKE**: Pull / Keep Enable Field
  - 0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1 PKE_1_Pull_Keeper_ENABLED — Pull/Keeper Enabled

Table continues on the next page...
## IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_05 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_05</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_05</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_05</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
## 11.7.189 SW_PAD_CTL_PAD_GPIO_AD_B1_06 SW PAD Control Register

(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_06)

### SW_PAD_CTL Register

Address: 401F_8000h base + 304h offset = 401F_8304h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC SW_PAD_CTL_PAD_GPIO_AD_B1_06 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain Enabled</strong>  — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 Ohm @ 1.8V)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_06</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.190 SW_PAD_CTL_PAD_GPIO_AD_B1_07 SW PAD Control Register

**(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_07)**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 308h offset = 401F_8308h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- **Field**
  - **31–17** - This field is reserved.
    - **Reserved**
  - **16** **HYS** - Hyst. Enable Field
    - Select one out of next values for pad: GPIO_AD_B1_07
      - 0 **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
      - 1 **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled
  - **15–14** **PUS** - Pull Up / Down Config. Field
    - Select one out of next values for pad: GPIO_AD_B1_07
      - 00 **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
      - 01 **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
      - 10 **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
      - 11 **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up
  - **13** **PUE** - Pull / Keep Select Field
    - Select one out of next values for pad: GPIO_AD_B1_07
      - 0 **PUE_0_Keeper** — Keeper
      - 1 **PUE_1_Pull** — Pull
  - **12** **PKE** - Pull / Keep Enable Field
    - Select one out of next values for pad: GPIO_AD_B1_07
      - 0 **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
      - 1 **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled
  - **11** **ODE** - Open Drain Enable Field
    - Select one out of next values for pad: GPIO_AD_B1_07

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_AD_B1_07

- 00 SPEED_0_low_50MHz — low(50MHz)
- 01 SPEED_1_medium_100MHz — medium(100MHz)
- 10 SPEED_2_fast_150MHz — fast(150MHz)
- 11 SPEED_3_max_200MHz — max(200MHz)

| 5–3   | Drive Strength Field |

Select one out of next values for pad: GPIO_AD_B1_07

- 000 DSE_0_output_driver_disabled — output driver disabled;
- 001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
- 010 DSE_2_R0_2 — R0/2
- 011 DSE_3_R0_3 — R0/3
- 100 DSE_4_R0_4 — R0/4
- 101 DSE_5_R0_5 — R0/5
- 110 DSE_6_R0_6 — R0/6
- 111 DSE_7_R0_7 — R0/7

<table>
<thead>
<tr>
<th>2–1</th>
<th>This field is reserved. Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_AD_B1_07

- 0 SRE_0_Slow_Slew_Rate — Slow Slew Rate
- 1 SRE_1_Fast_Slew_Rate — Fast Slew Rate
11.7.191  SW_PAD_CTL_PAD_GPIO_AD_B1_08 SW PAD Control Register  
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_08)

SW_PAD_CTL Register

Address: 401F_8000h base + 30Ch offset = 401F_830Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_08 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis.Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SWM_PAD_CTL_PAD_GPIO_AD_B1_08 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> — Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> — Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> — Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.192 SW_PAD_CTL_PAD_GPIO_AD_B1_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_09)

SW_PAD_CTL Register

Address: 401F_8000h base + 310h offset = 401F_8310h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_09 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td></td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
<tr>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td></td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
<tr>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td></td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td></td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_PullKeeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_PullKeeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
<tr>
<td></td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC SW_PAD_CTL_PAD_GPIO_AD_B1_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.193 SW_PAD_CTL_PAD_GPIO_AD_B1_10 SW PAD Control Register

**SW_PAD_CTL Register**

Address: 401F_8000h base + 314h offset = 401F_8314h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-17</td>
<td>31 – 17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 PKE_1_Pull_Keeper_ENABLED — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td><strong>Reserved</strong></td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td><strong>Reserved</strong></td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.194 SW_PAD_CTL_PAD_GPIO_AD_B1_11 SW PAD Control Register

**(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_11)**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 318h offset = 401F_8318h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
<td></td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
</tr>
<tr>
<td>0</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_11</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.195  SW_PAD_CTL_PAD_GPIO_AD_B1_12 SW PAD Control Register
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_12)

SW_PAD_CTL Register

Address: 401F_8000h base + 31Ch offset = 401F_831Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SRE</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_12 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_12</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_12</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_12</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
## IOMUXC Memory Map/Register Definition

### 11.7.196 SW_PAD_CTL_PAD_GPIO_AD_B1_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_13)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 320h offset = 401F_8320h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R/W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PUE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PKE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>ODE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>SPEED</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>DSE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>SRE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>PUS</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>PUE</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>PKE</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_13</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_13</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_13</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_AD_B1_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_14)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 324h offset = 401F_8324h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. <strong>Reserved</strong></td>
</tr>
</tbody>
</table>
| 16    | Hyst. Enable Field **HYS**  
Select one out of next values for pad: GPIO_AD_B1_14  
0 **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled  
1 **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled |
| 15–14 | Pull Up / Down Config. Field **PUS**  
Select one out of next values for pad: GPIO_AD_B1_14  
00 **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down  
01 **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up  
10 **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up  
11 **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up |
| 13    | Pull / Keep Select Field **PUE**  
Select one out of next values for pad: GPIO_AD_B1_14  
0 **PUE_0_Keeper** — Keeper  
1 **PUE_1_Pull** — Pull |
| 12    | Pull / Keep Enable Field **PKE**  
Select one out of next values for pad: GPIO_AD_B1_14  
0 **PKE_0_PullKeeper_Disabled** — Pull/Keeper Disabled  
1 **PKE_1_PullKeeper_Enabled** — Pull/Keeper Enabled |
| 11    | Open Drain Enable Field **ODE**  
Select one out of next values for pad: GPIO_AD_B1_14 |

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_14 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_14</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_14</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_AD_B1_14</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.198  SW_PAD_CTL_PAD_GPIO_AD_B1_15 SW PAD Control Register
(IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_15)

SW_PAD_CTL Register

Address: 401F_8000h base + 328h offset = 401F_8328h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>11–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_15 field descriptions

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_15 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
</tbody>
</table>

| 5–3 | DSE | Drive Strength Field |
|     |     | Select one out of next values for pad: GPIO_AD_B1_15 |
| 00  | DSE_0_output_driver_disabled — output driver disabled; |
| 001 | DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V) |
| 010 | DSE_2_R0_2 — R0/2 |
| 011 | DSE_3_R0_3 — R0/3 |
| 100 | DSE_4_R0_4 — R0/4 |
| 101 | DSE_5_R0_5 — R0/5 |
| 110 | DSE_6_R0_6 — R0/6 |
| 111 | DSE_7_R0_7 — R0/7 |

| 2–1 | This field is reserved. | Reserved |

<table>
<thead>
<tr>
<th>0</th>
<th>SRE</th>
<th>Slew Rate Field</th>
<th>Select one out of next values for pad: GPIO_AD_B1_15</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 11.7.199 SW_PAD_CTL_PAD_GPIO_B0_00 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_00)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 32Ch offset = 401F_832Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>PUS</td>
</tr>
<tr>
<td>14</td>
<td>PUE</td>
</tr>
<tr>
<td>13</td>
<td>PKE</td>
</tr>
<tr>
<td>12</td>
<td>ODE</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>SPEED</td>
</tr>
<tr>
<td>9</td>
<td>DSE</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>SRE</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0

---

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

693
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_00</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_00</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_00</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_00</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_00</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_00</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_00</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_00 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1
- This field is reserved.
Reserved

0
SRE
Slew Rate Field
Select one out of next values for pad: GPIO_B0_00

0  SRE_0_Slow_Slew_Rate — Slow Slew Rate
1  SRE_1_Fast_Slew_Rate — Fast Slew Rate

11.7.200  SW_PAD_CTL_PAD_GPIO_B0_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_01)

SW_PAD_CTL Register

Address: 401F_8000h base + 330h offset = 401F_8330h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.
Reserved |

16
HYS
Hyst. Enable Field
Select one out of next values for pad: GPIO_B0_01

0  HYS_0_Hysteresis_Disabled — Hysteresis Disabled
1  HYS_1_Hysteresis_Enabled — Hysteresis Enabled

15–14
PUS
Pull Up / Down Config. Field
Select one out of next values for pad: GPIO_B0_01

00  PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
01  PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE — Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_01</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE — Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_01</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE — Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_01</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED — Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_01</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE — Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_01</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE — Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_01</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.201 SW_PAD_CTL_PAD_GPIO_B0_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_02)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 334h offset = 401F_8334h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_02 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_02</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_02</td>
<td></td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_02</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_02</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_02</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_02 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 ODE_0_Open_Drain_Disabled</td>
<td>Open Drain Disabled</td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled</td>
<td>Open Drain Enabled</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved. (Reserved)</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_02</td>
</tr>
<tr>
<td>00 SPEED_0_low_50MHz</td>
<td>low(50MHz)</td>
</tr>
<tr>
<td>01 SPEED_1_medium_100MHz</td>
<td>medium(100MHz)</td>
</tr>
<tr>
<td>10 SPEED_2_fast_150MHz</td>
<td>fast(150MHz)</td>
</tr>
<tr>
<td>11 SPEED_3_max_200MHz</td>
<td>max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_02</td>
</tr>
<tr>
<td>000 DSE_0_output_driver_disabled</td>
<td>output driver disabled;</td>
</tr>
<tr>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</td>
<td>R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010 DSE_2_R0_2</td>
<td>R0/2</td>
</tr>
<tr>
<td>011 DSE_3_R0_3</td>
<td>R0/3</td>
</tr>
<tr>
<td>100 DSE_4_R0_4</td>
<td>R0/4</td>
</tr>
<tr>
<td>101 DSE_5_R0_5</td>
<td>R0/5</td>
</tr>
<tr>
<td>110 DSE_6_R0_6</td>
<td>R0/6</td>
</tr>
<tr>
<td>111 DSE_7_R0_7</td>
<td>R0/7</td>
</tr>
<tr>
<td>2–1 -</td>
<td>This field is reserved. (Reserved)</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_02</td>
</tr>
<tr>
<td>0 SRE_0_Slow_Slew_Rate</td>
<td>Slow Slew Rate</td>
</tr>
<tr>
<td>1 SRE_1_Fast_Slew_Rate</td>
<td>Fast Slew Rate</td>
</tr>
</tbody>
</table>

#### 11.7.202 SW\_PAD\_CTL\_PAD\_GPIO\_B0\_03 SW PAD Control Register (IOMUXC\_SW\_PAD\_CTL\_PAD\_GPIO\_B0\_03)

**SW\_PAD\_CTL Register**

Address: 401F\_8000h base + 338h offset = 401F\_8338h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>R/W</td>
<td>HYS</td>
</tr>
<tr>
<td>29</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>R/W</td>
<td>PUS</td>
</tr>
<tr>
<td>14</td>
<td>R/W</td>
<td>PUE</td>
</tr>
<tr>
<td>13</td>
<td>R/W</td>
<td>PKE</td>
</tr>
<tr>
<td>12</td>
<td>R/W</td>
<td>ODE</td>
</tr>
<tr>
<td>11</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>R/W</td>
<td>SPEED</td>
</tr>
<tr>
<td>9</td>
<td>R/W</td>
<td>DSE</td>
</tr>
<tr>
<td>8</td>
<td>R/W</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>R/W</td>
<td>SRE</td>
</tr>
</tbody>
</table>

Reset values: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_03 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_03</td>
</tr>
<tr>
<td></td>
<td>0 <strong>HYS_0_Hysteresis_Disabled</strong> — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 <strong>HYS_1_Hysteresis_Enabled</strong> — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_03</td>
</tr>
<tr>
<td></td>
<td>00 <strong>PUS_0_100K_Ohm_Pull_Down</strong> — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 <strong>PUS_1_47K_Ohm_Pull_Up</strong> — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 <strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 <strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_03</td>
</tr>
<tr>
<td></td>
<td>0 <strong>PUE_0_Rewriter</strong> — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 <strong>PUE_1_Pull</strong> — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_03</td>
</tr>
<tr>
<td></td>
<td>0 <strong>PKE_0_Pull_Keeper_Disabled</strong> — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 <strong>PKE_1_Pull_Keeper_Enabled</strong> — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_03</td>
</tr>
<tr>
<td></td>
<td>0 <strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 <strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_03</td>
</tr>
<tr>
<td></td>
<td>00 <strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 <strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 <strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 <strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_03</td>
</tr>
<tr>
<td></td>
<td>000 <strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 <strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 <strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
IOMUXC Memory Map/Register Definition

IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_03 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td>SRE</td>
</tr>
<tr>
<td>Slew Rate Field</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_03</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

11.7.203 SW_PAD_CTL_PAD_GPIO_B0_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_04)

SW_PAD_CTL Register

Address: 401F_8000h base + 33Ch offset = 401F_833Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td></td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_04 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>Hyst. Enable Field</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_04</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>Pull Up / Down Config. Field</td>
<td></td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_B0_04</td>
<td></td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_04</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_04</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_04</td>
</tr>
<tr>
<td></td>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_04</td>
</tr>
<tr>
<td></td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_04</td>
</tr>
<tr>
<td></td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_04</td>
</tr>
<tr>
<td></td>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.204  SW_PAD_CTL_PAD_GPIO_B0_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_05)

SW_PAD_CTL Register

Address: 401F_8000h base + 340h offset = 401F_8340h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bit</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_05</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_05</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_05</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_05</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_05</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_05 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

#### 7–6 SPEED

- **Speed Field**
  - Select one out of next values for pad: GPIO_B0_05
  - 00 SPEED_0_low_50MHz — low(50MHz)
  - 01 SPEED_1_medium_100MHz — medium(100MHz)
  - 10 SPEED_2_fast_150MHz — fast(150MHz)
  - 11 SPEED_3_max_200MHz — max(200MHz)

#### 5–3 DSE

- **Drive Strength Field**
  - Select one out of next values for pad: GPIO_B0_05
  - 000 DSE_0_output_driver_disabled — output driver disabled;
  - 001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
  - 010 DSE_2_R0_2 — R0/2
  - 011 DSE_3_R0_3 — R0/3
  - 100 DSE_4_R0_4 — R0/4
  - 101 DSE_5_R0_5 — R0/5
  - 110 DSE_6_R0_6 — R0/6
  - 111 DSE_7_R0_7 — R0/7

#### 2–1

- This field is reserved.
- Reserved

#### 0 SRE

- **Slew Rate Field**
  - Select one out of next values for pad: GPIO_B0_05
  - 0 SRE_0_Slow_Slew_Rate — Slow Slew Rate
  - 1 SRE_1_Fast_Slew_Rate — Fast Slew Rate

---

### 11.7.205 SW_PAD_CTL_PAD_GPIO_B0_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_06)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 344h offset = 401F_8344h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>HYS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_06 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_06</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_06</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_06</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_06</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_06</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_06</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_06</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_06 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
</tbody>
</table>

2–1
- This field is reserved.

0
SRE
Slew Rate Field

Select one out of next values for pad: GPIO_B0_06

0 SRE_0_Slow_Slew_Rate  — Slow Slew Rate
1 SRE_1_Fast_Slew_Rate  — Fast Slew Rate

### 11.7.206 SW_PAD_CTL_PAD_GPIO_B0_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_07)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 348h offset = 401F_8348h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PUE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PKE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>ODE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>SPEED</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>DSE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>SRE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.
|       | Reserved    |
| 16    | HYS         |
|       | Hyst. Enable Field |
|       | Select one out of next values for pad: GPIO_B0_07 |
| 0     | HYS_0_Hysteresis_Disabled  — Hysteresis Disabled |
| 1     | HYS_1_Hysteresis_Enabled   — Hysteresis Enabled |
| 15–14 | PUS         |
|       | Pull Up / Down Config. Field |
|       | Select one out of next values for pad: GPIO_B0_07 |
| 00    | PUS_0_100K_Ohm_Pull_Down   — 100K Ohm Pull Down |
| 01    | PUS_1_47K_Ohm_Pull_Up      — 47K Ohm Pull Up |

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_07</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_07</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_07</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8 Reserved</td>
<td></td>
</tr>
</tbody>
</table>

### SPEED field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_07</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
</tbody>
</table>

### DSE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_07</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

### SRE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_07</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.207 SW_PAD_CTL_PAD_GPIO_B0_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_08)

SW_PAD_CTL Register

Address: 401F_8000h base + 34Ch offset = 401F_834Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>HYS</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_08 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_08 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
<tr>
<td>0</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_08</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.208 SW_PAD_CTL_PAD_GPIO_B0_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_09)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 350h offset = 401F_8350h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read/Write</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>R</td>
<td>HYS</td>
</tr>
<tr>
<td>29</td>
<td>R</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>R</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read/Write</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>R</td>
<td>PUS</td>
</tr>
<tr>
<td>14</td>
<td>R</td>
<td>PUE</td>
</tr>
<tr>
<td>13</td>
<td>R</td>
<td>PKE</td>
</tr>
<tr>
<td>12</td>
<td>R</td>
<td>ODE</td>
</tr>
<tr>
<td>11</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>R</td>
<td>SPEED</td>
</tr>
<tr>
<td>9</td>
<td>R</td>
<td>DSE</td>
</tr>
<tr>
<td>8</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>R</td>
<td>SRE</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_09 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_09</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_09</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_09</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_09</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_09</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_09</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_09</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC Memory Map/Register Definition

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1  
This field is reserved.  
Reserved

| 0 | SRE |
|——|——|
| Slew Rate Field |
| Select one out of next values for pad: GPIO_B0_09 |
| 0 | SRE_0_Slow_Slew_Rate — Slow Slew Rate |
| 1 | SRE_1_Fast_Slew_Rate — Fast Slew Rate |

---

### 11.7.209 SW_PAD_CTL_PAD_GPIO_B0_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_10)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 354h offset = 401F_8354h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_10 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.  
Reserved |

| 16 | HYS |
|——|——|
| Hyst. Enable Field |
| Select one out of next values for pad: GPIO_B0_10 |
| 0 | HYS_0_Hysteresis_Disabled — Hysteresis Disabled |
| 1 | HYS_1_Hysteresis_Enabled — Hysteresis Enabled |

| 15–14 | PUS |
|——|——|
| Pull Up / Down Config. Field |
| Select one out of next values for pad: GPIO_B0_10 |
| 00 | PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down |
| 01 | PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td><strong>PUE</strong> Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>PUE_0Keeper</strong> — Keeper</td>
</tr>
<tr>
<td>1</td>
<td><strong>PUE_1Pull</strong> — Pull</td>
</tr>
<tr>
<td>12</td>
<td><strong>PKE</strong> Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>PKE_0PullKeeperDisabled</strong> — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>PKE_1PullKeeperEnabled</strong> — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td><strong>ODE</strong> Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>ODE_0OpenDrainDisabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1OpenDrainEnabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_10</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_10</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.210  SW_PAD_CTL_PAD_GPIO_B0_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_11)

SW_PAD_CTL Register

Address: 401F_8000h base + 358h offset = 401F_8358h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_11 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

**Field Descriptions**

- **HYS (Hyst. Enable Field)**
  - 0: HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1: HYS_1_Hysteresis_Enabled — Hysteresis Enabled

- **PUS (Pull Up / Down Config. Field)**
  - 00: PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01: PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10: PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11: PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **PUE (Pull / Keep Select Field)**
  - 0: PUE_0_Keeper — Keeper
  - 1: PUE_1_Pull — Pull

- **PKE (Pull / Keep Enable Field)**
  - 0: PKE_0_Pull_Keep_Enabled — Pull/Keep Disabled
  - 1: PKE_1_Pull_Keep_Enabled — Pull/Keep Enabled

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_11 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain.Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_11</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_11</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_11</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>

#### 11.7.211 SW_PAD_CTL_PAD_GPIO_B0_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_12)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 35Ch offset = 401F_835Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXF Semiconductors
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_12</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_12 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_13 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
</tbody>
</table>

#### Hyst. Enable Field
Select one out of next values for pad: GPIO_B0_13

- 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
- 1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

#### Pull Up / Down Config. Field
Select one out of next values for pad: GPIO_B0_13

- 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
- 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

---

**11.7.212 SW_PAD_CTL_PAD_GPIO_B0_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_13)**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 360h offset = 401F_8360h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_13 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
</tbody>
</table>

#### Hyst. Enable Field
Select one out of next values for pad: GPIO_B0_13

- 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
- 1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

#### Pull Up / Down Config. Field
Select one out of next values for pad: GPIO_B0_13

- 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
- 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

*Table continues on the next page...*
## IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_13 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_13</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_13</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_13</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_13</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_13</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B0_13</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.213 SW_PAD_CTL_PAD_GPIO_B0_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_14)

SW_PAD_CTL Register

Address: 401F_8000h base + 364h offset = 401F_8364h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 ODE_0_Open_Drain_Disabled</td>
<td>Open Drain Disabled</td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled</td>
<td>Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
</tbody>
</table>

### 11.7.214 SW_PAD_CTL_PAD_GPIO_B0_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_15)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 368h offset = 401F_8368h
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 - | This field is reserved.  
Reserved |
| 16 HYS | Hyst. Enable Field  
Select one out of next values for pad: GPIO_B0_15  
0 HYS_0_Hysteresis.Disabled — Hysteresis Disabled  
1 HYS_1_Hysteresis.Enabled — Hysteresis Enabled |
| 15–14 PUS | Pull Up / Down Config. Field  
Select one out of next values for pad: GPIO_B0_15  
00 PUS_0_100K.Ohm.Pull.Down — 100K Ohm Pull Down  
01 PUS_1_47K.Ohm.Pull.Up — 47K Ohm Pull Up  
10 PUS_2_100K.Ohm.Pull.Up — 100K Ohm Pull Up  
| 13 PUE | Pull / Keep Select Field  
Select one out of next values for pad: GPIO_B0_15  
0 PUE_0Keeper — Keeper  
1 PUE_1Pull — Pull |
| 12 PKE | Pull / Keep Enable Field  
Select one out of next values for pad: GPIO_B0_15  
0 PKE_0.Pull.Keep_disabled — Pull/Keeper Disabled  
1 PKE_1.Pull.Keep_enabled — Pull/Keeper Enabled |
| 11 ODE | Open Drain Enable Field  
Select one out of next values for pad: GPIO_B0_15  
0 ODE_0.Open.Drain.Disabled — Open Drain Disabled  
1 ODE_1.Open.Drain.Enabled — Open Drain Enabled |
| 10–8 - | This field is reserved.  
Reserved |
| 7–6 SPEED | Speed Field  
Select one out of next values for pad: GPIO_B0_15  
00 SPEED_0_low_50MHz — low(50MHz)  
01 SPEED_1_medium_100MHz — medium(100MHz)  
10 SPEED_2_fast_150MHz — fast(150MHz)  
11 SPEED_3_max_200MHz — max(200MHz) |
| 5–3 DSE | Drive Strength Field  
Select one out of next values for pad: GPIO_B0_15  
000 DSE_0.output.driver_disabled — output driver disabled;  
001 DSE_1.R0_150.Ohm.3_3V_260.Ohm.1.8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)  
010 DSE_2.R0_2 — R0/2 |

Table continues on the next page...
IOMUXC_SW_PAD_CTL_PAD_GPIOB0_15 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1
- This field is reserved.
Reserved

0
SRE
Slew Rate Field
Select one out of next values for pad: GPIO_B0_15

0  SRE_0_Slow_Slew_Rate — Slow Slew Rate
1  SRE_1_Fast_Slew_Rate — Fast Slew Rate

11.7.215 SW_PAD_CTL_PAD_GPIOB1_00 SW PAD Control
Register (IOMUXC_SW_PAD_CTL_PAD_GPIOB1_00)

SW_PAD_CTL Register

Address: 401F_8000h base + 36Ch offset = 401F_836Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIOB1_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.
Reserved |

16
HYS
Hyst. Enable Field
Select one out of next values for pad: GPIO_B1_00

0  HYS_0_Hysteresis_Disabled — Hysteresis Disabled
1  HYS_1_Hysteresis_Enabled — Hysteresis Enabled

15–14
PUS
Pull Up / Down Config. Field
Select one out of next values for pad: GPIO_B1_00

00  PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
01  PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10 PUS_2_100K_Ohm_Pull_Up</td>
<td>100K Ohm Pull Up</td>
</tr>
<tr>
<td>11 PUS_3_22K_Ohm_Pull_Up</td>
<td>22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_00</td>
</tr>
<tr>
<td>0 PUE_0_Keeper</td>
<td>Keeper</td>
</tr>
<tr>
<td>1 PUE_1_Pull</td>
<td>Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_00</td>
</tr>
<tr>
<td>0 PKE_0_Pull_Keeper_Disabled</td>
<td>Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1 PKE_1_Pull_Keeper_Enabled</td>
<td>Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_00</td>
</tr>
<tr>
<td>0 ODE_0_Open_Drain_Disabled</td>
<td>Open Drain Disabled</td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled</td>
<td>Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_00</td>
</tr>
<tr>
<td>00 SPEED_0_low_50MHz</td>
<td>low(50MHz)</td>
</tr>
<tr>
<td>01 SPEED_1_medium_100MHz</td>
<td>medium(100MHz)</td>
</tr>
<tr>
<td>10 SPEED_2_fast_150MHz</td>
<td>fast(150MHz)</td>
</tr>
<tr>
<td>11 SPEED_3_max_200MHz</td>
<td>max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_00</td>
</tr>
<tr>
<td>000 DSE_0_output_driver_disabled</td>
<td>output driver disabled;</td>
</tr>
<tr>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</td>
<td>R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010 DSE_2_R0_2</td>
<td>R0/2</td>
</tr>
<tr>
<td>011 DSE_3_R0_3</td>
<td>R0/3</td>
</tr>
<tr>
<td>100 DSE_4_R0_4</td>
<td>R0/4</td>
</tr>
<tr>
<td>101 DSE_5_R0_5</td>
<td>R0/5</td>
</tr>
<tr>
<td>110 DSE_6_R0_6</td>
<td>R0/6</td>
</tr>
<tr>
<td>111 DSE_7_R0_7</td>
<td>R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_00</td>
</tr>
<tr>
<td>0 SRE_0_Slow_Slew_Rate</td>
<td>Slow Slew Rate</td>
</tr>
<tr>
<td>1 SRE_1_Fast_Slew_Rate</td>
<td>Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.216  SW_PAD_CTL_PAD_GPIO_B1_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_01)

SW_PAD_CTL Register

Address: 401F_8000h base + 370h offset = 401F_8370h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/R</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

- This field is reserved.
- Reserved

<table>
<thead>
<tr>
<th>7–6 SPEED</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low (50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium (100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast (150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max (200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>5–3 DSE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0 (150 Ohm @ 3.3V, 260 Ohm @ 1.8V)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>2–1</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0 SRE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.217 SW_PAD_CTL_PAD_GPIO_B1_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_02)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 374h offset = 401F_8374h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13–12</td>
<td>PUE</td>
</tr>
<tr>
<td>11–10</td>
<td>PKE</td>
</tr>
<tr>
<td>9–8</td>
<td>ODE</td>
</tr>
<tr>
<td>7–6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5–4</td>
<td>SPEED</td>
</tr>
<tr>
<td>3–2</td>
<td>DSE</td>
</tr>
<tr>
<td>1–0</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>SRE</td>
</tr>
</tbody>
</table>

Reset values:
- 00000000000000000000000000000000
- 00000000000000000000000000000000
- 00000000000000000000000000000000
- 00000000000000000000000000000000
- 00000000000000000000000000000000
- 00000000000000000000000000000000
- 00000000000000000000000000000000
- 00000000000000000000000000000000

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**

NXP Semiconductors
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>4–0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Field 31–17**

This field is reserved.

**Field 16**

Hyst. Enable Field

Select one out of next values for pad: GPIO_B1_02

- **0**: HYS_0_Hysteresis_Disabled — Hysteresis Disabled
- **1**: HYS_1_Hysteresis_Enabled — Hysteresis Enabled

**Field 15–14**

Pull Up / Down Config. Field

Select one out of next values for pad: GPIO_B1_02

- **00**: PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
- **01**: PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
- **10**: PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
- **11**: PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

**Field 13**

Pull / Keep Select Field

Select one out of next values for pad: GPIO_B1_02

- **0**: PUE_0_Keeper — Keeper
- **1**: PUE_1_Pull — Pull

**Field 12**

Pull / Keep Enable Field

Select one out of next values for pad: GPIO_B1_02

- **0**: PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
- **1**: PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

**Field 11**

Open Drain Enable Field

Select one out of next values for pad: GPIO_B1_02

- **0**: ODE_0_Open_Drain_Disabled — Open Drain Disabled
- **1**: ODE_1_Open_Drain_Enabled — Open Drain Enabled

**Field 10–8**

This field is reserved.

Reserved

**Field 7–6**

Speed Field

Select one out of next values for pad: GPIO_B1_02

- **00**: SPEED_0_low_50MHz — low(50MHz)
- **01**: SPEED_1_medium_100MHz — medium(100MHz)
- **10**: SPEED_2_fast_150MHz — fast(150MHz)
- **11**: SPEED_3_max_200MHz — max(200MHz)

**Field 5–3**

Drive Strength Field

Select one out of next values for pad: GPIO_B1_02

- **00**: DSE_0_output_driver_disabled — output driver disabled;
- **01**: DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
- **010**: DSE_2_R0_2 — R0/2

Table continues on the next page...
IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_02 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1
- This field is reserved.
Reserved

0 SRE Slew Rate Field

Select one out of next values for pad: GPIO_B1_02

0 SRE_0_Slow_Slew_Rate — Slow Slew Rate
1 SRE_1_Fast_Slew_Rate — Fast Slew Rate

11.7.218 SW_PAD_CTL_PAD_GPIO_B1_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_03)

SW_PAD_CTL Register

Address: 401F_8000h base + 378h offset = 401F_8378h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_03 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>16</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Hyst. Enable Field</td>
<td></td>
</tr>
</tbody>
</table>
Select one out of next values for pad: GPIO_B1_03

0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

<table>
<thead>
<tr>
<th>15–14</th>
<th>PUS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Pull Up / Down Config. Field</td>
<td></td>
</tr>
</tbody>
</table>
Select one out of next values for pad: GPIO_B1_03

00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_03</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_03</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_03</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_03</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_03</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_03</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.219 SW_PAD_CTL_PAD_GPIO_B1_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_04)

SW_PAD_CTL Register

Address: 401F_8000h base + 37Ch offset = 401F_837Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>30</td>
<td>29</td>
</tr>
<tr>
<td>28</td>
<td>27</td>
<td>26</td>
</tr>
<tr>
<td>25</td>
<td>24</td>
<td>23</td>
</tr>
<tr>
<td>22</td>
<td>21</td>
<td>20</td>
</tr>
<tr>
<td>19</td>
<td>18</td>
<td>17</td>
</tr>
<tr>
<td>16</td>
<td>15</td>
<td>14</td>
</tr>
<tr>
<td>13</td>
<td>12</td>
<td>11</td>
</tr>
<tr>
<td>10</td>
<td>9</td>
<td>8</td>
</tr>
<tr>
<td>7</td>
<td>6</td>
<td>5</td>
</tr>
<tr>
<td>4</td>
<td>3</td>
<td>2</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>14</td>
<td>13</td>
</tr>
<tr>
<td>12</td>
<td>11</td>
<td>10</td>
</tr>
<tr>
<td>9</td>
<td>8</td>
<td>7</td>
</tr>
<tr>
<td>6</td>
<td>5</td>
<td>4</td>
</tr>
<tr>
<td>3</td>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_04 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
<tr>
<td>16</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>HYS_1_Hysteresis_ENABLED — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_ENABLED — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## IOMUXC SW_PAD_CTL_PAD_GPIO_B1_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_04</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.220 SW_PAD_CTL_PAD_GPIO_B1_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_05)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 380h offset = 401F_8380h

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rw</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rw</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
## IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>0</td>
<td><strong>HYS_0_Hysteresis_Disabled</strong> — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>HYS_1_Hysteresis_Enabled</strong> — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>00</td>
<td><strong>PUS_0_100K_Ohm_Pull_Down</strong> — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td><strong>PUS_1_47K_Ohm_Pull_Up</strong> — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>0</td>
<td><strong>PUE_0_Keeper</strong> — Keeper</td>
</tr>
<tr>
<td>1</td>
<td><strong>PUE_1_Pull</strong> — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>0</td>
<td><strong>PKE_0_Pull_Keeper_Disabled</strong> — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>PKE_1_Pull_Keeper_Enabled</strong> — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
IOMUXC SW_PAD_CTL_PAD_GPIO_B1_05 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

| 2–1 - | Reserved |

0 SRE | Slew Rate Field

Select one out of next values for pad: GPIO_B1_05

| 0 | SRE_0_Slow_Slew_Rate — Slow Slew Rate |
| 1 | SRE_1_Fast_Slew_Rate — Fast Slew Rate |

11.7.221 SW_PAD_CTL_PAD_GPIO_B1_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_06)

SW_PAD_CTL Register

Address: 401F_8000h base + 384h offset = 401F_8384h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_06 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

16 HYS | Hyst. Enable Field

Select one out of next values for pad: GPIO_B1_06

| 0 | HYS_0_Hysteresis_Disabled — Hysteresis Disabled |
| 1 | HYS_1_Hysteresis_Enabled — Hysteresis Enabled |

15–14 PUS | Pull Up / Down Config. Field

Select one out of next values for pad: GPIO_B1_06

| 00 | PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down |
| 01 | PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 10-11 | PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up  

11 | PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>12-13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_06</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
</tr>
<tr>
<td>11-12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_06</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
</tr>
<tr>
<td>10-11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_06</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
</tr>
</tbody>
</table>
| 10-8  | This field is reserved.  

Reserved |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>7-6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_06</td>
</tr>
<tr>
<td>0 0</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>0 1</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>1 0</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>1 1</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
</tr>
<tr>
<td>5-3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_06</td>
</tr>
<tr>
<td>0 0 0</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>0 0 1</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>0 1 0</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>0 1 1</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>1 0 0</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>1 0 1</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>1 1 0</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>1 1 1</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>-------</td>
<td>-------------</td>
</tr>
</tbody>
</table>
| 2-1   | This field is reserved.  

Reserved |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_06</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.222 SW_PAD_CTL_PAD_GPIO_B1_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_07)

SW_PAD_CTL Register

Address: 401F_8000h base + 388h offset = 401F_8388h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-17</td>
<td></td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R/W</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15-14</td>
<td>R/W</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>R/W</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>R/W</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>R/W</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_07 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_07</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15-14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_07</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_07</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_07</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_07</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>1</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.223 SW_PAD_CTL_PAD_GPIO_B1_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_08)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 38Ch offset = 401F_838Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30–24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>HYS</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–11</td>
<td>PUS PUE PKE ODE</td>
</tr>
<tr>
<td>10–8</td>
<td>SPEED DSE</td>
</tr>
<tr>
<td>7</td>
<td>SRE</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Reset: 0 0 0 1 0 0 0 0 1 0 1 1 0 0 0 0

---

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

733
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_08 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
</tbody>
</table>

#### Field Descriptions

- **HYS**: Hyst. Enable Field
  - 0: **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
  - 1: **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled

- **PUS**: Pull Up / Down Config. Field
  - 00: **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
  - 01: **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
  - 10: **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
  - 11: **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

- **PUE**: Pull / Keep Select Field
  - 0: **PUE_0_Keeper** — Keeper
  - 1: **PUE_1_Pull** — Pull

- **PKE**: Pull / Keep Enable Field
  - 0: **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
  - 1: **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled

- **ODE**: Open Drain Enable Field
  - 0: **ODE_0_Open_Drain_Disabled** — Open Drain Disabled
  - 1: **ODE_1_Open_Drain_Enabled** — Open Drain Enabled

- **SPEED**: Speed Field
  - 00: **SPEED_0_low_50MHz** — low(50MHz)
  - 01: **SPEED_1_medium_100MHz** — medium(100MHz)
  - 10: **SPEED_2_fast_150MHz** — fast(150MHz)
  - 11: **SPEED_3_max_200MHz** — max(200MHz)

- **DSE**: Drive Strength Field
  - 000: **DSE_0_output_driver_disabled** — output driver disabled;
  - 001: **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
  - 010: **DSE_2_R0_2** — R0/2

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_08 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE</td>
</tr>
</tbody>
</table>

Slew Rate Field

Select one out of next values for pad: GPIO_B1_08

- 0 SRE_0_Slow_Slew_Rate — Slow Slew Rate
- 1 SRE_1_Fast_Slew_Rate — Fast Slew Rate

---

### 11.7.224 SW_PAD_CTL_PAD_GPIO_B1_09 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_09)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 390h offset = 401F_8390h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
</tbody>
</table>

Hyst. Enable Field

Select one out of next values for pad: GPIO_B1_09

- 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
- 1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

Pull Up / Down Config. Field

Select one out of next values for pad: GPIO_B1_09

- 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
- 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up

---

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td><strong>PUS_2_100K_Ohm_Pull_Up</strong> — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td><strong>PUS_3_22K_Ohm_Pull_Up</strong> — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td><strong>PUE</strong> Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>PUE_0_Keeper</strong> — Keeper</td>
</tr>
<tr>
<td>1</td>
<td><strong>PUE_1_Pull</strong> — Pull</td>
</tr>
<tr>
<td>12</td>
<td><strong>PKE</strong> Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>PKE_0_Pull_Keeper_Disabled</strong> — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>PKE_1_Pull_Keeper_Enabled</strong> — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td><strong>ODE</strong> Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_09</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_09</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_09</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_B1_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_10)

**SW_PAD_CTL Register**

**Address:** 401F_8000h base + 394h offset = 401F_8394h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td></td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>R</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>R</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>R</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>R</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>R</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_10 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
</tbody>
</table>

- **HYS**
  - 0: **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
  - 1: **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled

- **PUS**
  - 00: **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
  - 01: **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
  - 10: **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
  - 11: **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

- **PUE**
  - 0: **PUE_0_Keeper** — Keeper
  - 1: **PUE_1_Pull** — Pull

- **PKE**
  - 0: **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
  - 1: **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enable</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_10</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_10</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_10</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.226 SW_PAD_CTL_PAD_GPIO_B1_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_11)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 398h offset = 401F_8399h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Reserved</th>
<th>HYS</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>PUS</th>
<th>PUE</th>
<th>PKE</th>
<th>ODE</th>
<th>Reserved</th>
<th>SPEED</th>
<th>DSE</th>
<th>Reserved</th>
<th>SRE</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

---

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**

NXP Semiconductors
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
<tr>
<td>HYS</td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
<tr>
<td>PUS</td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
<tr>
<td>PUE</td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
<tr>
<td>PKE</td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
<tr>
<td>ODE</td>
<td>0 ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td></td>
<td>1 ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
<tr>
<td>SPEED</td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
<tr>
<td>DSE</td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_11 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3  — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4  — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5  — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6  — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7  — R0/7</td>
</tr>
</tbody>
</table>

| 2–1   | This field is reserved. |
|       | Reserved                |

<table>
<thead>
<tr>
<th>0 SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_11</td>
</tr>
</tbody>
</table>

| 0 | SRE_0_Slow_Slew_Rate — Slow Slew Rate |
| 1 | SRE_1_Fast_Slew_Rate — Fast Slew Rate |

### 11.7.227 SW_PAD_CTL_PAD_GPIO_B1_12 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_12)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 39Ch offset = 401F_839Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>16 HYS</th>
<th>Hyst. Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
</tbody>
</table>

| 0 | HYS_0_Hysteresis_Disabled — Hysteresis Disabled |
| 1 | HYS_1_Hysteresis_Enabled — Hysteresis Enabled |

<table>
<thead>
<tr>
<th>15–14 PUS</th>
<th>Pull Up / Down Config. Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
</tbody>
</table>

| 00 | PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down |
| 01 | PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up |

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_12 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_12</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.228  SW_PAD_CTL_PAD_GPIO_B1_13 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_13)

SW_PAD_CTL Register

Address: 401F_8000h base + 3A0h offset = 401F_83A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-17</td>
<td>This field is reserved.</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
<td>HYS</td>
</tr>
<tr>
<td>15-14</td>
<td>Pull Up / Down Config. Field</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
<td>ODE</td>
</tr>
</tbody>
</table>

### Field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
<tr>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15-14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
<tr>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_13 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
<tr>
<td></td>
<td>00 SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>01 SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>10 SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>11 SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
<tr>
<td></td>
<td>000 DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>010 DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>011 DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>100 DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>101 DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>110 DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>111 DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_13</td>
</tr>
<tr>
<td></td>
<td>0 SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>1 SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>

### 11.7.229 SW_PAD_CTL_PAD_GPIO_B1_14 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_14)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 3A4h offset = 401F_83A4h

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

743
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_14 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
</tbody>
</table>

#### Field descriptions:

- **HYS**: Hyst. Enable Field
  - 0: HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1: HYS_1_Hysteresis_Enabled — Hysteresis Enabled

- **PUS**: Pull Up / Down Config. Field
  - 00: PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01: PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10: PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11: PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **PUE**: Pull / Keep Select Field
  - 0: PUE_0_Keeper — Keeper
  - 1: PUE_1_Pull — Pull

- **PKE**: Pull / Keep Enable Field
  - 0: PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1: PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

- **ODE**: Open Drain Enable Field
  - 0: ODE_0_Open_Drain_Disabled — Open Drain Disabled
  - 1: ODE_1_Open_Drain_Enabled — Open Drain Enabled

- **SPEED**: Speed Field
  - 00: SPEED_0_low_50MHz — low(50MHz)
  - 01: SPEED_1_medium_100MHz — medium(100MHz)
  - 10: SPEED_2_fast_150MHz — fast(150MHz)
  - 11: SPEED_3_max_200MHz — max(200MHz)

- **DSE**: Drive Strength Field
  - 000: DSE_0_output_driver_disabled — output driver disabled;
  - 001: DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)
  - 010: DSE_2_R0_2 — R0/2

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_14 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
</tbody>
</table>

2–1 -
- This field is reserved.
   - Reserved

<table>
<thead>
<tr>
<th>0</th>
<th>SRE</th>
<th>Slew Rate Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_14</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
<td></td>
</tr>
</tbody>
</table>

### 11.7.230 SW_PAD_CTL_PAD_GPIO_B1_15 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_15)

#### SW_PAD_CTL Register

Address: 401F_8000h base + 3A8h offset = 401F_83A8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>RW</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>RW</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 1 0 0 0 0 0 1 0 1 1 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_15 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 - | This field is reserved.
   - Reserved |

<table>
<thead>
<tr>
<th>16</th>
<th>HYS</th>
<th>Hyst. Enable Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>15–14</th>
<th>PUS</th>
<th>Pull Up / Down Config. Field</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
<td></td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_15 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain.Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>SPEED Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>DSE Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>SRE Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_B1_15</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.231  SW_PAD_CTL_PAD_GPIO_SD_B0_00 SW PAD Control Register  
(IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_00)

SW_PAD_CTL Register

Address: 401F_8000h base + 3ACh offset = 401F_83ACh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>HYS</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PUE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>PKE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
<td></td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC SW_PAD_CTL_PAD_GPIO_SD_B0_00 Field Descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 Ohm @ 1.8V)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_00</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.232 SW_PAD_CTL_PAD_GPIO_SD_B0_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_01)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3B0h offset = 401F_83B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
</tbody>
</table>

- **Hyst. Enable Field**
  - Select one out of next values for pad: GPIO_SD_B0_01
  - 0 **HYS_0_Hysteresis_Disabled** — Hysteresis Disabled
  - 1 **HYS_1_Hysteresis_Enabled** — Hysteresis Enabled

- **Pull Up / Down Config. Field**
  - Select one out of next values for pad: GPIO_SD_B0_01
  - 00 **PUS_0_100K_Ohm_Pull_Down** — 100K Ohm Pull Down
  - 01 **PUS_1_47K_Ohm_Pull_Up** — 47K Ohm Pull Up
  - 10 **PUS_2_100K_Ohm_Pull_Up** — 100K Ohm Pull Up
  - 11 **PUS_3_22K_Ohm_Pull_Up** — 22K Ohm Pull Up

- **Pull / Keep Select Field**
  - Select one out of next values for pad: GPIO_SD_B0_01
  - 0 **PUE_0_Keeper** — Keeper
  - 1 **PUE_1_Pull** — Pull

- **Pull / Keep Enable Field**
  - Select one out of next values for pad: GPIO_SD_B0_01
  - 0 **PKE_0_Pull_Keeper_Disabled** — Pull/Keeper Disabled
  - 1 **PKE_1_Pull_Keeper_Enabled** — Pull/Keeper Enabled
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_01 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 ODE_0_Open_Drain_Disabled</td>
<td>— Open Drain Disabled</td>
</tr>
<tr>
<td>1 ODE_1_Open_Drain_Enabled</td>
<td>— Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6 SPEED</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_01</td>
</tr>
<tr>
<td>00 SPEED_0_low_50MHz</td>
<td>— low(50MHz)</td>
</tr>
<tr>
<td>01 SPEED_1_medium_100MHz</td>
<td>— medium(100MHz)</td>
</tr>
<tr>
<td>10 SPEED_2_fast_150MHz</td>
<td>— fast(150MHz)</td>
</tr>
<tr>
<td>11 SPEED_3_max_200MHz</td>
<td>— max(200MHz)</td>
</tr>
<tr>
<td>5–3 DSE</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_01</td>
</tr>
<tr>
<td>000 DSE_0_output_driver_disabled</td>
<td>— output driver disabled;</td>
</tr>
<tr>
<td>001 DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</td>
<td>— R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010 DSE_2_R0_2</td>
<td>— R0/2</td>
</tr>
<tr>
<td>011 DSE_3_R0_3</td>
<td>— R0/3</td>
</tr>
<tr>
<td>100 DSE_4_R0_4</td>
<td>— R0/4</td>
</tr>
<tr>
<td>101 DSE_5_R0_5</td>
<td>— R0/5</td>
</tr>
<tr>
<td>110 DSE_6_R0_6</td>
<td>— R0/6</td>
</tr>
<tr>
<td>111 DSE_7_R0_7</td>
<td>— R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0 SRE</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_01</td>
</tr>
<tr>
<td>0 SRE_0_Slow_Slew_Rate</td>
<td>— Slow Slew Rate</td>
</tr>
<tr>
<td>1 SRE_1_Fast_Slew_Rate</td>
<td>— Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.233 SW_PAD_CTL_PAD_GPIO_SD_B0_02 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_02)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3B4h offset = 401F_83B4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_02 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 | This field is reserved.  
| - | Reserved |
| 16 | Hyst. Enable Field  
| HYS | Select one out of next values for pad: GPIO_SD_B0_02  
| 0 | HYS_0_Hysteresis_Disabled — Hysteresis Disabled  
| 1 | HYS_1_Hysteresis_Enabled — Hysteresis Enabled |
| 15–14 | Pull Up / Down Config. Field  
| PUS | Select one out of next values for pad: GPIO_SD_B0_02  
| 00 | PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down  
| 01 | PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up  
| 10 | PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up  
| 11 | PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
| 13 | Pull / Keep Select Field  
| PUE | Select one out of next values for pad: GPIO_SD_B0_02  
| 0 | PUE_0_Keeper — Keeper  
| 1 | PUE_1_Pull — Pull |
| 12 | Pull / Keep Enable Field  
| PKE | Select one out of next values for pad: GPIO_SD_B0_02  
| 0 | PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled  
| 1 | PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled |
| 11 | Open Drain Enable Field  
| ODE | Select one out of next values for pad: GPIO_SD_B0_02  
| | |

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_02 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_02</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_02</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_02</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
## 11.7.234 SW_PAD_CTL_PAD_GPIO_SD_B0_03 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_03)

### SW_PAD_CTL Register

Address: 401F_8000h base + 3B8h offset = 401F_83B8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_03 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
<tr>
<td></td>
<td>0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td></td>
<td>1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
<tr>
<td></td>
<td>00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td></td>
<td>01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td></td>
<td>11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
<tr>
<td></td>
<td>0 PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td></td>
<td>1 PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
<tr>
<td></td>
<td>0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td></td>
<td>1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_03 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_03</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.235 SW_PAD_CTL_PAD_GPIO_SD_B0_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_04)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3BCh offset = 401F_83BCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_04 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
</tbody>
</table>

- **16 HYS**: Hyst. Enable Field
  - Select one out of next values for pad: GPIO_SD_B0_04
    - 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
    - 1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

- **15–14 PUS**: Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_SD_B0_04
    - 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
    - 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
    - 10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
    - 11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

- **13 PUE**: Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_SD_B0_04
    - 0 PUE_0_Keeper — Keeper
    - 1 PUE_1_Pull — Pull

- **12 PKE**: Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_SD_B0_04
    - 0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
    - 1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

- **11 ODE**: Open Drain Enable Field
  - Select one out of next values for pad: GPIO_SD_B0_04

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
</tbody>
</table>

| 10–8  | This field is reserved. |
|       | Reserved |

| 7–6   | **SPEED** Speed Field |

| 00    | **SPEED_0_low_50MHz** — low(50MHz) |
| 01    | **SPEED_1_medium_100MHz** — medium(100MHz) |
| 10    | **SPEED_2_fast_150MHz** — fast(150MHz) |
| 11    | **SPEED_3_max_200MHz** — max(200MHz) |

| 5–3   | **DSE** Drive Strength Field |

| 000   | **DSE_0_output_driver_disabled** — output driver disabled; |
| 001   | **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V) |
| 010   | **DSE_2_R0_2** — R0/2 |
| 011   | **DSE_3_R0_3** — R0/3 |
| 010   | **DSE_4_R0_4** — R0/4 |
| 101   | **DSE_5_R0_5** — R0/5 |
| 110   | **DSE_6_R0_6** — R0/6 |
| 111   | **DSE_7_R0_7** — R0/7 |

| 2–1   | This field is reserved. |
|       | Reserved |

| 0     | **SRE** Slew Rate Field |

| 0     | **SRE_0_Slow_Slew_Rate** — Slow Slew Rate |
| 1     | **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
11.7.236 SW_PAD_CTL_PAD_GPIO_SD_B0_05 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_05)

SW_PAD_CTL Register

Address: 401F_8000h base + 3C0h offset = 401F_83C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HYS</td>
</tr>
</tbody>
</table>

| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

| Reset | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |

IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_05 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B0_05</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_05 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_05</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_05</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B0_05</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.237  SW_PAD_CTL_PAD_GPIO_SD_B1_00 SW PAD Control Register  
(IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_00)

SW_PAD_CTL Register

Address: 401F_8000h base + 3C4h offset = 401F_83C4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_00 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–17 - | This field is reserved.  
Reserved |
| 16 | Hyst. Enable Field  
Select one out of next values for pad: GPIO_SD_B1_00  
0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled  
1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled |
| 15–14 | Pull Up / Down Config. Field  
Select one out of next values for pad: GPIO_SD_B1_00  
00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down  
01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up  
10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up  
11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up |
| 13 | Pull / Keep Select Field  
Select one out of next values for pad: GPIO_SD_B1_00  
0 PUE_0Keeper — Keeper  
1 PUE_1Pull — Pull |
| 12 | Pull / Keep Enable Field  
Select one out of next values for pad: GPIO_SD_B1_00  
0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled  
1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled |
| 11 | Open Drain Enable Field  
Select one out of next values for pad: GPIO_SD_B1_00 |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
</tbody>
</table>

| 10–8  | This field is reserved. |
| 7–6   | **SPEED** Speed Field |
|       | Select one out of next values for pad: GPIO_SD_B1_00 |
| 00    | **SPEED_0_low_50MHz** — low(50MHz) |
| 01    | **SPEED_1_medium_100MHz** — medium(100MHz) |
| 10    | **SPEED_2_fast_150MHz** — fast(150MHz) |
| 11    | **SPEED_3_max_200MHz** — max(200MHz) |

| 5–3   | **DSE** Drive Strength Field |
|       | Select one out of next values for pad: GPIO_SD_B1_00 |
| 000   | **DSE_0_output_driver_disabled** — output driver disabled; |
| 001   | **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V) |
| 010   | **DSE_2_R0_2** — R0/2 |
| 011   | **DSE_3_R0_3** — R0/3 |
| 100   | **DSE_4_R0_4** — R0/4 |
| 101   | **DSE_5_R0_5** — R0/5 |
| 110   | **DSE_6_R0_6** — R0/6 |
| 111   | **DSE_7_R0_7** — R0/7 |

| 2–1   | This field is reserved. |
| 0     | **SRE** Slew Rate Field |
|       | Select one out of next values for pad: GPIO_SD_B1_00 |
| 0     | **SRE_0_Slow_Slew_Rate** — Slow Slew Rate |
| 1     | **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
11.7.238 SW_PAD_CTL_PAD_GPIO_SD_B1_01 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_01)

SW_PAD_CTL Register

Address: 401F_8000h base + 3C8h offset = 401F_83C8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_01 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_01</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_Ctl_PAD_GPIO_SD_B1_02 SW PAD Control Register

#### SW_PAD_CTL Register

Address: 401F_8000h base + 3CCh offset = 401F_83CCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_02</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_02</td>
</tr>
<tr>
<td>11</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>01</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_02</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_02</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_02 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td>SPEED</td>
<td>Select one out of next values for pad: GPIO_SD_B1_02</td>
</tr>
<tr>
<td></td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td></td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td></td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td></td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td>DSE</td>
<td>Select one out of next values for pad: GPIO_SD_B1_02</td>
</tr>
<tr>
<td></td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td></td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td></td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td></td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td></td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td></td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td></td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td></td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td>SRE</td>
<td>Select one out of next values for pad: GPIO_SD_B1_02</td>
</tr>
<tr>
<td></td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td></td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.240 SW_PAD_CTL_PAD_GPIO_SD_B1_03 SW PAD Control Register

**IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_03**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3D0h offset = 401F_83D0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B1_03</td>
<td></td>
</tr>
<tr>
<td>0 HYS_0_Hysteresis_Disabled—Hysteresis Disabled</td>
<td></td>
</tr>
<tr>
<td>1 HYS_1_Hysteresis_Enabled—Hysteresis Enabled</td>
<td></td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B1_03</td>
<td></td>
</tr>
<tr>
<td>00 PUS_0_100K_Ohm_Pull_Down—100K Ohm Pull Down</td>
<td></td>
</tr>
<tr>
<td>01 PUS_1_47K_Ohm_Pull_Up—47K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td>10 PUS_2_100K_Ohm_Pull_Up—100K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td>11 PUS_3_22K_Ohm_Pull_Up—22K Ohm Pull Up</td>
<td></td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B1_03</td>
<td></td>
</tr>
<tr>
<td>0 PUE_0_Keeper—Keeper</td>
<td></td>
</tr>
<tr>
<td>1 PUE_1_Pull—Pull</td>
<td></td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B1_03</td>
<td></td>
</tr>
<tr>
<td>0 PKE_0_Pull_Keeper_Disabled—Pull/Keeper Disabled</td>
<td></td>
</tr>
<tr>
<td>1 PKE_1_Pull_Keeper_Enabled—Pull/Keeper Enabled</td>
<td></td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td>Select one out of next values for pad: GPIO_SD_B1_03</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_SD_B1_03

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_SD_B1_03

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_SD_B1_03

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.241 SW_PAD_CTL_PAD_GPIO_SD_B1_04 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_04)

SW_PAD_CTL Register

Address: 401F_8000h base + 3D4h offset = 401F_83D4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
</tr>
<tr>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_04 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 HYS</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14 PUS</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13 PUE</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12 PKE</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11 ODE</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_04 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_04</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### SW_PAD_CTL_PAD_GPIO_SD_B1_05 SW PAD Control Register

**IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_05**

#### SW_PAD_CTL Register

Address: 401F_8000h base + 3D8h offset = 401F_83D8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_05** field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_05 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODE_0_Open_Drain_Disabled — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td>ODE_1_Open_Drain_Enabled — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td>Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
<tr>
<td>00</td>
<td>SPEED_0_low_50MHz — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td>SPEED_1_medium_100MHz — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td>SPEED_2_fast_150MHz — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td>SPEED_3_max_200MHz — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td>Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
<tr>
<td>000</td>
<td>DSE_0_output_driver_disabled — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td>DSE_2_R0_2 — R0/2</td>
</tr>
<tr>
<td>011</td>
<td>DSE_3_R0_3 — R0/3</td>
</tr>
<tr>
<td>100</td>
<td>DSE_4_R0_4 — R0/4</td>
</tr>
<tr>
<td>101</td>
<td>DSE_5_R0_5 — R0/5</td>
</tr>
<tr>
<td>110</td>
<td>DSE_6_R0_6 — R0/6</td>
</tr>
<tr>
<td>111</td>
<td>DSE_7_R0_7 — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_05</td>
</tr>
<tr>
<td>0</td>
<td>SRE_0_Slow_Slew_Rate — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td>SRE_1_Fast_Slew_Rate — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.243 SW_PAD_CTL_PAD_GPIO_SD_B1_06 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_06)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3DCh offset = 401F_83DCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>31-17</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
<td>Hyst. Enable Field</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15-14</td>
<td>PUS</td>
<td>Pull Up / Down Config. Field</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>PKE</td>
<td>Pull / Keep Enable Field</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>ODE</td>
<td>Open Drain Enable Field</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_06 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Select one out of next values for pad: GPIO_SD_B1_06

Table continues on the next page...
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_06 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
</tbody>
</table>
| 10–8  | This field is reserved.  
|       | Reserved |
| 7–6   | **SPEED** Speed Field  
|       | Select one out of next values for pad: GPIO_SD_B1_06  
| 00    | **SPEED_0_low_50MHz** — low(50MHz)  
| 01    | **SPEED_1_medium_100MHz** — medium(100MHz)  
| 10    | **SPEED_2_fast_150MHz** — fast(150MHz)  
| 11    | **SPEED_3_max_200MHz** — max(200MHz) |
| 5–3   | **DSE** Drive Strength Field  
|       | Select one out of next values for pad: GPIO_SD_B1_06  
| 000   | **DSE_0_output_driver_disabled** — output driver disabled;  
| 001   | **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V)  
| 010   | **DSE_2_R0_2** — R0/2  
| 011   | **DSE_3_R0_3** — R0/3  
| 100   | **DSE_4_R0_4** — R0/4  
| 101   | **DSE_5_R0_5** — R0/5  
| 110   | **DSE_6_R0_6** — R0/6  
| 111   | **DSE_7_R0_7** — R0/7 |
| 2–1   | This field is reserved.  
|       | Reserved |
| 0     | **SRE** Slew Rate Field  
|       | Select one out of next values for pad: GPIO_SD_B1_06  
| 0     | **SRE_0_Slow_Slew_Rate** — Slow Slew Rate  
| 1     | **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
### 11.7.244 SW_PAD_CTL_PAD_GPIO_SD_B1_07 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_07)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3E0h offset = 401F_83E0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R/W</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16</td>
<td>R/W</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>R/W</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>R/W</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>R/W</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>R/W</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_07 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

- **Field 31–17**: This field is reserved. Reserved
- **Field 16**: Hyst. Enable Field
  - Select one out of next values for pad: GPIO_SD_B1_07
  - 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled
- **Field 15–14**: Pull Up / Down Config. Field
  - Select one out of next values for pad: GPIO_SD_B1_07
  - 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up
- **Field 13**: Pull / Keep Select Field
  - Select one out of next values for pad: GPIO_SD_B1_07
  - 0 PUE_0_Keeper — Keeper
  - 1 PUE_1_Pull — Pull
- **Field 12**: Pull / Keep Enable Field
  - Select one out of next values for pad: GPIO_SD_B1_07
  - 0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled
- **Field 11**: Open Drain Enable Field
  - Select one out of next values for pad: GPIO_SD_B1_07

*Table continues on the next page...*
### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_07 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td><strong>Reserved</strong></td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_07</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_07</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td><strong>Reserved</strong></td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_07</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
### 11.7.245 SW_PAD_CTL_PAD_GPIO_SD_B1_08 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_08)

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3E4h offset = 401F_83E4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>PUS</td>
<td>PUE</td>
<td>PKE</td>
<td>ODE</td>
<td>Reserved</td>
<td>SPEED</td>
<td>DSE</td>
<td>Reserved</td>
<td>SRE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_08 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td>HYS_0_Hysteresis_Disabled — Hysteresis Disabled</td>
</tr>
<tr>
<td>1</td>
<td>HYS_1_Hysteresis_Enabled — Hysteresis Enabled</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
<tr>
<td>00</td>
<td>PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down</td>
</tr>
<tr>
<td>01</td>
<td>PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up</td>
</tr>
<tr>
<td>10</td>
<td>PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up</td>
</tr>
<tr>
<td>11</td>
<td>PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up</td>
</tr>
<tr>
<td>13</td>
<td>PUE Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td>PUE_0_Keeper — Keeper</td>
</tr>
<tr>
<td>1</td>
<td>PUE_1_Pull — Pull</td>
</tr>
<tr>
<td>12</td>
<td>PKE Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td>PKE_0_PullKeeper_Disabled — Pull/Keeper Disabled</td>
</tr>
<tr>
<td>1</td>
<td>PKE_1_PullKeeper_Enabled — Pull/Keeper Enabled</td>
</tr>
<tr>
<td>11</td>
<td>ODE Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2Fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_18V_260_3V_18V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_08</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
## 11.7.246 SW_PAD_CTL_PAD_GPIO_SD_B1_09 SW PAD Control Register

**IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_09**

**SW_PAD_CTL Register**

Address: 401F_8000h base + 3E8h offset = 401F_83E8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_09 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### Field Descriptions

#### 16 HYS
- **Hyst. Enable Field**
- Select one out of next values for pad: GPIO_SD_B1_09
  - 0 HYS_0_Hysteresis_Disabled — Hysteresis Disabled
  - 1 HYS_1_Hysteresis_Enabled — Hysteresis Enabled

#### 15–14 PUS
- **Pull Up / Down Config. Field**
- Select one out of next values for pad: GPIO_SD_B1_09
  - 00 PUS_0_100K_Ohm_Pull_Down — 100K Ohm Pull Down
  - 01 PUS_1_47K_Ohm_Pull_Up — 47K Ohm Pull Up
  - 10 PUS_2_100K_Ohm_Pull_Up — 100K Ohm Pull Up
  - 11 PUS_3_22K_Ohm_Pull_Up — 22K Ohm Pull Up

#### 13 PUE
- **Pull / Keep Select Field**
- Select one out of next values for pad: GPIO_SD_B1_09
  - 0 PUE_0_Keeper — Keeper
  - 1 PUE_1_Pull — Pull

#### 12 PKE
- **Pull / Keep Enable Field**
- Select one out of next values for pad: GPIO_SD_B1_09
  - 0 PKE_0_Pull_Keeper_Disabled — Pull/Keeper Disabled
  - 1 PKE_1_Pull_Keeper_Enabled — Pull/Keeper Enabled

#### 11 ODE
- **Open Drain Enable Field**
- Select one out of next values for pad: GPIO_SD_B1_09

*Table continues on the next page...*
### IOMUXC SW PAD_CTL_PAD_GPIO_SD_B1_09 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
</tbody>
</table>

#### Speed Field
Select one out of next values for pad: GPIO_SD_B1_09

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
</tbody>
</table>

#### Drive Strength Field
Select one out of next values for pad: GPIO_SD_B1_09

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
</tbody>
</table>

#### Slew Rate Field
Select one out of next values for pad: GPIO_SD_B1_09

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.247 SW_PAD_CTL_PAD_GPIO_SD_B1_10 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_10)

SW_PAD_CTL Register

Address: 401F_8000h base + 3ECh offset = 401F_83ECh

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td>15–14</td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td>13</td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td>12</td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td>11</td>
<td>Open Drain Enable Field</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
</tbody>
</table>

10–8  
-      
This field is reserved.  
Reserved

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 7–6   | **SPEED**  
Speed Field  
Select one out of next values for pad: GPIO_SD_B1_10 |
| 00    | **SPEED_0_low_50MHz** — low(50MHz) |
| 01    | **SPEED_1_medium_100MHz** — medium(100MHz) |
| 10    | **SPEED_2_fast_150MHz** — fast(150MHz) |
| 11    | **SPEED_3_max_200MHz** — max(200MHz) |

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 5–3   | **DSE**  
Drive Strength Field  
Select one out of next values for pad: GPIO_SD_B1_10 |
| 00    | **DSE_0_output_driver_disabled** — output driver disabled; |
| 001   | **DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V** — R0(150 Ohm @ 3.3V, 260 Ohm@1.8V) |
| 010   | **DSE_2_R0_2** — R0/2 |
| 011   | **DSE_3_R0_3** — R0/3 |
| 100   | **DSE_4_R0_4** — R0/4 |
| 101   | **DSE_5_R0_5** — R0/5 |
| 110   | **DSE_6_R0_6** — R0/6 |
| 111   | **DSE_7_R0_7** — R0/7 |

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2–1</td>
<td></td>
</tr>
</tbody>
</table>
-      
This field is reserved.  
Reserved |

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 0     | **SRE**  
Slew Rate Field  
Select one out of next values for pad: GPIO_SD_B1_10 |
| 0     | **SRE_0_Slow_Slew_Rate** — Slow Slew Rate |
| 1     | **SRE_1_Fast_Slew_Rate** — Fast Slew Rate |
11.7.248 SW_PAD_CTL_PAD_GPIO_SD_B1_11 SW PAD Control Register (IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_11)

SW_PAD_CTL Register

Address: 401F_8000h base + 3F0h offset = 401F_83F0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>R/W</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>PUS</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>PUE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>HYS</td>
</tr>
<tr>
<td></td>
<td>Hyst. Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td>15–14</td>
<td>PUS</td>
</tr>
<tr>
<td></td>
<td>Pull Up / Down Config. Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
<tr>
<td></td>
<td>00</td>
</tr>
<tr>
<td></td>
<td>01</td>
</tr>
<tr>
<td></td>
<td>10</td>
</tr>
<tr>
<td></td>
<td>11</td>
</tr>
<tr>
<td>13</td>
<td>PUE</td>
</tr>
<tr>
<td></td>
<td>Pull / Keep Select Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td>12</td>
<td>PKE</td>
</tr>
<tr>
<td></td>
<td>Pull / Keep Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>1</td>
</tr>
<tr>
<td>11</td>
<td>ODE</td>
</tr>
<tr>
<td></td>
<td>Open Drain Enable Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>ODE_0_Open_Drain_Disabled</strong> — Open Drain Disabled</td>
</tr>
<tr>
<td>1</td>
<td><strong>ODE_1_Open_Drain_Enabled</strong> — Open Drain Enabled</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–6</td>
<td><strong>SPEED</strong> Speed Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
<tr>
<td>00</td>
<td><strong>SPEED_0_low_50MHz</strong> — low(50MHz)</td>
</tr>
<tr>
<td>01</td>
<td><strong>SPEED_1_medium_100MHz</strong> — medium(100MHz)</td>
</tr>
<tr>
<td>10</td>
<td><strong>SPEED_2_fast_150MHz</strong> — fast(150MHz)</td>
</tr>
<tr>
<td>11</td>
<td><strong>SPEED_3_max_200MHz</strong> — max(200MHz)</td>
</tr>
<tr>
<td>5–3</td>
<td><strong>DSE</strong> Drive Strength Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
<tr>
<td>000</td>
<td><strong>DSE_0_output_driver_disabled</strong> — output driver disabled;</td>
</tr>
<tr>
<td>001</td>
<td><strong>DSE_1_R0_150_Ohm_3_3V_260_Ohm_1_8V</strong> — R0(150 Ohm @ 3.3V, 260 <a href="mailto:Ohm@1.8V">Ohm@1.8V</a>)</td>
</tr>
<tr>
<td>010</td>
<td><strong>DSE_2_R0_2</strong> — R0/2</td>
</tr>
<tr>
<td>011</td>
<td><strong>DSE_3_R0_3</strong> — R0/3</td>
</tr>
<tr>
<td>100</td>
<td><strong>DSE_4_R0_4</strong> — R0/4</td>
</tr>
<tr>
<td>101</td>
<td><strong>DSE_5_R0_5</strong> — R0/5</td>
</tr>
<tr>
<td>110</td>
<td><strong>DSE_6_R0_6</strong> — R0/6</td>
</tr>
<tr>
<td>111</td>
<td><strong>DSE_7_R0_7</strong> — R0/7</td>
</tr>
<tr>
<td>2–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE</strong> Slew Rate Field</td>
</tr>
<tr>
<td></td>
<td>Select one out of next values for pad: GPIO_SD_B1_11</td>
</tr>
<tr>
<td>0</td>
<td><strong>SRE_0_Slow_Slew_Rate</strong> — Slow Slew Rate</td>
</tr>
<tr>
<td>1</td>
<td><strong>SRE_1_Fast_Slew_Rate</strong> — Fast Slew Rate</td>
</tr>
</tbody>
</table>
11.7.249 ANATOP_USB_OTG1_ID_SELECT_INPUT DAISY Register
(IOMUXC_ANATOP_USB_OTG1_ID_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 3F4h offset = 401F_83F4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_ANATOP_USB_OTG1_ID_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: anatop, In Pin: usb_otg_id</td>
</tr>
<tr>
<td>0 GPIO_AD_B0_01_ALT3</td>
<td>Selecting Pad: GPIO_AD_B0_01 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_AD_B1_02_ALT0</td>
<td>Selecting Pad: GPIO_AD_B1_02 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.250 **ANATOP_USB_OTG2_ID_SELECT_INPUT DAISY Register**

(IOMUXC_ANATOP_USB_OTG2_ID_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 3F8h offset = 401F_83F8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

 Reserved

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

**Selecting Pads Involved in Daisy Chain.**

*Instance: anatop, In Pin: usb*

0  **GPIO_AD_B0_00_ALT3** — Selecting Pad: GPIO_AD_B0_00 for Mode: ALT3

1  **GPIO_AD_B1_00_ALT0** — Selecting Pad: GPIO_AD_B1_00 for Mode: ALT0

11.7.251 **CCM_PMIC_READY_SELECT_INPUT DAISY Register**

(IOMUXC_CCM_PMIC_READY_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 3FCh offset = 401F_83FCh

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

 Reserved

 DAISY
### IOMUXC_CCM_PMIC_READY_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: ccm, In Pin: pmic_vfunctional_ready

- 000  `GPIO_SD_B1_03_ALT6` — Selecting Pad: GPIO_SD_B1_03 for Mode: ALT6
- 001  `GPIO_AD_B0_12_ALT1` — Selecting Pad: GPIO_AD_B0_12 for Mode: ALT1
- 010  `GPIO_AD_B1_01_ALT4` — Selecting Pad: GPIO_AD_B1_01 for Mode: ALT4
- 011  `GPIO_AD_B1_08_ALT3` — Selecting Pad: GPIO_AD_B1_08 for Mode: ALT3
- 100  `GPIO_EMC_32_ALT3` — Selecting Pad: GPIO_EMC_32 for Mode: ALT3

### 11.7.252 CSI_DATA02_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA02_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 400h offset = 401F_8400h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

- 00000000000000000000000000

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

- 00000000000000000000000000

### IOMUXC_CSI_DATA02_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: csi, In Pin: csi_d2

- 0  `GPIO_AD_B1_15_ALT4` — Selecting Pad: GPIO_AD_B1_15 for Mode: ALT4
- 1  `GPIO_AD_B0_11_ALT4` — Selecting Pad: GPIO_AD_B0_11 for Mode: ALT4
11.7.253 CSI_DATA03_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA03_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 404h offset = 401F_8404h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_CSI_DATA03_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 0 DAISY | Selecting Pads Involved in Daisy Chain.  
Instance: csi, In Pin: csi_d3
| 0 GPIO_AD_B1_14_ALT4 — Selecting Pad: GPIO_AD_B1_14 for Mode: ALT4 |
| 1 GPIO_AD_B0_10_ALT4 — Selecting Pad: GPIO_AD_B0_10 for Mode: ALT4 |
11.7.254  CSI_DATA04_SELECT_INPUT DAISY Register
(IOMUXC_CSI_DATA04_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 408h offset = 401F_8408h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_CSI_DATA04_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: csi, In Pin: csi_d4</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B1_13_ALT4 — Selecting Pad: GPIO_AD_B1_13 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_09_ALT4 — Selecting Pad: GPIO_AD_B0_09 for Mode: ALT4</td>
</tr>
</tbody>
</table>
11.7.255 CSI_DATA05_SELECT_INPUT DAISY Register

(IOMUXC_CSI_DATA05_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 40Ch offset = 401F_840Ch

```
+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+-------------------+
|                      | 31                | 30                | 29                | 28                | 27                | 26                | 25                | 24                | 23                | 22                | 21                | 20                | 19                | 18                | 17                | 16                | 15                | 14                | 13                | 12                | 11                | 10                | 9                 | 8                 | 7                 | 6                 | 5                 | 4                 | 3                 | 2                 | 1                 | 0                 |
| Bit                 | 31                | 30                | 29                | 28                | 27                | 26                | 25                | 24                | 23                | 22                | 21                | 20                | 19                | 18                | 17                | 16                | 15                | 14                | 13                | 12                | 11                | 10                | 9                 | 8                 | 7                 | 6                 | 5                 | 4                 | 3                 | 2                 | 1                 | 0                 |                    |
| R                   | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 |                    |
| W                   | Reserved           |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |                    |
| Reset              | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 |                    |
```

IOMUXC_CSI_DATA05_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: csi, In Pin: csi_d5</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B1_12_ALT4 — Selecting Pad: GPIO_AD_B1_12 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_08_ALT4 — Selecting Pad: GPIO_AD_B0_08 for Mode: ALT4</td>
</tr>
</tbody>
</table>
### 11.7.256 CSI_DATA06_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA06_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 410h offset = 401F_8410h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_CSI_DATA06_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>Instance: csi, In Pin: csi_d6</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B1_11_ALT4 — Selecting Pad: GPIO_AD_B1_11 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_07_ALT4 — Selecting Pad: GPIO_AD_B0_07 for Mode: ALT4</td>
</tr>
</tbody>
</table>
11.7.257 CSI_DATA07_SELECT_INPUT DAISY Register
(IOMUXC_CSI_DATA07_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 414h offset = 401F_8414h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_CSI_DATA07_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: csi, In Pin: csi_d7</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B1_10_ALT4 — Selecting Pad: GPIO_AD_B1_10 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_06_ALT4 — Selecting Pad: GPIO_AD_B0_06 for Mode: ALT4</td>
</tr>
</tbody>
</table>
### 11.7.258 CSI_DATA08_SELECT_INPUT DAISY Register (IOMUXC_CSI_DATA08_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 418h offset = 401F_8418h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_CSI_DATA08_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: csi, In Pin: csi_d8</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B1_09_ALT4 — Selecting Pad: GPIO_AD_B1_09 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_05_ALT4 — Selecting Pad: GPIO_AD_B0_05 for Mode: ALT4</td>
</tr>
</tbody>
</table>
11.7.259 CSI_DATA09_SELECT_INPUT DAISY Register
(IOMUXC_CSI_DATA09_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 41Ch offset = 401F_841Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Reserved

IOMUXC_CSI_DATA09_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: csi, In Pin: csi_d9</td>
</tr>
<tr>
<td>0 GPIO_AD_B1_08_ALT4</td>
<td>— Selecting Pad: GPIO_AD_B1_08 for Mode: ALT4</td>
</tr>
<tr>
<td>1 GPIO_AD_B0_04_ALT4</td>
<td>— Selecting Pad: GPIO_AD_B0_04 for Mode: ALT4</td>
</tr>
</tbody>
</table>

11.7.260 CSI_HSYNC_SELECT_INPUT DAISY Register
(IOMUXC_CSI_HSYNC_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 420h offset = 401F_8420h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Reserved

IOMUXC Memory Map/Register Definition

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
IOMUXC_CSI_HSYNC_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: csi, In Pin: csi_hsync

- 00  GPIO_AD_B0_15_ALT4 — Selecting Pad: GPIO_AD_B0_15 for Mode: ALT4
- 01  GPIO_AD_B1_07_ALT4 — Selecting Pad: GPIO_AD_B1_07 for Mode: ALT4
- 10  GPIO_B1_14_ALT2 — Selecting Pad: GPIO_B1_14 for Mode: ALT2

11.7.261 CSI_PIXCLK_SELECT_INPUT DAISY Register (IOMUXC_CSI_PIXCLK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 424h offset = 401F_8424h

IOMUXC_CSI_PIXCLK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: csi, In Pin: csi_pixclk

- 0  GPIO_AD_B1_04_ALT4 — Selecting Pad: GPIO_AD_B1_04 for Mode: ALT4
- 1  GPIO_B1_12_ALT2 — Selecting Pad: GPIO_B1_12 for Mode: ALT2
11.7.262 CSI_VSYNC_SELECT_INPUT DAISY Register (IOMUXC_CSI_VSYNC_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 428h offset = 401F_8428h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_CSI_VSYNC_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: csi, In Pin: csi_vsync</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_AD_B0_14_ALT4 — Selecting Pad: GPIO_AD_B0_14 for Mode: ALT4</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B1_06_ALT4 — Selecting Pad: GPIO_AD_B1_06 for Mode: ALT4</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B1_13_ALT2 — Selecting Pad: GPIO_B1_13 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.263  ENET_IPG_CLK_RMII_SELECT_INPUT DAISY Register  
(IOMUXC_ENET_IPG_CLK_RMII_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 42Ch offset = 401F_842Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

DAISY

IOMUXC_ENET_IPG_CLK_RMII_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: enet, In Pin: rmii</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_25_ALT4 — Selecting Pad: GPIO_EMC_25 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_10_ALT6 — Selecting Pad: GPIO_B1_10 for Mode: ALT6</td>
</tr>
</tbody>
</table>

11.7.264  ENET_MDIO_SELECT_INPUT DAISY Register  
(IOMUXC_ENET_MDIO_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 430h offset = 401F_8430h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

DAISY
### IOMUXC_ENET_MDIO_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: enet, In Pin: mac0_mdio</td>
</tr>
<tr>
<td>00 GPIO_AD_B1_05_ALT1</td>
<td>— Selecting Pad: GPIO_AD_B1_05 for Mode: ALT1</td>
</tr>
<tr>
<td>01 GPIO_EMC_41_ALT4</td>
<td>— Selecting Pad: GPIO_EMC_41 for Mode: ALT4</td>
</tr>
<tr>
<td>10 GPIO_B1_15_ALT0</td>
<td>— Selecting Pad: GPIO_B1_15 for Mode: ALT0</td>
</tr>
</tbody>
</table>

### ENET0_RXDATA_SELECT_INPUT DAISY Register (IOMUXC_ENET0_RXDATA_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 434h offset = 401F_8434h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_ENET0_RXDATA_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: enet, In Pin: mac0_rxdata0</td>
</tr>
<tr>
<td>DAISY</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_20_ALT3 — Selecting Pad: GPIO_EMC_20 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_04_ALT3 — Selecting Pad: GPIO_B1_04 for Mode: ALT3</td>
</tr>
</tbody>
</table>
### 11.7.266 ENET1_RXDATA_SELECT_INPUT DAISY Register (IOMUXC_ENET1_RXDATA_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 438h offset = 401F_8438h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_ENET1_RXDATA_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: enet, In Pin: mac0_rxdata1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_19_ALT3 — Selecting Pad: GPIO_EMC_19 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_05_ALT3 — Selecting Pad: GPIO_B1_05 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.267  ENET_RXEN_SELECT_INPUT DAISY Register
(IOMUXC_ENET_RXEN_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 43Ch offset = 401F_843Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_ENET_RXEN_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: enet, In Pin: mac0_rxen</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_23_ALT3 — Selecting Pad: GPIO_EMC_23 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_06_ALT3 — Selecting Pad: GPIO_B1_06 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.268  ENET_RXERR_SELECT_INPUT DAISY Register
(IOMUXC_ENET_RXERR_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 440h offset = 401F_8440h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Field: 31–1
- This field is reserved.
- Reserved

Field: 0 DAISY
- Selecting Pads Involved in Daisy Chain.
- Instance: enet, In Pin: mac0_rxerr
  - 0  GPIO_EMC_26_ALT3 — Selecting Pad: GPIO_EMC_26 for Mode: ALT3
  - 1  GPIO_B1_11_ALT3 — Selecting Pad: GPIO_B1_11 for Mode: ALT3

11.7.269  ENET0_TIMER_SELECT_INPUT DAISY Register
(IOMUXC_ENET0_TIMER_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 444h offset = 401F_8444h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Field: 31–1
- This field is reserved.
- Reserved

Field: 0 DAISY
- Selecting Pads Involved in Daisy Chain.
- Instance: enet0, In Pin: mac00_rxerr
  - 0  GPIO_EMC_26_ALT3 — Selecting Pad: GPIO_EMC_26 for Mode: ALT3
  - 1  GPIO_B1_11_ALT3 — Selecting Pad: GPIO_B1_11 for Mode: ALT3
IOMUXC Memory Map/Register Definition

### IOMUXC_ENET0_TIMER_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: enet, In Pin: mac0_timer0</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_AD_B0_15_ALT3 — Selecting Pad: GPIO_AD_B0_15 for Mode: ALT3</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B0_11_ALT7 — Selecting Pad: GPIO_AD_B0_11 for Mode: ALT7</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B1_12_ALT3 — Selecting Pad: GPIO_B1_12 for Mode: ALT3</td>
</tr>
</tbody>
</table>

---

11.7.270  **ENET_TXCLK_SELECT_INPUT DAISY Register (IOMUXC_ENET_TXCLK_SELECT_INPUT)**

**DAISY Register**

Address: 401F_8000h base + 448h offset = 401F_8448h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_ENET_TXCLK_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: enet, In Pin: mac0_txclk</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_25_ALT3 — Selecting Pad: GPIO_EMC_25 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_10_ALT3 — Selecting Pad: GPIO_B1_10 for Mode: ALT3</td>
</tr>
</tbody>
</table>
### 11.7.271 FLEXCAN1_RX_SELECT_INPUT DAISY Register

**(IOMUXC_FLEXCAN1_RX_SELECT_INPUT)**

**DAISY Register**

Address: 401F_8000h base + 44Ch offset = 401F_844Ch

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexcan1, In Pin: RX

00 **GPIO_SD_B1_03_ALT4** — Selecting Pad: GPIO_SD_B1_03 for Mode: ALT4

01 **GPIO_EMC_18_ALT3** — Selecting Pad: GPIO_EMC_18 for Mode: ALT3

10 **GPIO_AD_B1_09_ALT2** — Selecting Pad: GPIO_AD_B1_09 for Mode: ALT2

11 **GPIO_B0_03_ALT2** — Selecting Pad: GPIO_B0_03 for Mode: ALT2

### 11.7.272 FLEXCAN2_RX_SELECT_INPUT DAISY Register

**(IOMUXC_FLEXCAN2_RX_SELECT_INPUT)**

**DAISY Register**

Address: 401F_8000h base + 450h offset = 401F_8450h
IOMUXC_FLEXCAN2_RX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexcan2, In Pin: RX

00 GPIO_EMC_10_ALT3 — Selecting Pad: GPIO_EMC_10 for Mode: ALT3
01 GPIO_AD_B0_03_ALT0 — Selecting Pad: GPIO_AD_B0_03 for Mode: ALT0
10 GPIO_AD_B0_15_ALT6 — Selecting Pad: GPIO_AD_B0_15 for Mode: ALT6
11 GPIO_B1_09_ALT6 — Selecting Pad: GPIO_B1_09 for Mode: ALT6

11.7.273 FLEXPWM1_PWMA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMA3_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 454h offset = 401F_8454h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexpwm1, In Pin: pwma3

000 GPIO_SD_B1_00_ALT2 — Selecting Pad: GPIO_SD_B1_00 for Mode: ALT2
001 GPIO_EMC_12_ALT4 — Selecting Pad: GPIO_EMC_12 for Mode: ALT4
010 GPIO_EMC_38_ALT1 — Selecting Pad: GPIO_EMC_38 for Mode: ALT1
011 GPIO_AD_B0_10_ALT1 — Selecting Pad: GPIO_AD_B0_10 for Mode: ALT1
100 GPIO_B1_00_ALT6 — Selecting Pad: GPIO_B1_00 for Mode: ALT6
11.7.274 FLEXPWM1_PWMA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMA0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 458h offset = 401F_8458h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_FLEXPWM1_PWMA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: flexpwm1, In Pin: pwma0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_23_ALT1 — Selecting Pad: GPIO_EMC_23 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B0_00_ALT1 — Selecting Pad: GPIO_SD_B0_00 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.275  FLEXPWM1_PWMA1_SELECT_INPUT DAISY Register
(IOMUXC_FLEXPWM1_PWMA1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 45Ch offset = 401F_845Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_FLEXPWM1_PWMA1_SELECT_INPUT** field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm1, In Pin: pwma1</td>
</tr>
</tbody>
</table>

- **0** GPIO_EMC_25_ALT1 — Selecting Pad: GPIO_EMC_25 for Mode: ALT1
- **1** GPIO_SD_B0_02_ALT1 — Selecting Pad: GPIO_SD_B0_02 for Mode: ALT1
11.7.276   FLEXPWM1_PWMA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMA2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 460h offset = 401F_8460h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_FLEXPWM1_PWMA2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm1, In Pin: pwma2</td>
</tr>
<tr>
<td>0 GPIO_EMC_27_ALT1 — Selecting Pad: GPIO_EMC_27 for Mode: ALT1</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_SD_B0_04_ALT1 — Selecting Pad: GPIO_SD_B0_04 for Mode: ALT1</td>
<td></td>
</tr>
</tbody>
</table>

11.7.277   FLEXPWM1_PWMB3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMB3_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 464h offset = 401F_8464h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 |  9 |  8 |  7 |  6 |  5 |  4 |  3 |  2 |  1 |  0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Chapter 11 IOMUX Controller (IOMUXC)
i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
NXPSemiconductors
### Table: IOMUXC_FLEXPWM1_PWMB3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexpwm1, In Pin: pwmb3

- 000 **GPIO_SD_B1_01_ALT2** — Selecting Pad: GPIO_SD_B1_01 for Mode: ALT2
- 001 **GPIO_EMC_13_ALT4** — Selecting Pad: GPIO_EMC_13 for Mode: ALT4
- 010 **GPIO_EMC_39_ALT1** — Selecting Pad: GPIO_EMC_39 for Mode: ALT1
- 011 **GPIO_AD_B0_11_ALT1** — Selecting Pad: GPIO_AD_B0_11 for Mode: ALT1
- 100 **GPIO_B1_01_ALT6** — Selecting Pad: GPIO_B1_01 for Mode: ALT6

---

### 11.7.278 FLEXPWM1_PWMB0_SELECT_INPUT DAISY Register

**IOMUXC_FLEXPWM1_PWMB0_SELECT_INPUT**

**DAISY Register**

Address: 401F_8000h base + 468h offset = 401F_8468h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### Table: IOMUXC_FLEXPWM1_PWMB0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexpwm1, In Pin: pwmb0

- 0 **GPIO_EMC_24_ALT1** — Selecting Pad: GPIO_EMC_24 for Mode: ALT1
- 1 **GPIO_SD_B0_01_ALT1** — Selecting Pad: GPIO_SD_B0_01 for Mode: ALT1
11.7.279  FLEXPWM1_PWMB1_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM1_PWMB1_SELECT_INPUT)

DAISY Register

Address: 4018000h base + 46Ch offset = 401F_846Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

DAISY

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_FLEXPWM1_PWMB1_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexpwm1, In Pin: pwmb1

0  GPIO_EMC_26_ALT1 — Selecting Pad: GPIO_EMC_26 for Mode: ALT1
1  GPIO_SD_B0_03_ALT1 — Selecting Pad: GPIO_SD_B0_03 for Mode: ALT1
### 11.7.280 FLEXPWM1_PWMB2_SELECT_INPUT DAISY Register
(IOMUXC_FLEXPWM1_PWMB2_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 470h offset = 401F_8470h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_FLEXPWM1_PWMB2_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: flexpwm1, In Pin: pwmb2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_28_ALT1 — Selecting Pad: GPIO_EMC_28 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B0_05_ALT1 — Selecting Pad: GPIO_SD_B0_05 for Mode: ALT1</td>
</tr>
</tbody>
</table>

### 11.7.281 FLEXPWM2_PWMA3_SELECT_INPUT DAISY Register
(IOMUXC_FLEXPWM2_PWMA3_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 474h offset = 401F_8474h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
IOMUXC_FLEXPWM2_PWMA3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm2, In Pin: pwma3</td>
</tr>
<tr>
<td>000</td>
<td>GPIO_SD_B1_02_ALT2 — Selecting Pad: GPIO_SD_B1_02 for Mode: ALT2</td>
</tr>
<tr>
<td>001</td>
<td>GPIO_EMC_19_ALT1 — Selecting Pad: GPIO_EMC_19 for Mode: ALT1</td>
</tr>
<tr>
<td>010</td>
<td>GPIO_AD_B0_00_ALT0 — Selecting Pad: GPIO_AD_B0_00 for Mode: ALT0</td>
</tr>
<tr>
<td>011</td>
<td>GPIO_AD_B0_09_ALT1 — Selecting Pad: GPIO_AD_B0_09 for Mode: ALT1</td>
</tr>
<tr>
<td>100</td>
<td>GPIO_B1_02_ALT6 — Selecting Pad: GPIO_B1_02 for Mode: ALT6</td>
</tr>
</tbody>
</table>

11.7.282 FLEXPWM2_PWMA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM2_PWMA0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 478h offset = 401F_8478h

IOMUXC_FLEXPWM2_PWMA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm2, In Pin: pwma0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_06_ALT1 — Selecting Pad: GPIO_EMC_06 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_06_ALT2 — Selecting Pad: GPIO_B0_06 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.283 **FLEXPWM2_PWMA1_SELECT_INPUT DAISY Register** (IOMUXC_FLEXPWM2_PWMA1_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 47Ch offset = 401F_847Ch

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**IOMUXC_FLEXPWM2_PWMA1_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td>Selecting Pads Involved in Daisy Chain.</td>
<td></td>
</tr>
<tr>
<td>Instance: flexpwm2, In Pin: pwma1</td>
<td></td>
</tr>
<tr>
<td>0 GPIO_EMC_08_ALT1 — Selecting Pad: GPIO_EMC_08 for Mode: ALT1</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_B0_08_ALT2 — Selecting Pad: GPIO_B0_08 for Mode: ALT2</td>
<td></td>
</tr>
</tbody>
</table>
11.7.284  FLEXPWM2_PWMA2_SELECT_INPUT DAISY Register

(IOMUXC_FLEXPWM2_PWMA2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 480h offset = 401F_8480h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm2, In Pin: pwma2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_10_ALT1</td>
<td>— Selecting Pad: GPIO_EMC_10 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_10_ALT2</td>
<td>— Selecting Pad: GPIO_B0_10 for Mode: ALT2</td>
</tr>
</tbody>
</table>

11.7.285  FLEXPWM2_PWMB3_SELECT_INPUT DAISY Register

(IOMUXC_FLEXPWM2_PWMB3_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 484h offset = 401F_8484h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm2, In Pin: pwmb3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_EMC_10_ALT1</td>
<td>— Selecting Pad: GPIO_EMC_10 for Mode: ALT1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_B0_10_ALT2</td>
<td>— Selecting Pad: GPIO_B0_10 for Mode: ALT2</td>
</tr>
</tbody>
</table>
### IOMUXC_FLEXPWM2_PWMB3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

- Instance: flexpwm2, In Pin: pwmb3
- 00 GPIO_SD_B1_03_ALT2 — Selecting Pad: GPIO_SD_B1_03 for Mode: ALT2
- 01 GPIO_EMC_20_ALT1 — Selecting Pad: GPIO_EMC_20 for Mode: ALT1
- 10 GPIO_AD_B0_01_ALT0 — Selecting Pad: GPIO_AD_B0_01 for Mode: ALT0
- 11 GPIO_B1_03_ALT6 — Selecting Pad: GPIO_B1_03 for Mode: ALT6

### 11.7.286 FLEXPWM2_PWMB0_SELECT_INPUT DAISY Register

#### (IOMUXC_FLEXPWM2_PWMB0_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 488h offset = 401F_8488h

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bit</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

#### IOMUXC_FLEXPWM2_PWMB0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

- Instance: flexpwm2, In Pin: pwmb0
- 0 GPIO_EMC_07_ALT1 — Selecting Pad: GPIO_EMC_07 for Mode: ALT1
- 1 GPIO_B0_07_ALT2 — Selecting Pad: GPIO_B0_07 for Mode: ALT2
### 11.7.287 FLEXPWM2_PWMB1_SELECT_INPUT DAISY Register

**IOMUXC_FLEXPWM2_PWMB1_SELECT_INPUT**

**DAISY Register**

Address: 401F_8000h base + 48Ch offset = 401F_848Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_FLEXPWM2_PWMB1_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

**DAISY**

Selecting Pads Involved in Daisy Chain.

Instance: flexpwm2, In Pin: pwmb1

| 0 GPIO_EMC_09_ALT1 — Selecting Pad: GPIO_EMC_09 for Mode: ALT1 |
| 1 GPIO_B0_09_ALT2 — Selecting Pad: GPIO_B0_09 for Mode: ALT2 |
### 11.7.288 FLEXPWM2_PWMB2_SELECT_INPUT DAISY Register

#### (IOMUXC_FLEXPWM2_PWMB2_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 490h offset = 401F_8490h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_FLEXPWM2_PWMB2_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm2, In Pin: pwmb2</td>
</tr>
<tr>
<td>0 GPIO_EMC_11_ALT1</td>
<td>Selecting Pad: GPIO_EMC_11 for Mode: ALT1</td>
</tr>
<tr>
<td>1 GPIO_B0_11_ALT2</td>
<td>Selecting Pad: GPIO_B0_11 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.289 FLEXPWM4_PWMA0_SELECT_INPUT DAISY Register
(IOMUXC_FLEXPWM4_PWMA0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 494h offset = 401F_8494h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_FLEXPWM4_PWMA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm4, In Pin: pwma0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_00_ALT1 — Selecting Pad: GPIO_EMC_00 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_08_ALT1 — Selecting Pad: GPIO_AD_B1_08 for Mode: ALT1</td>
</tr>
</tbody>
</table>
# 11.7.290 FLEXPWM4_PWMA1_SELECT_INPUT DAISY Register

(IOMUXC_FLEXPWM4_PWMA1_SELECT_INPUT)

## DAISY Register

Address: 401F_8000h base + 498h offset = 401F_8498h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

## IOMUXC_FLEXPWM4_PWMA1_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: flexpwm4, In Pin: pwma1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_02_ALT1 — Selecting Pad: GPIO_EMC_02 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_09_ALT1 — Selecting Pad: GPIO_AD_B1_09 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.291 FLEXPWM4_PWMA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM4_PWMA2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 49Ch offset = 401F_849Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_FLEXPWM4_PWMA2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

- Selecting Pads Involved in Daisy Chain.

Instance: flexpwm4, In Pin: pwma2

0 GPIO_EMC_04_ALT1 — Selecting Pad: GPIO_EMC_04 for Mode: ALT1
1 GPIO_B1_14_ALT1 — Selecting Pad: GPIO_B1_14 for Mode: ALT1
11.7.292 FLEXPWM4_PWMA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXPWM4_PWMA3_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 4A0h offset = 401F_84A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_FLEXPWM4_PWMA3_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexpwm4, In Pin: pwma3</td>
</tr>
<tr>
<td>0 GPIO_EMC_17_ALT1</td>
<td>Selecting Pad: GPIO_EMC_17 for Mode: ALT1</td>
</tr>
<tr>
<td>1 GPIO_B1_15_ALT1</td>
<td>Selecting Pad: GPIO_B1_15 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.293  FLEXSPIA_DQS_SELECT_INPUT DAISY Register  
(IOMUXC_FLEXSPIA_DQS_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4A4h offset = 401F_84A4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_FLEXSPIA_DQS_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1  | This field is reserved.  
|       | Reserved    |

|    | DAISY       |
|    | Selecting Pads Involved in Daisy Chain.  
|    | Instance: flexspi, In Pin: dqs |

|    | GPIO_SD_B1_05_ALT1 — Selecting Pad: GPIO_SD_B1_05 for Mode: ALT1 |
| 0  | GPIO_AD_B1_09_ALT0 — Selecting Pad: GPIO_AD_B1_09 for Mode: ALT0 |
**11.7.294  FLEXSPIA_DATA0_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DATA0_SELECT_INPUT)**

**DAISY Register**

Address: 401F_8000h base + 4A8h offset = 401F_84A8h

---

**Bit 31–1**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**Bit 0**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
<th>Instance: flexspi, In Pin: data0</th>
</tr>
</thead>
<tbody>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
<td>GPIO_SD_B1_08_ALT1 — Selecting Pad: GPIO_SD_B1_08 for Mode: ALT1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_13_ALT0 — Selecting Pad: GPIO_AD_B1_13 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.295 FLEXSPIA_DATA1_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPIA_DATA1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4ACh offset = 401F_84ACh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DAISY

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_FLEXSPIA_DATA1_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: flexspi, In Pin: data1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_09_ALT1 — Selecting Pad: GPIO_SD_B1_09 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_12_ALT0 — Selecting Pad: GPIO_AD_B1_12 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.296 FLEXSPIA_DATA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DATA2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4B0h offset = 401F_84B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_FLEXSPIA_DATA2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

31–1 This field is reserved. Reserved

0 DAISY Selecting Pads Involved in Daisy Chain.

Instance: flexspi, In Pin: data2

0 GPIO_SD_B1_10_ALT1 — Selecting Pad: GPIO_SD_B1_10 for Mode: ALT1
1 GPIO_AD_B1_11_ALT0 — Selecting Pad: GPIO_AD_B1_11 for Mode: ALT0
11.7.297  **FLEXSPIA_DATA3_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIA_DATA3_SELECT_INPUT)**

**DAISY Register**

Address: 401F_8000h base + 4B4h offset = 401F_84B4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_FLEXSPIA_DATA3_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi, In Pin: data3</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_11_ALT1 — Selecting Pad: GPIO_SD_B1_11 for Mode: ALT1</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_AD_B1_10_ALT0 — Selecting Pad: GPIO_AD_B1_10 for Mode: ALT0</td>
<td></td>
</tr>
</tbody>
</table>
11.7.298  FLEXSPIB_DATA0_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPIB_DATA0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4B8h offset = 401F_84B8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_FLEXSPIB_DATA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: flexspi, In Pin: data0</td>
</tr>
</tbody>
</table>

0   GPIO_SD_B1_03_ALT1 — Selecting Pad: GPIO_SD_B1_03 for Mode: ALT1
1   GPIO_AD_B1_07_ALT0 — Selecting Pad: GPIO_AD_B1_07 for Mode: ALT0
11.7.299  FLEXSPIB_DATA1_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPIB_DATA1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4BCh offset = 401F_84BCh

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi, In Pin: data1</td>
</tr>
<tr>
<td>0</td>
<td>0 GPIO_SD_B1_02_ALT1 — Selecting Pad: GPIO_SD_B1_02 for Mode: ALT1</td>
</tr>
<tr>
<td></td>
<td>1 GPIO_AD_B1_06_ALT0 — Selecting Pad: GPIO_AD_B1_06 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.300  FLEXSPIB_DATA2_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPIB_DATA2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4C0h offset = 401F_84C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_FLEXSPIB_DATA2_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexspi, In Pin: data2

- 0 GPIO_SD_B1_01_ALT1 — Selecting Pad: GPIO_SD_B1_01 for Mode: ALT1
- 1 GPIO_AD_B1_05_ALT0 — Selecting Pad: GPIO_AD_B1_05 for Mode: ALT0
### 11.7.301 FLEXSPIB_DATA3_SELECT_INPUT DAISY Register

**IOMUXC_FLEXSPIB_DATA3_SELECT_INPUT**

#### DAISY Register

Address: 401F_8000h base + 4C4h offset = 401F_84C4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### IOMUXC_FLEXSPIB_DATA3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi, In Pin: data3</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_00_ALT1 — Selecting Pad: GPIO_SD_B1_00 for Mode: ALT1</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_AD_B1_04_ALT0 — Selecting Pad: GPIO_AD_B1_04 for Mode: ALT0</td>
<td></td>
</tr>
</tbody>
</table>
11.7.302  FLEXSPIA_SCK_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPIA_SCK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4C8h offset = 401F_84C8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_FLEXSPIA_SCK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi, In Pin: sck_fa</td>
</tr>
<tr>
<td></td>
<td>0 GPIO_SD_B1_07_ALT1 — Selecting Pad: GPIO_SD_B1_07 for Mode: ALT1</td>
</tr>
<tr>
<td></td>
<td>1 GPIO_AD_B1_14_ALT0 — Selecting Pad: GPIO_AD_B1_14 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.303  LPI2C1_SCL_SELECT_INPUT DAISY Register (IOMUXC_LPI2C1_SCL_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4CCh offset = 401F_84CCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**Reserved**

**DAISY**

**IOMUXC_LPI2C1_SCL_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: lpi2c1, In Pin: lpi2c_scl</td>
</tr>
<tr>
<td>0</td>
<td><strong>GPIO_SD_B1_04_ALT2</strong> — Selecting Pad: GPIO_SD_B1_04 for Mode: ALT2</td>
</tr>
<tr>
<td>1</td>
<td><strong>GPIO_AD_B1_00_ALT3</strong> — Selecting Pad: GPIO_AD_B1_00 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.304 LPI2C1_SDA_SELECT_INPUT DAISY Register
(IOMUXC_LPI2C1_SDA_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4D0h offset = 401F_84D0h

```
+-------------------+-------------------+-------------------+-------------------+
| Bit              | Bit              | Bit              | Bit              |
| 31               | 30               | 29               | 28               |
| Reserved         | Reserved         | Reserved         | Reserved         |
| R                | W                | R                | W                |
| Reset            | 0                | 0                | 0                |
+-------------------+-------------------+-------------------+-------------------+
| Bit              | Bit              | Bit              | Bit              |
| 15               | 14               | 13               | 12               |
| Reserved         | Reserved         | Reserved         | Reserved         |
| R                | W                | R                | W                |
| Reset            | 0                | 0                | 0                |
+-------------------+-------------------+-------------------+-------------------+
```

IOMUXC_LPI2C1_SDA_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: lpi2c1, In Pin: lpi2c_sda</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_05_ALT2 — Selecting Pad: GPIO_SD_B1_05 for Mode: ALT2</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_01_ALT3 — Selecting Pad: GPIO_AD_B1_01 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.305  LPI2C2_SCL_SELECT_INPUT DAISY Register
(IOMUXC_LPI2C2_SCL_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4D4h offset = 401F_84D4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### IOMUXC_LPI2C2_SCL_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: lpi2c2, In Pin: lpi2c_scl</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_11_ALT3  —  Selecting Pad: GPIO_SD_B1_11 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_04_ALT2  —  Selecting Pad: GPIO_B0_04 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.306  LPI2C2_SDA_SELECT_INPUT DAISY Register  
(IOMUXC_LPI2C2_SDA_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4D8h offset = 401F_84D8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**Reserved**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**Reserved**

**IOMUXC_LPI2C2_SDA_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 0 DAISY | Selecting Pads Involved in Daisy Chain.  
Instance: Ipi2c2, In Pin: Ipi2c_sda  
0 GPIO_SD_B1_10_ALT3 — Selecting Pad: GPIO_SD_B1_10 for Mode: ALT3  
1 GPIO_B0_05_ALT2 — Selecting Pad: GPIO_B0_05 for Mode: ALT2 |

11.7.307  LPI2C3_SCL_SELECT_INPUT DAISY Register  
(IOMUXC_LPI2C3_SCL_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4DCh offset = 401F_84DCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**Reserved**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**Reserved**

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
## IOMUXC_LPI2C3_SCL_SELECT_INPUT Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: lpi2c3, In Pin: lpi2c_scl</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_22_ALT2 — Selecting Pad: GPIO_EMC_22 for Mode: ALT2</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_SD_B0_00_ALT2 — Selecting Pad: GPIO_SD_B0_00 for Mode: ALT2</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_AD_B1_07_ALT1 — Selecting Pad: GPIO_AD_B1_07 for Mode: ALT1</td>
</tr>
</tbody>
</table>

## 11.7.308 LPI2C3_SDA_SELECT_INPUT DAISY Register (IOMUXC_LPI2C3_SDA_SELECT_INPUT)

### DAISY Register

Address: 401F_8000h base + 4E0h offset = 401F_84E0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_LPI2C3_SDA_SELECT_INPUT Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: lpi2c3, In Pin: lpi2c_sda</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_21_ALT2 — Selecting Pad: GPIO_EMC_21 for Mode: ALT2</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_SD_B0_01_ALT2 — Selecting Pad: GPIO_SD_B0_01 for Mode: ALT2</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_AD_B1_06_ALT1 — Selecting Pad: GPIO_AD_B1_06 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.309 LPI2C4_SCL_SELECT_INPUT DAISY Register
(IOMUXC_LPI2C4_SCL_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4E4h offset = 401F_84E4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPI2C4_SCL_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>DAISY</td>
<td>Instance: lpi2c4, In Pin: lpi2c_scl</td>
</tr>
</tbody>
</table>

0  GPIO_EMCC_12_ALT2 — Selecting Pad: GPIO_EMCC_12 for Mode: ALT2
1  GPIO_AD_B0_12_ALT0 — Selecting Pad: GPIO_AD_B0_12 for Mode: ALT0
### 11.7.310 LPI2C4_SDA_SELECT_INPUT DAISY Register (IOMUXC_LPI2C4_SDA_SELECT_INPUT)

**DAISY Register**

**Address:** 401F_8000h base + 4E8h offset = 401F_84E8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### IOMUXC_LPI2C4_SDA_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>DAISY</th>
<th>Selecting Pads Involved in Daisy Chain.</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPIO_EMC_11_ALT2 — Selecting Pad: GPIO_EMC_11 for Mode: ALT2</td>
</tr>
<tr>
<td></td>
<td>Instance: LPI2C4, In Pin: LPI2C_SDA</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_13_ALT0 — Selecting Pad: GPIO_AD_B0_13 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.311  LPSPI1_PCS0_SELECT_INPUT DAISY Register (IOMUXC_LPSPI1_PCS0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4Ec offset = 401F_84Ec

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPSPI1_PCS0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pad: GPIO_SD_B0_01 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>Selecting Pad: GPIO_EMC_30 for Mode: ALT3</td>
</tr>
</tbody>
</table>

Instance: lpspi1, In Pin: lpspi_pcs0
### 11.7.312 LPSPI1_SCK_SELECT_INPUT DAISY Register (IOMUXC_LPSPI1_SCK_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 4F0h offset = 401F_84F0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### IOMUXC_LPSPI1_SCK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: lpspi1, In Pin: lpspi_sck</td>
</tr>
<tr>
<td>0 GPIO_EMCC_27_ALT3</td>
<td>Selecting Pad: GPIO_EMCC_27 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_SD_B0_00_ALT4</td>
<td>Selecting Pad: GPIO_SD_B0_00 for Mode: ALT4</td>
</tr>
</tbody>
</table>
11.7.313 LPSP1_SD1_SELECT_INPUT DAISY Register
(IOMUXC_LPSP1_SD1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4F4h offset = 401F_84F4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_LPSP1_SD1_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: Ipspi1, In Pin: Ipspi_sdi</td>
</tr>
<tr>
<td>0 GPIO_EMC_29_ALT3</td>
<td>— Selecting Pad: GPIO_EMC_29 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_SD_B0_03_ALT4</td>
<td>— Selecting Pad: GPIO_AD_B0_03 for Mode: ALT4</td>
</tr>
</tbody>
</table>
11.7.314 LPSPI1_SDO_SELECT_INPUT DAISY Register

(IOMUXC_LPSPI1_SDO_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 4F8h offset = 401F_84F8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPSPI1_SDO_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpspi1, In Pin: lpspi_sdo</td>
</tr>
<tr>
<td>0 GPIO_EMC_28_ALT3</td>
<td>— Selecting Pad: GPIO_EMC_28 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_SD_B0_02_ALT4</td>
<td>— Selecting Pad: GPIO_SD_B0_02 for Mode: ALT4</td>
</tr>
</tbody>
</table>
11.7.315  **LPSPI2_PCS0_SELECT_INPUT DAISY Register**  
*(IOMUXC_LPSPI2_PCS0_SELECT_INPUT)*

**DAISY Register**

Address: 401F_8000h base + 4FCh offset = 401F_84FCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_LPSPI2_PCS0_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

0  **DAISY**  
Selecting Pads Involved in Daisy Chain.  
Instance: lpspi2, In Pin: lpspi_pcs0

0  **GPIO_SD_B1_06_ALT4**  — Selecting Pad: GPIO_SD_B1_06 for Mode: ALT4  
1  **GPIO_EMC_01_ALT2**  — Selecting Pad: GPIO_EMC_01 for Mode: ALT2
11.7.316 LPSPI2_SCK_SELECT_INPUT DAISY Register (IOMUXC_LPSPI2_SCK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 500h offset = 401F_8500h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### IOMUXC_LPSPI2_SCK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: Ipspi2, In Pin: Ipspi_sck</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_07_ALT4</td>
<td>Selecting Pad: GPIO_SD_B1_07 for Mode: ALT4</td>
</tr>
<tr>
<td>1 GPIO_EMC_00_ALT2</td>
<td>Selecting Pad: GPIO_EMC_00 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.317  LPSPI2_SD<Select_INPUT DAISY Register
(IOMUXC_LPSPI2_SD<Select_INPUT)

DAISY Register

Address: 401_F_8000h base + 504h offset = 401_F_8504h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: Lpspi2, In Pin: Lpspi_sdi</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_09_ALT4 — Selecting Pad: GPIO_SD_B1_09 for Mode: ALT4</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>GPIO_EMC_03_ALT2 — Selecting Pad: GPIO_EMC_03 for Mode: ALT2</td>
<td></td>
</tr>
</tbody>
</table>
11.7.318  LPSPI2_SDO_SELECT_INPUT DAISY Register
(IOMUXC_LPSPI2_SDO_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 508h offset = 401F_8508h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPSPI2_SDO_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: Lpspi2, In Pin: Lpspi_sdo

- 0 GPIO_SD_B1_08_ALT4 — Selecting Pad: GPIO_SD_B1_08 for Mode: ALT4
- 1 GPIO_EMC_02_ALT2 — Selecting Pad: GPIO_EMC_02 for Mode: ALT2
11.7.319  \textbf{LPSPI3\_PCS0\_SELECT\_INPUT DAISY Register (IOMUXC\_LPSPI3\_PCS0\_SELECT\_INPUT)}

**DAISY Register**

Address: 401F\_8000h base + 50Ch offset = 401F\_850Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC\_LPSPI3\_PCS0\_SELECT\_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

| Instance: lpspi3, In Pin: lpspi\_pcs0 |
| 0  | \textbf{GPIO\_AD\_B0\_03\_ALT7} — Selecting Pad: GPIO\_AD\_B0\_03 for Mode: ALT7 |
| 1  | \textbf{GPIO\_AD\_B1\_12\_ALT2} — Selecting Pad: GPIO\_AD\_B1\_12 for Mode: ALT2 |
11.7.320 LPSPI3_SCK_SELECT_INPUT DAISY Register (IOMUXC_LPSPSI3_SCK_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 510h offset = 401F_8510h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_LPSPSI3_SCK_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: Ipspi3, In Pin: Ipspi_sck</td>
</tr>
<tr>
<td>0 GPIO_AD_B0_00_ALT7</td>
<td>Selecting Pad: GPIO_AD_B0_00 for Mode: ALT7</td>
</tr>
<tr>
<td>1 GPIO_AD_B1_15_ALT2</td>
<td>Selecting Pad: GPIO_AD_B1_15 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.321  LP SPI3_SD I_SELECT_INPUT DAISY Register  
(IOMUXC_LPSPI3_SD I_SELECT_INPUT)  

DAISY Register  
Address: 401F_8000h base + 514h offset = 401F_8514h  

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| W   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| R   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| W   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### IOMUXC_LPSPI3_SD I_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1  | This field is reserved.  
|       | Reserved |
| 0     | Selecting Pads Involved in Daisy Chain.  
|       | Instance: Lpspi3, In Pin: Lpspi_sdi |
| 1     | GPIO_AD_B1_13_ALT2 — Selecting Pad: GPIO_AD_B1_13 for Mode: ALT2 |
| 0     | GPIO_AD_B0_02_ALT7 — Selecting Pad: GPIO_AD_B0_02 for Mode: ALT7 |
11.7.322 LPSPI3_SDO_SELECT_INPUT DAISY Register (IOMUXC_LPSPI3_SDO_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 518h offset = 401F_8518h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPSPI3_SDO_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

Selecting Pads Involved in Daisy Chain.

Instance: lpspi3, In Pin: lpspi_sdo

1 GPIO_AD_B1_14_ALT2 — Selecting Pad: GPIO_AD_B1_14 for Mode: ALT2
0 GPIO_AD_B0_01_ALT7 — Selecting Pad: GPIO_AD_B0_01 for Mode: ALT7
## 11.7.323 LPSPI4_PCS0_SELECT_INPUT DAISY Register

**IOMUXC_LPSPI4_PCS0_SELECT_INPUT**

**DAISY Register**

Address: 401F_8000h base + 51Ch offset = 401F_851Ch

```
+---+---+---+---+---+---+---+---+---+---+---+---+---+
| 31| 30| 29| 28| 27| 26| 25| 24| 23| 22| 21| 20| 19| 18| 17| 16|
+---+---+---+---+---+---+---+---+---+---+---+---+---+
  R  | W  |  Reserved |
+---+---+-----------+
  R  | W  |  Reserved |
```

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### IOMUXC_LPSPI4_PCS0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>Instance: lpspi4, In Pin: lpspi_pcs0</td>
<td></td>
</tr>
<tr>
<td>0 GPIO_B0_00_ALT3</td>
<td>Selecting Pad: GPIO_B0_00 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_B1_04_ALT1</td>
<td>Selecting Pad:GPIO_B1_04 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.324  LP SPI4_SCK_SELECT_INPUT DAISY Register

(IOMUXC_LPSPI4_SCK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 520h offset = 401F_8520h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 00000000000000000000000000000000

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 00000000000000000000000000000000

IOMUXC_LPSPI4_SCK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>DAISY</td>
<td>Instance: Ipspi4, In Pin: Ipspi_sck</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_B0_03_ALT3 — Selecting Pad: GPIO_B0_03 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_07_ALT1 — Selecting Pad: GPIO_B1_07 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.325  LPSPI4_SDI_SELECT_INPUT DAISY Register
(IOMUXC_LPSPI4_SDI_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 524h offset = 401F_8524h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_LPSPI4_SDI_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpspi4, In Pin: lpspi_sdi</td>
</tr>
<tr>
<td>0 GPIO_B0_01_ALT3</td>
<td>— Selecting Pad: GPIO_B0_01 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_B1_05_ALT1</td>
<td>— Selecting Pad: GPIO_B1_05 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.326  LPSP4_SDO_SELECT_INPUT DAISY Register
(IOMUXC_LPSP4_SDO_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 528h offset = 401F_8528h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPSP4_SDO_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1  | This field is reserved.  
       | Reserved     |
| 0 DAISY | Selecting Pads Involved in Daisy Chain.  
         | Instance: lpspi4, In Pin: lpspi_sdo  
         | 0 GPIO_B0_02_ALT3 — Selecting Pad: GPIO_B0_02 for Mode: ALT3  
         | 1 GPIO_B1_06_ALT1 — Selecting Pad: GPIO_B1_06 for Mode: ALT1 |
11.7.327 LPUART2_RX_SELECT_INPUT DAISY Register

(IOMUXC_LPUART2_RX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 52Ch offset = 401F_852Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_LPUART2_RX_SELECT_INPUT** field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>Instance: lpuart2, In Pin: lpuart_rx</td>
<td></td>
</tr>
<tr>
<td>0 GPIO_SD_B1_10_ALT2</td>
<td>Selecting Pad: GPIO_SD_B1_10 for Mode: ALT2</td>
</tr>
<tr>
<td>1 GPIO_AD_B1_03_ALT2</td>
<td>Selecting Pad: GPIO_AD_B1_03 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.328  LPUART2_TX_SELECT_INPUT DAISY Register  
(IOMUXC_LPUART2_TX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 530h offset = 401F_8530h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

Reserved

IOMUXC_LPUART2_TX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpuart2, In Pin: lpuart_tx</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_11_ALT2</td>
<td>— Selecting Pad: GPIO_SD_B1_11 for Mode: ALT2</td>
</tr>
<tr>
<td>1 GPIO_AD_B1_02_ALT2</td>
<td>— Selecting Pad: GPIO_AD_B1_02 for Mode: ALT2</td>
</tr>
</tbody>
</table>
### LPUART3_CTS_B_SELECT_INPUT DAISY Register (IOMUXC_LPUART3_CTS_B_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 534h offset = 401F_8534h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_LPUART3_CTS_B_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpuart3, In Pin: lpuart_cts_b</td>
</tr>
</tbody>
</table>

- 0  GPIO_EMCC_15_ALT2 — Selecting Pad: GPIO_EMCC_15 for Mode: ALT2
- 1  GPIO_AD_B1_04_ALT2 — Selecting Pad: GPIO_AD_B1_04 for Mode: ALT2

### LPUART3_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART3_RX_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 538h offset = 401F_8538h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_LPUART3_RX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reservation</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpuart3, In Pin: lpuart_rx</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_14_ALT2 — Selecting Pad: GPIO_EMC_14 for Mode: ALT2</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_AD_B1_07_ALT2 — Selecting Pad: GPIO_AD_B1_07 for Mode: ALT2</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B0_09_ALT3 — Selecting Pad: GPIO_B0_09 for Mode: ALT3</td>
</tr>
</tbody>
</table>

### 11.7.331 LPUART3_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART3_TX_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 53Ch offset = 401F_853Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_LPUART3_TX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reservation</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpuart3, In Pin: lpuart_tx</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_13_ALT2 — Selecting Pad: GPIO_EMC_13 for Mode: ALT2</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_AD_B1_06_ALT2 — Selecting Pad: GPIO_AD_B1_06 for Mode: ALT2</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B0_08_ALT3 — Selecting Pad: GPIO_B0_08 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.332 LPUART4_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART4_RX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 540h offset = 401F_8540h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>W</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Bit Description

- Reserved (Field: 31–2)
- DAISY (Field: 15–0)

IOMUXC_LPUART4_RX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: lpuart4, In Pin: lpuart_rx</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_SD_B1_01_ALT4 — Selecting Pad: GPIO_SD_B1_01 for Mode: ALT4</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_20_ALT2 — Selecting Pad: GPIO_EMC_20 for Mode: ALT2</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B1_01_ALT2 — Selecting Pad: GPIO_B1_01 for Mode: ALT2</td>
</tr>
</tbody>
</table>

11.7.333 LPUART4_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART4_TX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 544h offset = 401F_8544h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>W</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Bit Description

- Reserved (Field: 31–2)
- DAISY (Field: 15–0)

IOMUXC Memory Map/Register Definition

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_LPUART4_TX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–2 | This field is reserved.  
|       | Reserved    |
| DAISY | Selecting Pads Involved in Daisy Chain.  
|       | Instance: lpuart4, In Pin: lpuart_tx  
| 00   | GPIO_SD_B1_00_ALT4 — Selecting Pad: GPIO_SD_B1_00 for Mode: ALT4  
| 01   | GPIO_EMC_19_ALT2 — Selecting Pad: GPIO_EMC_19 for Mode: ALT2  
| 10   | GPIO_B1_00_ALT2 — Selecting Pad: GPIO_B1_00 for Mode: ALT2  |

### 11.7.334 LPUART5_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART5_RX_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 548h offset = 401F_8548h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### IOMUXC_LPUART5_RX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1  | This field is reserved.  
|       | Reserved    |
| DAISY | Selecting Pads Involved in Daisy Chain.  
|       | Instance: lpuart5, In Pin: lpuart_rx  
| 0    | GPIO_EMC_24_ALT2 — Selecting Pad: GPIO_EMC_24 for Mode: ALT2  
| 1    | GPIO_B1_13_ALT1 — Selecting Pad: GPIO_B1_13 for Mode: ALT1  |
11.7.335 LPUART5_TX_SELECT_INPUT DAISY Register
(IOMUXC_LPUART5_TX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 54Ch offset = 401F_854Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_LPUART5_TX_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 31–1</td>
<td>This field is reserved. &lt;br&gt;Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. &lt;br&gt;Instance: lpuart5, In Pin: lpuart_tx</td>
</tr>
<tr>
<td>0 GPIO_EMC_23_ALT2</td>
<td>Selecting Pad: GPIO_EMC_23 for Mode: ALT2</td>
</tr>
<tr>
<td>1 GPIO_B1_12_ALT1</td>
<td>Selecting Pad: GPIO_B1_12 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.336   LPUART6_RX_SELECT_INPUT DAISY Register  
(IOMUXC_LPUART6_RX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 550h offset = 401F_8550h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPUART6_RX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpuart6, In: lpuart_rx</td>
</tr>
</tbody>
</table>
| DAISY | 0 GPIO_EMC_26_ALT2 — Selecting Pad: GPIO_EMC_26 for Mode: ALT2  
        1 GPIO_AD_B0_03_ALT2 — Selecting Pad: GPIO_AD_B0_03 for Mode: ALT2 |
11.7.337 LPUART6_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART6_TX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 554h offset = 401F_8554h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpuart6, In Pin: lpuart_tx</td>
</tr>
<tr>
<td>0 GPIO_EMU_25_ALT2</td>
<td>Selecting Pad: GPIO_EMU_25 for Mode: ALT2</td>
</tr>
<tr>
<td>1 GPIO_AD_B0_02_ALT2</td>
<td>Selecting Pad: GPIO_AD_B0_02 for Mode: ALT2</td>
</tr>
</tbody>
</table>
### 11.7.338 LPUART7_RX_SELECT_INPUT DAISY Register (IOMUXC_LPUART7_RX_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 558h offset = 401F_8558h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: lpuart7, In Pin: lpuart_rx</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_09_ALT2</td>
<td>Selecting Pad: GPIO_SD_B1_09 for Mode: ALT2</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_EMC_32_ALT2</td>
<td>Selecting Pad: GPIO_EMC_32 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.339  LPUART7_TX_SELECT_INPUT DAISY Register  
(IOMUXC_LPUART7_TX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 55Ch offset = 401F_855Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_LPUART7_TX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: lpuart7, In Pin: lpuart_tx

0  GPIO_SD_B1_08_ALT2 — Selecting Pad: GPIO_SD_B1_08 for Mode: ALT2
1  GPIO_EMC_31_ALT2 — Selecting Pad: GPIO_EMC_31 for Mode: ALT2

11.7.340  LPUART8_RX_SELECT_INPUT DAISY Register  
(IOMUXC_LPUART8_RX_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 560h offset = 401F_8560h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
## IOMUXC_LPUART8_RX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_SD_B0_05_ALT2 — Selecting Pad: GPIO_SD_B0_05 for Mode: ALT2</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B1_11_ALT2 — Selecting Pad: GPIO_AD_B1_11 for Mode: ALT2</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_EMC_39_ALT2 — Selecting Pad: GPIO_EMC_39 for Mode: ALT2</td>
</tr>
</tbody>
</table>

## 11.7.341 LPUART8_TX_SELECT_INPUT DAISY Register (IOMUXC_LPUART8_TX_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 564h offset = 401F_8564h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

## IOMUXC_LPUART8_TX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_SD_B0_04_ALT2 — Selecting Pad: GPIO_SD_B0_04 for Mode: ALT2</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B1_10_ALT2 — Selecting Pad: GPIO_AD_B1_10 for Mode: ALT2</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_EMC_38_ALT2 — Selecting Pad: GPIO_EMC_38 for Mode: ALT2</td>
</tr>
</tbody>
</table>
11.7.342 **NMI_GLUE_NMI_SELECT_INPUT DAISY Register**

*(IOMUXC_NMI_SELECT_INPUT)*

**DAISY Register**

Address: 401F_8000h base + 568h offset = 401F_8568h

### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: nmi_glue, In Pin: ipp_ind_nmi</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B0_12_ALT7 — Selecting Pad: GPIO_AD_B0_12 for Mode: ALT7</td>
</tr>
<tr>
<td>1</td>
<td>WAKEUP_ALT7 — Selecting Pad: WAKEUP for Mode: ALT7</td>
</tr>
</tbody>
</table>
### 11.7.343 QTIMER2_TIMER0_SELECT_INPUT DAISY Register (IOMUXC_QTIMER2_TIMER0_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 56Ch offset = 401F_856Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reserved**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: qtimer2, In Pin: timer0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_19_ALT4 — Selecting Pad: GPIO_EMC_19 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_03_ALT1 — Selecting Pad: GPIO_B0_03 for Mode: ALT1</td>
</tr>
</tbody>
</table>
### IOMUXC_QTIMER2_TIMER1_SELECT_INPUT DAISY Register

#### (IOMUXC_QTIMER2_TIMER1_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 570h offset = 401F_8570h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_QTIMER2_TIMER1_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: qtimer2, In Pin: timer1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_20_ALT4 — Selecting Pad: GPIO_EMC_20 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_04_ALT1 — Selecting Pad: GPIO_B0_04 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.345 QTIMER2_TIMER2_SELECT_INPUT DAISY Register (IOMUXC_QTIMER2_TIMER2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 574h offset = 401F_8574h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>R</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>W</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Reset</strong></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>R</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>W</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>Reset</strong></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_QTIMER2_TIMER2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: qtimer2, In Pin: timer2</td>
</tr>
<tr>
<td>0 GPIO_EMC_21_ALT4</td>
<td>Selecting Pad: GPIO_EMC_21 for Mode: ALT4</td>
</tr>
<tr>
<td>1 GPIO_B0_05_ALT1</td>
<td>Selecting Pad: GPIO_B0_05 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.346 QTIMER2_TIMER3_SELECT_INPUT DAISY Register
(IOMUXC_QTIMER2_TIMER3_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 578h offset = 401F_8578h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Reserved

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Reserved

IOMUXC_QTIMER2_TIMER3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: qtimer2, In Pin: timer3</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_22_ALT4 — Selecting Pad: GPIO_EMC_22 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_09_ALT1 — Selecting Pad: GPIO_B1_09 for Mode: ALT1</td>
</tr>
</tbody>
</table>

11.7.347 QTIMER3_TIMER0_SELECT_INPUT DAISY Register
(IOMUXC_QTIMER3_TIMER0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 57Ch offset = 401F_857Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Reserved

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Reserved

DAISY
## IOMUXC_QTIMER3_TIMER0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: qtimer3, In Pin: timer0</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_15_ALT4 — Selecting Pad: GPIO_EMC_15 for Mode: ALT4</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B1_00_ALT1 — Selecting Pad: GPIO_AD_B1_00 for Mode: ALT1</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B0_06_ALT1 — Selecting Pad: GPIO_B0_06 for Mode: ALT1</td>
</tr>
</tbody>
</table>

### 11.7.348 QTIMER3_TIMER1_SELECT_INPUT DAISY Register (IOMUXC_QTIMER3_TIMER1_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 580h offset = 401F_8580h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### IOMUXC_QTIMER3_TIMER1_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: qtimer3, In Pin: timer1</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_16_ALT4 — Selecting Pad: GPIO_EMC_16 for Mode: ALT4</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_AD_B1_01_ALT1 — Selecting Pad: GPIO_AD_B1_01 for Mode: ALT1</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B0_07_ALT1 — Selecting Pad: GPIO_B0_07 for Mode: ALT1</td>
</tr>
</tbody>
</table>
### 11.7.349 QTIMER3_TIMER2_SELECT_INPUT DAISY Register
(\texttt{IOMUXC_QTIMER3_TIMER2_SELECT_INPUT})

**DAISY Register**

Address: 401F\_8000h base + 584h offset = 401F\_8584h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC\_QTIMER3\_TIMER2\_SELECT\_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: qtimer3, In Pin: timer2</td>
</tr>
<tr>
<td></td>
<td>00 \texttt{GPIO_EMC_17_ALT4} — Selecting Pad: GPIO_EMC_17 for Mode: ALT4</td>
</tr>
<tr>
<td></td>
<td>01 \texttt{GPIO_AD_B1_02_ALT1} — Selecting Pad: GPIO_AD_B1_02 for Mode: ALT1</td>
</tr>
<tr>
<td></td>
<td>10 \texttt{GPIO_B0_08_ALT1} — Selecting Pad: GPIO_B0_08 for Mode: ALT1</td>
</tr>
</tbody>
</table>

### 11.7.350 QTIMER3_TIMER3_SELECT_INPUT DAISY Register
(\texttt{IOMUXC_QTIMER3_TIMER3_SELECT_INPUT})

**DAISY Register**

Address: 401F\_8000h base + 588h offset = 401F\_8588h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

870

NXP Semiconductors
IOMUXC_QTIMER3_TIMER3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

DAISY
Selecting Pads Involved in Daisy Chain.
Instance: qtimer3, In Pin: timer3

- 00 GPIO_EMC_18_ALT4 — Selecting Pad: GPIO_EMC_18 for Mode: ALT4
- 01 GPIO_AD_B1_03_ALT1 — Selecting Pad: GPIO_AD_B1_03 for Mode: ALT1
- 10 GPIO_B1_10_ALT1 — Selecting Pad: GPIO_B1_10 for Mode: ALT1

11.7.351 SAI1_MCLK2_SELECT_INPUT DAISY Register
(IOMUXC_SAI1_MCLK2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 58Ch offset = 401F_858Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SAI1_MCLK2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

DAISY
Selecting Pads Involved in Daisy Chain.
Instance: sai1, In Pin:sai_mclk2

- 00 GPIO_SD_B1_03_ALT3 — Selecting Pad: GPIO_SD_B1_03 for Mode: ALT3
- 01 GPIO_AD_B1_09_ALT3 — Selecting Pad: GPIO_AD_B1_09 for Mode: ALT3
- 10 GPIO_B0_13_ALT3 — Selecting Pad: GPIO_B0_13 for Mode: ALT3
# SAI1_RX_BCLK_SELECT_INPUT DAISY Register

**Address:** 401F_8000h base + 590h offset = 401F_8590h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

## IOMUXC_SAI1_RX_BCLK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: sai1, In Pin: sai_rx_bclk

- 00 **GPIO_SD_B1_05_ALT3** — Selecting Pad: GPIO_SD_B1_05 for Mode: ALT3
- 01 **GPIO_AD_B1_11_ALT3** — Selecting Pad: GPIO_AD_B1_11 for Mode: ALT3
- 10 **GPIO_B0_15_ALT3** — Selecting Pad: GPIO_B0_15 for Mode: ALT3

# SAI1_RX_DATA0_SELECT_INPUT DAISY Register

**Address:** 401F_8000h base + 594h offset = 401F_8594h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

## IOMUXC_SAI1_RX_DATA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: sai1, In Pin: sai_rx_data0
### IOMUXC_SAI1_RX_DATA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**DAISY**

Selecting Pads Involved in Daisy Chain.

- Instance: sai1, In Pin: sai_rx_data0

- 00  GPIO_SD_B1_06_ALT3 — Selecting Pad: GPIO_SD_B1_06 for Mode: ALT3
- 01  GPIO_AD_B1_12_ALT3 — Selecting Pad: GPIO_AD_B1_12 for Mode: ALT3
- 10  GPIO_B1_00_ALT3 — Selecting Pad: GPIO_B1_00 for Mode: ALT3

### 11.7.354 SAI1_RX_DATA1_SELECT_INPUT DAISY Register

**IOMUXC_SAI1_RX_DATA1_SELECT_INPUT**

### DAISY Register

Address: 401F_8000h base + 598h offset = 401F_8598h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_SAI1_RX_DATA1_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**DAISY**

Selecting Pads Involved in Daisy Chain.

- Instance: sai1, In Pin: sai_rx_data1

- 0  GPIO_SD_B1_00_ALT3 — Selecting Pad: GPIO_SD_B1_00 for Mode: ALT3
- 1  GPIO_B0_10_ALT3 — Selecting Pad: GPIO_B0_10 for Mode: ALT3
DAISY Register

Address: 401F_8000h base + 59Ch offset = 401F_859Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_SAI1_RX_DATA2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: sai1, In Pin: sai_rx_data2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_01_ALT3 — Selecting Pad: GPIO_SD_B1_01 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_11_ALT3 — Selecting Pad: GPIO_B0_11 for Mode: ALT3</td>
</tr>
</tbody>
</table>
### 11.7.356 SAI1_RX_DATA3_SELECT_INPUT DAISY Register

**IOMUXC_SAI1_RX_DATA3_SELECT_INPUT**

**DAISY Register**

Address: 401F_8000h base + 5A0h offset = 401F_85A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_SAI1_RX_DATA3_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: sai1, In Pin: sai_rx_data3</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_02_ALT3 — Selecting Pad: GPIO_SD_B1_02 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_12_ALT3 — Selecting Pad: GPIO_B0_12 for Mode: ALT3</td>
</tr>
</tbody>
</table>

### 11.7.357 SAI1_RX_SYNC_SELECT_INPUT DAISY Register

**IOMUXC_SAI1_RX_SYNC_SELECT_INPUT**

**DAISY Register**

Address: 401F_8000h base + 5A4h offset = 401F_85A4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_SAI1_RX_SYNC_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: sai1, In Pin: sai_rx_sync</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_SD_B1_04_ALT3 — Selecting Pad: GPIO_SD_B1_04 for Mode: ALT3</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B1_10_ALT3 — Selecting Pad: GPIO_AD_B1_10 for Mode: ALT3</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B0_14_ALT3 — Selecting Pad: GPIO_B0_14 for Mode: ALT3</td>
</tr>
</tbody>
</table>

### 11.7.358 SAI1_TX_BCLK_SELECT_INPUT DAISY Register (IOMUXC_SAI1_TX_BCLK_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 5A8h offset = 401F_85A8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>R/W</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>R/W</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
<th>R/W</th>
<th>DAISY</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>R/W</td>
<td></td>
</tr>
</tbody>
</table>

#### IOMUXC_SAI1_TX_BCLK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: sai1, In Pin: sai_tx_bclk</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_SD_B1_08_ALT3 — Selecting Pad: GPIO_SD_B1_08 for Mode: ALT3</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B1_14_ALT3 — Selecting Pad: GPIO_AD_B1_14 for Mode: ALT3</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B1_02_ALT3 — Selecting Pad: GPIO_B1_02 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.359 SAI1_TX_SYNC_SELECT_INPUT DAISY Register (IOMUXC_SAI1_TX_SYNC_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5ACh offset = 401F_85ACh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_SAI1_TX_SYNC_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: sai1, In Pin: sai_tx_sync

- 00 **GPIO_SD_B1_09_ALT3** — Selecting Pad: GPIO_SD_B1_09 for Mode: ALT3
- 01 **GPIO_AD_B1_15_ALT3** — Selecting Pad: GPIO_AD_B1_15 for Mode: ALT3
- 10 **GPIO_B1_03_ALT3** — Selecting Pad: GPIO_B1_03 for Mode: ALT3
11.7.360  SAI2_MCLK2_SELECT_INPUT DAISY Register (IOMUXC_SAI2_MCLK2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5B0h offset = 401F_85B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>DAISY</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_SAI2_MCLK2_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>DAISY</td>
<td>Instance: sai2, In Pin: sai_mclk2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_07_ALT2 — Selecting Pad: GPIO_EMC_07 for Mode: ALT2</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_10_ALT3 — Selecting Pad: GPIO_AD_B0_10 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.361  SAI2_RX_BCLK_SELECT_INPUT DAISY Register
(IOMUXC_SAI2_RX_BCLK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5B4h offset = 401F_85B4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_SAI2_RX_BCLK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: sai2, In Pin: sai_rx_bclk</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_10_ALT2 — Selecting Pad: GPIO_EMC_10 for Mode: ALT2</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_06_ALT3 — Selecting Pad: GPIO_AD_B0_06 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.362  SAI2_RX_DATA0_SELECT_INPUT DAISY Register  
(IOMUXC_SAI2_RX_DATA0_SELECT_INPUT)

### DAISY Register

Address: 401F_8000h base + 5B8h offset = 401F_85B8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### IOMUXC_SAI2_RX_DATA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1  | This field is reserved.  
Reserved |
| 0     | Selecting Pads Involved in Daisy Chain.  
Instance: sai2, In Pin: sai_rx_data0 |
| DAISY |  
0  GPIO_EMC_08_ALT2 — Selecting Pad: GPIO_EMC_08 for Mode: ALT2  
1  GPIO_AD_B0_08_ALT3 — Selecting Pad: GPIO_AD_B0_08 for Mode: ALT3 |
SAI2_RX_SYNC_SELECT_INPUT DAISY Register
(IOMUXC_SAI2_RX_SYNC_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5BCh offset = 401F_85BCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_SAI2_RX_SYNC_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: sai2, In Pin: sai_rx_sync</td>
</tr>
<tr>
<td>0 GPIO_EM0_09_ALT2</td>
<td>— Selecting Pad: GPIO_EM0_09 for Mode: ALT2</td>
</tr>
<tr>
<td>1 GPIO_AD_B0_07_ALT3</td>
<td>— Selecting Pad: GPIO_AD_B0_07 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.364  SAI2_TX_BCLK_SELECT_INPUT DAISY Register  
(IOMUXC_SAI2_TX_BCLK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5C0h offset = 401F_85C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_SAI2_TX_BCLK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: sai2, In Pin: sai_tx_bclk</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>0</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_EMC_06_ALT2</td>
<td>0</td>
<td>— Selecting Pad: GPIO_EMC_06 for Mode: ALT2</td>
</tr>
<tr>
<td>GPIO_AD_B0_05_ALT3</td>
<td>1</td>
<td>— Selecting Pad: GPIO_AD_B0_05 for Mode: ALT3</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
11.7.365 SAI2_TX_SYNC_SELECT_INPUT DAISY Register (IOMUXC_SAI2_TX_SYNC_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5C4h offset = 401F_85C4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_SAI2_TX_SYNC_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>1</td>
<td>Instance: sai2, In Pin: sai_tx_sync</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EM0_05_ALT2 — Selecting Pad: GPIO_EM0_05 for Mode: ALT2</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_04_ALT3 — Selecting Pad: GPIO_AD_B0_04 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.366  SPDIFF_IN_SELECT_INPUT DAISY Register
(IOMUXC_SPDIFF_IN_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5C8h offset = 401F_85C8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_SPDIFF_IN_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

Selecting Pads Involved in Daisy Chain.
Instance: spdif, In Pin: spdif_in

1  GPIO_EMC_16_ALT3 — Selecting Pad: GPIO_EMC_16 for Mode: ALT3
0  GPIO_AD_B1_03_ALT3 — Selecting Pad: GPIO_AD_B1_03 for Mode: ALT3
11.7.367  **USB_OTG2_OC_SELECT_INPUT DAISY Register**
*(IOMUXC_USB_OTG2_OC_SELECT_INPUT)*

**DAISY Register**

Address: 401F_8000h base + 5CCh offset = 401F_85CCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_USB_OTG2_OC_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: usb, In Pin: otg2_oc</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pad: GPIO_AD_B0_14 for Mode: ALT0</td>
</tr>
<tr>
<td>1</td>
<td>Selecting Pad: GPIO_EMC_40 for Mode: ALT3</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
DAISY Register

Address: \(401F_{8000h} \) base + 5D0h offset = \(401F_{85D0h}\)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

Field | Description |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_03_ALT0 — Selecting Pad: GPIO_AD_B1_03 for Mode: ALT0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B0_03_ALT3 — Selecting Pad: GPIO_AD_B0_03 for Mode: ALT3</td>
</tr>
</tbody>
</table>

DAISY Register

Address: \(401F_{8000h} \) base + 5D4h offset = \(401F_{85D4h}\)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

Field | Description |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_03_ALT0 — Selecting Pad: GPIO_AD_B1_03 for Mode: ALT0</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B0_03_ALT3 — Selecting Pad: GPIO_AD_B0_03 for Mode: ALT3</td>
</tr>
</tbody>
</table>
IOMUXC_USDHC1_CD_B_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: usdhc1, In Pin: cd_b</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_35_ALT6 — Selecting Pad: GPIO_EMC_35 for Mode: ALT6</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B1_02_ALT6 — Selecting Pad: GPIO_AD_B1_02 for Mode: ALT6</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B1_12_ALT6 — Selecting Pad: GPIO_B1_12 for Mode: ALT6</td>
</tr>
</tbody>
</table>

11.7.370 IOMUXC_USDHC1_WP_SELECT_INPUT DAISY Register (IOMUXC_USDHC1_USDHC1_WP_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5D8h offset = 401F_85D8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R/W   | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

IOMUXC_USDHC1_WP_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: usdhc1, In Pin: wp</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_12_ALT3 — Selecting Pad: GPIO_EMC_12 for Mode: ALT3</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_AD_B1_00_ALT6 — Selecting Pad:GPIO_AD_B1_00 for Mode: ALT6</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_36_ALT6 — Selecting Pad: GPIO_EMC_36 for Mode: ALT6</td>
</tr>
<tr>
<td>11</td>
<td>GPIO_B1_13_ALT6 — Selecting Pad: GPIO_B1_13 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.371 USDHC2_CLK_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_CLK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5DCh offset = 401F_85DCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### IOMUXC_USDHC2_CLK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.\n</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.\n</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_04_ALT0 — Selecting Pad: GPIO_SD_B1_04 for Mode: ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_09_ALT6 — Selecting Pad: GPIO_AD_B1_09 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.372  USDHC2_CD_B_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_CD_B_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5E0h offset = 401F_85E0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

- Selecting Pads Involved in Daisy Chain.
  - Instance: usdhc2, In Pin: det
  - GPIO_AD_B1_03_ALT6 — Selecting Pad:GPIO_AD_B1_03 for Mode: ALT6
  - GPIO_EMC_39_ALT6 — Selecting Pad: GPIO_EMC_39 for Mode: ALT6
11.7.373 USDHC2_CMD_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_CMD_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5E4h offset = 401F_85E4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_USDHC2_CMD_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: usdhc2, In Pin: cmd</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_05_ALT0 — Selecting Pad: GPIO_SD_B1_05 for Mode: ALT0</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_08_ALT6 — Selecting Pad: GPIO_AD_B1_08 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.374 USDHC2_DATA0_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_DATA0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5E8h offset = 401F_85E8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_USDHC2_DATA0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: usdhc2, In Pin: data0</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_03_ALT0 — Selecting Pad: GPIO_SD_B1_03 for Mode: ALT0</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_AD_B1_04_ALT6 — Selecting Pad:GPIO_AD_B1_04 for Mode: ALT6</td>
<td></td>
</tr>
</tbody>
</table>
### 11.7.375 USDHC2_DATA1_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_DATA1_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 5ECh offset = 401F_85ECh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_USDHC2_DATA1_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: usdhc2, In Pin: data1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_02_ALT0 — Selecting Pad: GPIO_SD_B1_02 for Mode: ALT0</td>
</tr>
<tr>
<td></td>
<td>GPIO_AD_B1_05_ALT6 — Selecting Pad: GPIO_AD_B1_05 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.376  USDHC2_DATA2_SELECT_INPUT DAISY Register  
(IOMUXC_USDHC2_DATA2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5F0h offset = 401F_85F0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- Reserved

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- DAISY

IOMUXC_USDHC2_DATA2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: usdhc2, In Pin: data2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_SD_B1_01_ALT0 — Selecting Pad: GPIO_SD_B1_01 for Mode: ALT0</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_06_ALT6 — Selecting Pad: GPIO_AD_B1_06 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.377  USDHC2_DATA3_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_DATA3_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5F4h offset = 401F_85F4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_USDHC2_DATA3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0 GPIO_SD_B1_00_ALT0 — Selecting Pad: GPIO_SD_B1_00 for Mode: ALT0</td>
</tr>
<tr>
<td></td>
<td>1 GPIO_AD_B1_07_ALT6 — Selecting Pad: GPIO_AD_B1_07 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.378 USDHC2_DATA4_SELECT_INPUT DAISY Register (IOMUXC_USDHC2_DATA4_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5F8h offset = 401F_85F8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: usdhc2, In Pin: data4</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_08_ALT0</td>
<td>Selecting Pad: GPIO_SD_B1_08 for Mode: ALT0</td>
</tr>
<tr>
<td>1 GPIO_AD_B1_12_ALT6</td>
<td>Selecting Pad: GPIO_AD_B1_12 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.379 USDHC2_DATA5_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_DATA5_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 5FCh offset = 401F_85FCh

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

Reserved

IOMUXC_USDHC2_DATA5_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: usdhc2, In Pin: data5</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_09_ALT0</td>
<td>Selecting Pad: GPIO_SD_B1_09 for Mode: ALT0</td>
</tr>
<tr>
<td>1 GPIO_AD_B1_13_ALT6</td>
<td>Selecting Pad: GPIO_AD_B1_13 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.380  USDHC2_DATA6_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_DATA6_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 600h offset = 401F_8600h

IOMUXC_USDHC2_DATA6_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: usdhc2, In Pin: data6</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_10_ALT0</td>
<td>— Selecting Pad: GPIO_SD_B1_10 for Mode: ALT0</td>
</tr>
<tr>
<td>1 GPIO_AD_B1_14_ALT6</td>
<td>— Selecting Pad: GPIO_AD_B1_14 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.381 USDHC2_DATA7_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_DATA7_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 604h offset = 401F_8604h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_USDHC2_DATA7_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: usdhc2, In Pin: data7</td>
</tr>
<tr>
<td>0 GPIO_SD_B1_11_ALT0 — Selecting Pad: GPIO_SD_B1_11 for Mode: ALT0</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_AD_B1_15_ALT6 — Selecting Pad: GPIO_AD_B1_15 for Mode: ALT6</td>
<td></td>
</tr>
</tbody>
</table>
11.7.382 USDHC2_WP_SELECT_INPUT DAISY Register
(IOMUXC_USDHC2_WP_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 608h offset = 401F_8608h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_USDHC2_WP_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: usdhc2, In Pin: wp</td>
</tr>
</tbody>
</table>

1 GPIO_AD_B1_10_ALT6 — Selecting Pad: GPIO_AD_B1_10 for Mode: ALT6
0 GPIO_EMC_37_ALT6 — Selecting Pad: GPIO_EMC_37 for Mode: ALT6
11.7.383 XBAR1_IN02_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN02_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 60Ch offset = 401F_860Ch

```
R W
31 30 29 28 27 26 25 24  | 23 22 21 20 19 18 17 16
Reserved

R W
15 14 13 12 11 10  9  8  |  7  6  5  4  3  2  1  0
Reserved
```

Reset: 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN02_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: xbar1, In Pin: xbar_in2</td>
</tr>
<tr>
<td>0 GPIO_EMC_00_ALT3</td>
<td>— Selecting Pad: GPIO_EMC_00 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_B1_14_ALT3</td>
<td>— Selecting Pad: GPIO_B1_14 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.384 XBAR1_IN03_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN03_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 610h offset = 401F_8610h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**IOMUXC_XBAR1_IN03_SELECT_INPUT** field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: xbar1, In Pin: xbar_in3</td>
</tr>
<tr>
<td>0 GPIO_EMC_01_ALT3</td>
<td>— Selecting Pad: GPIO_EMC_01 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_B1_15_ALT3</td>
<td>— Selecting Pad: GPIO_B1_15 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.385  XBAR1_IN04_SELECT_INPUT DAISY Register  
(IOMUXC_XBAR1_IN04_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 614h offset = 401F_8614h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### IOMUXC_XBAR1_IN04_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1 | 0  | This field is reserved.  
      | 1  | Reserved  |
| 0    | DAISY      | Selecting Pads Involved in Daisy Chain.  
      |     | Instance: xbar1, In Pin: xbar_in4  
      | 0   | GPIO_EMC_02_ALT3 — Selecting Pad: GPIO_EMC_02 for Mode: ALT3  
      | 1   | GPIO_SD_B0_00_ALT3 — Selecting Pad: GPIO_SD_B0_00 for Mode: ALT3  

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### 11.7.386 \( \text{XBAR1\_IN05\_SELECT\_INPUT} \) DAISY Register (IOMUXC\_XBAR1\_IN05\_SELECT\_INPUT)

**DAISY Register**

Address: \( 401F\_8000h \) base + 618h offset = \( 401F\_8618h \)

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC\_XBAR1\_IN05\_SELECT\_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_03_ALT3 — Selecting Pad: GPIO_EMC_03 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B0_01_ALT3 — Selecting Pad: GPIO_SD_B0_01 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.387  XBAR1_IN06_SELECT_INPUT DAISY Register  
(IOMUXC_XBAR1_IN06_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 61Ch offset = 401F_861Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN06_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: xbar1, In Pin: xbar_in6</td>
</tr>
<tr>
<td>0 GPIO_EMC_04_ALT3</td>
<td>— Selecting Pad: GPIO_EMC_04 for Mode: ALT3</td>
</tr>
<tr>
<td>1 GPIO_SD_B0_02_ALT3</td>
<td>— Selecting Pad: GPIO_SD_B0_02 for Mode: ALT3</td>
</tr>
</tbody>
</table>
11.7.388  XBAR1_IN07_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN07_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 620h offset = 401F_8620h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN07_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

Selecting Pads Involved in Daisy Chain.
Instance: xbar1, In Pin: xbar_in7

0  GPIO_EMC_05_ALT3 — Selecting Pad: GPIO_EMC_05 for Mode: ALT3
1  GPIO_SD_B0_03_ALT3 — Selecting Pad: GPIO_SD_B0_03 for Mode: ALT3
11.7.389  XBAR1_IN08_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN08_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 624h offset = 401F_8624h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN08_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: xbar1, In Pin: xbar_in8</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_06_ALT3 — Selecting Pad: GPIO_EMC_06 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B0_04_ALT3 — Selecting Pad: GPIO_SD_B0_04 for Mode: ALT3</td>
</tr>
</tbody>
</table>
### 11.7.390 XBAR1_IN09_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN09_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 628h offset = 401F_8628h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### IOMUXC_XBAR1_IN09_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>DAISY</td>
<td>Instance: xbar1, In Pin: xbar_in9</td>
</tr>
<tr>
<td></td>
<td>0 GPIO_EMC_07_ALT3 — Selecting Pad: GPIO_EMC_07 for Mode: ALT3</td>
</tr>
<tr>
<td></td>
<td>1 GPIO_SD_B0_05_ALT3 — Selecting Pad: GPIO_SD_B0_05 for Mode: ALT3</td>
</tr>
</tbody>
</table>

#### 11.7.391 XBAR1_IN17_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN17_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 62Ch offset = 401F_862Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### IOMUXC_XBAR1_IN17_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>DAISY</td>
<td>Instance: xbar1, In Pin: xbar_in9</td>
</tr>
<tr>
<td></td>
<td>0 GPIO_EMC_07_ALT3 — Selecting Pad: GPIO_EMC_07 for Mode: ALT3</td>
</tr>
<tr>
<td></td>
<td>1 GPIO_SD_B0_05_ALT3 — Selecting Pad: GPIO_SD_B0_05 for Mode: ALT3</td>
</tr>
</tbody>
</table>
IOMUXC_XBAR1_IN17_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: xbar1, In Pin: xbar_in17</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_08_ALT3 — Selecting Pad: GPIO_EMC_08 for Mode: ALT3</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B0_03_ALT1 — Selecting Pad: GPIO_AD_B0_03 for Mode: ALT1</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_AD_B0_05_ALT6 — Selecting Pad: GPIO_AD_B0_05 for Mode: ALT6</td>
</tr>
<tr>
<td>11</td>
<td>GPIO_B1_03_ALT1 — Selecting Pad: GPIO_B1_03 for Mode: ALT1</td>
</tr>
</tbody>
</table>

11.7.392  XBAR1_IN18_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN18_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 630h offset = 401F_8630h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: xbar1, In Pin: xbar_in18</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_35_ALT1 — Selecting Pad: GPIO_EMC_35 for Mode: ALT1</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B0_06_ALT6 — Selecting Pad: GPIO_AD_B0_06 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.393  XBAR1_IN20_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN20_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 634h offset = 401F_8634h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN20_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: xbar1, In Pin: xbar_in20</td>
</tr>
<tr>
<td>0 GPIO_EMC_15_ALT1 — Selecting Pad: GPIO_EMC_15 for Mode: ALT1</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_AD_B0_08_ALT6 — Selecting Pad: GPIO_AD_B0_08 for Mode: ALT6</td>
<td></td>
</tr>
</tbody>
</table>
11.7.394 XBAR1_IN22_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN22_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 638h offset = 401F_8638h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN22_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: xbar1, In Pin: xbar_in22</td>
</tr>
<tr>
<td>0 GPIO_EMC_36_ALT1</td>
<td>Selecting Pad: GPIO_EMC_36 for Mode: ALT1</td>
</tr>
<tr>
<td>1 GPIO_AD_B0_10_ALT6</td>
<td>Selecting Pad: GPIO_AD_B0_10 for Mode: ALT6</td>
</tr>
</tbody>
</table>
11.7.395 XBAR1_IN23_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN23_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 63Ch offset = 401F_863Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_XBAR1_IN23_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>Instance: xbar1, In Pin: xbar_in23</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_37_ALT1 — Selecting Pad: GPIO_EMC_37 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_11_ALT6 — Selecting Pad: GPIO_AD_B0_11 for Mode: ALT6</td>
</tr>
</tbody>
</table>
### 11.7.396 XBAR1_IN24_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN24_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 640h offset = 401F_8640h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### IOMUXC_XBAR1_IN24_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: xbar1, In Pin: xbar_in24

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPIO_EMC_12_ALT1 — Selecting Pad: GPIO_EMC_12 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_14_ALT1 — Selecting Pad: GPIO_AD_B0_14 for Mode: ALT1</td>
</tr>
</tbody>
</table>
### 11.7.397 XBAR1_IN14_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN14_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 644h offset = 401F_8644h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**IOMUXC_XBAR1_IN14_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: xbar1, In Pin: xbar_in14</td>
</tr>
<tr>
<td></td>
<td>0 GPIO_AD_B0_00_ALT1 — Selecting Pad: GPIO_AD_B0_00 for Mode: ALT1</td>
</tr>
<tr>
<td></td>
<td>1 GPIO_B1_00_ALT1 — Selecting Pad: GPIO_B1_00 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.398  XBAR1_IN15_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN15_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 648h offset = 401F_8648h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

DAISY

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_XBAR1_IN15_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: xbar1, In Pin: xbar_in15</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B0_01_ALT1 — Selecting Pad: GPIO_AD_B0_01 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_01_ALT1 — Selecting Pad: GPIO_B1_01 for Mode: ALT1</td>
</tr>
</tbody>
</table>
### 11.7.399  XBAR1_IN16_SELECT_INPUT DAISY Register

**IOMUXC_XBAR1_IN16_SELECT_INPUT**

#### DAISY Register

Address: 401F_8000h base + 64Ch offset = 401F_864Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### IOMUXC_XBAR1_IN16_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0  DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: xbar1, In Pin: xbar_in16</td>
</tr>
<tr>
<td>0  GPIO_AD_B0_02_ALT1</td>
<td>Selecting Pad: GPIO_AD_B0_02 for Mode: ALT1</td>
</tr>
<tr>
<td>1  GPIO_B1_02_ALT1</td>
<td>Selecting Pad: GPIO_B1_02 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.400 XBAR1_IN25_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN25_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 650h offset = 401F_8650h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IOMUXC_XBAR1_IN25_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: xbar1, In Pin: xbar_in25</td>
</tr>
<tr>
<td>0 GPIO_AD_B0_15_ALT1</td>
<td>Selecting Pad: GPIO_AD_B0_15 for Mode: ALT1</td>
</tr>
<tr>
<td>1 GPIO_EMC_13_ALT1</td>
<td>Selecting Pad: GPIO_EMC_13 for Mode: ALT1</td>
</tr>
</tbody>
</table>
11.7.401 XBAR1_IN19_SELECT_INPUT DAISY Register (IOMUXC_XBAR1_IN19_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 654h offset = 401F_8654h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN19_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

0 DAISY — Selecting Pads Involved in Daisy Chain.
Instance: xbar1, In Pin: xbar_in19

0 GPIO_EMC_14_ALT1 — Selecting Pad: GPIO_EMC_14 for Mode: ALT1
1 GPIO_AD_B0_07_ALT6 — Selecting Pad: GPIO_AD_B0_07 for Mode: ALT6
11.7.402 XBAR1_IN23_SELECT_INPUT DAISY Register
(IOMUXC_XBAR1_IN21_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 658h offset = 401F_8658h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

IOMUXC_XBAR1_IN21_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: xbar1, In Pin: xbar_in21</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_16_ALT1 — Selecting Pad: GPIO_EMC_16 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B0_09_ALT6 — Selecting Pad: GPIO_AD_B0_09 for Mode: ALT6</td>
</tr>
</tbody>
</table>

11.7.403 ENET2_IPG_CLK_RMII_SELECT_INPUT DAISY Register
(IOMUXC_ENET2_IPG_CLK_RMII_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 70Ch offset = 401F_870Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset:

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset:

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_ENET2_IPG_CLK_RMI select_input field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

**DAISY** Selecting Pads Involved in Daisy Chain.

- Instance: enet2, In Pin: ipg_clk_rmi

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPIO_EMC_33_ALT9 — Selecting Pad: GPIO_EMC_33 for Mode: ALT9</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B0_01_ALT9 — Selecting Pad: GPIO_SD_B0_01 for Mode: ALT9</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_B0_15_ALT9 — Selecting Pad: GPIO_B0_15 for Mode: ALT9</td>
</tr>
</tbody>
</table>

---

### 11.7.404 ENET2_IPP_IND_MAC0_MDIO_SELECT_INPUT DAISY Register (IOMUXC_ENET2_IPP_IND_MAC0_MDIO_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 710h offset = 401F_8710h

<table>
<thead>
<tr>
<th>Bit 31-16</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit 15-0</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**DAISY** Selecting Pads Involved in Daisy Chain.

- Instance: enet2, In Pin: ipp_ind_mac0_mdio

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPIO_EMC_39_ALT8 — Selecting Pad: GPIO_EMC_39 for Mode: ALT8</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_01_ALT8 — Selecting Pad: GPIO_B0_01 for Mode: ALT8</td>
</tr>
</tbody>
</table>

---

### IOMUXC_ENET2_IPP_IND_MAC0_MDIO_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

**DAISY** Selecting Pads Involved in Daisy Chain.

- Instance: enet2, In Pin: ipp_ind_mac0_mdio

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPIO_EMC_39_ALT8 — Selecting Pad: GPIO_EMC_39 for Mode: ALT8</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_01_ALT8 — Selecting Pad: GPIO_B0_01 for Mode: ALT8</td>
</tr>
</tbody>
</table>
11.7.405 ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_0 DAISY Register
(IOMUXC_ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_0)

DAISY Register

Address: 401F_8000h base + 714h offset = 401F_8714h

```
+------------------+-
| 31   30   29   28 |
|     27   26   25 |
|     24   23   22 |
|     21   20   19 |
|     18   17   16 |

R  W
Reset

+------------------+-
| 15   14   13   12 |
|     11   10   9   |
|     8    7    6 |
|     5    4    3 |
|     2    1    0 |

R  W
Reset

Field       Description
31–2        This field is reserved.
             Reserved

DAISY        Selecting Pads Involved in Daisy Chain.
             Instance: enet2, In Pin: ipp_ind_mac0_rxdata[0]
00           GPIO_EMC_35_ALT8 — Selecting Pad: GPIO_EMC_35 for Mode: ALT8
01           GPIO_SD_B0_03_ALT8 — Selecting Pad: GPIO_SD_B0_03 for Mode: ALT8
10           GPIO_B1_01_ALT8 — Selecting Pad: GPIO_B1_01 for Mode: ALT8

11.7.406 ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_1 DAISY Register
(IOMUXC_ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_1)

DAISY Register

Address: 401F_8000h base + 718h offset = 401F_8718h

```
+------------------+-
| 31   30   29   28 |
|     27   26   25 |
|     24   23   22 |
|     21   20   19 |
|     18   17   16 |

R  W
Reset

+------------------+-
| 15   14   13   12 |
|     11   10   9   |
|     8    7    6 |
|     5    4    3 |
|     2    1    0 |

R  W
Reset

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### IOMUXC_ENET2IPP_IND_MAC0_RXDATA_SELECT_INPUT_1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–2  | This field is reserved.  
|       | Reserved     |

**DAISY**

Selecting Pads Involved in Daisy Chain.

Instance: enet2, In Pin: ipp_ind_mac0_rxdata[1]

- 00 **GPIO_EMC_36_ALT8** — Selecting Pad: GPIO_EMC_36 for Mode: ALT8
- 01 **GPIO_SD_B0_04_ALT8** — Selecting Pad: GPIO_SD_B0_04 for Mode: ALT8
- 10 **GPIO_B1_02_ALT8** — Selecting Pad: GPIO_B1_02 for Mode: ALT8

### 11.7.407 ENET2IPP_IND_MAC0_RXEN_SELECT_INPUT DAISY Register (IOMUXC_ENET2IPP_IND_MAC0_RXEN_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 71Ch offset = 401F_871Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>W</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reserved**

<table>
<thead>
<tr>
<th>Bit</th>
<th>W</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**DAISY**

<table>
<thead>
<tr>
<th>Bit</th>
<th>W</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reserved**

### IOMUXC_ENET2IPP_IND_MAC0_RXEN_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–2  | This field is reserved.  
|       | Reserved     |

**DAISY**

Selecting Pads Involved in Daisy Chain.

Instance: enet2, In Pin: ipp_ind_mac0_rxen

- 00 **GPIO_EMC_37_ALT8** — Selecting Pad: GPIO_EMC_37 for Mode: ALT8
- 01 **GPIO_SD_B0_05_ALT8** — Selecting Pad: GPIO_SD_B0_05 for Mode: ALT8
- 10 **GPIO_B1_03_ALT8** — Selecting Pad: GPIO_B1_03 for Mode: ALT8
11.7.408  ENET2_IPP_IND_MAC0_RXERR_SELECT_INPUT DAISY Register
(IOMUXC_ENET2_IPP_IND_MAC0_RXERR_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 720h offset = 401F_8720h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Instance: enet2, In Pin: ipp_ind_mac0_rxerr

- 00  GPIO_EMC_34_ALT8 — Selecting Pad: GPIO_EMC_34 for Mode: ALT8
- 01  GPIO_SD_B0_02_ALT8 — Selecting Pad: GPIO_SD_B0_02 for Mode: ALT8
- 10  GPIO_B1_00_ALT8 — Selecting Pad: GPIO_B1_00 for Mode: ALT8
11.7.409  **ENET2_IPP_IND_MAC0_TIMER_SELECT_INPUT_0 DAISY Register**  
(IOMUXC_ENET2_IPP_IND_MAC0_TIMER_SELECT_INPUT_0)

**DAISY Register**

Address: 401F_8000h base + 724h offset = 401F_8724h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_ENET2_IPP_IND_MAC0_TIMER_SELECT_INPUT_0 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>DAISY</td>
<td>Instance: enet2, In Pin: ipp_ind_mac0_timer[0]</td>
</tr>
</tbody>
</table>

<p>| | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPIO_AD_B1_01_ALT8 — Selecting Pad: GPIO_AD_B1_01 for Mode: ALT8</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B0_03_ALT8 — Selecting Pad: GPIO_B0_03 for Mode: ALT8</td>
<td></td>
</tr>
</tbody>
</table>
11.7.410 ENET2_IPP_IND_MAC0_TXCLK_SELECT_INPUT DAISY Register
(IOMUXC_ENET2_IPP_IND_MAC0_TXCLK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 728h offset = 401F_8728h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Field: 31–2
- This field is reserved.
- Reserved

DAISY
- Selecting Pads Involved in Daisy Chain.

Instance: enet2, In Pin: ipp_ind_mac0_txclk
- 00 GPIO_EMC_33_ALT8 — Selecting Pad: GPIO_EMC_33 for Mode: ALT8
- 01 GPIO_SD_B0_01_ALT8 — Selecting Pad: GPIO_SD_B0_01 for Mode: ALT8
- 10 GPIO_B0_15_ALT8 — Selecting Pad: GPIO_B0_15 for Mode: ALT8

11.7.411 FLEXSPI2_IPP_IND_DQS_FA_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPI2_IPP_IND_DQS_FA_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 72Ch offset = 401F_872Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Field: 15–2
- This field is reserved.
- Reserved

DAISY
## IOMUXC_FLEXSPI2_IPP_IND_DQS_FA_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi2, In Pin: ipp_ind_dqs_fa</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_SPI_B1_00_ALT0 — Selecting Pad: GPIO_SPI_B1_00 for Mode: ALT0</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_23_ALT8 — Selecting Pad: GPIO_EMC_23 for Mode: ALT8</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_SPI_B0_09_ALT0 — Selecting Pad: GPIO_SPI_B0_09 for Mode: ALT0</td>
</tr>
</tbody>
</table>

## Chapter 11 IOMUX Controller (IOMUXC)

### 11.7.412 FLEXSPI2_IPP_IND_IO_FA_BIT0_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT0_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 730h offset = 401F_8730h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DAISY</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT0_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi2, In Pin: ipp_ind_io_fa_bit0</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_SPI_B1_04_ALT0 — Selecting Pad: GPIO_SPI_B1_04 for Mode: ALT0</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_26_ALT8 — Selecting Pad: GPIO_EMC_26 for Mode: ALT8</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_SPI_B0_02_ALT0 — Selecting Pad: GPIO_SPI_B0_02 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.413 FLEXSPI2_IPP_IND_IO_FA_BIT1_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 734h offset = 401F_8734h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
<td></td>
</tr>
</tbody>
</table>

IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT1_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexspi2, In Pin: ipp_ind_io_fa_bit1

00  GPIO_SPI_B1_03_ALT0 — Selecting Pad: GPIO_SPI_B1_03 for Mode: ALT0
01  GPIO_EMC_27_ALT8 — Selecting Pad: GPIO_EMC_27 for Mode: ALT8
10  GPIO_SPI_B0_12_ALT0 — Selecting Pad: GPIO_SPI_B0_12 for Mode: ALT0

11.7.414 FLEXSPI2_IPP_IND_IO_FA_BIT2_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 738h offset = 401F_8738h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
<td></td>
</tr>
</tbody>
</table>
# IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexspi2, In Pin: ipp_ind_io_fa_bit2

- 00 GPIO_SPI_B1_02_ALT0 — Selecting Pad: GPIO_SPI_B1_02 for Mode: ALT0
- 01 GPIO_EMC_28_ALT8 — Selecting Pad: GPIO_EMC_28 for Mode: ALT8
- 10 GPIO_SPI_B0_06_ALT0 — Selecting Pad: GPIO_SPI_B0_06 for Mode: ALT0

## 11.7.415 FLEXSPI2_IPP_IND_IO_FA_BIT3_SELECT_INPUT DAISY Register (IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT3_SELECT_INPUT)

### DAISY Register

Address: 401F_8000h base + 73Ch offset = 401F_873Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT3_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
</tbody>
</table>

Instance: flexspi2, In Pin: ipp_ind_io_fa_bit3

- 00 GPIO_SPI_B1_01_ALT0 — Selecting Pad: GPIO_SPI_B1_01 for Mode: ALT0
- 01 GPIO_EMC_29_ALT8 — Selecting Pad: GPIO_EMC_29 for Mode: ALT8
- 10 GPIO_SPI_B0_10_ALT0 — Selecting Pad: GPIO_SPI_B0_10 for Mode: ALT0
11.7.416 FLEXSPI2_IPP_IND_IO_FB_BIT0_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT0_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 740h offset = 401F_8740h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

RESET

IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT0_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi2, In Pin: ipp_ind_io_fb_bit0</td>
</tr>
<tr>
<td>0 GPIO_EMC_13_ALT8</td>
<td>Selecting Pad: GPIO_EMC_13 for Mode: ALT8</td>
</tr>
<tr>
<td>1 GPIO_SPI_B0_11_ALT0</td>
<td>Selecting Pad: GPIO_SPI_B0_11 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.417  FLEXSPI2_IPP_IND_IO_FB_BIT1_SELECT_INPUT DAISY Register
(IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 744h offset = 401F_8744h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT1_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi2, In Pin: ipp_ind_io_fb_bit1</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_14_ALT8 — Selecting Pad: GPIO_EMC_14 for Mode: ALT8</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SPI_B0_07_ALT0 — Selecting Pad: GPIO_SPI_B0_07 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.418  FLEXSPI2_IPP_IND_IO_FB_BIT2_SELECT_INPUT DAISY Register  
(IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 748h offset = 401F_8748h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1  | This field is reserved.  
|       | Reserved     |
| 0     | Selecting Pads Involved in Daisy Chain.  
| DAISY | Instance: flexspi2, In Pin: ipp_ind_io_fb_bit2  
|       | GPIO_EMC_15_ALT8 — Selecting Pad: GPIO_EMC_15 for Mode: ALT8  
|       | GPIO_SPI_B0_03_ALT0 — Selecting Pad: GPIO_SPI_B0_03 for Mode: ALT0 |
### FLEXSPI2_IPP_IND_IO_FB_BIT3_SELECT_INPUT DAISY Register

(IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT3_SELECT_INPUT)

**Register**

**Address:** 401F_8000h base + 74Ch offset = 401F_874Ch

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: flexspi2, In Pin: ipp_ind_io_fb_bit3</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_16_ALT8 — Selecting Pad: GPIO_EMC_16 for Mode: ALT8</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SPI_B0_04_ALT0 — Selecting Pad: GPIO_SPI_B0_04 for Mode: ALT0</td>
</tr>
</tbody>
</table>
### FLEXSPI2_IPP_IND_SCK_FA_SELECT_INPUT DAISY Register

(IOMUXC_FLEXSPI2_IPP_IND_SCK_FA_SELECT_INPUT)

#### DAISY Register

Address: 401F_8000h base + 750h offset = 401F_8750h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/RW</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/RW</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

#### IOMUXC_FLEXSPI2_IPP_IND_SCK_FA_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| DAISY     | Selecting Pads Involved in Daisy Chain.  

Instance: flexspi2, In Pin: ipp_ind_sck_fa

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>GPIO_SPI_B1_05_ALT0 — Selecting Pad: GPIO_SPI_B1_05 for Mode: ALT0</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_EMC_25_ALT8 — Selecting Pad: GPIO_EMC_25 for Mode: ALT8</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_SPI_B0_08_ALT0 — Selecting Pad: GPIO_SPI_B0_08 for Mode: ALT0</td>
</tr>
</tbody>
</table>
11.7.421  FLEXSPI2_IPP_IND_SCK_FB_SELECT_INPUT DAISY Register  
(IOMUXC_FLEXSPI2_IPP_IND_SCK_FB_SELECT_INPUT)  

DAISY Register  
Address: 401F_8000h base + 754h offset = 401F_8754h  

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved  

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved  

IOMUXC_FLEXSPI2_IPP_IND_SCK_FB_SELECT_INPUT field descriptions  

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–1  | This field is reserved.  

Reserved  

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 0 DAISY | Selecting Pads Involved in Daisy Chain.  

Instance: flexspi2, In Pin: ipp_ind_sck_fb  

| 0 | GPIO_EMC_12_ALT8 — Selecting Pad: GPIO_EMC_12 for Mode: ALT8  
| 1 | GPIO_SPI_B0_01_ALT0 — Selecting Pad: GPIO_SPI_B0_01 for Mode: ALT0  

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019  
NXP Semiconductors  
933
11.7.422  GPT1_IPP_IND_CAPIN1_SELECT_INPUT DAISY Register  
(IOMUXC_GPT1_IPP_IND_CAPIN1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 758h offset = 401F_8758h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
</tr>
<tr>
<td></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: gpt1, In Pin: ipp_ind_capin1</td>
</tr>
</tbody>
</table>

0  GPIO_EMC_24_ALT4 — Selecting Pad: GPIO_EMC_24 for Mode: ALT4
1  GPIO_B1_05_ALT8 — Selecting Pad: GPIO_B1_05 for Mode: ALT8
11.7.423 GPT1_IPP_IND_CAPIN2_SELECT_INPUT DAISY Register (IOMUXC_GPT1_IPP_IND_CAPIN2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 75Ch offset = 401F_875Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

Reset

IOMUXC_GPT1_IPP_IND_CAPIN2_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: gpt1, In Pin: ipp_ind_capin2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_23_ALT4 — Selecting Pad: GPIO_EMC_23 for Mode: ALT4</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_06_ALT8 — Selecting Pad: GPIO_B1_06 for Mode: ALT8</td>
</tr>
</tbody>
</table>
11.7.424  GPT1_IPP_IND_CLKIN_SELECT_INPUT DAISY Register 
(IOMUXC_GPT1_IPP_IND_CLKIN_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 760h offset = 401F_8760h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

IOMUXC_GPT1_IPP_IND_CLKIN_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: gpt1, In Pin: ipp_ind_clkin</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_AD_B0_13_ALT1 — Selecting Pad: GPIO_AD_B0_13 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_B1_04_ALT8 — Selecting Pad: GPIO_B1_04 for Mode: ALT8</td>
</tr>
</tbody>
</table>
11.7.425  GPT2_IPP_IND_CAPIN1_SELECT_INPUT DAISY Register
(IOMUXC_GPT2_IPP_IND_CAPIN1_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 764h offset = 401F_8764h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

Reserved

IOMUXC_GPT2_IPP_IND_CAPIN1_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1  -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: gpt2, In Pin: ipp_ind_capin1</td>
</tr>
</tbody>
</table>

0  GPIO_EMC_41_ALT1 — Selecting Pad: GPIO_EMC_41 for Mode: ALT1
1  GPIO_AD_B1_03_ALT8 — Selecting Pad: GPIO_AD_B1_03 for Mode: ALT8
11.7.426  GPT2_IPP_IND_CAPIN2_SELECT_INPUT DAISY Register
(IOMUXC_GPT2_IPP_IND_CAPIN2_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 768h offset = 401F_8768h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_GPT2_IPP_IND_CAPIN2_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: gpt2, In Pin: ipp_ind_capin2</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_40_ALT1 — Selecting Pad: GPIO_EMC_40 for Mode: ALT1</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_04_ALT8 — Selecting Pad: GPIO_AD_B1_04 for Mode: ALT8</td>
</tr>
</tbody>
</table>
11.7.427  GPT2_IPP_IND_CLKIN_SELECT_INPUT DAISY Register (IOMUXC_GPT2_IPP_IND_CLKIN_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 76Ch offset = 401F_876Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>DAISY</td>
</tr>
</tbody>
</table>

**IOMUXC_GPT2_IPP_IND_CLKIN_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain. Instance: gpt2, In Pin: ipp_ind_clkin</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPIO_AD_B0_09_ALT7 — Selecting Pad: GPIO_AD_B0_09 for Mode: ALT7</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_AD_B1_02_ALT8 — Selecting Pad: GPIO_AD_B1_02 for Mode: ALT8</td>
</tr>
</tbody>
</table>
### 11.7.428 SAI3_IPG_CLK_SAI_MCLK_SELECT_INPUT_2 DAISY Register

**(IOMUXC_SAI3_IPG_CLK_SAI_MCLK_SELECT_INPUT_2)**

**DAISY Register**

Address: 401F_8000h base + 770h offset = 401F_8770h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAISY</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**IOMUXC_SAI3_IPG_CLK_SAI_MCLK_SELECT_INPUT_2 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31-1   | This field is reserved.  
Reserved                                    |
| 0      | DAISY  
Selecting Pads Involved in Daisy Chain.  
|   0   | GPIO_EMC_37_ALT3 — Selecting Pad: GPIO_EMC_37 for Mode: ALT3 |
|   1   | GPIO_SD_B1_04_ALT8 — Selecting Pad: GPIO_SD_B1_04 for Mode: ALT8 |
11.7.429 SAI3_IPP_IND_SAI_RXBCLK_SELECT_INPUT DAISY Register
(IOMUXC_SAI3_IPP_IND_SAI_RXBCLK_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 774h offset = 401F_8774h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

IOMUXC_SAI3_IPP_IND_SAI_RXBCLK_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: sai3, In Pin: ipp_ind_sai_rxclk</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_35_ALT3 — Selecting Pad: GPIO_EMC_35 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B1_06_ALT8 — Selecting Pad: GPIO_SD_B1_06 for Mode: ALT8</td>
</tr>
</tbody>
</table>
11.7.430  **SAI3_IPP_IND_SAI_RXDATA_SELECT_INPUT_0 DAISY Register**

**IOMUXC_SAII3_IPP_IND_SAI_RXDATA_SELECT_INPUT_0**

**DAISY Register**

Address: 401F_8000h base + 778h offset = 401F_8778h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reserved**

**IOMUXC_SAII3_IPP_IND_SAI_RXDATA_SELECT_INPUT_0 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0 DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td>Instance: sai3, In Pin: ipp_ind_sai_rxdata[0]</td>
<td></td>
</tr>
<tr>
<td>0 GPIO_EMC_33_ALT3 — Selecting Pad: GPIO_EMC_33 for Mode: ALT3</td>
<td></td>
</tr>
<tr>
<td>1 GPIO_SD_B1_00_ALT8 — Selecting Pad: GPIO_SD_B1_00 for Mode: ALT8</td>
<td></td>
</tr>
</tbody>
</table>
11.7.431 SAI3_IPP_IND_SAI_RXSYNC_SELECT_INPUT DAISY Register
(IOMUXC_SAI3_IPP_IND_SAI_RXSYNC_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 77Ch offset = 401F_877Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SAI3_IPP_IND_SAI_RXSYNC_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: sai3, In Pin: ipp_ind_sai_rxsync</td>
</tr>
<tr>
<td>DAISY</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_34_ALT3 — Selecting Pad: GPIO_EMC_34 for Mode: ALT3</td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B1_05_ALT8 — Selecting Pad: GPIO_SD_B1_05 for Mode: ALT8</td>
</tr>
</tbody>
</table>
### 11.7.432 SAI3_IPP_IND_SAI_TXBCLK_SELECT_INPUT DAISY Register
(IOMUXC_SAI3_IPP_IND_SAI_TXBCLK_SELECT_INPUT)

**DAISY Register**

Address: 401F_8000h base + 780h offset = 401F_8780h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Reset*

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SAI3_IPP_IND_SAI_TXBCLK_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

0 DAISY

- Selecting Pads Involved in Daisy Chain.
- Instance: sai3, In Pin: ipp_ind_sai_txbclk

0 GPIO_EMC_38_ALT3 — Selecting Pad: GPIO_EMC_38 for Mode: ALT3
1 GPIO_SD_B1_03_ALT8 — Selecting Pad: GPIO_SD_B1_03 for Mode: ALT8
11.7.433  SAI3_IPP_IND_SAI_TXSYNC_SELECT_INPUT DAISY Register
(IOMUXC_SAI3_IPP_IND_SAI_TXSYNC_SELECT_INPUT)

DAISY Register

Address: 401F_8000h base + 784h offset = 401F_8784h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>DAISY</td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Instance: sai3, In Pin: ipp_ind_sai_txsync</td>
</tr>
<tr>
<td>0</td>
<td>GPIO_EMC_39_ALT3 — Selecting Pad: GPIO_EMC_39 for Mode: ALT3</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>GPIO_SD_B1_02_ALT8 — Selecting Pad: GPIO_SD_B1_02 for Mode: ALT8</td>
<td></td>
</tr>
</tbody>
</table>
### IOMUXC Memory Map/Register Definition

**11.7.434 SEMC_I_IPP_IND_DQS4_SELECT_INPUT DAISY Register**

**(IOMUXC_SEMC_I_IPP_IND_DQS4_SELECT_INPUT)**

**DAISY Register**

Address: 401F_8000h base + 788h offset = 401F_8788h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reserved**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**IOMUXC_SEMC_I_IPP_IND_DQS4_SELECT_INPUT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–2  | This field is reserved.
|       | Reserved    |
| DAISY | Selecting Pads Involved in Daisy Chain. |
|       | Instance: semc, In Pin: i_ipp_ind_dqs4 |
| 00    | GPIO_SD_B0_00_ALT9 — Selecting Pad: GPIO_SD_B0_00 for Mode: ALT9 |
| 01    | GPIO_EMC_39_ALT9 — Selecting Pad: GPIO_EMC_39 for Mode: ALT9 |
| 10    | GPIO_AD_B0_09_ALT9 — Selecting Pad: GPIO_AD_B0_09 for Mode: ALT9 |
| 11    | GPIO_B1_13_ALT8 — Selecting Pad: GPIO_B1_13 for Mode: ALT8 |

**11.7.435 CANFD_IPP_IND_CANRX_SELECT_INPUT DAISY Register**

**(IOMUXC_CANFD_IPP_IND_CANRX_SELECT_INPUT)**

**DAISY Register**

Address: 401F_8000h base + 78Ch offset = 401F_878Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reserved**

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
### IOMUXC_CANFD_IPP_IND_CANRX_SELECT_INPUT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td><strong>DAISY</strong></td>
<td>Selecting Pads Involved in Daisy Chain.</td>
</tr>
<tr>
<td></td>
<td>Instance: flexcan3/canfd, In Pin: ipp_ind_canrx</td>
</tr>
<tr>
<td>00</td>
<td>GPIO_EMC_37_ALT9 — Selecting Pad: GPIO_EMC_37 for Mode: ALT9</td>
</tr>
<tr>
<td>01</td>
<td>GPIO_AD_B0_15_ALT8 — Selecting Pad: GPIO_AD_B0_15 for Mode: ALT8</td>
</tr>
<tr>
<td>10</td>
<td>GPIO_AD_B0_11_ALT8 — Selecting Pad: GPIO_AD_B0_11 for Mode: ALT8</td>
</tr>
</tbody>
</table>
Chapter 12
General Purpose Input/Output (GPIO)

12.1 Chip-specific GPIO information

Table 12-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

High-speed GPIOs exist in this device.
- GPIO1-5 are standard-speed GPIOs that run off the IPG_CLK_ROOT, while GPIO6-9 are high-speed GPIOs that run at the AHB_CLK_ROOT frequency. See the table "System Clocks, Gating, and Override" in CCM chapter.
- Regular GPIO and high speed GPIO are paired (GPIO1 and GPIO6 share the same pins, GPIO2 and GPIO7 share, etc). The IOMUXC_GPR_GPR26-29 registers are used to determine if the regular or high-speed GPIO module is used for the GPIO pins on a given port.

12.2 Overview

The GPIO general-purpose input/output peripheral provides dedicated general-purpose pins that can be configured as either inputs or outputs.
When configured as an output, it is possible to write to an internal register to control the state driven on the output pin. When configured as an input, it is possible to detect the state of the input by reading the state of an internal register. In addition, the GPIO peripheral can produce CORE interrupts.

The GPIO is one of the blocks controlling the IOMUX of the chip.

**Figure 12-1. Chip IOMUX Scheme**

The GPIO functionality is provided through eight registers, an edge-detect circuit, and interrupt generation logic.
The eight registers are:

- Data register (GPIO_DR)
- GPIO direction register (GPIO_GDIR)
- Pad sample register (GPIO_PSR)
- Interrupt control registers (GPIO_ICR1, GPIO_ICR2)
- Edge select register (GPIO_EDGE_SEL)
- Interrupt mask register (GPIO_IMR)
- Interrupt status register (GPIO_ISR)

These registers are described in detail in the Register section.

Each GPIO input has a dedicated edge-detect circuit which can be configured through software to detect rising edges, falling edges, logic low-levels or logic high-levels on the input signals. The outputs of the edge detect circuits are optionally masked by setting the corresponding bit in the interrupt mask register (GPIO_IMR). These qualified outputs are OR'ed together to generate two one-bit interrupt lines:

- Combined interrupt indication for GPIOx signals 0 - 15
- Combined interrupt indication for GPIOx signals 16 - 31

In addition, GPIO1 provides visibility to each of its 8 low order interrupt sources (i.e. GPIO1 interrupt n, for n = 0 – 7). However, individual interrupt indications from other GPIOx are not available.

The GPIO edge detection is described further in Interrupt Control Unit.

The GPIO's overall functionality is described further in GPIO Functional Description.

### 12.2.1 Block Diagram

The GPIO subsystem contains multiple GPIO blocks, which can generate and control up to 32 signals for general purpose.

A block diagram of the GPIO is shown in Figure 12-2
12.2.2 Features

The GPIO includes the following features:

- General purpose input/output logic capabilities:
  - Drives specific data to output using the data register (GPIO_DR)
  - Controls the direction of the signal using the GPIO direction register (GPIO_GDIR)
  - Enables the core to sample the status of the corresponding inputs by reading the pad sample register (GPIO_PSR).
- GPIO interrupt capabilities:
  - Supports up to 32 interrupts
  - Identifies interrupt edges
  - Generates three active-high interrupts to the SoC interrupt controller
12.3 Clocks

The table found here describes the clock sources for GPIO.

Please see the CCM for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk_s</td>
<td>Peripheral access clock</td>
</tr>
</tbody>
</table>

12.4 GPIO Functional Description

This section provides a complete functional description of the block.

12.4.1 GPIO Function

A GPIO signal can operate as a general-purpose input/output when the IOMUX is set to GPIO mode. Each GPIO signal may be independently configured as either an input or an output using the GPIO direction register (GPIO_GDIR).

When configured as an output (GPIO_GDIR bit = 1), the value in the data bit in the GPIO data register (GPIO_DR) is driven on the corresponding GPIO line. When a signal is configured as an input (GPIO_GDIR bit = 0), the state of the input can be read from the corresponding GPIO_PSR bit.
12.4.2 GPIO pad structure

12.4.2.1 Input Driver

Input driver characteristics

- Selectable Schmitt trigger or CMOS input mode
- Keeper structure with buffer at the input receiver output to Core
- Receiver is tri-stated when I/O supply (OVDD) is powered down. (Keeper at receiver output keeps its previous state).

12.4.2.1.1 Schmitt trigger

The anti-jamming functionality of the Schmitt trigger is illustrated below.
12.4.2.1.2 Input keeper

A simple latch to hold the input value when OVDD is powered down, or the first inverter is tri-stated. Input buffer’s keeper is always enabled for all the pads.

12.4.2.2 Output Driver

Output driver characteristics

- Selectable CMOS or open-drain output type
• Selectable pull-keeper enable signal to enable/disable the pull-up/down and output keeper
• Selectable pull-up resistors of 22K, 47K, 100K and a pull-down resistor of 100KOhm. Unsilicided P+ poly resistor is used to limit resistance variation to within +/- 20%.
• Pull-up, pull-down, and pad keeper are disabled in output mode.
• Seven drive strengths in each operating mode
• Additional 2-bit slew rate control to select between 50, 100, and 200 MHz IO cell operation range with reduced switching noise

![Output Driver Functional Diagram](image)

**Figure 12-6. Output Driver Functional Diagram**

### 12.4.2.2.1 Drive strength

Drive strength selection can be used to make the impedance matched and get better signal integrity.

### 12.4.2.2.2 Output keeper

A simple latch to hold the input value.
12.4.2.2.3 PU / PD / Keeper Logic

When Keeper is enabled, the pull-up and pull-down are disabled, and the output value of the pad depends on the Keeper. The output keeper is powered by OVDD. When the core VDD is powered down or the first inverter is tri-stated, the pad’s state can be kept. Keeper and Pull can’t be enabled together.

12.4.2.2.4 Open drain

Open drain is a circuit technique which allows multiple devices to communication over a single wire bi-directionally. Open drain drivers usually operate with an external or internal pull-up resistor that holds the signal line high until a device sinks enough current to pull the line low, usually used for a bus with multiple devices.

Figure 12-7. Keeper functional diagram
If internal pull-up resistor (Rpu) is used, output level will depend on OVDD1

If external Rpu is used, output level will depend on OVDD2

Figure 12-8. Output buffer in open drain mode

12.4.2.3 Operating Frequency

Table 12-3. IO Operating Frequency

<table>
<thead>
<tr>
<th>DSE Setting</th>
<th>SRE / SPEED Setting</th>
<th>R_fixture (Ohm)</th>
<th>R_fixture (Ohm)</th>
<th>Operating Frequency (MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>OVDD = 1.8V nominal</td>
<td>OVDD = 3.3V nominal</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>400</td>
<td>220</td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td>50</td>
<td></td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>100</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>101</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>110</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>111</td>
<td></td>
<td>150</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>200</td>
<td>110</td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>100</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>101</td>
<td></td>
<td>50</td>
<td></td>
</tr>
<tr>
<td></td>
<td>110</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td></td>
<td>111</td>
<td></td>
<td>100</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>132</td>
<td>73</td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td>100</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 12-3. IO Operating Frequency (continued)

<table>
<thead>
<tr>
<th>DSE Setting</th>
<th>SRE / SPEED Setting</th>
<th>R_fixture (Ohm) OVDD = 1.8V nominal</th>
<th>R_fixture (Ohm) OVDD = 3.3V nominal</th>
<th>Operating Frequency (MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>100</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>101</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>110</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>111</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>100</td>
<td>0</td>
<td>104</td>
<td>58</td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>100</td>
<td></td>
<td></td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>101</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>110</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>111</td>
<td></td>
<td></td>
<td>150</td>
</tr>
<tr>
<td>101</td>
<td>0</td>
<td>83</td>
<td>46</td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>100</td>
<td></td>
<td></td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>101</td>
<td></td>
<td></td>
<td>100 (OVDD=1.8V nom)</td>
</tr>
<tr>
<td></td>
<td>110</td>
<td></td>
<td></td>
<td>150 (OVDD=3.3V nom)</td>
</tr>
<tr>
<td></td>
<td>111</td>
<td></td>
<td></td>
<td>100 (OVDD=1.8V nom)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>150 (OVDD=3.3V nom)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>150 (OVDD=1.8V nom)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>200 (OVDD=3.3V nom)</td>
</tr>
<tr>
<td>110</td>
<td>0</td>
<td>70</td>
<td>38</td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>100</td>
<td></td>
<td></td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>101</td>
<td></td>
<td></td>
<td>150</td>
</tr>
<tr>
<td></td>
<td>110</td>
<td></td>
<td></td>
<td>150</td>
</tr>
<tr>
<td></td>
<td>111</td>
<td></td>
<td></td>
<td>200</td>
</tr>
<tr>
<td>111</td>
<td>0</td>
<td>55</td>
<td>32</td>
<td>50</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>10</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td></td>
<td></td>
<td>100</td>
</tr>
<tr>
<td></td>
<td>100</td>
<td></td>
<td></td>
<td>50</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 12.4.3 GPIO Programming

#### 12.4.3.1 GPIO Read Mode

The programming sequence for reading input signals should be as follows:

1. Configure IOMUX to select GPIO mode (Via IOMUX Controller (IOMUXC)).
2. Configure GPIO direction register to input (GPIO_GDIR[GDIR] set to 0b).
3. Read value from data register/pad status register.

A pseudocode description to read [input3:input0] values is as follows:

```c
// SET INPUTS TO GPIO MODE.
write sw_mux_ctl_<input0>_<input1>_<input2>_<input3>, 32'h00000000
// SET GDIR TO INPUT.
write GDIR[31:4,input3_bit, input2_bit, input1_bit, input0_bit,] 32'hxxxxxxxxx0
// READ INPUT VALUE FROM DR.
read DR
// READ INPUT VALUE FROM PSR.
read PSR
```

**NOTE**

While the GPIO direction is set to input (GPIO_GDIR = 0), a read access to GPIO_DR does not return GPIO_DR data. Instead, it returns the GPIO_PSR data, which is the corresponding input signal value.

#### 12.4.3.2 GPIO Write Mode

The programming sequence for driving output signals should be as follows:

1. Configure IOMUX to select GPIO mode (Via IOMUXC), also enable SION if need to read loopback pad value through PSR
2. Configure GPIO direction register to output (GPIO_GDIR[GDIR] set to 1b).
3. Write value to data register (GPIO_DR).
A pseudocode description to drive 4'b0101 on [output3:output0] is as follows:

```c
// SET PADS TO GPIO MODE VIA IOMUX.
write sw_mux_ctl_pad_<output[0-3]>.mux_mode, <GPIO_MUX_MODE>
// Enable loopback so we can capture pad value into PSR in output mode
write sw_mux_ctl_pad_<output[0-3]>.sion, 1
// SET GDIR=1 TO OUTPUT BITS.
write GDIR[31:4,output3_bit,output2_bit, output1_bit, output0_bit], 32'hxxxxxxxF
// WRITE OUTPUT VALUE=4'b0101 TO DR.
write DR, 32'hxxxxxxx5
// READ OUTPUT VALUE FROM PSR ONLY.
read_cmp PSR, 32'hxxxxxxx5
```

### 12.4.4 Interrupt Control Unit

In addition to the general-purpose input/output function, the edge-detect logic in the GPIO peripheral reflects whether a transition has occurred on a given GPIO signal that is configured as an input (GDIR bit = 0). The interrupt control registers (GPIO_ICR1 and GPIO_ICR2) may be used to independently configure the interrupt condition of each input signal (low-to-high transition, high-to-low transition, low, or high). For information about GPIO_ICR1 and GPIO_ICR2 settings, see the Register section.

The interrupt control unit is built of 32 interrupt control subunits, where each subunit handles a single interrupt line.

### 12.5 GPIO Register Descriptions

There are eight 32-bit GPIO registers. All registers are accessible from the IP interface. Only 32-bit access is supported.

The GPIO memory map is shown in the following table.

#### 12.5.1 GPIO Memory map

GPIO\textsubscript{n} base address: 401B\_8000h + (n-1)×4000h, where \(n\) is from 1 to 4.

GPIO\textsubscript{5} base address: 400C\_0000h.

GPIO\textsubscript{n} base address: 4200\_0000h + (n-6)×4000h, where \(n\) is from 6 to 9.
## 12.5.2 GPIO data register (DR)

### 12.5.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO data register (DR)</td>
<td>0h</td>
</tr>
</tbody>
</table>

### 12.5.2.2 Function

The 32-bit GPIO_DR register stores data that is ready to be driven to the output lines. If the IOMUXC is in GPIO mode and a given GPIO direction bit is set, then the corresponding DR bit is driven to the output. If a given GPIO direction bit is cleared, then a read of GPIO_DR reflects the value of the corresponding signal. Two wait states are required in read access for synchronization.

The results of a read of a DR bit depends on the IOMUXC input mode settings and the corresponding GDIR bit as follows:

- If GDIR[n] is set and IOMUXC input mode is GPIO, then reading DR[n] returns the contents of DR[n].
- If GDIR[n] is cleared and IOMUXC input mode is GPIO, then reading DR[n] returns the corresponding input signal's value.
• If GDIR\[n\] is set and IOMUXC input mode is not GPIO, then reading DR\[n\] returns the contents of DR\[n\].
• If GDIR\[n\] is cleared and IOMUXC input mode is not GPIO, then reading DR\[n\] always returns zero.

### 12.5.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DR</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DR</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 12.5.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>DR</td>
</tr>
</tbody>
</table>
| DR    | Data bits. This register defines the value of the GPIO output when the signal is configured as an output (GDIR[n]=1). Writes to this register are stored in a register. Reading GPIO_DR returns the value stored in the register if the signal is configured as an output (GDIR[n]=1), or the input signal's value if configured as an input (GDIR[n]=0).  
**NOTE:** The I/O multiplexer must be configured to GPIO mode for the GPIO_DR value to connect with the signal. Reading the data register with the input path disabled always returns a zero value. |

### 12.5.3 GPIO direction register (GDIR)

#### 12.5.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GDIR</td>
<td>4h</td>
</tr>
</tbody>
</table>
12.5.3.2  Function

GPIO_GDIR functions as direction control when the IOMUXC is in GPIO mode. Each bit specifies the direction of a one-bit signal. The mapping of each DIR bit to a corresponding SoC signal is determined by the SoC's pin assignment and the IOMUX table. For more details consult the IOMUXC chapter.

12.5.3.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

12.5.3.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>GDIR</td>
</tr>
<tr>
<td>GDIR</td>
<td>GPIO direction bits. Bit n of this register defines the direction of the GPIO[n] signal.</td>
</tr>
</tbody>
</table>

NOTE: GPIO_GDIR affects only the direction of the I/O signal when the corresponding bit in the I/O MUX is configured for GPIO.

0b - GPIO is configured as input.
1b - GPIO is configured as output.

12.5.4  GPIO pad status register (PSR)

12.5.4.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PSR</td>
<td>8h</td>
</tr>
</tbody>
</table>
12.5.4.2 Function

GPIO_PSR is a read-only register. Each bit stores the value of the corresponding input signal (as configured in the IOMUX). This register is clocked with the ipg_clk_s clock, meaning that the input signal is sampled only when accessing this location. Two wait states are required any time this register is accessed for synchronization.

12.5.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

12.5.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>PSR</td>
</tr>
<tr>
<td>PSR</td>
<td>GPIO pad status bits (status bits). Reading GPIO_PSR returns the state of the corresponding input signal. Settings:</td>
</tr>
</tbody>
</table>

**NOTE:** The IOMUXC must be configured to GPIO mode for GPIO_PSR to reflect the state of the corresponding signal.

12.5.5 GPIO interrupt configuration register1 (ICR1)
12.5.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ICR1</td>
<td>Ch</td>
</tr>
</tbody>
</table>

12.5.5.2 Function

GPIO_ICR1 contains 16 two-bit fields, where each field specifies the interrupt configuration for a different input signal.

12.5.5.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td></td>
<td>ICR15</td>
<td>ICR14</td>
<td>ICR13</td>
<td>ICR12</td>
<td>ICR11</td>
<td>ICR10</td>
<td>ICR9</td>
<td>ICR8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>Bits</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td></td>
<td>ICR7</td>
<td>ICR6</td>
<td>ICR5</td>
<td>ICR4</td>
<td>ICR3</td>
<td>ICR2</td>
<td>ICR1</td>
<td>ICR0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>
```

12.5.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 15.</td>
</tr>
<tr>
<td>ICR15</td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>29-28</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 14.</td>
</tr>
<tr>
<td>ICR14</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>27-26</th>
<th>ICR13</th>
</tr>
</thead>
<tbody>
<tr>
<td>27-26</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 13.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>25-24</th>
<th>ICR12</th>
</tr>
</thead>
<tbody>
<tr>
<td>25-24</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 12.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>23-22</th>
<th>ICR11</th>
</tr>
</thead>
<tbody>
<tr>
<td>23-22</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 11.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>21-20</th>
<th>ICR10</th>
</tr>
</thead>
<tbody>
<tr>
<td>21-20</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 10.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>19-18</th>
<th>ICR9</th>
</tr>
</thead>
<tbody>
<tr>
<td>19-18</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 9.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field Settings

Bits ICRn[1:0] determine the interrupt condition for signal n as follows:

- **00b**: Interrupt n is low-level sensitive.
- **01b**: Interrupt n is high-level sensitive.
- **10b**: Interrupt n is rising-edge sensitive.
- **11b**: Interrupt n is falling-edge sensitive.

### 17-16 ICR8

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>17-16</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 8.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>- <strong>00b</strong>: Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>01b</strong>: Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>10b</strong>: Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>11b</strong>: Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

### 15-14 ICR7

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-14</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 7.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>- <strong>00b</strong>: Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>01b</strong>: Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>10b</strong>: Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>11b</strong>: Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

### 13-12 ICR6

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>13-12</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 6.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>- <strong>00b</strong>: Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>01b</strong>: Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>10b</strong>: Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>11b</strong>: Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

### 11-10 ICR5

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>11-10</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 5.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>- <strong>00b</strong>: Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>01b</strong>: Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>10b</strong>: Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>- <strong>11b</strong>: Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>

### 9-8 ICR4

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>9-8</td>
<td>Interrupt configuration 1 fields. This register controls the active condition of the interrupt function for GPIO interrupt 4.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Settings:</strong></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td>7-6</td>
<td>ICR3</td>
</tr>
<tr>
<td><strong>Settings:</strong></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td>5-4</td>
<td>ICR2</td>
</tr>
<tr>
<td><strong>Settings:</strong></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td>3-2</td>
<td>ICR1</td>
</tr>
<tr>
<td><strong>Settings:</strong></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td>1-0</td>
<td>ICR0</td>
</tr>
<tr>
<td><strong>Settings:</strong></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
</tbody>
</table>
12.5.6 GPIO interrupt configuration register2 (ICR2)

12.5.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ICR2</td>
<td>10h</td>
</tr>
</tbody>
</table>

12.5.6.2 Function

GPIO_ICR2 contains 16 two-bit fields, where each field specifies the interrupt configuration for a different input signal.

12.5.6.3 Diagram

```
| Bits | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R W  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  |
| ICR31| ICR30| ICR29| ICR28| ICR27| ICR26| ICR25| ICR24| ICR23| ICR22| ICR21| ICR20| ICR19| ICR18| ICR17| ICR16|
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
|      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R W  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  | R  |
| ICR23| ICR22| ICR21| ICR20| ICR19| ICR18| ICR17| ICR16|     |     |     |     |     |     |     |     |     |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
```

12.5.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>ICR31</td>
</tr>
<tr>
<td>ICR31</td>
<td></td>
</tr>
</tbody>
</table>

Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 31.

Settings:

Bits ICRn[1:0] determine the interrupt condition for signal n as follows:

- 00b - Interrupt n is low-level sensitive.
- 01b - Interrupt n is high-level sensitive.
- 10b - Interrupt n is rising-edge sensitive.
- 11b - Interrupt n is falling-edge sensitive.

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>29-28</td>
<td>ICR30</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 30.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>27-26</td>
<td>ICR29</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 29.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>25-24</td>
<td>ICR28</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 28.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>23-22</td>
<td>ICR27</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 27.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>21-20</td>
<td>ICR26</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 26.</td>
</tr>
<tr>
<td></td>
<td>Settings:</td>
</tr>
<tr>
<td></td>
<td>Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>
### Field  | Function
--- | ---
19-18 | ICR25
   | Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 25.
   | Settings:
   | Bits ICRn[1:0] determine the interrupt condition for signal n as follows:
   | 00b - Interrupt n is low-level sensitive.
   | 01b - Interrupt n is high-level sensitive.
   | 10b - Interrupt n is rising-edge sensitive.
   | 11b - Interrupt n is falling-edge sensitive.

17-16 | ICR24
   | Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 24.
   | Settings:
   | Bits ICRn[1:0] determine the interrupt condition for signal n as follows:
   | 00b - Interrupt n is low-level sensitive.
   | 01b - Interrupt n is high-level sensitive.
   | 10b - Interrupt n is rising-edge sensitive.
   | 11b - Interrupt n is falling-edge sensitive.

15-14 | ICR23
   | Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 23.
   | Settings:
   | Bits ICRn[1:0] determine the interrupt condition for signal n as follows:
   | 00b - Interrupt n is low-level sensitive.
   | 01b - Interrupt n is high-level sensitive.
   | 10b - Interrupt n is rising-edge sensitive.
   | 11b - Interrupt n is falling-edge sensitive.

13-12 | ICR22
   | Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 22.
   | Settings:
   | Bits ICRn[1:0] determine the interrupt condition for signal n as follows:
   | 00b - Interrupt n is low-level sensitive.
   | 01b - Interrupt n is high-level sensitive.
   | 10b - Interrupt n is rising-edge sensitive.
   | 11b - Interrupt n is falling-edge sensitive.

11-10 | ICR21
   | Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 21.
   | Settings:
   | Bits ICRn[1:0] determine the interrupt condition for signal n as follows:
   | 00b - Interrupt n is low-level sensitive.
   | 01b - Interrupt n is high-level sensitive.
   | 10b - Interrupt n is rising-edge sensitive.
   | 11b - Interrupt n is falling-edge sensitive.
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>9-8</td>
<td>ICR20</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 20. Settings: Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>7-6</td>
<td>ICR19</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 19. Settings: Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>5-4</td>
<td>ICR18</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 18. Settings: Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>3-2</td>
<td>ICR17</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 17. Settings: Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
<tr>
<td>1-0</td>
<td>ICR16</td>
</tr>
<tr>
<td></td>
<td>Interrupt configuration 2 fields. This register controls the active condition of the interrupt function for GPIO interrupt 16. Settings: Bits ICRn[1:0] determine the interrupt condition for signal n as follows:</td>
</tr>
<tr>
<td></td>
<td>00b - Interrupt n is low-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>01b - Interrupt n is high-level sensitive.</td>
</tr>
<tr>
<td></td>
<td>10b - Interrupt n is rising-edge sensitive.</td>
</tr>
<tr>
<td></td>
<td>11b - Interrupt n is falling-edge sensitive.</td>
</tr>
</tbody>
</table>
12.5.7  GPIO interrupt mask register (IMR)

12.5.7.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMR</td>
<td>14h</td>
</tr>
</tbody>
</table>

12.5.7.2  Function

GPIO IMPLIED contains masking bits for each interrupt line.

12.5.7.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

12.5.7.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>IMR</td>
</tr>
</tbody>
</table>
| IMR   | Interrupt Mask bits. This register is used to enable or disable the interrupt function on each of the 32 GPIO signals. Settings: Bit IMR[n] (n=0...31) controls interrupt n as follows: 0b - Interrupt n is disabled. 1b - Interrupt n is enabled.
12.5.8 GPIO interrupt status register (ISR)

12.5.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISR</td>
<td>18h</td>
</tr>
</tbody>
</table>

12.5.8.2 Function

The GPIO_ISR functions as an interrupt status indicator. Each bit indicates whether an interrupt condition has been met for the corresponding input signal. When an interrupt condition is met (as determined by the corresponding interrupt condition register field), the corresponding bit in this register is set. Two wait states are required in read access for synchronization. One wait state is required for reset.

12.5.8.3 Diagram

```
Bits 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16
R    |       ISR       |       |       |       |       |       |       |
W    |       W1C       |       |       |       |       |       |       |
Reset | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0   |
                   | 0 0 0 0 0 0 0 0   |
Bits 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0   |
R    |       ISR       |       |       |       |       |       |       |
W    |       W1C       |       |       |       |       |       |       |
Reset | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0   |
```

12.5.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>ISR</td>
</tr>
<tr>
<td>ISR</td>
<td>Interrupt status bits - Bit n of this register is asserted (active high) when the active condition (as determined by the corresponding ICR bit) is detected on the GPIO input and is waiting for service. The value of this register is independent of the value in GPIO_IMR.</td>
</tr>
</tbody>
</table>
When the active condition has been detected, the corresponding bit remains set until cleared by software. Status flags are cleared by writing a 1 to the corresponding bit position.

12.5.9  GPIO edge select register (EDGE_SEL)

12.5.9.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>EDGE_SEL</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

12.5.9.2  Function

GPIO_EDGE_SEL may be used to override the ICR registers' configuration. If the GPIO_EDGE_SEL bit is set, then a rising edge or falling edge in the corresponding signal generates an interrupt. This register provides backward compatibility. On reset all bits are cleared (ICR is not overridden).

12.5.9.3  Diagram

```
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
| R  | W  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
| R  | W  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
| R  | W  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
```

12.5.9.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>GPIO_EDGE_SEL</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPIO_EDGE_SEL</td>
<td>Edge select. When GPIO_EDGE_SEL[n] is set, the GPIO disregards the ICR[n] setting, and detects any edge on the corresponding input signal.</td>
</tr>
</tbody>
</table>

12.5.10  GPIO data register SET (DR_SET)

12.5.10.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DR_SET</td>
<td>84h</td>
</tr>
</tbody>
</table>

12.5.10.2  Function

The SET register of GPIO_DR.

12.5.10.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

12.5.10.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>DR_SET</td>
</tr>
<tr>
<td>DR_SET</td>
<td>The SET register of GPIO_DR.</td>
</tr>
</tbody>
</table>
12.5.11  GPIO data register CLEAR (DR_CLEAR)

12.5.11.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DR_CLEAR</td>
<td>88h</td>
</tr>
</tbody>
</table>

12.5.11.2  Function

The CLEAR register of GPIO_DR.

12.5.11.3  Diagram

```
+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+
| 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18      | 17      | 16      |
| R       | W       |         |         |         |         |         |         |         |         |         |         |         |         |         |         |
```

```
R: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
W: DR_CLEAR
```

```
+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+
| 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| R       | W       |         |         |         |         |         |         |         |         |         |         |         |         |         |         |
```

```
R: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
W: DR_CLEAR
```

12.5.11.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>DR_CLEAR</td>
</tr>
<tr>
<td>DR_CLEAR</td>
<td>The CLEAR register of GPIO_DR.</td>
</tr>
</tbody>
</table>

12.5.12  GPIO data register TOGGLE (DR_TOGGLE)
12.5.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DR_TOGGLE</td>
<td>8Ch</td>
</tr>
</tbody>
</table>

12.5.12.2 Function

The TOGGLE register of GPIO_DR.

12.5.12.3 Diagram

Bits 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16
R | W
Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

DR_TOGGLE

Bits 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0
R | W
Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

DR_TOGGLE

12.5.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>DR_TOGGLE</td>
</tr>
<tr>
<td>DR_TOGGLE</td>
<td>The TOGGLE register of GPIO_DR.</td>
</tr>
</tbody>
</table>
Chapter 13
Clock and Power Management

13.1 Introduction

This chapter describes the Clock and Power Management architecture of the SoC.

The chip targets applications where low power consumption, long battery life, always-on and instant-on capabilities are paramount, and where there is no need for active cooling. To achieve these capabilities, the primary focus of the chip's design is reducing current consumption as much as possible, while simultaneously enabling the maximum level of peak performance and a balanced level of sustained performance for target applications. To achieve this, the chip architecture uses a wide range of power-management techniques and their combinations for maximum system design flexibility.

This chapter contains information about:

- Structural components of the power and clock management systems of the chip
- Power, clock and thermal management techniques supported by the chip

All given numerical values are typical or examples. For accurate values one should refer to the datasheet.

13.2 Device Power Management Architecture Components

To provide a clean and versatile architecture supporting a wide range of power-management techniques, clocks, and power rails are managed resources.

For each rail, two levels of management are defined: the first level is centralized or SoC-level resource management, and the second is a local or "module level" resource management.

The high level architectural view of the clock, power and thermal management system of the chip is presented in the figure below.
13.2.1 Centralized components of clock generation and management

Centralized components of the clock generation and management sub-system are implemented in the following blocks:

- **CCM (Clock Control Module):** The CCM module provides control for primary (source level) and secondary (root level) clock generation, division, distribution, synchronization, and coarse-level gating. See Clock Controller Module (CCM) for
information on the CCM architecture, functional description and programming model.  
- LPCG (Low Power Clock Gating): This module distributes the clocks to all blocks in the SoC and handles block level software-controllable and automated clock gating. See Clock Controller Module (CCM) for information on the LPCG architecture and functional description.

### 13.2.2 Centralized components of power generation, distribution and management

Centralized components of the power generation, distribution and management sub-system are implemented in the following blocks:

- Power Management Unit (PMU). See Power Management Unit (PMU) for information on the PMU architecture, functional description and programming model.
- General Power Controller (GPC). See General Power Controller (GPC) for information on the GPC architecture, functional description and programming model.
- On Chip DC-DC regulator. See the DCDC chapter for more detailed information.

### 13.2.3 Reset generation and distribution system

Power and clock management are accompanied with an appropriate reset generation and distribution system, centralized functions of which are implemented by the System Reset Controller (SRC).

### 13.2.4 Power and clock management framework

Together, the modules listed above provide enhanced power-management features with centralized control for the clock, reset, and power-management signals on the SoC.

The centralized management framework defines the managed components of the power-management architecture. These components are called the clock, power, and voltage domains.

**NOTE**

A domain is a group of modules or functional blocks that share a common resource entity (for example, common clock root, common power source, or a common power switch). The software component managing shared resources should take
into account the joint constraints of all the modules belonging to that resource domain.

13.3 Clock Management
13.3.1 Centralized components of clock management system

The clock generation and management system is built around the CCM and LPCG blocks.

A high level block diagram of the clock management system in the SoC environment is shown in the following figure.

![Clock Management System Diagram]

**Figure 13-2. Clock Management System**

13.3.2 Clock generation

The clock generation section includes the components detailed in the following sections.
13.3.2.1 Crystal Oscillator (XTALOSC)

The Crystal Oscillator block is comprised of both the high frequency oscillator (typical frequency is 24 MHz) and the low frequency real time clock oscillator (typical frequency of 32.768 KHz). Each of these oscillators is implemented as a biased amplifier that, when combined with a suitable external quartz crystal and external load capacitors, implements an oscillator. See Crystal Oscillator (XTALOSC) for details of the XTALOSC block.

**NOTE**
1. The 24 MHz XTALOSC can be the external clock source of SYSTICK. Hardware divides this down to 100KHz before it reaches SYSTICK.
2. If XTALOSC24M_LowPwr_CTRLn[OSC_SEL] is set to ROSC, the chip's 24MHz clock will be from the 24MHz RCOSC. In this case, the RCOSC should be enabled properly beforehand.

13.3.2.2 PLLs

Seven PLLs are included in the clock generation section. Two of these PLLs are each equipped with four Phase Fractional Dividers (PFDs) in order to generate additional frequencies.

**NOTE**
Each PFD works independently by interpolating the VCO of the PLL to which it is connected. It effectively takes the PLL VCO frequency and produces 18/N x Fvco at its output where N ranges from 12 to 35. PFD is a completely digital design with no analog components or feedback loops. The frequency switch time is much faster than a PLL because keeping the base PLL locked and changing the integer N only changes the logical combination of the interpolated outputs of the VCO. Note that the PFD not only enables faster frequency changes than a PLL, but also allows the configuration to be safely changed "on-the-fly" without going through the output clock disabling/enabling process.

The seven PLLs are listed below:

- PLL1 (also referred to as ARM_PLL) - This is the PLL clocking the Arm core complex. It is a programmable integer frequency multiplier capable of output
frequency of up to 1.3 GHz. Note that this frequency is higher than the maximum chip supported frequency.

- PLL2 (also referred to as System_PLL or 528_PLL) - PLL2 runs at a fixed multiplier of 22, producing 528 MHz output frequency with 24 MHz reference from XTALOSC. Besides the main output, this PLL drives four PFDs (PLL2_PFD0...PLL2_PFD3). The main PLL2 output and its PFD outputs are used as inputs for many clock roots. These do not require exact/constant frequency and can be changed as a part of dynamic frequency scaling procedure. Typically, this PLL or its PFDs are a clock source for internal system buses, internal processing logic, SDRAM interface, NAND/NOR interface modules, etc.

- PLL3 (also referred to as USB1_PLL) - PLL3 is used in conjunction with the first instance of USB PHY (USBPHY1, also known as OTG PHY). This PLL drives four PFDs (PLL3_PFD0...PLL3_PFD3) and runs at a fixed multiplier of 20. This results in a VCO frequency of 480 MHz with a 24 MHz oscillator. The main PLL3 output and its PFD outputs are used as inputs for many clock roots that require constant frequency, such as UART and other serial interfaces, audio interfaces, etc.

- PLL4 (also referred to as an Audio PLL) - This is a fractional multiplier PLL used for generating a low jitter and high precision audio clock with standardized audio frequencies. The PLLs oscillator frequency range is from 650 MHz to 1300 MHz, and the frequency resolution is better than 1 Hz. This clock is mainly used as a clock for serial audio interfaces and as a reference clock for external audio codecs. It is equipped with a divider on its output and can generate divided by 1, 2 or 4 from the PLL VCO frequency.

- PLL5 (also referred to as a Video PLL) - This is a fractional multiplier PLL used for generating a low jitter and high precision video clock with standardized video frequencies. The PLLs oscillator frequency range is from 650 MHz to 1300 MHz, and the frequency resolution is better than 1 Hz. This clock is mainly used as a clock for display and video interfaces. It is equipped with dividers on its output and can generate clock divided by 1, 2, 4, 8 or 16 from the PLL VCO frequency.

- PLL6 (also referred to as ENET_PLL) - This PLL implements a fixed 20+(5/6) multiplier. With a 24 MHz input, it has a VCO frequency of 500 MHz. This PLL is used to generate:
  - 50 or 25 MHz for the external ethernet interface.
  - 125 MHz for reduced gigabit ethernet interface.
  - 100 MHz for general purposes.

- PLL7 (also referred to as USB2_PLL) - This PLL provides clock exclusively to USB2 PHY (USBPHY2, also known as OTG PHY). It runs at a fixed multiplier of 20, resulting in a VCO frequency of 480 MHz with a 24 MHz oscillator.
13.3.2.2.1 General PLL Control and Status Functions

Each PLLs configuration and control functions are accessible individually through its PFDs and global configuration and status registers.

Reference input clock for any of the PLLs could be selected individually by the BYPASS_CLK_SRC field of the PLL control register. See CCM Analog Memory Map/ Register Definition for more information.

Each of the PLLs could be individually configured to "Bypass", "Output disabled" and "Power Down" modes.

When configured in "Bypass" PLL pass directly its input reference clocks to the PLL output. Bypassing the PLL is done by setting the BYPASS bit in the control register. For the PLL equipped with PFDs the input reference clock is also bypassed to all PFDs outputs.

When configured in output disabled mode (ENABLE=0), the PLL's output is completely gated and there is neither a bypass clock nor PLL generated clock that propagates to PLL output. Each PLL output has an individual "Output Enable" control bit. The PFDs are gated by the ENABLE bit of their associated PLL. Each PFD does have an associated clock gate bit that can be used to turn it off individually.

When configured in "Power Down mode" most of the PLL circuitry is switched off. Neither main PLL output nor PFD outputs are available in this mode.

When the related PLL is powered up from the power down state or made to go through a relock cycle due to PLL reprogramming, it is required that the related PFDx_CLKGATE bit in CCM_ANALOG_PFD_480n or CCM_ANALOG_PFD_528n, be cycled on and off (1 to 0) after PLL lock. The PFDs can be in the clock gated state during PLL relock but must be clock un-gated only after lock is achieved. See the engineering bulletin, Configuration of Phase Fractional Dividers (EB790) at www.nxp.com for procedure details.

Individual PLL status is reflected in "PLL Lock" bits of the PLL control registers. PLL enable logic which monitors the register value change is implemented to gate off the PLL outputs during the "lock in" period.

Outputs are generated to be sent out by monitoring the individual PLL lock flags and filtering out any random initial edges.

Individual PLL Lock ready flags are first "ORED" with "enables" and then "ANDED" together to generate the global PLL lock ready flag that reflects status of all PLLs enabled in certain moment.
CCM Memory Map/Register Definition and CCM Analog Memory Map/Register Definition contains detailed descriptions of the memory mapped registers and control functions of the clock generation sub-module.

13.3.2.3 CCM

CCM includes:

- Clock root generation logic - This sub-block provides the registers that control most of the secondary clock source programming, including both the primary clock source selection and the clock dividers. The clock roots are each individual clocks to the core, system buses (AXI, AHB, IPG) and all other SoC peripherals, among those are serial clocks, baud clocks, and special functional clocks. Most of clock roots are specific per module.
- CCM, in coordination with GPC, PMU and SRC, manages the Power modes, namely RUN, WAIT and STOP modes. The gating of the peripheral clocks is programmable in RUN and WAIT modes.

CCM manages the frequency scaling procedure for:

- Arm core clock - "on the fly" without clock interruption, by either shifting between PLL sources PLL clock change or by changing the divider ratio.
- Peripheral root clock - by using programmable divider. The division factor can change on the fly without loss of clocks.

NOTE

On-the-fly frequency changing for synchronous interfaces like serial audio interfaces, video and display interfaces, or general purpose serial interfaces (e.g. UART, CAN) may cause synchronization loss and should not be done.

13.3.2.4 Low Power Clock Gating unit (LPCG)

The LPCG block receives the root clocks from CCM and splits them to clock branches for each block. The clock branches are individually gated clocks.

The enables for those gates can come from three sources:

- Clock enable signal from CCM - This signal is generated depending on the power mode the system is in. For each power mode, it is defined in the software using the configuration of the CGR bits in CCM.
• Clock enable signal from the block - This signal is generated by the block based on its internal logic. Not every enable signal from the block is used. Each clock enable signal from the block can be overridden based on the programmable bit in CCM.
• Clock enable signal from the reset controller (SRC) - This signal will enable the clock during the reset procedure.

13.3.3 Peripheral components of clock management system

13.3.3.1 Interface and functional clock

Each block within the SoC has specific clock input characteristic requirements. Based on the characteristics of the clocks delivered to modules, the clocks are divided into two categories: bus interface clocks and functional clocks.

The bus interface clocks have the following characteristics:

• They ensure proper communication between any block/subsystem and the system buses.
• In most cases, they supply the system interface and configuration registers of the block.
• A typical block has one system bus clock, but blocks with multiple interface clocks may also exist (that is, when a block is connected to multiple buses).
• The bus interface clocks are always fed by the outputs of the CCM/LPCG.
• Clock management for this type of clock is always implemented at the system level because it requires coordinated clock management between the block and system buses.

Functional clocks have the following characteristics:

• They supply the functional part of a block or a subsystem.
• Typically, these clocks are completely asynchronous and independent from the bus interface clock of the same block.
• A block can have one or more functional clocks. Some functional clocks are mandatory, while others are optional for its functioning. A block needs its mandatory clock(s) to be operational. The optional clocks are used for specific features and can be shut down without stopping the block activity.
• The functional clocks are fed either by a CCM/LPCG block functional clock output, or by some other clock source, such as a clock output of another block or an external signal coming from IOMUX.
13.3.3.2 Block level clock management

Each block in the system may also have specific clock requirements. Certain module clocks must be active when operating in some specific modes, or may be gated in some others. Generally, the activation and gating of the module clocks are managed by LPCG. Hence, the LPCG block must be programmed properly and, in case of hardware controllable clock gating, peripheral module should provide signals indicating when to activate and when to gate the module clocks.

The LPCG block differentiates the clock-management behavior for device modules based on whether the block can initiate transactions on the device interconnect (called master module), or if it cannot initiate transactions and only responds to the transactions initiated by the master (called slave module). Thus, two hardware-based clock-management protocols are used:

- Master protocol - Clock-management protocol between the CCM/LPCG and blocks that can be bus master
- Slave protocol - Clock-management protocol between the CCM/LPCG and slave modules

13.3.3.2.1 Master clock protocol

This protocol is used to indicate that a master module is ready to initiate a transaction on the device interconnect and requests specific (both functional and interface) clocks. The CCM/LPCG block ensures that the required clocks are active when the master module requests that the CCM/LPCG enable them. The module is said to be functional after the required clocks are activated.

Similarly, when the master module no longer requires the clocks, it informs the LPCG/CCM block and the LPCG/CCM can then gate the clocks to the module and all the clock precedents that are not used by other blocks. The master module is then said to be in clock-gated or partially clock gated mode.

Examples of module supporting master clock protocol USDHC. Please see details in chapters describing these modules and in the CCM enable override register (CCM_CMEOR).

13.3.3.2.2 Slave clock protocol

This hardware protocol allows CCM to control the state of a slave module. CCM informs the slave module, through assertion of a stop/change request, when its clocks (both interface and functional) can be changed or gated. The slave acknowledges the request and CCM is then allowed to gate or change the clocks to the block.
Similarly, a clock-gated slave module may need to be woken up because of some event or a service request from a master module. In this situation, CCM enables the clocks to the module and then de-asserts the stop request to signal the module to wake up.

Examples of modules supporting slave clock protocol are CAN, and GPT. Please see details in chapters describing these modules and in the CCM Module Enable Override Register (CCM_CMEOR). See CCM Memory Map/Register Definition for more details.

The protocol in both "master" and "slave" cases is completely hardware-controlled, but software should configure the clock management behavior for the module in two places: in the CCM registers associated with the block and in the block configuration registers.

### 13.3.3.3 Clock Domain(s)

A clock domain is a group of blocks fed by clock signals controlled by the same clock controls in CCM. By gating the clocks in a clock domain, the clocks to all the blocks belonging to that clock domain can be gated/activated, either by software control or by hardware control associated with block activity. Thus, a clock domain allows efficient control of the dynamic power consumption of the domain.

The device is partitioned into multiple clock domains and each clock domain is controlled by an associated group of clock gating cells within the LPCG block. This allows the CCM/LPCG to individually activate and gate each clock domain of the system.

### 13.3.3.4 Domain level clock management

The domain clock manager can automatically (based on hardware conditions) and manage the bus interface clocks within the clock domain. The functional clocks within the clock domain are managed through software settings.

### 13.3.3.5 Domain dependencies

A domain dependency is a hierarchical relationship between two clock domains. Clock domain "X" is said to depend on a clock domain "Y" when a block in clock domain "Y" provides services (or even just a clock) to a block in clock domain "X". As a result, clock domain "Y" must be active whenever clock domain "X" is active.

The dependency between two clock domains may also exist if one clock domain serves to ensure communication between two blocks (for example, the clock domain of the device interconnect).
13.4 Power management

13.4.1 Centralized Components of Power Management System

The power generation and management system is built around the PMU and GPC blocks. A high level block diagram of the power management system in the SoC environment is shown in the figure below.

![Diagram of Power Management System](image)

**Figure 13-3. Power Management System**

13.4.1.1 Integrated PMU

The first component of the power management system, referred to as the integrated PMU, is designed to simplify the external power interface.
It consists of a set of secondary power supplies that enable SoC operations from just two or three primary supplies. The high level block diagram of the power tree, utilizing the integrated PMU, is shown below.

![SOC Power Tree Diagram]

Figure 13-4. SOC Power Tree

The integrated PMU includes the following components:

- On-chip DCDC regulator
- Two Analog LDO regulators
- USB LDO
- SNVS regulator

See Power Management Unit (PMU) for further details on integrated PMU functional description and programmability.

13.4.1.1.1 DCDC Regulator

The DCDC regulator includes the following features:

- Adjustable (25 mV per step) high efficiency regulator
- Supports 3.3 V (±10%) input voltage
- Output ranged in 0.9 V~1.3 V
- Supports nominal run, low power standby and off modes
- Supports 0.9 V~1.3 V output in run mode
• Supports 0.9 V~1.0 V output in standby mode
• Over current and over voltage detection

These modes allow the regulator to implement voltage scaling and power gating, and allow bypass when an external high power efficient regulator is used as a direct source for some of the SoC loads.

The DVFS (Dynamic Voltage and Frequency Scaling) in a typical cost/complexity optimized application is considered by means of an internal DCDC. The DCDC workpoint can be dynamically adjusted according to the system's working frequency requirement.

13.4.1.1.2 Analog LDO regulators

There are two analog LDO regulators used for general system purposes:

• LDO_1P1 - The LDO_1P1 (VDD_HIGH_IN, NVCC_PLL) linearly regulates down a higher supply voltage (2.8V-3.3V) to produce a nominal 1.1V output voltage. This regulator supplies digital portions of USB PHYs, PLLs, and the internal 24 MHz oscillator.

• LDO_2P5 - The LDO_2P5 (VDD_HIGH_IN, VDD_HIGH_CAP) linearly regulates down a higher supply voltage (2.8V-3.3V) to produce a nominal 2.5V output voltage. The regular 2.5V LDO is combined with an alternate self-biased low-precision weak regulator which can be enabled for applications that need to keep the 2.5V output voltage alive during low power modes, where the main regulator and its associated global bandgap reference module are disabled to save power. The output of this weak-regulator is not programmable and is a function of its input power supply as well as its load current. Typically with a 3V input power supply, the weak-regulator output is 2.525V and its output impedance is approximately 40Ohm. Special procedure is recommended to move load back and forth between the main and low power (weak) regulators. This regulator supplies most of the analog circuitry of the integrated PHYs, and other analog and mix signal components integrated into the SoC.

13.4.1.1.3 USB LDO

The USB_LDO linearly regulates down the USB VBUS input voltages (typically 5V) to produce a nominal 3.0V output voltage. This regulator has a built in power-mux that allows the user to run the regulator from either one of the VBUS supplies when both are present. If only one of the VBUS voltages is present, the regulator automatically selects that supply. Current limit is also included to help the system keep the in-rush current within limits as required in USB 2.0 specification. This regulator supplies only low speed and full speed transceivers of USB PHYs.
13.4.1.4 SNVS regulator

The SNVS regulator takes the SNVS_IN supply and generates the SNVS_CAP supply, which in turn powers the real time clock and low power section of the SNVS modules. If VDDHIGH_IN is present, then the SNVS_IN supply is internally shorted to the VDDHIGH_IN supply to allow coin cell recharging if necessary.

13.4.1.2 GPC - General Power Controller

The GPC block includes the sub-blocks listed here.

- Power Gating Controller (PGC) - This sub-block of GPC has the following functions:
  - Provides the user with the ability to switch off power to a target subsystem.
  - Generates power-up and power-down control sequences. This includes interaction with CCM/LPCG and SRC, and control for clock and reset generation for power domains affected by power gating.
  - Provides programmable registers that adjust the timing of the power control signals.
  - Controls the CPU power domain and Memory sub-domain (PDRAMx).
- Wake-up interrupt controller - This controller initiates the system wake-up from low power modes when only low frequency real time clock remains active, and thus the Generic Interrupt Controller (GIC) can not handle synchronous interrupt signals. Additional features are as follows:
  - Supports up to 160 interrupts
  - Provides an option to mask/unmask each interrupt
  - Detects interrupts and generates the wake up signal

See General Power Controller (GPC) for further details on GPC, its sub-blocks, and information on its functional description and programmability.

13.4.1.3 SRC - System reset Controller

The reset controller is responsible for the generation of all reset signals and boot configuration decoding.

It determines the source and the type of reset, such as POR and COLD, and performs the necessary reset signal qualifications. SRC is capable of generating reset sequences in the following conditions:
• in interaction with external PMIC, based on external POR_B signal and "power ready" signals generated by the integrated PMU
• or in interaction with the integrated PMU only, based on its "power ready" signal.

Based on the type of reset, the reset logic generates the reset sequence for either the entire SoC or for the blocks that are power-gated.

See System Reset Controller (SRC) for further details on SRC functional description and programmability.

13.4.1.4 Power domain(s)

A power domain is a group of blocks or sub-blocks fed by power sources controlled by the same power controls in GPC.

Some power domains can be split into a logic sub-domain and a memory sub-domain. The memory sub-domain in such case may contain two entities:

- Memory array(s) - Powered by a dedicated voltage rail enabling memory retention while core is OFF.
- Memory interface logic - Powered by the same voltage source as the logic sub-domain of the power domain.

Signals crossing power domain boundaries or sub-domain boundaries are passed through proper isolation and/or level-shifting cells to ensure robust operations of the SoC when some of domains are power gated or working at a reduced voltage.

The following figure shows the power domain interface within the system.
13.4.1.4.1 Power distribution

The power distribution tree is comprised of multiple power domains. The main power domains are:

- Arm - The Arm domain contains the Arm Core platform. This domain can be supplied from internal or external controllable regulator.
- FlexRAM memory array - Bank0 to Bank15 of FlexRAM.
- OCRAM2 memory array - The OCRAM2 memory array is partitioned into 2 sub-domains: 64KB always on domain (also known as PDRET domain, starting from address 2020_0000h), 448KB PDRAM1 domain.
- SNVS/RTC low power domain - The SRTC (Secure Real Time Counter) domain contains only counter, comparator and compared data of the on-chip RTC. This domain should be supplied from an external single cell LiION battery and/or an external pre-regulated power supply. This SNVS domain also contains Low Power State Retention (LPSR) GPIO, IOMUX, and LPSR general purpose register.
- Analog domain - The analog domain contains the PLLs, LDOs and USB PHY. The domain supplies should be constant to allow continuous clock during any dynamic voltage scaling techniques. The digital supply should be provided from an internal regulator, and can be combined with the memory array supply. The analog supply should be provided from internal low noise regulator.
- Main SoC logic - The main SoC logic domain contains the rest of the logic of the SoC. It is supplied by the same power supply as the Arm Core Platform.

From a DVFS and Power Gating standpoint, the following digital logic domains are affected:

- Arm Core Platform - DVFS and power gating.
- FlexRAM memories - DVFS and power gating.
- PDRAM1 (within OCRAM2) memories - DVFS and power gating.
- Main SoC logic - DVFS, no power gating.

13.4.1.4.2 Domain memory and domain logic state retention in case of power gating

The following is the list of relevant memories and logic domains with the description of their state-retention support.

**NOTE**

For more detailed information, see the table "Low Power Mode Definition" in this chapter.

- Arm Core Platform logic - the software state retention for all logic is implemented in this domain and L1 cache memories. Software state retention means that the content
of relevant registers should be stored in some memory retaining its state (OCRAM for example) while the logic domain is power-gated.

• PDRET memories - hardware state-retention in all power modes except SNVS mode.
• FlexRAM PDRAM0 memories - hardware state-retention. When Arm core is power gated, PDRAM0 memories can be either left on with its content retained or power gated together with the core.
• FlexRAM PDRAM1 memories - can be powered gated (together) independently of Arm core power gating.
• SoC - hardware state-retention.
• SNVS_LP - hardware state-retention even when SoC supplies are removed.

13.4.1.4.3 Power Gating Domain Management

The following bullets provide the sequence required for power-gating the relevant power-domains:

13.4.1.4.3.1 Arm Core Platform

1. Copy through software all the Core configuration registers to a powered-on memory
2. Configure the GPC/PGC CPU registers in PGC Memory Map/Register Definition as follows to power-down the core on the next "WFI" instruction:
   • Configure the GPC/PGC PGC_CPU_PDNSCR Register ISO and ISO2SW bits. The ISO field determines the delay between the power-down request and enabling the platform isolation. The ISO2SW field determines the delay between the platform isolation and the actual power-off switch to the supplies.
   • Configure the GPC/PGC PGC_CPU_PUPSCR Register SW and SW2ISO bits. The SW field determines the delay between the power-up request and the actual power-up of the supplies. The SW2ISO field determines the delay between asserting power toggle and negating platform isolation.
   • Configure the GPC PGC PGC_CPU_CTRL PCR bit to allow the power down of the platform
   • Arm Core Platform should execute a "WFI" instruction.

<table>
<thead>
<tr>
<th>Isolation enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>Power on</td>
</tr>
<tr>
<td>Power sequence phase</td>
</tr>
<tr>
<td>ISO Count</td>
</tr>
</tbody>
</table>

Figure 13-6. Arm Core Platform isolation and power on switch flow
13.4.1.4.3.2 SoC

For additional power reduction it is possible to do the following:

- Power-down the internal oscillator by configuring the following bits CCM_CCR[COSC_EN] (CCM Memory Map/Register Definition). This can be done only in case there is no dependency on 24 MHz XTAL for wake-up.
- It is possible to turn off and turn on the PMIC supplies to the SoC even when the SoC supplies are off. Since SNVS_LP is powered through an "always on" supply, configuring the SNVS_LP DP_EN to "1" allows changing the PMIC_ON_REQ pad (SoC on/off supply indication to the PMIC) through the ONOFF pad.

13.4.1.4.4 Power Gating domain dependencies

There are 3 power domains that need to be isolated in different power-down cases:

- Arm Core Platform and PDRAMx - Isolation needs to be enabled before power-down. This is taken care of automatically after CCM and PGC are configured and the Arm Core Platform executes the "WFI" instruction.
- SNVS_LP - Different from the 2 domains above, the SNVS_LP isolation isolates the signals coming from the SoC to the SNVS_LP. This is required for saving the contents of the SNVS_LP (such as the real-time clock). The isolation is activated in 2 ways:
  - Automatically through the power-fail detector in the PMU
  - Through software configuration

![Diagram of SoC Voltage Domain, isolation cells, and voltage level shifters]

**Figure 13-7. Isolation cells and Voltage level shifters placing**
13.4.1.5  Voltage domains

The list found here states the different voltage domains and their scalability in regarding to power-saving in dynamic and static scenarios.

- SoC domain: including Core Platform, FlexRAM memories and SoC logic - Scalable voltage in both dynamic and static scenarios
- ANALOG components including PLLs - Fixed voltage
- I/O - Fixed voltage
- SNVS_LP - Fixed voltage

13.4.1.6  Voltage domain management

13.4.1.6.1  Dynamic

13.4.1.6.1.1  Voltage Scaling

A simplistic way to reduce power consumption in dynamic scenarios is to scale down the Arm and SoC voltage according to the allowed voltage points and corresponding frequencies specified in datasheet.

13.4.1.6.2  Static

13.4.1.6.2.1  Standby Leakage reduction (SLR)

Standby leakage reduction is a power-management technique utilizing:

- Reduced supply voltage for relevant domains

With SLR, the device switches into low-power active system modes automatically or in response to user requests during system Stop, Wait, or DSM modes (that is, in situations when no application is started and no system activity is presented).

When applying SLR, the system remains in the lowest static power mode while retaining logic and memory states. This technique trades static power consumption for wake-up latency while maintaining fast system response time suitable for most applications.

See CCM Control Register (CCM_CCR), CCM Low Power Control Register (CCM_CLPCR) and PMU Miscellaneous Register 0 (PMU_MISC0) for further details on SLR programmability options.

The following describes the flow for applying standby voltage:
• Configure the external PMIC standby voltage, refer to chip datasheet.
• Configure CCM_CCR[RBC_EN] bits to bypass and disable PMU regulators in the next Arm "WFI" execution.
• Configure CCM_CCR[REG_BYP_COUNT] bits to allow proper voltage restoration by the external PMIC when exiting standby.
• Arm Core Platform executes the "WFI" instruction that completes the software sequence putting the SoC into low power mode

13.4.1.7 System domains layout

The following table describes the different power modes.

For more information regarding the low-power application design points on i.MX RT series, see the application note AN12085: How to use i.MX RT Low Power Feature.

NOTE
The IDLE, SUSPEND and SNVS are usually referred as low power mode.

• IDLE Modes: CPU in WFI state, some portion of the chip can be clock gated or power gated. The chip can wakeup from this mode from IRQ with a very short latency. IDLE mode is entered automatically from RUN mode when CPU executes WFI instruction, so the state of IDLE mode will have dependency on the state of the RUN mode. To avoid showing a lot of IDLE modes, the following two IDLE states are defined:
  • System IDLE: the IDLE mode entered from Low Speed Run mode. When entering from other RUN modes, the difference is mainly the CPU/BUS frequency.
  • Low Power IDLE: the IDLE mode entered from Low Power RUN mode.
• SUSPEND Mode: CPU power gated, all clocks gated only except 32KHz, analog modules also enter low power state. It provides the lowest power while keeps the system alive, but it would have longer exit time.
• SNVS Mode: All the modules are turned off, only except RTC is active.
Table 13-1. Low Power Mode Definition

<table>
<thead>
<tr>
<th></th>
<th>Overdrive Run</th>
<th>Full Speed Run</th>
<th>Low Power Run</th>
<th>System Idle</th>
<th>Low Power Idle</th>
<th>Suspend</th>
<th>SNVS</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDD_SOC_IN voltage</td>
<td>1.25V min</td>
<td>1.15V min</td>
<td>0.925V min</td>
<td>1.15V min</td>
<td>0.925V min</td>
<td>0.925V min</td>
<td>OFF</td>
</tr>
<tr>
<td>CCM LPM Mode</td>
<td>Run</td>
<td>Run</td>
<td>RUN</td>
<td>WAIT</td>
<td>WAIT</td>
<td>STOP</td>
<td>N/A</td>
</tr>
<tr>
<td>Arm Core up to 600 MHz</td>
<td>Run</td>
<td>Run</td>
<td>Run</td>
<td>Wait</td>
<td>Wait</td>
<td>Power off</td>
<td>OFF</td>
</tr>
<tr>
<td>AHB Clock up to 600 MHz</td>
<td>Run</td>
<td>Run</td>
<td>Run</td>
<td>Up to 24 MHz</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>IPG clock up to 150 MHz</td>
<td>Run</td>
<td>Run</td>
<td>Run</td>
<td>Up to 24 MHz</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>PER clock up to 75 MHz</td>
<td>Run</td>
<td>Run</td>
<td>Run</td>
<td>Up to 24 MHz</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>L1 Cache</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>Powered down</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>PDRET</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>PDRAM0</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>PDRAM1</td>
<td>ON</td>
<td>ON</td>
<td>Powered down</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>System PLL</td>
<td>ON</td>
<td>ON</td>
<td>Powered down</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>Other PLL</td>
<td>ON</td>
<td>ON</td>
<td>Powered down</td>
<td>Powered down</td>
<td>Powered down</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>XTAL</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td>ON</td>
<td>OFF</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>RC OSC</td>
<td>OFF</td>
<td>OFF</td>
<td>ON</td>
<td>Off</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>LDO2P5</td>
<td>ON</td>
<td>OFF</td>
<td>Off</td>
<td>On</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>LDO1P1</td>
<td>ON</td>
<td>Off</td>
<td>Off</td>
<td>On</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>WEEK2P5</td>
<td>OFF</td>
<td>OFF</td>
<td>Off</td>
<td>On</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>WEEK1P1</td>
<td>OFF</td>
<td>OFF</td>
<td>Off</td>
<td>On</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>Bandgap</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td>On</td>
<td>Off</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>Low Power Bandgap</td>
<td>ON</td>
<td>ON</td>
<td>ON</td>
<td>On</td>
<td>ON</td>
<td>OFF</td>
<td></td>
</tr>
<tr>
<td>Module clocks</td>
<td>ON as configured in CCM</td>
<td>ON as configured in CCM</td>
<td>ON as configured in CCM</td>
<td>ON as configured in CCM</td>
<td>ON as configured in CCM</td>
<td>OFF</td>
<td>OFF</td>
</tr>
<tr>
<td>GPIO wakeup</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>RTC wakeup</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>USB remote wakeup</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
<td>Yes</td>
<td>Yes</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Other wakeup source</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
<td>Yes</td>
<td>Yes</td>
<td>No</td>
<td>No</td>
</tr>
</tbody>
</table>

There is a single hardware signal (stop_mode) coming into PMU which sets the PMU in either of two "STOP" states. The STOP state is controlled by the PMU_MISC0[STOP_MODE_CONFIG] bit (See PMU Memory Map/Register).
Definition). It is recommended that the blocks be configured for safe powerdown/up through the registers before asserting the stop_mode signal. Blocks not described in the section below are unaffected by stop_mode.

If the stop_mode_config is set to zero, thus in the STOP mode all blocks powered down in minimum power configuration.

If the stop_mode_config is set to one, thus in the STOP mode some of the blocks remain powered and in different states as defined in the table below.

<table>
<thead>
<tr>
<th>Block</th>
<th>STOP_MODE_CONFIG=0</th>
<th>STOP_MODE_CONFIG=1</th>
</tr>
</thead>
<tbody>
<tr>
<td>reg1p1</td>
<td>off</td>
<td>on</td>
</tr>
<tr>
<td>reg2p5</td>
<td>off</td>
<td>on</td>
</tr>
<tr>
<td>reg3p0</td>
<td>off/on depending on vbus. Uses crude local reference if vbus is present</td>
<td>off/on depending on vbus. Uses analog central bandgap if VBUS is present.</td>
</tr>
<tr>
<td>bandgap</td>
<td>off</td>
<td>functional</td>
</tr>
<tr>
<td>temp_sensor</td>
<td>off</td>
<td>off</td>
</tr>
<tr>
<td>well_bias</td>
<td>hardware controlled</td>
<td>hardware controlled</td>
</tr>
<tr>
<td>All PLLs</td>
<td>off</td>
<td>off</td>
</tr>
<tr>
<td>OSC24M</td>
<td>off</td>
<td>Controlled by CCM configuration</td>
</tr>
</tbody>
</table>

13.4.2 Power management techniques

The device supports the power-management techniques with the features found here.

- Partitioning of the device into voltage, power, clock, and reset domains
- Domain isolation that allows flexible configurations of domains on/off states to form use cases targeting various applications
- Clock tree with selective clock-gating conditions and almost independent clock roots
- Power, reset, and clock control hardware mechanism to manage sleep and wake-up dependencies of power domains
- Software-controllable and hardware-controllable clock gating for functional modules and buses
- Memory retention and state retention capability (Software State Retention for Arm core) for preserving memory contents and device state in low-power modes
- Support for low-power device modes input/output (I/O) pad configuration for minimum power
- Variety of operating modes to optimize device performance and wake-up times
- Thermal monitoring and thermal aware performance management
Many of the low power features are fully or partially software controllable and can be configured for the specific requirements of a target system.

Combining these techniques, the system designer may meet tight requirements of low-power standby and operational modes while maintaining high performance for time-critical tasks.

### 13.4.2.1 Power saving techniques

The table below lists power saving techniques supported by the SoC in their connection to different components of power consumption.

<table>
<thead>
<tr>
<th>Techniques</th>
<th>Active SoC Power</th>
<th>Standby SoC Power</th>
<th>System Power</th>
</tr>
</thead>
<tbody>
<tr>
<td>Temperature Monitoring, and active frequency throttling</td>
<td>✓</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Arm Core Platform SRPG (Software)</td>
<td></td>
<td>✓</td>
<td></td>
</tr>
<tr>
<td>Arm Core Platform Power Gating</td>
<td></td>
<td>✓</td>
<td></td>
</tr>
<tr>
<td>Clock gating (automatic dynamic and forced)</td>
<td>✓</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Integrated PMU (IR drop, efficiency, accuracy)</td>
<td>✓</td>
<td>✓</td>
<td>✓</td>
</tr>
<tr>
<td>C4 package (IR drop, thermal)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Display Backlight optimization (SW)</td>
<td></td>
<td></td>
<td>✓</td>
</tr>
<tr>
<td>Architecture: FlexRAM memories</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Architecture: USB integration</td>
<td></td>
<td></td>
<td>✓</td>
</tr>
<tr>
<td>Low Power DRAM: SDRAM</td>
<td></td>
<td></td>
<td>✓</td>
</tr>
</tbody>
</table>

### 13.4.2.2 Thermal-aware power management

The temperature sensor block (TEMPMON) implements a temperature sensor/conversion function. The block features an alarm function that can raise an interrupt signal if the temperature is above a specified threshold.

Software may implement temperature aware DVFS for the Arm domain as well as temperature aware frequency scaling for other system components to ensure that both the frequency and voltage is lowered when the die temperature is above the specified limit.

Software may also implement temperature aware task scheduling to ensure that non-critical tasks are suspended when the die temperature is above the specified limit.

See Temperature Monitor (TEMPMON) for further details on temperature monitor functions and programmability options.
13.4.2.3 Peripheral Power management

13.4.2.3.1 IO power reduction

Software configures IO to low power modes:

- PHYs - make sure that all unused PHYs are placed to lowest power state. Please refer relevant chapter for further information about different PHYs
- Digital IOs - Make sure all unnecessary PU/PD are disabled and IO are switched to either minimal drive strength or to input mode (when applicable)

13.4.2.4 Examples of External Power Supply Interface

This section presents the example of external power supply interfacing to the chip.

The scenario based on integrated PMU system is presented in the following figure. This scenario minimizes BoM and board design complexity.
13.5 ONOFF (Button)

The chip supports the use of a button input signal to request main SoC power state changes (i.e. On or Off) from the PMU.

The ONOFF logic inside of SNVS_LP allows for connecting directly to a PMIC or other voltage regulator device. The logic takes a button input signal and then outputs a pmic_en_b and set_pwr_off_irq signal. PMIC logic also supports the SNVS_LP tamper logic which will allow waking the system up when a tamper event has happened while in the OFF state. The logic has two different modes of operation (Dumb and Smart mode).

The Dumb PMIC mode uses a 2 state state machine, as shown below. The output of the pmic_en_b is generated by the state of the state machine.
The Dumb PMIC Mode uses pmic_en_b to issue a level signal for on and off. Dumb pmic mode has many different configuration options which include (debounce, off to on time, and max time out).

- **Debounce**: The debounce configuration supports 0 msec, 50 msec, 100 msec and 500 msec. The debounce is used to generate the set_pwr_off_irq interrupt. While in the ON state and the button is pressed longer than the debounce time the set_pwr_off_irq is generated.
- **Off to On Time**: The Off to On configuration supports 0 msec, 50 msec, 100 msec, and 500 msec. This configuration supports the time it takes to request power on after the configured button press time has been reached. After the button is pressed longer than the configuration time, the state machine will transition from the OFF to the ON state.
- **Max Timeout**: The max timeout configuration supports 5 secs, 10 secs, 15 secs and disable. This configuration supports the time it takes to request power down after the button has been pressed for the defined time.

The Smart PMIC mode is meant to connect to another PMIC. The pmic_en_b signal issues a pulse instead of a level signal. The only configuration option available for this mode is the Debounce configuration that is used for the set_pwr_off_irq.

### 13.6 WAKEUP Pin

This chip supports the use of a WAKEUP pin (GPIO5_IO00 ALT5) to request main SoC power on to exit SNVS mode. To use it, follow the tips below.
• SNVS must be in Dumb PMIC mode (default, and must for on-chip DCDC)
• Configure IOMUXC_SNVS to select WAKEUP pin ALT5 to mux it to GPIO5_IO00
• Configure GPIO5 ICR to either low level or high level sensitive
• Set GPIO5 IMR bit0 to enable GPIO5_IO00 interrupt
• Enter SNVS mode by SW or ON/OFF button, then on-chip DCDC will be off, and PMIC_ON_REQ pin will also go to low to notify outside
• Assert WAKEUP pin for at least two 32 KHz cycles (active high or low depends on GPIO5 ICR configuration), so that GPIO5 interrupt gets sampled by SNVS module
• SNVS will assert PMIC_ON_REQ pin high and on-chip DCDC begins to ramp on
• SoC power on procedure (except SNVS) begins (ROM boot, …)
Chapter 14
Clock Controller Module (CCM)

14.1 Chip-specific CCM information

Table 14-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

**NOTE**

The OCRAM clock cannot be turned off when CM7 Cache is running, on this device. See CCM_CCGR3[CG14] bitfield.

System STOP/WAIT status can be observed on pin. See CCM_STOP/CCM_WAIT in the "Muxing Options" table of the External Signals and Pin Multiplexing chapter, for pin muxing details.

14.2 Overview

The Clock Control Module (CCM) generates and controls clocks to the various modules in the design and manages low power modes. This module uses the available clock sources to generate the clock roots.
The Clock Controller Module controls the following functions:

- Uses the available clock sources to generate clock roots to various parts of the chip:
  - PLL1 also referenced as ARM PLL
  - PLL2 also referenced as System PLL
  - PLL3 also referenced as USB1 PLL
  - PLL4 also referenced as Audio PLL
  - PLL5 also referenced as Video PLL
  - PLL6 also referenced as ENET PLL
  - PLL7 also referenced as USB2 PLL (This PLL is only used by the USB UTM interface through a direct connection.)
- Uses programmable bits to control frequencies of the clock roots.
- Controls the low power mechanism.
- Provides control signals to LPCG for gating clocks.
- Provides handshake with SRC for reset performance.
- Provides handshake with GPC for support of power gating operations.

14.2.1 Features

The CCM includes these distinctive features:

- Provides root clock to SoC modules based on several source clocks.
- Arm core root clock is generated from a dedicated source clock.
- Includes separate dividers to control generation of core and bus root clocks (AXI, AHB, IPG).
- Includes separate dividers and clock source selectors for each serial root clock.
- Optional external clocks to bypass PLL clocks.
- Selects clock signals to output on CCM_CLKO onto the pads for observability.
- Controllable registers are accessible via IP bus.
- Manages the Low Power Modes, namely RUN, WAIT and STOP. The gating of the peripheral clocks is programmable in RUN and WAIT modes.
- Manages frequency scaling procedure for Arm core clock by shifting between PLL sources, without loss of clocks.
- Manages frequency scaling procedure for peripheral root clock by programmable divider. The division is done on the fly without loss of clocks.
- Interface for the following IPs:
  - PLL - Interfaces for each PLL
  - LPCG - Low Power Clock Gating unit
  - SRC - System Reset Controller
  - GPC - General Power Controller
14.2.2 CCM Block Diagram

CCM contains the following sub-blocks:

**Table 14-2. CCM Sub-blocks**

<table>
<thead>
<tr>
<th>CCM_CLK_SRC_DIV Sub-block</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_CLK_IGNITION</td>
<td>Manages the ignition process. This module starts its functionality after CCM comes out of reset. It manages the process that begins with starting the OSC, PLLs and finishes with creation of stable output root clocks after reset.</td>
</tr>
<tr>
<td>CCM_CLK_SWITCHER</td>
<td>Receives the clock outputs of the PLLs, together with the bypass clocks for the PLLs, and generates switcher clock outputs (pll3_sw_clk) for the CCM_CLK_ROOT_GEN sub-module.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 14-2. CCM Sub-blocks (continued)

<table>
<thead>
<tr>
<th>CCM_CLK_SRC_DIV Sub-block</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_CLK_ROOT_GEN</td>
<td>Receives the main clocks (PLLs / PFDs) and generates the output root clocks.</td>
</tr>
<tr>
<td>CCM_CLK_LOGIC</td>
<td>Generates the clock enables. It generates the clock enable signals based on info from CCM_LPM and CCM_IP. The clock enables are used in LPCG to turn off and on the split clocks.</td>
</tr>
<tr>
<td>CCM_LPM</td>
<td>Manages the low power modes of the IC.</td>
</tr>
<tr>
<td>CCM_HND_SK</td>
<td>Manages the handshake when changing certain root clock dividers that require handshake.</td>
</tr>
</tbody>
</table>

14.3 External Signals

The following table describes the external signals of CCM:

Table 14-3. CCM External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCM_REF_EN_B</td>
<td>Enable external reference clock (CKIH)</td>
<td>GPIO_SD_B1_07</td>
<td>ALT6</td>
<td>O</td>
</tr>
<tr>
<td>CCM_CLKO1</td>
<td>Observability clock 1 output</td>
<td>GPIO_SD_B0_04</td>
<td>ALT6</td>
<td>O</td>
</tr>
<tr>
<td>CCM_CLKO2</td>
<td>Observability clock 2 output</td>
<td>GPIO_SD_B0_05</td>
<td>ALT6</td>
<td>O</td>
</tr>
<tr>
<td>CCM_PMIC_STBY_REQ</td>
<td>Signal coming from PMIC to indicate that the voltage started to change in PMIC_STBY_REQ. CCM will ignore this indication if CLPCR [BYPASS_PMIC READY] is set.</td>
<td>PMIC_STBY_REQ</td>
<td>ALT0</td>
<td>I</td>
</tr>
<tr>
<td>CCM_PMIC_READY</td>
<td>Signal goes to STANBY_REQ pin, which notifies external power management IC to move from functional voltage to standby voltage.</td>
<td>GPIO_AD_B0_12</td>
<td>ALT1</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMC_32</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_08</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_01</td>
<td>ALT4</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_SD_B1_03</td>
<td>ALT6</td>
<td>O</td>
</tr>
</tbody>
</table>

14.4 CCM Clock Tree

The following figures (Part 1 and Part 2) show the clock tree configuration and clock roots for CCM.

For detailed sub-block information, see:

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
• Clock Switcher
• Clock Root Generator
• Low Power Clock Gating module (LPCG)
• System Clocks

**NOTE**

The default frequency values (in MHz) for the PLLs and PFDs are shown in the Clock Tree diagram that follows. The PLLs and PFDs control registers may be reprogrammed according to the speed grade of the SoC being used, but should not exceed that maximum setting for that speed grade.
NOTE

In this device, the clock root for FlexIO3 is also flexio2_clk_root, and the bitfield of clock selector/divider is shared for FlexIO2/FlexIO3.

14.5 System Clocks

The table found here shows the CCM output clocks' system-level connectivity.
The gating option in the table can either be CGR bit or clock enable from the block itself. Applicable override bits are also shown.

**Table 14-4. System Clocks, Gating, and Override**

<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACMPn</td>
<td>acmp1 clocks</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG10]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(acmp1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>acmp2 clocks</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG11]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(acmp2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>acmp3 clocks</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG12]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(acmp3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>acmp4 clocks</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG13]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(acmp4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>ADCn</td>
<td>adc1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG8]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(adc1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>adc2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG4]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(adc2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>ADC_ETC</td>
<td>adc_etc_ipg_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td>AIPS</td>
<td>aips_tz1_hclk</td>
<td>ahb_clk_root</td>
<td>CCGR0[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(aips_tz1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>aips_tz2_hclk</td>
<td>ahb_clk_root</td>
<td>CCGR0[CG1]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(aips_tz2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>aips_tz3_hclk</td>
<td>ahb_clk_root</td>
<td>CCGR6[CG9]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(aips_tz3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>aips_tz4_hclk</td>
<td>ahb_clk_root</td>
<td>CCGR5[CG6]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(aips_tz4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>AOIn</td>
<td>aoi1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG4]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(aoi1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>aoi2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG7]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(aoi2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>Arm CM7</td>
<td>cm7_mxrt_ipg_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>cm7_mxrt_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>cm7_mxrt_trace_clk_in</td>
<td>trace_clk_root</td>
<td>CCGR0[CG11]</td>
<td>(trace_clk_enable)</td>
</tr>
<tr>
<td></td>
<td>cm7_mxrt_main_clk</td>
<td>ahb_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>cm7_mxrt_axi_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td>BEE</td>
<td>bee_clk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG3]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(bee_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>CANN</td>
<td>can1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG7]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(can1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>can1_ipg_clk_chi</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG7]</td>
<td>(can1_clk_enable)</td>
</tr>
<tr>
<td></td>
<td>can1_ipg_clk_pe</td>
<td>can_clk_root</td>
<td>CCGR0[CG8]</td>
<td>(can1_serial_clk_enable)</td>
</tr>
<tr>
<td></td>
<td>can1_ipg_clk_pe_nogate</td>
<td>can_clk_root</td>
<td></td>
<td>(CMEOR[MOD_EN_OV_CAN1_CPI])</td>
</tr>
</tbody>
</table>
Table 14-4. System Clocks, Gating, and Override (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>can1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG7] (can1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>can1_mem_ram_CLK</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG7] (can1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>can2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG9] (can2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>can2_ipg_clk_chi</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG9] (can2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>can2_ipg_clk_pe</td>
<td>can_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG10] (can2_serial_clk_enable)</td>
<td>CMEOR[MOD_EN_OV_CAN2_CPI]</td>
</tr>
<tr>
<td>can2_ipg_clk_pe_nogate</td>
<td>can_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>can2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG9] (can2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>can2_mem_ram_CLK</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG9] (can2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>canfd_ipg_clk</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG3] (canfd_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>canfd_ipg_clk_chi</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG3] (canfd_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>canfd_ipg_clk_pe</td>
<td>can_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG4] (canfd_serial_clk_enable)</td>
<td>CMEOR[MOD_EN_OV_CAN2_CPI]</td>
</tr>
<tr>
<td>canfd_ipg_clk_pe_nogate</td>
<td>can_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ccm_ccm_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG3] (canfd_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>ccm_ipg_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CSI</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>csi_csi_hclk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>csi_ipg_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>csi_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>csi_ipg_clk_s_raw</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>csi_mem_rxfifo_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CSU</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>csu_ap_ckil_clk</td>
<td>ckil_sync_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>csu_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DCDC</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>dcc_clock</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DCP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>dcp_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 14-4. System Clocks, Gating, and Override (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>dcp_mem_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td>CCGR0[CG5]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(dcp_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>DMA_MUX</td>
<td>dma_ch_mux_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG3]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(dma_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>dma_ch_mux_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG3]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(dma_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>EDMA</td>
<td>edma_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG3]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(dma_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>edma_hclk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG3]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(dma_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>ENCn</td>
<td>enc1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG12]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enc1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enc2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG13]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enc2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enc3_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG14]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enc3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enc4_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG15]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enc4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>ENET</td>
<td>enet_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG5]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet_ipg_clk_mac0</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG5]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet_ipg_clk_mac0_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG5]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG5]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet_ipg_clk_time</td>
<td>ref_enetpll2_clk</td>
<td>CCGR1[CG5]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet_mem_mac0_mem_clock</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG5]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>ENET2</td>
<td>enet2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet2_ipg_clk_mac0</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet2_ipg_clk_mac0_s</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet2_ipg_clk_time</td>
<td>ref_enetpll2_clk</td>
<td>CCGR7[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>enet2_mem_mac0_mem_clock</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(enet_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>EWM</td>
<td>ewm_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG7]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(ewm_clk_enable)</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 14-4. System Clocks, Gating, and Override (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>ewm_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG7]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(ewm_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ewm_lpo_clk_0</td>
<td>ref_1m_clk (1MHz clock generated from the 24MHz RC oscillator)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ewm_lpo_clk_1</td>
<td>ckil_sync_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXIO</td>
<td>flexio1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG1]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(flexio1_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG1]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio1_flexio_clk</td>
<td>flexio1_clk_root</td>
<td>CCGR5[CG1]</td>
<td>(flexio1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>flexio2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG0]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio2_clk_enable</td>
<td></td>
<td>(flexio2_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG0]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio2_flexio_clk</td>
<td>flexio2_clk_root</td>
<td>CCGR3[CG0]</td>
<td>(flexio2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>flexio3_ipg_clk</td>
<td>ahb_clk_root</td>
<td>CCGR7[CG6]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio3_clk_enable</td>
<td></td>
<td>(flexio3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio3_ipg_clk_s</td>
<td>ahb_clk_root</td>
<td>CCGR7[CG6]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexio3_flexio_clk</td>
<td>flexio2_clk_root</td>
<td>CCGR7[CG6]</td>
<td>(flexio3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>FLEXPWMn</td>
<td>flexpwm1_ipg_clk_0</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG8]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(pwm1_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm1_ipg_clk_1</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG8]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm1_ipg_clk_2</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG8]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm1_ipg_clk_3</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG8]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm1_ipg_clk_flt</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG8]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm1_ipg_clk_cfg</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG8]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm2_ipg_clk_0</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG9]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm2_ipg_clk_1</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG9]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm2_ipg_clk_2</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG9]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm2_ipg_clk_3</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG9]</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 14-4. System Clocks, Gating, and Override (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>flexpwm2_ipg_clk_flt</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG9] (pwm2_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm2_ipg_clk_cfg</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG9] (pwm2_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm3_ipg_clk_0</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG10] (pwm3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm3_ipg_clk_1</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG10] (pwm3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm3_ipg_clk_2</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG10] (pwm3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm3_ipg_clk_3</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG10] (pwm3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm3_ipg_clk_flt</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG10] (pwm3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm3_ipg_clk_cfg</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG10] (pwm3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm4_ipg_clk_0</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG11] (pwm4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm4_ipg_clk_1</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG11] (pwm4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm4_ipg_clk_2</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG11] (pwm4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm4_ipg_clk_3</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG11] (pwm4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm4_ipg_clk_flt</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG11] (pwm4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>flexpwm4_ipg_clk_cfg</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG11] (pwm4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXRAM</td>
<td>flexram clock</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG9] (flexram_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>FLEXSPI</td>
<td>flexspi_hclk</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG5] (flexspi_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>flexspi_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG5] (flexspi_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>flexspi_ipg_clk_sfck</td>
<td>flexspi_clk_root</td>
<td>CCGR6[CG5] (flexspi_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>flexspi_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG5] (flexspi_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>FLEXSPI2</td>
<td>flexspi2_hclk</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG1] (flexspi_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>flexspi2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR7[CG1] (flexspi_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>flexspi2_ipg_clk_sfck</td>
<td>flexspi2_clk_root</td>
<td>CCGR7[CG1] (flexspi_clk_enable)</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>flexspi2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
<td>CCGR7[CG1] (flexspi_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>GPC</td>
<td>gpc_ipg_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpc_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpc_pgc_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpc_sys_clk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td>GPIOn</td>
<td>gpio1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG13] (gpio1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG15] (gpio2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio3_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG13] (gpio3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio4_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG6] (gpio4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio5_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG15] (gpio5_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio6_ipg_clk_s</td>
<td>ahb_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio7_ipg_clk_s</td>
<td>ahb_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio8_ipg_clk_s</td>
<td>ahb_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpio9_ipg_clk_s</td>
<td>ahb_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td>GPTn</td>
<td>gpt1_ipg_clk</td>
<td>perclk_clk_root</td>
<td>CCGR1[CG11] (gpt1_serial_clk_enable)</td>
<td>CMEOR[mod_en_ov_gpt]</td>
</tr>
<tr>
<td></td>
<td>gpt1_ipg_clk_24m</td>
<td>xtal_clkout</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpt1_ipg_clk_32k</td>
<td>c kil_sync_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpt1_ipg_clk_highfreq</td>
<td>perclk_clk_root</td>
<td>CCGR1[CG10] (gpt1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpt1_ipg_clk_s</td>
<td>perclk_clk_root</td>
<td>CCGR1[CG10] (gpt1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpt2_ipg_clk</td>
<td>perclk_clk_root</td>
<td>CCGR0[CG12] (gpt2_clk_enable)</td>
<td>CMEOR[mod_en_ov_gpt]</td>
</tr>
<tr>
<td></td>
<td>gpt2_ipg_clk_24m</td>
<td>xtal_clkout</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpt2_ipg_clk_32k</td>
<td>c kil_sync_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpt2_ipg_clk_highfreq</td>
<td>perclk_clk_root</td>
<td>CCGR0[CG13] (gpt2_serial_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>gpt2_ipg_clk_s</td>
<td>perclk_clk_root</td>
<td>CCGR0[CG12] (gpt2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>IOMUXC</td>
<td>iomuxc_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG1] (iomuxc_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>iomuxc_snvs_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG2] (iomuxc_snvs_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>iomuxc_snvs_gpr_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG15] (iomuxc_snvs_gpr_clk_enable)</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>iomuxc_gpr_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
<td>CCGR4[CG2] (iomuxc_gpr_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>KPP</td>
<td>kpp_ipg_clk_32k</td>
<td>clkl_sync_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>kpp_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG4] (kpp_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>LCDIF</td>
<td>lcdif_apb_clk</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG14] (lcdif_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lcdif_pix_clk</td>
<td>lcdif_clk_root</td>
<td>CCGR3[CG5] (lcdif_pix_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>LPI2Cn</td>
<td>lpi2c1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG3] (lpi2c1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG3] (lpi2c1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c1_lpi2c_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR2[CG3] (lpi2c1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c1_lpi2c_div_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR2[CG3] (lpi2c1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG4] (lpi2c2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG4] (lpi2c2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c2_lpi2c_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR2[CG4] (lpi2c2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c2_lpi2c_div_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR2[CG4] (lpi2c2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c3_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG5] (lpi2c3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c3_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG5] (lpi2c3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c3_lpi2c_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR2[CG5] (lpi2c3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c3_lpi2c_div_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR2[CG5] (lpi2c3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c4_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG12] (lpi2c4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c4_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG12] (lpi2c4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c4_lpi2c_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR6[CG12] (lpi2c4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpi2c4_lpi2c_div_clk</td>
<td>lpi2c_clk_root</td>
<td>CCGR6[CG12] (lpi2c4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>LPSPIn</td>
<td>lpspi1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG0] (lpspi1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>lpspi1_lpspi_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG0] (lpspi1_clk_enable)</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>lpspi1_lpspi_div_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG0]</td>
<td>(lpspi1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG0]</td>
<td>(lpspi1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG1]</td>
<td>(lpspi2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi2_lpspi_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG1]</td>
<td>(lpspi2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi2_lpspi_div_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG1]</td>
<td>(lpspi2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG1]</td>
<td>(lpspi2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi3_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG2]</td>
<td>(lpspi3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi3_lpspi_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG2]</td>
<td>(lpspi3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi3_lpspi_div_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG2]</td>
<td>(lpspi3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi3_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG2]</td>
<td>(lpspi3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi4_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG3]</td>
<td>(lpspi4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi4_lpspi_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG3]</td>
<td>(lpspi4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi4_lpspi_div_clk</td>
<td>lpspi_clk_root</td>
<td>CCGR1[CG3]</td>
<td>(lpspi4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpspi4_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG3]</td>
<td>(lpspi4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG12]</td>
<td>(lpuart1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG12]</td>
<td>(lpuart1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart1_lpuart_baud_clk</td>
<td>uart_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>lpuart1_lpuart_baud_gated_clk</td>
<td>uart_clk_root</td>
<td>CCGR5[CG12]</td>
<td>(lpuart1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG14]</td>
<td>(lpuart2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG14]</td>
<td>(lpuart2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart2_lpuart_baud_clk</td>
<td>uart_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>lpuart2_lpuart_baud_gated_clk</td>
<td>uart_clk_root</td>
<td>CCGR0[CG14]</td>
<td>(lpuart2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart3_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG6]</td>
<td>(lpuart3_clk_enable)</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>lpuart3_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG6]</td>
<td>(lpuart3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart3_lpuart_baud_clk</td>
<td>uart_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>lpuart3_lpuart_baud_gated_clk</td>
<td>uart_clk_root</td>
<td>CCGR0[CG6]</td>
<td>(lpuart3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart4_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG12]</td>
<td>(lpuart4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart4_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR1[CG12]</td>
<td>(lpuart4_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart4_lpuart_baud_clk</td>
<td>uart_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>lpuart5_lpuart_baud_gated_clk</td>
<td>uart_clk_root</td>
<td>CCGR3[CG1]</td>
<td>(lpuart5_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart5_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG3]</td>
<td>(lpuart6_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart5_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR3[CG3]</td>
<td>(lpuart6_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart6_lpuart_baud_clk</td>
<td>uart_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>lpuart6_lpuart_baud_gated_clk</td>
<td>uart_clk_root</td>
<td>CCGR3[CG3]</td>
<td>(lpuart6_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart7_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG13]</td>
<td>(lpuart7_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart7_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG13]</td>
<td>(lpuart7_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart7_lpuart_baud_clk</td>
<td>uart_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>lpuart7_lpuart_baud_gated_clk</td>
<td>uart_clk_root</td>
<td>CCGR5[CG13]</td>
<td>(lpuart7_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart8_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG7]</td>
<td>(lpuart8_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart8_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG7]</td>
<td>(lpuart8_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>lpuart8_lpuart_baud_clk</td>
<td>uart_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>lpuart8_lpuart_baud_gated_clk</td>
<td>uart_clk_root</td>
<td>CCGR6[CG7]</td>
<td>(lpuart8_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>MQS</td>
<td>mqs clock</td>
<td>sai3_clk_root</td>
<td>CCGR0[CG2]</td>
<td>(mqs_hmclk_clock_enable)</td>
</tr>
<tr>
<td>OCOTP</td>
<td>oocotp_ctrl_wrapper_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG6]</td>
<td>(oocotp_clk_enable)</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>ocotp_ctrl_wrapper_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG6]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(ocotp_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PIT</td>
<td>pit_ipg_clk</td>
<td>perclk_clk_root</td>
<td>CCGR1[CG6] (pit_clk_enable)</td>
<td>CMEOR[mod_en_ov_pit]</td>
</tr>
<tr>
<td></td>
<td>pit_ipg_clk_osc_rti</td>
<td>kil_sync_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>pit_ipg_clk_sync</td>
<td>perclk_clk_root</td>
<td>CCGR1[CG6] (pit_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>pit_ipg_clk_s</td>
<td>perclk_clk_root</td>
<td>CCGR1[CG6] (pit_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>PXP</td>
<td>pxp_clk</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG15]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(pxp_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>QTIMERn</td>
<td>qtimer1_clk0</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG13]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer1_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer1_clk1</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG13]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer1_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer1_clk2</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG13]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer1_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer1_clk3</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG13]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer1_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer2_clk0</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG14]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer2_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer2_clk1</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG14]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer2_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer2_clk2</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG14]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer2_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer2_clk3</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG14]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer2_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer3_clk0</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG15]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer3_clk1</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG15]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer3_clk2</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG15]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer3_clk3</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG15]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer3_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer4_clk0</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG8]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer4_clk1</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG8]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer4_clk2</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG8]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>qtimer4_clk3</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG8]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(qtimer4_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ROMCP</td>
<td>rom_96k_rom_CLK</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(rom_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>romcp_hclk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG0]</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>(rom_clk_enable)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
## System Clocks

### Table 14-4. System Clocks, Gating, and Override (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>romcp_hclk_reg</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG0] (rom_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>romcp_sec_mst_hclk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG0] (rom_clk_enable)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>SAI1n</td>
<td>sai1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG9] (sai1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG9] (sai1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai1_ipg_clk_sai_mclk[1]</td>
<td>sai1_mclk1_mux_clk</td>
<td>CCGR5[CG9] (sai1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR1[SAI1_MCLK1_SEL]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai1_ipg_clk_sai_mclk[2]</td>
<td>sai1_mclk2_mux_clk</td>
<td>CCGR5[CG9] (sai1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR1[SAI1_MCLK2_SEL]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai1_ipg_clk_sai_mclk[3]</td>
<td>sai1_mclk3_mux_clk</td>
<td>CCGR5[CG9] (sai1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR1[SAI1_MCLK3_SEL]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipg_clk_sai_mclk[1]</td>
<td>sai2_clk_root</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR1[SAI1_MCLK1_SEL]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipg_clk_sai_mclk[2]</td>
<td>sai2_mclk2_mux_clk</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR1[SAI2_MCLK2_SEL]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipg_clk_sai_mclk[3]</td>
<td>sai2_mclk3_mux_clk</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUXC_GPR_GPR1[SAI2_MCLK3_SEL]</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipt_clk_sai_bclk</td>
<td>sai2_clk_root</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipt_clk_sai_bclk_b</td>
<td>sai2_clk_root</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai2_ipt_clk_sai_mclk</td>
<td>sai2_clk_root</td>
<td>CCGR5[CG10] (sai2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>sai3_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG11] (sai3_clk_enable)</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>sai3_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG11]</td>
<td>(sai3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>sai3_ipg_clk_sai_mclk[1]</td>
<td></td>
<td>sai3_clk_root</td>
<td>CCGR5[CG11]</td>
<td>(sai3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>sai3_ipg_clk_sai_mclk[2]</td>
<td></td>
<td>iOMUX_top.sai3_ipg_clk_sai_mclk</td>
<td>CCGR5[CG11]</td>
<td>(sai3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>sai3_ipt_clk_sai_bclk</td>
<td></td>
<td>sai3_clk_root</td>
<td>CCGR5[CG11]</td>
<td>(sai3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>sai3_ipt_clk_sai_bclk_b</td>
<td></td>
<td>sai3_clk_root</td>
<td>CCGR5[CG11]</td>
<td>(sai3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>sai3_ipt_clk_sai_mclk</td>
<td></td>
<td>sai3_clk_root</td>
<td>CCGR5[CG11]</td>
<td>(sai3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SEMC</td>
<td>semc clock</td>
<td>semc_clk_root</td>
<td>CCGR3[CG2]</td>
<td>(semc_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SIM</td>
<td>sim_emss_mainclk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG7]</td>
<td>(sim_emss_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sim_m_mainclk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG6]</td>
<td>(sim_m_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sim_m_mainclk_r</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG4]</td>
<td>(sim_m_mainclk_r_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sim_m7_mainclk</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG4]</td>
<td>(sim_m7_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sim_m7_mainclk_r</td>
<td>ipg_clk_root</td>
<td>CCGR4[CG0]</td>
<td>(sim_m7_mainclk_r_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sim_main_mainclk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG8]</td>
<td>(sim_main_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sim_main_mainclk_r</td>
<td>ipg_clk_root</td>
<td>CCGR0[CG4]</td>
<td>(sim_main_mainclk_r_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>sim_per_mainclk</td>
<td>ipg_clk_root</td>
<td>CCGR6[CG10]</td>
<td>(sim_per_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SNVS</td>
<td>snvs_hp_wrapper_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG14]</td>
<td>(snvs_hp_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>snvs_hp_wrapper_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG14]</td>
<td>(snvs_hp_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>snvs_hp_wrapper_ipg_hip_RTC_clk</td>
<td>clkil_sync_clk_root</td>
<td>CCGR5[CG14]</td>
<td>(snvs_hp_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>snvs_lp_wrapper_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG15]</td>
<td>(snvs_lp_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>snvs_lp_wrapper_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG15]</td>
<td>(snvs_lp_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>snvs_lp_wrapper_ipg_drvclk</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>yice_clk_s</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SPDIF</td>
<td>spdif_gclkw_t0</td>
<td>ipg_clk_root</td>
<td>CCGR5(CG7) (spdifi_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>spdif_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>spdif_tx_clk</td>
<td>spdifi0_clk_root</td>
<td>CCGR5(CG7) (spdifi_clk_enable)</td>
</tr>
<tr>
<td></td>
<td>SRC</td>
<td>src_src_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td></td>
</tr>
<tr>
<td></td>
<td>TRNG</td>
<td>trng_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG6) (trng_clk_enable) CMEOR[mod_en_ov_trng]</td>
</tr>
<tr>
<td></td>
<td>TSC</td>
<td>tsc_dig_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR4(CG5) (tsc_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>tsc_dig_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR4(CG5) (tsc_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>tsc_dig_ipg_clk_perclk</td>
<td>usdhc1_clk_root</td>
<td>CCGR6(CG1) (usdhc1_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td>USB</td>
<td>usb_ipg_ahb_clk</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG0) (usboh3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usb_ipg_clk_32khz</td>
<td>ckil_sync_clk_root</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>usb_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG0) (usboh3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usb_ipg_clk_s_pl301</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG0) (usboh3_clk_enable)</td>
</tr>
<tr>
<td></td>
<td>USDHCn</td>
<td>usdhc1_hclk</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG1) (usdhc1_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usdhc1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG1) (usdhc1_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usdhc1_ipg_clk_perclk</td>
<td>usdhc1_clk_root</td>
<td>CCGR6(CG1) (usdhc1_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usdhc1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG1) (usdhc1_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usdhc2_hclk</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG2) (usdhc2_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usdhc2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG2) (usdhc2_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usdhc2_ipg_clk_perclk</td>
<td>usdhc2_clk_root</td>
<td>CCGR6(CG2) (usdhc2_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td></td>
<td>usdhc2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR6(CG2) (usdhc2_clk_enable) CMEOR[mod_en_ov_usdhc]</td>
</tr>
<tr>
<td></td>
<td>WDOGn</td>
<td>wdog1_ipg_clk</td>
<td>ipg_clk_root</td>
<td>CCGR3(CG8) (wdog1_clk_enable)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>wdog1_ipg_clk_32k</td>
<td>ckil_sync_clk_root</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>wdog1_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>CCGR3(CG8) (wdog1_clk_enable)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 14-4. System Clocks, Gating, and Override (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Module Clock</th>
<th>Clock Root</th>
<th>Module Clock Gating Enable</th>
<th>Module Override Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>wdog2_ipg_clk</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG5] (wdog2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>wdog2_ipg_clk_32k</td>
<td>ckl_sync_clk_root</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>wdog2_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG5] (wdog2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>wdog3_ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td>wdog3_ipg_clk</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR5[CG2] (wdog3_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>wdog3_lpo_clk</td>
<td>ckl_sync_clk_root</td>
<td>ckl_sync_clk_root</td>
<td></td>
<td></td>
</tr>
<tr>
<td>wdog3_ext_clk</td>
<td>ref_1m_clk (1MHz clock generated from the 24MHz RC oscillator)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>XBARn</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>xbar1_ipb_clk</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG11] (xbar1_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>xbar2_ipb_clk</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG12] (xbar2_clk_enable)</td>
<td></td>
</tr>
<tr>
<td>xbar3_ipb_clk</td>
<td>ipg_clk_root</td>
<td>ipg_clk_root</td>
<td>CCGR2[CG7] (xbar3_clk_enable)</td>
<td></td>
</tr>
</tbody>
</table>

### Table 14-5. System Clock Frequency Values

<table>
<thead>
<tr>
<th>Clock Root</th>
<th>Default Frequency (POR) (MHz)</th>
<th>Overdrive Run</th>
<th>Full Speed Run</th>
<th>Low Power Run</th>
<th>System Idle</th>
<th>Low Power Idle</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDD_SOC_IN voltage</td>
<td></td>
<td>1.25V min</td>
<td>1.15V min</td>
<td>0.925V min</td>
<td>1.15V min</td>
<td>0.925V min</td>
</tr>
<tr>
<td>AHB_CLK_ROOT</td>
<td>12</td>
<td>600</td>
<td>528</td>
<td>24</td>
<td>528</td>
<td>24</td>
</tr>
<tr>
<td>IPG_CLK_ROOT</td>
<td>3</td>
<td>150</td>
<td>132</td>
<td>24</td>
<td>132</td>
<td>24</td>
</tr>
<tr>
<td>PERCLK_CLK_ROOT</td>
<td>6</td>
<td>75</td>
<td>72</td>
<td>24</td>
<td>72</td>
<td>24</td>
</tr>
<tr>
<td>USDHC1_CLK_ROOT</td>
<td>12</td>
<td>200</td>
<td>200</td>
<td>24</td>
<td>200</td>
<td>24</td>
</tr>
<tr>
<td>USDHC2_CLK_ROOT</td>
<td>12</td>
<td>200</td>
<td>200</td>
<td>24</td>
<td>200</td>
<td>24</td>
</tr>
<tr>
<td>SEMC_CLK_ROOT</td>
<td>8</td>
<td>166</td>
<td>166</td>
<td>24</td>
<td>166</td>
<td>24</td>
</tr>
<tr>
<td>CSI_CLK_ROOT</td>
<td>12</td>
<td>80</td>
<td>80</td>
<td>24</td>
<td>80</td>
<td>24</td>
</tr>
<tr>
<td>FLEXSPI_CLK_ROOT</td>
<td>2</td>
<td>332</td>
<td>332</td>
<td>24</td>
<td>332</td>
<td>24</td>
</tr>
<tr>
<td>FLEXSPI2_CLK_ROOT</td>
<td>12</td>
<td>332</td>
<td>332</td>
<td>24</td>
<td>332</td>
<td>24</td>
</tr>
<tr>
<td>LPSPI_CLK_ROOT</td>
<td>6</td>
<td>132</td>
<td>132</td>
<td>24</td>
<td>132</td>
<td>24</td>
</tr>
<tr>
<td>TRACE_CLK_ROOT</td>
<td>6</td>
<td>150</td>
<td>132</td>
<td>24</td>
<td>132</td>
<td>24</td>
</tr>
<tr>
<td>SAI1_CLK_ROOT</td>
<td>3</td>
<td>66</td>
<td>66</td>
<td>24</td>
<td>66</td>
<td>24</td>
</tr>
<tr>
<td>SAI2_CLK_ROOT</td>
<td>3</td>
<td>66</td>
<td>66</td>
<td>24</td>
<td>66</td>
<td>24</td>
</tr>
<tr>
<td>SAI3_CLK_ROOT</td>
<td>3</td>
<td>66</td>
<td>66</td>
<td>24</td>
<td>66</td>
<td>24</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 14-5. System Clock Frequency Values (continued)

<table>
<thead>
<tr>
<th>Clock Root</th>
<th>Default Frequency (POR) (MHz)</th>
<th>Maximum Frequency (MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Overdrive Run</td>
</tr>
<tr>
<td>VDD_SOC_IN voltage</td>
<td></td>
<td>1.25V min</td>
</tr>
<tr>
<td>LPI2C_CLK_ROOT</td>
<td>24</td>
<td>66</td>
</tr>
<tr>
<td>CAN_CLK_ROOT</td>
<td>OFF</td>
<td>80</td>
</tr>
<tr>
<td>UART_CLK_ROOT</td>
<td>4</td>
<td>80</td>
</tr>
<tr>
<td>LCDIF_CLK_ROOT</td>
<td>3</td>
<td>75</td>
</tr>
<tr>
<td>SPDIF0_CLK_ROOT</td>
<td>1.5</td>
<td>66</td>
</tr>
<tr>
<td>FLEXIO1_CLK_ROOT</td>
<td>1.5</td>
<td>120</td>
</tr>
<tr>
<td>FLEXIO2_CLK_ROOT</td>
<td>1.5</td>
<td>120</td>
</tr>
</tbody>
</table>

### 14.6 Functional Description

This section provides a complete functional description of the block.

#### 14.6.1 Clock Generation

**14.6.1.1 External Low Frequency Clock - CKIL**

The chip can use a 32 kHz or 32.768 kHz crystal as the external low-frequency source (XTALOSC). Throughout this chapter, the low-frequency crystal is referred to as the 32 kHz crystal.

This clock source should always be active when the chip is powered on. The 32 kHz entering the CCM are referred to as CKIL. CKIL is synchronized to IPG_CLK and supplied to modules that need it.

**14.6.1.1.1 CKIL synchronizing to IPG_CLK**

CKIL is synchronized to ipg_clk when the system is in functional mode. When the system is in STOP mode (when there is no IPG_CLK) the CKIL synchronizer is bypassed, and raw CKIL is supplied to the system.
14.6.1.2 External High Frequency Clock - CKIH and internal oscillator

The chip uses an internal oscillator to generate the reference clock (OSC). The internal oscillator is connected to the external crystal (XTALOSC) which generates the 24 MHz reference clock.

14.6.1.3 PLL reference clock

There are several PLLs in this chip.

PLL1 - ARM PLL (typical functional frequency )
PLL2 - System PLL (functional frequency 528 MHz)
PLL3 - USB1 PLL (functional frequency 480 MHz)
PLL4 - Audio PLL
PLL5 - Video PLL
PLL6 - ENET PLL
PLL7 - USB2 PLL (functional frequency 480 MHz)

Some of the PLLs are described in the sections below. See CCM Analog Memory Map/Register Definition for register information.

14.6.1.3.1 ARM PLL (PLL1)

This PLL synthesizes a low jitter clock from a 24 MHz reference clock. The clock output frequency for this PLL ranges from 650 MHz to 1.3 GHz. The output frequency is selected by a 7-bit register field CCM_ANALOG_PLL_ARM[DIV_SELECT].

PLL output frequency = \( F_{ref} \times \frac{DIV\_SEL}{2} \)

**NOTE**

The upper frequency range may exceed the maximum frequency supported. Please see the datasheet for more information.

14.6.1.3.2 System PLL (PLL2)

This PLL synthesizes a low jitter clock from the 24 MHz reference clock. The PLL has one output clock, plus 4 PFD outputs. The System PLL supports spread spectrum modulation for use in applications to minimize radiated emissions. The spread spectrum PLL output clock is frequency modulated so that the energy is spread over a wider
bandwidth, thereby reducing peak radiated emissions. Due to this feature support, the associated lock time of this PLL is longer than other PLLs in the SoC that do not support spread spectrum modulation.

Spread spectrum operation is controlled by configuring the CCM_ANALOG_PLL_SYS_SS register. When enabled, the PLL output frequency will decrease by the amount defined in the STEP field, until it reaches the limiting frequency in the STOP field. The frequency will then similarly return to the original nominal frequency. The following equations control the spread-spectrum operation:

$$\text{Spread spectrum range} = \text{Ref} \times \frac{\text{CCM_ANALOG_PLL_SYS_SS[STOP]}}{\text{CCM_ANALOG_PLL_SYS_DENOM[B]}}$$

$$\text{Modulation frequency} = \text{Ref} \times \frac{\text{CCM_ANALOG_PLL_SYS_SS[STEP]}}{2 \times \text{CCM_ANALOG_PLL_SYS_SS[STOP]}}$$

Although this PLL does have a DIV_SELECT register field, it is intended that this PLL will only be run at the default frequency of 528 MHz.

This PLL also supports a Fractional-N synthesizer.

14.6.1.3.3  USB1 PLL (PLL3)

These PLLs synthesize a low jitter clock from the 24 MHz reference clock. USB1 PLL has 4 frequency-programmable PFD (phase fractional divider) outputs.

The output frequency of USB1 PLL is 480 MHz. Even though USB1 PLL has a DIV_SELECT register field, this PLL should always be set to 480 MHz in normal operation.

14.6.1.3.4  Audio PLL (PLL4)

The audio PLL synthesize a low jitter clock from a 24 MHz reference clock. The clock output frequency range for this PLL is from 650 MHz to 1.3 GHz. It has a Fractional-N synthesizer.

There are /1, /2, /4 post dividers for the Audio PLL. The output frequency can be set by programming the fields in the CCM_ANALOG_PLL_AUDIO, and CCM_ANALOG_MISC2 register sets according to the following equation.

$$\text{PLL output frequency} = \text{Ref} * (\text{DIV_SELECT} + \text{NUM/DENOM})$$
14.6.1.3.5 Video PLL (PLL5)

The video PLL synthesize a low jitter clock from a 24 MHz reference clock. The clock output frequency range for this PLL is from 650 MHz to 1.3 GHz. It has a Fractional-N synthesizer.

There are /1, /2, /4, /8, /16 post dividers for the Video PLL. The output frequency can be set by programming the fields in the CCM_ANALOG_PLL_VIDEO, and CCM_ANALOG_MISC2 register sets according to the following equation.

\[ \text{PLL output frequency} = \text{Fref} \times (\text{DIV_SELECT} + \text{NUM/DENOM}) \]

14.6.1.3.6 Ethernet PLL (PLL6)

This PLL synthesizes a low jitter clock from the 24 MHz reference clock.

The reference clocks generated by this PLL are:

- ref_enetpll1 programmable to 25, 50, 100 and 125 MHz by setting CCM_ANALOG_PLL_ENET[DIV_SELECT] bitfield
- ref_enetpll2 fixed at 25 MHz

14.6.1.3.7 USB2 PLL (PLL7)

USB2 PLL is only used by the USB UTM interface through a direct connection.

14.6.1.4 Phase Fractional Dividers (PFD)

There are several PFD outputs from the System PLL and USB1 PLL.

Each PFD output generates a fractional multiplication of the associated PLL’s VCO frequency. Where the output frequency is equal to Fvco*18/N, N can range from 12-35. The PFDs allow for clock frequency changes without forcing the relock of the root PLL. This feature is useful in support of dynamic voltage and frequency scaling (DVFS). See CCM Analog Memory Map/Register Definition.

When the related PLL is powered up from the power down state or made to go through a relock cycle due to PLL regrogramming, it is required that the related PFDx_CLKGATE bit in CCM_ANALOG_PFD_480n or CCM_ANALOG_PFD_528n, be cycled on and off (1 to 0) after PLL lock. The PFDs can be in the clock gated state during PLL relock but must be un-clock gated only after lock is achieved. See the engineering bulletin, Configuration of Phase Fractional Dividers (EB790) at www.nxp.com for procedure details.
14.6.1.5  **CCM internal clock generation**

The clock generation is comprised of two sub-modules:

CCM_CLK_SWITCHER  
CCM_CLK_ROOT_GEN  

14.6.1.5.1  **Clock Switcher**

The Clock Switcher (CCM_CLK_SWITCHER) sub-module receives the PLL output clocks and the PLL bypass clocks.

**Figure 14-4** describes the generation of the three switcher clocks.

The figure also includes the Frequency Switch Control sub-module responsible for frequency change.
14.6.1.5.2 PLL bypass procedure

In addition to PLL bypass options in CCM_ANALOG module, switcher and clk_root_gen sub-modules includes capability for each of the PLL clocks to be bypassed with an external bypass clock.

Figure 14-4. Switcher clock generation
14.6.1.5.3 PLL clock change

In order to modify or stop the clock output of a specific PLL, all the clocks generated from the current PLL must be transitioned to the new PLL whose frequency is not being modified.

For clocks which can't be stopped (core and bus clocks), this should be done via the glitchless mux. Before changing the PLL setting, power it down. Power up the PLL after the change. See Disabling / Enabling PLLs for more information.

14.6.1.5.4 Clock Root Generator

The Clock Root Generator (CCM_CLK_ROOT_GEN) sub-module generates the root clocks to be delivered to LPCG.

The following figures describe clock generation. The frequencies in parentheses are the default typical frequencies.

Figure 14-5. BUS clock generation
NOTE
All 6-bit PODF dividers found in the diagrams above can operate on low frequency.

14.6.1.5.5 Divider change handshake
Modifying the following dividers will start the handshake:
- periph_clk_sel
- arm_podf
- ahb_podf

The dividers listed above are designed with a handshake. For dividers without a handshake design, the following sequence must be performed when updating PODF value:
1. Gate the output clock off before updating PODF value.
2. Gate the output clock on after the PODF value is updated and stable.

To update the PODF value without gating the output clock off will cause unpredictable results such as no clock output.

14.6.1.6 Disabling / Enabling PLLs
PLL disabling and enabling is done via analog module.

Before disabling a PLL using the analog registers, software should first move all the clocks generated from that specific PLL to another source. This alternate source could be another PLL, or a PFD driven by another PLL. Alternatively, software can bypass the PLL and use the PLL reference clock (usually 24 MHz) as the output clock. Bypassing the PLL is done by setting the analog BYPASS bit in the control register for that PLL.

14.6.1.7 Clock Switching Multiplexers
There are a multitude of multiplexers available throughout the clock generation logic that provide alternate clock sources for the system clocks controlled by the CCM. The CCM uses several synchronous glitchless clock multiplexers as well as asynchronous glitchy clock multiplexers.

Synchronous muxes ensure there are no glitches between the transition of two asynchronous clocks and that there will be no pulses that are of a frequency higher than either input clock. For the synchronous multiplexer to work properly, both the current clock and the clock to be selected must remain active during the entire selection process.
There are several glitchless (synchronous) muxes used in the CCM. The table below lists the muxes and the respective control bits.

### Table 14-6. Glitchless Multiplexers

<table>
<thead>
<tr>
<th>Glitchless Mux</th>
<th>Mux Select Bit</th>
<th>Handshake Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>periph_clk_mux</td>
<td>CBCDR[periph_clk_sel]</td>
<td>CDHIPR[periph_clk_sel_busy]</td>
</tr>
<tr>
<td>semc_clk_mux</td>
<td>CBCDR[semc_clk_sel]</td>
<td></td>
</tr>
<tr>
<td>pll3_sw_clk_mux</td>
<td>CCSR[pll3_sw_clk_sel]</td>
<td></td>
</tr>
</tbody>
</table>

**NOTE**

Any change of the periph_clk_sel sync mux select will involve handshake. Refer to the CDHIPR register for the handshake busy bits.

For critical system bus clocks, changing the clock source can be done in the CCM using the glitchless clock muxes in Figure 14-5. In the figure, the thick bar on the input side indicates the glitchless muxes. Those without the thick bar are regular muxes (not glitchless).

For example, before disabling PLL2, software can switch the AHB_CLK_ROOT away from the PLL2 or one of its PFDs by programming CBCMR[PERIPH_CLK2_SEL] and CBCDR[PERIPH_CLK2_PODF] to provide an appropriate frequency clock, then glitchlessly switch to it by programming CBCDR[PERIPH_CLK_SEL].

Asynchronous multiplexers or glitchy multiplexers, allow the clock to switch immediately after the multiplexer select changed. This immediate switch of two asynchronous clock domains can cause the output clock to glitch. Since both clock sources to the mux are asynchronous, switching the clocks from one source to the other can cause a glitch to be generated, regardless of the input clock source.

The output clocks to the mux are required to be gated before switching the source clock in the CCM clock mux. If the output clocks are not gated, clock glitches can propagate to the logic that follows the clock mux, causing the logic to behave unpredictably.

For serial clocks, software should first disable the module, then gate its clock in the LPCG. Then it should move the mux controlling the source of the clocks to another PLL, and reset the module and its clocks. Only then is it safe to disable the PLL. The mux for the serial clocks is not glitchless.

### 14.6.1.8 Low Power Clock Gating module (LPCG)

The LPCG module receives the root clocks and splits them to clock branches for each module. The clock branches are gated clocks.
The enables for those gates can come from four sources:

1. Clock enable signal from CCM - this signal is generated by configuring of the CGR bits in the CCM. It is based on the low power mode.
2. Clock enable signal from the module - this signal is generated by the module based on internal logic of the module. Not every enable signal from the module is used. For used clock enable signals from the module, CCM will generate an override signal based on a programable bit in CCM (CMEOR).
3. Clock enable signal from Reset controller (SRC) - this signal will enable the clock during the reset procedure. Please see the SRC chapter for details on the clock enable signal during reset procedure.
4. Hard-coded enable from fuse box.

These enable signals are ANDed to generate the enable signal for the gating cell.

The enable signal for the gating cell is synchronized with the clock it needs to gate in order to prevent glitches on the gated clock.

Notifications are generated for CCM to indicate when clock roots should be opened and closed. All notifications that correspond to the same clock root will be ORed to generate one notification signal to CCM for clock root gating.

The following figure describes the clock split inside the LPCG module. It describes the case of two modules; one module is without an enable signal and one is shown with an enable signal. SRC enable signals and sync flip flops are omitted from this figure.
14.6.2 DVFS support

When performing DVFS, the frequency shift procedure for the Arm core clock domain can be performed by software.

CPU PLL frequency and CCM ARM clock divider is controlled by CCM and CPU power domain supply voltage value is controlled by CCM_ANALOG module.

NOTE
The frequency should be shifted down first and then voltage value reduced, and vice-versa, when shifting the frequency up.

NOTE
CCM_ANALOG will not control the voltage value in Bypass mode
14.6.3 Power modes

The chip supports 3 low power modes: RUN mode, WAIT mode, STOP mode.

14.6.3.1 RUN mode

This is the normal/functional operating mode. In this mode, the CPU runs in its normal operational mode. Clocks to the modules can be gated by configuring the corresponding CCGRx bits.

14.6.3.2 WAIT mode

In this mode the CPU clock is gated. All other clocks are functional and can be gated by programming their CGR bits when all Arm cores are in WFI, and L2 cache and SCU are idle.

14.6.3.2.1 Entering WAIT mode

If the CLPCR[LPM] bit is set by software to WAIT mode, when CPU executes the next wait for interrupt (WFI) instruction, WAIT mode sequence will start.

As part of the WFI routine, alternative interrupt controller in GPC should be updated; the CPU platform interrupt controller will be disabled first by software and will be not functional, due to clock gating. Interrupts during WAIT mode are monitored by alternative interrupt controller.

After execution of the WFI routine, the CPU platform will assert idle signals for each component of the platform and CCM will gate clock to the platform.

The next actions can be programmed during WAIT mode:

1. CCM request will be issued if the handshake is not bypassed by programing the CLPCR register. If the corresponding bits are set, the request signal will not be issued to the corresponding module and CCM will not wait for its acknowledge in the process of entering low power mode. After CCM receives all the acknowledge signals needed, then it will enter WAIT mode.
2. Close the clocks to the modules which were defined to be shut at WAIT mode in the CCGR bits.
3. Observability to indicate WAIT mode.

Any enabled interrupt assertion will start the exit from WAIT mode.
14.6.3.2.2 Exiting WAIT mode

As soon as enabled interrupt is asserted, CPU supply will be restored if CPU SRPG was applied and clocks are enabled to CPU and other modules.

14.6.3.3 STOP mode

In this mode all system clocks are stopped, along with the CPU, system buses and all PLLs. Power gating can be applied for Arm platform. External supply voltage can be reduced to decrease leakage.

14.6.3.3.1 Entering STOP mode

Procedure entering STOP mode is the same, as entering WAIT mode until the moment of disabling clocks to modules. (LPM bit should be configured to STOP mode.)

After clocks to modules are gated, the following actions will be taken:

- PLLs are disabled
- CCM_PMIC_STBY_REQ asserted, if vstby bit is set
- osc_en signal is negated
- osc_pwrdn is asserted, if sbyos bit is set

Counter will be triggered after CCM_PMIC_STBY_REQ assertion to allow to external regulator or PMIC to decrease voltage until valid voltage range. On counter completion, stop_mode signal will be asserted, that will trigger disabling analog elements in anatop. CCM's low power state machine will remain in state STOP_GPC until STOP mode is exited.

14.6.3.3.2 Exiting STOP mode

As soon as an enabled interrupt is asserted, the CCM will begin the process of exiting STOP mode.

The following will take place:

1. If vstby bit was set, deassert PMIC_STBY_REQ to notify power management IC to change voltage from standby voltage to functional voltage.
2. If sbyos was set, and CCM closed either external oscillator or on board oscillator, then CCM will start oscillator by asserting ref_en_b signal and deasserting cosc_pwrdown signal respectively.
3. After the number of cycles of CKILs defined in stby_count bits, wait until PMIC functional voltage is ready. This is the notification from power management IC that the voltage is ready at its functional value. Only then will CCM continue the steps.
4. Start osc. If oscillator was started, wait until oscnt has finished its counting to make sure that oscillator is ready.
5. Start PLLs. Only the PLLs that were configured to be on prior to the entrance to STOP mode will be started.
6. CCM will request GPC to restore Arm power by GPC_PUP_REQ. If power was removed from the Arm platform, GPC will notify CCM by asserting signal GPC_PUP_ACK that power to Arm is back on, and its safe to exit from STOP mode. Only then will the CCM progress to the next step.
7. After assertion of notification from src that the resets for the power gated modules has been finished, (src_power_gating_reset_done is set) negate the low power request signals to all modules and enable all module clocks including Arm clocks and CKIL sync, and return to run mode. (Clocks whose CCGR bits are not to be opened in RUN mode will not be opened; they will continued to be gated.)

After the system is in run mode, the ccm_ipg_stop and system_in_stop_mode signals negate.

14.7 CCM Memory Map/Register Definition

NOTE
The register reset values for CCM change depending on the boot configuration. See Clocks at boot time for more information.

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400F_C000</td>
<td>CCM Control Register (CCM_CCR)</td>
<td>32</td>
<td>R/W</td>
<td>0401_107Fh</td>
<td>14.7.1/1047</td>
</tr>
<tr>
<td>400F_C008</td>
<td>CCM Status Register (CCM_CSR)</td>
<td>32</td>
<td>R</td>
<td>0000_0010h</td>
<td>14.7.2/1049</td>
</tr>
<tr>
<td>400F_C00C</td>
<td>CCM Clock Switcher Register (CCM_CCSR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0100h</td>
<td>14.7.3/1051</td>
</tr>
<tr>
<td>400F_C010</td>
<td>CCM Arm Clock Root Register (CCM_CACRR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>14.7.4/1052</td>
</tr>
<tr>
<td>400F_C014</td>
<td>CCM Bus Clock Divider Register (CCM_CBCDR)</td>
<td>32</td>
<td>R/W</td>
<td>000A_8300h</td>
<td>14.7.5/1053</td>
</tr>
<tr>
<td>400F_C018</td>
<td>CCM Bus Clock Multiplexer Register (CCM_CBCCMR)</td>
<td>32</td>
<td>R/W</td>
<td>2DAE_8324h</td>
<td>14.7.6/1055</td>
</tr>
<tr>
<td>400F_C01C</td>
<td>CCM Serial Clock Multiplexer Register 1 (CCM_CSCMRR1)</td>
<td>32</td>
<td>R/W</td>
<td>0490_0000h</td>
<td>14.7.7/1057</td>
</tr>
<tr>
<td>400F_C020</td>
<td>CCM Serial Clock Multiplexer Register 2 (CCM_CSCMRR2)</td>
<td>32</td>
<td>R/W</td>
<td>1319_2F06h</td>
<td>14.7.8/1059</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CCM Memory Map/Register Definition

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400F_C024</td>
<td>CCM Serial Clock Divider Register 1 (CCM_CSCDR1)</td>
<td>32</td>
<td>R/W</td>
<td>0649_0B00h</td>
<td>14.7.9/1061</td>
</tr>
<tr>
<td>400F_C028</td>
<td>CCM Clock Divider Register (CCM_CSC1CDR)</td>
<td>32</td>
<td>R/W</td>
<td>0EC1_02C1h</td>
<td>14.7.10/1063</td>
</tr>
<tr>
<td>400F_C02C</td>
<td>CCM Clock Divider Register (CCM_CSC2CDR)</td>
<td>32</td>
<td>R/W</td>
<td>0073_36C1h</td>
<td>14.7.11/1064</td>
</tr>
<tr>
<td>400F_C030</td>
<td>CCM D1 Clock Divider Register (CCM_CD1CDR)</td>
<td>32</td>
<td>R/W</td>
<td>33F7_1F92h</td>
<td>14.7.12/1065</td>
</tr>
<tr>
<td>400F_C038</td>
<td>CCM Serial Clock Divider Register 2 (CCM_CSCDR2)</td>
<td>32</td>
<td>R/W</td>
<td>0002_9150h</td>
<td>14.7.13/1067</td>
</tr>
<tr>
<td>400F_C03C</td>
<td>CCM Serial Clock Divider Register 3 (CCM_CSCDR3)</td>
<td>32</td>
<td>R/W</td>
<td>0003_0841h</td>
<td>14.7.14/1069</td>
</tr>
<tr>
<td>400F_C048</td>
<td>CCM Divider Handshake In-Process Register (CCM_CDHI)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>14.7.15/1070</td>
</tr>
<tr>
<td>400F_C054</td>
<td>CCM Low Power Control Register (CCM_CLPCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0079h</td>
<td>14.7.16/1073</td>
</tr>
<tr>
<td>400F_C058</td>
<td>CCM Interrupt Status Register (CCM_CISR)</td>
<td>32</td>
<td>w1c</td>
<td>0000_0000h</td>
<td>14.7.17/1075</td>
</tr>
<tr>
<td>400F_C05C</td>
<td>CCM Interrupt Mask Register (CCM_CIMR)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.18/1078</td>
</tr>
<tr>
<td>400F_C060</td>
<td>CCM Clock Output Source Register (CCM_CCOSR)</td>
<td>32</td>
<td>R/W</td>
<td>000A_001h</td>
<td>14.7.19/1080</td>
</tr>
<tr>
<td>400F_C064</td>
<td>CCM General Purpose Register (CCM_CGPR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_FE62h</td>
<td>14.7.20/1082</td>
</tr>
<tr>
<td>400F_C068</td>
<td>CCM Clock Gating Register 0 (CCM_CCGR0)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.21/1083</td>
</tr>
<tr>
<td>400F_C06C</td>
<td>CCM Clock Gating Register 1 (CCM_CCGR1)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.22/1085</td>
</tr>
<tr>
<td>400F_C070</td>
<td>CCM Clock Gating Register 2 (CCM_CCGR2)</td>
<td>32</td>
<td>R/W</td>
<td>FC3F_FFFFh</td>
<td>14.7.23/1086</td>
</tr>
<tr>
<td>400F_C074</td>
<td>CCM Clock Gating Register 3 (CCM_CCGR3)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFCFh</td>
<td>14.7.24/1087</td>
</tr>
<tr>
<td>400F_C078</td>
<td>CCM Clock Gating Register 4 (CCM_CCGR4)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.25/1089</td>
</tr>
<tr>
<td>400F_C07C</td>
<td>CCM Clock Gating Register 5 (CCM_CCGR5)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.26/1090</td>
</tr>
<tr>
<td>400F_C080</td>
<td>CCM Clock Gating Register 6 (CCM_CCGR6)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.27/1091</td>
</tr>
<tr>
<td>400F_C084</td>
<td>CCM Clock Gating Register 7 (CCM_CCGR7)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.28/1093</td>
</tr>
<tr>
<td>400F_C088</td>
<td>CCM Module Enable Override Register (CCM_CMEOR)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>14.7.29/1094</td>
</tr>
</tbody>
</table>
14.7.1 CCM Control Register (CCM_CCR)

The figure below represents the CCM Control Register (CCR), which contains bits to control general operation of CCM. The table below provides its field descriptions.

Address: 400F_C000h base + 0h offset = 400F_C000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>RBC_EN</td>
</tr>
<tr>
<td>26–21</td>
<td>REG_BYPASS_COUNT</td>
</tr>
<tr>
<td>20–13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>COSC_EN</td>
</tr>
</tbody>
</table>

### CCM_CCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>RBC_EN</td>
</tr>
<tr>
<td>Enable for REG_BYPASS_COUNTER. If enabled, analog_reg_bypass signal will be asserted after REG_BYPASS_COUNT clocks of CKIL, after standby voltage is requested. If standby voltage is not requested analog_reg_bypass won't be asserted, event if counter is enabled.</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>REG_BYPASS_COUNTER enabled.</td>
</tr>
<tr>
<td>0</td>
<td>REG_BYPASS_COUNTER disabled</td>
</tr>
<tr>
<td>26–21</td>
<td>REG_BYPASS_COUNT</td>
</tr>
<tr>
<td>Counter for analog_reg_bypass signal assertion after standby voltage request by PMIC_STBY_REQ. Should be zeroed and reconfigured after exit from low power mode.</td>
<td></td>
</tr>
<tr>
<td>REG_BYPASS_COUNT can also be used for holding off interrupts when the PGC unit is sending signals to power gate the core.</td>
<td></td>
</tr>
<tr>
<td>000000</td>
<td>no delay</td>
</tr>
<tr>
<td>000001</td>
<td>1 CKIL clock period delay</td>
</tr>
<tr>
<td>111111</td>
<td>63 CKIL clock periods delay</td>
</tr>
<tr>
<td>20–13</td>
<td>Reserved</td>
</tr>
<tr>
<td>This read-only field is reserved and always has the value 0.</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>COSC_EN</td>
</tr>
<tr>
<td>On chip oscillator enable bit - this bit value is reflected on the output cosc_en. The system will start with on chip oscillator enabled to supply source for the PLLs. Software can change this bit if a transition to the bypass PLL clocks was performed for all the PLLs. In cases that this bit is changed from '0' to '1' then CCM will enable the on chip oscillator and after counting oscnt ckil clock cycles it will notify that on chip</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Oscillator is ready by an interrupt cosc_ready and by status bit cosc_ready. The cosc_en bit should be changed only when on chip oscillator is not chosen as the clock source.</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>disable on chip oscillator</td>
</tr>
<tr>
<td>1</td>
<td>enable on chip oscillator</td>
</tr>
<tr>
<td>11–8 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>OSCNT</td>
<td>Oscillator ready counter value. These bits define value of 32KHz counter, that serve as counter for oscillator lock time. This is used for oscillator lock time. Current estimation is ~5ms. This counter will be used in ignition sequence and in wake from stop sequence if sbyos bit was defined, to notify that on chip oscillator output is ready for the dpll_ip to use and only then the gate in dpll_ip can be opened.</td>
</tr>
<tr>
<td>00000000</td>
<td>count 1 ckil</td>
</tr>
<tr>
<td>11111111</td>
<td>count 256 ckil's</td>
</tr>
</tbody>
</table>
14.7.2 CCM Status Register (CCM_CSR)

The figure below represents the CCM status Register (CSR). The status bits are read-only bits. The table below provides its field descriptions.

Address: 400F_C000h base + 8h offset = 400F_C008h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**CCM_CSR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–6 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 5       | **COSC READY** Status indication of on board oscillator. This bit will be asserted if on chip oscillator is enabled and on chip oscillator is not powered down, and if oscnt counter has finished counting.  
          | 0 on board oscillator is not ready.  
          | 1 on board oscillator is ready.                                                                                                             |
| 4       | **Reserved** This read-only field is reserved and always has the value 1.                                                                     |
| 3       | **CAMP2 READY** Status indication of CAMP2.  
          | 0 CAMP2 is not ready.  
          | 1 CAMP2 is ready.                                                                                                                             |
| 2–1     | **Reserved** This read-only field is reserved and always has the value 0.                                                                    |
| 0       | **REF_EN_B** Status of the value of CCM_REF_EN_B output of ccm  
          | 0 value of CCM_REF_EN_B is ‘0’  
          | 1 value of CCM_REF_EN_B is ‘1’                                                                                                               |
### 14.7.3 CCM Clock Switcher Register (CCM_CCSR)

The figure below represents the CCM Clock Switcher register (CCCSR). The CCSR register contains bits to control the switcher sub-module dividers and multiplexers. The table below provides its field descriptions.

Address: 400F_C00h base + Ch offset = 400F_C00Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>1</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

![CCM_CCSR Diagram]

#### CCM_CCSR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–9 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–3 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>2 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>1 Reserved</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
CCM_CCSR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PLL3_SW_CLK_SEL</td>
<td>Selects source to generate pll3_sw_clk. This bit should only be used for testing purposes.</td>
</tr>
<tr>
<td>0 pll3_main_clk</td>
<td></td>
</tr>
<tr>
<td>1 pll3 bypass clock</td>
<td></td>
</tr>
</tbody>
</table>

14.7.4 CCM Arm Clock Root Register (CCM_CACRR)

The figure below represents the CCM Arm Clock Root register (CACRR). The CACRR register contains bits to control the Arm clock root generation. The table below provides its field descriptions.

Address: 400F_C000h base + 10h offset = 400F_C010h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>ARM_PODF</td>
<td>Divider for Arm clock root.</td>
</tr>
</tbody>
</table>

NOTE: If arm_freq_shift_divider is set to '1' then any new write to arm_podf will be held until arm_clk_switch_req signal is asserted.

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
</tbody>
</table>
### 14.7.5 CCM Bus Clock Divider Register (CCM_CBCDR)

The figure below represents the CCM Bus Clock Divider Register (CBCDR). The CBCDR register contains bits to control the clock generation sub module dividers. The table below provides its field descriptions.

**Address:** 400F_C000h base + 14h offset = 400F_C014h

#### CCM_CBCDR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>29–27 PERIPH_CLK2_PODF</td>
<td>Divider for periph_clk2_podf.</td>
</tr>
<tr>
<td>000 divide by 1</td>
<td></td>
</tr>
<tr>
<td>001 divide by 2</td>
<td></td>
</tr>
<tr>
<td>010 divide by 3</td>
<td></td>
</tr>
<tr>
<td>011 divide by 4</td>
<td></td>
</tr>
<tr>
<td>100 divide by 5</td>
<td></td>
</tr>
<tr>
<td>101 divide by 6</td>
<td></td>
</tr>
<tr>
<td>110 divide by 7</td>
<td></td>
</tr>
<tr>
<td>111 divide by 8</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CCM_CBCDR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>26</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Selector for peripheral main clock. <strong>NOTE:</strong> Alternative clock source should be used when PLL is relocked. For PLL relock procedure pls refer to the PLL chapter. <strong>NOTE:</strong> Any change of this sync mux select will involve handshake with the MMDC. Refer to the CCDR and CDHIPR registers for the handshake bypass and busy bits. 0 derive clock from pre_periph_clk_sel 1 derive clock from periph_clk2_clk_divided</td>
</tr>
<tr>
<td>24–19</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>18–16</td>
<td>Post divider for SEMC clock. <strong>NOTE:</strong> Any change of this divider might involve handshake with EMI. See CDHIPR register for the handshake busy bits. 000 divide by 1 001 divide by 2 010 divide by 3 011 divide by 4 100 divide by 5 101 divide by 6 110 divide by 7 111 divide by 8</td>
</tr>
<tr>
<td>15–13</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>12–10</td>
<td>Divider for AHB PODF. <strong>NOTE:</strong> Any change of this divider might involve handshake with EMI. See CDHIPR register for the handshake busy bits. 000 divide by 1 001 divide by 2 010 divide by 3 011 divide by 4 100 divide by 5 101 divide by 6 110 divide by 7 111 divide by 8</td>
</tr>
<tr>
<td>9–8</td>
<td>Divider for ipg podf. 00 divide by 1 01 divide by 2 10 divide by 3 11 divide by 4</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 SEMC_ALT_CLK_SEL</td>
<td>SEMC alternative clock select</td>
</tr>
<tr>
<td></td>
<td>0 PLL2 PFD2 will be selected as alternative clock for SEMC root clock</td>
</tr>
<tr>
<td></td>
<td>1 PLL3 PFD1 will be selected as alternative clock for SEMC root clock</td>
</tr>
<tr>
<td>6 SEMC_CLK_SEL</td>
<td>SEMC clock source select</td>
</tr>
<tr>
<td></td>
<td>0 Periph_clk output will be used as SEMC clock root</td>
</tr>
<tr>
<td></td>
<td>1 SEMC alternative clock will be used as SEMC clock root</td>
</tr>
<tr>
<td>5–3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 14.7.6 CCM Bus Clock Multiplexer Register (CCM_CBCCMR)

The figure below represents the CCM Bus Clock Multiplexer Register (CBCCMR). The CBCCMR register contains bits to control the multiplexers that generate the bus clocks. The table below provides its field descriptions.

**NOTE**

Any change on the above multiplexer will have to be done while the module that its clock is affected is not functional and the respective clock is gated in LPCG. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.

Address: 400F_C000h base + 18h offset = 400F_C018h
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–29 FLEXSPI2_PODF</td>
<td>Divider for flexspi2 clock root.</td>
</tr>
<tr>
<td>000 divide by 1</td>
<td></td>
</tr>
<tr>
<td>001 divide by 2</td>
<td></td>
</tr>
<tr>
<td>010 divide by 3</td>
<td></td>
</tr>
<tr>
<td>011 divide by 4</td>
<td></td>
</tr>
<tr>
<td>100 divide by 5</td>
<td></td>
</tr>
<tr>
<td>101 divide by 6</td>
<td></td>
</tr>
<tr>
<td>110 divide by 7</td>
<td></td>
</tr>
<tr>
<td>111 divide by 8</td>
<td></td>
</tr>
<tr>
<td>28–26 LPSPI_PODF</td>
<td>Divider for LPSPI.</td>
</tr>
<tr>
<td>NOTE: Divider should be updated when output clock is gated.</td>
<td></td>
</tr>
<tr>
<td>000 divide by 1</td>
<td></td>
</tr>
<tr>
<td>001 divide by 2</td>
<td></td>
</tr>
<tr>
<td>010 divide by 3</td>
<td></td>
</tr>
<tr>
<td>011 divide by 4</td>
<td></td>
</tr>
<tr>
<td>100 divide by 5</td>
<td></td>
</tr>
<tr>
<td>101 divide by 6</td>
<td></td>
</tr>
<tr>
<td>110 divide by 7</td>
<td></td>
</tr>
<tr>
<td>111 divide by 8</td>
<td></td>
</tr>
<tr>
<td>25–23 LCDIF_PODF</td>
<td>Post-divider for LCDIF clock.</td>
</tr>
<tr>
<td>000 divide by 1</td>
<td></td>
</tr>
<tr>
<td>001 divide by 2</td>
<td></td>
</tr>
<tr>
<td>010 divide by 3</td>
<td></td>
</tr>
<tr>
<td>011 divide by 4</td>
<td></td>
</tr>
<tr>
<td>100 divide by 5</td>
<td></td>
</tr>
<tr>
<td>101 divide by 6</td>
<td></td>
</tr>
<tr>
<td>110 divide by 7</td>
<td></td>
</tr>
<tr>
<td>111 divide by 8</td>
<td></td>
</tr>
<tr>
<td>22–20 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>19–18 PRE_PERIPH_CLK_SEL</td>
<td>Selector for pre_periph clock multiplexer</td>
</tr>
<tr>
<td>00 derive clock from PLL2</td>
<td></td>
</tr>
<tr>
<td>01 derive clock from PLL2 PFD2</td>
<td></td>
</tr>
<tr>
<td>10 derive clock from PLL2 PFD0</td>
<td></td>
</tr>
<tr>
<td>11 derive clock from divided PLL1</td>
<td></td>
</tr>
<tr>
<td>17–16 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>15–14 TRACE_CLK_SEL</td>
<td>Selector for Trace clock multiplexer</td>
</tr>
<tr>
<td>00 derive clock from PLL2</td>
<td></td>
</tr>
<tr>
<td>01 derive clock from PLL2 PFD2</td>
<td></td>
</tr>
<tr>
<td>10 derive clock from PLL2 PFD0</td>
<td></td>
</tr>
<tr>
<td>11 derive clock from PLL2 PFD1</td>
<td></td>
</tr>
</tbody>
</table>
### CCM_CBCMR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13–12 PERIPH_CLK2_SEL</td>
<td>Selector for peripheral clk2 clock multiplexer</td>
</tr>
<tr>
<td>00</td>
<td>derive clock from pll3_sw_clk</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from osc_clk (pll1_ref_clk)</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from pll2_bypass_clk</td>
</tr>
<tr>
<td>11</td>
<td>reserved</td>
</tr>
<tr>
<td>11–10 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>9–8 FLEXSPI2_CLK_SEL</td>
<td>Selector for flexspi2 clock multiplexer</td>
</tr>
<tr>
<td>00</td>
<td>derive clock from PLL2 PFD2</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from PLL3 PFD0</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from PLL3 PFD1</td>
</tr>
<tr>
<td>11</td>
<td>derive clock from PLL2 (pll2_main_clk)</td>
</tr>
<tr>
<td>7–6 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>5–4 LPSPI_CLK_SEL</td>
<td>Selector for lpspi clock multiplexer</td>
</tr>
<tr>
<td>00</td>
<td>derive clock from PLL3 PFD1 clk</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from PLL3 PFD0</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from PLL2</td>
</tr>
<tr>
<td>11</td>
<td>derive clock from PLL2 PFD2</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

#### 14.7.7 CCM Serial Clock Multiplexer Register 1 (CCM_CSCMR1)

The figure below represents the CCM Serial Clock Multiplexer Register 1 (CSCMR1). The CSCMR1 register contains bits to control the multiplexers that generate the serial clocks. The table below provides its field descriptions.

**NOTE**

Any change on the above multiplexer will have to be done while the module that its clock is affected is not functional and the clock is gated. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.
## CCM_CSCMR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30–29</td>
<td>Selector for flexspi clock multiplexer</td>
</tr>
</tbody>
</table>
| FLEXSPI_CLK_SEL | 00 derive clock from semc_clk_root_pre  
|         | 01 derive clock from pll3_sw_clk  
|         | 10 derive clock from PLL2 PFD2  
|         | 11 derive clock from PLL3 PFD0  |
| 28–26   | This field is reserved.  
| Reserved |             |
| 25–23   | Divider for flexspi clock root. |
| FLEXSPI_PODF | 00 divide by 1  
|         | 001 divide by 2  
|         | 010 divide by 3  
|         | 011 divide by 4  
|         | 100 divide by 5  
|         | 101 divide by 6  
|         | 110 divide by 7  
|         | 111 divide by 8  |
| 22–18   | This field is reserved.  
| Reserved |             |
| 17      | Selector for usdhc2 clock multiplexer |
| USDHC2_CLK_SEL | 0 derive clock from PLL2 PFD2  
|         | 1 derive clock from PLL2 PFD0  |
| 16      | Selector for usdhc1 clock multiplexer |
| USDHC1_CLK_SEL |             |

Table continues on the next page...
## CCM_CSCMR1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>derive clock from PLL2 PFD2</td>
</tr>
<tr>
<td>1</td>
<td>derive clock from PLL2 PFD0</td>
</tr>
<tr>
<td>15–14 SAI3_CLK_SEL</td>
<td>Selector for sai3/adc1/adc2 clock multiplexer</td>
</tr>
<tr>
<td>00</td>
<td>derive clock from PLL3 PFD2</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from PLL5</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from PLL4</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>13–12 SAI2_CLK_SEL</td>
<td>Selector for sai2 clock multiplexer</td>
</tr>
<tr>
<td>00</td>
<td>derive clock from PLL3 PFD2</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from PLL5</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from PLL4</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>11–10 SAI1_CLK_SEL</td>
<td>Selector for sai1 clock multiplexer</td>
</tr>
<tr>
<td>00</td>
<td>derive clock from PLL3 PFD2</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from PLL5</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from PLL4</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>9–7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>SELECTOR FOR THE PERCLK CLOCK MULTIPLEXOR</td>
</tr>
<tr>
<td>0</td>
<td>derive clock from ipg clk root</td>
</tr>
<tr>
<td>1</td>
<td>derive clock from osc_clk</td>
</tr>
<tr>
<td>PERCLK_PODF</td>
<td>Divider for perclk podf.</td>
</tr>
<tr>
<td>0000000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>0000001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>0000010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>0000011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>000100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>000101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>000110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111111</td>
<td>divide by 64</td>
</tr>
</tbody>
</table>

### 14.7.8 CCM Serial Clock Multiplexer Register 2 (CCM_CSCMR2)

The figure below represents the CCM Serial Clock Multiplexer Register 2 (CSCMR2). The CSCMR2 register contains bits to control the multiplexers that generate the serial clocks. The table below provides its field descriptions.

**NOTE**

Any change on the above multiplexer will have to be done while the module that its clock is affected is not functional and...
the clock is gated. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.

Address: 400F_C000h base + 20h offset = 400F_C020h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>Reserved</td>
<td>FLEXIO2_CLK_SEL</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>Reserved</td>
<td>CAN_CLK_SEL</td>
<td>CAN_CLK_PODF</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**CCM_CSCMR2 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–21</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>20–19</td>
<td>Selector for flexio2/flexio3 clock multiplexer</td>
</tr>
<tr>
<td>FLEXIO2_CLK_SEL</td>
<td>00 derive clock from PLL4 divided clock</td>
</tr>
<tr>
<td>20–19</td>
<td>01 derive clock from PLL3 PFD2 clock</td>
</tr>
<tr>
<td>20–19</td>
<td>10 derive clock from PLL5 clock</td>
</tr>
<tr>
<td>20–19</td>
<td>11 derive clock from pll3_sw_clk</td>
</tr>
<tr>
<td>18–10</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>9–8</td>
<td>Selector for CAN/CANFD clock multiplexer</td>
</tr>
<tr>
<td>CAN_CLK_SEL</td>
<td>00 derive clock from pll3_sw_clk divided clock (60M)</td>
</tr>
<tr>
<td>9–8</td>
<td>01 derive clock from osc_clk (24M)</td>
</tr>
<tr>
<td>9–8</td>
<td>10 derive clock from pll3_sw_clk divided clock (80M)</td>
</tr>
<tr>
<td>9–8</td>
<td>11 Disable FlexCAN clock</td>
</tr>
<tr>
<td>7–2</td>
<td>Divider for CAN/CANFD clock podf.</td>
</tr>
<tr>
<td>CAN_CLK_PODF</td>
<td>000000 divide by 1</td>
</tr>
<tr>
<td>7–2</td>
<td>...</td>
</tr>
<tr>
<td>CAN_CLK_PODF</td>
<td>000111 divide by 8</td>
</tr>
<tr>
<td>7–2</td>
<td>...</td>
</tr>
<tr>
<td>CAN_CLK_PODF</td>
<td>111111 divide by 2^6</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
14.7.9  CCM Serial Clock Divider Register 1 (CCM_CSCDR1)

The figure below represents the CCM Serial Clock Divider Register 1 (CSCDR1). The CSCDR1 register contains bits to control the clock generation sub-module dividers. The table below provides its field descriptions.

**NOTE**

Any change on the above dividers will have to be done while the module that its clock is affected is not functional and the affected clock is gated. If the change will be done during operation of the module, then it is not guaranteed that the modules operation will not be harmed.

Address: 400F_C000h base + 24h offset = 400F_C024h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>TRACE_PODF</td>
<td>Reserved</td>
<td>USDHC2_PODF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>USDHC1_PODF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>UART_CLK_SEL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>UAR_T_CLK_PODF</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**CCM_CSCDR1 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>27 - Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>26–25 TRACE_PODF</td>
<td>Divider for trace clock.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>divide by 1</td>
</tr>
<tr>
<td>01</td>
<td>divide by 2</td>
</tr>
<tr>
<td>10</td>
<td>divide by 3</td>
</tr>
<tr>
<td>11</td>
<td>divide by 4</td>
</tr>
<tr>
<td>24–19 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>18–16 USDHC2_PODF</td>
<td>Divider for usdhc2 clock.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
<tr>
<td>15–14 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>13–11 USDHC1_PODF</td>
<td>Divider for usdhc1 clock podf.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
<tr>
<td>10–7</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>6</td>
<td>UART_CLK_SEL Selector for the UART clock multiplexor</td>
</tr>
<tr>
<td>0</td>
<td>derive clock from pll3_80m</td>
</tr>
<tr>
<td>1</td>
<td>derive clock from osc_clk</td>
</tr>
<tr>
<td>UART_CLK_PODF</td>
<td>Divider for uart clock podf.</td>
</tr>
<tr>
<td>000000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>111111</td>
<td>divide by $2^6$</td>
</tr>
</tbody>
</table>
The figure below represents the CCM SAI1, and SAI3 Clock Divider Register (CS1CDR). The CS1CDR register contains bits to control the SAI1 and SAI3 clock generation dividers. The table below provides its field descriptions.

Address: \(400F\_C000h\) base + \(28h\) offset = \(400F\_C028h\)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Reserved</th>
<th>FLEXIO2_CLK_PODF</th>
<th>SAI3_CLK_PRED</th>
<th>SAI3_CLK_PODF</th>
<th>FLEXIO2_CLK_PRED</th>
<th>SAI1_CLK_PRED</th>
<th>SAI1_CLK_PODF</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27-25</td>
<td>FLEXIO2_CLK_PODF</td>
<td>000</td>
<td>001</td>
<td>010</td>
<td>011</td>
<td>100</td>
<td>101</td>
</tr>
<tr>
<td></td>
<td></td>
<td>divide by 1</td>
<td>divide by 2</td>
<td>divide by 3</td>
<td>divide by 4</td>
<td>divide by 5</td>
<td>divide by 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24-22</td>
<td>SAI3_CLK_PRED</td>
<td>000</td>
<td>001</td>
<td>010</td>
<td>011</td>
<td>100</td>
<td>101</td>
</tr>
<tr>
<td></td>
<td></td>
<td>divide by 1</td>
<td>divide by 2</td>
<td>divide by 3</td>
<td>divide by 4</td>
<td>divide by 5</td>
<td>divide by 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>21-16</td>
<td>SAI3_CLK_PODF</td>
<td>000000</td>
<td>111111</td>
<td>0</td>
<td>2^6</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>divide by 1</td>
<td>divide by 2^6</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
| 15-12 | Reserved | This read-only field is reserved and always has the value 0.

Table continues on the next page...
### CCM_CS1CDR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11–9 FLEXIO2_CLK_PRED</td>
<td>Divider for flexio2/flexio3 clock.</td>
</tr>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>8–6 SAI1_CLK_PRED</th>
<th>Divider for sai1 clock pred.</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SAI1_CLK_PODF</th>
<th>Divider for sai1 clock podf.</th>
</tr>
</thead>
<tbody>
<tr>
<td>The input clock to this divider should be lower than 300Mhz, the predivider can be used to achieve this.</td>
<td></td>
</tr>
<tr>
<td>000000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>111111</td>
<td>divide by 2^6</td>
</tr>
</tbody>
</table>

### 14.7.11 CCM Clock Divider Register (CCM_CS2CDR)

The figure below represents the CCM SAI2 Clock Divider Register (CS2CDR). The CS2CDR register contains bits to control the SAI2 clock generation dividers. The table below provides its field descriptions.

Address: $400F_{C000h} \text{ base} + 2Ch \text{ offset} = 400F_{C02Ch}$

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |
## CCM_CSF2CDR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–27 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>26–9 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>8–6 SAI2_CLK_PRED</td>
<td>Divider for sai2 clock pred.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td></td>
<td>000 divide by 1</td>
</tr>
<tr>
<td></td>
<td>001 divide by 2</td>
</tr>
<tr>
<td></td>
<td>010 divide by 3</td>
</tr>
<tr>
<td></td>
<td>011 divide by 4</td>
</tr>
<tr>
<td></td>
<td>100 divide by 5</td>
</tr>
<tr>
<td></td>
<td>101 divide by 6</td>
</tr>
<tr>
<td></td>
<td>110 divide by 7</td>
</tr>
<tr>
<td></td>
<td>111 divide by 8</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8–6 SAI2_CLK_PODF</td>
<td>Divider for sai2 clock podf.</td>
</tr>
<tr>
<td></td>
<td>The input clock to this divider should be lower than 300Mhz, the predivider can be used to achieve this.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td></td>
<td>0000000 divide by 1</td>
</tr>
<tr>
<td></td>
<td>111111 divide by $2^6$</td>
</tr>
</tbody>
</table>

### 14.7.12 CCM D1 Clock Divider Register (CCM_CDCDR)

The figure below represents the CCM DI Clock Divider Register (CDCDR). The table below provides its field descriptions.

Address: 400F_C000h base + 30h offset = 400F_C030h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Reserved</th>
<th>SPDIF0_CLK_PRED</th>
<th>SPDIF0_CLK_PODF</th>
<th>SPDIF0_CLK_SEL</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Reserved</th>
<th>FLEXIO1_CLK_PRED</th>
<th>FLEXIO1_CLK_PODF</th>
<th>FLEXIO1_CLK_SEL</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### CCM_CDCDR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td></td>
<td>0  derive from pll3_120M clock</td>
</tr>
<tr>
<td></td>
<td>1  derive clock from PLL2 PFD2</td>
</tr>
<tr>
<td>27–25</td>
<td>Divider for spdif0 clock pred.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td></td>
<td>000 divide by 1 (do not use with high input frequencies)</td>
</tr>
<tr>
<td></td>
<td>001 divide by 2</td>
</tr>
<tr>
<td></td>
<td>010 divide by 3</td>
</tr>
<tr>
<td></td>
<td>011 divide by 4</td>
</tr>
<tr>
<td></td>
<td>100 divide by 5</td>
</tr>
<tr>
<td></td>
<td>101 divide by 6</td>
</tr>
<tr>
<td></td>
<td>110 divide by 7</td>
</tr>
<tr>
<td></td>
<td>111 divide by 8</td>
</tr>
<tr>
<td>24–22</td>
<td>Divider for spdif0 clock podf.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td></td>
<td>000 divide by 1</td>
</tr>
<tr>
<td></td>
<td>001 divide by 2</td>
</tr>
<tr>
<td></td>
<td>010 divide by 3</td>
</tr>
<tr>
<td></td>
<td>011 divide by 4</td>
</tr>
<tr>
<td></td>
<td>100 divide by 5</td>
</tr>
<tr>
<td></td>
<td>101 divide by 6</td>
</tr>
<tr>
<td></td>
<td>110 divide by 7</td>
</tr>
<tr>
<td></td>
<td>111 divide by 8</td>
</tr>
<tr>
<td>21–20</td>
<td>Selector for spdif0 clock multiplexer</td>
</tr>
<tr>
<td></td>
<td>00 derive clock from PLL4</td>
</tr>
<tr>
<td></td>
<td>01 derive clock from PLL3 PFD2</td>
</tr>
<tr>
<td></td>
<td>10 derive clock from PLL5</td>
</tr>
<tr>
<td></td>
<td>11 derive clock from pll3_sw_clk</td>
</tr>
<tr>
<td>19–15</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>14–12</td>
<td>Divider for flexio1 clock pred.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td></td>
<td>000 divide by 1 (do not use with high input frequencies)</td>
</tr>
<tr>
<td></td>
<td>001 divide by 2</td>
</tr>
<tr>
<td></td>
<td>010 divide by 3</td>
</tr>
<tr>
<td></td>
<td>111 divide by 8</td>
</tr>
<tr>
<td>11–9</td>
<td>Divider for flexio1 clock podf.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CCM_CDCDR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
<tr>
<td>8–7</td>
<td>FLEXIO1_CLK_SEL</td>
</tr>
<tr>
<td></td>
<td>Selector for flexio1 clock multiplexer</td>
</tr>
<tr>
<td>00</td>
<td>derive clock from PLL4</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from PLL3 PFD2</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from PLL5</td>
</tr>
<tr>
<td>11</td>
<td>derive clock from pll3_sw_clk</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 14.7.13 CCM Serial Clock Divider Register 2 (CCM_CSCDR2)

The figure below represents the CCM Serial Clock Divider Register 2 (CCM_CSCDR2). The CSCDR2 register contains bits to control the clock generation sub-module dividers. The table below provides its field descriptions.

Address: 400F_C000h base + 38h offset = 400F_C038h

#### CCM_CSCDR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–25</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>24–19</td>
<td>LPI2C_CLK_PODF</td>
</tr>
<tr>
<td></td>
<td>Divider for lpi2c clock podf.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### CCM_CSCDR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>NOTE:</strong></td>
<td>The input clock to this divider should be lower than 300Mhz, the predivider can be used to achieve this.</td>
</tr>
<tr>
<td>000000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>111111</td>
<td>divide by 2^6</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>18</th>
<th>LPI2C_CLK_SEL</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>derive clock from pll3_60m</td>
</tr>
<tr>
<td>1</td>
<td>derive clock from osc_clk</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>17–15</th>
<th>LCDIF_PRE_CLK_SEL</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>derive clock from PLL2</td>
</tr>
<tr>
<td>001</td>
<td>derive clock from PLL3 PFD3</td>
</tr>
<tr>
<td>010</td>
<td>derive clock from PLL5</td>
</tr>
<tr>
<td>011</td>
<td>derive clock from PLL2 PFD0</td>
</tr>
<tr>
<td>100</td>
<td>derive clock from PLL2 PFD1</td>
</tr>
<tr>
<td>101</td>
<td>derive clock from PLL3 PFD1</td>
</tr>
<tr>
<td>110-111</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>14–12</th>
<th>LCDIF_PRED</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>NOTE:</strong></td>
<td>Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>11–9</th>
<th>This field is reserved.</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>-</th>
<th>This field is reserved.</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

---

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**

NXP Semiconductors
14.7.14  CCM Serial Clock Divider Register 3 (CCM_CSCDR3)

The figure below represents the CCM Serial Clock Divider Register 3 (CSCDR3). The CSCDR3 register contains bits to control the clock generation sub-module dividers. The table below provides its field descriptions.

Address: 400F_C000h base + 3Ch offset = 400F_C03Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18–14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13–11</td>
<td>CSI_PODF</td>
</tr>
<tr>
<td>10–9</td>
<td>CSI_CLK_SEL</td>
</tr>
</tbody>
</table>

**CCM_CSCDR3 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–19</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>18–14</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>13–11</td>
<td>Post divider for csi_mclk.</td>
</tr>
<tr>
<td>CSI_PODF</td>
<td><strong>NOTE:</strong> Divider should be updated when output clock is gated.</td>
</tr>
<tr>
<td>10–9</td>
<td>Selector for csi_mclk multiplexer</td>
</tr>
<tr>
<td>CSI_CLK_SEL</td>
<td></td>
</tr>
<tr>
<td>00</td>
<td>derive clock from osc_clk (24M)</td>
</tr>
<tr>
<td>01</td>
<td>derive clock from PLL2 PFD2</td>
</tr>
<tr>
<td>10</td>
<td>derive clock from pll3_120M</td>
</tr>
<tr>
<td>11</td>
<td>derive clock from PLL3 PFD1</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
14.7.15  CCM Divider Handshake In-Process Register (CCM_CDHIPR)

The figure below represents the CCM Divider Handshake In-Process Register (CDHIPR). The CDHIPR register contains read-only bits that indicate that CCM is in the process of updating dividers or muxes that might need handshake with modules.

Address: 400F_C000h base + 48h offset = 400F_C048h

---

The diagram shows the layout of the CDHIPR register with the following fields:

- **R** (Read-Only): The register contains read-only bits.
- **ARM_PODF_BUSY**: Indicates if the ARM PODF is busy.
- **Reset**: The default state of the register when reset.

The diagram illustrates the bit positions and their default values upon reset.
### CCM_CDHIPR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>16 ARM_PODF_BUSY</td>
<td>Busy indicator for arm_podf.  &lt;br&gt;0: divider is not busy and its value represents the actual division.  &lt;br&gt;1: divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the arm_podf will be applied.</td>
</tr>
<tr>
<td>15–6 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>5 PERIPH_CLK_SEL_BUSY</td>
<td>Busy indicator for periph_clk_sel mux control.  &lt;br&gt;0: mux is not busy and its value represents the actual division.  &lt;br&gt;1: mux is busy with handshake process with module. The value read in the periph_clk_sel represents the previous value of select, and after the handshake periph_clk_sel value will be applied.</td>
</tr>
<tr>
<td>4 -</td>
<td>This field is reserved.  &lt;br&gt;Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3 PERIPH2_CLK_SEL_BUSY</td>
<td>Busy indicator for periph2_clk_sel mux control.</td>
</tr>
<tr>
<td></td>
<td>0 mux is not busy and its value represents the actual division.</td>
</tr>
<tr>
<td></td>
<td>1 mux is busy with handshake process with module. The value read in the periph2_clk_sel represents the previous value of select, and after the handshake periph2_clk_sel value will be applied.</td>
</tr>
<tr>
<td>2 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>1 AHB_PODF_BUSY</td>
<td>Busy indicator for ahb_podf.</td>
</tr>
<tr>
<td></td>
<td>0 divider is not busy and its value represents the actual division.</td>
</tr>
<tr>
<td></td>
<td>1 divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the ahb_podf will be applied.</td>
</tr>
<tr>
<td>0 SEMC_PODF_BUSY</td>
<td>Busy indicator for semc_podf.</td>
</tr>
<tr>
<td></td>
<td>0 divider is not busy and its value represents the actual division.</td>
</tr>
<tr>
<td></td>
<td>1 divider is busy with handshake process with module. The value read in the divider represents the previous value of the division factor, and after the handshake the written value of the semc_podf will be applied.</td>
</tr>
</tbody>
</table>
14.7.16  CCM Low Power Control Register (CCM_CLPCR)

The figure below represents the CCM Low Power Control Register (CLPCR). The CLPCR register contains bits to control the low power modes operation. The table below provides its field descriptions.

Address: 400F_C000h base + 54h offset = 400F_C054h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Reserved This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>27</td>
<td>MASK_L2CC_IDLE</td>
</tr>
<tr>
<td>26</td>
<td>MASK_SCU_IDLE</td>
</tr>
<tr>
<td>15–8</td>
<td>COSC_PWRDOWN, STBY_COUNT, DIS_REFCLOCK, SBYOS, ARM_CLK_DIS_ON_LPM, Reserved, Reserved, LPM</td>
</tr>
</tbody>
</table>

**CCM_CLPCR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>27 MASK_L2CC_IDLE</td>
<td>Mask L2CC IDLE for entering low power mode.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Assertion of all bits[27:22] will generate low power mode request</td>
</tr>
<tr>
<td>26 MASK_SCU_IDLE</td>
<td>Mask SCU IDLE for entering low power mode</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Assertion of all bits[27:22] will generate low power mode request</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CCM_CLPCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>25–23 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>22 MASK_CORE0_WFI</td>
<td>Mask WFI of core0 for entering low power mode</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Assertion of all bits[27:22] will generate low power mode request</td>
</tr>
<tr>
<td>22</td>
<td>0 WFI of core0 is not masked</td>
</tr>
<tr>
<td>22</td>
<td>1 WFI of core0 is masked</td>
</tr>
<tr>
<td>21 BYPASS_LPM_HS0</td>
<td>Bypass low power mode handshake.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>This bit should always be set to 1'b1 by software.</td>
</tr>
<tr>
<td>20</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>19 BYPASS_LPM_HS1</td>
<td>Bypass low power mode handshake.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>This bit should always be set to 1'b1 by software.</td>
</tr>
<tr>
<td>18–12 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>11 COSC_PWRDOWN</td>
<td>In run mode, software can manually control powering down of on chip oscillator, i.e. generating ‘1’ on cosc_pwrdown signal. If software manually powered down the on chip oscillator, then sbyos functionality for on chip oscillator will be bypassed. The manual closing of onchip oscillator should be performed only in case the reference oscillator is not the source of all the clocks generation.</td>
</tr>
<tr>
<td>11</td>
<td>0 On chip oscillator will not be powered down, i.e. cosc_pwrdown = '0'.</td>
</tr>
<tr>
<td>11</td>
<td>1 On chip oscillator will be powered down, i.e. cosc_pwrdown = '1'.</td>
</tr>
<tr>
<td>10–9 STBY_COUNT</td>
<td>Standby counter definition. These two bits define, in the case of stop exit (if VSTBY bit was set).</td>
</tr>
<tr>
<td>10–9 STBY_COUNT</td>
<td><strong>NOTE:</strong> Clock cycles ratio depends on pmic_delay_scaler, defined by CGPR[0] bit.</td>
</tr>
<tr>
<td></td>
<td>00 CCM will wait (1*pmic_delay_scaler)+1 ckil clock cycles</td>
</tr>
<tr>
<td></td>
<td>01 CCM will wait (3*pmic_delay_scaler)+1 ckil clock cycles</td>
</tr>
<tr>
<td></td>
<td>10 CCM will wait (7*pmic_delay_scaler)+1 ckil clock cycles</td>
</tr>
<tr>
<td></td>
<td>11 CCM will wait (15*pmic_delay_scaler)+1 ckil clock cycles</td>
</tr>
<tr>
<td>8 VSTBY</td>
<td>Voltage standby request bit. This bit defines if PMIC_STBY_REQ pin, which notifies external power management IC to move from functional voltage to standby voltage, will be asserted in STOP mode.</td>
</tr>
<tr>
<td>8 VSTBY</td>
<td>0 Voltage will not be changed to standby voltage after next entrance to STOP mode.</td>
</tr>
<tr>
<td></td>
<td>( PMIC_STBY_REQ will remain negated - '0')</td>
</tr>
<tr>
<td>8 VSTBY</td>
<td>1 Voltage will be requested to change to standby voltage after next entrance to stop mode.</td>
</tr>
<tr>
<td></td>
<td>( PMIC_STBY_REQ will be asserted - '1').</td>
</tr>
<tr>
<td>7 DIS_REF_OSC</td>
<td>dis_ref_os - in run mode, software can manually control closing of external reference oscillator clock, i.e. generating ‘1’ on CCM_REF_EN_B signal. If software closed manually the external reference clock, then sbyos functionality will be bypassed. The manual closing of external reference oscillator should be performed only in case the reference oscillator is not the source of any clock generation.</td>
</tr>
<tr>
<td>7 DIS_REF_OSC</td>
<td><strong>NOTE:</strong> When returning from stop mode, the PMIC_STBY_REQ will be deasserted (if it was asserted when entering stop mode). See stby_count bits.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
CCM_CLPCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>external high frequency oscillator will be enabled, i.e. CCM_REF_EN_B = '0'.</td>
</tr>
<tr>
<td>1</td>
<td>external high frequency oscillator will be disabled, i.e. CCM_REF_EN_B = '1'.</td>
</tr>
<tr>
<td>6 SBYOS</td>
<td>Standby clock oscillator bit. This bit defines if cosc_pwrdown, which power down the on chip oscillator, will be asserted in STOP mode. This bit is discarded if cosc_pwrdown='1' for the on chip oscillator.</td>
</tr>
<tr>
<td>0</td>
<td>On-chip oscillator will not be powered down, after next entrance to STOP mode. (CCM_REF_EN_B will remain asserted - '0' and cosc_pwrdown will remain de asserted - '0').</td>
</tr>
<tr>
<td>1</td>
<td>On-chip oscillator will be powered down, after next entrance to STOP mode. (CCM_REF_EN_B will be deasserted - '1' and cosc_pwrdown will be asserted - '1'). When returning from STOP mode, external oscillator will be enabled again, on-chip oscillator will return to oscillator mode, and after oscnt count, CCM will continue with the exit from the STOP mode process.</td>
</tr>
<tr>
<td>5 ARM_CLK_DIS_ON_LPM</td>
<td>Define if Arm clocks (arm_clk, soc_mxclk, soc_pclk, soc_dbg_pclk, vl_wrck) will be disabled on wait mode. This is useful for debug mode, when the user still wants to simulate entering wait mode and still keep Arm clock functioning.</td>
</tr>
<tr>
<td>0</td>
<td>Arm clock enabled on wait mode.</td>
</tr>
<tr>
<td>1</td>
<td>Arm clock disabled on wait mode.</td>
</tr>
<tr>
<td>4–3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>2 LPM</td>
<td>Setting the low power mode that system will enter on next assertion of dsm_request signal.</td>
</tr>
<tr>
<td>00</td>
<td>Remain in run mode</td>
</tr>
<tr>
<td>01</td>
<td>Transfer to wait mode</td>
</tr>
<tr>
<td>10</td>
<td>Transfer to stop mode</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

14.7.17 CCM Interrupt Status Register (CCM_CISR)

The figure below represents the CCM Interrupt Status Register (CISR). This is a write one to clear register. After an interrupt is generated, software should write one to clear it. The table below provides its field descriptions.

**NOTE**

CCM interrupt request 1 can be masked by CCM interrupt request 1 mask bit. CCM interrupt request 2 can be masked by CCM interrupt request 2 mask bit.
### CCM Memory Map/Register Definition

Address: 400F_C000h base + 58h offset = 400F_C058h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     | w1c |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### CCM_CISR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–27</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## CCM_CISR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>26 ARM_PODF_LOADED</td>
<td>CCM interrupt request 1 generated due to frequency change of arm_podf. The interrupt will commence only if arm_podf is loaded during a DVFS operation.</td>
</tr>
<tr>
<td></td>
<td>0 interrupt is not generated due to frequency change of arm_podf</td>
</tr>
<tr>
<td></td>
<td>1 interrupt generated due to frequency change of arm_podf</td>
</tr>
<tr>
<td>25–24 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>23 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>22 PERIPH_CLK_SEL_LOADED</td>
<td>CCM interrupt request 1 generated due to update of periph_clk_sel.</td>
</tr>
<tr>
<td></td>
<td>0 interrupt is not generated due to update of periph_clk_sel.</td>
</tr>
<tr>
<td></td>
<td>1 interrupt generated due to update of periph_clk_sel</td>
</tr>
<tr>
<td>21 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>20 AHB_PODF_LOADED</td>
<td>CCM interrupt request 1 generated due to frequency change of ahb_podf</td>
</tr>
<tr>
<td></td>
<td>0 interrupt is not generated due to frequency change of ahb_podf</td>
</tr>
<tr>
<td></td>
<td>1 interrupt generated due to frequency change of ahb_podf</td>
</tr>
<tr>
<td>19 PERIPH2_CLK_SEL_LOADED</td>
<td>CCM interrupt request 1 generated due to frequency change of periph2_clk_sel</td>
</tr>
<tr>
<td></td>
<td>0 interrupt is not generated due to frequency change of periph2_clk_sel</td>
</tr>
<tr>
<td></td>
<td>1 interrupt generated due to frequency change of periph2_clk_sel</td>
</tr>
<tr>
<td>18 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>17 SEMC_PODF_LOADED</td>
<td>CCM interrupt request 1 generated due to frequency change of semc_podf</td>
</tr>
<tr>
<td></td>
<td>0 interrupt is not generated due to frequency change of semc_podf</td>
</tr>
<tr>
<td></td>
<td>1 interrupt generated due to frequency change of semc_podf</td>
</tr>
<tr>
<td>16–7 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>6 COSC_READY</td>
<td>CCM interrupt request 2 generated due to on board oscillator ready, i.e. oscnt has finished counting.</td>
</tr>
<tr>
<td></td>
<td>0 interrupt is not generated due to on board oscillator ready</td>
</tr>
<tr>
<td></td>
<td>1 interrupt generated due to on board oscillator ready</td>
</tr>
<tr>
<td>5–1 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>0 LRF_PLL</td>
<td>CCM interrupt request 2 generated due to lock of all enabled and not bypased PLLs</td>
</tr>
<tr>
<td></td>
<td>0 interrupt is not generated due to lock ready of all enabled and not bypased PLLs</td>
</tr>
<tr>
<td></td>
<td>1 interrupt generated due to lock ready of all enabled and not bypased PLLs</td>
</tr>
</tbody>
</table>
14.7.18  CCM Interrupt Mask Register (CCM_CIMR)

The figure below represents the CCM Interrupt Mask Register (CIMR). The table below provides its field descriptions.

Address: 400F_C000h base + 5Ch offset = 400F_C05Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field Description</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–27</td>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>26</td>
<td>ARM_PODF_LOADED</td>
<td>mask interrupt generation due to frequency change of arm_podf</td>
</tr>
<tr>
<td>25</td>
<td>MASK_PERIPH_CLK_SEL_LOADED</td>
<td>0 don't mask interrupt due to frequency change of arm_podf - interrupt will be created</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 mask interrupt due to frequency change of arm_podf</td>
</tr>
<tr>
<td>22</td>
<td>MASK_PERIPH2_CLK_SEL_LOADED</td>
<td>mask interrupt generation due to update of periph_clk_sel.</td>
</tr>
<tr>
<td>21</td>
<td>MASK_SEMC_PODF_LOADED</td>
<td>0 don't mask interrupt due to update of periph_clk_sel - interrupt will be created</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 mask interrupt due to update of periph_clk_sel</td>
</tr>
<tr>
<td>20</td>
<td>MASK_AHB_PODF_LOADED</td>
<td>0 don't mask interrupt due to frequency change of arm_podf - interrupt will be created</td>
</tr>
<tr>
<td>19</td>
<td>MASK_PERIPH_CLK_SEL_LOADED</td>
<td>1 mask interrupt due to frequency change of arm_podf</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>20 MASK_AHB_PODF_LOADED</td>
<td>mask interrupt generation due to frequency change of ahb_podf</td>
</tr>
<tr>
<td>0</td>
<td>don't mask interrupt due to frequency change of ahb_podf -</td>
</tr>
<tr>
<td>1</td>
<td>interrupt will be created</td>
</tr>
<tr>
<td>19 MASK_PERIPH2_CLK_SEL_LOAD</td>
<td>mask interrupt generation due to update of periph2_clk_sel.</td>
</tr>
<tr>
<td>0</td>
<td>don't mask interrupt due to update of periph2_clk_sel - interrupt will be created</td>
</tr>
<tr>
<td>1</td>
<td>mask interrupt due to update of periph2_clk_sel</td>
</tr>
<tr>
<td>18</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>17 MASK_SEMC_PODF_LOADED</td>
<td>mask interrupt generation due to frequency change of semc_podf</td>
</tr>
<tr>
<td>0</td>
<td>don't mask interrupt due to frequency change of semc_podf -</td>
</tr>
<tr>
<td>1</td>
<td>interrupt will be created</td>
</tr>
<tr>
<td>16–7 Reserved</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>6 MASK_COSC_READY</td>
<td>mask interrupt generation due to on board oscillator ready</td>
</tr>
<tr>
<td>0</td>
<td>don't mask interrupt due to on board oscillator ready -</td>
</tr>
<tr>
<td>1</td>
<td>interrupt will be created</td>
</tr>
<tr>
<td>5–1 Reserved</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>0 MASK_LRF_PLL</td>
<td>mask interrupt generation due to lrf of PLLs</td>
</tr>
<tr>
<td>0</td>
<td>don't mask interrupt due to lrf of PLLs - interrupt will be</td>
</tr>
<tr>
<td>1</td>
<td>created</td>
</tr>
<tr>
<td>1</td>
<td>mask interrupt due to lrf of PLLs</td>
</tr>
</tbody>
</table>
14.7.19  CCM Clock Output Source Register (CCM_CCOSR)

The figure below represents the CCM Clock Output Source Register (CCOSR). The CCOSR register contains bits to control the clock that will be generated on the output ipp_do_clko1. The table below provides its field descriptions.

Address: 400F_C000h base + 60h offset = 400F_C060h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Bit</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

CCM_CCOSR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–25</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 24      | CCM_CLKO2_EN| Enable of CCM_CLKO2 clock
|         | 0            | CCM_CLKO2 disabled. |
|         | 1            | CCM_CLKO2 enabled. |
| 23–21   | CCM_CLKO2_DIV| Setting the divider of CCM_CLKO2 |
|         | 000          | divide by 1 |
|         | 001          | divide by 2 |
|         | 010          | divide by 3 |
|         | 011          | divide by 4 |
|         | 100          | divide by 5 |
|         | 101          | divide by 6 |
|         | 110          | divide by 7 |
|         | 111          | divide by 8 |
| 20–16   | CCM_CLKO2_SEL| Selection of the clock to be generated on CCM_CLKO2 |
|         | 00011        | usdhc1_clk_root |
|         | 00110        | lpi2c_clk_root |
### CCM_CCOSR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>01011</td>
<td>csi_clk_root</td>
</tr>
<tr>
<td>01110</td>
<td>osc_clk</td>
</tr>
<tr>
<td>10001</td>
<td>usdhc2_clk_root</td>
</tr>
<tr>
<td>10010</td>
<td>sai1_clk_root</td>
</tr>
<tr>
<td>10011</td>
<td>sai2_clk_root</td>
</tr>
<tr>
<td>10100</td>
<td>sai3_clk_root (shared with ADC1 and ADC2 alt_clk root)</td>
</tr>
<tr>
<td>10111</td>
<td>can_clk_root (FlexCAN, shared with CANFD)</td>
</tr>
<tr>
<td>11011</td>
<td>flexspi_clk_root</td>
</tr>
<tr>
<td>11100</td>
<td>uart_clk_root</td>
</tr>
<tr>
<td>11101</td>
<td>spdif0_clk_root</td>
</tr>
<tr>
<td>11111</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–9</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>CLK_OUT_SEL</td>
</tr>
<tr>
<td>0</td>
<td>CCM_CLKO1 output drives CCM_CLKO1 clock</td>
</tr>
<tr>
<td>1</td>
<td>CCM_CLKO1 output drives CCM_CLKO2 clock</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>CLKO1_EN</td>
</tr>
<tr>
<td>0</td>
<td>CCM_CLKO1 disabled.</td>
</tr>
<tr>
<td>1</td>
<td>CCM_CLKO1 enabled.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6–4</td>
<td>CLKO1_DIV</td>
</tr>
<tr>
<td>000</td>
<td>divide by 1</td>
</tr>
<tr>
<td>001</td>
<td>divide by 2</td>
</tr>
<tr>
<td>010</td>
<td>divide by 3</td>
</tr>
<tr>
<td>011</td>
<td>divide by 4</td>
</tr>
<tr>
<td>100</td>
<td>divide by 5</td>
</tr>
<tr>
<td>101</td>
<td>divide by 6</td>
</tr>
<tr>
<td>110</td>
<td>divide by 7</td>
</tr>
<tr>
<td>111</td>
<td>divide by 8</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>CLKO1_SEL</td>
</tr>
<tr>
<td>0000</td>
<td>USB1 PLL clock (divided by 2)</td>
</tr>
<tr>
<td>0001</td>
<td>SYS PLL clock (divided by 2)</td>
</tr>
<tr>
<td>0011</td>
<td>VIDEO PLL clock (divided by 2)</td>
</tr>
<tr>
<td>0101</td>
<td>semc_clk_root</td>
</tr>
<tr>
<td>0110</td>
<td>Reserved</td>
</tr>
<tr>
<td>1010</td>
<td>lcdif_pix_clk_root</td>
</tr>
<tr>
<td>1011</td>
<td>ahb_clk_root</td>
</tr>
<tr>
<td>1100</td>
<td>ipg_clk_root</td>
</tr>
<tr>
<td>1101</td>
<td>perclk_root</td>
</tr>
<tr>
<td>1110</td>
<td>ckl_sync_clk_root</td>
</tr>
<tr>
<td>1111</td>
<td>pll4_main_clk</td>
</tr>
</tbody>
</table>
14.7.20  CCM General Purpose Register (CCM_CGPR)

Fast PLL enable. Can be used to engage PLL faster after STOP mode, if 24MHz OSC was active

Address: 400F_C000h base + 64h offset = 400F_C064h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–18</td>
<td>Reserved</td>
<td>0</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 17   | INT_MEM_CLK_LPM                                  | 1     | Control for the Deep Sleep signal to the Arm Platform memories with additional control logic based on the Arm WFI signal. Used to keep the Arm Platform memory clocks enabled if an interrupt is pending when entering low power mode.  

**NOTE:** This bit should always be set when the CCM_CLPCR_LPM bits are set to 01(WAIT Mode) or 10 (STOP mode) without power gating. This bit does not have to be set for STOP mode entry.  

0  Disable the clock to the Arm platform memories when entering Low Power Mode  
1  Keep the clocks to the Arm platform memories enabled only if an interrupt is pending when entering Low Power Modes (WAIT and STOP without power gating)  

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>FPL</td>
<td>1</td>
<td>Fast PLL enable.</td>
</tr>
</tbody>
</table>

0  Engage PLL enable default way.  
1  Engage PLL enable 3 CKIL clocks earlier at exiting low power mode (STOP). Should be used only if 24MHz OSC was active in low power mode.  

Table continues on the next page...
### CCM_CGPR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 SYS_MEM_DS_CTRL</td>
<td>System memory DS control</td>
</tr>
<tr>
<td>00</td>
<td>Disable memory DS mode always</td>
</tr>
<tr>
<td>01</td>
<td>Enable memory (outside Arm platform) DS mode when system STOP and PLL are disabled</td>
</tr>
<tr>
<td>1x</td>
<td>Enable memory (outside Arm platform) DS mode when system is in STOP mode</td>
</tr>
<tr>
<td>13–9 Reserved</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>8–7 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>6–5 Reserved</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>4 EFUSE_PROG_SUPPLY_GATE</td>
<td>Defines the value of the output signal cgpr_dout[4]. Gate of program supply for efuse programming</td>
</tr>
<tr>
<td>0</td>
<td>fuse programing supply voltage is gated off to the efuse module</td>
</tr>
<tr>
<td>1</td>
<td>allow fuse programing.</td>
</tr>
<tr>
<td>3–2 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>1 Reserved</td>
<td>Reserved. Keep default value set to '1' for proper operation.</td>
</tr>
<tr>
<td>0 PMIC_DELAY_SCALER</td>
<td>Defines clock division of clock for stby_count (pmic delay counter)</td>
</tr>
<tr>
<td>0</td>
<td>clock is not divided</td>
</tr>
<tr>
<td>1</td>
<td>clock is divided /8</td>
</tr>
</tbody>
</table>

### 14.7.21 CCM Clock Gating Register 0 (CCM_CCGR0)

**CG(i) bits CCGR 0-6**

These bits are used to turn on/off the clock to each module independently. The following table details the possible clock activity conditions for each module.

<table>
<thead>
<tr>
<th>CGR value</th>
<th>Clock Activity Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Clock is off during all modes. Stop enter hardware handshake is disabled.</td>
</tr>
<tr>
<td>01</td>
<td>Clock is on in run mode, but off in WAIT and STOP modes</td>
</tr>
<tr>
<td>10</td>
<td>Not applicable (Reserved).</td>
</tr>
<tr>
<td>11</td>
<td>Clock is on during all modes, except STOP mode.</td>
</tr>
</tbody>
</table>

Module should be stopped, before set its bits to "0"; clocks to the module will be stopped immediately.

The tables above show the register mappings for the different CGRs. The clock connectivity table should be used to match the "CCM output affected" to the actual clocks going into the modules.
The figure below represents the CCM Clock Gating Register 0 (CCM_CCGR0). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 7 CGR registers. The number of registers required is according to the number of peripherals in the system.

Address: 400F_C000h base + 68h offset = 400F_C068h

<table>
<thead>
<tr>
<th>Bit</th>
<th>RW</th>
<th>CG15</th>
<th>CG14</th>
<th>CG13</th>
<th>CG12</th>
<th>CG11</th>
<th>CG10</th>
<th>CG9</th>
<th>CG8</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>RW</th>
<th>CG7</th>
<th>CG6</th>
<th>CG5</th>
<th>CG4</th>
<th>CG3</th>
<th>CG2</th>
<th>CG1</th>
<th>CG0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

**CCM_CCGR0 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>gpio2_clocks (gpio2 clk_enable)</td>
</tr>
<tr>
<td>29–28</td>
<td>lpuart2 clock (lpuart2 clk_enable)</td>
</tr>
<tr>
<td>27–26</td>
<td>gpt2 serial clocks (gpt2_serial_clk_enable)</td>
</tr>
<tr>
<td>25–24</td>
<td>gpt2 bus clocks (gpt2_bus_clk_enable)</td>
</tr>
<tr>
<td>23–22</td>
<td>trace clock (trace_clk_enable)</td>
</tr>
<tr>
<td>21–20</td>
<td>can2_serial clock (can2_serial_clk_enable)</td>
</tr>
<tr>
<td>19–18</td>
<td>can2 clock (can2_clk_enable)</td>
</tr>
<tr>
<td>17–16</td>
<td>can1_serial clock (can1_serial_clk_enable)</td>
</tr>
<tr>
<td>15–14</td>
<td>can1 clock (can1_clk_enable)</td>
</tr>
<tr>
<td>13–12</td>
<td>lpuart3 clock (lpuart3_clk_enable)</td>
</tr>
<tr>
<td>11–10</td>
<td>dcp clock (dcp_clk_enable)</td>
</tr>
<tr>
<td>9–8</td>
<td>sim_m or sim_main register access clock (sim_m_mainclk_r_enable)</td>
</tr>
<tr>
<td>7–6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5–4</td>
<td>mqs clock (mqs_hmclk_clock_enable)</td>
</tr>
<tr>
<td>3–2</td>
<td>aips_tz2 clocks (aips_tz2_clk_enable)</td>
</tr>
<tr>
<td>1</td>
<td>aips_tz1 clocks (aips_tz1_clk_enable)</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
14.7.22 CCM Clock Gating Register 1 (CCM_CCGR1)

The figure below represents the CCM Clock Gating Register 1 (CCM_CCGR1). The clock gating registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 400F_C000h base + 6Ch offset = 400F_C06Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>CG15</td>
<td>CG14</td>
<td>CG13</td>
<td>CG12</td>
<td>CG11</td>
<td>CG10</td>
<td>CG9</td>
<td>CG8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>CG7</td>
<td>CG6</td>
<td>CG5</td>
<td>CG4</td>
<td>CG3</td>
<td>CG2</td>
<td>CG1</td>
<td>CG0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

**CCM_CCGR1 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>gpio5 clock (gpio5_clk_enable)</td>
</tr>
<tr>
<td>29–28</td>
<td>csu clock (csu_clk_enable)</td>
</tr>
<tr>
<td>27–26</td>
<td>gpio1 clock (gpio1_clk_enable)</td>
</tr>
<tr>
<td>25–24</td>
<td>lpuart4 clock (lpuart4_clk_enable)</td>
</tr>
<tr>
<td>23–22</td>
<td>gpt1 serial clock (gpt_serial_clk_enable)</td>
</tr>
<tr>
<td>21–20</td>
<td>gpt1 bus clock (gpt_clk_enable)</td>
</tr>
<tr>
<td>19–18</td>
<td>semc_exsc clock (semc_exsc_clk_enable)</td>
</tr>
<tr>
<td>17–16</td>
<td>adc1 clock (adc1_clk_enable)</td>
</tr>
<tr>
<td>15–14</td>
<td>aoi2 clocks (aoi2_clk_enable)</td>
</tr>
<tr>
<td>13–12</td>
<td>pit clocks (pit_clk_enable)</td>
</tr>
<tr>
<td>11–10</td>
<td>enet clock (enet_clk_enable)</td>
</tr>
<tr>
<td>9–8</td>
<td>adc2 clock (adc2_clk_enable)</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
CCM_CCGR1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7–6</td>
<td>lpspi4 clocks (lpspi4_clk_enable)</td>
</tr>
<tr>
<td>5–4</td>
<td>lpspi3 clocks (lpspi3_clk_enable)</td>
</tr>
<tr>
<td>3–2</td>
<td>lpspi2 clocks (lpspi2_clk_enable)</td>
</tr>
<tr>
<td>CG0</td>
<td>lpspi1 clocks (lpspi1_clk_enable)</td>
</tr>
</tbody>
</table>

14.7.23 CCM Clock Gating Register 2 (CCM_CCGR2)

The figure below represents the CCM Clock Gating Register 2 (CCM_CCGR2). The clock gating registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 400F_C000h base + 70h offset = 400F_C070h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CG15</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>CG14</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>CG13</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>CG12</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>CG11</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>CG10</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>CG9</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>CG8</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

CCM_CCGR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>pxp clocks (pxp_clk_enable)</td>
</tr>
<tr>
<td>29–28</td>
<td>lcd clocks (lcd_clk_enable)</td>
</tr>
<tr>
<td>27–26</td>
<td>gpio3 clock (gpio3_clk_enable)</td>
</tr>
<tr>
<td>25–24</td>
<td>xbar2 clock (xbar2_clk_enable)</td>
</tr>
<tr>
<td>23–22</td>
<td>xbar1 clock (xbar1_clk_enable)</td>
</tr>
<tr>
<td>21–20</td>
<td>ipmux3 clock (ipmux3_clk_enable)</td>
</tr>
<tr>
<td>19–18</td>
<td>ipmux2 clock (ipmux2_clk_enable)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
CCM_CCGR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17–16</td>
<td>ipmux1 clock (ipmux1_clks_enable)</td>
</tr>
<tr>
<td>15–14</td>
<td>xbar3 clock (xbar3_clk_enable)</td>
</tr>
<tr>
<td>13–12</td>
<td>OCOTP_CTRL clock (ocotp_clk_enable)</td>
</tr>
<tr>
<td>11–10</td>
<td>lpi2c3 clock (lpi2c3_clk_enable)</td>
</tr>
<tr>
<td>9–8</td>
<td>lpi2c2 clock (lpi2c2_clk_enable)</td>
</tr>
<tr>
<td>7–6</td>
<td>lpi2c1 clock (lpi2c1_clk_enable)</td>
</tr>
<tr>
<td>5–4</td>
<td>iomuxc_snvs clock (iomuxc_snvs_clk_enable)</td>
</tr>
<tr>
<td>3–2</td>
<td>csi clock (csi_clk_enable)</td>
</tr>
<tr>
<td>0</td>
<td>ocram_exsc clock (ocram_exsc_clk_enable)</td>
</tr>
</tbody>
</table>

14.7.24 CCM Clock Gating Register 3 (CCM_CCGR3)

The figure below represents the CCM Clock Gating Register 3 (CCM_CCGR3). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

**NOTE**

The OCRAM clock cannot be turned off when CM7 Cache is running. For details, refer to CCM_CCGR3[CG14] bitfield.

Address: 400F_C000h base + 74h offset = 400F_C074h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CG15</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CG7</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>
## CCM_CCRG3 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 CG15</td>
<td>iomuxc_snvs_gpr clock (iomuxc_snvs_gpr_clk_enable)</td>
</tr>
<tr>
<td>29–28 CG14</td>
<td>The OCRAM clock cannot be turned off when the CM cache is running on this device. ocram clock(ocram_clk_enable)</td>
</tr>
<tr>
<td>27–26 CG13</td>
<td>acmp4 clocks (acmp4_clk_enable)</td>
</tr>
<tr>
<td>25–24 CG12</td>
<td>acmp3 clocks (acmp3_clk_enable)</td>
</tr>
<tr>
<td>23–22 CG11</td>
<td>acmp2 clocks (acmp2_clk_enable)</td>
</tr>
<tr>
<td>21–20 CG10</td>
<td>acmp1 clocks (acmp1_clk_enable)</td>
</tr>
<tr>
<td>19–18 CG9</td>
<td>flexram clock (flexram_clk_enable)</td>
</tr>
<tr>
<td>17–16 CG8</td>
<td>wdog1 clock (wdog1_clk_enable)</td>
</tr>
<tr>
<td>15–14 CG7</td>
<td>ewm clocks (ewm_clk_enable)</td>
</tr>
<tr>
<td>13–12 CG6</td>
<td>gpio4 clock (gpio4_clk_enable)</td>
</tr>
<tr>
<td>11–10 CG5</td>
<td>lcdif pix clock (lcdif_pix_clk_enable)</td>
</tr>
<tr>
<td>9–8 CG4</td>
<td>aoi1 clock (aoi1_clk_enable)</td>
</tr>
<tr>
<td>7–6 CG3</td>
<td>lpuart6 clock (lpuart6_clk_enable)</td>
</tr>
<tr>
<td>5–4 CG2</td>
<td>semc clocks (semc_clk_enable)</td>
</tr>
<tr>
<td>3–2 CG1</td>
<td>lpuart5 clock (lpuart5_clk_enable)</td>
</tr>
<tr>
<td>CG0</td>
<td>flexio2 clocks (flexio2_clk_enable)</td>
</tr>
</tbody>
</table>
14.7.25  CCM Clock Gating Register 4 (CCM_CCGR4)

The figure below represents the CCM Clock Gating Register 4 (CCM_CCGR4). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 400F_C000h base + 78h offset = 400F_C078h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>CG15</td>
<td>CG14</td>
<td>CG13</td>
<td>CG12</td>
<td>CG11</td>
<td>CG10</td>
<td>CG9</td>
<td>CG8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>CG7</td>
<td>CG6</td>
<td>CG5</td>
<td>CG4</td>
<td>CG3</td>
<td>CG2</td>
<td>CG1</td>
<td>CG0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

### CCM_CCGR4 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>CG15 enc4 clocks (enc4_clk_enable)</td>
</tr>
<tr>
<td>29–28</td>
<td>CG14 enc3 clocks (enc3_clk_enable)</td>
</tr>
<tr>
<td>27–26</td>
<td>CG13 enc2 clocks (enc2_clk_enable)</td>
</tr>
<tr>
<td>25–24</td>
<td>CG12 enc1 clocks (enc1_clk_enable)</td>
</tr>
<tr>
<td>23–22</td>
<td>CG11 pwm4 clocks (pwm4_clk_enable)</td>
</tr>
<tr>
<td>21–20</td>
<td>CG10 pwm3 clocks (pwm3_clk_enable)</td>
</tr>
<tr>
<td>19–18</td>
<td>CG9  pwm2 clocks (pwm2_clk_enable)</td>
</tr>
<tr>
<td>17–16</td>
<td>CG8  pwm1 clocks (pwm1_clk_enable)</td>
</tr>
<tr>
<td>15–14</td>
<td>CG7  sim_ems clocks (sim_ems_clk_enable)</td>
</tr>
<tr>
<td>13–12</td>
<td>CG6  sim_m clocks (sim_m_clk_enable)</td>
</tr>
<tr>
<td>11–10</td>
<td>CG5  tsc_dig clock (tsc_clk_enable)</td>
</tr>
<tr>
<td>9–8</td>
<td>CG4  sim_m7 clock (sim_m7_clk_enable)</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### CCM_CCGR4 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7–6</td>
<td>bee clock (bee_clk_enable)</td>
</tr>
<tr>
<td>5–4</td>
<td>iomuxc gpr clock (iomuxc_gpr_clk_enable)</td>
</tr>
<tr>
<td>3–2</td>
<td>iomuxc clock (iomuxc_clk_enable)</td>
</tr>
<tr>
<td>CG0</td>
<td>sim_m7 register access clock (sim_m7_mainclk_r_enable)</td>
</tr>
</tbody>
</table>

### 14.7.26 CCM Clock Gating Register 5 (CCM_CCGR5)

The figure below represents the CCM Clock Gating Register 5 (CCM_CCGR5). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 400F_C000h base + 7Ch offset = 400F_C07Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>CG15</th>
<th>CG14</th>
<th>CG13</th>
<th>CG12</th>
<th>CG11</th>
<th>CG10</th>
<th>CG9</th>
<th>CG8</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

### CCM_CCGR5 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>snvs_lp clock (snvs_lp_clk_enable)</td>
</tr>
<tr>
<td>29–28</td>
<td>snvs_hp clock (snvs_hp_clk_enable)</td>
</tr>
<tr>
<td>27–26</td>
<td>lpuart7 clock (lpuart7_clk_enable)</td>
</tr>
<tr>
<td>25–24</td>
<td>lpuart1 clock (lpuart1_clk_enable)</td>
</tr>
<tr>
<td>23–22</td>
<td>sai3 clock (sai3_clk_enable)</td>
</tr>
<tr>
<td>21–20</td>
<td>sai2 clock (sai2_clk_enable)</td>
</tr>
<tr>
<td>19–18</td>
<td>sai1 clock (sai1_clk_enable)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
CCM_CCGR5 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17–16</td>
<td>sim_main clock (sim_main_clk_enable)</td>
</tr>
<tr>
<td>15–14</td>
<td>spdif clock (spdif_clk_enable)</td>
</tr>
<tr>
<td>13–12</td>
<td>aipstz4 clocks (aips_tz4_clk_enable)</td>
</tr>
<tr>
<td>11–10</td>
<td>wdog2 clock (wdog2_clk_enable)</td>
</tr>
<tr>
<td>9–8</td>
<td>kpp clock (kpp_clk_enable)</td>
</tr>
<tr>
<td>7–6</td>
<td>dma clock (dma_clk_enable)</td>
</tr>
<tr>
<td>5–4</td>
<td>wdog3 clock (wdog3_clk_enable)</td>
</tr>
<tr>
<td>3–2</td>
<td>flexio1 clock (flexio1_clk_enable)</td>
</tr>
<tr>
<td>1</td>
<td>rom clock (rom_clk_enable)</td>
</tr>
</tbody>
</table>

14.7.27   CCM Clock Gating Register 6 (CCM_CCGR6)

The figure below represents the CCM Clock Gating Register 6 (CCM_CCGR6). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 400F_C000h base + 80h offset = 400F_C080h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

CCM_CCGR6 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>timer3 clocks (timer3_clk_enable)</td>
</tr>
<tr>
<td>29–28</td>
<td>timer2 clocks (timer2_clk_enable)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>27–26</td>
<td>timer1 clocks (timer1_clk_enable)</td>
</tr>
<tr>
<td>CG13</td>
<td></td>
</tr>
<tr>
<td>25–24</td>
<td>lpi2c4 serial clock (lpi2c4_serial_clk_enable)</td>
</tr>
<tr>
<td>CG12</td>
<td></td>
</tr>
<tr>
<td>23–22</td>
<td>anadig clocks (anadig_clk_enable)</td>
</tr>
<tr>
<td>CG11</td>
<td></td>
</tr>
<tr>
<td>21–20</td>
<td>sim_axbs_p_clk_enable</td>
</tr>
<tr>
<td>CG10</td>
<td></td>
</tr>
<tr>
<td>19–18</td>
<td>aips_tz3 clock (aips_tz3_clk_enable)</td>
</tr>
<tr>
<td>CG9</td>
<td></td>
</tr>
<tr>
<td>17–16</td>
<td>timer4 clocks (timer4_clk_enable)</td>
</tr>
<tr>
<td>CG8</td>
<td></td>
</tr>
<tr>
<td>15–14</td>
<td>lpuart8 clocks (lpuart8_clk_enable)</td>
</tr>
<tr>
<td>CG7</td>
<td></td>
</tr>
<tr>
<td>13–12</td>
<td>trng clock (trng_clk_enable)</td>
</tr>
<tr>
<td>CG6</td>
<td></td>
</tr>
<tr>
<td>11–10</td>
<td>flexspi clocks (flexspi_clk_enable)</td>
</tr>
<tr>
<td>CG5</td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> sim_ems_clk_enable must also be cleared, when flexspi_clk_enable is cleared.</td>
</tr>
<tr>
<td>9–8</td>
<td>ipmux4 clock (ipmux4_clk_enable)</td>
</tr>
<tr>
<td>CG4</td>
<td></td>
</tr>
<tr>
<td>7–6</td>
<td>dcdc clocks (dcdc_clk_enable)</td>
</tr>
<tr>
<td>CG3</td>
<td></td>
</tr>
<tr>
<td>5–4</td>
<td>usdhc2 clocks (usdhc2_clk_enable)</td>
</tr>
<tr>
<td>CG2</td>
<td></td>
</tr>
<tr>
<td>3–2</td>
<td>usdhc1 clocks (usdhc1_clk_enable)</td>
</tr>
<tr>
<td>CG1</td>
<td></td>
</tr>
<tr>
<td>CG0</td>
<td>usboh3 clock (usboh3_clk_enable)</td>
</tr>
</tbody>
</table>
14.7.28 CCM Clock Gating Register 7 (CCM_CCGR7)

The figure below represents the CCM Clock Gating Register 7 (CCM_CCGR7). The clock gating Registers define the clock gating for power reduction of each clock (CG(i) bits). There are 8 CGR registers. The number of registers required is determined by the number of peripherals in the system.

Address: 400F_C000h base + 84h offset = 400F_C084h

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15–14</th>
<th>13–12</th>
<th>11–10</th>
<th>9–8</th>
<th>7–6</th>
<th>5–4</th>
<th>3–2</th>
<th>1–0</th>
</tr>
</thead>
<tbody>
<tr>
<td>RW</td>
<td>Reserved</td>
<td>CG6</td>
<td>CG5</td>
<td>CG4</td>
<td>CG3</td>
<td>CG2</td>
<td>CG1</td>
<td>CG0</td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

CCM_CCGR7 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>29–28</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>27–26</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>25–24</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>23–22</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>21–20</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>19–18</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>17–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>15–14</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>13–12</td>
<td>flexio3_clk_enable</td>
</tr>
<tr>
<td>CG6</td>
<td></td>
</tr>
<tr>
<td>11–10</td>
<td>aips_lite_clk_enable</td>
</tr>
<tr>
<td>CG5</td>
<td></td>
</tr>
<tr>
<td>9–8</td>
<td>can3_serial_clk_enable</td>
</tr>
<tr>
<td>CG4</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
CCM_CCGR7 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7–6</td>
<td>can3_clk_enable</td>
</tr>
<tr>
<td>CG3</td>
<td></td>
</tr>
<tr>
<td>5–4</td>
<td>axbs_l_clk_enable</td>
</tr>
<tr>
<td>CG2</td>
<td></td>
</tr>
<tr>
<td>3–2</td>
<td>flexspi2_clk_enable</td>
</tr>
<tr>
<td>CG1</td>
<td></td>
</tr>
<tr>
<td>CG0</td>
<td>enet2_clk_enable</td>
</tr>
</tbody>
</table>

14.7.29 CCM Module Enable Override Register (CCM_CMEOR)

The follow figure represents the CCM Module Enable Override Register (CMEOR). The CMEOR register contains bits to override the clock enable signal from the module. This bit will be applicable only for modules whose clock enable signals are used. The following table provides its field descriptions.

Address: 400F_C000h base + 88h offset = 400F_C088h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>MOD_EN_OV_CAN1_CPI</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>MOD_EN_OV_CAN2_CPI</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>MOD_EN_OV_CANFD_CPI</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>MOD_EN_OV_TRNG</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>MOD_EN_USDHC</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>MOD_EN_OV_PIT</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>MOD_EN_OV_GPT</td>
<td></td>
</tr>
</tbody>
</table>

CCM_CMEOR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### CCM_CMEOR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MOD_EN_OV_CAN1_CPI 30</td>
<td>Overide clock enable signal from CAN1 - clock will not be gated based on CAN's signal 'enable_clk_cpi'.</td>
</tr>
<tr>
<td>0</td>
<td>don't override module enable signal</td>
</tr>
<tr>
<td>1</td>
<td>override module enable signal</td>
</tr>
<tr>
<td>Reserved 29</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>MOD_EN_OV_CAN2_CPI 28</td>
<td>Overide clock enable signal from CAN2 - clock will not be gated based on CAN's signal 'enable_clk_cpi'.</td>
</tr>
<tr>
<td>0</td>
<td>don't override module enable signal</td>
</tr>
<tr>
<td>1</td>
<td>override module enable signal</td>
</tr>
<tr>
<td>Reserved 27–11</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>MOD_EN_OV_CANFD_CPI 10</td>
<td>Overide clock enable signal from FlexCAN3(CANFD) - clock will not be gated based on CAN's signal 'enable_clk_cpi'.</td>
</tr>
<tr>
<td>0</td>
<td>don't override module enable signal</td>
</tr>
<tr>
<td>1</td>
<td>override module enable signal</td>
</tr>
<tr>
<td>Reserved 9</td>
<td>Overide clock enable signal from TRNG</td>
</tr>
<tr>
<td>0</td>
<td>don't override module enable signal</td>
</tr>
<tr>
<td>1</td>
<td>override module enable signal</td>
</tr>
<tr>
<td>Reserved 8</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>MOD_EN_USDHC 7</td>
<td>Overide clock enable signal from USDHC.</td>
</tr>
<tr>
<td>0</td>
<td>don't override module enable signal</td>
</tr>
<tr>
<td>1</td>
<td>override module enable signal</td>
</tr>
<tr>
<td>Reserved 6</td>
<td>Overide clock enable signal from PIT - clock will not be gated based on PIT's signal 'ipg_enable_clk' .</td>
</tr>
<tr>
<td>0</td>
<td>don't override module enable signal</td>
</tr>
<tr>
<td>1</td>
<td>override module enable signal</td>
</tr>
<tr>
<td>Reserved 5</td>
<td>Overide clock enable signal from GPT - clock will not be gated based on GPT's signal 'ipg_enable_clk'.</td>
</tr>
<tr>
<td>0</td>
<td>don't override module enable signal</td>
</tr>
<tr>
<td>1</td>
<td>override module enable signal</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
</tbody>
</table>
This section describes the registers for the analog PLLs. The registers which have the same description are grouped within {}. The register offsets for the various PLLs are:

- **ARM PLL**: \{0h000, 0h004, 0h008, 0h00C\}.
- **USB1 PLL**: \{0h010, 0h014, 0h018, 0h01C\}, \{0h0F0, 0h0F4, 0h0F8, 0h0FC\}.
- **System PLL**: \{0h030, 0h034, 0h038, 0h03C\}, 0h040, 0h050, 0h060, \{0h100, 0h104, 0h108, 0h10C\}.
- **Audio / Video PLL**: \{0h070, 0h074, 0h078, 0h07C\}, 0h080, 0h090, \{0h0A0, 0h0A4, 0h0A8, 0h0AC\}, 0h0B0, 0h0C0

### CCM_ANALOG memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_8000</td>
<td>Analog ARM PLL control Register (CCM_ANALOG_PLL_ARM)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3063h</td>
<td>14.8.1/1099</td>
</tr>
<tr>
<td>400D_8004</td>
<td>Analog ARM PLL control Register (CCM_ANALOG_PLL_ARM_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3063h</td>
<td>14.8.1/1099</td>
</tr>
<tr>
<td>400D_8008</td>
<td>Analog ARM PLL control Register (CCM_ANALOG_PLL_ARM_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3063h</td>
<td>14.8.1/1099</td>
</tr>
<tr>
<td>400D_800C</td>
<td>Analog ARM PLL control Register (CCM_ANALOG_PLL_ARM_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3063h</td>
<td>14.8.1/1099</td>
</tr>
<tr>
<td>400D_8010</td>
<td>Analog USB1 480MHz PLL Control Register (CCM_ANALOG_PLL_USB1)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.2/1101</td>
</tr>
<tr>
<td>400D_8014</td>
<td>Analog USB1 480MHz PLL Control Register (CCM_ANALOG_PLL_USB1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.2/1101</td>
</tr>
<tr>
<td>400D_8018</td>
<td>Analog USB1 480MHz PLL Control Register (CCM_ANALOG_PLL_USB1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.2/1101</td>
</tr>
<tr>
<td>400D_801C</td>
<td>Analog USB1 480MHz PLL Control Register (CCM_ANALOG_PLL_USB1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.2/1101</td>
</tr>
<tr>
<td>400D_8020</td>
<td>Analog USB2 480MHz PLL Control Register (CCM_ANALOG_PLL_USB2)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.3/1104</td>
</tr>
<tr>
<td>400D_8024</td>
<td>Analog USB2 480MHz PLL Control Register (CCM_ANALOG_PLL_USB2_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.3/1104</td>
</tr>
<tr>
<td>400D_8028</td>
<td>Analog USB2 480MHz PLL Control Register (CCM_ANALOG_PLL_USB2_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.3/1104</td>
</tr>
<tr>
<td>400D_802C</td>
<td>Analog USB2 480MHz PLL Control Register (CCM_ANALOG_PLL_USB2_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_2000h</td>
<td>14.8.3/1104</td>
</tr>
<tr>
<td>400D_8030</td>
<td>Analog System PLL Control Register (CCM_ANALOG_PLL_SYS)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3001h</td>
<td>14.8.4/1106</td>
</tr>
<tr>
<td>400D_8034</td>
<td>Analog System PLL Control Register (CCM_ANALOG_PLL_SYS_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3001h</td>
<td>14.8.4/1106</td>
</tr>
<tr>
<td>400D_8038</td>
<td>Analog System PLL Control Register (CCM_ANALOG_PLL_SYS_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3001h</td>
<td>14.8.4/1106</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CCM_ANALOG memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_803C</td>
<td>Analog System PLL Control Register (CCM_ANALOG_PLL_SYS_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_3001h</td>
<td>14.8.4/1106</td>
</tr>
<tr>
<td>400D_8040</td>
<td>528MHz System PLL Spread Spectrum Register (CCM_ANALOG_PLL_SYS_SS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>14.8.5/1107</td>
</tr>
<tr>
<td>400D_8050</td>
<td>Numerator of 528MHz System PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_SYS_NUM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>14.8.6/1108</td>
</tr>
<tr>
<td>400D_8060</td>
<td>Denominator of 528MHz System PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_SYS_DENOM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0012h</td>
<td>14.8.7/1109</td>
</tr>
<tr>
<td>400D_8070</td>
<td>Analog Audio PLL control Register (CCM_ANALOG_PLL_AUDIO)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1006h</td>
<td>14.8.8/1110</td>
</tr>
<tr>
<td>400D_8074</td>
<td>Analog Audio PLL control Register (CCM_ANALOG_PLL_AUDIO_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1006h</td>
<td>14.8.8/1110</td>
</tr>
<tr>
<td>400D_8078</td>
<td>Analog Audio PLL control Register (CCM_ANALOG_PLL_AUDIO_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1006h</td>
<td>14.8.8/1110</td>
</tr>
<tr>
<td>400D_807C</td>
<td>Analog Audio PLL control Register (CCM_ANALOG_PLL_AUDIO_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1006h</td>
<td>14.8.8/1110</td>
</tr>
<tr>
<td>400D_8080</td>
<td>Numerator of Audio PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_AUDIO_NUM)</td>
<td>32</td>
<td>R/W</td>
<td>05F5_E100h</td>
<td>14.8.9/1112</td>
</tr>
<tr>
<td>400D_8090</td>
<td>Denominator of Audio PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_AUDIO_DENOM)</td>
<td>32</td>
<td>R/W</td>
<td>2964_619Ch</td>
<td>14.8.10/1112</td>
</tr>
<tr>
<td>400D_80A0</td>
<td>Analog Video PLL control Register (CCM_ANALOG_PLL_VIDEO)</td>
<td>32</td>
<td>R/W</td>
<td>0001_100Ch</td>
<td>14.8.11/1114</td>
</tr>
<tr>
<td>400D_80A4</td>
<td>Analog Video PLL control Register (CCM_ANALOG_PLL_VIDEO_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_100Ch</td>
<td>14.8.11/1114</td>
</tr>
<tr>
<td>400D_80A8</td>
<td>Analog Video PLL control Register (CCM_ANALOG_PLL_VIDEO_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_100Ch</td>
<td>14.8.11/1114</td>
</tr>
<tr>
<td>400D_80AC</td>
<td>Analog Video PLL control Register (CCM_ANALOG_PLL_VIDEO_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_100Ch</td>
<td>14.8.11/1114</td>
</tr>
<tr>
<td>400D_80B0</td>
<td>Numerator of Video PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_VIDEO_NUM)</td>
<td>32</td>
<td>R/W</td>
<td>05F5_E100h</td>
<td>14.8.12/1116</td>
</tr>
<tr>
<td>400D_80C0</td>
<td>Denominator of Video PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_VIDEO_DENOM)</td>
<td>32</td>
<td>R/W</td>
<td>10A2_4447h</td>
<td>14.8.13/1116</td>
</tr>
<tr>
<td>400D_80E0</td>
<td>Analog ENET PLL Control Register (CCM_ANALOG_PLL_ENET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1001h</td>
<td>14.8.14/1118</td>
</tr>
<tr>
<td>400D_80E4</td>
<td>Analog ENET PLL Control Register (CCM_ANALOG_PLL_ENET_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1001h</td>
<td>14.8.14/1118</td>
</tr>
<tr>
<td>400D_80E8</td>
<td>Analog ENET PLL Control Register (CCM_ANALOG_PLL_ENET_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1001h</td>
<td>14.8.14/1118</td>
</tr>
<tr>
<td>400D_80EC</td>
<td>Analog ENET PLL Control Register (CCM_ANALOG_PLL_ENET_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_1001h</td>
<td>14.8.14/1118</td>
</tr>
<tr>
<td>400D_80F0</td>
<td>480MHz Clock (PLL3) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_480)</td>
<td>32</td>
<td>R/W</td>
<td>1311_100Ch</td>
<td>14.8.15/1120</td>
</tr>
<tr>
<td>400D_80F4</td>
<td>480MHz Clock (PLL3) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_480_SET)</td>
<td>32</td>
<td>R/W</td>
<td>1311_100Ch</td>
<td>14.8.15/1120</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## CCM_ANALOG memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_80F8</td>
<td>480MHz Clock (PLL3) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_480_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>1311_100Ch</td>
<td>14.8.15/1120</td>
</tr>
<tr>
<td>400D_80FC</td>
<td>480MHz Clock (PLL3) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_480_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>1311_100Ch</td>
<td>14.8.15/1120</td>
</tr>
<tr>
<td>400D_8100</td>
<td>528MHz Clock (PLL2) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_528)</td>
<td>32</td>
<td>R/W</td>
<td>1018_101Bh</td>
<td>14.8.16/1122</td>
</tr>
<tr>
<td>400D_8104</td>
<td>528MHz Clock (PLL2) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_528_SET)</td>
<td>32</td>
<td>R/W</td>
<td>1018_101Bh</td>
<td>14.8.16/1122</td>
</tr>
<tr>
<td>400D_8108</td>
<td>528MHz Clock (PLL2) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_528_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>1018_101Bh</td>
<td>14.8.16/1122</td>
</tr>
<tr>
<td>400D_810C</td>
<td>528MHz Clock (PLL2) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_528_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>1018_101Bh</td>
<td>14.8.16/1122</td>
</tr>
<tr>
<td>400D_8150</td>
<td>Miscellaneous Register 0 (CCM_ANALOG_MISC0)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>14.8.17/1125</td>
</tr>
<tr>
<td>400D_8154</td>
<td>Miscellaneous Register 0 (CCM_ANALOG_MISC0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>14.8.17/1125</td>
</tr>
<tr>
<td>400D_8158</td>
<td>Miscellaneous Register 0 (CCM_ANALOG_MISC0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>14.8.17/1125</td>
</tr>
<tr>
<td>400D_815C</td>
<td>Miscellaneous Register 0 (CCM_ANALOG_MISC0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>14.8.17/1125</td>
</tr>
<tr>
<td>400D_8160</td>
<td>Miscellaneous Register 1 (CCM_ANALOG_MISC1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>14.8.18/1129</td>
</tr>
<tr>
<td>400D_8164</td>
<td>Miscellaneous Register 1 (CCM_ANALOG_MISC1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>14.8.18/1129</td>
</tr>
<tr>
<td>400D_8168</td>
<td>Miscellaneous Register 1 (CCM_ANALOG_MISC1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>14.8.18/1129</td>
</tr>
<tr>
<td>400D_816C</td>
<td>Miscellaneous Register 1 (CCM_ANALOG_MISC1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>14.8.18/1129</td>
</tr>
<tr>
<td>400D_8170</td>
<td>Miscellaneous Register 2 (CCM_ANALOG_MISC2)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>14.8.19/1132</td>
</tr>
<tr>
<td>400D_8174</td>
<td>Miscellaneous Register 2 (CCM_ANALOG_MISC2_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>14.8.19/1132</td>
</tr>
<tr>
<td>400D_8178</td>
<td>Miscellaneous Register 2 (CCM_ANALOG_MISC2_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>14.8.19/1132</td>
</tr>
<tr>
<td>400D_817C</td>
<td>Miscellaneous Register 2 (CCM_ANALOG_MISC2_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>14.8.19/1132</td>
</tr>
</tbody>
</table>
14.8.1 Analog ARM PLL control Register  
(CCM_ANALOG_PLL_ARMn)

The control register provides control for the system PLL.

Address: 400D_8000h base + 0h offset + (4d × i), where i=0d to 3d

### CCM_ANALOG_PLL_ARMn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 LOCK</td>
<td>1 - PLL is currently locked.</td>
</tr>
<tr>
<td>0 - PLL is not currently locked.</td>
<td></td>
</tr>
<tr>
<td>30–20 -</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>19 PLL_SEL</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CCM_ANALOG_PLL_ARMn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>18–17 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>16 BYPASS</td>
<td>Bypass the PLL.</td>
</tr>
<tr>
<td>15–14 BYPASS_CLK_SRC</td>
<td>Determines the bypass source.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Changing the Bypass clock source also changes the PLL reference clock source.</td>
</tr>
<tr>
<td>0x0</td>
<td><strong>REF_CLK_24M</strong> — Select the 24MHz oscillator as source.</td>
</tr>
<tr>
<td>0x1</td>
<td><strong>CLK1</strong> — Select the CLK1_N / CLK1_P as source.</td>
</tr>
<tr>
<td>0x2</td>
<td><strong>Reserved1</strong> —</td>
</tr>
<tr>
<td>0x3</td>
<td><strong>Reserved2</strong> —</td>
</tr>
<tr>
<td>13 ENABLE</td>
<td>Enable the clock output.</td>
</tr>
<tr>
<td>12 POWERDOWN</td>
<td>Powers down the PLL.</td>
</tr>
<tr>
<td>11–7 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>DIV_SELECT</td>
<td>This field controls the PLL loop divider. Valid range for divider value: 54-108. Fout = Fin * div_select/2.0.</td>
</tr>
</tbody>
</table>
14.8.2 Analog USB1 480MHz PLL Control Register (CCM_ANALOG_PLL_USB1n)

The control register provides control for USBPHY0 480MHz PLL.

Address: 400D_8000h base + 10h offset + (4d × i), where i=0d to 3d
### CCM_ANALOG_PLL_USB1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>LOCK</td>
</tr>
<tr>
<td>0 - PLL is not currently locked.</td>
<td></td>
</tr>
<tr>
<td>1 - PLL is currently locked.</td>
<td></td>
</tr>
<tr>
<td>30–17</td>
<td>-</td>
</tr>
<tr>
<td>Always set to zero (0).</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>BYPASS</td>
</tr>
<tr>
<td>Bypass the PLL.</td>
<td></td>
</tr>
<tr>
<td>15–14</td>
<td>BYPASS_CLK_SRC</td>
</tr>
<tr>
<td>Determines the bypass source.</td>
<td></td>
</tr>
<tr>
<td>0x0 REF_CLK_24M — Select the 24MHz oscillator as source.</td>
<td></td>
</tr>
<tr>
<td>0x1 CLK1 — Select the CLK1_N / CLK1_P as source.</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>ENABLE</td>
</tr>
<tr>
<td>Enable the PLL clock output.</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>POWER</td>
</tr>
<tr>
<td>Powers up the PLL. This bit will be set automatically when USBPHY0 remote wakeup event happens.</td>
<td></td>
</tr>
<tr>
<td>11–7</td>
<td>-</td>
</tr>
<tr>
<td>Always set to zero (0).</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>EN_USB_CLKS</td>
</tr>
<tr>
<td>Powers the 9-phase PLL outputs for USBPHYn. Additionally, the UTMI clock gate must be deasserted in the USBPHYn to enable USBn operation (clear CLKGATE bit in USBPHYn_CTRL). This bit will be set automatically when USBPHYn remote wakeup event occurs.</td>
<td></td>
</tr>
<tr>
<td>0 PLL outputs for USBPHYn off.</td>
<td></td>
</tr>
<tr>
<td>1 PLL outputs for USBPHYn on.</td>
<td></td>
</tr>
<tr>
<td>5–2</td>
<td>-</td>
</tr>
<tr>
<td>Always set to zero (0).</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>DIV_SELECT</td>
</tr>
<tr>
<td>This field controls the PLL loop divider. 0 - Fout=Ref<em>20; 1 - Fout=Ref</em>22.</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved.</td>
</tr>
</tbody>
</table>
14.8.3 Analog USB2 480MHz PLL Control Register (CCM_ANALOG_PLL_USB2n)

The control register provides control for USBPHY1 480MHz PLL.

Address: \textasciitilde400D_8000h base + 20h offset + (4d \times i), where i=0d to 3d

![Diagram of the control register with bit 16 set]
### CCM_ANALOG_PLL_USB2n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>LOCK 1 - PLL is currently locked. 0 - PLL is not currently locked.</td>
</tr>
<tr>
<td>30–17</td>
<td>- Always set to zero (0).</td>
</tr>
<tr>
<td>16</td>
<td>BYPASS Bypass the PLL.</td>
</tr>
<tr>
<td>15–14</td>
<td>BYPASS_CLK_SRC Determines the bypass source.</td>
</tr>
<tr>
<td>0x0</td>
<td>REF_CLK_24M — Select the 24MHz oscillator as source.</td>
</tr>
<tr>
<td>0x1</td>
<td>CLK1 — Select the CLK1_N / CLK1_P as source.</td>
</tr>
<tr>
<td>0x2</td>
<td>Reserved1 —</td>
</tr>
<tr>
<td>0x3</td>
<td>Reserved2 —</td>
</tr>
<tr>
<td>13</td>
<td>ENABLE Enable the PLL clock output.</td>
</tr>
<tr>
<td>12</td>
<td>POWER Powers up the PLL. This bit will be set automatically when USBPHY1 remote wakeup event happens.</td>
</tr>
<tr>
<td>11–7</td>
<td>- Always set to zero (0).</td>
</tr>
<tr>
<td>6</td>
<td>EN_USB_CLKS 0: 8-phase PLL outputs for USBPHY1 are powered down. If set to 1, 8-phase PLL outputs for USBPHY1 are powered up. Additionally, the utmi clock gate must be deasserted in the USBPHY1 to enable USB0 operation (clear CLKGATE bit in USBPHY1_CTRL).This bit will be set automatically when USBPHY1 remote wakeup event happens.</td>
</tr>
<tr>
<td>5–2</td>
<td>- Always set to zero (0).</td>
</tr>
<tr>
<td>1</td>
<td>DIV_SELECT This field controls the PLL loop divider. 0 - Fout=Fref<em>20; 1 - Fout=Fref</em>22.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
14.8.4  Analog System PLL Control Register  
(CCM_ANALOG_PLL_SYSn)

The control register provides control for the 528MHz PLL.

Address: 400D_8000h base + 30h offset + (4d × i), where i=0d to 3d
## CCM_ANALOG_PLL_SYS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 LOCK</td>
<td>1 - PLL is currently locked; 0 - PLL is not currently locked.</td>
</tr>
<tr>
<td>30–19</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>18–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 BYPASS</td>
<td>Bypass the PLL.</td>
</tr>
</tbody>
</table>
| 15–14 BYPASS_CLK_SRC | Determines the bypass source.  
                                  | 0x0  REF_CLK_24M — Select the 24MHz oscillator as source.  
                                  | 0x1  CLK1 — Select the CLK1_N / CLK1_P as source.          |
| 13 ENABLE      | Enable PLL output                                                           |
| 12 POWERDOWN   | Powers down the PLL.                                                        |
| 11–7           | This field is reserved. Reserved                                            |
| 6–1            | Always set to zero (0).                                                     |
| 0 DIV_SELECT   | This field controls the PLL loop divider. 0 - Fout=Fref*20; 1 - Fout=Fref*22. |

### 14.8.5 528MHz System PLL Spread Spectrum Register (CCM_ANALOG_PLL_SYS_SS)

This register contains the 528MHz PLL spread spectrum controls.

This register contains the 528MHz PLL spread spectrum controls.

**Address:** 400D_8000h base + 40h offset = 400D_8040h

```
+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
<table>
<thead>
<tr>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>STOP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bit</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td>ENABLE</td>
<td>STEP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bit</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td>ENABLE</td>
<td>STEP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### CCM_ANALOG_PLL_SYS_SS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 STOP</td>
<td>Frequency change = stop/CCM_ANALOG_PLL_SYS_DENOM[B] * 24MHz.</td>
</tr>
<tr>
<td>15 ENABLE</td>
<td>Enable bit</td>
</tr>
<tr>
<td></td>
<td>0 — Spread spectrum modulation disabled</td>
</tr>
<tr>
<td></td>
<td>1 — Spread spectrum modulation enabled</td>
</tr>
<tr>
<td>STEP</td>
<td>Frequency change step = step/CCM_ANALOG_PLL_SYS_DENOM[B] * 24MHz.</td>
</tr>
</tbody>
</table>

### Numerator of 528MHz System PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_SYS_NUM)

This register contains the numerator of 528MHz PLL fractional loop divider (signed number).

Absolute value should be less than denominator.

Address: 400D_8000h base + 50h offset = 400D_8050h

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    | -  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### CCM_ANALOG_PLL_SYS_NUM field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>A</td>
<td>30 bit numerator (A) of fractional loop divider (signed integer).</td>
</tr>
</tbody>
</table>
14.8.7 Denominator of 528MHz System PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_SYS_DENOM)

This register contains the denominator of 528MHz PLL fractional loop divider.

Address: 400D_8000h base + 60h offset = 400D_8060h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | -  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Reset** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0

**CCM_ANALOG_PLL_SYS_DENOM field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>-</td>
<td></td>
</tr>
<tr>
<td>B</td>
<td>30 bit denominator (B) of fractional loop divider (unsigned integer).</td>
</tr>
</tbody>
</table>
14.8.8 Analog Audio PLL control Register
(CCM_ANALOG_PLL_AUDIO\textsubscript{n})

The control register provides control for the audio PLL.

Address: \texttt{400D_8000h base + 70h offset + (4d \times i)} where \texttt{i=0d to 3d}

\begin{table}[h]
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline
\hline
\hline
\hline
Reset & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 \\
\hline
\end{tabular}
\end{table}
### CCM_ANALOG_PLL_AUDIO field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 LOCK</td>
<td>1 - PLL is currently locked. 0 - PLL is not currently locked.</td>
</tr>
<tr>
<td>30–22 -</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>21 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>20–19 POST_DIV_SELECT</td>
<td>These bits implement a divider after the PLL, but before the enable and bypass mux.</td>
</tr>
<tr>
<td>00</td>
<td>— Divide by 4.</td>
</tr>
<tr>
<td>01</td>
<td>— Divide by 2.</td>
</tr>
<tr>
<td>10</td>
<td>— Divide by 1.</td>
</tr>
<tr>
<td>11</td>
<td>— Reserved</td>
</tr>
<tr>
<td>18–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 BYPASS</td>
<td>Bypass the PLL.</td>
</tr>
<tr>
<td>15–14 BYPASS_CLK_SRC</td>
<td>Determines the bypass source.</td>
</tr>
<tr>
<td>0x0 REF_CLK_24M</td>
<td>— Select the 24MHz oscillator as source.</td>
</tr>
<tr>
<td>0x1 CLK1</td>
<td>— Select the CLK1_N / CLK1_P as source.</td>
</tr>
<tr>
<td>0x2 Reserved1</td>
<td>—</td>
</tr>
<tr>
<td>0x3 Reserved2</td>
<td>—</td>
</tr>
<tr>
<td>13 ENABLE</td>
<td>Enable PLL output</td>
</tr>
<tr>
<td>12 POWERDOWN</td>
<td>Powers down the PLL.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 14.8.9 Numerator of Audio PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_AUDIO_NUM)

This register contains the numerator (A) of Audio PLL fractional loop divider (Signed number).

Absolute value should be less than denominator

Address: 400D_8000h base + 80h offset = 400D_8080h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | -  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### CCM_ANALOG_PLL_AUDIO_NUM field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>A</td>
<td>30 bit numerator of fractional loop divider.</td>
</tr>
</tbody>
</table>

### 14.8.10 Denominator of Audio PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_AUDIO_DENOM)

This register contains the denominator (B) of Audio PLL fractional loop divider (unsigned number).

Address: 400D_8000h base + 90h offset = 400D_8090h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | -  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | 0  |

---

CCM ANALOG_PLL_AUDIO
field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11–7</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>DIV_SELECT</td>
<td>This field controls the PLL loop divider. Valid range for DIV_SELECT divider value: 27~54.</td>
</tr>
</tbody>
</table>
## CCM_ANALOG_PLL_AUDIO_DENOM field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>B</td>
<td>30 bit denominator of fractional loop divider.</td>
</tr>
</tbody>
</table>
14.8.11 Analog Video PLL control Register (CCM_ANALOG_PLL_VIDEO\textsubscript{n})

The control register provides control for the Video PLL.

Address: \(400D_{\text{h}}8000h\) base + A0h offset + \((4d \times i)\), where \(i=0d\) to \(3d\)
### CCM_ANALOG_PLL_VIDEO field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31  LOCK</td>
<td>1 - PLL is currently locked; 0 - PLL is not currently locked.</td>
</tr>
<tr>
<td>30–22 Reserved</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>21  Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>20–19 POST_DIV_SELECT</td>
<td>These bits implement a divider after the PLL, but before the enable and bypass mux.</td>
</tr>
<tr>
<td>18–17 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16  BYPASS</td>
<td>Bypass the PLL.</td>
</tr>
<tr>
<td>15–14 BYPASS_CLK_SRC</td>
<td>Determines the bypass source.</td>
</tr>
<tr>
<td>0x0 REF_CLK_24M</td>
<td>Select the 24MHz oscillator as source.</td>
</tr>
<tr>
<td>0x1 CLK1</td>
<td>Select the CLK1_N / CLK1_P as source.</td>
</tr>
<tr>
<td>0x2 Reserved1</td>
<td>—</td>
</tr>
<tr>
<td>0x3 Reserved2</td>
<td>—</td>
</tr>
<tr>
<td>13  ENABLE</td>
<td>Enable PLL output</td>
</tr>
<tr>
<td>12  POWERDOWN</td>
<td>Powers down the PLL.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### CCM_ANALOG_PLL_VIDEO field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11–7 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>DIV_SELECT</td>
<td>This field controls the PLL loop divider. Valid range for DIV_SELECT divider value: 27–54.</td>
</tr>
</tbody>
</table>

### 14.8.12 Numerator of Video PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_VIDEO_NUM)

This register contains the numerator (A) of Video PLL fractional loop divider (signed number).

Absolute value should be less than denominator

Address: 400D_8000h base + B0h offset = 400D_80B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>A</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 1 0 1 1 1 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### CCM_ANALOG_PLL_VIDEO_NUM field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>A</td>
<td>30 bit numerator of fractional loop divider (signed number). The absolute value should be less than denominator.</td>
</tr>
</tbody>
</table>

### 14.8.13 Denominator of Video PLL Fractional Loop Divider Register (CCM_ANALOG_PLL_VIDEO_DENOM)

This register contains the denominator (B) of Video PLL fractional loop divider (unsigned number).

Address: 400D_8000h base + C0h offset = 400D_80C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>B</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 1 1 1
## CCM_ANALOG_PLL_VIDEO_DENOM field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>Always set to zero (0).</td>
</tr>
<tr>
<td>B</td>
<td>30 bit denominator of fractional loop divider.</td>
</tr>
</tbody>
</table>
14.8.14 Analog ENET PLL Control Register
(CCM_ANALOG_PLL_ENETn)

The control register provides control for the ENET PLL.

Address: 400D_8000h base + E0h offset + (4d × i), where i=0d to 3d
### Chapter 14 Clock Controller Module (CCM)

![Bitwise diagram](image)

#### CCM_ANALOG_PLL_ENETn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>LOCK 1 - PLL is currently locked; 0 - PLL is not currently locked.</td>
</tr>
<tr>
<td>30–22</td>
<td>- Always set to zero (0).</td>
</tr>
<tr>
<td>21</td>
<td>ENET_25M_REF_EN Enable the PLL providing ENET 25 MHz reference clock</td>
</tr>
<tr>
<td>20</td>
<td>ENET2_REF_EN Enable the PLL providing the ENET reference clock</td>
</tr>
<tr>
<td>19</td>
<td>- This field is reserved. Reserved</td>
</tr>
<tr>
<td>18–17</td>
<td>- This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>BYPASS Bypass the PLL.</td>
</tr>
<tr>
<td>15–14</td>
<td>BYPASS_CLK_SRC Determines the bypass source.</td>
</tr>
<tr>
<td>12</td>
<td>POWERDOWN Powers down the PLL.</td>
</tr>
<tr>
<td>11–7</td>
<td>- This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

---

*Table continues on the next page...*
14.8.15 480MHz Clock (PLL3) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_480n)

The PFD_480 control register provides control for PFD clock generation.

This register controls the 4-phase fractional clock dividers. The fractional clock frequencies are a product of the values in these registers.

Address: 400D_8000h base + F0h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit 31 30 29 28 27 26 25 24</th>
<th>Bit 23 22 21 20 19 18 17 16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>PFD3_CLKGATE</td>
</tr>
<tr>
<td>PFD3_STABLE</td>
<td>PFD3_FRAC</td>
</tr>
<tr>
<td>W</td>
<td></td>
</tr>
<tr>
<td>Reset 0 0 0 1 0 0 1 1</td>
<td>0 0 0 1 0 0 0 1</td>
</tr>
</tbody>
</table>
### i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

**Chapter 14 Clock Controller Module (CCM)**

#### CCM_ANALOG_PFD_480n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 - PFD3_CLKGATE</td>
<td>IO Clock Gate. If set to 1, the 3rd fractional divider clock (reference ref_pfd3) is off (power savings). 0: ref_pfd3 fractional divider clock is enabled. Need to assert this bit before PLL is powered down</td>
</tr>
<tr>
<td>30 - PFD3_STABLE</td>
<td>This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code. The value inverts when the new programmed fractional divide value has taken effect. Read this bit, program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state.</td>
</tr>
<tr>
<td>29-24 - PFD3_FRAC</td>
<td>This field controls the fractional divide value. The resulting frequency shall be 480*18/PFD3_FRAC where PFD3_FRAC is in the range 12-35.</td>
</tr>
<tr>
<td>23 - PFD2_CLKGATE</td>
<td>IO Clock Gate. If set to 1, the IO fractional divider clock (reference ref_pfd2) is off (power savings). 0: ref_pfd2 fractional divider clock is enabled. Need to assert this bit before PLL is powered down</td>
</tr>
<tr>
<td>22 - PFD2_STABLE</td>
<td>This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code. The value inverts when the new programmed fractional divide value has taken effect. Read this bit, program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state.</td>
</tr>
<tr>
<td>21-16 - PFD2_FRAC</td>
<td>This field controls the fractional divide value. The resulting frequency shall be 480*18/PFD2_FRAC where PFD2_FRAC is in the range 12-35.</td>
</tr>
<tr>
<td>15 - PFD1_CLKGATE</td>
<td>IO Clock Gate. If set to 1, the IO fractional divider clock (reference ref_pfd1) is off (power savings). 0: ref_pfd1 fractional divider clock is enabled. Need to assert this bit before PLL is powered down</td>
</tr>
<tr>
<td>14 - PFD1_STABLE</td>
<td>This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code. The value inverts when the new programmed fractional divide value has taken effect. Read this bit,</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CCM_ANALOG_PFD_480n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13–8 PFD1_FRAC</td>
<td>This field controls the fractional divide value. The resulting frequency shall be 480*18/PFD1_FRAC where PFD1_FRAC is in the range 12-35.</td>
</tr>
<tr>
<td>7 PFD0_CLKGATE</td>
<td>If set to 1, the IO fractional divider clock (reference ref_pfd0) is off (power savings). 0: ref_pfd0 fractional divider clock is enabled. Read this bit, program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state.</td>
</tr>
<tr>
<td>6 PFD0_STABLE</td>
<td>This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code. The value inverts when the new programmed fractional divide value has taken effect. Read this bit, program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state.</td>
</tr>
<tr>
<td>PFD0_FRAC</td>
<td>This field controls the fractional divide value. The resulting frequency shall be 480*18/PFD0_FRAC where PFD0_FRAC is in the range 12-35.</td>
</tr>
</tbody>
</table>

### 14.8.16 528MHz Clock (PLL2) Phase Fractional Divider Control Register (CCM_ANALOG_PFD_528n)

The PFD_528 control register provides control for PFD clock generation.

This register controls the 3-phase fractional clock dividers. The fractional clock frequencies are a product of the values in these registers.

Address: 400D_8000h base + 100h offset + (4d × i), where i=0d to 3d

![Register Diagram](image-url)
### CCM_ANALOG_PFD_528n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31 PFD3_CLKGATE | IO Clock Gate. If set to 1, the 3rd fractional divider clock (reference ref_pfd3) is off (power savings). 0: ref_pfd3 fractional divider clock is enabled.  
Need to assert this bit before PLL powered down |
| 30 PFD3_STABLE | This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code.  
The value inverts when the new programmed fractional divide value has taken effect. Read this bit, program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state. |
| 29–24 PFD3_FRAC | This field controls the fractional divide value. The resulting frequency shall be $528 \times 18 / PFD3_{FRAC}$ where $PFD3_{FRAC}$ is in the range 12-35. |
| 23 PFD2_CLKGATE | IO Clock Gate. If set to 1, the IO fractional divider clock (reference ref_pfd2) is off (power savings). 0: ref_pfd2 fractional divider clock is enabled.  
Need to assert this bit before PLL powered down |
| 22 PFD2_STABLE | This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code.  
The value inverts when the new programmed fractional divide value has taken effect. Read this bit, program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state. |
| 21–16 PFD2_FRAC | This field controls the fractional divide value. The resulting frequency shall be $528 \times 18 / PFD2_{FRAC}$ where $PFD2_{FRAC}$ is in the range 12-35. |
| 15 PFD1_CLKGATE | IO Clock Gate. If set to 1, the IO fractional divider clock (reference ref_pfd1) is off (power savings). 0: ref_pfd1 fractional divider clock is enabled.  
Need to assert this bit before PLL powered down |
| 14 PFD1_STABLE | This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code.  
The value inverts when the new programmed fractional divide value has taken effect. Read this bit, |

*Table continues on the next page...*
### CCM_ANALOG_PFD_528n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state.</td>
</tr>
<tr>
<td>13–8</td>
<td>PFD1_FRAC This field controls the fractional divide value. The resulting frequency shall be 528*18/PFD1_FRAC where PFD1_FRAC is in the range 12-35.</td>
</tr>
<tr>
<td>7</td>
<td>PFD0_CLKGATE If set to 1, the IO fractional divider clock (reference ref_pfd0) is off (power savings). 0: ref_pfd0 fractional divider clock is enabled. Need to assert this bit before PLL powered down.</td>
</tr>
<tr>
<td>6</td>
<td>PFD0_STABLE This read-only bitfield is for DIAGNOSTIC PURPOSES ONLY since the fractional divider should become stable quickly enough that this field will never need to be used by either device driver or application code. The value inverts when the new programmed fractional divide value has taken effect. Read this bit, program the new value, and when this bit inverts, the phase divider clock output is stable. Note that the value will not invert when the fractional divider is taken out of or placed into clock-gated state.</td>
</tr>
<tr>
<td></td>
<td>PFD0_FRAC This field controls the fractional divide value. The resulting frequency shall be 528*18/PFD0_FRAC where PFD0_FRAC is in the range 12-35.</td>
</tr>
</tbody>
</table>
14.8.17 Miscellaneous Register 0 (CCM_ANALOG_MISC0n)

This register defines the control and status bits for miscellaneous analog blocks.

Address: 400D_8000h base + 150h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- **XTAL_24M_PWD**: Reserved
- **RTC_XTAL_SOURCE**: CLKGATE_DELAY
- **CLKGATE_CTRL**: Reserved
- **OSC_XTALOK_EN**

---

Chapter 14 Clock Controller Module (CCM)

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### CCM_ANALOG_MISC0n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>30</td>
<td>XTAL_24M_PWD</td>
</tr>
<tr>
<td></td>
<td>This field powers down the 24M crystal oscillator if set true.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to CCM. See <a href="https://docs.nxp.com">Crystal Oscillator (XTALOSC)</a></td>
</tr>
<tr>
<td>29</td>
<td>RTC_XTAL_SOURCE</td>
</tr>
<tr>
<td></td>
<td>This field indicates which chip source is being used for the rtc clock.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to CCM. See <a href="https://docs.nxp.com">Crystal Oscillator (XTALOSC)</a></td>
</tr>
<tr>
<td>0</td>
<td>Internal ring oscillator</td>
</tr>
<tr>
<td>1</td>
<td>RTC_XTAL</td>
</tr>
<tr>
<td>28–26</td>
<td>CLKGATE_DELAY</td>
</tr>
<tr>
<td></td>
<td>This field specifies the delay between powering up the XTL 24MHz clock and</td>
</tr>
<tr>
<td></td>
<td>releasing the clock to the digital logic inside the analog block.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Do not change the field during a low power event. This is not a</td>
</tr>
<tr>
<td></td>
<td>field that the user would normally need to modify.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to CCM. See <a href="https://docs.nxp.com">Crystal Oscillator (XTALOSC)</a></td>
</tr>
<tr>
<td>000</td>
<td>0.5ms</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>001</td>
<td>1.0ms</td>
</tr>
<tr>
<td>010</td>
<td>2.0ms</td>
</tr>
<tr>
<td>011</td>
<td>3.0ms</td>
</tr>
<tr>
<td>100</td>
<td>4.0ms</td>
</tr>
<tr>
<td>101</td>
<td>5.0ms</td>
</tr>
<tr>
<td>110</td>
<td>6.0ms</td>
</tr>
<tr>
<td>111</td>
<td>7.0ms</td>
</tr>
</tbody>
</table>

**25 CLKGATE_CTRL**

This bit allows disabling the clock gate (always ungated) for the xtal 24MHz clock that clocks the digital logic in the analog block.

**NOTE:** Do not change the field during a low power event. This is not a field that the user would normally need to modify.

**NOTE:** Not related to CCM. See Crystal Oscillator (XTALOSC)

0  **ALLOW_AUTO_GATE** — Allow the logic to automatically gate the clock when the XTAL is powered down.

1  **NO_AUTO_GATE** — Prevent the logic from ever gating off the clock.

**24–17 -**

This field is reserved.

Always set to zero.

**16 OSC_XTALOK_EN**

This bit enables the detector that signals when the 24MHz crystal oscillator is stable.

**NOTE:** Not related to CCM. See Crystal Oscillator (XTALOSC)

**15 OSC_XTALOK**

Status bit that signals that the output of the 24-MHz crystal oscillator is stable. Generated from a timer and active detection of the actual frequency.

**NOTE:** Not related to CCM. See Crystal Oscillator (XTALOSC)

**14–13 OSC_I**

This field determines the bias current in the 24MHz oscillator. The aim is to start up with the highest bias current, which can be decreased after startup if it is determined to be acceptable.

**NOTE:** Not related to CCM. See Crystal Oscillator (XTALOSC)

00  **NOMINAL** — Nominal

01  **MINUS_12.5_PERCENT** — Decrease current by 12.5%

10  **MINUS_25_PERCENT** — Decrease current by 25.0%

11  **MINUS_37.5_PERCENT** — Decrease current by 37.5%

**12 DISCON_HIGH_SNVS**

This bit controls a switch from VDD_HIGH_IN to VDD_SNVS_IN.

0  Turn on the switch

1  Turn off the switch

**11–10 STOP_MODE_CONFIG**

Configure the analog behavior in stop mode.

00  All analog except RTC powered down on stop mode assertion.

01  Beside RTC, analog bandgap, 1p1 and 2p5 regulators are also on.

10  Beside RTC, 1p1 and 2p5 regulators are also on, low-power bandgap is selected so that the normal analog bandgap together with the rest analog is powered down.

11  Beside RTC, low-power bandgap is selected and the rest analog is powered down.

*Table continues on the next page...*
### CCM_ANALOG_MISC0n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>9–8</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 7     | REFTOP_VBGUP Status bit that signals the analog bandgap voltage is up and stable. 1 - Stable.  
**NOTE:** Not related to CCM. See Power Management Unit (PMU) |
| 6–4   | REFTOP_VBGADJ  
**NOTE:** Not related to CCM. See Power Management Unit (PMU)  
000 Nominal VBG  
001 VBG+0.78%  
010 VBG+1.56%  
011 VBG+2.34%  
100 VBG-0.78%  
101 VBG-1.56%  
110 VBG-2.34%  
111 VBG-3.12% |
| 3     | REFTOP_SELFBIASOFF Control bit to disable the self-bias circuit in the analog bandgap. The self-bias circuit is used by the bandgap during startup. This bit should be set after the bandgap has stabilized and is necessary for best noise performance of analog blocks using the outputs of the bandgap.  
**NOTE:** Value should be returned to zero before removing vddhigh_in or asserting bit 0 of this register (REFTOP_PWD) to assure proper restart of the circuit.  
**NOTE:** Not related to CCM. See Power Management Unit (PMU)  
0 Uses coarse bias currents for startup  
1 Uses bandgap-based bias currents for best performance |
| 2–1   | This field is reserved. |
| 0     | REFTOP_PWD Control bit to power-down the analog bandgap reference circuitry.  
**NOTE:** A note of caution, the bandgap is necessary for correct operation of most of the LDO, PLL, and other analog functions on the die.  
**NOTE:** Not related to CCM. See Power Management Unit (PMU) |
14.8.18 Miscellaneous Register 1 (CCM_ANALOG_MISC1n)

This register defines the control and status bits for miscellaneous analog blocks. The LVDS1 and LVDS2 controls below control the behavior of the anaclk1/1b LVDS IO.

Address: 400D_8000h base + 160h offset + (4d × i), where i=0d to 3d

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>IRQ_DIG_BO</td>
<td>IRQ_ANA_BO</td>
<td>IRQ_TEMPHIGH</td>
<td>IRQ_TEMPLEW</td>
<td>IRQ_TEMPPANIC</td>
<td>Reserved</td>
<td>PFD_528_AUTOGATE_EN</td>
<td>PFD_480_AUTOGATE_EN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td>LVDSCLK1_IBEN</td>
<td>Reserved</td>
<td>LVDSCLK1_OBEN</td>
<td>Reserved</td>
<td>Reserved</td>
<td>LVDS1_CLK_SEL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```
### CCM_ANALOG_MISC1n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IRQ_DIG_BO</td>
<td>This status bit is set to one when any of the digital regulator brownout interrupts assert. Check the regulator status bits to discover which regulator interrupt asserted.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to CCM. See Power Management Unit (PMU)</td>
</tr>
<tr>
<td>IRQ_ANA_BO</td>
<td>This status bit is set to one when any of the analog regulator brownout interrupts assert. Check the regulator status bits to discover which regulator interrupt asserted.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to CCM. See Power Management Unit (PMU)</td>
</tr>
<tr>
<td>IRQ_TEMPHIGH</td>
<td>This status bit is set to one when the temperature sensor high interrupt asserts for high temperature.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to CCM. See Temperature Monitor (TEMPMON)</td>
</tr>
<tr>
<td>IRQ_TEMPLLOW</td>
<td>This status bit is set to one when the temperature sensor low interrupt asserts for low temperature.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to CCM. See Temperature Monitor (TEMPMON)</td>
</tr>
<tr>
<td>IRQ_TEMPPANIC</td>
<td>This status bit is set to one when the temperature sensor panic interrupt asserts for a panic high temperature.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to CCM. See Temperature Monitor (TEMPMON)</td>
</tr>
<tr>
<td>26–18</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>17</td>
<td>This enables a feature that will clkgate (reset) all PFD_528 clocks anytime the PLL_528 is unlocked or powered off.</td>
</tr>
<tr>
<td>PFD_528 автомата_EN</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>This enables a feature that will clkgate (reset) all PFD_480 clocks anytime the USB1_PLL_480 is unlocked or powered off.</td>
</tr>
<tr>
<td>PFD_480 автомата_EN</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>This enables the LVDS input buffer for anaclk1/1b. Do not enable input and output buffers simultaneously.</td>
</tr>
<tr>
<td>LVDSCLK1_ IBEN</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>10</td>
<td>This enables the LVDS output buffer for anaclk1/1b. Do not enable input and output buffers simultaneously.</td>
</tr>
<tr>
<td>LVDSCLK1_ OBEN</td>
<td></td>
</tr>
<tr>
<td>9–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>LVDS1_CLK_ SEL</td>
<td>This field selects the clk to be routed to anaclk1/1b.</td>
</tr>
<tr>
<td>00000</td>
<td>ARM_PLL — Arm PLL</td>
</tr>
<tr>
<td>00001</td>
<td>SYS_PLL — System PLL</td>
</tr>
<tr>
<td>00010</td>
<td>PFD4 — ref_pfd4_clk == pll2_pll0_clk</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00011</td>
<td><strong>PFD5</strong> — ref_pfd5_clk == pll2_pfd1_clk</td>
</tr>
<tr>
<td>00100</td>
<td><strong>PFD6</strong> — ref_pfd6_clk == pll2_pfd2_clk</td>
</tr>
<tr>
<td>00101</td>
<td><strong>PFD7</strong> — ref_pfd7_clk == pll2_pfd3_clk</td>
</tr>
<tr>
<td>00110</td>
<td><strong>AUDIO_PLL</strong> — Audio PLL</td>
</tr>
<tr>
<td>00111</td>
<td><strong>VIDEO_PLL</strong> — Video PLL</td>
</tr>
<tr>
<td>01001</td>
<td><strong>ETHERNET_REF</strong> — ethernet ref clock (ENET_PLL)</td>
</tr>
<tr>
<td>01100</td>
<td><strong>USB1_PLL</strong> — USB1 PLL clock</td>
</tr>
<tr>
<td>01101</td>
<td><strong>USB2_PLL</strong> — USB2 PLL clock</td>
</tr>
<tr>
<td>01110</td>
<td><strong>PFD0</strong> — ref_pfd0_clk == pll3_pfd0_clk</td>
</tr>
<tr>
<td>01111</td>
<td><strong>PFD1</strong> — ref_pfd1_clk == pll3_pfd1_clk</td>
</tr>
<tr>
<td>10000</td>
<td><strong>PFD2</strong> — ref_pfd2_clk == pll3_pfd2_clk</td>
</tr>
<tr>
<td>10001</td>
<td><strong>PFD3</strong> — ref_pfd3_clk == pll3_pfd3_clk</td>
</tr>
<tr>
<td>10010</td>
<td><strong>XTAL</strong> — xtal (24M)</td>
</tr>
<tr>
<td>10101</td>
<td><strong>ref_pfd7_clk</strong> == pll2_pfd3_clk</td>
</tr>
</tbody>
</table>
14.8.19 Miscellaneous Register 2 (CCM_ANALOG_MISC2n)

This register defines the control for miscellaneous analog blocks.

**NOTE**

This register is shared with PMU.

Address: 400D_8000h base + 170h offset + (4d × i), where i=0d to 3d
### CCM_ANALOG_MISC2n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 VIDEO_DIV</td>
<td>Post-divider for video. The output clock of the video PLL should be gated prior to changing this divider to prevent glitches. This divider is feed by PLL_VIDEO[POST_DIV_SELECT] to achieve division ratios of 1/1, 1/2, 1/4.</td>
</tr>
<tr>
<td></td>
<td>00 divide by 1 (Default)</td>
</tr>
<tr>
<td></td>
<td>01 divide by 2</td>
</tr>
<tr>
<td></td>
<td>10 divide by 1</td>
</tr>
<tr>
<td></td>
<td>11 divide by 4</td>
</tr>
<tr>
<td>29–28 REG2_STEP_TIME</td>
<td>Number of clock periods (24MHz clock).</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to CCM. See Power Management Unit (PMU)</td>
</tr>
<tr>
<td></td>
<td>00 <strong>64_CLOCKS</strong> — 64</td>
</tr>
<tr>
<td></td>
<td>01 <strong>128_CLOCKS</strong> — 128</td>
</tr>
<tr>
<td></td>
<td>10 <strong>256_CLOCKS</strong> — 256</td>
</tr>
<tr>
<td></td>
<td>11 <strong>512_CLOCKS</strong> — 512</td>
</tr>
<tr>
<td>27–26 REG1_STEP_TIME</td>
<td>Number of clock periods (24MHz clock).</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### CCM_ANALOG_MISC2n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to CCM. See Power Management Unit (PMU)</td>
</tr>
<tr>
<td><strong>64_CLOCKS</strong></td>
<td>64</td>
</tr>
<tr>
<td><strong>128_CLOCKS</strong></td>
<td>128</td>
</tr>
<tr>
<td><strong>256_CLOCKS</strong></td>
<td>256</td>
</tr>
<tr>
<td><strong>512_CLOCKS</strong></td>
<td>512</td>
</tr>
</tbody>
</table>

#### 25–24

**REG0_STEP_TIME**

Number of clock periods (24MHz clock).

**NOTE:** Not related to CCM. See Power Management Unit (PMU)

<table>
<thead>
<tr>
<th></th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>64_CLOCKS — 64</td>
</tr>
<tr>
<td>01</td>
<td>128_CLOCKS — 128</td>
</tr>
<tr>
<td>10</td>
<td>256_CLOCKS — 256</td>
</tr>
<tr>
<td>11</td>
<td>512_CLOCKS — 512</td>
</tr>
</tbody>
</table>

#### 23

**AUDIO_DIV_MS(MSB)**

MSB of Post-divider for Audio PLL. The output clock of the video PLL should be gated prior to changing this divider to prevent glitches. This divider is feed by PLL_AUDIOn[POST_DIV_SELECT] to achieve division ratios of /1, /2, /4.

**NOTE:** MSB bit value pertains to the first bit, please program the LSB bit (bit 15) as well to change divider value for more information.

<table>
<thead>
<tr>
<th></th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>divide by 1 (Default)</td>
</tr>
<tr>
<td>01</td>
<td>divide by 2</td>
</tr>
<tr>
<td>10</td>
<td>divide by 1</td>
</tr>
<tr>
<td>11</td>
<td>divide by 4</td>
</tr>
</tbody>
</table>

#### 22

**REG2_OK**

Signals that the voltage is above the brownout level for the SOC supply. 1 = regulator output > brownout_target

**NOTE:** Not related to CCM. See Power Management Unit (PMU)

#### 21

**REG2_ENABLE_BO**

Enables the brownout detection.

**NOTE:** Not related to CCM. See Power Management Unit (PMU)

#### 20

This field is reserved.

#### 19

**REG2_BO_STATUS**

Reg2 brownout status bit.

**NOTE:** Not related to CCM. See Power Management Unit (PMU)

#### 18–16

**REG2_BO_OFFSET**

This field defines the brown out voltage offset for the xPU power domain. IRQ_DIG_BO is also asserted. Single-bit increments reflect 25mV brownout voltage steps. The reset brown-offset is 175mV below the programmed target code. Brownout target = OUTPUT_TRG - BO_OFFSET. Some steps may be irrelevant because of input supply limitations or load operation.

**NOTE:** Not related to CCM. See Power Management Unit (PMU)

<table>
<thead>
<tr>
<th></th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>100</td>
<td>Brownout offset = 0.100V</td>
</tr>
<tr>
<td>111</td>
<td>Brownout offset = 0.175V</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## CCM_ANALOG_MISC2n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15 AUDIO_DIV_LSB | LSB of Post-divider for Audio PLL. The output clock of the video PLL should be gated prior to changing this divider to prevent glitches. This divider is feed by PLL_AUDIOn[POST_DIV_SELECT] to achieve division ratios of /1, /2, /4.  
**NOTE:** LSB bit value pertains to the last bit, please program the MSB bit (bit 23) as well, to change divider value for more information.  
00 divide by 1 (Default)  
01 divide by 2  
10 divide by 1  
11 divide by 4 |
| 14 REG1_OK   | GPU/VPU supply  
**NOTE:** Not related to CCM. See Power Management Unit (PMU) |
| 13 REG1_ENABLE_BO | Enables the brownout detection.  
**NOTE:** Not related to CCM. See Power Management Unit (PMU) |
| 12 -         | This field is reserved. |
| 11 REG1_BO_STATUS | Reg1 brownout status bit.  
**NOTE:** Not related to CCM. See Power Management Unit (PMU) |
| 10–8 REG1_BO_OFFSET | This field defines the brown out voltage offset for the xPU power domain. IRQ_DIG_BO is also asserted. Single-bit increments reflect 25mV brownout voltage steps. The reset brown-offset is 175mV below the programmed target code. Brownout target = OUTPUT_TRG - BO_OFFSET. Some steps may be irrelevant because of input supply limitations or load operation.  
**NOTE:** Not related to CCM. See Power Management Unit (PMU)  
100 Brownout offset = 0.100V  
111 Brownout offset = 0.175V |
| 7 PLL3_DISABLE | When USB is in low power suspend mode this Control bit is used to indicate if other system peripherals require the USB PLL3 clock when the SoC is not in low power mode. A user needs to set this bit if they want to optionally disable PLL3 while the SoC is not in any low power mode to save power. When the system does go into low power mode this bit setting would not have any affect.  
**NOTE:** When USB is in low power suspend mode users would need to ensure PLL3 is not being used before setting this bit in RUN mode. Please refer to the correct PLL disabling procedure in Disabling / Enabling PLLs  
0 PLL3 is being used by peripherals and is enabled when SoC is not in any low power mode  
1 PLL3 can be disabled when the SoC is not in any low power mode |
| 6 REG0_OK    | Arm supply  
**NOTE:** Not related to CCM. See Power Management Unit (PMU) |

Table continues on the next page...
### CCM_ANALOG_MISC2n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5 REG0_ENABLE_ BO</td>
<td>Enables the brownout detection.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to CCM. See <a href="https://example.com">Power Management Unit (PMU)</a></td>
</tr>
<tr>
<td>4 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>3 REG0_BO_ STATUS</td>
<td>Reg0 brownout status bit.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to CCM. See <a href="https://example.com">Power Management Unit (PMU)</a></td>
</tr>
<tr>
<td>1</td>
<td>Brownout, supply is below target minus brownout offset.</td>
</tr>
<tr>
<td>REG0_BO_OFFSET</td>
<td>This field defines the brown out voltage offset for the CORE power domain.</td>
</tr>
<tr>
<td></td>
<td>IRQ_DIG_BO is also asserted. Single-bit increments reflect 25mV brownout voltage steps. Some steps may be irrelevant because of input supply limitations or load operation.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to CCM. See <a href="https://example.com">Power Management Unit (PMU)</a></td>
</tr>
<tr>
<td>100</td>
<td>Brownout offset = 0.100V</td>
</tr>
<tr>
<td>111</td>
<td>Brownout offset = 0.175V</td>
</tr>
</tbody>
</table>
Chapter 15
Crystal Oscillator (XTALOSC)

15.1 Chip-specific XTALOSC information

Table 15-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

15.2 Overview

This block comprises both the 24 MHz and 32 kHz implementation of a biased amplifier that when combined with a suitable external quartz crystal and external load capacitors, implements an oscillator.

The block includes means to:

- Accept an external clock source.
- Detect if the crystal frequency is close to 24 MHz or 32 kHz.
- Reduce the operating current via software after the oscillator has started (24 MHz specific feature)
- Supply another ~32 kHz clock source based off an independent internal oscillator if there is no oscillation sensed on the RTC_XTAL bumps (contacts) (32 kHz specific feature)
feature). The internal oscillator will provide clocks to the same on-chip modules as the external 32 kHz oscillator.

- Automatically switch to the external oscillation source when sensed on the RTC_XTAL bumps (contacts) (32 kHz specific feature).

15.3 External Signals

The table found here describes the external signals of XTALOSC:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>REF_CLK_32K</td>
<td>32 kHz reference clock</td>
<td>GPIO_AD_B0_00</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td>REF_CLK_24M</td>
<td>24 MHz reference clock</td>
<td>GPIO_AD_B0_01</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_03</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_13</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td>XTALI</td>
<td>Crystal oscillator input</td>
<td>XTALI</td>
<td>No Muxing</td>
<td>O</td>
</tr>
<tr>
<td>XTALO</td>
<td>Crystal oscillator output</td>
<td>XTALO</td>
<td>No Muxing</td>
<td>O</td>
</tr>
</tbody>
</table>

15.4 Crystal Oscillator 24 MHz

15.4.1 Oscillator Configuration (24 MHz)

The basic block diagram of the 24 MHz module configured as a crystal oscillator is shown below.
This integrated biased amplifier can be used to create different frequency oscillators with different external component selection. However, care should be taken as many of the serial IO modules depend on the fixed frequency of 24 MHz. Please consult the sections of the document pertaining to the USB, ENET interfaces, for example. After a healthy oscillation is established, then the bias current of the oscillator can generally be reduced to save power. This is accomplished through the XTALOSC24M_MISC0[OSC_I] bits, defined in the MISC0 register later in this chapter. Restore the XTALOSC24M_MISC0[OSC_I] bits before going into a power mode where the XTALOSC24 is powered down or oscillator startup may become an issue. The power down of the XTALOSC24 module is controlled by the CCM. See this section of the manual for more details.

### 15.4.2 Bypass Configuration (24 MHz)

If it is desired to drive the chip with an external clock source, then the 24 MHz oscillator could be driven in one of three configurations using a nominal 1.1V source.

1. A single ended external clock source can be used to overdrive the output of the amplifier (XTALO). Since the oscillation sensing amplifier is differential, the
XTALI pin should be externally floating and capacitively loaded. The combination of the internal biasing resistor and the external capacitor will filter the signal applied to the XTALO pin and develop a rough reference for the sensing amplifier to compare to.

2. A single ended external clock source can be used to drive XTALI. In this configuration, XTALO should be left externally floating.

3. A differential external clock source can be used to drive both XTALI and XTALO.

Generally, configuration 2 is anticipated to be the most used configuration, but all three configurations may be utilized.

### 15.4.3 RC Oscillator (24 MHz)

A lower-power RC oscillator module is available on-chip as a possible alternative to the 24 MHz crystal oscillator after a successful power-up sequence.

The 24 MHz RC oscillator is a self-tuning circuit that will output the programmed frequency value by using the RTC clock as it’s reference. This oscillator is intended for normal operation and not fast boot.

While the power consumption of this RC oscillator is much lower than the 24 MHz crystal oscillator, one limitation of this RC oscillator module is that its clock frequency is not as accurate. Therefore, care should be observed when using this oscillator as the reference for the on-chip PLLs as their output clock frequency will be lower/higher than when using the 24 MHz crystal oscillator clock.

### 15.4.4 Crystal Frequency Detection(24 MHz)

A submodule exists that gives a fairly crude (relative to the accuracy of a crystal) estimation of whether the clock frequency is correct.

This function may be enabled by setting the XTALOSC24M_MISC0[OSC_XTALOK_EN] bit. It is disabled at system reset. When the oscillator is stable and the correct frequency is detected, the XTALOSC24M_MISC0[OSC_XTALOK] bit will be set. Note that the correct frequency will be observed before the oscillator fully blooms (the oscillation waveform build-up is completed).

### 15.5 Crystal Oscillator 32 kHz
15.5.1 Oscillator Configuration (32 kHz)

The basic block diagram of the 32 kHz module configured as a crystal oscillator is shown below.

![Oscillator Configuration (32 kHz) Diagram]

This integrated biased amplifier can be used to create different frequency oscillators with different external component selection. Generally, RTC oscillators are either implemented with 32 kHz or 32.768 kHz crystals. Please consult the Security Reference Manual for appropriate frequency selection and configuration. Care must be taken to limit external leakage as this may debias the amplifier and degrade the gain.

The internal oscillator is automatically multiplexed in the clocking system when the system detects a loss of clock. The internal oscillator will provide clocks to the same on-chip modules as the external 32 kHz oscillator. The internal oscillator is not precise relative to a crystal. While it will provide a clock to the system, it generally will not be precise enough for long term time keeping. The internal oscillator is anticipated to be useful for quicker startup times and tampering prevention, but should not be used as the exclusive source for the 32 kHz clocks. An external 32 kHz clock source must be used for production systems.
15.5.2 Bypass Configuration (32 kHz)

If it is desired to drive the chip with an external clock source, then the 32 kHz oscillator could be driven in one of three configurations using a nominal 1.1V source.

1. A single ended external clock source can be used to overdrive the output of the amplifier (RTC_XTALO). Since the oscillation sensing amplifier is differential, the RTC_XTALI pin should be externally floating and capacitively loaded. The combination of the internal biasing resistor and the external capacitor will filter the signal applied to the RTC_XTALO pin and develop a rough reference for the sensing amplifier to compare to.

2. A single ended external clock source can be used to drive RTC_XTALI. In this configuration, RTC_XTALO should be left externally floating.

3. A differential external clock source can be used to drive both RTC_XTALI and RTC_XTALO.

Generally, configuration 2 is anticipated to be the most used configuration, but all three configurations may be utilized.

15.6 XTAŁOSC 24MHz Memory Map/Register Definition

NOTE
The register content is mixed with analog functions not related to the oscillator function. These bits are noted.

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_8150</td>
<td>Miscellaneous Register 0 (XTALOSC24M_MISC0)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>15.6.1/1144</td>
</tr>
<tr>
<td>400D_8154</td>
<td>Miscellaneous Register 0 (XTALOSC24M_MISC0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>15.6.1/1144</td>
</tr>
<tr>
<td>400D_8158</td>
<td>Miscellaneous Register 0 (XTALOSC24M_MISC0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>15.6.1/1144</td>
</tr>
<tr>
<td>400D_815C</td>
<td>Miscellaneous Register 0 (XTALOSC24M_MISC0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>15.6.1/1144</td>
</tr>
<tr>
<td>400D_8270</td>
<td>XTAL OSC (LP) Control Register (XTALOSC24M_LOW_PWR_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>See section</td>
<td>15.6.2/1148</td>
</tr>
<tr>
<td>400D_8274</td>
<td>XTAL OSC (LP) Control Register (XTALOSC24M_LOW_PWR_CTRL_SET)</td>
<td>32</td>
<td>R/W</td>
<td>See section</td>
<td>15.6.2/1148</td>
</tr>
<tr>
<td>400D_8278</td>
<td>XTAL OSC (LP) Control Register (XTALOSC24M_LOW_PWR_CTRL_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>See section</td>
<td>15.6.2/1148</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## XTALOSC24M Memory Map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_827C</td>
<td>XTAL OSC (LP) Control Register (XTALOSC24M_LOW_PWR_CTRL_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>See section 15.6.2/1148</td>
<td></td>
</tr>
<tr>
<td>400D_82A0</td>
<td>XTAL OSC Configuration 0 Register (XTALOSC24M_OSC_CONFIG0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1020h</td>
<td>15.6.3/1151</td>
</tr>
<tr>
<td>400D_82A4</td>
<td>XTAL OSC Configuration 0 Register (XTALOSC24M_OSC_CONFIG0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1020h</td>
<td>15.6.3/1151</td>
</tr>
<tr>
<td>400D_82A8</td>
<td>XTAL OSC Configuration 0 Register (XTALOSC24M_OSC_CONFIG0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1020h</td>
<td>15.6.3/1151</td>
</tr>
<tr>
<td>400D_82AC</td>
<td>XTAL OSC Configuration 0 Register (XTALOSC24M_OSC_CONFIG0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1020h</td>
<td>15.6.3/1151</td>
</tr>
<tr>
<td>400D_82B0</td>
<td>XTAL OSC Configuration 1 Register (XTALOSC24M_OSC_CONFIG1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_02EEh</td>
<td>15.6.4/1152</td>
</tr>
<tr>
<td>400D_82B4</td>
<td>XTAL OSC Configuration 1 Register (XTALOSC24M_OSC_CONFIG1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_02EEh</td>
<td>15.6.4/1152</td>
</tr>
<tr>
<td>400D_82B8</td>
<td>XTAL OSC Configuration 1 Register (XTALOSC24M_OSC_CONFIG1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_02EEh</td>
<td>15.6.4/1152</td>
</tr>
<tr>
<td>400D_82BC</td>
<td>XTAL OSC Configuration 1 Register (XTALOSC24M_OSC_CONFIG1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_02EEh</td>
<td>15.6.4/1152</td>
</tr>
<tr>
<td>400D_82C0</td>
<td>XTAL OSC Configuration 2 Register (XTALOSC24M_OSC_CONFIG2)</td>
<td>32</td>
<td>R/W</td>
<td>0001_02E2h</td>
<td>15.6.5/1153</td>
</tr>
<tr>
<td>400D_82C4</td>
<td>XTAL OSC Configuration 2 Register (XTALOSC24M_OSC_CONFIG2_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0001_02E2h</td>
<td>15.6.5/1153</td>
</tr>
<tr>
<td>400D_82C8</td>
<td>XTAL OSC Configuration 2 Register (XTALOSC24M_OSC_CONFIG2_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0001_02E2h</td>
<td>15.6.5/1153</td>
</tr>
<tr>
<td>400D_82CC</td>
<td>XTAL OSC Configuration 2 Register (XTALOSC24M_OSC_CONFIG2_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0001_02E2h</td>
<td>15.6.5/1153</td>
</tr>
</tbody>
</table>
15.6.1 Miscellaneous Register 0 (XTALOSC24M_MISC0n)

This register defines the control and status bits for miscellaneous analog blocks.

Address: 400D_8000h base + 150h offset + (4d × i), where i=0d to 3d

![Diagram of Miscellaneous Register 0 (XTALOSC24M_MISC0n)]
### XTALOSC24M_MISC0n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 VID_PLL_PREDIV</td>
<td>Predivider for the source clock of the PLL's.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to oscillator.</td>
</tr>
<tr>
<td>0</td>
<td>Divide by 1</td>
</tr>
<tr>
<td>1</td>
<td>Divide by 2</td>
</tr>
<tr>
<td>30 XTAL_24M_PWD</td>
<td>This field powers down the 24M crystal oscillator if set true.</td>
</tr>
<tr>
<td>29 RTC_XTAL_SOURCE</td>
<td>This field indicates which chip source is being used for the rtc clock.</td>
</tr>
<tr>
<td>0</td>
<td>Internal ring oscillator</td>
</tr>
<tr>
<td>1</td>
<td>RTC_XTAL</td>
</tr>
<tr>
<td>28–26 CLKGATE_DELAY</td>
<td>This field specifies the delay between powering up the XTAL 24MHz clock and releasing the clock to the digital logic inside the analog block.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Do not change the field during a low power event. This is not a field that the user would normally need to modify.</td>
</tr>
<tr>
<td>000</td>
<td>0.5ms</td>
</tr>
<tr>
<td>001</td>
<td>1.0ms</td>
</tr>
<tr>
<td>010</td>
<td>2.0ms</td>
</tr>
<tr>
<td>011</td>
<td>3.0ms</td>
</tr>
<tr>
<td>100</td>
<td>4.0ms</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### XTALOSC24M_MISC0n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>101</td>
<td>5.0ms</td>
</tr>
<tr>
<td>110</td>
<td>6.0ms</td>
</tr>
<tr>
<td>111</td>
<td>7.0ms</td>
</tr>
</tbody>
</table>

#### 25 CLKGATE_CTRL

This bit allows disabling the clock gate (always ungated) for the xtal 24MHz clock that clocks the digital logic in the analog block.

**NOTE:** Do not change the field during a low power event. This is not a field that the user would normally need to modify.

- **0 ALLOW_AUTO_GATE** — Allow the logic to automatically gate the clock when the XTAL is powered down.
- **1 NO_AUTO_GATE** — Prevent the logic from ever gating off the clock.

#### 24–17

This field is reserved. Always set to zero.

#### 16 OSC_XTALOK_EN

This bit enables the detector that signals when the 24MHz crystal oscillator is stable.

#### 15 OSC_XTALOK

Status bit that signals that the output of the 24-MHz crystal oscillator is stable. Generated from a timer and active detection of the actual frequency.

#### 14–13 OSC_I

This field determines the bias current in the 24MHz oscillator. The aim is to start up with the highest bias current, which can be decreased after startup if it is determined to be acceptable.

- **00 NOMINAL** — Nominal
- **01 MINUS_12_5_PERCENT** — Decrease current by 12.5%
- **10 MINUS_25_PERCENT** — Decrease current by 25.0%
- **11 MINUS_37_5_PERCENT** — Decrease current by 37.5%

#### 12 DISCON_HIGH_SNV S

This bit controls a switch from VDD_HIGH_IN to VDD_SNVS_IN.

- **0** Turn on the switch
- **1** Turn off the switch

#### 11–10 STOP_MODE_CONFIG

Configure the analog behavior in stop mode.

**NOTE:** Not related to oscillator.

- **00** All analog except rtc powered down on stop mode assertion. XtalOsc=on, RCOsc=off;
- **01** Certain analog functions such as certain regulators left up. XtalOsc=on, RCOsc=off;
- **10** XtalOsc=off, RCOsc=on, Old BG=on, New BG=off.
- **11** XtalOsc=off, RCOsc=on, Old BG=off, New BG=on.

#### 9–8

This field is reserved. Reserved

#### 7 REFTOP_VBGUP

Status bit that signals the analog bandgap voltage is up and stable. 1 - Stable.

**NOTE:** Not related to oscillator.

#### 6–4 REFTOP_VBGADJ

**NOTE:** Not related to oscillator.

- **000** Nominal VBG

*Table continues on the next page...*
### XTALOSC24M_MISC0n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>001</td>
<td>VBG+0.78%</td>
</tr>
<tr>
<td>010</td>
<td>VBG+1.56%</td>
</tr>
<tr>
<td>011</td>
<td>VBG+2.34%</td>
</tr>
<tr>
<td>100</td>
<td>VBG-0.78%</td>
</tr>
<tr>
<td>101</td>
<td>VBG-1.56%</td>
</tr>
<tr>
<td>110</td>
<td>VBG-2.34%</td>
</tr>
<tr>
<td>111</td>
<td>VBG-3.12%</td>
</tr>
</tbody>
</table>

3 REFTOP_SELFBIASOFF

Control bit to disable the self-bias circuit in the analog bandgap. The self-bias circuit is used by the bandgap during startup. This bit should be set after the bandgap has stabilized and is necessary for best noise performance of analog blocks using the outputs of the bandgap.

**NOTE:** Value should be returned to zero before removing vddhigh_in or asserting bit 0 of this register (REFTOP_PWD) to assure proper restart of the circuit.

**NOTE:** Not related to oscillator.

0 Uses coarse bias currents for startup
1 Uses bandgap-based bias currents for best performance.

2–1 This field is reserved.

0 REFTOP_PWD

Control bit to power-down the analog bandgap reference circuitry.

**NOTE:** A note of caution, the bandgap is necessary for correct operation of most of the LDO, pll, and other analog functions on the die.

**NOTE:** Not related to oscillator.
## 15.6.2 XTAL OSC (LP) Control Register

*(XTALOSC24M_LOW_PWR_CTRL<sub>n</sub>)*

This register defines xtal osc and low power configuration.

Address: 400D_8000h base + 270h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

### Register Definition

- **GPU_PWRGATE**: GPU Power Gate
- **MIX_PWRGATE**: MIX Power Gate
- **XTALOSC_PWR_UP_STAT**: XTALOSC Power-Up Status

---

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**

NXP Semiconductors
### XTALOSC24M_LOW_PWR_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–19 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>18 GPU_PWRGATE</td>
<td>GPU power gate control. Used as software mask. Set to zero to force ungated.</td>
</tr>
<tr>
<td>17 MIX_PWRGATE</td>
<td>Display power gate control. Used as software mask. Set to zero to force ungated.</td>
</tr>
<tr>
<td>16 XTALOSC_PWRUP_STAT</td>
<td>Status of the 24MHz xtal oscillator.</td>
</tr>
<tr>
<td></td>
<td>0 Not stable</td>
</tr>
<tr>
<td></td>
<td>1 Stable and ready to use</td>
</tr>
<tr>
<td>15–14 XTALOSC_PWRUP_DELAY</td>
<td>Specifies the time delay between when the 24MHz xtal is powered up until it is stable and ready to use.</td>
</tr>
<tr>
<td>13 RCOSC_CG_OVERRIDE</td>
<td>For debug purposes only. This bit effects clock gating of certain digital logic clocked by the 24MHz clk.</td>
</tr>
<tr>
<td>12 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>11 DISPLAY_PWRGATE</td>
<td>Display logic power gate control. Used as software override.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to oscillator.</td>
</tr>
<tr>
<td>10 CPU_PWRGATE</td>
<td>CPU power gate control. Used as software override.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Attention:</strong></td>
<td>Test purpose only</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to oscillator.</td>
</tr>
<tr>
<td>L2_PWRGATE</td>
<td>L2 power gate control. Used as software override.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to oscillator.</td>
</tr>
<tr>
<td>L1_PWRGATE</td>
<td>L1 power gate control. Used as software override.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to oscillator.</td>
</tr>
<tr>
<td>REFTOP_IBIAS_OFF</td>
<td>Low power reftop ibias disable.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to oscillator.</td>
</tr>
<tr>
<td>LPBG_TEST</td>
<td>Low power bandgap test bit.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to oscillator.</td>
</tr>
<tr>
<td>LPBG_SEL</td>
<td>Bandgap select.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Not related to oscillator.</td>
</tr>
<tr>
<td>OSC_SEL</td>
<td>Select the source for the 24MHz clock.</td>
</tr>
<tr>
<td>0</td>
<td>XTAL OSC</td>
</tr>
<tr>
<td>1</td>
<td>RC OSC</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>RC_OSC_EN</td>
<td>RC Osc. enable control.</td>
</tr>
<tr>
<td>0</td>
<td>Use XTAL OSC to source the 24MHz clock</td>
</tr>
<tr>
<td>1</td>
<td>Use RC OSC</td>
</tr>
</tbody>
</table>
15.6.3 XTAL OSC Configuration 0 Register (XTALOSC24M_OSC_CONFIG0n)

This register is used to configure the 24MHz RC oscillator.

Address: 400D_8000h base + 2A0h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>RC_OSC_PROG_CUR</td>
</tr>
<tr>
<td>23–20</td>
<td>-</td>
</tr>
<tr>
<td>19–16</td>
<td>HYST_MINUS</td>
</tr>
<tr>
<td>15–12</td>
<td>HYST_PLUS</td>
</tr>
<tr>
<td>11–4</td>
<td>RC_OSC_PROG</td>
</tr>
<tr>
<td>3</td>
<td>INVERT</td>
</tr>
</tbody>
</table>

Table continues on the next page...
XTALOSC24M_OSC_CONFIG0n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2 BYPASS</td>
<td>Bypasses any calculated RC tuning value and uses the programmed register value.</td>
</tr>
<tr>
<td>1 ENABLE</td>
<td>Enables the tuning logic to calculate new RC tuning values. Disabling essentially freezes the state of the calculation.</td>
</tr>
<tr>
<td>0 START</td>
<td>Start/stop bit for the RC tuning calculation logic. If stopped the tuning logic is reset.</td>
</tr>
</tbody>
</table>

15.6.4 XTAL OSC Configuration 1 Register (XTALOSC24M_OSC_CONFIG1n)

This register is used to configure the 24MHz RC oscillator.

Address: 400D_8000h base + 2B0h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–20 COUNT_RC_CUR</td>
<td>The current tuning value in use.</td>
</tr>
<tr>
<td>19–12 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>COUNT_RC_TRG</td>
<td>The target count used to tune the RC OSC frequency. Essentially the number of desired RC OSC clock cycles is within one 32kHz clock cycle.</td>
</tr>
</tbody>
</table>
15.6.5 XTAL OSC Configuration 2 Register (XTALOSC24M_OSC_CONFIG2n)

This register is used to configure the 1MHz clock generated from the 24MHz RC oscillator.

Address: 400D_8000h base + 2C0h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>CLK_1M_ERR_FL Flag indicates that the count_1m count wasn't reached within 1 32kHz period. This is intended as feedback to software that the HW_ANADIG_OSC_CONFIG2_COUNT_1M_TRG value is too high for the RC Osc frequency.</td>
</tr>
<tr>
<td>30–18</td>
<td>- Reserved.</td>
</tr>
<tr>
<td>17</td>
<td>MUX_1M Mux the corrected or uncorrected 1MHz clock to the output. 0 - free 1MHz clock; 1 - locked 1MHz clock.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
XTALOSC 24MHz Memory Map/Register Definition

**XTALOSC24M_OSC_CONFIG2** field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16 ENABLE_1M</td>
<td>Enable the 1MHz clock output. 0 - disabled; 1 - enabled.</td>
</tr>
<tr>
<td>15–12</td>
<td>Reserved</td>
</tr>
<tr>
<td>COUNT_1M_</td>
<td>The target count used to tune the 1MHz clock frequency. Essentially the</td>
</tr>
<tr>
<td>TRG</td>
<td>number of desired RC OSC clock cycles used to generate the 1MHz clock is</td>
</tr>
<tr>
<td></td>
<td>within one 32kHz clock cycle.</td>
</tr>
</tbody>
</table>
Chapter 16
Power Management Unit (PMU)

16.1 Chip-specific PMU information

Table 16-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

NOTE

The following bitfields are not applicable on this device, and those corresponding bits are Reserved:

- in PMU_REG_COREn register:
  - RAMP_RATE
  - REG2_TARG
  - REG1_TARG
  - REG0_TARG
- in PMU_MISC1n register: IRQ_DIG_BO.
- in PMU_MISC2n register:
  - REG2_STEP_TIME
  - REG1_STEP_TIME
  - REG0_STEP_TIME
  - REG2_OK
  - REG2_ENABLE_BO
  - REG1_ENABLE_BO
16.2 Overview

The power management unit (PMU) is designed to simplify the external power interface. The power system can be split into the input power sources and their characteristics, the integrated power transforming and controlling elements, and the final load interconnection and requirements.

A typical power system uses the PMU is depicted in the following diagram.
Using four LDO regulators, the number of external supplies is greatly reduced. Not counting the backup coin and USB inputs, the number of external supplies is reduced to two. Missing from this external supply total is the number of necessary external supplies to power the desired memory interface; that number varies depending on the type of external memory selected. Other supplies may also be necessary to supply the voltage to the different I/O power segments if their I/O voltages have to be different from what is provided above.

### 16.3 Analog LDO Regulators

There are two analog regulators described here.
**16.3.1 LDO 1P1**

The LDO_1P1 module on the chip implements a programmable linear-regulator function from a higher analog supply voltage (2.8 V–3.3 V) to produce a nominal 1.1 V output voltage.

The output of the regulator can be programmed in 25 mV steps from 0.8 V to 1.4 V. The regulator has been designed to be stable with a minimum external low-ESR decoupling capacitance, though the actual capacitance required should be determined by the application. A programmable brownout detector is included in the regulator which can be used by the system to determine when the load capability of the regulator is being exceeded, so the necessary steps can be taken.

Current limiting can be enabled by setting the PMU_REG_1P1[ENABLE_ILIMIT] bit to allow for in-rush current requirements during startup if needed. Active pulldown can also be enabled by setting the PMU_REG_1P1[ENABLE_PULLDOWN] bit for systems requiring this feature.

**16.3.2 LDO 2P5**

The LDO_2P5 module on the chip implements a programmable linear-regulator function from a higher analog supply voltage (2.8V-3.3V) to produce a nominal 2.5V output voltage.

The output of the regulator can be programmed in 25mV steps from 2.0V to 2.75V. The regulator has been designed to be stable with a minimum external low-ESR decoupling capacitance, though the actual capacitance required should be determined by the application. A programmable brown-out detector is included in the regulator which can be used by the system to determine when the load capability of the regulator is being exceeded to take the necessary steps.

Current-limiting can be enabled by setting the REG_PMU_2P5[ENABLE_ILIMIT] bit to allow for in-rush current requirements during start-up if needed. Active-pulldown can also be enabled by setting the REG_PMU_2P5[ENABLE_PULLDOWN] bit for systems requiring this feature.

**16.3.3 Low Power Operation**

The 1.1 V and 2.5 V LDO includes an alternate, self-biased, low-precision, weak regulator which can be enabled for applications needing to keep the 1.1 V and 2.5 V output voltage alive during low-power modes where the main regulator and its associated global bandgap reference module are disabled.
The output of this weak regulator is not programmable and is a function of its input power supply as well as load current. The low-power mode is enabled by setting high the PMU_REG_1P1[ENABLE_WEAK_LINREG] and PMU_REG_2P5[ENABLE_WEAK_LINREG] bit of the regulator. It is recommended that the following sequence be followed to enable this mode:

1. Throttle down the 1.1 V / 2.5 V attached load to its low-power maintain state.
2. Disable the main 1.1 V / 2.5 V regulator driver by clearing the PMU_REG_1P1[ENABLE_LINREG] / PMU_REG_2P5[ENABLE_LINREG] bit.
3. Enable the weak 1.1 V / 2.5 V regulator by setting the PMU_REG_1P1[ENABLE_WEAK_LINREG] / PMU_REG_2P5[ENABLE_WEAK_LINREG] bit.

To go back to full-power operation, reverse the steps outlined above. Note that the external decoupling cap is supporting the power supply between steps 2 and 3. Therefore step 3 should happen appropriately in time relative to the discharge of the supporting capacitor.

### 16.4 USB LDO Regulator

The USB_LDO module on the chip implements a programmable linear-regulator function from the USB VBUS voltages (typically 5 V) to produce a nominal 3.0 V output voltage.

The output of the regulator can be programmed in 25 mV steps, from 2.625V to 3.4 V. The regulator has been designed to be stable with a minimum external low-ESR decoupling capacitor of 4.7 µF, though the actual capacitance required should be determined by the application. A programmable brownout detector is included in the regulator which can be used by the system to determine when the load capability of the regulator is being exceeded, so the necessary steps can be taken. This regulator has a built-in power mux which allows the user to choose to run the regulator from either VBUS supply when both are present. If only one of the VBUS voltages is present, then the regulator automatically selects this supply. Current limit is also included to help the system meet in-rush current targets.

Upon attachment of VBUS, this regulator starts up in a low-power, self-preservation mode to prevent over-voltage conditions on the chip. It is expected that the user transition to full regulation by enabling the regulator and disabling the in-rush current limits via its control registers. Upon VBUS removal, it is further expected that the regulator controls are returned to their reset state.
16.5 SNVS Regulator

The SNVS regulator takes the SNVS_IN supply and generates the SNVS_CAP supply, which powers the real time clock and SNVS blocks.

The SNVS_LDO is a non-programmable linear-regulator function, producing a nominal 1.1V output voltage.

16.6 PMU Memory Map/Register Definition

The register definitions that affect the behavior of the digital LDO regulators follow.

NOTE
Some of the registers are collections of bits that affect multiple components on the chip. Those that are not pertinent to this chapter have comments in the related register bitfields.

If a full description is desired, please consult the full register programming reference in the related block.

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_8110</td>
<td>Regulator 1P1 Register (PMU_REG_1P1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.1/1162</td>
</tr>
<tr>
<td>400D_8114</td>
<td>Regulator 1P1 Register (PMU_REG_1P1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.1/1162</td>
</tr>
<tr>
<td>400D_8118</td>
<td>Regulator 1P1 Register (PMU_REG_1P1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.1/1162</td>
</tr>
<tr>
<td>400D_811C</td>
<td>Regulator 1P1 Register (PMU_REG_1P1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.1/1162</td>
</tr>
<tr>
<td>400D_8120</td>
<td>Regulator 3P0 Register (PMU_REG_3P0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0F74h</td>
<td>16.6.2/1165</td>
</tr>
<tr>
<td>400D_8124</td>
<td>Regulator 3P0 Register (PMU_REG_3P0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0F74h</td>
<td>16.6.2/1165</td>
</tr>
<tr>
<td>400D_8128</td>
<td>Regulator 3P0 Register (PMU_REG_3P0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0F74h</td>
<td>16.6.2/1165</td>
</tr>
<tr>
<td>400D_812C</td>
<td>Regulator 3P0 Register (PMU_REG_3P0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0F74h</td>
<td>16.6.2/1165</td>
</tr>
<tr>
<td>400D_8130</td>
<td>Regulator 2P5 Register (PMU_REG_2P5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.3/1167</td>
</tr>
<tr>
<td>400D_8134</td>
<td>Regulator 2P5 Register (PMU_REG_2P5_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.3/1167</td>
</tr>
<tr>
<td>400D_8138</td>
<td>Regulator 2P5 Register (PMU_REG_2P5_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.3/1167</td>
</tr>
<tr>
<td>400D_813C</td>
<td>Regulator 2P5 Register (PMU_REG_2P5_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1073h</td>
<td>16.6.3/1167</td>
</tr>
<tr>
<td>400D_8140</td>
<td>Digital Regulator Core Register (PMU_REG_CORE)</td>
<td>32</td>
<td>R/W</td>
<td>0048_2012h</td>
<td>16.6.4/1169</td>
</tr>
<tr>
<td>400D_8144</td>
<td>Digital Regulator Core Register (PMU_REG_CORE_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0048_2012h</td>
<td>16.6.4/1169</td>
</tr>
<tr>
<td>400D_8148</td>
<td>Digital Regulator Core Register (PMU_REG_CORE_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0048_2012h</td>
<td>16.6.4/1169</td>
</tr>
<tr>
<td>400D_814C</td>
<td>Digital Regulator Core Register (PMU_REG_CORE_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0048_2012h</td>
<td>16.6.4/1169</td>
</tr>
<tr>
<td>400D_8150</td>
<td>Miscellaneous Register 0 (PMU_MISC0)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>16.6.5/1173</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_8154</td>
<td>Miscellaneous Register 0 (PMU_MISC0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>16.6.5/1173</td>
</tr>
<tr>
<td>400D_8158</td>
<td>Miscellaneous Register 0 (PMU_MISC0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>16.6.5/1173</td>
</tr>
<tr>
<td>400D_815C</td>
<td>Miscellaneous Register 0 (PMU_MISC0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>16.6.5/1173</td>
</tr>
<tr>
<td>400D_8160</td>
<td>Miscellaneous Register 1 (PMU_MISC1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>16.6.6/1177</td>
</tr>
<tr>
<td>400D_8164</td>
<td>Miscellaneous Register 1 (PMU_MISC1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>16.6.6/1177</td>
</tr>
<tr>
<td>400D_8168</td>
<td>Miscellaneous Register 1 (PMU_MISC1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>16.6.6/1177</td>
</tr>
<tr>
<td>400D_816C</td>
<td>Miscellaneous Register 1 (PMU_MISC1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>16.6.6/1177</td>
</tr>
<tr>
<td>400D_8170</td>
<td>Miscellaneous Control Register (PMU_MISC2)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>16.6.7/1179</td>
</tr>
<tr>
<td>400D_8174</td>
<td>Miscellaneous Control Register (PMU_MISC2_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>16.6.7/1179</td>
</tr>
<tr>
<td>400D_8178</td>
<td>Miscellaneous Control Register (PMU_MISC2_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>16.6.7/1179</td>
</tr>
<tr>
<td>400D_817C</td>
<td>Miscellaneous Control Register (PMU_MISC2_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0027_2727h</td>
<td>16.6.7/1179</td>
</tr>
</tbody>
</table>
# 16.6.1 Regulator 1P1 Register (PMU_REG_1P1n)

This register defines the control and status bits for the 1.1V regulator. This regulator is designed to power the digital portions of the analog cells.

Address: \(400D_{8000h} \text{ base} + 110h \text{ offset} + (4d \times i), \text{ where } i=0d \text{ to } 3d\)

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reserved

SELREF_WEAK_LINREG
ENABLE_WEAK_LINREG
OK_VDD1P1
BO_VDD1P1

Reset initial values:

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### PMU_REG_1P1\(n\) field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–20 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>19 SELREF_WEAK_LINREG</td>
<td>Selects the source for the reference voltage of the weak 1p1 regulator.</td>
</tr>
<tr>
<td>18 ENABLE_WEAK_LINREG</td>
<td>Enables the weak 1p1 regulator. This regulator can be used when the main 1p1 regulator is disabled, under low-power conditions.</td>
</tr>
<tr>
<td>17 OK_VDD1P1</td>
<td>Status bit that signals when the regulator output is ok. 1 = regulator output &gt; brownout target</td>
</tr>
<tr>
<td>16 BO_VDD1P1</td>
<td>Status bit that signals when a brownout is detected on the regulator output.</td>
</tr>
<tr>
<td>15–13 Reserved</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>
| 12–8 OUTPUT_TRG | Control bits to adjust the regulator output voltage. Each LSB is worth 25mV. Programming examples are detailed below. Other output target voltages may be interpolated from these examples. Choices must be in this range: 0x1b >= output_trg >= 0x04  
**NOTE:** There may be reduced chip functionality or reliability at the extremes of the programming range. |
| 7 Reserved     | This field is reserved.                                                     |

0x04 0.8V  
0x10 1.1V  
0x1b 1.375V

*Table continues on the next page...*
### PMU_REG_1P1n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6–4 BO_OFFSET</td>
<td>Control bits to adjust the regulator brownout offset voltage in 25mV steps. The reset brown-offset is 175mV below the programmed target code. Brownout target = OUTPUT_TRG - BO_OFFSET. Some steps may be irrelevant because of input supply limitations or load operation.</td>
</tr>
<tr>
<td>3 ENABLE_PULLDOWN</td>
<td>Control bit to enable the pull-down circuitry in the regulator</td>
</tr>
<tr>
<td>2 ENABLE_ILIMIT</td>
<td>Control bit to enable the current-limit circuitry in the regulator.</td>
</tr>
<tr>
<td>1 ENABLE_BO</td>
<td>Control bit to enable the brownout circuitry in the regulator.</td>
</tr>
<tr>
<td>0 ENABLE_LINREG</td>
<td>Control bit to enable the regulator output.</td>
</tr>
</tbody>
</table>
16.6.2 Regulator 3P0 Register (PMU_REG_3P0n)

This register defines the control and status bits for the 3.0V regulator powered by the host USB VBUS pin.

Address: 400D_8000h base + 120h offset + (4d × i), where i=0d to 3d

![Register Diagram]

**PMU_REG_3P0n field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–18</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### PMU Memory Map/Register Definition

#### PMU_REG_3P0n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17 OK_VDD3P0</td>
<td>Status bit that signals when the regulator output is ok. 1 = regulator output &gt; brownout target</td>
</tr>
<tr>
<td>16 BO_VDD3P0</td>
<td>Status bit that signals when a brownout is detected on the regulator output.</td>
</tr>
<tr>
<td>15–13 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>12–8 OUTPUT_TRG</td>
<td>Control bits to adjust the regulator output voltage. Each LSB is worth 25mV. Programming examples are detailed below. Other output target voltages may be interpolated from these examples. <strong>NOTE:</strong> There may be reduced chip functionality or reliability at the extremes of the programming range.</td>
</tr>
<tr>
<td>7 VBUS_SEL</td>
<td>Select input voltage source for LDO_3P0 from either USB_OTG1_VBUS or USB_OTG2_VBUS. If only one of the two VBUS voltages is present, it is automatically selected.</td>
</tr>
<tr>
<td>6–4 BO_OFFSET</td>
<td>Control bits to adjust the regulator brownout offset voltage in 25mV steps. The reset brown-offset is 175mV below the programmed target code. Brownout target = OUTPUT_TRG - BO_OFFSET. Some steps may not be relevant because of input supply limitations or load operation.</td>
</tr>
<tr>
<td>3 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>2 ENABLE_ILIMIT</td>
<td>Control bit to enable the current-limit circuitry in the regulator.</td>
</tr>
<tr>
<td>1 ENABLE_BO</td>
<td>Control bit to enable the brownout circuitry in the regulator.</td>
</tr>
<tr>
<td>0 ENABLE_LINREG</td>
<td>Control bit to enable the regulator output to be set by the programmed target voltage setting and internal bandgap reference.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Code</th>
<th>Voltage</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>2.625V</td>
</tr>
<tr>
<td>0x0f</td>
<td>3.000V</td>
</tr>
<tr>
<td>0x1f</td>
<td>3.400V</td>
</tr>
</tbody>
</table>

- **USB_OTG1_VBUS** — Utilize VBUS OTG1 power
- **USB_OTG2_VBUS** — Utilize VBUS OTG2 power
### 16.6.3 Regulator 2P5 Register (PMU_REG_2P5n)

This register defines the control and status bits for the 2.5V regulator.

Address: 400D_8000h base + 130h offset + (4d × i), where i=0d to 3d

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Reset**

- 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**Bits Description**

- **R**: Reserved
- **W**: Reset
- **15**: ENABLE_WEAK_LINREG
- **16**: OK_VDD2P5
- **17**: BO_VDD2P5
PMU Memory Map/Register Definition

### PMU_REG_2P5n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–19</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>18 ENABLE_WEAK_LINREG</td>
<td>Enables the weak 2p5 regulator. This low power regulator is used when the main 2p5 regulator is disabled to keep the 2.5V output roughly at 2.5V. Scales directly with the value of VDDHIGH_IN.</td>
</tr>
<tr>
<td>17 OK_VDD2P5</td>
<td>Status bit that signals when the regulator output is ok. 1 = regulator output &gt; brownout target</td>
</tr>
<tr>
<td>16 BO_VDD2P5</td>
<td>Status bit that signals when a brownout is detected on the regulator output.</td>
</tr>
<tr>
<td>15–13</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>
| 12–8 OUTPUT_TRG | Control bits to adjust the regulator output voltage. Each LSB is worth 25mV. Programming examples are detailed below. Other output target voltages may be interpolated from these examples.  
**NOTE:** There may be reduced chip functionality or reliability at the extremes of the programming range.  
0x00 2.10V  
0x10 2.50V  
0x1f 2.875V |
| 7              | This field is reserved.                                                                                 |
| 6–4 BO_OFFSET  | Control bits to adjust the regulator brownout offset voltage in 25mV steps. The reset brown-offset is 175mV below the programmed target code. Brownout target = OUTPUT_TRG - BO_OFFSET. Some steps may be irrelevant because of input supply limitations or load operation. |
| 3 ENABLE_PULLDOWN | Control bit to enable the pull-down circuitry in the regulator                                          |

Table continues on the next page...
PMU_REG_2P5n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>ENABLE_ILIMIT Control bit to enable the current-limit circuitry in the regulator.</td>
</tr>
<tr>
<td>1</td>
<td>ENABLE_BO Control bit to enable the brownout circuitry in the regulator.</td>
</tr>
<tr>
<td>0</td>
<td>ENABLE_LINREG Control bit to enable the regulator output.</td>
</tr>
</tbody>
</table>

16.6.4  Digital Regulator Core Register (PMU_REG_COREn)

This register defines the function of the digital regulators

Address: 400D_8000h base + 140h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
<th>Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>This field is reserved.</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>FET_ODRIVE</td>
<td>15–14</td>
</tr>
<tr>
<td></td>
<td>If set, increases the gate drive on power gating FETs to reduce leakage in the off state. Care must be taken to apply this bit only when the input supply voltage to the power FET is less than 1.1V.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>NOTE: This bit should only be used in low-power modes where the external input supply voltage is nominally 0.9V.</td>
<td></td>
</tr>
<tr>
<td>28–27</td>
<td>RAMP_RATE</td>
<td>11–8</td>
</tr>
<tr>
<td></td>
<td>Regulator voltage ramp rate.</td>
<td></td>
</tr>
<tr>
<td>00</td>
<td>Fast</td>
<td>4</td>
</tr>
<tr>
<td>01</td>
<td>Medium Fast</td>
<td>0</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>Medium Slow</td>
</tr>
<tr>
<td>11</td>
<td>Slow</td>
</tr>
<tr>
<td>26–23</td>
<td>REG2_ADJ</td>
</tr>
<tr>
<td></td>
<td>This bit field defines the adjustment bits to calibrate the target value of Reg2. The adjustment is applied on top on any adjustment applied to the global reference in the misc0 register.</td>
</tr>
<tr>
<td>0000</td>
<td>No adjustment</td>
</tr>
<tr>
<td>0001</td>
<td>+ 0.25%</td>
</tr>
<tr>
<td>0010</td>
<td>+ 0.50%</td>
</tr>
<tr>
<td>0011</td>
<td>+ 0.75%</td>
</tr>
<tr>
<td>0100</td>
<td>+ 1.00%</td>
</tr>
<tr>
<td>0101</td>
<td>+ 1.25%</td>
</tr>
<tr>
<td>0110</td>
<td>+ 1.50%</td>
</tr>
<tr>
<td>0111</td>
<td>+ 1.75%</td>
</tr>
<tr>
<td>1000</td>
<td>- 0.25%</td>
</tr>
<tr>
<td>1001</td>
<td>- 0.50%</td>
</tr>
<tr>
<td>1010</td>
<td>- 0.75%</td>
</tr>
<tr>
<td>1011</td>
<td>- 1.00%</td>
</tr>
<tr>
<td>1100</td>
<td>- 1.25%</td>
</tr>
<tr>
<td>1101</td>
<td>- 1.50%</td>
</tr>
<tr>
<td>1110</td>
<td>- 1.75%</td>
</tr>
<tr>
<td>1111</td>
<td>- 2.00%</td>
</tr>
<tr>
<td>22–18</td>
<td>REG2_TARG</td>
</tr>
<tr>
<td></td>
<td>This field defines the target voltage for the SOC power domain. Single-bit increments reflect 25mV core voltage steps. Some steps may not be relevant because of input supply limitations or load operation.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This register is capable of programming an over-voltage condition on the device. Consult the datasheet Operating Ranges table for the allowed voltages.</td>
</tr>
<tr>
<td>00000</td>
<td>Power gated off</td>
</tr>
<tr>
<td>00001</td>
<td>Target core voltage = 0.725V</td>
</tr>
<tr>
<td>00010</td>
<td>Target core voltage = 0.750V</td>
</tr>
<tr>
<td>00011</td>
<td>Target core voltage = 0.775V</td>
</tr>
<tr>
<td>...</td>
<td></td>
</tr>
<tr>
<td>10000</td>
<td>Target core voltage = 1.100V</td>
</tr>
<tr>
<td>...</td>
<td></td>
</tr>
<tr>
<td>11110</td>
<td>Target core voltage = 1.450V</td>
</tr>
<tr>
<td>11111</td>
<td>Power FET switched full on. No regulation.</td>
</tr>
<tr>
<td>17–14</td>
<td>REG1_ADJ</td>
</tr>
<tr>
<td></td>
<td>This bit field defines the adjustment bits to calibrate the target value of Reg1. The adjustment is applied on top on any adjustment applied to the global reference in the misc0 register.</td>
</tr>
<tr>
<td>0000</td>
<td>No adjustment</td>
</tr>
<tr>
<td>0001</td>
<td>+ 0.25%</td>
</tr>
<tr>
<td>0010</td>
<td>+ 0.50%</td>
</tr>
<tr>
<td>0011</td>
<td>+ 0.75%</td>
</tr>
<tr>
<td>0100</td>
<td>+ 1.00%</td>
</tr>
<tr>
<td>0101</td>
<td>+ 1.25%</td>
</tr>
<tr>
<td>0110</td>
<td>+ 1.50%</td>
</tr>
<tr>
<td>0111</td>
<td>+ 1.75%</td>
</tr>
<tr>
<td>1000</td>
<td>- 0.25%</td>
</tr>
</tbody>
</table>

Table continues on the next page...
PMU_REG_CORE field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1001</td>
<td>- 0.50%</td>
</tr>
<tr>
<td>1010</td>
<td>- 0.75%</td>
</tr>
<tr>
<td>1011</td>
<td>- 1.00%</td>
</tr>
<tr>
<td>1100</td>
<td>- 1.25%</td>
</tr>
<tr>
<td>1101</td>
<td>- 1.50%</td>
</tr>
<tr>
<td>1110</td>
<td>- 1.75%</td>
</tr>
<tr>
<td>1111</td>
<td>- 2.00%</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>REG1_TARG</th>
<th>This bit field defines the target voltage for the vpu/gpu power domain. Single bit increments reflect 25mV core voltage steps. Not all steps will make sense to use either because of input supply limitations or load operation.</th>
</tr>
</thead>
<tbody>
<tr>
<td>00000</td>
<td>Power gated off</td>
</tr>
<tr>
<td>00001</td>
<td>Target core voltage = 0.725V</td>
</tr>
<tr>
<td>00010</td>
<td>Target core voltage = 0.750V</td>
</tr>
<tr>
<td>00011</td>
<td>Target core voltage = 0.775V</td>
</tr>
<tr>
<td></td>
<td>...</td>
</tr>
<tr>
<td>10000</td>
<td>Target core voltage = 1.100V</td>
</tr>
<tr>
<td></td>
<td>...</td>
</tr>
<tr>
<td>11110</td>
<td>Target core voltage = 1.450V</td>
</tr>
<tr>
<td>11111</td>
<td>Power FET switched full on. No regulation.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>REG0_ADJ</th>
<th>This bit field defines the adjustment bits to calibrate the target value of Reg0. The adjustment is applied on top on any adjustment applied to the global reference in the misc0 register.</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000</td>
<td>No adjustment</td>
</tr>
<tr>
<td>0001</td>
<td>+ 0.25%</td>
</tr>
<tr>
<td>0010</td>
<td>+ 0.50%</td>
</tr>
<tr>
<td>0011</td>
<td>+ 0.75%</td>
</tr>
<tr>
<td>0100</td>
<td>+ 1.00%</td>
</tr>
<tr>
<td>0101</td>
<td>+ 1.25%</td>
</tr>
<tr>
<td>0110</td>
<td>+ 1.50%</td>
</tr>
<tr>
<td>0111</td>
<td>+ 1.75%</td>
</tr>
<tr>
<td>1000</td>
<td>- 0.25%</td>
</tr>
<tr>
<td>1001</td>
<td>- 0.50%</td>
</tr>
<tr>
<td>1010</td>
<td>- 0.75%</td>
</tr>
<tr>
<td>1011</td>
<td>- 1.00%</td>
</tr>
<tr>
<td>1100</td>
<td>- 1.25%</td>
</tr>
<tr>
<td>1101</td>
<td>- 1.50%</td>
</tr>
<tr>
<td>1110</td>
<td>- 1.75%</td>
</tr>
<tr>
<td>1111</td>
<td>- 2.00%</td>
</tr>
</tbody>
</table>

REG0_TARG | This field defines the target voltage for the Arm core power domain. Single-bit increments reflect 25mV core voltage steps. Some steps may not be relevant because of input supply limitations or load operation. |
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>00000</td>
<td>Power gated off</td>
</tr>
<tr>
<td>00001</td>
<td>Target core voltage = 0.725V</td>
</tr>
<tr>
<td>00010</td>
<td>Target core voltage = 0.750V</td>
</tr>
</tbody>
</table>

NOTE: This register is capable of programming an over-voltage condition on the device. Consult the datasheet Operating Ranges table for the allowed voltages.
PMU_REG_COREn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00011</td>
<td>Target core voltage = 0.775V</td>
</tr>
<tr>
<td></td>
<td>...</td>
</tr>
<tr>
<td>10000</td>
<td>Target core voltage = 1.100V</td>
</tr>
<tr>
<td></td>
<td>...</td>
</tr>
<tr>
<td>11110</td>
<td>Target core voltage = 1.450V</td>
</tr>
<tr>
<td>11111</td>
<td>Power FET switched full on. No regulation.</td>
</tr>
</tbody>
</table>
16.6.5 Miscellaneous Register 0 (PMU_MISC0n)

This register defines the control and status bits for miscellaneous analog blocks.

Address: 400D_8000h base + 150h offset + (4d \times i), where i=0d to 3d
### PMU_MISC0n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 VID_PLL_PREDIV</td>
<td>Predivider for the source clock of the PLL's.</td>
</tr>
<tr>
<td></td>
<td>0  Divide by 1</td>
</tr>
<tr>
<td></td>
<td>1  Divide by 2</td>
</tr>
<tr>
<td>30 XTAL_24M_PWD</td>
<td>This field powers down the 24M crystal oscillator if set true.</td>
</tr>
<tr>
<td>29 RTC_XTAL_SOURCE</td>
<td>This field indicates which chip source is being used for the rtc clock.</td>
</tr>
<tr>
<td></td>
<td>0  Internal ring oscillator</td>
</tr>
<tr>
<td></td>
<td>1  RTC_XTAL</td>
</tr>
<tr>
<td>28–26 CLKGATE_DELAY</td>
<td>This field specifies the delay between powering up the XTAL 24MHz clock and releasing the clock to the digital logic inside the analog block.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Do not change the field during a low power event. This is not a field that the user would normally need to modify.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Not related to PMU.</td>
</tr>
<tr>
<td></td>
<td>000  0.5ms</td>
</tr>
<tr>
<td></td>
<td>001  1.0ms</td>
</tr>
<tr>
<td></td>
<td>010  2.0ms</td>
</tr>
<tr>
<td></td>
<td>011  3.0ms</td>
</tr>
<tr>
<td></td>
<td>100  4.0ms</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### PMU_MISC0 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>101</td>
<td>5.0ms</td>
</tr>
<tr>
<td>110</td>
<td>6.0ms</td>
</tr>
<tr>
<td>111</td>
<td>7.0ms</td>
</tr>
</tbody>
</table>

**25**

**CLKGATE_CTRL**

This bit allows disabling the clock gate (always ungated) for the xtal 24MHz clock that clocks the digital logic in the analog block.

*NOTE:* Do not change the field during a low power event. This is not a field that the user would normally need to modify.

*NOTE:* Not related to PMU.

0  **ALLOW_AUTO_GATE** — Allow the logic to automatically gate the clock when the XTAL is powered down.

1  **NO_AUTO_GATE** — Prevent the logic from ever gating off the clock.

| 24–17 | This field is reserved.  
|       | Always set to zero. |

| 16    | This bit enables the detector that signals when the 24MHz crystal oscillator is stable.  
|       | *NOTE:* Not related to PMU, Clocking content |

| 15    | Status bit that signals that the output of the 24-MHz crystal oscillator is stable. Generated from a timer and active detection of the actual frequency.  
|       | *NOTE:* Not related to PMU, clocking content. |

| 14–13 | This field determines the bias current in the 24MHz oscillator. The aim is to start up with the highest bias current, which can be decreased after startup if it is determined to be acceptable.  
|       | *NOTE:* Not related to PMU. |

00  **NOMINAL** — Nominal

01  **MINUS_12.5_PERCENT** — Decrease current by 12.5%

10  **MINUS_25_PERCENT** — Decrease current by 25.0%

11  **MINUS_37.5_PERCENT** — Decrease current by 37.5%

| 12    | This bit controls a switch from VDD_HIGH_IN to VDD_SNVS_IN.  
|       | 0  Turn on the switch  
|       | 1  Turn off the switch |

| 11–10 | Configure the analog behavior in stop mode.  
|       | 00  **SUSPEND (DSM)** — All analog except rtc powered down on stop mode assertion.  
|       | 01  **STANDBY** — Analog regulators are ON.  
|       | 10  **STOP (lower power)** — Analog regulators are ON.  
|       | 11  **STOP (very lower power)** — Analog regulators are OFF. |

| 9–8   | This field is reserved.  
|       | Reserved |

| 7     | Status bit that signals the analog bandgap voltage is up and stable. 1 - Stable. |

*Table continues on the next page...*
### PMU_MISC0n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6–4</td>
<td><strong>REFTOP_VBGADJ</strong></td>
</tr>
<tr>
<td>000</td>
<td>Nominal VBG</td>
</tr>
<tr>
<td>001</td>
<td>VBG+0.78%</td>
</tr>
<tr>
<td>010</td>
<td>VBG+1.56%</td>
</tr>
<tr>
<td>011</td>
<td>VBG+2.34%</td>
</tr>
<tr>
<td>100</td>
<td>VBG-0.78%</td>
</tr>
<tr>
<td>101</td>
<td>VBG-1.56%</td>
</tr>
<tr>
<td>110</td>
<td>VBG-2.34%</td>
</tr>
<tr>
<td>111</td>
<td>VBG-3.12%</td>
</tr>
<tr>
<td>3</td>
<td><strong>REFTOP_SELFBIASOFF</strong></td>
</tr>
<tr>
<td></td>
<td>Control bit to disable the self-bias circuit in</td>
</tr>
<tr>
<td></td>
<td>the analog bandgap. The self-bias circuit is</td>
</tr>
<tr>
<td></td>
<td>used by the bandgap during startup. This bit</td>
</tr>
<tr>
<td></td>
<td>should be set after the bandgap has stabilized</td>
</tr>
<tr>
<td></td>
<td>and is necessary for best noise performance of</td>
</tr>
<tr>
<td></td>
<td>analog blocks using the outputs of the bandgap.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Value should be returned to zero before</td>
</tr>
<tr>
<td></td>
<td>removing vddhigh_in or asserting bit 0 of this</td>
</tr>
<tr>
<td></td>
<td>register (REFTOP_PWD) to assure proper restart of</td>
</tr>
<tr>
<td></td>
<td>the circuit.</td>
</tr>
<tr>
<td>0</td>
<td>Uses coarse bias currents for startup</td>
</tr>
<tr>
<td>1</td>
<td>Uses bandgap-based bias currents for best</td>
</tr>
<tr>
<td></td>
<td>performance.</td>
</tr>
<tr>
<td>2</td>
<td><strong>REFTOP_LOWPOWER</strong></td>
</tr>
<tr>
<td></td>
<td>Control bit to enable the low-power mode in the</td>
</tr>
<tr>
<td></td>
<td>analog bandgap.</td>
</tr>
<tr>
<td>1</td>
<td><strong>REFTOP_PWDVBGUP</strong></td>
</tr>
<tr>
<td></td>
<td>Control bit to power down the VBG-up detection</td>
</tr>
<tr>
<td></td>
<td>circuitry in the analog bandgap.</td>
</tr>
<tr>
<td>0</td>
<td><strong>REFTOP_PWD</strong></td>
</tr>
<tr>
<td></td>
<td>Control bit to power-down the analog bandgap</td>
</tr>
<tr>
<td></td>
<td>reference circuitry.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> A note of caution, the bandgap is</td>
</tr>
<tr>
<td></td>
<td>necessary for correct operation of most of the</td>
</tr>
<tr>
<td></td>
<td>LDO, PLL, and other analog functions on the die.</td>
</tr>
</tbody>
</table>

---

**PMU Memory Map/Register Definition**

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
16.6.6  Miscellaneous Register 1 (PMU_MISC1n)

This register defines the control and status bits for miscellaneous analog blocks.

Address: 400D_8000h base + 160h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>IRQ_DIG_BO</th>
<th>IRQ_ANA_BO</th>
<th>IRQ_TEMPHIGH</th>
<th>IRQ_TEMPLOW</th>
<th>IRQ_TEMPPANIC</th>
<th>LVDSCLK2_IBEN</th>
<th>LVDSCLK1_IBEN</th>
<th>LVDSCLK2_OBEN</th>
<th>LVDSCLK1_OBEN</th>
<th>Reserved</th>
<th>Reserved</th>
<th>LVDS2_CLK_SEL</th>
<th>LVDS1_CLK_SEL</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td>LVDS2_CLK_SEL</td>
<td>LVDS1_CLK_SEL</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>IRQ_DIG_BO</td>
<td>IRQ_ANA_BO</td>
<td>IRQ_TEMPHIGH</td>
<td>IRQ_TEMPLOW</td>
<td>IRQ_TEMPPANIC</td>
<td>LVDSCLK2_IBEN</td>
<td>LVDSCLK1_IBEN</td>
<td>LVDSCLK2_OBEN</td>
<td>LVDSCLK1_OBEN</td>
<td>Reserved</td>
<td>Reserved</td>
<td>LVDS2_CLK_SEL</td>
<td>LVDS1_CLK_SEL</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>IRQ_TEMPHIGH</td>
<td>IRQ_ANA_BO</td>
<td>IRQ_TEMPHIGH</td>
<td>IRQ_TEMPLOW</td>
<td>IRQ_TEMPPANIC</td>
<td>LVDSCLK2_IBEN</td>
<td>LVDSCLK1_IBEN</td>
<td>LVDSCLK2_OBEN</td>
<td>LVDSCLK1_OBEN</td>
<td>Reserved</td>
<td>Reserved</td>
<td>LVDS2_CLK_SEL</td>
<td>LVDS1_CLK_SEL</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

PMU_MISC1n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>IRQ_DIG_BO</td>
</tr>
<tr>
<td></td>
<td>This status bit is set to one when any of the digital regulator brownout interrupts assert. Check the regulator status bits to discover which regulator interrupt asserted.</td>
</tr>
<tr>
<td>30</td>
<td>IRQ_ANA_BO</td>
</tr>
<tr>
<td></td>
<td>This status bit is set to one when any of the analog regulator brownout interrupts assert. Check the regulator status bits to discover which regulator interrupt asserted.</td>
</tr>
<tr>
<td>29</td>
<td>IRQ_TEMPHIGH</td>
</tr>
<tr>
<td></td>
<td>This status bit is set to one when the temperature sensor high interrupt asserts for high temperature.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### PMU_MISC1n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>28</td>
<td>NOTE: Not related to PMU, Temperature Monitor content.</td>
</tr>
<tr>
<td>27</td>
<td>NOTE: Not related to PMU, Temperature Monitor content.</td>
</tr>
<tr>
<td>26–18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>NOTE: Not related to PMU, Temperature Monitor content.</td>
</tr>
<tr>
<td>16</td>
<td>This enables a feature that will clkgate (reset) all PFD_528 clocks anytime the PLL_528 is unlocked or powered off.</td>
</tr>
<tr>
<td>15–14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>NOTE: Not related to PMU.</td>
</tr>
<tr>
<td>12</td>
<td>This enables the LVDS input buffer for anaclock2/2b. Do not enable input and output buffers simultaneously.</td>
</tr>
<tr>
<td>11</td>
<td>NOTE: Not related to PMU, Clocking content.</td>
</tr>
<tr>
<td>10</td>
<td>NOTE: Not related to PMU, clocking content.</td>
</tr>
<tr>
<td>9–5</td>
<td>This field selects the clk to be routed to anaclock2/2b.</td>
</tr>
<tr>
<td>00000</td>
<td>ARM_PLL — ARM PLL</td>
</tr>
<tr>
<td>00001</td>
<td>SYS_PLL — System PLL</td>
</tr>
<tr>
<td>00010</td>
<td>PFD4 — ref_pfd4_clk == pll2_pfd0_clk</td>
</tr>
<tr>
<td>00011</td>
<td>PFD5 — ref_pfd5_clk == pll2_pfd1_clk</td>
</tr>
<tr>
<td>00100</td>
<td>PFD6 — ref_pfd6_clk == pll2_pfd2_clk</td>
</tr>
<tr>
<td>00101</td>
<td>PFD7 — ref_pfd7_clk == pll2_pfd3_clk</td>
</tr>
<tr>
<td>00110</td>
<td>AUDIO_PLL — Audio PLL</td>
</tr>
<tr>
<td>00111</td>
<td>VIDEO_PLL — Video PLL</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## PMU_MISC1n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>01000</td>
<td>MLB_PLL — MLB PLL</td>
</tr>
<tr>
<td>01001</td>
<td>ETHERNET_REF — ethernet ref clock (ENET_PLL)</td>
</tr>
<tr>
<td>01010</td>
<td>PCIE_REF — PCIe ref clock (125M)</td>
</tr>
<tr>
<td>01011</td>
<td>SATA_REF — SATA ref clock (100M)</td>
</tr>
<tr>
<td>01100</td>
<td>USB1_PLL — USB1 PLL clock</td>
</tr>
<tr>
<td>01101</td>
<td>USB2_PLL — USB2 PLL clock</td>
</tr>
<tr>
<td>01110</td>
<td>PFD0 — ref_pfd0_clk == pll3_pfd0_clk</td>
</tr>
<tr>
<td>01111</td>
<td>PFD1 — ref_pfd1_clk == pll3_pfd1_clk</td>
</tr>
<tr>
<td>10000</td>
<td>PFD2 — ref_pfd2_clk == pll3_pfd2_clk</td>
</tr>
<tr>
<td>10001</td>
<td>PFD3 — ref_pfd3_clk == pll3_pfd3_clk</td>
</tr>
<tr>
<td>10010</td>
<td>XTAL — xtal (24M)</td>
</tr>
<tr>
<td>10011</td>
<td>LVDS1 — LVDS1 (loopback)</td>
</tr>
<tr>
<td>10100</td>
<td>LVDS2 — LVDS2 (not useful)</td>
</tr>
<tr>
<td>10101 to 11111</td>
<td>— ref_pfd7_clk == pll2_pfd3_clk</td>
</tr>
</tbody>
</table>

LVDS1_CLK_SEL

This field selects the clk to be routed to anaclk1/1b.

**NOTE:** Not related to PMU.

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00000</td>
<td>ARM_PLL — ARM PLL</td>
</tr>
<tr>
<td>00001</td>
<td>SYS_PLL — System PLL</td>
</tr>
<tr>
<td>00010</td>
<td>PFD4 — ref_pfd4_clk == pll2_pfd0_clk</td>
</tr>
<tr>
<td>00011</td>
<td>PFD5 — ref_pfd5_clk == pll2_pfd1_clk</td>
</tr>
<tr>
<td>00100</td>
<td>PFD6 — ref_pfd6_clk == pll2_pfd2_clk</td>
</tr>
<tr>
<td>00101</td>
<td>PFD7 — ref_pfd7_clk == pll2_pfd3_clk</td>
</tr>
<tr>
<td>00110</td>
<td>AUDIO_PLL — Audio PLL</td>
</tr>
<tr>
<td>00111</td>
<td>VIDEO_PLL — Video PLL</td>
</tr>
<tr>
<td>01001</td>
<td>ETHERNET_REF — ethernet ref clock (ENET_PLL)</td>
</tr>
<tr>
<td>01100</td>
<td>USB1_PLL — USB1 PLL clock</td>
</tr>
<tr>
<td>01101</td>
<td>USB2_PLL — USB2 PLL clock</td>
</tr>
<tr>
<td>01110</td>
<td>PFD0 — ref_pfd0_clk == pll3_pfd0_clk</td>
</tr>
<tr>
<td>01111</td>
<td>PFD1 — ref_pfd1_clk == pll3_pfd1_clk</td>
</tr>
<tr>
<td>10000</td>
<td>PFD2 — ref_pfd2_clk == pll3_pfd2_clk</td>
</tr>
<tr>
<td>10001</td>
<td>PFD3 — ref_pfd3_clk == pll3_pfd3_clk</td>
</tr>
<tr>
<td>10010</td>
<td>XTAL — xtal (24M)</td>
</tr>
<tr>
<td>10101 to 11111</td>
<td>— ref_pfd7_clk == pll2_pfd3_clk</td>
</tr>
</tbody>
</table>

### 16.6.7 Miscellaneous Control Register (PMU_MISC2n)

This register defines the control for miscellaneous PMU Analog blocks.

**NOTE**

This register is shared with CCM.
### PMU Memory Map/Register Definition

Address: 400D_8000h base + 170h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>REG2_ENABLE_BO</td>
<td></td>
<td>REG2_BO_OFFSET</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>REG2_OK</td>
<td></td>
<td>REG2_BO_STATUS</td>
<td></td>
</tr>
<tr>
<td></td>
<td>VIDEO_DIV</td>
<td>REG2_STEP_TIME</td>
<td>REG1_STEP_TIME</td>
<td>REG0_STEP_TIME</td>
<td>AUDIO_DIV_MSB</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 1 1
### PMU_MISC2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–30 VIDEO_DIV    | Post-divider for video. The output clock of the video PLL should be gated prior to changing this divider to prevent glitches. This divider is fed by PLL_VIDEO[POST_DIV_SELECT] to achieve division ratios of /1, /2, /4, /8, and /16.  
**NOTE:** Not related to PMU. See Clock Controller Module (CCM) for more information.  
00 divide by 1 (Default)  
01 divide by 2  
10 divide by 4  
11 divide by 8  |
| 29–28 REG2_STEP_TIME | Number of clock periods (24MHz clock).  
00 64_CLOCKS — 64  
01 128_CLOCKS — 128  
10 256_CLOCKS — 256  
11 512_CLOCKS — 512  |
| 27–26 REG1_STEP_TIME | Number of clock periods (24MHz clock).  
00 64_CLOCKS — 64  
01 128_CLOCKS — 128  |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>256_CLOCKS — 256</td>
</tr>
<tr>
<td>11</td>
<td>512_CLOCKS — 512</td>
</tr>
<tr>
<td>25–24</td>
<td>Number of clock periods (24MHz clock).</td>
</tr>
<tr>
<td>REG0_STEP_</td>
<td>Time</td>
</tr>
<tr>
<td>TIME</td>
<td>00 64_CLOCKS — 64</td>
</tr>
<tr>
<td></td>
<td>01 128_CLOCKS — 128</td>
</tr>
<tr>
<td></td>
<td>10 256_CLOCKS — 256</td>
</tr>
<tr>
<td></td>
<td>11 512_CLOCKS — 512</td>
</tr>
<tr>
<td>23</td>
<td>MSB of Post-divider for Audio PLL. The output clock of the video PLL should be gated prior to changing this divider to prevent glitches. This divider is fed by PLL_AUDIOn[POST_DIV_SELECT] to achieve division ratios of /1, /2, /4, /8, and /16.</td>
</tr>
<tr>
<td>AUDIO_DIV_</td>
<td>MSB</td>
</tr>
<tr>
<td>MSB</td>
<td>NOTE: MSB bit value pertains to the first bit, please program the LSB bit (bit 15) as well to change divider value</td>
</tr>
<tr>
<td></td>
<td>NOTE: Not related to PMU. See Clock Controller Module (CCM) for more information.</td>
</tr>
<tr>
<td></td>
<td>00 divide by 1 (Default)</td>
</tr>
<tr>
<td></td>
<td>01 divide by 2</td>
</tr>
<tr>
<td></td>
<td>10 divide by 1</td>
</tr>
<tr>
<td></td>
<td>11 divide by 4</td>
</tr>
<tr>
<td>22</td>
<td>Signals that the voltage is above the brownout level for the SOC supply. 1 = regulator output &gt; brownout_target</td>
</tr>
<tr>
<td>REG2_OK</td>
<td>Enables the brownout detection.</td>
</tr>
<tr>
<td>21</td>
<td>REG2_ENABLE_BO</td>
</tr>
<tr>
<td></td>
<td>Enables the brownout detection.</td>
</tr>
<tr>
<td>20</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>19</td>
<td>REG2_BO_STATUS</td>
</tr>
<tr>
<td>REG2_BO_</td>
<td>Reg2 brownout status bit.</td>
</tr>
<tr>
<td>OFFSET</td>
<td>18–16</td>
</tr>
<tr>
<td></td>
<td>This field defines the brown out voltage offset for the xPU power domain. IRQ_DIG_BO is also asserted. Single-bit increments reflect 25mV brownout voltage steps. The reset brown-offset is 175mV below the programmed target code. Brownout target = OUTPUT_TRG - BO_OFFSET. Some steps may be irrelevant because of input supply limitations or load operation.</td>
</tr>
<tr>
<td></td>
<td>NOTE: Brownout offset = 0.100V</td>
</tr>
<tr>
<td></td>
<td>NOTE: Brownout offset = 0.175V</td>
</tr>
<tr>
<td></td>
<td>00 Brownout offset = 0.100V</td>
</tr>
<tr>
<td></td>
<td>11 Brownout offset = 0.175V</td>
</tr>
<tr>
<td>15</td>
<td>LSB of Post-divider for Audio PLL. The output clock of the video PLL should be gated prior to changing this divider to prevent glitches. This divider is fed by PLL_AUDIOn[POST_DIV_SELECT] to achieve division ratios of /1, /2, /4, /8, and /16.</td>
</tr>
<tr>
<td>AUDIO_DIV_</td>
<td>LSB</td>
</tr>
<tr>
<td>LSB</td>
<td>NOTE: LSB bit value pertains to the last bit, please program the MSB bit (bit 23) as well, to change divider value</td>
</tr>
<tr>
<td></td>
<td>NOTE: Not related to PMU. See Clock Controller Module (CCM) for more information.</td>
</tr>
<tr>
<td></td>
<td>00 divide by 1 (Default)</td>
</tr>
<tr>
<td></td>
<td>01 divide by 2</td>
</tr>
<tr>
<td></td>
<td>10 divide by 1</td>
</tr>
<tr>
<td></td>
<td>11 divide by 4</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### PMU_MISC2n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14 - Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>13 REG1_ENABLE_BO</td>
<td>Enables the brownout detection.</td>
</tr>
<tr>
<td>12 - Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>11 REG1_BO_STATUS</td>
<td>Reg1 brownout status bit.</td>
</tr>
<tr>
<td>10–8 REG1_BO_OFFSET</td>
<td>This field defines the brown out voltage offset for the xPU power domain. IRQ_DIG_BO is also asserted. Single-bit increments reflect 25mV brownout voltage steps. The reset brown-offset is 175mV below the programmed target code. Brownout target = OUTPUT_TRG - BO_OFFSET. Some steps may be irrelevant because of input supply limitations or load operation.</td>
</tr>
<tr>
<td>7 PLL3_disable</td>
<td>Default value of &quot;0&quot;. Should be set to &quot;1&quot; to turn off the USB-PLL(PLL3) in run mode.</td>
</tr>
<tr>
<td>6 - Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>5 REG0_ENABLE_BO</td>
<td>Enables the brownout detection.</td>
</tr>
<tr>
<td>4 - Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>3 REG0_BO_STATUS</td>
<td>Reg0 brownout status bit.</td>
</tr>
<tr>
<td>REG0_BO_OFFSET</td>
<td>This field defines the brown out voltage offset for the CORE power domain. IRQ_DIG_BO is also asserted. Single-bit increments reflect 25mV brownout voltage steps. Some steps may be irrelevant because of input supply limitations or load operation.</td>
</tr>
</tbody>
</table>

**NOTE:** Not related to PMU. See Clock Controller Module (CCM) for more information.
Chapter 17
General Power Controller (GPC)

17.1 Chip-specific GPC information

Table 17-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
<tr>
<td>and XBAR Assignments</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

17.2 Overview

The General Power Control (GPC) block includes the sub-blocks listed here.

- CPU Power Gating Control (PGC)

Each sub-block has its own IP registers.

GPC determines wake-up IRQ for exiting WAIT/STOP mode (with or without CPU power gating).
17.3 Clocks

The table found here describes the clock sources for GPC.

Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
<tr>
<td>pgc_clk</td>
<td>ipg_clk_root</td>
<td>PGC peripheral clock</td>
</tr>
<tr>
<td>sys_clk</td>
<td>ipg_clk_root</td>
<td>Module clock</td>
</tr>
</tbody>
</table>

17.4 Power Gating Control (PGC)

Power Gating (PGC) is applied to the Arm CPU and FlexRAM optionally in STOP low power mode, after all essential CPU registers data are saved by Arm dormant procedure.
If any of the unmasked interrupts appears, CPU is powered up and clock restore request (exit from STOP mode) is sent to CCM.

**PGC power down sequence:**

- CCM sends power down request when the chip is about to enter stop mode. The user should define which modules will be powered down (CTRL registers of corresponding PGC module, bit 0).

**PGC power up sequence:**

- One of the power up irq is asserted.
- Power up request is asserted in GPC and in CCM.
- The Power Gated modules are powered up, according to PGC settings of appropriate module.

The Power Gated modules require reset after powering up. The next figure describes GPC-SRC handshake procedure for reset after power gating.
17.4.1 Overview

The Power Gating Controller (PGC) is a power management component that controls the power-down and power-up sequencing of individual subsystems.

The sequence timing is programmable using the PGC control registers. Figure 17-3 shows PGC as part of the SoC’s overall power management scheme.
17.4.1.1 Features

Key features of the PGC include:

- Provides the ability to switch off power to a target subsystem.
- Generates power-up and power-down control sequences.
- Provides programmable registers to adjust the timing of the power control signals.

17.5 GPC Interrupt Controller (INTC)

The INTC (Interrupt Controller) detects an interrupt and generates the wakeup signal. It supports up to 160 interrupts.

17.5.1 Interrupt Controller features

The features of the GPC INTC are listed below.

Features:

- Supports up to 160 interrupts
- Provides an option to mask/unmask each interrupt
- Detects interrupts and generates the wake up signal
- 32-bits IP bus interface
- All registers are byte-accessible
17.6  GPC Memory Map/Register Definition

Detailed descriptions of each register can be found below.

Writes to GPC registers only takes effect in supervisor mode.

### GPC memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400F_4000</td>
<td>GPC Interface control register (GPC_CNTR)</td>
<td>32</td>
<td>R/W</td>
<td>0052_0000h</td>
<td>17.6.1/1190</td>
</tr>
<tr>
<td>400F_4008</td>
<td>IRQ masking register 1 (GPC_IMR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.6.2/1192</td>
</tr>
<tr>
<td>400F_400C</td>
<td>IRQ masking register 2 (GPC_IMR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.6.3/1192</td>
</tr>
<tr>
<td>400F_4010</td>
<td>IRQ masking register 3 (GPC_IMR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.6.4/1193</td>
</tr>
<tr>
<td>400F_4014</td>
<td>IRQ masking register 4 (GPC_IMR4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.6.5/1193</td>
</tr>
<tr>
<td>400F_4018</td>
<td>IRQ status resister 1 (GPC_ISR1)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>17.6.6/1194</td>
</tr>
<tr>
<td>400F_401C</td>
<td>IRQ status resister 2 (GPC_ISR2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>17.6.7/1194</td>
</tr>
<tr>
<td>400F_4020</td>
<td>IRQ status resister 3 (GPC_ISR3)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>17.6.8/1195</td>
</tr>
<tr>
<td>400F_4024</td>
<td>IRQ status resister 4 (GPC_ISR4)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>17.6.9/1195</td>
</tr>
<tr>
<td>400F_4034</td>
<td>IRQ masking register 5 (GPC_IMR5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.6.10/1196</td>
</tr>
<tr>
<td>400F_4038</td>
<td>IRQ status resister 5 (GPC_ISR5)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>17.6.11/1196</td>
</tr>
</tbody>
</table>

17.6.1  GPC Interface control register (GPC_CNTR)

Address: 400F_4000h base + 0h offset = 400F_4000h

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### GPC_CNTR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–23 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>22 PDRAM0_PGE</td>
<td>FlexRAM PDRAM0 Power Gate Enable</td>
</tr>
<tr>
<td>22 1</td>
<td>FlexRAM PDRAM0 domain will be powered down when the CPU core is powered down.</td>
</tr>
<tr>
<td>22 0</td>
<td>FlexRAM PDRAM0 domain will keep power even if the CPU core is powered down.</td>
</tr>
<tr>
<td>21</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>21 Reserved</td>
<td>This read-only field is reserved and always has the value 1.</td>
</tr>
<tr>
<td>19–17 Reserved</td>
<td>This bitfield is readable/writeable, but avoid writing to this reserved bitfield.</td>
</tr>
<tr>
<td>16</td>
<td>This bitfield is readable/writeable, but avoid writing to this reserved bitfield.</td>
</tr>
<tr>
<td>15–6 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>5</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>3 MEGA_PUP_REQ</td>
<td>MEGA domain (FlexRAM PDRAM1) power up request. Self-clear bit. <strong>Writable but read will always return 0.</strong></td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Software can directly power up FlexRAM PDRAM1 by writing this bit, given PGC_MEGA_CTRL[PCR] is set and FlexRAM PDRAM1 has been powered down by setting MEGA_PDN_REQ.</td>
</tr>
<tr>
<td>3 0</td>
<td>— No Request</td>
</tr>
<tr>
<td>3 1</td>
<td>— Request power up sequence</td>
</tr>
<tr>
<td>2 MEGA_PDN_REQ</td>
<td>MEGA domain (FlexRAM PDRAM1) power down request. Self-clear bit. <strong>Writable but read will always return 0.</strong></td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Software can directly power down FlexRAM PDRAM1 by writing this bit, given PGC_MEGA_CTRL[PCR] is set.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 17.6.2 IRQ masking register 1 (GPC_IMR1)

IMR1 Register - masking of irq[31:0].

Address: 400F_4000h base + 8h offset = 400F_4008h

| Bit | 31  | 30   | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R/ W | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**GPC_IMR1 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMR1</td>
<td>IRQ[31:0] masking bits: 1-irq masked, 0-irq is not masked</td>
</tr>
</tbody>
</table>

### 17.6.3 IRQ masking register 2 (GPC_IMR2)

IMR2 Register - masking of irq[63:32].

Address: 400F_4000h base + 8h offset = 400F_400Ch

| Bit | 31  | 30   | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R/ W | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**GPC_IMR2 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMR2</td>
<td>IRQ[63:32] masking bits: 1-irq masked, 0-irq is not masked</td>
</tr>
</tbody>
</table>
17.6.4  IRQ masking register 3 (GPC_IMR3)

IMR3 Register - masking of irq[95:64].

Address: 400F_4000h base + 10h offset = 400F_4010h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | W  | IMR3 |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

GPC_IMR3 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMR3</td>
<td>IRQ[95:64] masking bits: 1-irq masked, 0-irq is not masked</td>
</tr>
</tbody>
</table>

17.6.5  IRQ masking register 4 (GPC_IMR4)

IMR4 Register - masking of irq[127:96].

Address: 400F_4000h base + 14h offset = 400F_4014h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | W  | IMR4 |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

GPC_IMR4 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMR4</td>
<td>IRQ[127:96] masking bits: 1-irq masked, 0-irq is not masked</td>
</tr>
</tbody>
</table>
17.6.6  IRQ status register 1 (GPC_ISR1)

ISR1 Register - status of irq [31:0].

Address: 400F_4000h base + 18h offset = 400F_4018h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

GPC_ISR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISR1</td>
<td>IRQ[31:0] status, read only</td>
</tr>
</tbody>
</table>

17.6.7  IRQ status register 2 (GPC_ISR2)

ISR2 Register - status of irq [63:32].

Address: 400F_4000h base + 1Ch offset = 400F_401Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

GPC_ISR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISR2</td>
<td>IRQ[63:32] status, read only</td>
</tr>
</tbody>
</table>
### 17.6.8 IRQ status register 3 (GPC_ISR3)

ISR3 Register - status of irq [95:64].

Address: 400F_4000h base + 20h offset = 400F_4020h

![ISR3 Register Diagram]

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISR3</td>
<td>IRQ[95:64] status, read only</td>
</tr>
</tbody>
</table>

### 17.6.9 IRQ status register 4 (GPC_ISR4)

ISR4 Register - status of irq [127:96].

Address: 400F_4000h base + 24h offset = 400F_4024h

![ISR4 Register Diagram]

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ISR4</td>
<td>IRQ[127:96] status, read only</td>
</tr>
</tbody>
</table>
17.6.10  IRQ masking register 5 (GPC_IMR5)

IMR5 Register - masking of irq[159:128].

Address: 400F_4000h base + 34h offset = 400F_4034h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

<table>
<thead>
<tr>
<th>Field</th>
<th>IMR5</th>
</tr>
</thead>
<tbody>
<tr>
<td>Description</td>
<td>IRQ[159:128] masking bits: 1-irq masked, 0-irq is not masked</td>
</tr>
</tbody>
</table>

17.6.11  IRQ status resister 5 (GPC_ISR5)

ISR5 Register - status of irq [159:128].

Address: 400F_4000h base + 38h offset = 400F_4038h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

<table>
<thead>
<tr>
<th>Field</th>
<th>ISR5</th>
</tr>
</thead>
<tbody>
<tr>
<td>Description</td>
<td>IRQ[159:128] status, read only</td>
</tr>
</tbody>
</table>

17.7  PGC Memory Map/Register Definition

The PGC registers can be accessed only in supervisor mode.
Attempts to access registers when not in supervisor mode or attempts to access an unimplemented address location might trigger a bus transfer error. In this case, software should take appropriate action (such as ignore the error, log the error, or initiate a soft reset).

All PGC registers are byte-accessible.

**NOTE**

PGC MEGA is used to control the power gate of PDRAM1 domain. PGC CPU is used to control the power gate of PDM7 domain (CM7 CPU). FlexRAM PDRAM0 domain is further controlled by GPC_CNTR[PDRAM0_PGE] bit.

### PGC memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400F_4220</td>
<td>PGC Mega Control Register (PGC_MEGA_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.7.1/1198</td>
</tr>
<tr>
<td>400F_4224</td>
<td>PGC Mega Power Up Sequence Control Register (PGC_MEGA_PUPSCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0F01h</td>
<td>17.7.2/1198</td>
</tr>
<tr>
<td>400F_4228</td>
<td>PGC Mega Pull Down Sequence Control Register (PGC_MEGA_PDNSCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0101h</td>
<td>17.7.3/1199</td>
</tr>
<tr>
<td>400F_422C</td>
<td>PGC Mega Power Gating Controller Status Register (PGC_MEGA_SR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.7.4/1200</td>
</tr>
<tr>
<td>400F_42A0</td>
<td>PGC CPU Control Register (PGC_CPU_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.7.5/1200</td>
</tr>
<tr>
<td>400F_42A4</td>
<td>PGC CPU Power Up Sequence Control Register (PGC_CPU_PUPSCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0F01h</td>
<td>17.7.6/1201</td>
</tr>
<tr>
<td>400F_42A8</td>
<td>PGC CPU Pull Down Sequence Control Register (PGC_CPU_PDNSCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0101h</td>
<td>17.7.7/1202</td>
</tr>
<tr>
<td>400F_42AC</td>
<td>PGC CPU Power Gating Controller Status Register (PGC_CPU_SR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>17.7.8/1202</td>
</tr>
</tbody>
</table>
17.7.1 PGC Mega Control Register (PGC_MEGA_CTRL)

The PGCR enables the response to a power-down request.

Address: 400F_4000h base + 220h offset = 400F_4220h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PCR</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

PGC_MEGA_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Power Control</td>
</tr>
<tr>
<td>PCR</td>
<td></td>
</tr>
</tbody>
</table>

**NOTE:** PCR must not change from power-down request (pdn_req) assertion until the target subsystem is completely powered up.

0 Do not switch off power even if pdn_req is asserted.

1 Switch off power when pdn_req is asserted.

17.7.2 PGC Mega Power Up Sequence Control Register (PGC_MEGA_PUPSCR)

The PUPSCR contains the power-up timing parameters.

Address: 400F_4000h base + 224h offset = 400F_4224h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### PGC_MEGA_PUPSCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13–8</td>
<td>SW2ISO</td>
</tr>
<tr>
<td>7–6</td>
<td>Reserved</td>
</tr>
<tr>
<td>SW</td>
<td></td>
</tr>
</tbody>
</table>

### 17.7.3 PGC Mega Pull Down Sequence Control Register (PGC_MEGA_PDNSCR)

The PDNSCR contains the power-down timing parameters.

Address: $400F_{4000h}$ base + $228h$ offset = $400F_{4228h}$

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14</td>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–8</td>
<td>ISO2SW</td>
<td>After asserting isolation, the PGC waits a number of IPG clocks equal to the value of ISO2SW before negating power toggle on/off signal (switch_b) to switch off power. <strong>NOTE:</strong> ISO2SW must not be programmed to zero.</td>
</tr>
<tr>
<td>7–6</td>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>ISO</td>
<td></td>
<td>After a power-down request (pdn_req assertion), the PGC waits a number of IPG clocks equal to the value of ISO before asserting isolation. <strong>NOTE:</strong> ISO must not be programmed to zero.</td>
</tr>
</tbody>
</table>
17.7.4 PGC Mega Power Gating Controller Status Register (PGC_MEGA_SR)

The SR contains the status parameters.

Address: 400F_4000h base + 22Ch offset = 400F_422Ch

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>PSR</td>
</tr>
</tbody>
</table>

31–1 Reserved: This read-only field is reserved and always has the value 0.

0 PSR: Power status. When in functional (or software-controlled debug) mode, PGC hardware sets PSR as soon as any of the power control output changes its state to one (isolation or power off occurs). Write one to clear this bit. Software should clear this bit after power up; otherwise, PSR continues to reflect the power status of the initial power down.

0 The target subsystem was not powered down for the previous power-down request.

1 The target subsystem was powered down for the previous power-down request.

17.7.5 PGC CPU Control Register (PGC_CPU_CTRL)

The PGCR enables the response to a power-down request.

Address: 400F_4000h base + 2A0h offset = 400F_42A0h

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td><strong>PCR</strong></td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>PCR must not change from power-down request (pdn_req) assertion until the target subsystem is completely powered up.</td>
</tr>
<tr>
<td>0</td>
<td>Do not switch off power even if pdn_req is asserted.</td>
</tr>
<tr>
<td>1</td>
<td>Switch off power when pdn_req is asserted.</td>
</tr>
</tbody>
</table>

#### 17.7.6 PGC CPU Power Up Sequence Control Register (PGC_CPU_PUPSCR)

The PUPSCR contains the power-up timing parameters.

**Address:** 400F_4000h base + 2A4h offset = 400F_42A4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13–8</td>
<td><strong>SW2ISO</strong></td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>SW2ISO must not be programmed to zero.</td>
</tr>
<tr>
<td>7–6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5–0</td>
<td><strong>SW</strong></td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>SW must not be programmed to zero. The PGC clock is generated from the IPG_CLK_ROOT, for frequency configuration of the IPG_CLK_ROOT. See Clock Controller Module (CCM).</td>
</tr>
</tbody>
</table>

---

**Reset**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>1</td>
</tr>
<tr>
<td>9</td>
<td>1</td>
</tr>
<tr>
<td>8</td>
<td>1</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>
17.7.7 PGC CPU Pull Down Sequence Control Register (PGC_CPU_PDNSCR)

The PDNSCR contains the power-down timing parameters.

Address: 400F_4000h base + 2A8h offset = 400F_42A8h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  |

PGC_CPU_PDNSCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>13–8</td>
<td>After asserting isolation, the PGC waits a number of IPG clocks equal to the value of ISO2SW before negating power toggle on/off signal (switch_b) to switch off power.</td>
</tr>
<tr>
<td>ISO2SW</td>
<td></td>
</tr>
<tr>
<td>7–6</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>ISO</td>
<td>After a power-down request (pdn_req assertion), the PGC waits a number of IPG clocks equal to the value of ISO before asserting isolation.</td>
</tr>
<tr>
<td>NOTE: ISO must not be programmed to zero.</td>
<td></td>
</tr>
</tbody>
</table>

17.7.8 PGC CPU Power Gating Controller Status Register (PGC_CPU_SR)

The SR contains the status parameters.

Address: 400F_4000h base + 2ACh offset = 400F_42ACh

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

PGC Memory Map/Register Definition

NXP Semiconductors
### PGC_CPU_SR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 0 PSR | Power status. When in functional (or software-controlled debug) mode, PGC hardware sets PSR as soon as any of the power control output changes its state to one (isolation or power off occurs). Write one to clear this bit. Software should clear this bit after power up; otherwise, PSR continues to reflect the power status of the initial power down.  
0 The target subsystem was not powered down for the previous power-down request.  
1 The target subsystem was powered down for the previous power-down request. |
Chapter 18
DCDC Converter (DCDC)

18.1 Chip-specific DCDC information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

18.2 Introduction

This module is a synchronous buck mode DCDC converter with a single output.

18.3 Features

The DCDC module includes the following features:

- Buck mode, a single output
- PSWITCH pin to control DCDC to enable or bypass DCDC
- Continuous conduction mode (CCM) and discontinuous conduction mode (DCM) operation
- Power-save mode operation
- Over current protection
• Over voltage protection
• Low voltage detection
• Internal oscillator to support the case when the crystal oscillator is not present as in the block diagram

18.4 Block diagram

Figure 18-1. DCDC block diagram

18.5 Functional description

The DCDC converter is a synchronous step down converter with a single output. In run mode, it can operate in the continuous conduction mode or discontinuous conduction mode, depending on the level of the load current. The load current level is about 50mA in a typical case, but it depends on the exact value of inductance, input voltage level and output target. If DCM mode is enabled, the DCDC can switch to DCM mode automatically if the current of the inductance goes to zero. The current does not need to be monitored to switch modes. Discontinuous conduction mode must be enabled by the register configuration.
The DCDC can also be configured to operate in power-save mode when the load current is less than 50 mA. During the power-save mode, the converter operates with reduced switching frequency in PFM mode and with a minimum quiescent current to maintain high efficiency.

DCM and CCM both work in run mode, in which the DCDC regulates the output continuously.

PFM is Pulse Frequency Modulation. In PFM, which is also named Pulse Mode, the DCDC is idle until the output drops to the low threshold. The DCDC then starts to charge the output to the high threshold. After it reaches the high threshold, the DCDC is idle again.

The DCDC also includes the following three protection functions:
- **Over current protection.** In run mode, DCDC will shut down when detecting abnormal large current in the P-type power switch. In power save mode, DCDC will stop charging inductor when detecting large current in the P-type power switch. The threshold is also different in run mode and in power save mode: the former is 1 A–2 A, and the latter is 200 mA–250 mA.
- **Over voltage protection.** DCDC will shut down when detecting the output voltage is too high.
- **Low voltage detection.** DCDC will shut down when detecting the input voltage is too low.

Another function of DCDC is that it can detect the peak current in the P-channel switch. When the peak current exceeds the threshold, DCDC will give an alert signal, and the threshold can be configured. By this way, DCDC can roughly detect the current loading.

## 18.6 Application information

### 18.6.1 Turn on DCDC

The below conditions must be met to enable the DCDC:
- Power snvs_1p0 and clk32k in snvs_1p0 are available
- DCDC_IN powered up
- After DCDC_IN powered up, delay about 1ms reset time to enable DCDC
- PSWITCH and PMIC_ON_REQ are both high to enable DCDC

The sequence is:
1. Power snvs1p0 and clk32k
2. PMIC_ON_REQ = 1
3. DCDC_IN powered up
4. Delay 1ms reset time
5. PSWITCH = 1
6. DCDC is now enabled

OR:
1. Power snvs_1p0 and clk32k
2. DCDC_IN powered up
3. Delay 1ms reset time
4. PSWITCH = 1
5. PMIC_ON_REQ = 1
6. DCDC is now enabled

Only if when PSWITCH and PMIC_ON_REQ are both high, DCDC can be enabled, PMIC_ON_REQ can be before or after DCDC_IN, just to assure delay about 1ms reset time to enable DCDC after DCDC_IN power up,

NOTE
For safety purpose, over-voltage detector needs to be enabled, i.e. PWD_HIGH_VOLT_DET=1'b0.

18.6.2 Target Voltage Adjustment

DISABLE_STEP=0x0

set TRG

NOTE
If setting disable_step=0, the overshoot will be low when changing the target, but the settling time is longer. If setting disable_step=1, the settling time is shorter, but the overshoot might be higher. The following settings can speed up the settling time: pwd_cmp_offset=0x0; loopctrl_en_rcscale=0x4.

18.6.3 Continuous Conduction Mode

pwd_zcd=0x1
pwd_cmp_offset=0x0
loopctrl_en_rcscale=0x3
18.6.4  Discontinuous Conduction Mode

pwd_zcd=0x0
pwd_cmp_offset=0x0
loopctrl_en_rcscale=0x4
DCM_SET_CTRL=1'b1

NOTE
Because discontinuous conduction mode can increase the efficiency of DCDC in case of low current loading, it is always recommended.

18.6.5  Power Saving Mode

Before entering this mode, set the target value of run mode the same as power saving mode, because DCDC will switch back to run mode if it detects the current loading is larger than about 50 mA (the threshold can be configured).

PMIC_STBY_REQ=0x1

18.7  Memory Map and register definition

This section includes the DCDC module memory map and detailed descriptions of all registers.

18.7.1  DCDC register descriptions

18.7.1.1  DCDC memory map

DCDC base address: 4008_0000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>DCDC Register 0 (REG0)</td>
<td>32</td>
<td>RW</td>
<td>1403_0111h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Memory Map and register definition

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>4h</td>
<td>DCDC Register 1 (REG1)</td>
<td>32</td>
<td>RW</td>
<td>111B_A29Ch</td>
</tr>
<tr>
<td>8h</td>
<td>DCDC Register 2 (REG2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0002h</td>
</tr>
<tr>
<td>Ch</td>
<td>DCDC Register 3 (REG3)</td>
<td>32</td>
<td>RW</td>
<td>0000_010Eh</td>
</tr>
</tbody>
</table>

18.7.1.2  DCDC Register 0 (REG0)

18.7.1.2.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG0</td>
<td>0h</td>
</tr>
</tbody>
</table>

18.7.1.2.2  Function

DCDC register 0

This register controls various high-level functions of the DCDC
### 18.7.1.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>STS_DC_OK</td>
<td>Reserved</td>
<td>XTAL_24M_OK</td>
<td>CURRENT_ALERT_RESET</td>
<td>XTALOK_DISABLE</td>
<td>PWD_CMP_OFFSET</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>LP_HIGH_HYS</td>
<td>LP_OVERLOAD_FREQ_SE</td>
<td>LP_OVERLOAD_THRSH</td>
<td>LP_OVERLOAD_DET</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 1 0 1 0 0 0 0 0 0 0 1 1

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1

### 18.7.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 STS_DC_OK     | DCDC Output OK  
This is the status bit indicates if the DCDC output voltage is stable. The lock time depends on the loading and the DCDC mode.  
0b - DCDC is settling  
1b - DCDC already settled |
| 30 __             | Reserved   |
| 29 XTAL_24M_OK   | 24M XTAL OK  
This bit determines if the DCDC uses the internal ring oscillator or the xtal 24M.  
0b - DCDC uses internal ring OSC  
1b - DCDC uses xtal 24M |
| 28 CURRENT_ALERT_RESET | Reset Current Alert Signal |

Table continues on the next page...
### Field | Function
--- | ---
This bit is the reset signal of current detector, if current loading is larger than the threshold of the current detector which is set by CUR_SNS_THRSH, the current detector will give out an alert signal, CURRENT_ALERT_RESET can reset the alert signal.  
- 0b - Current Alert Signal not reset  
- 1b - Current Alert Signal reset
27 | XTA Lopez_DISAB I LE  
Disable xtalok detection circuit  
This is a debug bit which should not be changed in real case. This bit disables and bypasses the clock 24 MHz reference clock detector.  
- 0b - Enable xtalok detection circuit  
- 1b - Disable xtalok detection circuit and always outputs OK signal "1"  
26 | PWD_CMP_OFFSET  
Power down output range comparator  
Output range comparator monitors the output voltage of DCDC. When the DCDC output voltage is out of range, this comparator will speed up DCDC control loop in an attempt to bring the DCDC output voltage back in range.  
PWD_CMP_OFFSET must be set to 0 (output range comparator on) if LOOPCTRL_EN_RCSCALE is to be used to speed up the transient response.  
- 0b - Output range comparator powered up  
- 1b - Output range comparator powered down
25 | Reserved
24 | Reserved
23 | Reserved
22 | Reserved
21 | LP_HIGH_HYS  
Low Power High Hysteric Value  
Adjust hysteretic value in low power from 12.5mV to 25mV  
- 0b - Adjust hysteretic value in low power to 12.5mV  
- 1b - Adjust hysteretic value in low power to 25mV
20 | LP_OVERLOAD_FREQ_SEL  
Low Power Overload Frequency Select  
The period of counting the charging times in power save mode  
- 0b - eight 32k cycle  
- 1b - sixteen 32k cycle
19-18 | LP_OVERLOAD_THRSH  
Low Power Overload Threshold  
The threshold of the counting number of charging times during the period that lp_overload_freq_sel sets in power save mode.  
- 00b - 32  
- 01b - 64  
- 10b - 16  
- 11b - 8
17 | PWD_HIGH_VOLT_DET  
Power Down High Voltage Detection  
Power down overvoltage detection comparator  
- 0b - Overvoltage detection comparator is enabled

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 16 1b - Overvoltage detection comparator is disabled | Low Power Overload Sense Enable
Enable the overload detection in power save mode, if current is larger than the overloading threshold (typical value is 50 mA), DCDC will switch to the run mode automatically
0b - Overload Detection in power save mode disabled
1b - Overload Detection in power save mode enabled |
| 15-12 Reserved |                                                                           |
| 11 0b - Low voltage detection comparator is enabled | Power Down Battery Detection Comparator
Set to "1" to power down the low voltage detection comparator
0b - Low voltage detection comparator is enabled
1b - Low voltage detection comparator is disabled |
| 10-9 Overcurrent Trigger Adjust | The threshold of over current detection in run mode and power save mode:
00b - In Run Mode, 1 A. In Power Save Mode, 0.25 A
01b - In Run Mode, 2 A. In Power Save Mode, 0.25 A
10b - In Run Mode, 1 A. In Power Save Mode, 0.2 A
11b - In Run Mode, 2 A. In Power Save Mode, 0.2 A |
| 8 0b - Overcurrent detection comparator is enabled | Power down overcurrent detection comparator
0b - Overcurrent detection comparator is enabled
1b - Overcurrent detection comparator is disabled |
| 7-5 Current Sense (detector) Threshold | Set the threshold of current detector, if the peak current of the inductor exceeds the threshold, the current detector will assert.
000b - 150 mA
001b - 250 mA
010b - 350 mA
011b - 450 mA
100b - 550 mA
101b - 650 mA |
| 4 0b - Current Detector powered up | Power down signal of the current detector.
Power down the control signal of the current detector.
0b - Current Detector powered up
1b - Current Detector powered down |
| 3 0b - Internal oscillator powered up | Power down internal osc
Only set this bit when 24 MHz crystal osc is available
0b - Internal oscillator powered up
1b - Internal oscillator powered down |
| 2 0b - DCDC uses internal ring oscillator | Select Clock
Select 24 MHz Crystal clock for DCDC, when DISABLE_AUTO_CLK_SWITCH is set.
If DISABLE_AUTO_CLK_SWITCH is set to 0 and 24M xtal is OK, the clock source will switch from internal ring OSC to 24M xtal automatically. If DISABLE_AUTO_CLK_SWITCH is set to 1, SEL_CLK will determine which clock source the DCDC uses: if SEL_CLK=0, DCDC will use internal ring OSC, if SEL_CLK=1, DCDC will use 24M xtal.
0b - DCDC uses internal ring oscillator
Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 1b - DCDC uses 24M xtal | Disable Auto Clock Switch<br>Disable automatic clock switch from internal oscill to xtal clock.  
                                  0b - If DISABLE_AUTO_CLK_SWITCH is set to 0 and 24M xtal is OK, the clock source will switch from internal ring OSC to 24M xtal automatically  
                                  1b - If DISABLE_AUTO_CLK_SWITCH is set to 1, SEL_CLK will determine which clock source the DCDC uses |
| 0b - PWD_ZCD          | Power Down Zero Cross Detection<br>Power down the zero cross detection function for discontinuous conductor mode.  
                                  0b - Zero cross detection function powered up  
                                  1b - Zero cross detection function powered down |

### 18.7.1.3 DCDC Register 1 (REG1)

#### 18.7.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG1</td>
<td>4h</td>
</tr>
</tbody>
</table>

#### 18.7.1.3.2 Function

DCDC register 1

This register controls various high-level functions of the DCDC
### 18.7.1.3.3 Diagram

The diagram shows the register bits layout for the DCDC Converter (DCDC) module of the i.MX RT1060 Processor Reference Manual. The register bits are divided into several fields, each with a specific function.

#### Bits 31-29
- **R**: Reserved
- **W**: VBG_TRIM

#### Bits 28-24
- **R**: LOOPCTRL_EN_HYST
- **W**: LOOPCTRL_HST_THRESH

#### Bits 23-19
- **R**: Reserved

#### Bits 18-16
- **W**: Reserved

#### Bits 15-11
- **R**: LP_CMP_ISRCC_SE
- **W**: REG_RLOAD_SE

#### Bits 10-6
- **R**: Reserved
- **W**: REG_FBK_SE

#### Bits 5-1
- **W**: Reserved

#### Bits 0
- **R**: Reset

### 18.7.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>28-24</td>
<td>VBG_TRIM</td>
</tr>
<tr>
<td><strong>Trim Bandgap Voltage</strong></td>
<td>Each bit encoding is 3mV step starting from 0.552V</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>LOOPCTRL_EN_HYST</td>
</tr>
<tr>
<td><strong>Enable Hysteresis</strong></td>
<td>Enable hysteresis in switching converter common mode analog comparators. This feature will improve transient supply ripple and efficiency</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>Increase Threshold Detection</td>
</tr>
<tr>
<td><strong>Increase the hysteresis threshold for the common mode analog comparator.</strong></td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Memory Map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOOPCTRL_HS T_THRESH</td>
<td>0b - Lower hysteresis threshold (about 2.5mV in typical, but this value can vary with PVT corners</td>
</tr>
<tr>
<td></td>
<td>1b - Higher hysteresis threshold (about 5mV in typical)</td>
</tr>
<tr>
<td>20-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13-12</td>
<td>Low Power Comparator Current Bias</td>
</tr>
<tr>
<td>LP_CMP_ISRC_SEL</td>
<td>Set the current bias of low power comparator</td>
</tr>
<tr>
<td></td>
<td>00b - 50 nA</td>
</tr>
<tr>
<td></td>
<td>01b - 100 nA</td>
</tr>
<tr>
<td></td>
<td>10b - 200 nA</td>
</tr>
<tr>
<td></td>
<td>11b - 400 nA</td>
</tr>
<tr>
<td>11-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>This controls the load resistor of the internal regulator of DCDC. The load resistor is connected by default to 1. To disconnect the load resistor, set this bit to 0.</td>
</tr>
<tr>
<td>REG_RLOAD_SW</td>
<td>The internal regulator is only powered on in RUN mode. In SUSPEND mode, the whole internal regulator is powered down.</td>
</tr>
<tr>
<td></td>
<td>If REG_RLOAD_SW is set to 1, the DCDC connects a resistor loading on the output of internal regulator when the regulator starts up. This is good for the stability of the regulator startup. Connecting this load resistor increases the current of DCDC_IN by 0.5mA.</td>
</tr>
<tr>
<td></td>
<td>After the STS_DC_OK asserts, this control bit can be set to 0 to disconnect the resistor. This saves the current caused by the resistor loading.</td>
</tr>
<tr>
<td></td>
<td>0b - Load resistor disconnected</td>
</tr>
<tr>
<td></td>
<td>1b - Load resistor connected</td>
</tr>
<tr>
<td>8-7</td>
<td>Select the feedback point of the internal regulator</td>
</tr>
<tr>
<td>REG_FBK_SEL</td>
<td>00b - The regulator outputs 1.0V with 1.2V reference voltage</td>
</tr>
<tr>
<td></td>
<td>01b - The regulator outputs 1.1V with 1.2V reference voltage</td>
</tr>
<tr>
<td></td>
<td>10b - The regulator outputs 1.0V with 1.3V reference voltage</td>
</tr>
<tr>
<td></td>
<td>11b - The regulator outputs 1.1V with 1.3V reference voltage</td>
</tr>
<tr>
<td>6-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 18.7.1.4 DCDC Register 2 (REG2)

#### 18.7.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG2</td>
<td>8h</td>
</tr>
</tbody>
</table>

#### 18.7.1.4.2 Function

DCDC register 2
This register controls various high-level functions of the DCDC

### 18.7.1.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

### 18.7.1.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved</td>
</tr>
<tr>
<td><em>DCM_SET_CTRL</em></td>
<td>DCM Set Control</td>
</tr>
<tr>
<td>28</td>
<td>Set high to improve the transition from heavy load to light load</td>
</tr>
<tr>
<td></td>
<td>When DCDC is working in DCM and DCM_SET_CTRL= 1, the DCDC will switch</td>
</tr>
<tr>
<td></td>
<td>to CCM to discharge the output when the overshoot on the output is</td>
</tr>
<tr>
<td></td>
<td>higher than the out-of-range threshold, by which the overshoot on the</td>
</tr>
<tr>
<td></td>
<td>transition can be improved. If DCM_SET_CTRL=0, the DCDC doesn’t support</td>
</tr>
<tr>
<td></td>
<td>this function.</td>
</tr>
<tr>
<td></td>
<td>DCM_SET_CTRL=1 is recommended when supporting DCM mode.</td>
</tr>
<tr>
<td>27</td>
<td>Disable Pulse Skip</td>
</tr>
<tr>
<td>DISABLE_PULSE_SKIP</td>
<td>Set to &quot;0&quot;: stop charging if the duty cycle is lower than what set by</td>
</tr>
<tr>
<td></td>
<td>NEGLIMIT_IN.</td>
</tr>
<tr>
<td></td>
<td>0b - DCDC will be idle to save current dissipation when the duty cycle</td>
</tr>
<tr>
<td></td>
<td>get to the low limit which is set by NEGLIMIT_IN.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### DCDC Register 3 (REG3)

#### Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG3</td>
<td>Ch</td>
</tr>
</tbody>
</table>
18.7.1.5.2 Function

DCDC register 3

This register controls various high-level functions of the DCDC

18.7.1.5.3 Diagram

![Diagram of DCDC register 3]

18.7.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Disable Step</td>
</tr>
<tr>
<td>DISABLE_STEP</td>
<td>Disable stepping for the output VDD_SOC of DCDC</td>
</tr>
<tr>
<td>29-25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Set DCDC clock to half frequency for continuous mode</td>
</tr>
<tr>
<td>MINPWR_DC_HALFCLK</td>
<td>0b - DCDC clock remains at full frequency for continuous mode</td>
</tr>
<tr>
<td>23-11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10-8</td>
<td>Low Power Target Value</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>TARGET_LP</td>
<td>Target value of standby (low power) mode</td>
</tr>
<tr>
<td></td>
<td>000b - 0.9 V</td>
</tr>
<tr>
<td></td>
<td>001b - 0.925 V</td>
</tr>
<tr>
<td></td>
<td>010b - 0.95 V</td>
</tr>
<tr>
<td></td>
<td>011b - 0.975 V</td>
</tr>
<tr>
<td></td>
<td>100b - 1.0 V</td>
</tr>
<tr>
<td>7-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-0</td>
<td>Target value of VDD_SOC</td>
</tr>
<tr>
<td>TRG</td>
<td>Target value of VDD_SOC, 25 mV each step</td>
</tr>
<tr>
<td></td>
<td>• 0x0: 0.8V</td>
</tr>
<tr>
<td></td>
<td>• 0xE: 1.15V</td>
</tr>
<tr>
<td></td>
<td>• 0x1F: 1.575V</td>
</tr>
</tbody>
</table>
Chapter 19
Temperature Monitor (TEMPMON)

19.1 Chip-specific TEMPMON information

Table 19-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

19.2 Overview

The temperature sensor module implements a temperature sensor/conversion function based on a temperature-dependent voltage to time conversion.

The module features alarm functions that can raise independent interrupt signals if the temperature is above two high-temperature thresholds and below a low temperature threshold. These temperature thresholds are programmable and designated as low, high and panic temperature. The panic threshold is a special programmable threshold in that if the temperature increases above this value and the temperature-panic-reset interrupt is enabled in the System Reset Controller, the hardware will assume that software no longer has control over the thermal situation and will initiate a reset of the chip.
In order to avoid false panic temperature initiated resets, the panic alarm will not fire until the temperature panic condition has been met for four consecutive conversion cycles. A self-repeating mode can also be programmed which executes a temperature sensing operation based on a programmed delay.

Since the high and low temperature thresholds are programmable, they form a sliding temperature bracket that can be tailored to the application’s needs. For example, at start-up software can set the low temperature threshold to the minimum temperature code and the high temperature threshold to a maximum operating temperature for the system.

The system can then use this module to monitor the on-die temperature and take appropriate actions such as throttling back the core frequency when a high temperature interrupt is set. After the high temperature interrupt is set then the system can program the low temperature threshold to a desired cool down temperature. The system would then switch to monitoring the low temperature alarm and wait for its interrupt to be set. With this scheme, after the low temperature interrupt is set then software could be assured that the temperature has cooled down to a safe level and the process could be repeated.

The high-level implementation of the temperature sensor is shown in the figure below.

**Figure 19-1. High Level Temp Sensor System Diagram**

As shown in the figure above, the temperature sensor uses and assumes that the bandgap reference, 480MHz PLL and 32KHz RTC modules are properly programmed and fully settled for correct operation.
19.3 Software Usage Guidelines

During normal system operation software can use the temperature sensor counter output (TEMP_CNT) in conjunction with the fused temperature calibration data to determine the on-die operational temperature or to set an over-temperature interrupt alarm to within a couple of °C.

Based on calibration, two sets of temperature and counter values will be available via fuses on the device. These data points will correspond to the points \((N_1, T_1)\) and \((N_2, T_2)\) in the curve below.

![Figure 19-2. Temperature Measurement Cycle](image)

After a temperature measurement cycle, software should use the calibration points in conjunction with the temperature code value in the TEMPMON_TEMPSENSE0[TEMP_CNT] bitfield to calculate the temperature for the device using the following equation:

\[
T_{\text{meas}} = T_2 - (N_{\text{meas}} - N_2) \times \left( \frac{(T_2 - T_1)}{(N_1 - N_2)} \right)
\]

Likewise, to determine the alarm counter value to be written in the TEMPMON_TEMPSENSE0 register for a temperature based interrupt, the above equation can be solved for the \(N_{\text{meas}}\) value that should be used based on the desired temperature trigger.

The temperature calibration point fuse values are available in the OCOTP_ANA1 register. The temperature calibration values are fused individually for each part in the product testing process. The fields of this register are described in the following table.
Table 19-2. OCOTP_ANA1 Temperature Sensor Calibration Data

<table>
<thead>
<tr>
<th>Bit Range</th>
<th>Bit Mask</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:20]</td>
<td>FFF0_0000h</td>
<td>ROOM_COUNT</td>
<td>Value of TEMPMON_TEMPSENSE0[TEMP_VALUE] after a measurement cycle at room temperature (25.0 °C).</td>
</tr>
<tr>
<td>[19:8]</td>
<td>000F_FF00h</td>
<td>HOT_COUNT</td>
<td>Value of TEMPMON_TEMPSENSE0[TEMP_VALUE] after a measurement cycle at the hot temperature, i.e. HOT_TEMP.</td>
</tr>
<tr>
<td>[7:0]</td>
<td>0000_00FFh</td>
<td>HOT_TEMP</td>
<td>The hot temperature test point. Each LSB equals 1 °C.</td>
</tr>
</tbody>
</table>

The points on the calibration curve are as follows.

- \((N_1, T_1) = (ROOM_COUNT, 25.0)\)
- \((N_2, T_2) = (HOT_COUNT, HOT_TEMP)\)
- \((N_{\text{meas}}, T_{\text{meas}}) = (\text{TEMP_CNT}, T_{\text{meas}})\)

Substituting the fields from OCOTP_ANA1 into the earlier equation results in the following:

\[
T_{\text{meas}} = \text{HOT_TEMP} - (N_{\text{meas}} - \text{HOT_COUNT}) \times \left(\frac{\text{HOT_TEMP} - 25.0}{\text{ROOM_COUNT} - \text{HOT_COUNT}}\right)
\]

19.4 TEMPMON Memory Map/Register Definition

TEMPMON memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/ page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_8180</td>
<td>Tempsensor Control Register 0 (TEMPMON_TEMPSENSE0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.1/1226</td>
</tr>
<tr>
<td>400D_8184</td>
<td>Tempsensor Control Register 0 (TEMPMON_TEMPSENSE0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.1/1226</td>
</tr>
<tr>
<td>400D_8188</td>
<td>Tempsensor Control Register 0 (TEMPMON_TEMPSENSE0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.1/1226</td>
</tr>
<tr>
<td>400D_818C</td>
<td>Tempsensor Control Register 0 (TEMPMON_TEMPSENSE0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.1/1226</td>
</tr>
<tr>
<td>400D_8190</td>
<td>Tempsensor Control Register 1 (TEMPMON_TEMPSENSE1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.2/1228</td>
</tr>
<tr>
<td>400D_8194</td>
<td>Tempsensor Control Register 1 (TEMPMON_TEMPSENSE1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.2/1228</td>
</tr>
<tr>
<td>400D_8198</td>
<td>Tempsensor Control Register 1 (TEMPMON_TEMPSENSE1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.2/1228</td>
</tr>
<tr>
<td>400D_819C</td>
<td>Tempsensor Control Register 1 (TEMPMON_TEMPSENSE1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>19.4.2/1228</td>
</tr>
<tr>
<td>400D_8290</td>
<td>Tempsensor Control Register 2 (TEMPMON_TEMPSENSE2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>19.4.3/1228</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## TEMPMON memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_8294</td>
<td>Tempsensor Control Register 2 (TEMPMON_TEMPSENSE2_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>19.4.3/1228</td>
</tr>
<tr>
<td>400D_8298</td>
<td>Tempsensor Control Register 2 (TEMPMON_TEMPSENSE2_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>19.4.3/1228</td>
</tr>
<tr>
<td>400D_829C</td>
<td>Tempsensor Control Register 2 (TEMPMON_TEMPSENSE2_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>19.4.3/1228</td>
</tr>
</tbody>
</table>
19.4.1 Tempsensor Control Register 0 (TEMPMON_TEMPSENSE0n)

This register defines the basic controls for the temperature sensor minus the frequency of automatic sampling which is defined in the tempsensor.

Address: 400D_8000h base + 180h offset + (4d × i), where i=0d to 3d
### TEMPMON_TEMPSENSE0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–20 ALARM_VALUE</td>
<td>This bit field contains the temperature count (raw sensor output) that will generate a high alarm when TEMP_CNT is smaller than this field.</td>
</tr>
<tr>
<td>19–8 TEMP_CNT</td>
<td>This bit field contains the last measured temperature count.</td>
</tr>
<tr>
<td>7</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved.</td>
</tr>
<tr>
<td>6</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved.</td>
</tr>
<tr>
<td>5–3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved.</td>
</tr>
<tr>
<td>2 FINISHED</td>
<td>Indicates that the latest temp is valid. This bit should be cleared by the sensor after the start of each measurement.</td>
</tr>
<tr>
<td>0</td>
<td>INVALID — Last measurement is not ready yet.</td>
</tr>
<tr>
<td>1</td>
<td>VALID — Last measurement is valid.</td>
</tr>
<tr>
<td>1 MEASURE_TEMP</td>
<td>Starts the measurement process. If the measurement frequency is zero in the TEMPSENSE1 register, this results in a single conversion.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
29.4.2 Tempsensor Control Register 1 (TEMPMON_TEMPSENSE1n)

This register defines the automatic repeat time of the temperature sensor.

Address: 400D_8000h base + 190h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>Measure_FREQ</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

**TEMPMON_TEMPSENSE1n field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>MEASURE_FREQ</td>
<td>This bits determines how many RTC clocks to wait before automatically repeating a temperature measurement. The pause time before remeasuring is the field value multiplied by the RTC period.</td>
</tr>
</tbody>
</table>

- 0x0000: Defines a single measurement with no repeat.
- 0x0001: Updates the temperature value at a RTC clock rate.
- 0x0002: Updates the temperature value at a RTC/2 clock rate.
- ...                        
- 0xFFFF: Determines a two second sample period with a 32.768KHz RTC clock. Exact timings depend on the accuracy of the RTC clock.

29.4.3 Tempsensor Control Register 2 (TEMPMONTEMPSENSE2n)

This register defines the automatic repeat time of the temperature sensor.

Address: 400D_8000h base + 290h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>Panic_ALARM_VALUE</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

\[\text{i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019}\]
### TEMPMON_TEMPSENSE2n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>27–16</td>
<td>PANIC_ALARM_VALUE This bit field contains the temperature count that will generate a panic interrupt when TEMP_CNT is smaller than this field.</td>
</tr>
<tr>
<td>15–12</td>
<td>LOW_ALARM_VALUE This bit field contains the temperature count that will generate a low alarm interrupt when the field is exceeded by TEMP_CNT.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Chapter 20
Secure Non-Volatile Storage (SNVS)

20.1 Chip-specific SNVS information

Table 20-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

NOTE
Tamper Detection feature and ZMK hardware programming are not applicable on this device.

20.2 SNVS introduction

SNVS is a companion module to the DCP module.

SNVS incorporates both security and non-security functionality. The SNVS non-security functionality is described in this document, but the SNVS security functionality is described only in the Security Reference Manual.

SNVS non-security functions:
- Realtime Counter (RTC) - a software accessible realtime counter
  - RTC can be set to the value in the SRTC
Periodic Interrupt - a hardware-generated interrupt that occurs periodically at software-specified frequency

General Purpose Register - a set of registers used to hold 128 bits of data specified by software
  - If the SNVS_LP power input is connected to an uninterrupted power supply, e.g. a coin cell battery, the GPR value is maintained when main SoC is powered off

Chip power-on/power-off - If the SNVS_LP power input is connected to an uninterrupted power supply and the Power On button input signal is connected to a power button external to the chip, logic within SNVS_LP can be used to wake the chip from a power down.

### 20.2.1 SNVS feature list

The following table summarizes the features of SNVS:

<table>
<thead>
<tr>
<th>Feature</th>
<th>Description</th>
<th>Links for Further Information</th>
</tr>
</thead>
<tbody>
<tr>
<td>Real time counter (RTC)</td>
<td>• The RTC is driven by a dedicated clock, which is off when the system power is down.</td>
<td>SNVS_HP Real Time Counter</td>
</tr>
<tr>
<td></td>
<td>• Programmable time alarm interrupt</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• Periodic interrupt can be generated with software-selected frequency.</td>
<td></td>
</tr>
<tr>
<td>Monotonic counter</td>
<td>• The monotonic counter can only increment.</td>
<td>Using the Monotonic Counter (MC)</td>
</tr>
<tr>
<td></td>
<td>• The monotonic counter does not rollover. Instead the monotonic counter logic issues an alarm if the monotonic counter reaches its maximum value.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• The monotonic counter value is marked as invalid if an SNVS tamper event is detected.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• If the SNVS_LP power input is connected to an uninterrupted power supply (see xref href=&quot;snvs_power_domains.dita#power_domains&quot;/&gt;, the monotonic counter value is retained even if the main chip is powered down.</td>
<td></td>
</tr>
<tr>
<td>General-purpose register</td>
<td>• The general-purpose register is available to software to store 128 bits of data.</td>
<td>Using the General-Purpose Register</td>
</tr>
<tr>
<td></td>
<td>• The general-purpose register is zeroized when a security violation is detected.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• If the SNVS_LP power input is connected to an uninterrupted power supply (see xref href=&quot;snvs_power_domains.dita#power_domains&quot;/&gt;, the general-purpose register value is retained even if the main chip is powered down.</td>
<td></td>
</tr>
<tr>
<td>Register access restrictions</td>
<td>• Registers can be programmed only when the SNVS is in functional state, i.e. not in scan mode.</td>
<td>privileged and non-privileged registers</td>
</tr>
<tr>
<td></td>
<td>• Some registers/values can be written only once per boot cycle.</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 20-2. SNVS feature list (continued)

<table>
<thead>
<tr>
<th>Feature</th>
<th>Description</th>
<th>Links for Further Information</th>
</tr>
</thead>
</table>
| Wakeup from power off    | • Input signal from off chip requests SNVS_LP to power on the main SoC (Assuming that the SNVS_LP power input is connected to an uninterrupted power supply (see SNVS power domains).)  
• Hardware debounces the input signal using software-specified signal bounce characteristics | LP Wake-Up Interrupt Enable   |

20.2.2 SNVS functional description

SNVS implements several non-security features that involve software interaction:
- reading or writing the Realtime Counter (RTC) (This is a non-privileged operation.) - software can also instruct SNVS to load the current SRTC value into the RTC
- reading or writing the General Purpose Register (GPR) (Note that there may be a significant delay when reading or writing registers in the LP section if the LP clock is different from the HP clock.)

The following sections describe in more detail the operation of SNVS.

20.3 SNVS Structure

SNVS is organized as two major sub-modules:
- Low-Power Section of SNVS (SNVS_LP)

The SNVS_LP section provides hardware that enables secure storage and protection of sensitive data. The SNVS module is designed to safely hold security-related data such as cryptographic key, time counter, monotonic counter, and general purpose security information.

The SNVS_LP block implements the following functional units:
- Control and Status Registers
- General Purpose Registers

When the LP section is powered by a backup battery the state of these registers is maintained even when the main chip power is off. (see SNVS power domains)

- High-Power Section of SNVS (SNVS_HP)

The SNVS_HP section contains all SNVS status and configuration registers. It implements all features that enable system communication and provisioning of the SNVS_LP section.
The SNVS_HP provides an interface between SNVS_LP and the rest of the system.

The SNVS_HP block implements the following functional units:
- IP Bus Interface
- SNVS_LP Interface
- Zeroizable Master Key Programming Mechanism
- Real Time Counter with Alarm Control and Status Registers
- Control and status registers

SNVS_HP is in the chip's power supply domain and thus receives power along with the rest of the chip.

The following figure illustrates the structure of SNVS.
20.3.1 SNVS power domains

In some versions of SNVS (including this version), the LP (Low Power) section is implemented in an independent power domain from the HP (High Power) section, and most other logic on the chip. Throughout the SNVS documentation whenever mention is made of "always-on" logic, this assumes a version of SNVS that implements an independent power domain for the LP section, and that the power for this section is supplied by an uninterrupted power supply. The purpose for the independent power domain is so that data can be retained and certain logic can remain functional even when the main chip logic is powered down. But this is possible only if the LP domain remains powered via an uninterrupted power supply when the main chip power domain is powered off. Usually this uninterrupted power supply would be a coin-cell battery, with possibly some power management logic to power the LP section from main power (and perhaps recharge the coin cell battery) when main power is on, and switch to coin-cell power when the main power is off. In versions of SNVS with an independent LP power domain the LP section can be electrically isolated from the rest of the chip logic to ensure that its logic does not get corrupted when the main chip is powered down. If the battery runs down or is removed, an LP POR will occur when the LP section next powers up. Note that some OEMs may choose to connect LP power to HP/main chip power and dispense with a coin cell battery. In that case the SNVS will operate the same as an SNVS without an independent LP power domain. No state will be retained in the LP section when the chip is powered down, and an LP POR will occur whenever there is an HP POR.

20.3.2 SNVS clock sources

The SNVS has the following clock sources:

- System peripheral clock input. This clock is used by the SNVS's internal logic, for example, the Security State Machine. This clock can be gated outside of the module when the SNVS indicates that it is not in use.
- HP RTC clock. This clock is used by SNVS_HP real-time counter. This clock does not need to be synchronous with other clocks.

20.4 Runtime Procedures

SNVS implements a number of features that are intended to be accessed by software at runtime (as opposed to accessed at boot time). These features include:

- Real Time Clock (see SNVS_HP Real Time Counter)
- Secure Real Time Clock (see SNVS_LP Secure Real Time Counter (SRTC))
• General Purpose Register (see Using the General-Purpose Register)
• Monotonic Counter (see Using the Monotonic Counter (MC))

Procedures for using these features are described in the following sections.

20.4.1 Using SNVS Timer Facilities

SNVS incorporates timer facilities that can optionally generate an interrupt at a specified time. As described in the following sections, SNVS_HP incorporates a Real Time Counter that is available for general use, and SNVS_LP incorporates a Secure Real Time Counter intended for security applications.

20.4.1.1 SNVS_HP Real Time Counter

SNVS_HP implements a real time counter that can be read or written by any application; it has no privileged software access restrictions. When the chip is powered down the RTC is not active and it is reset at chip POR. The RTC can be used to generate a functional interrupt request either at a specific time, or at a specific frequency, or both. To generate an interrupt request at a specific time HPTA_EN is set to 0, the desired time is written to HPTA_MS and HPTA_LS and then HPTA_EN is set to 1. HPTA_EN, HPTA_MS and HPTA_LS can be written by any software that has access to SNVS registers; there are no privileged access restrictions. The counter can be synchronized to the SNVS_LP SRTC by writing to the HP_TS bit of SNVS_HP Control Register. This is particularly useful if the SNVS_LP is powered from an uninterrupted power source (e.g. a coin cell battery) because the RTC can then be set from a chip-internal time source.

20.4.1.2 RTC/SRTC control bits setting

All SNVS registers are programmed from the register bus, consequently any software-initiated changes are synchronized with the IP clock. Several registers can also change synchronously with the RTC/SRTC clock after they are programmed. To avoid IP clock and RTC/SRTC clock synchronization issues, the following values can be changed only when the corresponding function is disabled.

<table>
<thead>
<tr>
<th>Function</th>
<th>Value/register</th>
<th>Control bit setting</th>
</tr>
</thead>
<tbody>
<tr>
<td>HP section</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HP Real Time Counter</td>
<td>HPRTCMR and HPRTCLR Registers</td>
<td>RTC_EN = 0 : HPRTCMR/HPRTCLR can be programmed</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 20-3. RTC/SRTC synchronized values list (continued)

<table>
<thead>
<tr>
<th>Function</th>
<th>Value/register</th>
<th>Control bit setting</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>RTC_EN = 1 : HPRTCNR/HPRTCLR cannot be programmed</td>
</tr>
<tr>
<td>HP Time Alarm</td>
<td>HPTAMR and HPTALR Registers</td>
<td>HPTA_EN = 0 : HPTAMR/HPTALR can be programmed</td>
</tr>
<tr>
<td></td>
<td></td>
<td>HPTA_EN = 1 : HPTAMR/HPTALR cannot be programmed</td>
</tr>
<tr>
<td>LP section</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LP Secure Real Time Counter</td>
<td>LPRTCMR and LPRTCLR Registers</td>
<td>SRRTC_ENV = 0 : LPRTCMR/LPRTCLR can be programmed</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SRRTC_ENV = 1 : LPRTCMR/LPRTCLR cannot be programmed</td>
</tr>
<tr>
<td>LP Time Alarm</td>
<td>LPTAR Register</td>
<td>LPTA_EN = 0 : LPTAR can be programmed</td>
</tr>
<tr>
<td></td>
<td></td>
<td>LPTA_EN = 1 : LPTAR cannot be programmed</td>
</tr>
</tbody>
</table>

Use the following steps to program synchronized values:

1. Check the enable bit value. If set, clear it.
2. Verify that the enable bit is cleared. There are two reasons to verify the enable bit's setting:
   - Enable bit clearing does not happen immediately; it takes three IP clock cycles and two RTC/SRTC clock cycles to change the enable bit's value.
   - If the enable bit is locked for programming, it cannot be cleared.
3. Program the desired value.
4. Set the enable bit; it takes three IP clock cycles and two RTC/SRTC clock cycles for the bit to set.

**NOTE**

Incrementing the value programmed into RTC/SRTC registers by two compensates for the two RTC/SRTC clock cycle delay that is required to enable the counter.

### 20.4.1.3 Reading RTC and SRTC values

Software should follow the following procedure to ensure that it has read correct data from the RTC (HPRTCNR and HPRTCLR) and SRTC (LPSRTCMR and LPSRTCLR) registers:
• Read the most-significant half and the least-significant half of the RTC/SRTC and then read both halves again. If the values read are the same both times, the value is correct.
• If the two consecutive pairs of reads yield different results, perform two more reads.

The worst case scenario may require three sessions of two consecutive pairs of reads. There are several reasons that the values may be incorrectly read initially:
• Synchronization issues between the RTC/SRTC clock and the system clock
• Since the counter continues to increment, there may be a carry from the least-significant 32-bits to the most-significant bits in between reading the two halves of the counter

20.4.2 Using Other SNVS Registers

The sections below describe how to use the General Purpose Register.Monotonic Counter. The sections below describe how to use the General Purpose Register and the Monotonic Counter.

20.4.2.1 Using the General-Purpose Register

SNVS implements a 128-bit general-purpose register allows software to store a small amount of data. To maintain backward compatibility with versions of SNVS that implement only a 32-bit general purpose register, the most-significant word of the general purpose register is aliased to the legacy address. The data in the GPR will be retained during system power-down mode as long as the SNVS_LP remains powered by an uninterrupted power source (e.g. coin cell battery).

20.5 Reset and Initialization of SNVS

SNVS is implemented in two sections (HP and LP) that both must be initialized by software following POR. If the SNVS_LP is powered by an uninterrupted power source that is separate from main SoC power, then SNVS can operate in either of two modes, depending upon whether the main SoC power is on or off. During main SoC power-down SNVS_HP is powered-down, but SNVS_LP is powered from the backup power supply and is electrically isolated from the rest of the chip. In this mode SNVS_LP keeps its registers' values and monitors the SNVS_LP tamper detection inputs, but the LP registers cannot be read or written. During main SoC power-up the isolation of SNVS_LP is disabled and both SNVS_HP and SNVS_LP are powered from the main SoC power.
Both LP and HP registers can be read and written (locks and privilege modes permitting). Signals between the SNVS_HP and SNVS_LP sections are enabled and all SNVS functions are operational.

Since the HP and LP sections reside in different power domains, the POR for the two sections can occur at different times. If the SNVS_LP section remains powered by an uninterrupted power source when the main SoC power is off, SNVS_LP is initialized rarely, typically once when the device is first powered on and again whenever the battery is replaced. During main SoC power-up the isolation of SNVS_LP is disabled and both SNVS_HP and SNVS_LP are powered from the main SoC power. Signals between the SNVS_HP and SNVS_LP sections are enabled and all SNVS functions are operational. The SNVS_HP section is powered from the main SoC power, so it must be initialized whenever the device is powered on. If the SNVS_LP section is powered from the main SoC power rather than from an uninterrupted power source, the SNVS_LP section must also be initialized at SoC POR.

Initializing the LP section The following steps should be completed to properly initialize the SNVS LP section (required only on LP POR, i.e. when the battery is replaced):

1. Program the Power Glitch Detector and clear the power glitch record in the LP status register
2. If the SRTC will be used, set the Secure Real Time Clock
3. If the ZMK will be used, provision the ZMK
4. If the Monotonic Counter will be used, burn an additional Monotonic Counter Era bit in the fuse bank and reset the Monotonic Counter

Initializing the HP section The following steps should be completed to properly initialize the SNVS HP section (following successful completion of secure boot):

1. Perform normal or secure boot to put the SNVS into a functional state (Non-secure, Trusted, Secure)
2. At SNVS_LP POR a power glitch violation will be asserted. Therefore at the first HP POR following an LP POR software should write the proper initialization value (41736166h) into the LPPGDR and clear the power glitch record in the LP status register. See Power glitch detector (PGD) for more details.
3. Transition SSM from trusted state to secure state (if not already done by HAB).
4. Enable security violations and interrupts in HPSVCR and HPSICR registers
5. Program SNVS general functions/configurations
6. Select Master Key (OTPMK, ZMK or XOR of the two. Default is OTPMK.)
7. Set lock bits. The ms bit of the SNVS_HP lock register should be set before starting any functional operation. Setting this bit prevents further changes to the Master Key selection.
20.5.1 Initialization Checklists

SNVS is implemented in two sections (HP and LP) that both must be initialized by software following POR. If the SNVS_LP is powered by an uninterrupted power source that is separate from main SoC power, then SNVS can operate in either of two modes, depending upon whether the main SoC power is on or off. During main SoC power-down SNVS_HP is powered-down, but SNVS_LP is powered from the backup power supply and is electrically isolated from the rest of the chip. In this mode SNVS_LP keeps its registers' values and monitors the SNVS_LP tamper detection inputs, but the LP registers cannot be read or written. During main SoC power-up the isolation of SNVS_LP is disabled and both SNVS_HP and SNVS_LP are powered from the main SoC power. Both LP and HP registers can be read and written (locks and privilege modes permitting). Signals between the SNVS_HP and SNVS_LP sections are enabled and all SNVS functions are operational.

Since the HP and LP sections reside in different power domains, the POR for the two sections can occur at different times. If the SNVS_LP section remains powered by an uninterrupted power source when the main SoC power is off, SNVS_LP is initialized rarely, typically once when the device is first powered on and again whenever the battery is replaced. During main SoC power-up the isolation of SNVS_LP is disabled and both
SNVS_HP and SNVS_LP are powered from the main SoC power. Signals between the
SNVS_HP and SNVS_LP sections are enabled and all SNVS functions are operational.
The SNVS_HP section is powered from the main SoC power, so it must be initialized
whenever the device is powered on. If the SNVS_LP section is powered from the main
SoC power rather than from an uninterrupted power source, the SNVS_LP section must
also be initialized at SoC POR.

20.6 SNVS register descriptions

This section contains detailed register descriptions for the SNVS registers. Each
description includes a standard register diagram and register table. The register table
provides detailed descriptions of the register bit and field functions, in bit order.

SNVS registers consist of two types:

- Privileged read/write accessible
- Non-privileged read/write accessible

Privileged read/write accessible registers can only be accessed for read/write by
privileged software. Unauthorized write accesses are ignored, and unauthorized read
accesses return zero. Non-privileged software can access privileged access registers when
the non-privileged software access enable bit is set in the SNVS_HP Command Register.

- Non-Secure
- Trusted
- Secure

Non-privileged read/write accessible registers are read/write accessible by any software.
The LP register values are set only on LP POR and are unaffected by System (HP) POR.
The HP registers are set only on System POR and are unaffected by LP POR.

The following table shows the SNVS main memory map.

NOTE
For more information on security-related bitfields, see the
Security Reference Manual for this device.
20.6.1  SNVS Memory map

SNVS base address: 400D_4000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>SNVS_HP Lock Register (HPLR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>4h</td>
<td>SNVS_HP Command Register (HPCOMR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8h</td>
<td>SNVS_HP Control Register (HPCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>SNVS_HP Status Register (HPSR)</td>
<td>32</td>
<td>RW</td>
<td>8000_0000h</td>
</tr>
<tr>
<td>24h</td>
<td>SNVS_HP Real Time Counter MSB Register (HPRTCMR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>28h</td>
<td>SNVS_HP Real Time Counter LSB Register (HPRTCLR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>2Ch</td>
<td>SNVS_HP Time Alarm MSB Register (HPTAMR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>30h</td>
<td>SNVS_HP Time Alarm LSB Register (HPTALR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>34h</td>
<td>SNVS_LP Lock Register (LPLR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>38h</td>
<td>SNVS_LP Control Register (LPCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0020h</td>
</tr>
<tr>
<td>4Ch</td>
<td>SNVS_LP Status Register (LPSR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>5Ch</td>
<td>SNVS_LP Secure Monotonic Counter MSB Register (LPSMCMR)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>60h</td>
<td>SNVS_LP Secure Monotonic Counter LSB Register (LPSMCLR)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>68h</td>
<td>SNVS_LP General Purpose Register 0 (legacy alias) (LPGPR0_legacy_alias)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>90h - 9Ch</td>
<td>SNVS_LP General Purpose Registers 0 .. 3 (LPGPR0_alias - LPGPR3_alias)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>100h - 10Ch</td>
<td>SNVS_LP General Purpose Registers 0 .. 3 (LPGPR0 - LPGPR3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>BF8h</td>
<td>SNVS_HP Version ID Register 1 (HPVIDR1)</td>
<td>32</td>
<td>RO</td>
<td>003E_0104h</td>
</tr>
<tr>
<td>BFCh</td>
<td>SNVS_HP Version ID Register 2 (HPVIDR2)</td>
<td>32</td>
<td>RO</td>
<td>0600_0000h</td>
</tr>
</tbody>
</table>

20.6.2  SNVS_HP Lock Register (HPLR)

20.6.2.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPLR</td>
<td>0h</td>
</tr>
</tbody>
</table>
20.6.2.2 Function

The SNVS_HP Lock Register contains lock bits for the SNVS registers. This is a privileged write register.

20.6.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

20.6.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>Reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>Reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>Reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>Reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>23-19</td>
<td>Reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-10</td>
<td>Reserved.</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>General Purpose Register Soft Lock&lt;br&gt;When set, prevents any writes to the GPR. Once set, this bit can only be reset by the system reset. 0b - Write access is allowed 1b - Write access is not allowed</td>
</tr>
<tr>
<td>4</td>
<td>Monotonic Counter Soft Lock&lt;br&gt;When set, prevents any writes (increments) to the MC Registers and MC_ENV bit. Once set, this bit can only be reset by the system reset. 0b - Write access (increment) is allowed 1b - Write access (increment) is not allowed</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 20.6.3 SNVS_HP Command Register (HPCOMR)
20.6.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPCOMR</td>
<td>4h</td>
</tr>
</tbody>
</table>

20.6.3.2 Function

The SNVS_HP Command Register contains the command, configuration, and control bits for the SNVS block. This is a privileged write register.

20.6.3.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>NPSWA_EN</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>LP_SW</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

20.6.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Non-Privileged Software Access Enable</td>
</tr>
<tr>
<td>NPSWA_EN</td>
<td>When set, allows non-privileged software to access all SNVS registers, including those that are privileged software read/write access only.</td>
</tr>
<tr>
<td></td>
<td>0 Only privileged software can access privileged registers</td>
</tr>
<tr>
<td></td>
<td>1 Any software can access privileged registers</td>
</tr>
<tr>
<td>30-20</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>LP_SWR_DIS&lt;br&gt;LP Software Reset Disable&lt;br&gt;When set, disables the LP software reset. Once set, this bit can only be reset by the system reset.&lt;br&gt;0b - LP software reset is enabled&lt;br&gt;1b - LP software reset is disabled</td>
</tr>
<tr>
<td>4</td>
<td>LP_SWR&lt;br&gt;LP Software Reset&lt;br&gt;When set to 1, the registers in the SNVS_LP section are reset.&lt;br&gt;0b - No Action&lt;br&gt;1b - Reset LP section</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
20.6.4 SNVS_HP Control Register (HPCR)

20.6.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPCR</td>
<td>8h</td>
</tr>
</tbody>
</table>

20.6.4.2 Function

The SNVS_HP Control Register contains various control bits of the HP section of SNVS. This is not a privileged write register.

20.6.4.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bits</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

20.6.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field | Function
--- | ---
27 | Button interrupt mask. This bit is used to mask the ipi_snvs_btn_int_b (button) interrupt request.  
   | 0: Interrupt disabled  
   | 1: Interrupt enabled
26-24 | Button Configuration. This field is used to configure which feature of the button (BTN) input signal constitutes “active”.  
   | 000: Button signal is active high  
   | 001: Button signal is active low  
   | 010: Button signal is active on the falling edge  
   | 011: Button signal is active on the rising edge  
   | 100: Button signal is active on any edge  
   | All other patterns are reserved.
23-17 | Reserved.
16 | Reserved
15 | Reserved.
14-10 | HP Calibration Value  
   | Defines signed calibration value for the HP Real Time Counter. This field can be programmed only when RTC Calibration is disabled (HPCALB_EN is not set). This is a 5-bit 2's complement value, hence the allowable calibration values are in the range from -16 to +15 counts per 32768 ticks of the counter.  
   | 00000b - +0 counts per each 32768 ticks of the counter  
   | 00001b - +1 counts per each 32768 ticks of the counter  
   | 00010b - +2 counts per each 32768 ticks of the counter  
   | 01111b - +15 counts per each 32768 ticks of the counter  
   | 10000b - -16 counts per each 32768 ticks of the counter  
   | 10001b - -15 counts per each 32768 ticks of the counter  
   | 11110b - -2 counts per each 32768 ticks of the counter  
   | 11111b - -1 counts per each 32768 ticks of the counter
9 | Reserved.
8 | HP Real Time Counter Calibration Enabled  
   | Indicates that the time calibration mechanism is enabled.  
   | 0b - HP Timer calibration disabled  
   | 1b - HP Timer calibration enabled
7-4 | Periodic Interrupt Frequency  
   | Defines frequency of the periodic interrupt. The interrupt is generated when a zero-to-one or one-to-zero transition occurs on the selected bit of the HP Real Time Counter and Real Time Counter and Periodic Interrupt are both enabled (RTC_EN and PI_EN are set). It is recommended to program this field when Periodic Interrupt is disabled (PI_EN is not set). The possible frequencies are:  
   | 0000b - bit 0 of the HPRTCLR is selected as a source of the periodic interrupt  
   | 0001b - bit 1 of the HPRTCLR is selected as a source of the periodic interrupt  
   | 0010b - bit 2 of the HPRTCLR is selected as a source of the periodic interrupt

*Table continues on the next page...*
### Field | Function
--- | ---
0011b | bit 3 of the HPRTCLR is selected as a source of the periodic interrupt
0100b | bit 4 of the HPRTCLR is selected as a source of the periodic interrupt
0101b | bit 5 of the HPRTCLR is selected as a source of the periodic interrupt
0110b | bit 6 of the HPRTCLR is selected as a source of the periodic interrupt
0111b | bit 7 of the HPRTCLR is selected as a source of the periodic interrupt
1000b | bit 8 of the HPRTCLR is selected as a source of the periodic interrupt
1001b | bit 9 of the HPRTCLR is selected as a source of the periodic interrupt
1010b | bit 10 of the HPRTCLR is selected as a source of the periodic interrupt
1011b | bit 11 of the HPRTCLR is selected as a source of the periodic interrupt
1100b | bit 12 of the HPRTCLR is selected as a source of the periodic interrupt
1101b | bit 13 of the HPRTCLR is selected as a source of the periodic interrupt
1110b | bit 14 of the HPRTCLR is selected as a source of the periodic interrupt
1111b | bit 15 of the HPRTCLR is selected as a source of the periodic interrupt

<table>
<thead>
<tr>
<th>3</th>
<th>HP Periodic Interrupt Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>PI_EN</td>
<td>The periodic interrupt can be generated only if the HP Real Time Counter is enabled.</td>
</tr>
<tr>
<td>0b</td>
<td>HP Periodic Interrupt is disabled</td>
</tr>
<tr>
<td>1b</td>
<td>HP Periodic Interrupt is enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>2</th>
<th>Disable periodic interrupt in the functional interrupt</th>
</tr>
</thead>
<tbody>
<tr>
<td>DIS_PI</td>
<td>0b</td>
</tr>
<tr>
<td>1b</td>
<td>Disable periodic interrupt in the function interrupt</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>1</th>
<th>HP Time Alarm Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPTA_EN</td>
<td>When set, the time alarm interrupt is generated if the value in the HP Time Alarm Registers is equal to the value of the HP Real Time Counter.</td>
</tr>
<tr>
<td>0b</td>
<td>HP Time Alarm Interrupt is disabled</td>
</tr>
<tr>
<td>1b</td>
<td>HP Time Alarm Interrupt is enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0</th>
<th>HP Real Time Counter Enable. This bit syncs with the 32KHz clock. It won't update with the bus clock.</th>
</tr>
</thead>
<tbody>
<tr>
<td>RTC_EN</td>
<td>0b</td>
</tr>
<tr>
<td>1b</td>
<td>RTC is enabled</td>
</tr>
</tbody>
</table>

### 20.6.5 SNVS_HP Status Register (HPSR)

#### 20.6.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPSR</td>
<td>14h</td>
</tr>
</tbody>
</table>

#### 20.6.5.2 Function

The HP Status Register reflects the internal state of the SNVS. This is *not* a privileged write register.
20.6.5.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BI</td>
<td>BTN</td>
<td>Reserved</td>
<td>LPDIS</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>PI</td>
<td>W1C</td>
<td>HPTA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

1. The value of Low Power Disable is determined by the no_battery input signal to SNVS.

20.6.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26-25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Button Interrupt</td>
</tr>
<tr>
<td>BI</td>
<td>Signal ipi_snvs_btn_int_b was asserted.</td>
</tr>
<tr>
<td>6</td>
<td>Button</td>
</tr>
<tr>
<td>BTN</td>
<td>Value of the BTN input. This is the external button used for PMIC control.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0: BTN not pressed</td>
<td></td>
</tr>
<tr>
<td>1: BTN pressed</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>Reserved.</td>
</tr>
<tr>
<td>4</td>
<td>Low Power Disable</td>
</tr>
<tr>
<td>LPDIS</td>
<td>If 1, the low power section has been disabled by means of an input signal to SNVS.</td>
</tr>
<tr>
<td>3-2</td>
<td>Reserved.</td>
</tr>
<tr>
<td>1</td>
<td>Periodic Interrupt</td>
</tr>
<tr>
<td>PI</td>
<td>Indicates that periodic interrupt has occurred since this bit was last cleared.</td>
</tr>
<tr>
<td>0b - No periodic interrupt occurred.</td>
<td></td>
</tr>
<tr>
<td>1b - A periodic interrupt occurred.</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HP Time Alarm</td>
</tr>
<tr>
<td>HPTA</td>
<td>Indicates that the HP Time Alarm has occurred since this bit was last cleared.</td>
</tr>
<tr>
<td>0b - No time alarm interrupt occurred.</td>
<td></td>
</tr>
<tr>
<td>1b - A time alarm interrupt occurred.</td>
<td></td>
</tr>
</tbody>
</table>

20.6.6 SNVS_HP Real Time Counter MSB Register (HPRTCMR)

20.6.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPRTCMR</td>
<td>24h</td>
</tr>
</tbody>
</table>

20.6.6.2 Function

The SNVS_HP Real Time Counter MSB register contains the 15 most-significant bits of the HP Real Time Counter. This is not a privileged write register.
20.6.6.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reserved

RTC

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

20.6.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>14-0</td>
<td>HP Real Time Counter</td>
</tr>
<tr>
<td>RTC</td>
<td>The most-significant 15 bits of the RTC. This register can be programmed only when RTC is not active (RTC_EN bit is not set).</td>
</tr>
</tbody>
</table>

20.6.7 SNVS_HP Real Time Counter LSB Register (HPRTCLR)

20.6.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPRTCLR</td>
<td>28h</td>
</tr>
</tbody>
</table>

20.6.7.2 Function

The SNVS_HP Real Time Counter LSB register contains the 32 least-significant bits of the HP real time counter. This is not a privileged write register.
20.6.7.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

20.6.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>HP Real Time Counter</td>
</tr>
<tr>
<td>RTC</td>
<td>least-significant 32 bits. This register can be programmed only when RTC is not active (RTC_EN bit is not set).</td>
</tr>
</tbody>
</table>

20.6.8 SNVS_HP Time Alarm MSB Register (HPTAMR)

20.6.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPTAMR</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

20.6.8.2 Function

The SNVS_HP Time Alarm MSB register contains the most-significant bits of the SNVS_HP Time Alarm value. This is not a privileged write register.


20.6.8.3  **Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

20.6.8.4  **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved.</td>
</tr>
<tr>
<td>14-0</td>
<td>HP Time Alarm, most-significant 15 bits.</td>
</tr>
<tr>
<td>HPTA_MS</td>
<td>This register can be programmed only when HP time alarm is disabled (HPTA_EN bit is not set).</td>
</tr>
</tbody>
</table>

20.6.9  **SNVS_HP Time Alarm LSB Register (HPTALR)**

20.6.9.1  **Offset**

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPTALR</td>
<td>30h</td>
</tr>
</tbody>
</table>

20.6.9.2  **Function**

The SNVS_HP Time Alarm LSB register contains the 32 least-significant bits of the SNVS_HP Time Alarm value. This is not a privileged write register.
### 20.6.9.3 Diagram

#### Bits

<table>
<thead>
<tr>
<th></th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HPTA_LS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HPTA_LS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 20.6.9.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>HP Time Alarm, 32 least-significant bits.</td>
</tr>
<tr>
<td>HPTA_LS</td>
<td>This register can be programmed only when HP time alarm is disabled (HPTA_EN bit is not set).</td>
</tr>
</tbody>
</table>

### 20.6.10 SNVS_LP Lock Register (LPLR)

#### 20.6.10.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPLR</td>
<td>34h</td>
</tr>
</tbody>
</table>

#### 20.6.10.2 Function

The SNVS_LP Lock Register contains lock bits for the SNVS_LP registers. This is a privileged write register.
### 20.6.10.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 20.6.10.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved.</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>Reserved.</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>Reserved.</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>Reserved.</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>Reserved.</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Reserved.</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>23-10</td>
<td>Reserved.</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>5</td>
</tr>
<tr>
<td>GPR_HL</td>
<td>General Purpose Register Hard Lock</td>
</tr>
<tr>
<td></td>
<td>When set, prevents any writes to the GPR. Once set, this bit can only be reset by the LP POR.</td>
</tr>
<tr>
<td></td>
<td>0b - Write access is allowed.</td>
</tr>
<tr>
<td></td>
<td>1b - Write access is not allowed.</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>MC_HL</td>
<td>Monotonic Counter Hard Lock</td>
</tr>
<tr>
<td></td>
<td>When set, prevents any writes (increments) to the MC Registers and MC_ENV bit. Once set, this bit can only be reset by the LP POR.</td>
</tr>
<tr>
<td></td>
<td>0b - Write access (increment) is allowed.</td>
</tr>
<tr>
<td></td>
<td>1b - Write access (increment) is not allowed.</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 20.6.11 SNVS_LPV Control Register (LPCR)

#### 20.6.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPCR</td>
<td>38h</td>
</tr>
</tbody>
</table>

#### 20.6.11.2 Function

The SNVS_LPV Control Register contains various control bits of the LP section of SNVS. This is a privileged write register.
20.6.11.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

20.6.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-25</td>
<td>Reserved.</td>
</tr>
<tr>
<td>24</td>
<td>Reserved.</td>
</tr>
<tr>
<td>23</td>
<td>PK_OVERRIDE PK_OVERRIDE PMIC On Request Override</td>
</tr>
<tr>
<td></td>
<td>The value written to PK_OVERRIDE will be asserted on output signal snvs_lp_pk_override. That signal is used to override the IOMUX control for the PMIC I/O pad.</td>
</tr>
<tr>
<td>22</td>
<td>PK_EN PMIC On Request Enable</td>
</tr>
<tr>
<td></td>
<td>The value written to PK_EN will be asserted on output signal snvs_lp_pk_en. That signal is used to turn off the pullup/pulldown circuitry in the PMIC I/O pad.</td>
</tr>
<tr>
<td>21-20</td>
<td>ON_TIME ON_TIME The ON_TIME field is used to configure the period of time after BTN is asserted before pmic_en_b is asserted to turn on the SoC power.</td>
</tr>
<tr>
<td></td>
<td>00: 500msec off-&gt;on transition time</td>
</tr>
<tr>
<td></td>
<td>01: 50msec off-&gt;on transition time</td>
</tr>
<tr>
<td></td>
<td>10: 100msec off-&gt;on transition time</td>
</tr>
<tr>
<td></td>
<td>11: 0msec off-&gt;on transition time</td>
</tr>
<tr>
<td>19-18</td>
<td>DEBOUNCE DEBOUNCE This field configures the amount of debounce time for the BTN input signal.</td>
</tr>
<tr>
<td></td>
<td>00: 50msec debounce</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>01: 100msec debounce</td>
<td>10: 500msec debounce</td>
</tr>
<tr>
<td>11: 0msec debounce</td>
<td></td>
</tr>
<tr>
<td>01: 10 secs</td>
<td>10: 15 secs</td>
</tr>
<tr>
<td>11: long press disabled (pmic_en_b will not be asserted regardless of how long BTN is asserted)</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>Reserved.</td>
</tr>
<tr>
<td>14-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved.</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Power Glitch Enable</td>
</tr>
<tr>
<td>0 - disabled</td>
<td>1 - enabled</td>
</tr>
<tr>
<td>6</td>
<td>Turn off System Power</td>
</tr>
<tr>
<td>0b - Leave system power on.</td>
<td>1b - Turn off system power.</td>
</tr>
<tr>
<td>5</td>
<td>Dumb PMIC Enabled</td>
</tr>
<tr>
<td>0b - Smart PMIC enabled.</td>
<td>1b - Dumb PMIC enabled.</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>LP Wake-Up Interrupt Enable</td>
</tr>
<tr>
<td>0 LP wake-up interrupt is disabled.</td>
<td>1 LP wake-up interrupt is enabled.</td>
</tr>
<tr>
<td>2</td>
<td>Monotonic Counter Enabled and Valid</td>
</tr>
<tr>
<td>When set, the MC can be incremented (by write transaction to the LPSMCMR or LPSMCLR). Once MC_SL or MC_HL bit is set. This bit can be changed only by LP Software reset or LP POR.</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### SNVS register descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>MC is disabled or invalid.</td>
</tr>
<tr>
<td>1b</td>
<td>MC is enabled and valid.</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 20.6.12 SNVS_LP Status Register (LPSR)

#### 20.6.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPSR</td>
<td>4Ch</td>
</tr>
</tbody>
</table>

#### 20.6.12.2 Function

The SNVS_LP Status Register reflects the internal state and behavior of the SNVS_LP. This is a privileged write register.

#### 20.6.12.3 Diagram

![Diagram of SNVS_LP Status Register (LPSR)](image)
### 20.6.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29-21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 18    | Set Power Off  
     | The SPO bit is set when the power button is pressed longer than the configured debounce time. Writing to the SPO bit will clear the set_pwr_off_irq interrupt.  
     | 0b - Set Power Off was not detected.  
     | 1b - Set Power Off was detected. |
| 17    | Emergency Off  
     | This bit is set when a power off is requested.  
     | 0b - Emergency off was not detected.  
     | 1b - Emergency off was detected. |
| 16    | Reserved |
| 15-10 | Reserved |
| 9     | Reserved |
| 8-4   | Reserved |
| 3     | Reserved |
| 2     | Monotonic Counter Rollover  
     | 0b - MC has not reached its maximum value.  
     | 1b - MC has reached its maximum value. |
| 1     | Reserved |
| 0     | Reserved |
20.6.13  SNVS_LP Secure Monotonic Counter MSB Register (LPSMCMR)

20.6.13.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPSMCMR</td>
<td>5Ch</td>
</tr>
</tbody>
</table>

20.6.13.2  Function

The SNVS_LP Secure Monotonic Counter MSB Register contains the monotonic counter era bits and the most-significant 16 bits of the monotonic counter. The monotonic counter is incremented by one if there is a write command to the LPSMCMR or LPSMCLR register. This is a non-privileged read-only register.

20.6.13.3  Diagram

```
Bits 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
R     MC_ERA_BITS
W
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     MON_COUNTER
W
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

20.6.13.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Monotonic Counter Era Bits</td>
</tr>
<tr>
<td>MC_ERA_BITS</td>
<td>These bits are inputs to the module and typically connect to fuses. When the Monotonic Counter is in use (i.e. enabled and valid and powered by an uninterrupted power source, e.g. a coin cell battery), and the boot software detects that the Monotonic Counter most-significant 16 Bits and Monotonic Counter LSB Register have been reset (MC_ENV=0), the boot software can take action to ensure that the value in the...</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Monotonic Counter remains monotonic (i.e. never decreasing).

The action is to blow an additional MC_ERA_BITS fuse. Since the MC_ERA_BITS field forms the most-significant field of the monotonic counter, blowing an additional fuse guarantees that the new monotonic counter value is higher than any previous value. Typically this would be necessary only when the coin cell battery is changed. Since the Monotonic Counter is reset on an LP Software Reset, an excessive number of MC_ERA_BITS fuses may be consumed if LP Software Reset is used repeatedly.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>MON_COUNTER</td>
<td>Monotonic Counter most-significant 16 Bits</td>
</tr>
<tr>
<td></td>
<td>The MC is incremented by one when:</td>
</tr>
<tr>
<td></td>
<td>• A write transaction to the LPSMCMR or LPSMCLR register is detected.</td>
</tr>
<tr>
<td></td>
<td>• The MC_ENV bit is set.</td>
</tr>
<tr>
<td></td>
<td>• MC_SL and MC_HL bits are not set.</td>
</tr>
<tr>
<td></td>
<td>This value can be reset only by LP software reset or LP POR.</td>
</tr>
</tbody>
</table>

## 20.6.14 SNVS_LP Secure Monotonic Counter LSB Register (LPSMCLR)

### 20.6.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPSMCLR</td>
<td>60h</td>
</tr>
</tbody>
</table>

### 20.6.14.2 Function

The SNVS_LP Secure Monotonic Counter LSB Register contains the 32 least-significant bits of the monotonic counter. The MC is incremented by one if there is a write command to the LPSMCMR or LPSMCLR register. This is a non-privileged read-only register.
20.6.14.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>MON_COUNTER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>MON_COUNTER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>MON_COUNTER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>MON_COUNTER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

20.6.14.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0 MON_COUNTER</td>
<td>Monotonic Counter bits</td>
</tr>
<tr>
<td></td>
<td>The MC is incremented by one when:</td>
</tr>
<tr>
<td></td>
<td>• A write transaction to the LPSMCMR or LPSMCLR Register is detected.</td>
</tr>
<tr>
<td></td>
<td>• The MC_ENV bit is set.</td>
</tr>
<tr>
<td></td>
<td>• MC_SL and MC_HL bits are not set.</td>
</tr>
<tr>
<td></td>
<td>This value can be reset only by LP software reset or LP POR.</td>
</tr>
</tbody>
</table>

20.6.15  SNVS_LP General Purpose Register 0 (legacy alias) (LPGPR0_legacy_alias)

20.6.15.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPGPR0_legacy_alias</td>
<td>68h</td>
</tr>
</tbody>
</table>
20.6.15.2 Function

The SNVS_LP General Purpose Register is a 128-bit read/write register located in SNVS_LP, which can be used by any application for retaining data during an SoC power-down mode. This is a privileged read/write register. The full GPR register is accessed as 4 32-bit registers located in successive word addresses starting at offset 100h. For backward compatibility with earlier versions of SNVS, LPGPR0..LPGPR3 are aliased at the earlier offset of 90h and LPGPR0 is aliased at its original offset of 68h. The GPR will be automatically zeroized when a tamper event occurs, unless GPR zeroization is disabled via the GPR_Z_DIS bit in the LP Control Register.

20.6.15.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

20.6.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>General Purpose Register</td>
</tr>
<tr>
<td>GPR</td>
<td>When GPR_SL or GPR_HL bit is set, the register cannot be programmed.</td>
</tr>
</tbody>
</table>

20.6.16 SNVS_LP General Purpose Registers 0 .. 3 (LPGPR0_alias - LPGPR3_alias)

20.6.16.1 Offset

For a = 0 to 3:
20.6.16.2 Function

The SNVS_LP General Purpose Register is a 128-bit read/write register located in SNVS_LP, which can be used by any application for retaining data during an SoC power-down mode. This is a privileged read/write register. The full GPR register is accessed as 4 32-bit registers located in successive word addresses starting at offset 100h. For backward compatibility with earlier versions of SNVS, LPGPR0..LPGPR3 are aliased at the earlier offset of 90h and LPGPR0 is aliased at its original offset of 68h. The GPR will be automatically zeroized when a tamper event occurs, unless GPR zeroization is disabled via the GPR_Z_DIS bit in the LP Control Register.

20.6.16.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>W</td>
<td>R</td>
<td>GPR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>GPR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

20.6.16.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>General Purpose Register</td>
</tr>
<tr>
<td>GPR</td>
<td>When GPR_SL or GPR_HL bit is set, the register cannot be programmed.</td>
</tr>
</tbody>
</table>
20.6.17 SNVS_LP General Purpose Registers 0 .. 3 (LPGPR0 - LPGPR3)

20.6.17.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPGPRa</td>
<td>100h + (a × 4h)</td>
</tr>
</tbody>
</table>

20.6.17.2 Function

The SNVS_LP General Purpose Register is a 128-bit read/write register located in SNVS_LP, which can be used by any application for retaining data during an SoC power-down mode. This is a privileged read/write register. The full GPR register is accessed as 4 32-bit registers located in successive word addresses starting at offset 100h. For backward compatibility with earlier versions of SNVS, LPGPR0..LPGPR3 are aliased at the earlier offset of 90h and LPGPR0 is aliased at its original offset of 68h. The GPR will be automatically zeroized when a tamper event occurs, unless GPR zeroization is disabled via the GPR_Z_DIS bit in the LP Control Register.

20.6.17.3 Diagram

![Diagram of SNVS_LP General Purpose Registers](image)
### 20.6.17.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>General Purpose Register</td>
</tr>
<tr>
<td>GPR</td>
<td>When GPR_SL or GPR_HL bit is set, the register cannot be programmed.</td>
</tr>
</tbody>
</table>

### 20.6.18 SNVS_HP Version ID Register 1 (HPVIDR1)

#### 20.6.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPVIDR1</td>
<td>BF8h</td>
</tr>
</tbody>
</table>

#### 20.6.18.2 Function

The SNVS_HP Version ID Register 1 is a non-privileged read-only register that contains the current version of the SNVS. The version consists of a module ID, a major version number, and a minor version number.

#### 20.6.18.3 Diagram

```plaintext
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

**IP_ID**

**MAJOR_REV**

**MINOR_REV**
20.6.18.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16 IP_ID</td>
<td>SNVS block ID</td>
</tr>
<tr>
<td>15-8 MAJOR_REV</td>
<td>SNVS block major version number</td>
</tr>
<tr>
<td>7-0 MINOR_REV</td>
<td>SNVS block minor version number</td>
</tr>
</tbody>
</table>

20.6.19 SNVS_HP Version ID Register 2 (HPVIDR2)

20.6.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HPVIDR2</td>
<td>BFCh</td>
</tr>
</tbody>
</table>

20.6.19.2 Function

The SNVS_HP Version ID Register 2 is a non-privileged read-only register that indicates the current version of the SNVS. Version ID register 2 consists of the following fields: integration options, ECO revision, and configuration options.

20.6.19.3 Diagram

![Diagram of SNVS_HP Version ID Register 2 (HPVIDR2)]
### 20.6.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>IP Era</td>
</tr>
<tr>
<td>IP_ERA</td>
<td>00h - Era 1 or 2</td>
</tr>
<tr>
<td></td>
<td>03h - Era 3</td>
</tr>
<tr>
<td></td>
<td>04h - Era 4</td>
</tr>
<tr>
<td></td>
<td>05h - Era 5</td>
</tr>
<tr>
<td>23-16</td>
<td>SNVS Integration Options</td>
</tr>
<tr>
<td>INTG_OPT</td>
<td></td>
</tr>
<tr>
<td>15-8</td>
<td>SNVS ECO Revision</td>
</tr>
<tr>
<td>ECO_REV</td>
<td></td>
</tr>
<tr>
<td>7-0</td>
<td>SNVS Configuration Options</td>
</tr>
<tr>
<td>CONFIG_OPT</td>
<td></td>
</tr>
</tbody>
</table>
Chapter 21
System Reset Controller (SRC)

21.1 Chip-specific SRC information

Table 21-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

21.2 SRC Overview

The System Reset Controller (SRC) controls the reset and boot operation of the SoC.

It is responsible for the generation of all reset signals and boot decoding.

The reset controller determines the source and the type of reset, such as POR, COLD, and performs the necessary reset qualification and stretching sequences. Based on the type of reset, the reset logic generates the reset sequence for the entire IC. Whenever the chip is powered on, the reset is issued through SRC_ONOFF signal and the entire chip is reset.

21.2.1 Features

The SRC includes the following features.
• Receives and handles the resets from all the reset sources
• Resets the appropriate domains based upon the resets sources and the nature of the reset
• Latches the SRC_BOOT_MODE pins and common configuration signals from the internal fuse

21.3 External Signals

The following table describes the external signals of SRC.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRC_BT_CFG0</td>
<td>Boot configuration signals</td>
<td>GPIO_B0_04</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG1</td>
<td></td>
<td>GPIO_B0_05</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG2</td>
<td></td>
<td>GPIO_B0_06</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG3</td>
<td></td>
<td>GPIO_B0_07</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG4</td>
<td></td>
<td>GPIO_B0_08</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG5</td>
<td></td>
<td>GPIO_B0_09</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG6</td>
<td></td>
<td>GPIO_B0_10</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG7</td>
<td></td>
<td>GPIO_B0_11</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG8</td>
<td></td>
<td>GPIO_B0_12</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG9</td>
<td></td>
<td>GPIO_B0_13</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG10</td>
<td></td>
<td>GPIO_B0_14</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BT_CFG11</td>
<td></td>
<td>GPIO_B0_15</td>
<td>ALT6</td>
<td>I</td>
</tr>
<tr>
<td>SRC_POR_B</td>
<td>Power on reset signal</td>
<td>POR_B</td>
<td></td>
<td>I</td>
</tr>
<tr>
<td>SRC_ONOFF</td>
<td>ON/OFF signal</td>
<td>ONOFF</td>
<td></td>
<td>I</td>
</tr>
<tr>
<td>SRC_BOOT_MODE0</td>
<td>Boot mode signals</td>
<td>GPIO_AD_B0_04</td>
<td>ALT0</td>
<td>I</td>
</tr>
<tr>
<td>SRC_BOOT_MODE1</td>
<td></td>
<td>GPIO_AD_B0_05</td>
<td>ALT0</td>
<td>I</td>
</tr>
</tbody>
</table>

21.4 Clocks

The table found here describes the clock sources for SRC.
Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

### Table 21-3. SRC Clocks

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
</tbody>
</table>

#### 21.5 Top-level resets, power-up sequence and external supply integration

Information found here defines chip resets, power-up sequence, and external supply integration.

#### 21.5.1 Reset and Power-up Flow

The chip presumes the following reset and power-up flow:
Top-level resets, power-up sequence and external supply integration

**Figure 21-1. Chip reset scheme under PMU control**

Note: PMIC_ON_REQ acts as an active high-signal
1 or high Z = ON
0 = OFF
Figure 21-2. Chip reset scheme under external PMIC control

PMIC_ON_REQ acts as power-on alarm:
0->1 = power-on by alarm

PMIC_STBY_REQ enters and exits PMIC standby
0->1 = enter standby
1-> 0 = wake-up from standby
Top-level resets, power-up sequence and external supply integration

Figure 21-3. Chip on/off state flow diagram
21.5.2 Finite-State Machine (FSM)

![Finite-State Machine Diagram]

- **ON**
  - button pressed < 5s.
  - generate irq
  - alarm positive edge
  - emergency off
  - log emergency off
  - button pressed > 5s.

- **OFF**
  - alarm negative edge
  - button pressed (any duration)

Figure 21-4. FSM

21.5.3 Power mode transitions

**Table 21-4. Power mode transitions**

<table>
<thead>
<tr>
<th>Power mode</th>
<th>Configuration with external PMIC</th>
<th>Configuration with internal PMIC</th>
</tr>
</thead>
</table>
| ON, first time              | 1. Either coin cell or SoC power supply is connected to SNVS.  
  2. When button is pressed, PMIC powers on.                                                                                                                                                                                                                                                                                                                                  | 1. Either coin cell or SoC power supply is connected to SNVS, PMIC_ON_REQ goes to ‘1’.  
  2. Drive DCDC_PSWITCH to high, 1 ms after DCDC_IN is powered.  
  3. DCDC regulator is enabled.                                                                                                                                                                                                                                                                                  |
| Normal ON to OFF, by button | 1. Button is pressed for a short duration on the external PMIC.  
  2. Interrupt request (irq) is sent to SoC from external PMIC.                                                                                                                                                                                                                                                                                                           | 1. SoC button is pressed for a short duration.  
  2. Interrupt request (irq) is sent to SoC from FSM.  
  3. Alarm timer is set up by software routine and started.                                                                                                                                                                                                                                                                                                              |

*Table continues on the next page...*
### Table 21-4. Power mode transitions (continued)

<table>
<thead>
<tr>
<th>Power mode</th>
<th>Configuration with external PMIC</th>
<th>Configuration with internal PMIC</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>3. SoC is programming PMIC for power off when standby is asserted.</td>
<td>4. Upon alarm_in assertion to '1', PMIC_ON_REQ goes '0'.</td>
</tr>
<tr>
<td></td>
<td>4. In CCM STOP mode, Standby is asserted, PMIC gates SoC supplies.</td>
<td>5. DCDC regulator goes OFF.</td>
</tr>
<tr>
<td>Emergency ON to OFF, by button</td>
<td>1. Button is pressed for an extended time on the external PMIC.</td>
<td>1. Button is pressed for longer than 5 seconds on the SoC.</td>
</tr>
<tr>
<td></td>
<td>2. PMIC is powering off.</td>
<td>2. FSM validates button pressed for 5 seconds.</td>
</tr>
<tr>
<td>OFF to ON, by button</td>
<td>1. Button is pressed on the external PMIC.</td>
<td>3. Emergency power off is logged, PMIC_ON_REQ goes '0', alarm_mask goes '1'.</td>
</tr>
<tr>
<td></td>
<td>2. PMIC powers ON.</td>
<td>4. DCDC regulator goes OFF.</td>
</tr>
<tr>
<td>OFF to ON, by timer alarm</td>
<td>1. Timer alarm in SNVS is programmed by software before SoC goes OFF.</td>
<td>1. Timer alarm in SNVS is programmed by software before SoC goes OFF.</td>
</tr>
<tr>
<td></td>
<td>2. SoC enters OFF mode.</td>
<td>2. SoC enters OFF mode.</td>
</tr>
<tr>
<td></td>
<td>3. Upon timer limit, wake up alarm goes '0'.</td>
<td>3. Upon timer limit, wake up alarm goes '0'.</td>
</tr>
<tr>
<td></td>
<td>4. PMIC_ON_REQ goes '1'.</td>
<td>4. PMIC_ON_REQ goes '1'.</td>
</tr>
<tr>
<td></td>
<td>PMIC receives assertion of PMIC_ON_REQ and wakes up.</td>
<td>4. DCDC regulator is enabled by PMIC_ON_REQ = 1.</td>
</tr>
</tbody>
</table>

#### 21.6 Power-On Reset and power sequencing

This module generates an internal POR_B signal that is logically AND'ed with any externally applied SRC_POR_B signal. The internal POR_B signal will be held low until all of the following conditions are met:

- 4ms after the external power supply VDDHIGH_IN is valid
- 1ms after the VDD_SOC_IN supply is valid

The 4ms and 1ms delays are derived from counting the 32 kHz RTC clock cycles; the accuracy depends on the accuracy of the RTC. When the RTC crystal is either absent or in the process of powering up, an internal ring oscillator will be the source of RTC, which is not as accurate as the crystal.

##### 21.6.1 External POR using SRC_POR_B

If the external SRC_POR_B signal is used to control the processor POR, SRC_POR_B must remain low (asserted) until the VDD_SOC supplies are stable.
21.6.2 Internal POR

If the external SRC_POR_B signal is not used (always held high or left unconnected), the processor defaults to the internal POR function (PMU controls generation of the POR based on the power supplies).

21.7 Functional Description

21.7.1 Reset Control

This section details the reset control of this device.

21.7.1.1 Reset inputs and outputs

The reset control logic receives reset requests from all potential reset sources. All the immediate sources of reset are directly passed to the reset stretching block, whereas the resets requiring qualification are passed on to the reset qualification logic before they are sent to the reset stretching block.

All reset inputs and outputs are described in the following figure:
The reset types and modules they affect are shown in Table 21-5. As there is no chip POR, the POR_B is used to reset the entire chip including test logic and JTAG modules.

**NOTE**

All resets are expected to be active low except jtag_sw_rst.

### Table 21-5. SRC reset functionality

<table>
<thead>
<tr>
<th>SoC Modules</th>
<th>POR</th>
<th>COLD</th>
</tr>
</thead>
<tbody>
<tr>
<td>System modules (PLLs, fuses, etc)</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>Functional modules</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>Arm</td>
<td>yes</td>
<td>yes</td>
</tr>
<tr>
<td>IOMUXC</td>
<td>yes</td>
<td>no</td>
</tr>
<tr>
<td>Arm debug</td>
<td>yes</td>
<td>no</td>
</tr>
<tr>
<td>SJC</td>
<td>yes</td>
<td>no</td>
</tr>
</tbody>
</table>
The reset priorities are POR (strongest) and COLD (weakest). If a stronger reset is asserted during the sequence of a weaker reset, then the weaker sequence will be overridden, and the stronger reset sequence will commence. There is no priority within a reset type (POR, etc). If a reset is asserted during the reset sequence of the same type, the reset sequence will be interrupted and restarted.

The following lists the functionality of each of these reset outputs:

- system_early_rst_b - Resets the system modules that need to start first as CCM, OCOTP_CTRL, FUSEBOX, etc.
- system_rst_b - Resets functional modules
- arm_rst_b - Resets Arm module (on regular system reset)
- arm_por_rst_b - Resets Arm POR input
- arm_dbg_rst_b - Reset debug logic of Arm
- test_logic_rst_b - Reset test logic (IOMUXC, DAP)
- sjc_por_rst_b - Reset to SJC

**NOTE**

It is assumed that each reset source will deassert after its assertion, either due to reset generated to the system from SRC, or by negation of the reset source (if it came from an external source to the chip). In the latter case, the reset source is assumed to be held for at least 2 XTALI clocks so it can be sampled by SRC.

### 21.7.1.2 Reset Handling

#### 21.7.1.2.1 POR (SRC_POR_B)

SRC_POR_B is an external reset signal. When the chip is powered up, the reset signal is passed through the POR_B pin indicating power-up sequence. The SRC resets the entire chip including the JTAG (SJC) module. All SRC registers will be reset during the POR sequence.

As soon as SRC_POR_B occurs, all resets are asserted and the entire chip is reset by SRC. The SRC_POR_B is stretched for 2 XTALI cycles and the stretching sequence takes place after 2 XTALI clocks of POR_B pin deassertion.

The sjc_por_rst_b signal is deasserted together with SRC_POR_B signal. The output is also deasserted after the stretching of SRC_POR_B has deasserted.

After the above resets deassert, system_early_rst_b reset is deasserted after 2 XTALI clocks. The system_early_rst_b is used for the CCM and PLL-IPs to start generating PLL clock outputs and the system root clocks.
When the system root clocks are ready, the CCM will assert system_clk_ready signal. This signal is generated during the start sequence in the CCM and it involves the preparation of the PLLs to generate clock roots for functional operation.

SRC then enables OCOTP_CTRL and fusebox clocks, so that fuses can be loaded to OCOTP_CTRL.

- SRC will prepare the boot information
- After 8 ipg cycles, resets to all modules will be de-asserted
- After 8 ipg cycles, system clocks will be enabled (en_system_clk).

21.7.1.2.2 COLD RESET

The sequence is similar to SRC_POR_B except the memory repair operation is not performed.

After the reset source deasserts, system_early_rst_b reset is deasserted after at least 2 XTALI clocks. The system_early_rst_b is used for the CCM and PLL-IPs to start generating PLL clock outputs and the system root clocks.

After the system root clocks are ready, the CCM will assert system_clk_ready signal. This signal is generated during the start sequence in the CCM and it involves the preparation of the PLLs to generate clock roots for functional operation. See CCM for more information.

After system_clk_ready arrives at the SRC, it will enable OCOTP_CTRL and fusebox clocks, so that fuses can be loaded to OCOTP_CTRL. OCOTP_CTRL will notify with iim_ready_flag when the fusebox loading finishes.

- SRC will prepare the boot information
- After 8 ipg cycles resets to all modules will be deasserted
- After 8 ipg cycles, system clocks will be enabled (en_system_clk).

21.7.2 Parallel Reset Requests

SRC will follow the following rules in the case of parallel reset requests:

1. The order of strength of resets is POR - strongest, COLD - weakest
2. If a stronger reset is asserted during weaker reset sequence, then the stronger reset will take over and the stronger reset process will commence. The following cases fall into this category:
   - POR reset request in the middle of cold reset process - the cold will be stopped and the POR sequence will start.
3. If a weaker reset is asserted during stronger reset sequence, then the stronger reset sequence will continue without interference. If at the end of the stronger reset process the weaker request is still asserted then the weaker sequence will commence. The following cases fall into this category:
   - COLD reset requests in the middle of POR reset process - the POR process will continue without interference.

4. If a similar reset request is asserted during the process of reset handling, then the process of reset handling will start over (with the same process). The following cases fall into this category:
   - POR reset request in the middle of POR reset process - the POR process will start over.
   - COLD reset request in the middle of COLD reset process - the COLD process will start over.

21.7.3 Boot Mode Control

21.7.3.1 BOOT_MODE Pin Latching

The exact boot sequence is controlled by the values of the BOOT_MODE pins on this device.

The value of the BOOT_MODE pins will be latched after the OCOTP_CTRL asserts the fuse read completion flag. After latching, the values of the BOOT_MODE pins are used to determine the booting options of the core as described in the SRC_SBMRx registers.

The boot mode general purpose bits can be provided to the SRC from either e-fuses or GPIO signals. The gpio_bt_sel e-fuse defines the source to be used to derive the boot information. When gpio_bt_sel is set, e-fuses are used. When cleared, GPIO signals are used.

The boot information is provided in SRC_SBMR1 register. The figure below shows the selection of boot mode information.
 SRC Memory Map/Register Definition

21.8 SRC Memory Map/Register Definition

SRC memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400F_8000</td>
<td>SRC Control Register (SRC_SCR)</td>
<td>32</td>
<td>R/W</td>
<td>A048_0520h</td>
<td>21.8.1/1285</td>
</tr>
<tr>
<td>400F_8004</td>
<td>SRC Boot Mode Register 1 (SRC_SBMR1)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>21.8.2/1287</td>
</tr>
<tr>
<td>400F_8008</td>
<td>SRC Reset Status Register (SRC_SRSR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>21.8.3/1288</td>
</tr>
<tr>
<td>400F_801C</td>
<td>SRC Boot Mode Register 2 (SRC_SBMR2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>21.8.4/1291</td>
</tr>
<tr>
<td>400F_8020</td>
<td>SRC General Purpose Register 1 (SRC_GPR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>21.8.5/1292</td>
</tr>
<tr>
<td>400F_8024</td>
<td>SRC General Purpose Register 2 (SRC_GPR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>21.8.6/1293</td>
</tr>
<tr>
<td>400F_8028</td>
<td>SRC General Purpose Register 3 (SRC_GPR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>21.8.7/1293</td>
</tr>
<tr>
<td>400F_802C</td>
<td>SRC General Purpose Register 4 (SRC_GPR4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>21.8.8/1294</td>
</tr>
<tr>
<td>400F_8030</td>
<td>SRC General Purpose Register 5 (SRC_GPR5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>21.8.9/1294</td>
</tr>
</tbody>
</table>

Table continues on the next page...
21.8.1 SRC Control Register (SRC_SCR)

The Reset control register (SCR), contains bits that control operation of the reset controller.

Address: 400F_8000h base + 0h offset = 400F_8000h
## SRC_SCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td><strong>mask_wdog3_rst</strong>&lt;br&gt;Mask <em>wdog3_rst_b</em> source. If these 4 bits are coded from A to 5 then, the <em>wdog3_rst_b</em> input to SRC will be masked and the <em>wdog3_rst_b</em> will not create a reset to the chip.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>Any other code than 0101 will be coded to 1010 i.e. <em>wdog3_rst_b</em> is not masked.</td>
</tr>
<tr>
<td></td>
<td>0101 <em>wdog3_rst_b</em> is masked</td>
</tr>
<tr>
<td>27–26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td><strong>dbg_rst_msk_pg</strong>&lt;br&gt;Do not assert debug resets after power gating event of core</td>
</tr>
<tr>
<td></td>
<td>0 do not mask core debug resets (debug resets will be asserted after power gating event)</td>
</tr>
<tr>
<td></td>
<td>1 mask core debug resets (debug resets won't be asserted after power gating event)</td>
</tr>
<tr>
<td>24–22</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20–18</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>17</td>
<td><strong>core0_dbg_rst</strong>&lt;br&gt;Software reset for core0 debug only.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>This is a self clearing bit. After it is set to 1, the reset process will begin, and when it finishes, this bit will be self cleared.</td>
</tr>
<tr>
<td></td>
<td>0 do not assert core0 debug reset</td>
</tr>
<tr>
<td>16–14</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13</td>
<td><strong>core0_rst</strong>&lt;br&gt;Software reset for core0 only.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>This is a self clearing bit. After it is set to 1, the reset process will begin, and when it finishes, this bit will be self cleared.</td>
</tr>
<tr>
<td></td>
<td>0 do not assert core0 reset</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10–7</td>
<td><strong>mask_wdog_rst</strong>&lt;br&gt;Mask <em>wdog_rst_b</em> source. If these 4 bits are coded from A to 5 then, the <em>wdog_rst_b</em> input to SRC will be masked and the <em>wdog_rst_b</em> will not create a reset to the chip.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>During the time the WDOG event is masked using SRC logic, it is likely that the WDOG Reset Status Register (WRSR) bit 1 (which indicates a WDOG timeout event) will get asserted. software / OS developer must prepare for this case. Re-enabling the WDOG is possible, by unmasking it in SRC, though it must be preceded by servicing the WDOG. However, for the case that the event has been asserted, the status bit (WRSR bit-1) will remain asserted, regardless of servicing the WDOG module. (Hardware reset is the only way to cause the de-assertion of that bit).</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### SRC_SCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>any other code will be coded to 1010 i.e. wdog_rst_b is not masked</td>
<td></td>
</tr>
<tr>
<td>0101</td>
<td>wdog_rst_b is masked</td>
</tr>
<tr>
<td>1010</td>
<td>wdog_rst_b is not masked (default)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>6–5</th>
</tr>
</thead>
<tbody>
<tr>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>4</th>
</tr>
</thead>
<tbody>
<tr>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>3–1</th>
</tr>
</thead>
<tbody>
<tr>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 21.8.2 SRC Boot Mode Register 1 (SRC_SBMR1)

The Boot Mode register (SBMR) contains bits that reflect the status of Boot Mode Pins of the chip. The reset value is configuration dependent (depending on boot/fuses/IO pads).

If SRC_GPR10[28] bit is set, this bit instructs the ROM code to use the SRC_GPR9 register as if it is SBMR1. This allows software to override the fuse bits and boot from an alternate boot source.

Address: 400F_8000h base + 4h offset = 400F_8004h

#### SRC_SBMR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>Refer to fusemap.</td>
</tr>
<tr>
<td>BOOT_CFG4[7:0]</td>
<td>Refer to fusemap.</td>
</tr>
<tr>
<td>23–16</td>
<td>Refer to fusemap.</td>
</tr>
<tr>
<td>BOOT_CFG3[7:0]</td>
<td>Refer to fusemap.</td>
</tr>
<tr>
<td>15–8</td>
<td>Refer to fusemap.</td>
</tr>
<tr>
<td>BOOT_CFG2[7:0]</td>
<td>Refer to fusemap.</td>
</tr>
<tr>
<td>11</td>
<td>Refer to fusemap.</td>
</tr>
<tr>
<td>BOOT_CFG1[7:0]</td>
<td>Refer to fusemap.</td>
</tr>
</tbody>
</table>
21.8.3 SRC Reset Status Register (SRC_SRSR)

The SRSR is a write to one clear register which records the source of the reset events for the chip. The SRC reset status register will capture all the reset sources that have occurred. This register is reset on ipp_reset_b. This is a read-write register.

For bit[6-0] - writing zero does not have any effect. Writing one will clear the corresponding bit. The individual bits can be cleared by writing one to that bit. When the system comes out of reset, this register will have bits set corresponding to all the reset sources that occurred during system reset. Software has to take care to clear this register by writing one after every reset that occurs so that the register will contain the information of recently occurred reset.

Address: 400F_8000h base + 8h offset = 400F_8008h
## SRC_SRSR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>16 - Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>15–9 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>8 tempsense_rst_b</td>
<td>Temper Sensor software reset. Indicates whether the reset was the result of software reset from on-chip Temperature Sensor.</td>
</tr>
<tr>
<td>7 wdog3_rst_b</td>
<td>IC Watchdog3 Time-out reset. Indicates whether the reset was the result of the watchdog3 timeout event.</td>
</tr>
<tr>
<td>6 jtag_sw_rst</td>
<td>JTAG software reset. Indicates whether the reset was the result of software reset from JTAG.</td>
</tr>
<tr>
<td>5 jtag_rst_b</td>
<td>HIGH-Z JTAG reset. Indicates whether the reset was the result of HIGH-Z reset from JTAG.</td>
</tr>
<tr>
<td>4 wdog_rst_b</td>
<td>IC Watchdog Time-out reset. Indicates whether the reset was the result of the watchdog time-out event.</td>
</tr>
</tbody>
</table>

---

Table continues on the next page...
### SRC_SRSR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 3 ipp_user_reset_b | Indicates whether the reset was the result of the ipp_user_reset_b qualified reset.  
0  Reset is not a result of the ipp_user_reset_b qualified as COLD reset event.  
1  Reset is a result of the ipp_user_reset_b qualified as COLD reset event. |
| 2 csu_reset_b | Indicates whether the reset was the result of the csu_reset_b input.  
0  Reset is not a result of the csu_reset_b event.  
1  Reset is a result of the csu_reset_b event. |
| 1 lookup_sysresetreq | Indicates a reset has been caused by CPU lockup or software setting of SYSRESETREQ bit in Application Interrupt and Reset Control Register of the Arm core. SW needs to write a value to SRC_GPR5 before writing the SYSRESETREQ bit and use the SRC_GPR5 value to distinguish if the reset is caused by SYSRESETREQ or CPU lockup.  
0  Reset is not a result of the mentioned case.  
1  Reset is a result of the mentioned case. |
| 0 ipp_reset_b | Indicates whether reset was the result of ipp_reset_b pin (Power-up sequence)  
0  Reset is not a result of ipp_reset_b pin.  
1  Reset is a result of ipp_reset_b pin. |
21.8.4 SRC Boot Mode Register 2 (SRC_SBMR2)

The Boot Mode register (SBMR), contains bits that reflect the status of Boot Mode Pins of the chip. The default values for those bits depends on the values of pins/fuses during reset sequence, hence the question mark on their default value.

Address: 400F_8000h base + 1Ch offset = 400F_801Ch

![Diagram of SRC Boot Mode Register 2 (SRC_SBMR2)]
### SRC_SBMR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–26</td>
<td>Reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>25–24</td>
<td>BMOD[1:0] shows the latched state of the BOOT_MODE1 and BOOT_MODE0 signals on the rising edge of POR_B. See the Boot mode pin settings section of System Boot.</td>
</tr>
<tr>
<td>23–5</td>
<td>Reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4</td>
<td>BT_FUSE_SEL (connected to gpio btFuse_sel) shows the state of the BT_FUSE_SEL fuse. See Fusemap for additional information on this fuse.</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEC_CONFIG[1:0]</td>
<td>SECONFIG[1] shows the state of the SECONFIG[1] fuse. See Fusemap for additional information on this fuse. SECONFIG[0] shows the state of the SECONFIG[0] fuse. This fuse is shown as reserved in Fusemap (address 0x440[1]) because it does not have a user-relevant function.</td>
</tr>
</tbody>
</table>

### 21.8.5 SRC General Purpose Register 1 (SRC_GPR1)

**NOTE**
This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 20h offset = 400F_8020h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>PERSISTENT_ENTRY0</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

### SRC_GPR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PERSISTENT_ENTRY0</td>
<td>Holds entry function for core0 for waking-up from low power mode. The SRC ensures that the register value will persist across system resets.</td>
</tr>
</tbody>
</table>
21.8.6 SRC General Purpose Register 2 (SRC_GPR2)

NOTE
This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 24h offset = 400F_8024h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | W  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

SRC_GPR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PERSISTENT_ARG0</td>
<td>Holds argument of entry function for core0 for waking-up from low power mode. The SRC ensures that the register value will persist across system resets.</td>
</tr>
</tbody>
</table>

21.8.7 SRC General Purpose Register 3 (SRC_GPR3)

NOTE
This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 28h offset = 400F_8028h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | W  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

SRC_GPR3 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Read/write general purpose bits used to store an arbitrary value.</td>
</tr>
</tbody>
</table>
21.8.8 SRC General Purpose Register 4 (SRC_GPR4)

NOTE
This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 2Ch offset = 400F_802Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R/W | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

SRC_GPR4 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Read/write general purpose bits used to store an arbitrary value.</td>
</tr>
</tbody>
</table>

21.8.9 SRC General Purpose Register 5 (SRC_GPR5)

NOTE
SW needs to write a value to SRC_GPR5 before writing the SYSRESETREQ bit and use the SRC_GPR5 value to distinguish if the reset is caused by SYSRESETREQ or CPU lockup

Address: 400F_8000h base + 30h offset = 400F_8030h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R/W | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

SRC_GPR5 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Read/write general purpose bits used to store an arbitrary value.</td>
</tr>
</tbody>
</table>
21.8.10  SRC General Purpose Register 6 (SRC_GPR6)

**NOTE**

This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 34h offset = 400F_8034h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**SRC_GPR6 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Read/write general purpose bits used to store an arbitrary value.</td>
</tr>
</tbody>
</table>

21.8.11  SRC General Purpose Register 7 (SRC_GPR7)

**NOTE**

This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 38h offset = 400F_8038h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**SRC_GPR7 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Read/write general purpose bits used to store an arbitrary value.</td>
</tr>
</tbody>
</table>
21.8.12 SRC General Purpose Register 8 (SRC_GPR8)

**NOTE**

This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 3Ch offset = 400F_803Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**SRC_GPR8 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Read/write general purpose bits used to store an arbitrary value.</td>
</tr>
</tbody>
</table>

21.8.13 SRC General Purpose Register 9 (SRC_GPR9)

**NOTE**

This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 40h offset = 400F_8040h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**SRC_GPR9 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>
21.8.14 SRC General Purpose Register 10 (SRC_GPR10)

NOTE

This register is used by the ROM code and should not be used by application software.

Address: 400F_8000h base + 44h offset = 400F_8044h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>PERSIST_SECONDARY_BOOT</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>W</td>
<td>-</td>
<td>-</td>
<td>PERSIST_REDUNDANT_BOOT</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>W</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**SRC_GPR10 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31    | Read/write bit, for general purpose  
  **NOTE:** Reset only by POR |
| 30    | PERSIST_SECONDARY_BOOT  
  This bit identifies which image must be used - primary and secondary.  
  Used only for eMMC/SD/FlexSPI NOR boot. |
| 29–28 | Read/write bits, for general purpose  
  **NOTE:** Reset only by POR |
| 27–26 | PERSIST_REDUNDANT_BOOT  
  This field identifies which image must be used - 0/1/2/3. Used for both SPI NAND and SLC raw NAND devices. |

*Table continues on the next page...*
SRC_GPR10 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>25 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Read/write bits, for general purpose</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Reset only by POR</td>
</tr>
</tbody>
</table>
Chapter 22
Fusemap

22.1 Boot Fusemap

This section describes the various modes and the selection of the required boot devices.

A separate map is given for each and every boot device. The device select is specified by the BOOT_CFG1[7:4] fuses.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>FlexSPI1 (Serial NOR)</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>SD</td>
<td>0</td>
<td>1</td>
<td>x</td>
<td>x</td>
</tr>
<tr>
<td>MMC/eMMC</td>
<td>1</td>
<td>0</td>
<td>x</td>
<td>x</td>
</tr>
<tr>
<td>SEMC (NAND)</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>x</td>
</tr>
<tr>
<td>SEMC (NOR)</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>FlexSPI1 (Serial NAND)</td>
<td>1</td>
<td>1</td>
<td>x</td>
<td>x</td>
</tr>
</tbody>
</table>

NOTE

The fuses marked as “Reserved” are reserved for NXP internal (and future) use only, or are security related. Customers must not attempt to burn these, because the IC behavior may be unpredictable. The reserved fuses can be read as either '0' or '1'. Security-related fuses are described in the Security Reference Manual (SRM) for this device.

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[7:0] (BOOT_CFG1)</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>xSPI FLASH Auto Probe Type</td>
<td>EncryptedXIP</td>
<td>0 - QuadSPI NOR</td>
<td>0 - Disabled</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 22-2. FlexSPI (Serial NOR) boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[15:8]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>(BOOT_CFG2)</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>FLASH TYPE:</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>000 - Device supports 3B read by default</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>001 - Device supports 4B read by default</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>010 - HyperFlash 1V8</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>011 - HyperFlash 3V3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>100 - MXIC Octal DDR</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>101 - Micron Octal DDR</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>111 - QSPI device supports 3B read by default (on secondary pinmux option)</td>
<td></td>
</tr>
<tr>
<td>0x450[23:16]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>(BOOT_CFG3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x450[31:24]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>(BOOT_CFG4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[7:0]</td>
<td>Reserved</td>
<td>FORCE_COLD_BOOT(SBMR)</td>
<td>BT_FUSE_SEL</td>
<td>Reserved</td>
<td>BOOT_FREQ (ARM/BSU)</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 - 396/132 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - 528/132 MHz</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[15:8]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[23:16]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[31:24]</td>
<td>SD_PWR_CYCLE_SELECTION:</td>
<td>PWR_STABLE_CYCLE_SELECT:</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>NAND_ECC_DISABLE</td>
<td></td>
</tr>
<tr>
<td></td>
<td>'00' - 20ms</td>
<td>'0' - 2.5ms</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 - NAND ECC is enabled</td>
<td></td>
</tr>
<tr>
<td></td>
<td>'01' - 10ms</td>
<td>'1' - 5ms</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 - NAND ECC is disabled</td>
<td></td>
</tr>
<tr>
<td></td>
<td>'10' - 5ms</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Enable DLL for SD/EMMC</td>
<td></td>
</tr>
<tr>
<td></td>
<td>'11' - 2.5ms</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 - Disable DLL for SD/EMMC</td>
<td></td>
</tr>
<tr>
<td>0x470[7:0]</td>
<td>DLL Override:</td>
<td>SD1_RST_POLARITY_SELECT:</td>
<td>SD2_VOLTAGE_SELECT:</td>
<td>UART Serial Download Disable:</td>
<td>Disable SDMMC Manufacture mode:</td>
<td>L1 I-Cache DISABLE</td>
<td>BT_MPU_DISABLE</td>
<td>Override SD Pad Settings</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 22-2. FlexSPI (Serial NOR) boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x470[15:8]</td>
<td>SD2_RST_POLARITY_SELECT:</td>
<td>0 - Reset active low 1 - Reset active high</td>
<td>eMMC 4.4 - RESET TO PRE-IDLE STATE</td>
<td>Override HYS bit for SD/MMC pads</td>
<td>USDHC_PAD_D_PULL_DOWN:</td>
<td>0 - no action 1 - pull down</td>
<td>ENABLE_EMMC_22K_PULLUP:</td>
<td>0 - 47K pullup 1 - 22K pullup</td>
</tr>
<tr>
<td>0x470[23:16]</td>
<td>Reserved</td>
<td>LPB_BOOT: (Core / Bus) '00' - LPB Disable '01' - 1 GPIO (def freq) '10' - Div by 2 '11' - Div by 4</td>
<td>Reserved</td>
<td>Boot Failure Indicator Pin Select[3:0]</td>
<td>00000 - gpio1.IO00 00001 - gpio1.IO01 ... 11111 - gpio1.IO31</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x470[31:24]</td>
<td>Override NAND Pad Settings (using PAD_SETTING value)</td>
<td>MMC_DLL_DLY[6:0]: Delay target for SD/eMMC DLL, it is applied to slave mode target delay or override mode target delay depends on DLL Override fuse bit value. DELAYCELL_NUM (FlexSPI NOR): &quot;000&quot; - DLL Override feature is disabled &quot;001-111&quot; - DLL Override feature is enabled Note: Please refer to the Reference Manual for pins which gpio1.IOxx will be muxed to by default</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

See OVRDVAL in FLEXSPI chapter in the Reference Manual for more details

### Table 22-3. SD boot fusemap

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[7:0] (BOOT_CFG1)</td>
<td>0</td>
<td>1</td>
<td>SD/SDXC Speed: 00 - Normal/SDR12 01 - High/SDR25 10 - SDR50 11 - SDR104</td>
<td>SD Power Cycle Enable: '0' - No power cycle '1' - Enabled via USDHC_RS T pad</td>
<td>SD Loop back Clock Source Select: (for SDR50 and SDR104 only) '0' - through SD pad '1' - direct</td>
<td>Port Select: 0 - eSDHC1 1 - eSDHC2</td>
<td>Fast Boot: 0 - Regular 1 - Fast Boot</td>
<td></td>
</tr>
<tr>
<td>0x450[15:8] (BOOT_CFG2)</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Bus Width: 0 - 1-bit</td>
<td>SD1 Voltage Selection:</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 22-3. SD boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[23:16] (BOOT_CFG3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0x450[31:24] (BOOT_CFG4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[7:0]</td>
<td>Reserved</td>
<td>FORCE_COLD_BOOT (SBMR)</td>
<td>BT_FUSE_SEL</td>
<td>Reserved</td>
<td>BOOT_FREQ (ARM/BSU)</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>0x460[15:8]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved (SDR config)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[23:16]</td>
<td>Reserved</td>
<td>WDOG_ENABLE</td>
<td>Reserved</td>
<td>DAP_SJC_SWD_SEL</td>
<td>SDP_READ_DISABLE</td>
<td>SDP_DISABLE</td>
<td>FORCE_INTERNAL_BOOT</td>
<td></td>
</tr>
<tr>
<td>0x460[31:24]</td>
<td>SD_PWR_CYCLE_SELECTION:</td>
<td>PWR_STABLE_CYCLE_SELECTION:</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>NAND_ECC_DISABLE</td>
<td>DLL_ENABLE</td>
<td></td>
</tr>
<tr>
<td>0x470[7:0]</td>
<td>DLL Override:</td>
<td>SD1_RST_POLARITY_SELECT:</td>
<td>SD2_VOLTAGE_SELECTION:</td>
<td>UART Serial Download Disable:</td>
<td>Disable SDMMC Manufacture mode:</td>
<td>L1 I-Cache DISABLE</td>
<td>L1 D-Cache DISABLE:</td>
<td>Override Pad Settings (using PAD_SETTNGS value)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 22-3. SD boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x470[23:16]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>USDHC_CMD_OE_PR_E_EN (SD/MMC debug)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPB_BOOT: (Core / Bus)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>'00' - Div by 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>'01' - Div by 2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>'10' - Div by 4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>'11' - Div by 8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Boot Failure Indicator Pin Select[3:0]</td>
</tr>
<tr>
<td>00000 - gpio1.IO00</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>00001 - gpio1.IO01</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>...</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11111 - gpio1.IO31</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Note: Please refer RM for pins which gpio1.IOxx will be muxed to by default</td>
</tr>
<tr>
<td>0x470[31:24]</td>
<td>Override NAND Pad Settings (using PAD_SETTNGS value)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MMC_DLL_DLY[6:0]:</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Delay target for SD/eMMC DLL, it is applied to slave mode target delay or override mode target delay depends on DLL Override fuse bit value.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DELAY_CELL_NUM (FlexSPI NOR):</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>&quot;000&quot; - DLL Override feature is disabled</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>&quot;001-111&quot; - DLL Override feature is enabled,</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>See OVRDVAL in FLEXSPI chapter in RM for more details</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Table 22-4. MMC/eMMC boot fusemap

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[7:0] (BOOT_CFG1)</td>
<td>1</td>
<td>0</td>
<td>SD/MMC Speed: 0 - Normal 1 - High</td>
<td>Fast Boot Acknowledged Enable: 0 - Boot Ack Disabled 1 - Boot Ack Enabled</td>
<td>SD Power Cycle Enable: '0' - No power cycle '1' - Enabled via USDHC_RS T pad</td>
<td>SD Loop back Clock Source Select: (for SDR50 and SDR104 only) '0' - through SD pad '1' - direct</td>
<td>Port Select: 0 - eSDHC1 1 - eSDHC2</td>
<td>Fast Boot: 0 - Regular 1 - Fast Boot</td>
</tr>
<tr>
<td>0x450[15:8] (BOOT_CFG2)</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Bus Width: 01 - 4-bit 01 - 8-bit 10 - 4-bit DDR(MMC 4.4) 11 - 8-bit DDR(MMC 4.4)</td>
<td>SD1 Voltage Selection: 0 - 3.3V 1 - 1.8V</td>
<td></td>
</tr>
<tr>
<td>0x450[23:16] (BOOT_CFG3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x450[31:24] (BOOT_CFG4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[7:0]</td>
<td>Reserved</td>
<td>FORCE_COLD_BOOT(T(SBMR)</td>
<td>BT_FUSE_SEL</td>
<td>Reserved</td>
<td>BOOT_FREQ(ARM/BSU) 0 - 396/132 MHz</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>
## Table 22-4. MMC/eMMC boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x460[15:8]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>WDOG_EN</td>
<td>DAP_SJC_SDW_SEL</td>
<td>SDP_READ_DISABLE</td>
<td>SDP_DISABLE</td>
</tr>
<tr>
<td>0x460[23:16]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>PWR_STABLE_CYCLE_SELECTIO_N:</td>
<td>'0' - Disable</td>
<td>'1' - Enabled</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x470[7:0]</td>
<td>DLL Override:</td>
<td>0 - DLL Slave Mode for SD/eMMC</td>
<td>1 - DLL Override Mode for SD/eMMC</td>
<td>SD_RST_POLARITY_SELECT:</td>
<td>0 - Reset active low</td>
<td>1 - Reset active high</td>
<td>SD2_VOLTAGE_SELECTIO_N:</td>
</tr>
</tbody>
</table>
| 0x470[15:8] | SD2\_RST\_POLARITY\_SELECT: | 0 - Reset active low | 1 - Reset active high | eMMC\_4.4\_RESET TO PRE-IDLE STATE | Override HYS bit for SD/MMC pads | USDHC\_PA
| 0x470[23:16]| USDHC\_CMD\_OE\_PR\_E\_EN (SD/MMC debug) | LPB\_BOOT: (Core / Bus) | '00' - Div by 1 | '01' - Div by 2 | '10' - Div by 4 | '11' - Div by 8 | Reserved | Boot Failure Indicator Pin Select[3:0] | 00000 - gpio1.IO00 | 00001 - gpio1.IO01 | ... | 11111 - gpio1.IO31 |
| 0x470[31:24] | Override NAND Pad Settings (using PAD\_SETTNG value) | MMC\_DLL\_DL\_Y[6:0]: Delay target for SD/eMMC DLL, it is applied to slave mode target delay or override mode target delay depends on DLL Override fuse bit value. | 000000 - gpio1.IO00 | 000001 - gpio1.IO01 | ... | 111111 - gpio1.IO31 | Note: Please refer RM for pins which gpio1.IOxx will be muxed to by default |

### Note:
- Please refer to the reference manual for more details on specific fuse settings and their effects on the i.MX RT1060 processor.
### Table 22-4. MMC/eMMC boot fusemap

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

"001-111" - DLL Override feature is enabled, See OVRDVAL in FLEXSPI chapter in RM for more details

### Table 22-5. SEMC (NAND) boot fusemap

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[7:0] (BOOT_CFG1)</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BOOT_SEARCH_STRIDE</td>
<td>Search stride for FCB and DBBT</td>
<td>Search strides in terms of page</td>
<td>0000 - 64</td>
<td>Other value - (2^{(\text{BOOT SEARCH STRIDE})})</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BOOT_SCA</td>
<td>RCH_COU</td>
<td>NT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 - 1</td>
<td>1 - 2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x450[15:8] (BOOT_CFG2)</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>DOS</td>
<td>disable:</td>
<td>0 - disabled</td>
</tr>
<tr>
<td>ECC_ALG_</td>
<td>SEL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Disable:</td>
<td>0 - SW ECC selected</td>
<td>1 - Device ECC selected</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ONFI</td>
<td>compliant:</td>
<td>0 - Yes, ONFI</td>
<td>1 - No, spec</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x450[23:16] (BOOT_CFG3)</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x450[31:24] (BOOT_CFG4)</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[7:0]</td>
<td>Reserved</td>
<td>FORCE_COLD_BOOT(SBMR)</td>
<td>Reserved</td>
<td>BT_FUSE_SEL</td>
<td>Reserved</td>
<td>BOOT_FREQ (ARM/BSU)</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0 - 396/132 MHz</td>
<td>1 - 528/132 MHz</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[15:8]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved (SDR config)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[23:16]</td>
<td>Reserved</td>
<td>WDOG_ENABLED</td>
<td>Reserved</td>
<td>DAP_SJC_SWD_SEL</td>
<td>Reserved</td>
<td>SDP_READ_DISABLE</td>
<td>SDP_DISABLE</td>
<td>FORCE_INTERNAL_BOOT</td>
</tr>
<tr>
<td>'0' - Disabled</td>
<td>'1' - Enabled</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[31:24]</td>
<td>SD_PWR_CYCLE_SELECTION:</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>NAND_ECC_DISABLE</td>
<td>Reserved</td>
<td>DLL_ENABLE</td>
<td></td>
</tr>
<tr>
<td>'00' - 20ms</td>
<td>'01' - 10ms</td>
<td>'10' - 5ms</td>
<td>'11' - 2.5ms</td>
<td>'0' - 5ms</td>
<td>'1' - 2.5ms</td>
<td>0 - NAND ECC is enabled</td>
<td>0 - Disable DLL for SD/eMMC</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 22-5. SEMC (NAND) boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x470[7:0]</td>
<td>DLL Override:</td>
<td>SD1_RST_POLARITY_SELECT:</td>
<td>SD2_VOLTAGE_SELECTIO N</td>
<td>UART Serial Download Disable:</td>
<td>Disable SDMMC Manufacture mode:</td>
<td>L1 I-Cache DISABLE</td>
<td>L1 D-Cache DISABLE:</td>
<td>Override Pad Settings (using PAD_SETTNGS value)</td>
</tr>
<tr>
<td></td>
<td>0 - DLL Slave Mode for SD/ eMMC</td>
<td>0 - Reset active low</td>
<td>0 - 3.3V</td>
<td>'0' - Not Disable</td>
<td>0 - Enable</td>
<td>0 - NAND ECC is disabled</td>
<td>1 - Enable DLL for SD/ Emmc</td>
<td></td>
</tr>
<tr>
<td></td>
<td>1 - DLL Override Mode for SD/eMMC</td>
<td>1 - Reset active high</td>
<td>1 - 1.8V</td>
<td>'1' - Disable</td>
<td>1 - Disable</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x470[15:8]</td>
<td>SD2_RST_POLARITY_SELECT:</td>
<td>eMMC 4.4 - RESET TO PRE-IDLE STATE</td>
<td>Override HYS bit for SD/MMC pads</td>
<td>USDHC_PA D_PULL_D OWN:</td>
<td>ENABLE_EMMC_22K_PULLUP:</td>
<td>Boot Failure Indicator Pin Select[4]</td>
<td>USDHC_IOMUX_SION_BIT_ENABLE:</td>
<td></td>
</tr>
<tr>
<td></td>
<td>0 - Reset active low</td>
<td>0 - no action</td>
<td>0 - 47K pullup</td>
<td>0 - Disable</td>
<td>0 - Disable</td>
<td>0 - Disable</td>
<td>0 - Disable</td>
<td></td>
</tr>
<tr>
<td></td>
<td>1 - Reset active high</td>
<td>1 - pull down</td>
<td>1 - 22K pullup</td>
<td>1 - Enable</td>
<td>1 - Enable</td>
<td>1 - Enable</td>
<td>1 - Enable</td>
<td></td>
</tr>
<tr>
<td>0x470[23:16]</td>
<td>USDHC_CMD_OE_PR E_EN (SD/MMC debug)</td>
<td>LPB_BOOT: (Core / Bus)</td>
<td>Reserved</td>
<td>Boot Failure Indicator Pin Select[3:0]</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'00' - Div by 1</td>
<td></td>
<td>00000 - gpio1.IO00</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'01' - Div by 2</td>
<td></td>
<td>00001 - gpio1.IO01</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'10' - Div by 4</td>
<td></td>
<td>...</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'11' - Div by 8</td>
<td></td>
<td>11111 - gpio1.IO31</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Note: Please refer RM for pins which gpio1.IOxx will be muxed to by default</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x470[31:24]</td>
<td>Override NAND Pad Settings (using PAD_SETTNGS value)</td>
<td>MMC_DLL_DLY[6:0]:</td>
<td>Delay target for SD/eMMC DLL, it is applied to slave mode target delay or override mode target delay depends on DLL Override fuse bit value.</td>
<td>DELAY_CELL_NUM (FlexSPI NOR):</td>
<td>&quot;000&quot; - DLL Override feature is disabled</td>
<td>&quot;001-111&quot; - DLL Override feature is enabled,</td>
<td>See OVRDVAL in FLEXSPI chapter in RM for more details</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>&quot;000&quot; - DLL Override feature is disabled</td>
<td>&quot;001-111&quot; - DLL Override feature is enabled,</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Table 22-6. SEMC (NOR) boot fusemap

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[7:0] (BOOT_CFG1)</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Reserved</td>
<td>Clock Freq:</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>000 - 33MHz</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>001 - 66MHz</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>010 - 108MHz</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>011 - 133MHz</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 22-6. SEMC (NOR) boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[15:8]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>DQS Disable:</td>
<td>0 - disabled</td>
<td>1 - enabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Data Port Size:</td>
<td>0 - 16 bit</td>
<td>1 - 8 bit</td>
</tr>
<tr>
<td>(BOOT_CFG2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>AC Timing</td>
<td>0 - Default</td>
<td>1 - Fuse (0x6E0)</td>
</tr>
<tr>
<td>0x450[23:16]</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>(BOOT_CFG3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x450[31:24]</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>(BOOT_CFG4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[15:8]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[15:8]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>WDOG_ENABLE:</td>
<td>'0' - Disabled</td>
<td>'1' - Enabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>(BOOT_CFG5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[23:16]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>DAP_SJC_SWD_SEL</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[31:24]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x470[7:0]</td>
<td>DLL Override:</td>
<td>SD_PWR_CYCLE_SELECTION:</td>
<td>SD1_RST_POLARITY_SELECT:</td>
<td>SD2_VOLTAGE_SELECTIO N:</td>
<td>UART Serial Download Disable:</td>
<td>Disable SDMMC Manufacture mode:</td>
<td>L1 I-Cache DISABLE:</td>
<td>L1 D-Cache DISABLE:</td>
</tr>
<tr>
<td></td>
<td>0 - DLL Slave Mode for SD/eMMC</td>
<td>'00' - 20ms</td>
<td>0 - Reset active low</td>
<td>0 - 3.3V</td>
<td>'0' - Not Disable</td>
<td>0 - Enable</td>
<td>0 - Enable</td>
<td>0 - Enable</td>
</tr>
<tr>
<td></td>
<td>1 - DLL Override Mode for SD/eMMC</td>
<td>'01' - 10ms</td>
<td>1 - Reset active high</td>
<td>1 - 1.8V</td>
<td>'1' - Disable</td>
<td>1 - Disable</td>
<td>1 - Disable</td>
<td>1 - Disable</td>
</tr>
<tr>
<td></td>
<td></td>
<td>'10' - 5ms</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'11' - 2.5ms</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x470[15:8]</td>
<td>SD2_RST_POLARITY_SELECT:</td>
<td>eMMC 4.4 - RESET TO PRE-IDLE STATE</td>
<td>Override HYS bit for SD/MMC pads</td>
<td>USDHC_PADD_PULL_DOWN:</td>
<td>ENABLE_EMMC_22K_PULLUP:</td>
<td>Boot Failure Indicator Pin Select[4]</td>
<td>USDHC_IOMUX_MUX_SION_BIT_ENABLE:</td>
<td>USDHC_IOMUX_SRE Enable:</td>
</tr>
<tr>
<td></td>
<td>0 - Reset active low</td>
<td></td>
<td>0 - no action</td>
<td>0 - no action</td>
<td>0 - 47K pullup</td>
<td></td>
<td>0 - Disable</td>
<td>0 - Disable</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 22-6. SEMC (NOR) boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x470[23:16]</td>
<td></td>
<td></td>
<td></td>
<td>1 - pull down</td>
<td>1 - 22K pullup</td>
<td>1 - Enable</td>
<td>1 - Enable</td>
<td></td>
</tr>
<tr>
<td>USDHC_C</td>
<td></td>
<td></td>
<td></td>
<td>LPB_BOOT: (Core / Bus)</td>
<td>Reserved</td>
<td>Boot Failure Indicator Pin Select[3:0]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>MD_OE_PR</td>
<td></td>
<td></td>
<td></td>
<td>'00' - Div by 1</td>
<td>Reserved</td>
<td>00000 - gpio1.IO00</td>
<td></td>
<td></td>
</tr>
<tr>
<td>E_EN (SD/MMC debug)</td>
<td></td>
<td></td>
<td></td>
<td>'01' - Div by 2</td>
<td>00001 - gpio1.IO01</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>'10' - Div by 4</td>
<td></td>
<td>...</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>'11' - Div by 8</td>
<td>11111 - gpio1.IO31</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Note: Please refer RM for pins which gpio1.IOxx will be muxed to by default</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Table 22-7. FlexSPI1 (Serial NAND) boot fusemap

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x450[7:0]</td>
<td></td>
<td></td>
<td></td>
<td>SAFE FREQ: (Default safe communication frequency)</td>
<td>Reserved</td>
<td>SPI NAND HOLD TIME:</td>
<td>Reserved</td>
<td>BOOT_SEARCH_STRIDE:</td>
</tr>
<tr>
<td>(BOOT_CFG1)</td>
<td>1</td>
<td>1</td>
<td></td>
<td>0 – High Speed (50MHz)</td>
<td>00 - 0us</td>
<td>00 - 0us</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 – Low Speed (30MHz)</td>
<td>01 - 500us</td>
<td>01 - 500us</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>COL_ADDR:</td>
<td>10 - 1ms</td>
<td>10 - 1ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ESS_WIDT:</td>
<td>11 - 3ms</td>
<td>11 - 3ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>H:</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 – 12bits</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 – 13bits</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x450[15:8]</td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>BOOT_SELECT:</td>
</tr>
<tr>
<td>(BOOT_CFG2)</td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>CS_INTERVAL:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>CS deasserted interval between two commands</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>0 – 100ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>1 – 200ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>2 – 400ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>3 – 50ns</td>
</tr>
<tr>
<td>0x450[23:16]</td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>BOOT_SEARCH_STRIDE:</td>
</tr>
<tr>
<td>(BOOT_CFG3)</td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>0 - 1</td>
</tr>
<tr>
<td>0x450[31:24]</td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>1 - 2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>(BOOT_CFG4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x460[7:0]</td>
<td>Reserved</td>
<td>FORCE_COLD_BOOT(SBMR)</td>
<td>BT_FUSE_SEL</td>
<td>Reserved</td>
<td>BOOT_FREQ Q (ARM/BSU)</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[15:8]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>(SDR config)</td>
<td></td>
</tr>
<tr>
<td>0x460[23:16]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>WDOG_ENABLE</td>
<td>Reserved</td>
<td>DAP_SJC_SWD_SEL</td>
<td>SDP_READ_DISABLE</td>
<td>SDP_DISABLE</td>
<td>FORCE_INTERNAL_BOOT</td>
</tr>
<tr>
<td>0x470[7:0]</td>
<td>Reserved</td>
<td>SD_PWR_CYCLE_SELECTION:</td>
<td>SD1_RST_POLARITY_SELECT:</td>
<td>SD2_VOLTAGE_SELECTION:</td>
<td>UART Serial Download Disable:</td>
<td>Disable SDMMC Manufacturer mode:</td>
<td>L1 I-Cache DISABLE</td>
<td>L1 D-Cache DISABLE:</td>
</tr>
<tr>
<td>0x470[23:16]</td>
<td>Reserved</td>
<td>LPB_BOOT: (Core / Bus)</td>
<td>Boot Failure Indicator Pin Select[3:0]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 22-7. FlexSPI1 (Serial NAND) boot fusemap (continued)
Table 22-7. FlexSPI1 (Serial NAND) boot fusemap (continued)

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x470[31:24]</td>
<td>Override NAND Pad Settings (using PAD_SETTNGS value)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Note: Please refer RM for pins which gpio1.IOxx will be muxed to by default</td>
</tr>
</tbody>
</table>

**Table 22-8. Lock fuses**

<table>
<thead>
<tr>
<th>Address</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x400[7:0]</td>
<td>Reserved</td>
<td>SJC_RESP_LOCK</td>
<td>Reserved</td>
<td>BOOT_CFG_LOCK</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0- Unlock</td>
<td></td>
<td>00- Unlock</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'1' - WP, OP, RP</td>
<td></td>
<td>'1x' - OP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>'x1' - WP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x400[15:8]</td>
<td>Reserved</td>
<td>GP2_LOCK</td>
<td>GP1_LOCK</td>
<td>MAC_ADDR_LOCK</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>00- Unlock</td>
<td></td>
<td>00- Unlock</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'1x' - OP</td>
<td></td>
<td>'1x' - OP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>'x1' - WP</td>
<td></td>
<td>'x1' - WP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x400[23:16]</td>
<td>Reserved</td>
<td>MISC_CONF_LOCK '1' - WP + OP</td>
<td>Reserved</td>
<td>ANALOG_LOCK</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00- Unlock</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>'1x' - OP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>'x1' - WP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x400[31:24]</td>
<td>Reserved</td>
<td>Reserved</td>
<td>GP3_LOCK</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>'1x' - OP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>'x1' - WP</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTE**

Do NOT program *Reserved* bits that are not security related (mentioned in the SRM).
### 22.3 Fusemap Descriptions Table

This section describes the chip fusemap descriptions.

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x400[1:0]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 0x400[3:2]   | BOOT_CFG_LOC K     | 2               | Perform lock on BOOT related fuses. | 00 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register)  
               |                    |                               | x1 - Write Lock (The controlled field can be read or sensed only)       |           | N/A       |
|              |                    |                 |                                 | 1x - Operation Lock (The controlled field can't be overridden)           |           |
| 0x400[5:4]   | Reserved           | 2               | Reserved                        | Reserved                                                                | Reserved  |
| 0x400[6]     | SJC_RESP_LOC K     | 1               | SJC response lock               | 0 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register)  
               |                    |                               | 1 - Lock (The controlled field can't be read, sensed, burned or overridden in the corresponded IIM register) |           | N/A       |
| 0x400[7]     | Reserved           | 1               | Reserved                        | Reserved                                                                | Reserved  |
| 0x400[9:8]   | MAC_ADDR_LOC K     | 2               | Lock MAC_ADDR fuses.            | 00 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register)  
               |                    |                               | x1 - Write Lock (The controlled field can be read or sensed only)       |           | N/A       |
|              |                    |                 |                                 | 1x - Operation Lock (The controlled field can't be overridden)           |           |
| 0x400[11:10] | GP1_LOCK           | 2               | Lock for General Purpose fuse register #1 (GP1) | 00 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register)  
               |                    |                               | x1 - Write Lock (The controlled field can be read or sensed only)       |           | N/A       |
|              |                    |                 |                                 | 1x - Operation Lock (The controlled field can't be overridden)           |           |

*Table continues on the next page...*
### Table 22-9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x400[13:12]</td>
<td>GP2_LOCK</td>
<td>2</td>
<td>Lock for General Purpose fuse register #2 (GP2)</td>
<td>00 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register) x1 - Write Lock (The controlled field can be read or sensed only) 1x - Operation Lock (The controlled field can't be overridden)</td>
<td>N/A</td>
</tr>
<tr>
<td>0x400[14]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x400[15]</td>
<td>Reserved</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[16]</td>
<td>SW_GP1_LOCK</td>
<td>1</td>
<td>Lock for SW_GP1 fuse.</td>
<td>0 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register) 1 - Lock (The controlled field can't be sensed, burned or overridden in the corresponded IIM register)</td>
<td>N/A</td>
</tr>
<tr>
<td>0x400[17]</td>
<td>Reserved</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[19:18]</td>
<td>ANALOG_LOCK</td>
<td>2</td>
<td>Lock for analog related fuse.</td>
<td>00 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register) x1 - Write Lock (The controlled field can be read or sensed only) 1x - Operation Lock (The controlled field can't be overridden)</td>
<td>N/A</td>
</tr>
<tr>
<td>0x400[20]</td>
<td>Reserved</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[21]</td>
<td>Reserved</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[22]</td>
<td>MISC_CONF_Lock</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>N/A</td>
</tr>
<tr>
<td>0x400[23]</td>
<td>Reserved</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[24]</td>
<td>Reserved</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[25]</td>
<td>Reserved</td>
<td>1</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[25:24]</td>
<td>Reserved</td>
<td>2</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
<tr>
<td>0x400[27:26]</td>
<td>GP3_LOCK</td>
<td>2</td>
<td>Lock for GP3 fuse</td>
<td>0 - Unlock (The controlled field can be read, sensed, burned or overridden in the corresponded IIM register) x1 - Write Lock (The controlled field can be read or sensed only) 1x - Operation Lock (The controlled field can't be overridden)</td>
<td>N/A</td>
</tr>
<tr>
<td>0x400[29:28]</td>
<td>Reserved</td>
<td>2</td>
<td>reserved</td>
<td>reserved</td>
<td>reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 22-9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x400[30]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x400[31]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x420 - 0x410</td>
<td>SJC_CHALL/UNIQUE_ID[63:0]</td>
<td>64</td>
<td>SJC CHALLENGE / Unique ID</td>
<td>N/A</td>
<td></td>
</tr>
<tr>
<td>0x430[7:0]</td>
<td>Reserved</td>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[15:8]</td>
<td>Reserved</td>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[19:16]</td>
<td>SI_REV[3:0]</td>
<td>4</td>
<td>Silicon Revision number</td>
<td>N/A</td>
<td></td>
</tr>
<tr>
<td>0x430[20]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[21]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[22]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[23]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[24]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[25]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[26]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[27]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[28]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[29]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[30]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x430[31]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[0]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[1]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[2]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[3]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[4]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[5]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[6]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[7]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[8]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[9]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[10]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[11]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[12]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[13]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[14]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[15]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[17:16]</td>
<td>SPEED_GRAD[1:0]</td>
<td>2</td>
<td>Burned by tester program, for indicating IC core speed</td>
<td>FRAL[0:1] MHz P/N Code 00 Reserved 01 500 05</td>
<td>TESTER_LOCK</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 22.9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x440[19:18]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>10 600 06</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[20]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>11 Reserved Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[21]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[23:22]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[24]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[25]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[26]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[27]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[28]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[29]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[30]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x440[31]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x450[7:0]</td>
<td>BOOT_CFG1</td>
<td>8</td>
<td>BOOT configuration register #1, Usage varies, depending on selected boot device.</td>
<td>0x0000 - FlexSPI (NOR) boot 0x01xx - SD boot 0x10xx - MMC/eMMC boot 0x0001 - SEMC (NAND) boot 0x001x - SEMC (NOR) boot 0x10xx - FlexSPI (serial NAND) boot Others - Reserved Refer to Fuse Map for details.</td>
<td>BOO.FR_CFG_LOCK</td>
</tr>
<tr>
<td>0x450[15:8]</td>
<td>BOOT_CFG2</td>
<td>8</td>
<td>BOOT configuration register #2, Usage varies, depending on selected boot device.</td>
<td>See fuse-map tab for details.</td>
<td>BOO.FR_CFG_LOCK</td>
</tr>
<tr>
<td>0x450[23:16]</td>
<td>BOOT_CFG3</td>
<td>8</td>
<td>BOOT configuration register #3</td>
<td>See fuse-map tab for details.</td>
<td>BOO.FR_CFG_LOCK</td>
</tr>
<tr>
<td>0x450[31:24]</td>
<td>BOOT_CFG4</td>
<td>8</td>
<td>BOOT configuration register #4</td>
<td>See fuse-map tab for details.</td>
<td>BOO.FR_CFG_LOCK</td>
</tr>
<tr>
<td>0x460[0]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[1]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[2]</td>
<td>BOO_FREQ</td>
<td>1</td>
<td>Determines, ARM Core and Bus frequencies during boot</td>
<td>0 - (ARM) 396 / (Bus) 132 MHz 1 - (ARM) 528 / (Bus) 132 MHz</td>
<td>BOO.FR_CFG_LOCK</td>
</tr>
<tr>
<td>0x460[3]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserve Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[4]</td>
<td>BT_FUSE_SEL</td>
<td>1</td>
<td>Determines, whether using fuses for boot configuration, or GPIO / Serial loader</td>
<td>If boot_mode=&quot;10&quot; (internal boot) 0=Boot mode configuration is taken from GPIOs.</td>
<td>BOO.FR_CFG_LOCK</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 22-9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x460[5]</td>
<td>FORCE_COLD_BOOT(SBMR)</td>
<td>1</td>
<td>Force cold boot when core comes out of reset. Reflected in SBMR register of SRC</td>
<td>1 - Boot mode configuration is taken from fuses.</td>
<td>BOOT CF G_LOCK</td>
</tr>
<tr>
<td>0x460[6]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[7]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[11:8]</td>
<td>SDRAM_CONFIG[7:0]</td>
<td>4</td>
<td>(SDRAM config options)</td>
<td>Reserved</td>
<td>BOOT CF G_LOCK</td>
</tr>
<tr>
<td>0x460[13:12]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[15:14]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[16]</td>
<td>FORCE_INTERNAL_BOOT</td>
<td>1</td>
<td>After this fuse is blown, the external BT_MODE[1:0] pins will be ignored, BootROM will take Boot Mode as &quot;internal boot.&quot;</td>
<td>0 - Boot Mode from BT_MODE pins</td>
<td>BOOT CF G_LOCK</td>
</tr>
<tr>
<td>0x460[17]</td>
<td>SDP_DISABLE</td>
<td>1</td>
<td>Disable/Enable serial download support</td>
<td>0 - Serial download supported</td>
<td>BOOT CF G_LOCK</td>
</tr>
<tr>
<td>0x460[18]</td>
<td>SDP_READ_DISABLE</td>
<td>1</td>
<td>Disable/Enable serial download READ_REGISTER command.</td>
<td>0 - SDP READ_REGISTER command is enabled</td>
<td>BOOT CF G_LOCK</td>
</tr>
<tr>
<td>0x460[19]</td>
<td>DAP_SJC_SWD_SEL</td>
<td>1</td>
<td>Control DAP works in JTAG or SWD mode</td>
<td>0 - DAP works in SWD mode</td>
<td>BOOT CF G_LOCK</td>
</tr>
<tr>
<td>0x460[20]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[21]</td>
<td>WDOG_ENABLE</td>
<td>1</td>
<td>Watchdog Enable</td>
<td>Used to specify whether to enable / not watchdog at boot.</td>
<td>BOOT CF G_LOCK</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 22-9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x460[23:22]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[24]</td>
<td>DLL_ENABLE</td>
<td>1</td>
<td>Controls the enable/disable of the DLL for SD/eMMC boot</td>
<td>0 - Disable DLL for SD/eMMC</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Enable DLL for SD/eMMC</td>
<td></td>
</tr>
<tr>
<td>0x460[25]</td>
<td>NAND_ECC_DISABLE</td>
<td>1</td>
<td>Indicate whether to enabled ECC (done by SW/Device HW) for Raw Nand device</td>
<td>0 - NAND ECC is enabled</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0 - NAND ECC is disabled</td>
<td></td>
</tr>
<tr>
<td>0x460[26]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[27]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x460[28]</td>
<td>Reserved</td>
<td>1</td>
<td></td>
<td></td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x460[29]</td>
<td>PWR_STABLE_CYCLE_SELECTION</td>
<td>1</td>
<td>Select Power Stable Cycle</td>
<td>0 - 5ms</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - 2.5ms</td>
<td></td>
</tr>
<tr>
<td>0x460[31:30]</td>
<td>SD_PWR_CYCLE_SELECTION</td>
<td>2</td>
<td>Select SD Power Cycle</td>
<td>00 - 20ms</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - 10ms</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - 5ms</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11 - 2.5ms</td>
<td></td>
</tr>
<tr>
<td>0x470[0]</td>
<td>Override SD Pad Settings</td>
<td>1</td>
<td>Overrides ROM default value for SD PAD control register. When set ROM will override SD pad control register with value programmed into PAD_SETTINGS fuse bits.</td>
<td></td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x470[1]</td>
<td>BT_MPU_DISABLE</td>
<td>1</td>
<td>The fuse bit is used for ROM to not enable MMU</td>
<td>0 - MPU is enabled during boot</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - MPU is disabled during boot</td>
<td></td>
</tr>
<tr>
<td>0x470[2]</td>
<td>L1 I-Cache DISABLE</td>
<td>1</td>
<td>The fuse bit is used for ROM to not enable L1 I-Cache</td>
<td>0 - L1 I-Cache is enabled during boot</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - L1 I-Cache is disabled during boot</td>
<td></td>
</tr>
<tr>
<td>0x470[3]</td>
<td>Disable SDMMC Manufacture mode</td>
<td>1</td>
<td>The fuse bit is used to disable ROM feature “SD/MMC Manufacturing Mode”.</td>
<td>0 - Enable 1 – Disable</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x470[4]</td>
<td>UART Serial Download Disable</td>
<td>1</td>
<td>Disable UART Serial Download</td>
<td>0 - Disable 1 - Enable</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x470[5]</td>
<td>SD2 VOLTAGE SELECTION</td>
<td>1</td>
<td>Fuse bit to change voltage selection for SD2 pads. When set ROM will select 1.8V for SD3 pads otherwise 3.3V</td>
<td>0 - 3.3V 1 - 1.8V</td>
<td>BOOT_CF G_LOCK</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x470[6]</td>
<td>SD1_RST_Polarity_SELECT</td>
<td>1</td>
<td>Select reset polarity for SD1</td>
<td>0 - Reset active low</td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Reset active high</td>
<td>G_LOCK</td>
</tr>
<tr>
<td>0x470[7]</td>
<td>DLL Override</td>
<td>1</td>
<td>Select the DLL mode for SD/eMMC.</td>
<td>0 - DLL Slave Mode for SD/ eMMC</td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - DLL Override Mode for SD/ eMMC</td>
<td>G_LOCK</td>
</tr>
<tr>
<td>0x470[8]</td>
<td>USDHC_IOMUX_SRE_Enable</td>
<td>1</td>
<td>The fuse bit is used for ROM to enable SRE bit for SD pads</td>
<td>0 - Disable</td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Enable</td>
<td>G_LOCK</td>
</tr>
<tr>
<td>0x470[9]</td>
<td>USDHC_IOMUX_SION_BIT_ENABLE</td>
<td>1</td>
<td>The fuse bit is used for ROM to enable SION bit for MUX control register.</td>
<td>0 - Disable</td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - Enable</td>
<td>G_LOCK</td>
</tr>
<tr>
<td>0x470[10]</td>
<td>Boot Failure Indicator Pin Select[4]</td>
<td>1</td>
<td>Indicate Boot Failure</td>
<td>00000 - gpio1.IO00</td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>00001 - gpio1.IO01</td>
<td>G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11111 - gpio1.IO31</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Note: Please refer RM for pins which gpio1.IOxx will be muxed to by default</td>
<td></td>
</tr>
<tr>
<td>0x470[11]</td>
<td>ENABLE_EMMC_22K_PULLUP</td>
<td>1</td>
<td>The fuse bit is used for ROM to enable 22K pullup for SD pads.</td>
<td>0 - 47K pullup</td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - 22K pullup</td>
<td>G_LOCK</td>
</tr>
<tr>
<td>0x470[12]</td>
<td>USDHC_PAD_PULL_DOWN</td>
<td>1</td>
<td>The fuse bit is used for ROM to enable pull down bit for SD pads.</td>
<td>0 - no action</td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - pull down</td>
<td>G_LOCK</td>
</tr>
<tr>
<td>0x470[13]</td>
<td>Override HYS bit for SD/MMC pads</td>
<td>1</td>
<td>After this fuse is blown, the [HYS] bit of IOMUXC_SW_PAD_CTL_PAD_SDx_CLK (x is the SD port which the ROM boot from), IOMUXC_SW_PAD_CTL_PAD_SDx_CMD, IOMUXC_SW_PAD_CTL_PAD_SDx_DAT0-n (n will be 0, 3, or 7, depends on the bus width selected) will be set.</td>
<td></td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>G_LOCK</td>
</tr>
<tr>
<td>0x470[14]</td>
<td>eMMC 4.4 - RESET TO PRE-IDLE STATE</td>
<td>1</td>
<td>After this fuse is blown, the CMD0 with argument 0xf0f0f0 will be sent to put the eMMC card into pre-IDLE state so that eMMC card's fast boot can work properly. This is useful for the warm</td>
<td></td>
<td>BOOT_CF</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>G_LOCK</td>
</tr>
</tbody>
</table>
Table 22-9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x470[15]</td>
<td>SD2_RST_POLARITY_SELECT</td>
<td>1</td>
<td>Select reset polarity for SD2</td>
<td>0 - Reset active low&lt;br&gt;1 - Reset active high</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>boot, such as boot due to the WDOG reset.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x470[19:16]</td>
<td>Boot Failure Indicator Pin Select[3:0]</td>
<td>4</td>
<td>Misscellanious power management configuration bits.</td>
<td>00000 - gpio1.IO00&lt;br&gt;00001 - gpio1.IO01&lt;br&gt;...&lt;br&gt;11111 - gpio1.IO31</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Note: Please refer RM for pins which gpio1.IOxx will be muxed to by default</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x470[20]</td>
<td>BT_LPB_POLARITY</td>
<td>1</td>
<td>Define GPIO3 polarity, for determining LPB boot mode.</td>
<td>0' - Active High&lt;br&gt;'1' - Active Low</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x470[22:21]</td>
<td>LPB_BOOT</td>
<td>2</td>
<td>Divide (Core / Bus) based on Boot Frequencies</td>
<td>'00' - Div by 1;&lt;br&gt;'01' - Div by 2;&lt;br&gt;'10' - Div by 4;&lt;br&gt;'11' - Div by 8</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x470[23]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x470[30:24]</td>
<td>MMC_DLL_DLY[6:0]</td>
<td>7</td>
<td>eMMC 4.4 delay line default value (set by boot rom), used in conjunction with &quot;DLL Override&quot; = 1 (BOOT_CFG3[3])</td>
<td>Connected to LVDS module.</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x470[31]</td>
<td>Override NAND Pad Settings</td>
<td>1</td>
<td>Override pad settings for NAND boot.</td>
<td>Reserved</td>
<td>BOOT_CF G_LOCK</td>
</tr>
<tr>
<td>0x480[5:0]</td>
<td>Reserved</td>
<td>6</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[7:6]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[15:8]</td>
<td>Reserved</td>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[23:16]</td>
<td>Reserved</td>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[26:24]</td>
<td>Reserved</td>
<td>3</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[27]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[29:28]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[30]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x480[31]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x490[9:0]</td>
<td>Reserved</td>
<td>10</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x490[23:10]</td>
<td>Reserved</td>
<td>14</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x490[27:24]</td>
<td>Reserved</td>
<td>4</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x490[31:28]</td>
<td>Reserved</td>
<td>4</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x4A0[7:0]</td>
<td>Reserved</td>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x4A0[19:8]</td>
<td>Reserved</td>
<td>76</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## Table 22-9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x4C0[31:20]</td>
<td>Reserved</td>
<td>12</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x4D0[31:0]</td>
<td>Reserved</td>
<td>32</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x4E0[31:0]</td>
<td>Reserved</td>
<td>32</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x4F0[15:0]</td>
<td>USB_VID[31:0]</td>
<td>16</td>
<td>USB VID</td>
<td>Reserved</td>
<td>ANALOG_Lock</td>
</tr>
<tr>
<td>0x4F0[31:16]</td>
<td>USB_PID[31:0]</td>
<td>16</td>
<td>USB PID</td>
<td>Reserved</td>
<td>ANALOG_Lock</td>
</tr>
<tr>
<td>0x500[31:0]</td>
<td>Reserved</td>
<td>256</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x580[31:0]</td>
<td>Reserved</td>
<td>256</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x600[23:0]</td>
<td>SJC_RESP[55:0]</td>
<td>56</td>
<td>Response reference value for the secure JTAG controller</td>
<td>SJC_RESP_LOCK</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>(locks also for read and explicit sense)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0x610[31:24]</td>
<td>Reserved</td>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x620[15:0]</td>
<td>MAC1_ADDR[47:0]</td>
<td>48</td>
<td>Ethernet MAC Address</td>
<td>MAC_ADD_R_LOCK</td>
<td></td>
</tr>
<tr>
<td>0x630[31:16]</td>
<td>MAC2_ADDR[47:0]</td>
<td>48</td>
<td>Ethernet2 MAC Address</td>
<td>MAC_ADD_R_LOCK</td>
<td></td>
</tr>
<tr>
<td>0x650[31:0]</td>
<td>Reserved</td>
<td>32</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x660[31:0]</td>
<td>GP1[31:0]</td>
<td>32</td>
<td>General Purpose fuse register #1</td>
<td>GP1_LOCK</td>
<td></td>
</tr>
<tr>
<td>0x670[31:0]</td>
<td>GP2[31:0]</td>
<td>32</td>
<td>General Purpose fuse register #2</td>
<td>GP2_LOCK</td>
<td></td>
</tr>
<tr>
<td>0x680[31:0]</td>
<td>SW_GP1[31:0]</td>
<td>32</td>
<td>SW general purpose key</td>
<td>SW_GP1_LOCK</td>
<td></td>
</tr>
<tr>
<td>0x690[31:0]</td>
<td>Reserved</td>
<td>128</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 0x6D0[5:0]   | PAD_SETTINGS       | 6               | Used with conjunction of MMC/SD/Nand "Override Pad Settings" fuse value, as follow:
|              |                    |                 | '0' - Use IO default settings for boot device IO pads. |
|              |                    |                 | '1' - Use "Override" value, as set by this register. |
|              |                    |                 | I/O pads settings of selected boot interface, are override with this fuses, as follow:  |
|              |                    |                 | [0] - Slew Rate |
|              |                    |                 | [3:1] Drive Strength |
|              |                    |                 | [5:4] - Speed Settings. Refer to IO PAD chapter for "Settings" fields value |
| 0x6D0[6]     | USB_VBUS_EVENT_HANDLER_ENABLE | 1 | Rom handle USB VBUS attach/detach event | 0 - ROM not handle USB VBUS attach/detach event |
|              |                    |                 | 1 - ROM handle USB VBUS attach/detach event |
| 0x6D0[7]     | Enable Boot Failure Indicator Pin | 1 | Enable Boot Failure Indicator Pin | 0 - disabled  |
|              |                    |                 | 1 - enabled |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x6D0[11:8]</td>
<td>READ_RETRY_SEQ_ID</td>
<td>4</td>
<td>Choose Read Retry Sequence</td>
<td>0000 - don't use read retry(RR) sequence embedded in ROM 0001 - Micron 20nm RR sequence 0010 - Toshiba A19nm RR sequence 0011 - Toshiba 19nm RR sequence 0100 - SanDisk 19nm RR sequence 0101 - SanDisk 1ynmRR sequence Others - Reserved</td>
<td>MISC_CON F_LOCK</td>
</tr>
<tr>
<td>0x6D0[12]</td>
<td>Reserved</td>
<td>1</td>
<td>Unallocated</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x6D0[15:13]</td>
<td>WDOG Timeout Select</td>
<td>3</td>
<td>Select WDOG Timeout</td>
<td>000 - 64s 001 - 32s 010 - 16s 011 - 8s 100 - 4s Others - Reserved</td>
<td>MISC_CON F_LOCK</td>
</tr>
<tr>
<td>0x6D0[19:16]</td>
<td>Default_FlexRAM_Part</td>
<td>4</td>
<td>Default FlexRAM RAM bank partitioning</td>
<td>CFG DTCM ITCM ORAM RAM_Bank0~15_CFG (D=DTCM, I=ITCM, O=ORAM) 0000: 128KB 128KB 256KB</td>
<td>MISC_CON F_LOCK</td>
</tr>
<tr>
<td>Fuse Address</td>
<td>Fuses Name</td>
<td>Number of Fuses</td>
<td>Fuses Function</td>
<td>Setting</td>
<td>Locked by</td>
</tr>
<tr>
<td>--------------</td>
<td>------------</td>
<td>-----------------</td>
<td>----------------</td>
<td>---------</td>
<td>-----------</td>
</tr>
<tr>
<td>0x6D0[21:20]</td>
<td>Reserved</td>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x6D0[22]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x6D0[23]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x6D0[24]</td>
<td>EEPROM_RECOVERY_EN</td>
<td>1</td>
<td>EEPROM Recovery Enable</td>
<td>'0' - Disabled</td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td>0x6D0[26:25]</td>
<td>LPSPI_PORT_SEL</td>
<td>2</td>
<td>LPSPI Port Select</td>
<td>00 - LPSPI1</td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - LPSPI2</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - LPSPI3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11 - LPSPI4</td>
<td></td>
</tr>
<tr>
<td>0x6D0[27]</td>
<td>LPSPI_ADDR</td>
<td>1</td>
<td>SPI Addressing</td>
<td>0 - 3-bytes (24-bit)</td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1 - 2-bytes (16-bit)</td>
<td></td>
</tr>
<tr>
<td>0x6D0[29:28]</td>
<td>LPSPI_SPEED</td>
<td>2</td>
<td>LPSPI Speed select</td>
<td>00 - 20 MHz (default)</td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>01 - 10 MHz</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>10 - 5 MHz</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>11 - 2 MHz</td>
<td></td>
</tr>
<tr>
<td>0x6D0[31:30]</td>
<td>SD_CALIBRATION_STEP</td>
<td>2</td>
<td>SD Calibration Step</td>
<td>'00' - 1</td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td>0x6E0[7:0]</td>
<td>BOOT_CONFIG_MISC0</td>
<td>8</td>
<td>boot configuration misc</td>
<td></td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td>0x6E0[15:8]</td>
<td>BOOT_CONFIG_MISC1</td>
<td>8</td>
<td>boot configuration misc</td>
<td></td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td>0x6E0[23:16]</td>
<td>BOOT_CONFIG_MISC2</td>
<td>8</td>
<td>boot configuration misc</td>
<td></td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td>0x6E0[31:24]</td>
<td>BOOT_CONFIG_MISC3</td>
<td>8</td>
<td>boot configuration misc</td>
<td></td>
<td>MISC_CON_F_LOCK</td>
</tr>
<tr>
<td>0x6F0[2:0]</td>
<td>Reserved</td>
<td>3</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x6F0[3]</td>
<td>Reserved</td>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x6F0[7:4]</td>
<td>Reserved</td>
<td>4</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 22-9. Fusemap Descriptions (continued)

<table>
<thead>
<tr>
<th>Fuse Address</th>
<th>Fuses Name</th>
<th>Number of Fuses</th>
<th>Fuses Function</th>
<th>Setting</th>
<th>Locked by</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x6F0[15:8]</td>
<td>Reserved</td>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x6F0[31:16]</td>
<td>Reserved</td>
<td>16</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x800[31:0]</td>
<td>Reserved</td>
<td>256</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x880[31:0]</td>
<td>GP3[127:0]</td>
<td>128</td>
<td>General Purpose fuse register #3</td>
<td>GP3_LOCK</td>
<td></td>
</tr>
<tr>
<td>0x8C0[31:0]</td>
<td>Reserved</td>
<td>128</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
Chapter 23
On-Chip OTP Controller (OCOTP_CTRL)

23.1 Chip-specific OCOTP_CTRL information

Table 23-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

NOTE

Security-related fuses are shown as reserved here. For details, refer to the Security Reference Manual.

23.2 Overview

This section contains information describing the requirements for the on-chip eFuse OTP controller along with details about the block functionality and implementation.

In this document, the words "eFuse" and "OTP" are interchangeable. OCOTP refers to the hardware block itself.
23.2.1 Features

The OCOTP provides the following features:

- 32-bit word restricted program and read to 2 kbit of eFuse OTP.
- Loading and housing of fuse content into shadow registers
- Memory-mapped (restricted) access to shadow registers
- Generation of STICKY_REG which consists of sticky register bits
- Provides program-protect and read-protect eFuse
- Provides override and read protection of shadow register

23.3 Clocks

The table found here describes the clock sources for OCOTP. Please see the chip-specific clocking section for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
</tbody>
</table>
23.4 Top-Level Symbol and Functional Overview

The figure below shows the OCOTP system level diagram.

![Figure 23-1. OCOTP System Level Diagram](image)

23.4.1 Operation

The IP bus interface of the OCOTP has the following functions.

- Configure control registers for programming and reading all the fuse words
- Override and read shadow registers

OCOTP configuration for programs and reads are performed on 32-bit words for software (SW) convenience. For writes, the 32-bit word reflects the "write-mask." Bit fields with 0 will not be programmed and bit fields with 1 will be programmed. OCOTP will program bit field with 1 in the fuse word one bit by one bit. For reads, OCOTP will read 4 times to get 4 bytes in the fuse word in order.
23.4.1.1 Shadow Register Reload

All fuse words in efusebox are shadowed. Therefore, fuse information is available through memory mapped shadow registers. If fuses are subsequently programmed, the shadow registers should be reloaded to keep them coherent with the fuse bank arrays.

The "reload shadows" feature allows the user to force a reload of the shadow registers without having to reset the device. To force a reload, complete the following steps:

1. Set the HW_OCOTP_TIMING[STROBE_READ] field value appropriately.
2. Set the HW_OCOTP_TIMING[RELAX] field value appropriately.
3. Check that HW_OCOTP_CTRL[BUSY] and HW_OCOTP_CTRL[ERROR] are clear. Overlapped accesses are not supported by the controller. Any pending write, read or reload must be completed before a new access can be requested.
4. Set the HW_OCOTP_CTRL[RELOAD_SHADOWS] bit. OCOTP will read all the fuses one by one and put it into corresponding shadow register.
5. Wait for HW_OCOTP_CTRL[BUSY] and HW_OCOTP_CTRL[RELOAD_SHADOWS] to be cleared by the controller.

The controller will automatically clear the HW_OCOTP_CTRL[RELOAD_SHADOWS] bit after the successful completion of the operation.

23.4.1.2 Fuse and Shadow Register Read

All shadow registers are always readable through the IPS bus. When their corresponding fuse lock bits are set, the shadow registers also become read locked. After read locking, reading from these registers will return 0xBADABADA.

In addition HW_OCOTP_CTRL[ERROR] will be set. It must be cleared by software before any new write, read or reload access can be issued. Subsequent reads to unlocked shadow locations will still work successfully however.

To read fuse words directly from the fusebox, complete the following steps:

1. Program HW_OCOTP_TIMING[STROBE_READ] and HW_OCOTP_TIMING[RELAX] fields with timing values to match the current frequency of the ipg_clk. OTP read will work at maximum bus frequencies as long as the HW_OCOTP_TIMING parameters are set correctly.
2. Check that HW_OCOTP_CTRL[BUSY] and HW_OCOTP_CTRL[ERROR] are clear. Overlapped accesses are not supported by the controller. Any pending write, read or reload must be completed before a read access can be requested.
3. Write the requested fuse address to HW_OCOTP_CTRL[ADDR].
4. Set HW_OCOTP_READ_CTRL[READ_FUSE] to 1. OCOTP will auto read the fuse word according to HW_OCOTP_CTRL[ADDR] in fusebox. Then put read value into HW_OCOTP_READ_FUSE_DATA
5. Once complete, the controller will clear BUSY. A read request to a protected or locked region will result in no OTP access and no setting of HW_OCOTP_CTRL[BUSY]. In addition HW_OCOTP_CTRL[ERROR] will be set. It must be cleared by software before any new access can be issued.
6. Read HW_OCOTP_READ_FUSE_DATA to get fuse word value. HW_OCOTP_READ_FUSE_DATA will be 0xBADABADA when HW_OCOTP_CTRL[ERROR] is set.

23.4.1.3 Fuse and Shadow Register Writes

Shadow register bits can be overridden by software until the corresponding fuse lock bit for the region is set. When the lock shadow bit is set, the shadow registers for that lock region become write locked. The HW_OCOTP_LOCKn register also has no overwrite or fuse lock bits, but it is always read-only.

In order to avoid "rogue" code performing erroneous writes to OTP, a special unlocking sequence is required for writes to the fuse banks. To program fuse bank complete the following steps:

1. Program the following fields with timing values to match the frequency of ipg_clk:
   - HW_OCOTP_TIMING[STROBE_PROG]
   - HW_OCOTP_TIMING[RELAX]
   OTP writes will work at maximum bus frequencies as long as the HW_OCOTP_TIMING parameters are set correctly.
2. Check that HW_OCOTP_CTRL[BUSY] and HW_OCOTP_CTRL[ERROR] are clear. Overlapped accesses are not supported by the controller. Any pending write or reload must be completed before a write access can be requested.
3. Write the requested address to HW_OCOTP_CTRL[ADDR] and program the unlock code into HW_OCOTP_CTRL[WR_UNLOCK]. The unlock code must be programmed for each write access. The unlock code is documented in the register description. Both the unlock code and address can be written in the same operation.
4. Write the data to the HW_OCOTP_DATA register. This will automatically set HW_OCOTP_CTRL[BUSY] and clear HW_OCOTP_CTRL[WR_UNLOCK]. Bit fields with 1's will result in that OTP bit being programmed. Bit fields with 0's will be ignored. At the same time that the write is accepted, the controller makes an internal copy of HW_OCOTP_CTRL[ADDR] which cannot be updated until the next write sequence is initiated. This copy guarantees that erroneous writes to
HW_OCOTP_CTRL[ADDR] will not affect an active write operation. During the write operation, HW_OCOTP_DATA cannot be modified.

5. Once complete, the controller will clear HW_OCOTP_CTRL[BUSY]. A write request to a protected or locked region will result in no OTP access and no setting of HW_OCOTP_CTRL[BUSY]. In addition HW_OCOTP_CTRL[ERROR] will be set. It must be cleared by software before any new write access can be issued.

It should be noted that write latencies to OTP are numbers of 10 micro-seconds per word. The write latency is based on the number of "1" bits being written. For example: to program half the fuse bits in one 32-bit word needs 10 us x 16.

HW_OCOTP_CTRL[ERROR] will be set under the following conditions:

- A write is performed to a shadow register during a shadow reload (essentially, while HW_OCOTP_CTRL[RELOAD_SHADOWS] is set). In addition, the contents of the shadow register shall not be updated.
- A write is performed to a shadow register which has been locked.
- A read is performed to a shadow register which has been read locked.
- A program is performed to a fuse word which has been locked.
- A read is performed to a fuse word which has been read locked.

### 23.4.1.4 Write Postamble

Due to internal electrical characteristics of the OTP during writes, all OTP operations (direct reads, shadow reloads, or other writes) following a write must wait at least 2 µs after the clearing of HW_OCOTP_CTRL[BUSY] following the write. The delay guarantees programming voltages on-chip reach a steady state when exiting a write sequence.

A recommended software sequence to meet the postamble requirements is as follows:

1. Issue the write and poll for HW_OCOTP_CTRL[BUSY].
2. Once HW_OCOTP_CTRL[BUSY] is clear, wait 2 µs.
3. Perform the next OTP operation.

### 23.4.2 Fuse Shadow Memory Footprint

The OTP memory footprint is shown in the following figure. The registers are grouped by lock region. Their names correspond to the fusemap names.
23.4.3 OTP Read/Write Timing Parameters

The timing fields contained in the HW_OCOTP_TIMING register that specify counter limit values, which are used to time how long the state machine remains in the various states, as well as specify the STROBE signal timing.

The timing parameters are specified in ipg_clk cycles. Since the ipg_clk frequency can be set to a range of values, these parameters must be adjusted with the clock to yield the appropriate delay.

<table>
<thead>
<tr>
<th>Register Field</th>
<th>Description</th>
</tr>
</thead>
</table>

Table continues on the next page...
**23.4.4 Behavior During Reset**

The OCOTP is always active. The shadow registers automatically load the appropriate OTP contents after reset is deasserted. During this load-time HW_OCOTP_CTRL[BUSY] is set.

**23.4.5 Secure JTAG control**

The JTAG control fuses are used to allow or disallow JTAG access to secured resources. Three JTAG security levels are implemented as shown in the table below.
### Table 23-3. JTAG Security Level Control Bits

<table>
<thead>
<tr>
<th>Security Mode</th>
<th>JTAG_SMODE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>No Debug</td>
<td>2'b11</td>
<td>The highest security level.</td>
</tr>
<tr>
<td>Secure JTAG</td>
<td>2'b01</td>
<td>Limit the JTAG access by using key based authentication mechanism.</td>
</tr>
<tr>
<td>JTAG Enable</td>
<td>2'b00</td>
<td>Low Security, all JTAG features are enabled.</td>
</tr>
</tbody>
</table>

### 23.5 Fuse Map

See the Fusemap chapter of this reference manual for more information.

### 23.6 OCOTP Memory Map/Register Definition

The OCOTP Memory Map/Register Definition can be found here.

#### NOTE

Writing or reading unimplemented register address in OCOTP Controller will not send error and read data will be 0.

### 23.6.1 OCOTP register descriptions

OCOTP Hardware Register Format Summary

#### 23.6.1.1 OCOTP memory map

OCOTP base address: 401F_4000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>OTP Controller Control and Status Register (CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>4h</td>
<td>OTP Controller Control and Status Register (CTRL_SET)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8h</td>
<td>OTP Controller Control and Status Register (CTRL_CLR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>OTP Controller Control and Status Register (CTRL_TOG)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>OTP Controller Timing Register (TIMING)</td>
<td>32</td>
<td>RW</td>
<td>0C0D_9755h</td>
</tr>
<tr>
<td>20h</td>
<td>OTP Controller Write Data Register (DATA)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>30h</td>
<td>OTP Controller Write Data Register (READ_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>40h</td>
<td>OTP Controller Read Data Register (READ_FUSE_DATA)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>60h</td>
<td>Software Controllable Signals Register (SCS)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>64h</td>
<td>Software Controllable Signals Register (SCS_SET)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>68h</td>
<td>Software Controllable Signals Register (SCS_CLR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>6Ch</td>
<td>Software Controllable Signals Register (SCS_TOG)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>90h</td>
<td>OTP Controller Version Register (VERSION)</td>
<td>32</td>
<td>RO</td>
<td>0300_0000h</td>
</tr>
<tr>
<td>100h</td>
<td>OTP Controller Timing Register 2 (TIMING2)</td>
<td>32</td>
<td>RW</td>
<td>01C3_0092h</td>
</tr>
<tr>
<td>400h</td>
<td>Value of OTP Bank0 Word0 (Lock controls) (LOCK)</td>
<td>32</td>
<td>RW</td>
<td>0012_8003h</td>
</tr>
<tr>
<td>410h</td>
<td>Value of OTP Bank0 Word1 (Configuration and Manufacturing Info.) (CFG0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>420h</td>
<td>Value of OTP Bank0 Word2 (Configuration and Manufacturing Info.) (CFG1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>430h</td>
<td>Value of OTP Bank0 Word3 (Configuration and Manufacturing Info.) (CFG2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>440h</td>
<td>Value of OTP Bank0 Word4 (Configuration and Manufacturing Info.) (CFG3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>450h</td>
<td>Value of OTP Bank0 Word5 (Configuration and Manufacturing Info.) (CFG4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>460h</td>
<td>Value of OTP Bank0 Word6 (Configuration and Manufacturing Info.) (CFG5)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>470h</td>
<td>Value of OTP Bank0 Word7 (Configuration and Manufacturing Info.) (CFG6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>4F0h</td>
<td>Value of OTP Bank1 Word7 (Analog Info.) (ANA2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>600h</td>
<td>Value of OTP Bank4 Word0 (Secure JTAG Response Field) (SJC_RESP0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>610h</td>
<td>Value of OTP Bank4 Word1 (Secure JTAG Response Field) (SJC_RESP1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>620h</td>
<td>Value of OTP Bank4 Word2 (MAC Address) (MAC0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>630h</td>
<td>Value of OTP Bank4 Word3 (MAC Address) (MAC1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>640h</td>
<td>Value of OTP Bank4 Word4 (MAC2 Address) (MAC2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>660h</td>
<td>Value of OTP Bank4 Word6 (General Purpose Customer Defined Info) (GP1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>670h</td>
<td>Value of OTP Bank4 Word7 (General Purpose Customer Defined Info) (GP2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>680h</td>
<td>Value of OTP Bank5 Word0 (SW GP1) (SW_GP1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>6D0h</td>
<td>Value of OTP Bank5 Word5 (Misc Conf) (MISC_CONF0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>6E0h</td>
<td>Value of OTP Bank5 Word6 (Misc Conf) (MISC_CONF1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>880h</td>
<td>Value of OTP Bank7 Word0 (GP3) (GP30)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>890h</td>
<td>Value of OTP Bank7 Word1 (GP3) (GP31)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8A0h</td>
<td>Value of OTP Bank7 Word2 (GP3) (GP32)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8B0h</td>
<td>Value of OTP Bank7 Word3 (GP3) (GP33)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>
23.6.1.2 OTP Controller Control and Status Register (CTRL)

23.6.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL</td>
<td>0h</td>
</tr>
</tbody>
</table>

23.6.1.2.2 Function

The OCOTP Control and Status Register provides the necessary software interface for performing read and write operations to the On-Chip OTP (One-Time Programmable ROM). The control fields such as WR_UNLOCK, ADDR, BUSY and ERROR may be used in conjunction with the DATA register to perform write operations. Read operations to the On-Chip OTP involve ADDR, BUSY and ERROR bit fields and the READ_CTRL register. The read value is saved in the READ_FUSE_DATA register.

23.6.1.2.3 Diagram

23.6.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16 WR_UNLOCK</td>
<td>Write Unlock</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Write 0x3E77 to enable OTP write accesses. NOTE: This register must be unlocked on a write-by-write basis (a write is initiated when DATA is written), so the UNLOCK bitfield must contain the correct key value during all writes to DATA, otherwise a write shall not be initiated. This field is automatically cleared after a successful write completion (clearing of BUSY).

Values not listed are reserved.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000000000000000b</td>
<td>OTP write access is locked.</td>
</tr>
<tr>
<td>0011111001110111b</td>
<td>OTP write access is unlocked.</td>
</tr>
</tbody>
</table>

15-13
---
Reserved

12-11
---
Reserved

10
RELOAD_SHADOWS
Reload Shadow Registers
This bit can be set to force re-loading of the shadow registers. This operation will automatically set BUSY. After the shadow registers have been re-loaded, BUSY and RELOAD_SHADOWS are automatically cleared by the controller.

0b - Do not force shadow register re-load.
1b - Force shadow register re-load. This bit is cleared automatically after shadow registers are re-loaded.

9
ERROR
Locked Region Access Error
This bit is set by the controller when an access to a locked region (OTP or shadow register) is requested. Reset this bit by writing a one to the CTRL_CLR[ERROR] bit and not by writing to the CTRL register.

0b - No error.
1b - Error - access to a locked region requested.

8
BUSY
OTP controller status bit
This bit is automatically set by the controller when a write or read access to the OTP is started. When set, no new write access or read access to OTP (including RELOAD_SHADOWS) can be performed. This bit is cleared by the controller when an access completes. After reset (or after setting RELOAD_SHADOWS), this bit is set by the controller until the HW/SW and LOCK registers are successfully copied, after which time it is automatically cleared by the controller.

0b - No write or read access to OTP started.
1b - Write or read access to OTP started.

7-6
---
Reserved

5-0
ADDR
OTP write and read access address register
Specifies one of 128 word address locations (0x00 - 0x3F).

23.6.1.3 OTP Controller Control and Status Register (CTRL_SET)

23.6.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL_SET</td>
<td>4h</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
NXP Semiconductors
23.6.1.3.2 Function

The OCOTP Control and Status Register provides the necessary software interface for performing read and write operations to the On-Chip OTP (One-Time Programmable ROM). The control fields such as WR_UNLOCK, ADDR, BUSY and ERROR may be used in conjunction with the DATA register to perform write operations. Read operations to the On-Chip OTP involve ADDR, BUSY and ERROR bit fields and the READ_CTRL register. The read value is saved in the READ_FUSE_DATA register.

23.6.1.3.3 Diagram

![Diagram of OCOTP Control and Status Register]

23.6.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Write Unlock</td>
</tr>
<tr>
<td>WR_UNLOCK</td>
<td>Write 0x3E77 to enable OTP write accesses. NOTE: This register must be unlocked on a write-by-write basis (a write is initiated when DATA is written), so the UNLOCK bitfield must contain the correct key value during all writes to DATA, otherwise a write shall not be initiated. This field is automatically cleared after a successful write completion (clearing of BUSY). Values not listed are reserved.</td>
</tr>
<tr>
<td>15-13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reload Shadow Registers</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### OCOTP Memory Map/Register Definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>RELOAD_SHADOWS</td>
<td>This bit can be set to force re-loading of the shadow registers. This operation will automatically set BUSY. After the shadow registers have been re-loaded, BUSY and RELOAD_SHADOWS are automatically cleared by the controller.</td>
</tr>
<tr>
<td>9</td>
<td>ERROR Locked Region Access Error</td>
</tr>
<tr>
<td>8</td>
<td>BUSY OTP controller status bit</td>
</tr>
<tr>
<td>7-6</td>
<td>__ Reserved</td>
</tr>
<tr>
<td>5-0</td>
<td>ADDR OTP write and read access address register</td>
</tr>
</tbody>
</table>

### 23.6.1.4 OTP Controller Control and Status Register (CTRL_CLR)

#### 23.6.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL_CLR</td>
<td>8h</td>
</tr>
</tbody>
</table>

#### 23.6.1.4.2 Function

The OCOTP Control and Status Register provides the necessary software interface for performing read and write operations to the On-Chip OTP (One-Time Programmable ROM). The control fields such as WR_UNLOCK, ADDR, BUSY and ERROR may be used in conjunction with the DATA register to perform write operations. Read operations to the On-Chip OTP involve ADDR, BUSY and ERROR bit fields and the READ_CTRL register. The read value is saved in the READ_FUSE_DATA register.
### 23.6.1.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>WR_UNLOCK</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 23.6.1.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16 WR_UNLOCK</td>
<td>Write Unlock&lt;br&gt;Write 0x3E77 to enable OTP write accesses. NOTE: This register must be unlocked on a write-by-write basis (a write is initiated when DATA is written), so the UNLOCK bitfield must contain the correct key value during all writes to DATA, otherwise a write shall not be initiated. This field is automatically cleared after a successful write completion (clearing of BUSY).&lt;br&gt;Values not listed are reserved.</td>
</tr>
<tr>
<td>15-13 Reserved</td>
<td></td>
</tr>
<tr>
<td>12-11 Reserved</td>
<td></td>
</tr>
<tr>
<td>10 RELOAD_SHADOWS</td>
<td>Reload Shadow Registers&lt;br&gt;This bit can be set to force re-loading of the shadow registers. This operation will automatically set BUSY. After the shadow registers have been re-loaded, BUSY and RELOAD_SHADOWS are automatically cleared by the controller.</td>
</tr>
<tr>
<td>9 ERROR</td>
<td>Locked Region Access Error&lt;br&gt;This bit is set by the controller when an access to a locked region (OTP or shadow register) is requested. Reset this bit by writing a one to the CTRL_CLR[ERROR] bit and not by writing to the CTRL register.</td>
</tr>
<tr>
<td>8 BUSY</td>
<td>OTP controller status bit&lt;br&gt;This bit is automatically set by the controller when a write or read access to the OTP is started. When set, no new write access or read access to OTP (including RELOAD_SHADOWS) can be performed. This bit is cleared by the controller when an access completes. After reset (or after setting RELOAD_SHADOWS), this bit is set by the controller until the HW/SW and LOCK registers are successfully copied, after which time it is automatically cleared by the controller.</td>
</tr>
<tr>
<td>7-6 Reserved</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 23.6.1.5 OTP Controller Control and Status Register (CTRL_TOG)

#### 23.6.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL_TOG</td>
<td>Ch</td>
</tr>
</tbody>
</table>

#### 23.6.1.5.2 Function

The OCOTP Control and Status Register provides the necessary software interface for performing read and write operations to the On-Chip OTP (One-Time Programmable ROM). The control fields such as WR_UNLOCK, ADDR, BUSY and ERROR may be used in conjunction with the DATA register to perform write operations. Read operations to the On-Chip OTP involve ADDR, BUSY and ERROR bit fields and the READ_CTRL register. The read value is saved in the READ_FUSE_DATA register.

#### 23.6.1.5.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reload_Shadows</td>
<td>Error</td>
<td>Busy</td>
<td>Reserved</td>
<td>Addr</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```
23.6.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>WR_UNLOCK</td>
</tr>
<tr>
<td></td>
<td>Write Unlock</td>
</tr>
<tr>
<td></td>
<td>Write 0x3E77 to enable OTP write accesses. NOTE: This register must be</td>
</tr>
<tr>
<td></td>
<td>unlocked on a write-by-write basis (a write is initiated when DATA is</td>
</tr>
<tr>
<td></td>
<td>written), so the UNLOCK bitfield must contain the correct key value</td>
</tr>
<tr>
<td></td>
<td>during all writes to DATA, otherwise a write shall not be initiated. This</td>
</tr>
<tr>
<td></td>
<td>field is automatically cleared after a successful write completion</td>
</tr>
<tr>
<td></td>
<td>(clearing of BUSY).</td>
</tr>
<tr>
<td>15-13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>RELOAD_SHADOWS</td>
</tr>
<tr>
<td></td>
<td>Reload Shadow Registers</td>
</tr>
<tr>
<td></td>
<td>This bit can be set to force re-loading of the shadow registers. This</td>
</tr>
<tr>
<td></td>
<td>operation will automatically set BUSY. After the shadow registers have</td>
</tr>
<tr>
<td></td>
<td>been re-loaded, BUSY and RELOAD_SHADOWS are automatically cleared by the</td>
</tr>
<tr>
<td></td>
<td>controller.</td>
</tr>
<tr>
<td>9</td>
<td>ERROR</td>
</tr>
<tr>
<td></td>
<td>Locked Region Access Error</td>
</tr>
<tr>
<td></td>
<td>This bit is set by the controller when an access to a locked region (OTP</td>
</tr>
<tr>
<td></td>
<td>or shadow register) is requested. Reset this bit by writing a one to the</td>
</tr>
<tr>
<td></td>
<td>CTRL_CLR[ERROR] bit and not by writing to the CTRL register.</td>
</tr>
<tr>
<td>8</td>
<td>BUSY</td>
</tr>
<tr>
<td></td>
<td>OTP controller status bit</td>
</tr>
<tr>
<td></td>
<td>This bit is automatically set by the controller when a write or read</td>
</tr>
<tr>
<td></td>
<td>access to the OTP is started. When set, no new write access or read</td>
</tr>
<tr>
<td></td>
<td>access to OTP (including RELOAD_SHADOWS) can be performed. This bit is</td>
</tr>
<tr>
<td></td>
<td>cleared by the controller when an access completes. After reset (or after</td>
</tr>
<tr>
<td></td>
<td>setting RELOAD_SHADOWS), this bit is set by the controller until the HW/SW</td>
</tr>
<tr>
<td></td>
<td>and LOCK registers are successfully copied, after which time it is</td>
</tr>
<tr>
<td></td>
<td>automatically cleared by the controller.</td>
</tr>
<tr>
<td>7-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-0</td>
<td>ADDR</td>
</tr>
<tr>
<td></td>
<td>OTP write and read access address register</td>
</tr>
<tr>
<td></td>
<td>Specifies one of 128 word address locations (0x00 - 0x3F).</td>
</tr>
</tbody>
</table>

23.6.1.6 OTP Controller Timing Register (TIMING)

23.6.1.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMING</td>
<td>10h</td>
</tr>
</tbody>
</table>

23.6.1.6.2 Function

The OCOTP Data Register is used for OTP Programming
This register specifies timing parameters for programming and reading the OTP fuse array.

See OTP Read/Write Timing Parameters for more details.

### 23.6.1.6.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>RELAX</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 23.6.1.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-22</td>
<td>Wait Interval</td>
</tr>
<tr>
<td>WAIT</td>
<td>This count value specifies the time interval between auto read and write access in one time program to the OTP. It is given in number of ipg_clk periods. The OTP controller performs a read action before each program action. This is the &quot;auto&quot; read. The purpose of the auto read is to avoid multiple programming to the same bits.</td>
</tr>
<tr>
<td>21-16</td>
<td>Read Strobe Period</td>
</tr>
<tr>
<td>STROBE_READ</td>
<td>This count value specifies the strobe period in one time read OTP (Trd). Trd = ((STROBE_READ+1)-2*(RELAX_READ+1))/ipg_clk_freq. It is given in number of ipg_clk periods.</td>
</tr>
<tr>
<td>15-12</td>
<td>Relax Count Value</td>
</tr>
<tr>
<td>RELAX</td>
<td>This count value specifies the time to add to all default timing parameters other than the Tpgm and Trd. It is given in number of ipg_clk periods.</td>
</tr>
<tr>
<td>11-0</td>
<td>Write Strobe Period</td>
</tr>
<tr>
<td>STROBE_PROG</td>
<td>This count value controls the strobe period in one time to write OTP (Tpgm). Tpgm = ((STROBE_PROG+1)-2*(RELAX_PROG+1))/ipg_clk_freq. It is given in number of ipg_clk periods.</td>
</tr>
</tbody>
</table>

### 23.6.1.7 OTP Controller Write Data Register (DATA)
23.6.1.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATA</td>
<td>20h</td>
</tr>
</tbody>
</table>

23.6.1.7.2 Function

This register is used in conjunction with the CTRL register to perform one-time writes to the OTP. See the Fuse and Shadow Register Writes section for operating details.

23.6.1.7.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Used to initiate a write to OTP. See the Fuse and Shadow Register Writes section for operating details.</td>
</tr>
</tbody>
</table>

23.6.1.8 OTP Controller Write Data Register (READ_CTRL)

23.6.1.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>READ_CTRL</td>
<td>30h</td>
</tr>
</tbody>
</table>
23.6.1.8.2 Function

This register is used in conjunction with CTRL to perform reads of the OTP. See the Fuse and Shadow Register Read section for operating details.

23.6.1.8.3 Diagram

23.6.1.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>READ_FUSE</td>
</tr>
</tbody>
</table>

USED TO INITIATE A READ FROM OTP. SEE THE Fuse and Shadow Register Read section for operating details.

23.6.1.9 OTP Controller Read Data Register (READ_FUSE_DATA)

23.6.1.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>READ_FUSE_DATA</td>
<td>40h</td>
</tr>
</tbody>
</table>

23.6.1.9.2 Function

The data read from OTP.
23.6.1.9.3  **Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DATA</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DATA</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.9.4  **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>The data read from OTP. See the Fuse and Shadow Register Read section for operating details.</td>
</tr>
<tr>
<td>DATA</td>
<td></td>
</tr>
</tbody>
</table>

23.6.1.10  **Software Controllable Signals Register (SCS)**

23.6.1.10.1  **Offset**

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCS</td>
<td>60h</td>
</tr>
</tbody>
</table>

23.6.1.10.2  **Function**

This register holds volatile configuration values that can be set and locked by software.
23.6.1.10.3 Diagram

![Diagram of bits 31 to 0 in the register with LOCK and SPARE fields]

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>LOCK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>SPARE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.10.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>LOCK</td>
</tr>
</tbody>
</table>
|        | This bitfield locks the bits in this register.  
|        | 0b - Bits in this register are unlocked.  
|        | 1b - Bits in this register are locked. When set, all of the bits in this register are locked and can not be changed through SW programming. After this bit is set, it can only be cleared by a POR. |

| 30-1   | SPARE    |
|        | Unallocated read/write bits for implementation specific software use. |

| 0      | HAB_JDE  |
|        | HAB JTAG Debug Enable  
|        | This bit can be used by the High Assurance Boot (HAB) portion of the Boot ROM to enable JTAG debugging, assuming that a properly signed command to do so is found and validated by the HAB. The HAB will lock the register before passing control to the application whether or not JTAG debugging has been enabled. Once JTAG is enabled by this bit, it cannot be disabled unless the system is reset by POR.  
|        | 0b - JTAG debugging is not enabled by the HAB (it may still be enabled by other mechanisms).  
|        | 1b - JTAG debugging is enabled by the HAB (though this signal may be gated off). |

23.6.1.11 Software Controllable Signals Register (SCS_SET)

23.6.1.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCS_SET</td>
<td>64h</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
23.6.11.2 Function

This register holds volatile configuration values that can be set and locked by software.

23.6.11.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>LOCK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>SPARE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>SPARE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>E</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Lock</td>
</tr>
<tr>
<td>LOCK</td>
<td>This bitfield locks the bits in this register.</td>
</tr>
<tr>
<td>30-1</td>
<td>Unallocated read/write bits for implementation specific software use.</td>
</tr>
<tr>
<td>SPARE</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HAB_JDE</td>
</tr>
<tr>
<td>HAB_JDE</td>
<td>HAB JTAG Debug Enable</td>
</tr>
<tr>
<td></td>
<td>This bit can be used by the High Assurance Boot (HAB) portion of the Boot ROM to enable JTAG debugging, assuming that a properly signed command to do so is found and validated by the HAB. The HAB will lock the register before passing control to the application whether or not JTAG debugging has been enabled. Once JTAG is enabled by this bit, it cannot be disabled unless the system is reset by POR.</td>
</tr>
</tbody>
</table>

23.6.12 Software Controllable Signals Register (SCS_CLR)

23.6.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCS_CLR</td>
<td>68h</td>
</tr>
</tbody>
</table>
23.6.1.12.2  Function

This register holds volatile configuration values that can be set and locked by software.

23.6.1.12.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>LOCK</td>
<td>SPARE</td>
<td>E</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>SPARE</td>
<td>E</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

23.6.1.12.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>LOCK</td>
</tr>
<tr>
<td></td>
<td>This bitfield locks the bits in this register.</td>
</tr>
<tr>
<td>30-1</td>
<td>SPARE</td>
</tr>
<tr>
<td></td>
<td>Unallocated read/write bits for implementation specific software use.</td>
</tr>
<tr>
<td>0</td>
<td>HAB_JDE</td>
</tr>
<tr>
<td></td>
<td>HAB JTAG Debug Enable</td>
</tr>
<tr>
<td></td>
<td>This bit can be used by the High Assurance Boot (HAB) portion of the Boot ROM to enable JTAG debugging, assuming that a properly signed command to do so is found and validated by the HAB. The HAB will lock the register before passing control to the application whether or not JTAG debugging has been enabled. Once JTAG is enabled by this bit, it cannot be disabled unless the system is reset by POR.</td>
</tr>
</tbody>
</table>

23.6.1.13  Software Controllable Signals Register (SCS_TOG)

23.6.1.13.1  Offset

```
<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCS_TOG</td>
<td>6Ch</td>
</tr>
</tbody>
</table>
```
23.6.1.13.2 Function

This register holds volatile configuration values that can be set and locked by software.

23.6.1.13.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>LOCK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>SPARE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>HAB_JDE</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

23.6.1.13.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Lock</td>
</tr>
<tr>
<td>LOCK</td>
<td>This bitfield locks the bits in this register.</td>
</tr>
<tr>
<td>30-1</td>
<td>SPARE</td>
</tr>
<tr>
<td>Unallocated read/write bits for implementation specific software use.</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>HAB_JDE</td>
</tr>
<tr>
<td>HAB JTAG Debug Enable</td>
<td></td>
</tr>
<tr>
<td>This bit can be used by the High Assurance Boot (HAB) portion of the Boot ROM to enable JTAG debugging, assuming that a properly signed command to do so is found and validated by the HAB. The HAB will lock the register before passing control to the application whether or not JTAG debugging has been enabled. Once JTAG is enabled by this bit, it cannot be disabled unless the system is reset by POR.</td>
<td></td>
</tr>
</tbody>
</table>

23.6.1.14 OTP Controller Version Register (VERSION)

23.6.1.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VERSION</td>
<td>90h</td>
</tr>
</tbody>
</table>
23.6.1.14.2  Function

This register indicates the RTL version in use.

23.6.1.14.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>MAJOR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 1 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th></th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>STEP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

23.6.1.14.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Major RTL Version</td>
</tr>
<tr>
<td>MAJOR</td>
<td>Fixed read-only value reflecting the MAJOR field of the RTL version.</td>
</tr>
<tr>
<td>23-16</td>
<td>Minor RTL Version</td>
</tr>
<tr>
<td>MINOR</td>
<td>Fixed read-only value reflecting the MINOR field of the RTL version.</td>
</tr>
<tr>
<td>15-0</td>
<td>RTL Version Steping</td>
</tr>
<tr>
<td>STEP</td>
<td>Fixed read-only value reflecting the stepping of the RTL version.</td>
</tr>
</tbody>
</table>

23.6.1.15  OTP Controller Timing Register 2 (TIMING2)

23.6.1.15.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMING2</td>
<td>100h</td>
</tr>
</tbody>
</table>

23.6.1.15.2  Function

This register specifies timing parameters for programming and reading the OCOTP fuse array.
See OTP Read/Write Timing Parameters for more details.

### 23.6.1.15.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RELAX_READ</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RELAX_PROG</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### 23.6.1.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-22</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 21-16  | Relax Read count value
| RELAX_READ | This count value specifies the strobe period in one time read OTP. \( \text{Trd} = ((\text{STROBE\_READ} + 1) - 2 * (\text{RELAX\_READ} + 1)) / \text{ipg\_clk\_freq}. \) It is given in number of ipg\_clk periods. |
| 15-12  | Reserved                                                                  |
| 11-0   | Relax Prog. count value
| RELAX_PROG | This count value specifies the strobe period in one time write OTP. \( \text{Tpgm} = ((\text{STROBE\_PROG} + 1) - 2 * (\text{RELAX\_PROG} + 1)) / \text{ipg\_clk\_freq}. \) It is given in number of ipg\_clk periods. |

### 23.6.1.16 Value of OTP Bank0 Word0 (Lock controls) (LOCK)

#### 23.6.1.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOCK</td>
<td>400h</td>
</tr>
</tbody>
</table>

#### 23.6.1.16.2 Function

Shadowed memory mapped access to OTP Bank 0, word 0 (ADDR = 0x00).
Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]

23.6.1.16.3 Diagram

| Bits | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|      | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  |

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

23.6.1.16.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>30-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>27-26</td>
<td>GP3 Write Lock Status</td>
</tr>
<tr>
<td>GP3</td>
<td>Status of shadow register and OTP write lock for GP3 region. When bit 1 is set, the writing of this region's shadow register is blocked. When bit 0 is set, the writing of this region's OTP fuse word is blocked.</td>
</tr>
<tr>
<td>25-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>MISC_CONF Write Lock Status</td>
</tr>
<tr>
<td>MISC_CONF</td>
<td>Status of shadow register and OTP write lock for misc_conf region.</td>
</tr>
<tr>
<td></td>
<td>0b - Writing of this region's shadow register and OTP fuse word are not blocked.</td>
</tr>
<tr>
<td></td>
<td>1b - When set, the writing of this region's shadow register and OTP fuse word are blocked.</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-18</td>
<td>ANALOG Write Lock Status</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>SW_GP1 Write Lock Status</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13-12</td>
<td>GP2 Write Lock Status</td>
</tr>
<tr>
<td>11-10</td>
<td>GP1 Write Lock Status</td>
</tr>
<tr>
<td>9-8</td>
<td>MAC_ADDR Write Lock Status</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>SJC_RESP Lock Status</td>
</tr>
<tr>
<td>5-4</td>
<td>MEM_TRIM Write Lock Status</td>
</tr>
<tr>
<td>3-2</td>
<td>BOOT_CFG Write Lock Status</td>
</tr>
<tr>
<td>1-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**ANALOG Write Lock Status**

Status of shadow register and OTP write lock for analog region. When bit 1 is set, the writing of this region's shadow register is blocked. When bit 0 is set, the writing of this region's OTP fuse word is blocked.

**SW_GP1 Write Lock Status**

Status of shadow register and OTP write lock for sw_gp1 region.

0b - Writing of this region's shadow register and OTP fuse word are not blocked.
1b - When set, the writing of this region's shadow register and OTP fuse word are blocked.

**GP2 Write Lock Status**

Status of shadow register and OTP write lock for gp2 region. When bit 1 is set, the writing of this region's shadow register is blocked. When bit 0 is set, the writing of this region's OTP fuse word is blocked.

**GP1 Write Lock Status**

Status of shadow register and OTP write lock for gp2 region. When bit 1 is set, the writing of this region's shadow register is blocked. When bit 0 is set, the writing of this region's OTP fuse word is blocked.

**MAC_ADDR Write Lock Status**

Status of shadow register and OTP write lock for mac_addr region. When bit 1 is set, the writing of this region's shadow register is blocked. When bit 0 is set, the writing of this region's OTP fuse word is blocked.

**SJC_RESP Lock Status**

Status of shadow register read and write, OTP read and write lock for sjc.resp region.

0b - The writing or reading of this region's shadow register and OTP fuse word are not blocked.
1b - When set, the writing of this region's shadow register and OTP fuse word are blocked. The read of this region's shadow register and OTP fuse word are also blocked.

**MEM_TRIM Write Lock Status**

Status of shadow register and OTP write lock for mem.trim region. When bit 1 is set, the writing of this region's shadow register is blocked. When bit 0 is set, the writing of this region's OTP fuse word is blocked.

**BOOT_CFG Write Lock Status**

Status of shadow register and OTP write lock for boot_cfg region. When bit 1 is set, the writing of this region's shadow register is blocked. When bit 0 is set, the writing of this region's OTP fuse word is blocked.
23.6.1.17 Value of OTP Bank0 Word1 (Configuration and Manufacturing Info.) (CFG0)

23.6.1.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFG0</td>
<td>410h</td>
</tr>
</tbody>
</table>

23.6.1.17.2 Function

Shadowed memory mapped access to OTP Bank 0, word 1 (ADDR = 0x01).
Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]

23.6.1.17.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.17.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 0, word 1 (ADDR = 0x01). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>
23.6.1.18  Value of OTP Bank0 Word2 (Configuration and Manufacturing Info.) (CFG1)

23.6.1.18.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFG1</td>
<td>420h</td>
</tr>
</tbody>
</table>

23.6.1.18.2  Function

Shadowed memory mapped access to OTP Bank 0, word 2 (ADDR = 0x02).
Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]

23.6.1.18.3  Diagram

```
| R | W |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 31| 30| 29| 28| 27| 26| 25| 24| 23| 22| 21| 20| 19| 18| 17| 16| 15| 14| 13| 12| 11| 10|  9|  8|  7|  6|  5|  4|  3|  2|  1|  0|
| R | W |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 31| 30| 29| 28| 27| 26| 25| 24| 23| 22| 21| 20| 19| 18| 17| 16| 15| 14| 13| 12| 11| 10|  9|  8|  7|  6|  5|  4|  3|  2|  1|  0|
| R | W |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
```

23.6.1.18.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 0, word 2 (ADDR = 0x02). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.19  Value of OTP Bank0 Word3 (Configuration and Manufacturing Info.) (CFG2)
23.6.1.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFG2</td>
<td>430h</td>
</tr>
</tbody>
</table>

23.6.1.19.2 Function

Shadowed memory mapped access to OTP Bank 0, word 3 (ADDR = 0x03).
Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]

23.6.1.19.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>R</th>
<th>W</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

23.6.1.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 0, word 3 (ADDR = 0x03). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.20 Value of OTP Bank0 Word4 (Configuration and Manufacturing Info.) (CFG3)

23.6.1.20.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFG3</td>
<td>440h</td>
</tr>
</tbody>
</table>
23.6.1.20.2 Function

Non-shadowed memory mapped access to OTP Bank 0, word 4 (ADDR = 0x04).

23.6.1.20.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BITS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

23.6.1.20.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 0, word 4 (ADDR = 0x04). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.21 Value of OTP Bank0 Word5 (Configuration and Manufacturing Info.) (CFG4)

23.6.1.21.1 Offset

```
<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFG4</td>
<td>450h</td>
</tr>
</tbody>
</table>
```

23.6.1.21.2 Function

Shadowed memory mapped access to OTP Bank 0, word 5 (ADDR = 0x05).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.21.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.21.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 0, word 5 (ADDR = 0x05). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.22  Value of OTP Bank0 Word6 (Configuration and Manufacturing Info.) (CFG5)

23.6.1.22.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFG5</td>
<td>460h</td>
</tr>
</tbody>
</table>

23.6.1.22.2  Function

Shadowed memory mapped access to OTP Bank 0, word 6 (ADDR = 0x06).
Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
### 23.6.1.22.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BIT</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BIT</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 23.6.1.22.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td></td>
</tr>
</tbody>
</table>

This register reflects the value of OTP Bank 0, word 6 (ADDR = 0x06). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.

### 23.6.1.23 Value of OTP Bank0 Word7 (Configuration and Manufacturing Info.) (CFG6)

#### 23.6.1.23.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFG6</td>
<td>470h</td>
</tr>
</tbody>
</table>

#### 23.6.1.23.2 Function

Shadowed memory mapped access to OTP Bank 0, word 7 (ADDR = 0x07).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
### 23.6.1.23.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 23.6.1.23.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 0, word 7 (ADDR = 0x07). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

### 23.6.1.24 Value of OTP Bank1 Word7 (Analog Info.) (ANA2)

#### 23.6.1.24.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ANA2</td>
<td>4F0h</td>
</tr>
</tbody>
</table>

#### 23.6.1.24.2 Function

Shadowed memory mapped access to OTP Bank 1, word 7 (ADDR = 0x0F).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
### 23.6.1.24.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Bits</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Bits</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### 23.6.1.24.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 1, word 7 (ADDR = 0x0F). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

### 23.6.1.25 Value of OTP Bank4 Word0 (Secure JTAG Response Field) (SJC_RESP0)

#### 23.6.1.25.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SJC_RESP0</td>
<td>600h</td>
</tr>
</tbody>
</table>

#### 23.6.1.25.2 Function

Shadowed memory mapped access to OTP Bank 4, word 0 (ADDR = 0x20).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.25.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BITS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BITS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.25.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 4, word 0 (ADDR = 0x20). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.26 Value of OTP Bank4 Word1 (Secure JTAG Response Field) (SJC_RESP1)

23.6.1.26.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SJC_RESP1</td>
<td>610h</td>
</tr>
</tbody>
</table>

23.6.1.26.2 Function

Shadowed memory mapped access to OTP Bank 4, word 1 (ADDR = 0x21).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.26.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

23.6.1.26.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 4, word 1 (ADDR = 0x21). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.27  Value of OTP Bank4 Word2 (MAC Address) (MAC0)

23.6.1.27.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAC0</td>
<td>620h</td>
</tr>
</tbody>
</table>

23.6.1.27.2  Function

Shadowed memory mapped access to OTP Bank 4, word 2 (ADDR = 0x22).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.27.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.27.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 4, word 2 (ADDR = 0x22). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.28 Value of OTP Bank4 Word3 (MAC Address) (MAC1)

23.6.1.28.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAC1</td>
<td>630h</td>
</tr>
</tbody>
</table>

23.6.1.28.2 Function

Shadowed memory mapped access to OTP Bank 4, word 3 (ADDR = 0x23).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.28.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.28.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 4, word 3 (ADDR = 0x23). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.29  Value of OTP Bank4 Word4 (MAC2 Address) (MAC2)

23.6.1.29.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MAC2</td>
<td>640h</td>
</tr>
</tbody>
</table>

23.6.1.29.2  Function

Shadowed memory mapped access to OTP Bank 4, word 4 (ADDR = 0x24).
Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
### 23.6.1.29.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 23.6.1.29.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 4, word 4 (ADDR = 0x24). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

### 23.6.1.30 Value of OTP Bank4 Word6 (General Purpose Customer Defined Info) (GP1)

#### 23.6.1.30.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GP1</td>
<td>660h</td>
</tr>
</tbody>
</table>

#### 23.6.1.30.2 Function

Shadowed memory mapped access to OTP Bank 4, word 6 (ADDR = 0x26).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.30.3 Diagram

Bits  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
R    |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
W    | BITS|
Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Bits  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
R    |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
W    | BITS|
Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

23.6.1.30.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 4, word 6 (ADDR = 0x26). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.31 Value of OTP Bank4 Word7 (General Purpose Customer Defined Info) (GP2)

23.6.1.31.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GP2</td>
<td>670h</td>
</tr>
</tbody>
</table>

23.6.1.31.2 Function

Shadowed memory mapped access to OTP Bank 4, word 7 (ADDR = 0x27).
Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.31.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
</tr>
<tr>
<td>30</td>
</tr>
<tr>
<td>29</td>
</tr>
<tr>
<td>28</td>
</tr>
<tr>
<td>27</td>
</tr>
<tr>
<td>26</td>
</tr>
<tr>
<td>25</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>23</td>
</tr>
<tr>
<td>22</td>
</tr>
<tr>
<td>21</td>
</tr>
<tr>
<td>20</td>
</tr>
<tr>
<td>19</td>
</tr>
<tr>
<td>18</td>
</tr>
<tr>
<td>17</td>
</tr>
<tr>
<td>16</td>
</tr>
</tbody>
</table>

R

W

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
</tr>
<tr>
<td>14</td>
</tr>
<tr>
<td>13</td>
</tr>
<tr>
<td>12</td>
</tr>
<tr>
<td>11</td>
</tr>
<tr>
<td>10</td>
</tr>
<tr>
<td>9</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>7</td>
</tr>
<tr>
<td>6</td>
</tr>
<tr>
<td>5</td>
</tr>
<tr>
<td>4</td>
</tr>
<tr>
<td>3</td>
</tr>
<tr>
<td>2</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

R

W

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

23.6.1.31.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 4, word 7 (ADDR = 0x27). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.32  Value of OTP Bank5 Word0 (SW GP1) (SW_GP1)

23.6.1.32.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SW_GP1</td>
<td>680h</td>
</tr>
</tbody>
</table>

23.6.1.32.2  Function

Shadowed memory mapped access to OTP Bank 5, word 0 (ADDR = 0x28).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.32.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BITS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BITS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.32.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
</tbody>
</table>
| BITS   | This register reflects the value of OTP Bank 5, word 0 (ADDR = 0x28). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.

23.6.1.33  Value of OTP Bank5 Word5 (Misc Conf) (MISC_CONF0)

23.6.1.33.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MISC_CONF0</td>
<td>6D0h</td>
</tr>
</tbody>
</table>

23.6.1.33.2  Function

Shadowed memory mapped access to OTP Bank 5, word 5 (ADDR = 0x2D).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
### 23.6.1.33.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 23.6.1.33.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td></td>
</tr>
</tbody>
</table>

This register reflects the value of OTP Bank 5, word 5 (ADDR = 0x2D). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.

### 23.6.1.34 Value of OTP Bank5 Word6 (Misc Conf) (MISC_CONF1)

#### 23.6.1.34.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MISC_CONF1</td>
<td>6E0h</td>
</tr>
</tbody>
</table>

#### 23.6.1.34.2 Function

Shadowed memory mapped access to OTP Bank 5, word 6 (ADDR = 0x2E).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.34.3  Diagram

---

23.6.1.34.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 5, word 6 (ADDR = 0x2E). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.35  Value of OTP Bank7 Word0 (GP3) (GP30)

23.6.1.35.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GP30</td>
<td>880h</td>
</tr>
</tbody>
</table>

23.6.1.35.2  Function

Shadowed memory mapped access to OTP Bank 7, word 0 (ADDR = 0x38).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.35.3  Diagram

Bits 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
<th>BITS</th>
</tr>
</thead>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
<th>BITS</th>
</tr>
</thead>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

23.6.1.35.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td></td>
</tr>
<tr>
<td></td>
<td>This register reflects the value of OTP Bank 7, word 0 (ADDR = 0x38). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
<tr>
<td></td>
<td>Reflects value of OTP Bank 7, word 0 (ADDR = 0x38).</td>
</tr>
</tbody>
</table>

23.6.1.36  Value of OTP Bank7 Word1 (GP3) (GP31)

23.6.1.36.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GP31</td>
<td>890h</td>
</tr>
</tbody>
</table>

23.6.1.36.2  Function

Shadowed memory mapped access to OTP Bank 7, word 1 (ADDR = 0x39).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.36.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>BITS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>BITS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

23.6.1.36.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 7, word 1 (ADDR = 0x39). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.37  Value of OTP Bank7 Word2 (GP3) (GP32)

23.6.1.37.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GP32</td>
<td>8A0h</td>
</tr>
</tbody>
</table>

23.6.1.37.2  Function

Shadowed memory mapped access to OTP Bank 7, word 2 (ADDR = 0x3A).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.37.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BITS</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.37.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 7, word 2 (ADDR = 0x3A). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>

23.6.1.38  Value of OTP Bank7 Word3 (GP3) (GP33)

23.6.1.38.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GP33</td>
<td>8B0h</td>
</tr>
</tbody>
</table>

23.6.1.38.2  Function

Shadowed memory mapped access to OTP Bank 7, word 3 (ADDR = 0x3B).

Copied from the OTP automatically after reset. Can be re-loaded by setting CTRL[RELOAD_SHADOWS]
23.6.1.38.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

23.6.1.38.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>BITS</td>
</tr>
<tr>
<td>BITS</td>
<td>This register reflects the value of OTP Bank 7, word 3 (ADDR = 0x3B). See the Fusemap Descriptions Table in the Fusemap chapter for more fuse details.</td>
</tr>
</tbody>
</table>
Chapter 24
External Memory Controllers

24.1 Overview

This chip has these external memory interfaces and controllers:

- Smart External Memory Controller (SEMC)
- eSD/eMMC/SDIO Interface
- Quad Serial Peripheral Interface (QSPI)

24.2 Smart External Memory Controller (SEMC) Overview

The SEMC is a multi-standard memory controller optimized for both high-performance and low pin-count. It can support multiple external memories in the same application with shared address and data pins. The interface supported includes SDRAM, NOR Flash, SRAM and NAND Flash, as well as 8080 display interface.

The key features of the SEMC include:

- Support up to 8 memory regions up to 512Mbit per region which can be configured to be memory space of SDRAM, NOR Flash, NAND Flash, SRAM or 8080 display frame buffer
- Chip Select (CS) signals
- Ability to disable SDRAM and NAND controller by separate fuse bit
- Support Address Latch Enable (ALE)
- SDRAM interface
  - Supports both 8-bit and 16-bit modes
  - Up to 512Mb per each Chip Select (CS) and up to 4x CS
- NOR Flash and SRAM interface
  - Supports 16-bit mode
  - Async mode
  - Address and Data Multiplexing (ADM)
  - Support NOR Flash program via IPBus configuration
• 8080 display interface
  • Supports both 8/16/24-bit modes
  • Up to 100MHz
  • Without tearing effect support
• NAND Flash
  • 8/16-bit NAND FLASH,
  • Async mode only
  • Only supports device which is capable of cache read/write operations
  • Only supports page based operation
• Dynamic I/O sharing which enables multiple external memory device in parallel
• Multi-device access pattern scheduler
  • 8 entries scheduler
  • QoS priority, latency and efficiency adjustable arbitration scheme
• SDRAM access pattern optimization
  • 8 entries command reordering queue
  • QoS priority, latency and efficiency adjustable arbitration scheme

24.3 eMMC/eSD/SDIO

This chip has two Ultra Secured Digital Host Controller (uSDHC) modules for SD/ eMMC interface. It provides the interface between the host system and the SD/ SDIO/MMC cards.

The key features include:

• Support SD/SDIO standard, up to version 3.0
• Support MMC standard, up to version 4.5
• Support 3.3V and 1.8V operation, but do not support 1.2V operation.
• Supports 1-bit / 4-bit SD and SDIO modes, 1-bit / 4-bit / 8-bit MMC modes
  • Up to 800 Mbps of data transfer for SDIO cards using 4 parallel data lines in SDR mode
  • Up to 400 Mbps of data transfer for SDIO card using 4 parallel data lines in DDR mode
  • Up to 800 Mbps of data transfer for SDXC cards using 4 parallel data lines in SDR mode
  • Up to 400 Mbps of data transfer for SDXC card using 4 parallel data lines in DDR mode
  • Up to 1600 Mbps of data transfer for MMC cards using 8 parallel data lines in SDR mode
  • Up to 800 Mbps of data transfer for MMC cards using 8 parallel data lines in DDR mode
24.4 Quad Serial Peripheral Interface

This chip has one Quad Serial Peripheral Interface block (named FlexSPI) acts as an interface to one or two external serial flash devices, each with up to four bidirectional data lines.

The key features includes:

- Each channel can be configured as 1/2/4-bit operation
- Support both dual-channel or single-channel operation
- Support both SDR mode and DDR mode
- Support up to 166MHz SDR Mode and 166MHz DDR Mode (with external Flash device DQS input)
- Support up to 133MHz SDR Mode and 66MHz DDR Mode (with internal DQS loopback mode)
Chapter 25
Smart External Memory Controller (SEMC)

25.1 Chip-specific SEMC information

Table 25-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

**NOTE**

- For SEMC_CLKX0, see SEMC_CLK5 in IOMUXC chapter.
- For SEMC_CLKX1, see SEMC_CLK6 in IOMUXC chapter.

**NOTE**

Non-ADMUX ASYNC mode for the SRAM operation is depended on pin availability.
25.2 About this module

25.2.1 Introduction

The SEMC is a multi-standard memory controller optimized for both high-performance and low pin-count. It can support multiple external memories in the same application with shared address and data pins. The interface supported includes SDRAM, NOR Flash, SRAM and NAND Flash, as well as 8080 display interface.

25.2.2 Features

The SEMC includes the following features:

- Memory space:
  - Support up to 9 memory regions:
    - Region #0 for SDRAM CS0 device
    - Region #1 for SDRAM CS1 device
    - Region #2 for SDRAM CS2 device
    - Region #3 for SDRAM CS3 device
    - Region #4 and #8 for NAND device (IP command and AXI command use different region to avoid large region address range on AXI interface)
    - Region #5 for NOR device
    - Region #6 for SRAM device
    - Region #7 for 8080 display frame buffer
  - Each region is configurable for base address, memory size and valid bit
- AXI slave interface
  - Support 16 outstanding transfer totally for write and read
  - Support 8 outstanding transfer for write
  - Support 16 outstanding transfer for read
  - Multi-device access pattern optimization with Queue A
    - 8 entries command reordering in Queue A
    - QoS priority, latency and efficiency adjustable arbitration scheme
  - SDRAM access pattern optimization with Queue B
    - 8 entries command reordering in Queue B
    - QoS priority, latency and efficiency adjustable arbitration scheme
  - Trigger device read or write access (AXI command)
  - 32/16/8 bit access supported
  - All burst length supported
  - Only INCR and WRAP burst supported
NOTE
WRAP read/write with 16 bit or 8 bit data size is not supported

• No prefetch/cachable support
• IP Bus interface
  • Internal configuration register access
  • Trigger device access such as device initialization/configuration/read/write (IP command)
• SDRAM interface
  • Support 8/16 bit modes
  • Up to 4 Chip Select (CS) and each CS up to 512Mb
• NAND Flash interface
  • Support 8/16 bit modes
  • No HW ECC
  • Only supports device which is capable of cache read/write operations
  • Only supports page based read/write operation
  • Only supports 32 bit transfer size for AXI write operation
• NOR Flash interface
  • Support 16 bit mode
  • Support ADMUX and AADM modes
  • NOR flash write access is supported only by IP command
  • Up to 512Mb memory size

NOTE
• Up to 512Mb memory size if SEMC_ADDR08 is used as address
• Up to 256Mb memory size if SEMC_ADDR08 is used as chip select

• SRAM interface
  • Support 16 bit mode
  • Support ADMUX and AADM modes
  • Up to 512Mb memory size

NOTE
• Up to 512Mb memory size if SEMC_ADDR08 is used as address
• Up to 256Mb memory size if SEMC_ADDR08 is used as chip select

• 8080 display interface
• Support 8/16 bit modes
• Without tearing effect support
• Misc
  • Dynamic I/O sharing which enables multiple external memory device in parallel
  • Up to 7 Chip Select (CS) signals
  • Ability to disable SDRAM and NAND controller by separate fuse bit
  • Support Address Latch Enable (ALE) for SRAM/NOR device

25.2.3 Operation Modes

SEMC supports following operation modes:

• Module Disable mode

  In module disable mode, internal clock is gated for low power, but access to
  configuration and status registers is available.

  This mode is entered by setting MCR[MDIS], and exited by clearing MCR[MDIS].
  Software should polling STS0[IDLE] to make sure there is no pending transaction
  before entering module disable mode.

• Stop mode

  When the system requires SEMC to enter stop mode (ipg_stop=0x1), SEMC waits
  for all transactions to complete (STS0[IDLE]=0x1) and return acknowledge
  handshake to system (ipg_stop_ack=0x1). The system can gate off SEMC clock after
  acknowledge handshake returned. There is no clock gating action internally.

  SEMC exit this mode immediately when system stop mode request deasserted with
  the acknowledge handshake deasserted.

• Normal mode

  Access to external devices and internal registers are available in normal mode.
  SEMC clock is not gated internally.
25.2.4 Block diagram

Figure 25-1. SEMC block diagram

25.3 Signals

This table describes the SEMC module signals.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC_DATA00</td>
<td>IO</td>
<td>Data/Address Bit 0</td>
</tr>
<tr>
<td>SEMC_DATA01</td>
<td>IO</td>
<td>Data/Address Bit 1</td>
</tr>
<tr>
<td>SEMC_DATA02</td>
<td>IO</td>
<td>Data/Address Bit 2</td>
</tr>
<tr>
<td>SEMC_DATA03</td>
<td>IO</td>
<td>Data/Address Bit 3</td>
</tr>
<tr>
<td>SEMC_DATA04</td>
<td>IO</td>
<td>Data/Address Bit 4</td>
</tr>
<tr>
<td>SEMC_DATA05</td>
<td>IO</td>
<td>Data/Address Bit 5</td>
</tr>
<tr>
<td>SEMC_DATA06</td>
<td>IO</td>
<td>Data/Address Bit 6</td>
</tr>
<tr>
<td>SEMC_DATA07</td>
<td>IO</td>
<td>Data/Address Bit 7</td>
</tr>
<tr>
<td>SEMC_DATA08</td>
<td>IO</td>
<td>Data/Address Bit 8</td>
</tr>
<tr>
<td>SEMC_DATA09</td>
<td>IO</td>
<td>Data/Address Bit 9</td>
</tr>
<tr>
<td>SEMC_DATA10</td>
<td>IO</td>
<td>Data/Address Bit 10</td>
</tr>
<tr>
<td>SEMC_DATA11</td>
<td>IO</td>
<td>Data/Address Bit 11</td>
</tr>
<tr>
<td>SEMC_DATA12</td>
<td>IO</td>
<td>Data/Address Bit 12</td>
</tr>
<tr>
<td>SEMC_DATA13</td>
<td>IO</td>
<td>Data/Address Bit 13</td>
</tr>
<tr>
<td>SEMC_DATA14</td>
<td>IO</td>
<td>Data/Address Bit 14</td>
</tr>
<tr>
<td>SEMC_DATA15</td>
<td>IO</td>
<td>Data/Address Bit 15</td>
</tr>
<tr>
<td>SEMC_DM1</td>
<td>O</td>
<td>Write Data Mask Bit 1</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Signal</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC_DM0</td>
<td>O</td>
<td>Write Data Mask Bit 0</td>
</tr>
<tr>
<td>SEMC_ADDR00</td>
<td>O</td>
<td>Address Bit 0</td>
</tr>
<tr>
<td>SEMC_ADDR01</td>
<td>O</td>
<td>Address Bit 1</td>
</tr>
<tr>
<td>SEMC_ADDR02</td>
<td>O</td>
<td>Address Bit 2</td>
</tr>
<tr>
<td>SEMC_ADDR03</td>
<td>O</td>
<td>Address Bit 3</td>
</tr>
<tr>
<td>SEMC_ADDR04</td>
<td>O</td>
<td>Address Bit 4</td>
</tr>
<tr>
<td>SEMC_ADDR05</td>
<td>O</td>
<td>Address Bit 5</td>
</tr>
<tr>
<td>SEMC_ADDR06</td>
<td>O</td>
<td>Address Bit 6</td>
</tr>
<tr>
<td>SEMC_ADDR07</td>
<td>O</td>
<td>Address Bit 7</td>
</tr>
<tr>
<td>SEMC_ADDR08</td>
<td>O</td>
<td>Address Bit 8</td>
</tr>
<tr>
<td>SEMC_ADDR09</td>
<td>O</td>
<td>Address Bit 9</td>
</tr>
<tr>
<td>SEMC_ADDR10</td>
<td>O</td>
<td>Address Bit 10</td>
</tr>
<tr>
<td>SEMC_ADDR11</td>
<td>O</td>
<td>Address Bit 11</td>
</tr>
<tr>
<td>SEMC_ADDR12</td>
<td>O</td>
<td>Address Bit 12</td>
</tr>
<tr>
<td>SEMC_BA0</td>
<td>O</td>
<td>Bank Address Bit 0</td>
</tr>
<tr>
<td>SEMC_BA1</td>
<td>O</td>
<td>Bank Address Bit 1</td>
</tr>
<tr>
<td>SEMC_CAS</td>
<td>O</td>
<td>Column Address Strobe</td>
</tr>
<tr>
<td>SEMC_RAS</td>
<td>O</td>
<td>Row Address Strobe</td>
</tr>
<tr>
<td>SEMC_WE</td>
<td>O</td>
<td>Write Enable (For SDRAM only)</td>
</tr>
<tr>
<td>SEMC_CKE</td>
<td>O</td>
<td>CKE (For SDRAM only)</td>
</tr>
<tr>
<td>SEMC_CLK</td>
<td>O</td>
<td>CLK (For SDRAM only)</td>
</tr>
<tr>
<td>SEMC_CS0</td>
<td>O</td>
<td>Chip Select (For SDRAM CS0 only)</td>
</tr>
<tr>
<td>SEMC_CSX0</td>
<td>O</td>
<td>Configurable Chip Select 0</td>
</tr>
<tr>
<td>SEMC_CSX1</td>
<td>O</td>
<td>Configurable Chip Select 1</td>
</tr>
<tr>
<td>SEMC_CSX2</td>
<td>O</td>
<td>Configurable Chip Select 2</td>
</tr>
<tr>
<td>SEMC_CSX3</td>
<td>O</td>
<td>Configurable Chip Select 3</td>
</tr>
<tr>
<td>SEMC_RDY</td>
<td>IO</td>
<td>Ready input pin for NAND</td>
</tr>
<tr>
<td>SEMC_DQS</td>
<td>IO</td>
<td>DQS</td>
</tr>
<tr>
<td>SEMC_DQS4</td>
<td>IO</td>
<td>DQS</td>
</tr>
<tr>
<td>SEMC_CLKX0</td>
<td>O</td>
<td>Configurable clock 0 for NOR/SRAM</td>
</tr>
<tr>
<td>SEMC_CLKX1</td>
<td>O</td>
<td>Configurable clock 1 for NOR/SRAM</td>
</tr>
</tbody>
</table>

**NOTE**
For detail pin mux inside SEMC, please refer to Pin Mux in SEMC
25.4 Memory Map and register definition

This section includes the SEMC module memory map and detailed descriptions of all registers.

25.4.1 SEMC register descriptions

25.4.1.1 SEMC memory map

SEMC base address: 402F_0000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Module Control Register (MCR)</td>
<td>32</td>
<td>RW</td>
<td>1000_0002h</td>
</tr>
<tr>
<td>4h</td>
<td>IO Mux Control Register (IOCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8h</td>
<td>Bus (AXI) Master Control Register 0 (BMCR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>Bus (AXI) Master Control Register 1 (BMCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>Base Register 0 (For SDRAM CS0 device) (BR0)</td>
<td>32</td>
<td>RW</td>
<td>8000_001Dh</td>
</tr>
<tr>
<td>14h</td>
<td>Base Register 1 (For SDRAM CS1 device) (BR1)</td>
<td>32</td>
<td>RW</td>
<td>8400_001Ch</td>
</tr>
<tr>
<td>18h</td>
<td>Base Register 2 (For SDRAM CS2 device) (BR2)</td>
<td>32</td>
<td>RW</td>
<td>8800_001Ch</td>
</tr>
<tr>
<td>1Ch</td>
<td>Base Register 3 (For SDRAM CS3 device) (BR3)</td>
<td>32</td>
<td>RW</td>
<td>8C00_001Ch</td>
</tr>
<tr>
<td>20h</td>
<td>Base Register 4 (For NAND device) (BR4)</td>
<td>32</td>
<td>RW</td>
<td>9E00_001Ah</td>
</tr>
<tr>
<td>24h</td>
<td>Base Register 5 (For NOR device) (BR5)</td>
<td>32</td>
<td>RW</td>
<td>9000_0018h</td>
</tr>
<tr>
<td>28h</td>
<td>Base Register 6 (For PSRAM device 0) (BR6)</td>
<td>32</td>
<td>RW</td>
<td>9800_0018h</td>
</tr>
<tr>
<td>2Ch</td>
<td>Base Register 7 (For DBI-B (MIPI Display Bus Interface Type B) device) (BR7)</td>
<td>32</td>
<td>RW</td>
<td>9C00_001Ah</td>
</tr>
<tr>
<td>30h</td>
<td>Base Register 8 (For NAND device) (BR8)</td>
<td>32</td>
<td>RW</td>
<td>0000_0026h</td>
</tr>
<tr>
<td>34h</td>
<td>DLL Control Register (DLLCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0100h</td>
</tr>
<tr>
<td>38h</td>
<td>Interrupt Enable Register (INTEN)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>3Ch</td>
<td>Interrupt Enable Register (INTR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>40h</td>
<td>SDRAM control register 0 (SDRAMCR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0C26h</td>
</tr>
<tr>
<td>44h</td>
<td>SDRAM control register 1 (SDRAMCR1)</td>
<td>32</td>
<td>RW</td>
<td>0099_4934h</td>
</tr>
<tr>
<td>48h</td>
<td>SDRAM control register 2 (SDRAMCR2)</td>
<td>32</td>
<td>RW</td>
<td>8000_0EEEh</td>
</tr>
<tr>
<td>4Ch</td>
<td>SDRAM control register 3 (SDRAMCR3)</td>
<td>32</td>
<td>RW</td>
<td>4080_8000h</td>
</tr>
<tr>
<td>50h</td>
<td>NAND control register 0 (NANDCR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>54h</td>
<td>NAND control register 1 (NANDCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>58h</td>
<td>NAND control register 2 (NANDCR2)</td>
<td>32</td>
<td>RW</td>
<td>0001_0410h</td>
</tr>
</tbody>
</table>

*Table continues on the next page.*
## Memory Map and register definition

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>5Ch</td>
<td>NAND control register 3 (NANDCR3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>60h</td>
<td>NOR control register 0 (NORCR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>64h</td>
<td>NOR control register 1 (NORCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>68h</td>
<td>NOR control register 2 (NORCR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>6Ch</td>
<td>NOR control register 3 (NORCR3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>70h</td>
<td>SRAM control register 0 (SRAMCR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>74h</td>
<td>SRAM control register 1 (SRAMCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>78h</td>
<td>SRAM control register 2 (SRAMCR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>7Ch</td>
<td>SRAM control register 3 (SRAMCR3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>80h</td>
<td>DBI-B control register 0 (DBICR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>84h</td>
<td>DBI-B control register 1 (DBICR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>90h</td>
<td>IP Command control register 0 (IPCR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>94h</td>
<td>IP Command control register 1 (IPCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>98h</td>
<td>IP Command control register 2 (IPCR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>9Ch</td>
<td>IP Command register (IPCMD)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>A0h</td>
<td>TX DATA register (for IP Command) (IPTXDAT)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>B0h</td>
<td>RX DATA register (for IP Command) (IPRXDAT)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C0h</td>
<td>Status register 0 (STS0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0001h</td>
</tr>
<tr>
<td>C4h</td>
<td>Status register 1 (STS1)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C8h</td>
<td>Status register 2 (STS2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>CCh</td>
<td>Status register 3 (STS3)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>D0h</td>
<td>Status register 4 (STS4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>D4h</td>
<td>Status register 5 (STS5)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>D8h</td>
<td>Status register 6 (STS6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>DCh</td>
<td>Status register 7 (STS7)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E0h</td>
<td>Status register 8 (STS8)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E4h</td>
<td>Status register 9 (STS9)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E8h</td>
<td>Status register 10 (STS10)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>ECh</td>
<td>Status register 11 (STS11)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>F0h</td>
<td>Status register 12 (STS12)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>F4h</td>
<td>Status register 13 (STS13)</td>
<td>32</td>
<td>RO</td>
<td>0000_0100h</td>
</tr>
<tr>
<td>F8h</td>
<td>Status register 14 (STS14)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>FCh</td>
<td>Status register 15 (STS15)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

### 25.4.1.2 Module Control Register (MCR)
25.4.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR</td>
<td>0h</td>
</tr>
</tbody>
</table>

25.4.1.2.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bits</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

25.4.1.2.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28-24</td>
<td>Bus timeout cycles</td>
</tr>
<tr>
<td>BTO</td>
<td>AXI Bus timeout cycle is as following (255*(2^BTO)):</td>
</tr>
<tr>
<td></td>
<td>000000b - 255*1</td>
</tr>
<tr>
<td></td>
<td>00001-11110b - 255<em>2 - 255</em>2^30</td>
</tr>
<tr>
<td></td>
<td>11111b - 255*2^31</td>
</tr>
<tr>
<td>23-16</td>
<td>Command Execution timeout cycles</td>
</tr>
<tr>
<td>CTO</td>
<td>When Command Execution time exceed this timeout cycles, IPCMDERR or AXICMDERR interrupt is generated. When CTO is set to zero, timeout cycle is 256<em>1024 cycle. otherwisee timeout cycle is CTO</em>1024 cycle.</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>WAIT/RDY# polarity for NAND</td>
</tr>
<tr>
<td>WPOL1</td>
<td>0b - Active low</td>
</tr>
<tr>
<td></td>
<td>1b - Active high</td>
</tr>
<tr>
<td>6</td>
<td>WAIT/RDY# polarity for NOR/PSRAM</td>
</tr>
<tr>
<td>WPOL0</td>
<td>0b - Active low</td>
</tr>
<tr>
<td></td>
<td>1b - Active high</td>
</tr>
<tr>
<td>5-3</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Memory Map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 2     | DQS (read strobe) mode  
0b - Dummy read strobe loopbacked internally  
1b - Dummy read strobe loopbacked from DQS pad |
| 1     | Module Disable  
0b - Module enabled  
1b - Module disabled |
| 0     | Software Reset  
Reset all internal logic in SEMC except configuration register |

#### 25.4.1.3 IO Mux Control Register (IOCR)

##### 25.4.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IOCR</td>
<td>4h</td>
</tr>
</tbody>
</table>

##### 25.4.1.3.2 Diagram

![Diagram of IO Mux Control Register (IOCR)]

##### 25.4.1.3.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-26</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 25    | MUX_CLKX1 | SEMC_CLKX1 function selection  
0b - NOR clock  
1b - SRAM clock |
| 24    | MUX_CLKX0 | SEMC_CLKX0 function selection  
0b - NOR clock  
1b - SRAM clock |
| 23-18 | Reserved |
| 17-15 | MUX_RDY  | SEMC_RDY function selection  
000b - NAND Ready/Wait# input  
001b - SDRAM CS1  
010b - SDRAM CS2  
011b - SDRAM CS3  
100b - NOR CE#  
101b - PSRAM CE#  
110b - DBI CSX  
111b - NOR/PSRAM Address bit 27 |
| 14-12 | MUX_CSX3 | SEMC_CSX3 output selection  
000b - NOR/PSRAM Address bit 27 (A27)  
001b - SDRAM CS1  
010b - SDRAM CS2  
011b - SDRAM CS3  
100b - NAND CE#  
101b - NOR CE#  
110b - PSRAM CE#  
111b - DBI CSX |
| 11-9  | MUX_CSX2 | SEMC_CSX2 output selection  
000b - NOR/PSRAM Address bit 26 (A26)  
001b - SDRAM CS1  
010b - SDRAM CS2  
011b - SDRAM CS3  
100b - NAND CE#  
101b - NOR CE#  
110b - PSRAM CE#  
111b - DBI CSX |
| 8-6   | MUX_CSX1 | SEMC_CSX1 output selection  
000b - NOR/PSRAM Address bit 25 (A25)  
001b - SDRAM CS1  
010b - SDRAM CS2  
011b - SDRAM CS3  
100b - NAND CE#  
101b - NOR CE#  
110b - PSRAM CE#  
111b - DBI CSX |
| 5-3   | MUX_CSX0 | SEMC_CSX0 output selection  
000b - NOR/PSRAM Address bit 24 (A24)  
001b - SDRAM CS1  
010b - SDRAM CS2  
011b - SDRAM CS3  
100b - NAND CE#  
101b - NOR CE#  
110b - PSRAM CE#  
111b - DBI CSX |

*Table continues on the next page...*
## 25.4.1.4 Bus (AXI) Master Control Register 0 (BMCR0)

### 25.4.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BMCR0</td>
<td>8h</td>
</tr>
</tbody>
</table>

### 25.4.1.4.2 Function

Queue A weight settings for AXI bus access to SDRAM, NAND, NOR, SRAM and DBI slaves.

**NOTE**

Please refer to BMCR0 Registers Configuration

### 25.4.1.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
<td>WRWS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>WSH</td>
<td></td>
<td>WAGE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>WQOS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### 25.4.1.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-16</td>
<td>Weight of slave hit with Read/Write Switch. This weight score is valid when queue command's slave is same as current executing command with read/write operation switch.</td>
</tr>
<tr>
<td>15-8</td>
<td>Weight of Slave Hit without read/write switch. This weight score is valid when queue command's slave is same as current executing command without read/write operation switch.</td>
</tr>
<tr>
<td>7-4</td>
<td>Weight of AGE calculation. Each command in queue has an age signal to indicate its wait period. It is multiplied by WAGE to get weight score.</td>
</tr>
<tr>
<td>3-0</td>
<td>Weight of QOS calculation. AXI bus access has AxQOS signal set, which is used as a priority indicator for the associated write or read transaction. A higher value indicates a higher priority transaction. AxQOS is multiplied by WQOS to get weight score.</td>
</tr>
</tbody>
</table>

### 25.4.1.5 Bus (AXI) Master Control Register 1 (BMCR1)

#### 25.4.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BMCR1</td>
<td>Ch</td>
</tr>
</tbody>
</table>

#### 25.4.1.5.2 Function

Queue B weight settings for AXI bus access to SDRAM slave.

**NOTE**

Please refer to BMCR1 Registers Configuration

#### 25.4.1.5.3 Diagram

![Diagram of BMCR1 Register](attachment:image.png)

---

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

1391
25.4.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24 WBR</td>
<td>Weight of Bank Rotation. This weight score is valid when queue command's bank is not same as current executing command.</td>
</tr>
<tr>
<td>23-16 WRWS</td>
<td>Weight of slave hit without Read/Write Switch. This weight score is valid when queue command's read/write operation is same as current executing command.</td>
</tr>
<tr>
<td>15-8 WPH</td>
<td>Weight of Page Hit. This weight score is valid when queue command's page hits current executing command.</td>
</tr>
<tr>
<td>7-4 WAGE</td>
<td>Weight of AGE calculation. Each command in queue has an age signal to indicate its wait period. It is multiplied by WAGE to get weight score.</td>
</tr>
<tr>
<td>3-0 WQOS</td>
<td>Weight of QOS calculation. AXI bus access has AxQOS signal set, which is used as a priority indicator for the associated write or read transaction. A higher value indicates a higher priority transaction. AxQOS is multiplied by WQOS to get weight score.</td>
</tr>
</tbody>
</table>

25.4.1.6 Base Register 0 (For SDRAM CS0 device) (BR0)

25.4.1.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR0</td>
<td>10h</td>
</tr>
</tbody>
</table>

25.4.1.6.2 Function

This configuration register applied to both AXI command and IP command.

25.4.1.6.3 Diagram

```
Bits 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16
R     W                  BA
Reset 1 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

Bits 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0
R     W                  MS VLD
Reset 0 0 0 0 0 0 0 0 | 0 0 0 1 1 1 0 1
```
### 25.4.1.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12 BA</td>
<td>Base Address&lt;br&gt;This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero.</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1 MS</td>
<td>Memory size&lt;br&gt;00000b - 4KB&lt;br&gt;00001b - 8KB&lt;br&gt;00010b - 16KB&lt;br&gt;00011b - 32KB&lt;br&gt;00100b - 64KB&lt;br&gt;00101b - 128KB&lt;br&gt;00110b - 256KB&lt;br&gt;00111b - 512KB&lt;br&gt;01000b - 1MB&lt;br&gt;01001b - 2MB&lt;br&gt;01010b - 4MB&lt;br&gt;01011b - 8MB&lt;br&gt;01100b - 16MB&lt;br&gt;01101b - 32MB&lt;br&gt;01110b - 64MB&lt;br&gt;01111b - 128MB&lt;br&gt;10000b - 256MB&lt;br&gt;10001b - 512MB&lt;br&gt;10010b - 1GB&lt;br&gt;10011b - 2GB&lt;br&gt;10100-11111b - 4GB</td>
</tr>
<tr>
<td>0 VLD</td>
<td>Valid</td>
</tr>
</tbody>
</table>

### 25.4.1.7 Base Register 1 (For SDRAM CS1 device) (BR1)

#### 25.4.1.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR1</td>
<td>14h</td>
</tr>
</tbody>
</table>

#### 25.4.1.7.2 Function

This configuration register applied to both AXI command and IP command.
25.4.1.7.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Base Address</td>
</tr>
<tr>
<td>BA</td>
<td>This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero.</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1</td>
<td>Memory size</td>
</tr>
<tr>
<td>MS</td>
<td>Memory size</td>
</tr>
<tr>
<td>0</td>
<td>Valid</td>
</tr>
</tbody>
</table>

Memory Map and register definition

Memory Map and register definition

Memory Map and register definition
25.4.1.8 Base Register 2 (For SDRAM CS2 device) (BR2)

25.4.1.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR2</td>
<td>18h</td>
</tr>
</tbody>
</table>

25.4.1.8.2 Function

This configuration register applied to both AXI command and IP command.

25.4.1.8.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>
```

25.4.1.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Base Address</td>
</tr>
<tr>
<td>BA</td>
<td>This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero.</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1</td>
<td>Memory size</td>
</tr>
<tr>
<td>MS</td>
<td>00000b - 4KB</td>
</tr>
<tr>
<td>MS</td>
<td>00001b - 8KB</td>
</tr>
<tr>
<td>MS</td>
<td>00101b - 16KB</td>
</tr>
<tr>
<td>MS</td>
<td>00011b - 32KB</td>
</tr>
<tr>
<td>MS</td>
<td>00100b - 64KB</td>
</tr>
<tr>
<td>MS</td>
<td>00101b - 128KB</td>
</tr>
<tr>
<td>MS</td>
<td>00110b - 256KB</td>
</tr>
<tr>
<td>MS</td>
<td>00111b - 512KB</td>
</tr>
<tr>
<td>MS</td>
<td>01000b - 1MB</td>
</tr>
<tr>
<td>MS</td>
<td>01001b - 2MB</td>
</tr>
<tr>
<td>MS</td>
<td>01010b - 4MB</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Memory Map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>01011b - 8MB</td>
</tr>
<tr>
<td></td>
<td>01100b - 16MB</td>
</tr>
<tr>
<td></td>
<td>01101b - 32MB</td>
</tr>
<tr>
<td></td>
<td>01110b - 64MB</td>
</tr>
<tr>
<td></td>
<td>01111b - 128MB</td>
</tr>
<tr>
<td></td>
<td>10000b - 256MB</td>
</tr>
<tr>
<td></td>
<td>10001b - 512MB</td>
</tr>
<tr>
<td></td>
<td>10010b - 1GB</td>
</tr>
<tr>
<td></td>
<td>10011b - 2GB</td>
</tr>
<tr>
<td></td>
<td>10100-11111b - 4GB</td>
</tr>
<tr>
<td>0</td>
<td>VLD Valid</td>
</tr>
</tbody>
</table>

25.4.1.9  Base Register 3 (For SDRAM CS3 device) (BR3)

25.4.1.9.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR3</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

25.4.1.9.2  Function

This configuration register applied to both AXI command and IP command.

25.4.1.9.3  Diagram

![Diagram of Base Register 3 (BR3)](image-url)
25.4.1.9.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12 BA</td>
<td>Base Address</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1 MS</td>
<td>Memory size</td>
</tr>
<tr>
<td>0</td>
<td>Valid</td>
</tr>
</tbody>
</table>

- 00000b - 4KB
- 00001b - 8KB
- 00010b - 16KB
- 00011b - 32KB
- 00100b - 64KB
- 00101b - 128KB
- 00110b - 256KB
- 00111b - 512KB
- 01000b - 1MB
- 01001b - 2MB
- 01010b - 4MB
- 01011b - 8MB
- 01100b - 16MB
- 01101b - 32MB
- 01110b - 64MB
- 01111b - 128MB
- 10000b - 256MB
- 10001b - 512MB
- 10010b - 1GB
- 10011b - 2GB
- 10100-11111b - 4GB

25.4.1.10 Base Register 4 (For NAND device) (BR4)

25.4.1.10.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR4</td>
<td>20h</td>
</tr>
</tbody>
</table>

25.4.1.10.2 Function
This configuration register applied to AXI command only.
Memory Map and register definition

25.4.1.10.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BA</td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BA</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>VLD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.10.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Base Address</td>
</tr>
<tr>
<td>BA</td>
<td>This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero.</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1</td>
<td>Memory size</td>
</tr>
<tr>
<td>MS</td>
<td>Memory size</td>
</tr>
<tr>
<td>0</td>
<td>Valid</td>
</tr>
</tbody>
</table>

00000b - 4KB
00001b - 8KB
00010b - 16KB
00011b - 32KB
00100b - 64KB
00101b - 128KB
00110b - 256KB
00111b - 512KB
01000b - 1MB
01001b - 2MB
01010b - 4MB
01011b - 8MB
01100b - 16MB
01101b - 32MB
01110b - 64MB
01111b - 128MB
10000b - 256MB
10001b - 512MB
10010b - 1GB
10011b - 2GB
10100-11111b - 4GB
25.4.1.11 Base Register 5 (For NOR device) (BR5)

25.4.1.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR5</td>
<td>24h</td>
</tr>
</tbody>
</table>

25.4.1.11.2 Function

This configuration register applied to both AXI command and IP command.

25.4.1.11.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>VLD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0 0
```

25.4.1.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Base Address</td>
</tr>
<tr>
<td>BA</td>
<td>This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero.</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1</td>
<td>Memory size</td>
</tr>
<tr>
<td>MS</td>
<td>00000b - 4KB</td>
</tr>
<tr>
<td></td>
<td>00001b - 8KB</td>
</tr>
<tr>
<td></td>
<td>00010b - 16KB</td>
</tr>
<tr>
<td></td>
<td>00011b - 32KB</td>
</tr>
<tr>
<td></td>
<td>00100b - 64KB</td>
</tr>
<tr>
<td></td>
<td>00101b - 128KB</td>
</tr>
<tr>
<td></td>
<td>00110b - 256KB</td>
</tr>
<tr>
<td></td>
<td>00111b - 512KB</td>
</tr>
<tr>
<td></td>
<td>01000b - 1MB</td>
</tr>
<tr>
<td></td>
<td>01001b - 2MB</td>
</tr>
<tr>
<td></td>
<td>01010b - 4MB</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Memory Map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>01011b - 8MB</td>
</tr>
<tr>
<td></td>
<td>01100b - 16MB</td>
</tr>
<tr>
<td></td>
<td>01101b - 32MB</td>
</tr>
<tr>
<td></td>
<td>01110b - 64MB</td>
</tr>
<tr>
<td></td>
<td>01111b - 128MB</td>
</tr>
<tr>
<td></td>
<td>10000b - 256MB</td>
</tr>
<tr>
<td></td>
<td>10001b - 512MB</td>
</tr>
<tr>
<td></td>
<td>10010b - 1GB</td>
</tr>
<tr>
<td></td>
<td>10011b - 2GB</td>
</tr>
<tr>
<td></td>
<td>10100-11111b - 4GB</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0</th>
<th>Valid</th>
</tr>
</thead>
<tbody>
<tr>
<td>VLD</td>
<td></td>
</tr>
</tbody>
</table>

### 25.4.1.12 Base Register 6 (For PSRAM device 0) (BR6)

#### 25.4.1.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR6</td>
<td>28h</td>
</tr>
</tbody>
</table>

#### 25.4.1.12.2 Function

This configuration register applied to both AXI command and IP command.

#### 25.4.1.12.3 Diagram

```
| Bits | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

<table>
<thead>
<tr>
<th>Reset</th>
<th>1</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

```
| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

<table>
<thead>
<tr>
<th>Reset</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>VLD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### 25.4.1.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31-12 BA | Base Address  
This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero. |
| 11-6 | Reserved |
| 5-1 MS | Memory size  
00000b - 4KB  
00001b - 8KB  
00010b - 16KB  
00011b - 32KB  
00100b - 64KB  
00101b - 128KB  
00110b - 256KB  
00111b - 512KB  
01000b - 1MB  
01001b - 2MB  
01010b - 4MB  
01011b - 8MB  
01100b - 16MB  
01101b - 32MB  
01110b - 64MB  
01111b - 128MB  
10000b - 256MB  
10001b - 512MB  
10010b - 1GB  
10011b - 2GB  
10100-11111b - 4GB |
| 0 VLD | Valid |

### 25.4.1.13 Base Register 7 (For DBI-B (MIPI Display Bus Interface Type B) device) (BR7)

#### 25.4.1.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR7</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

#### 25.4.1.13.2 Function

This configuration register applied to both AXI command and IP command.
### 25.4.1.13.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### 25.4.1.13.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Base Address</td>
</tr>
<tr>
<td>BA</td>
<td>This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero.</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1</td>
<td>Memory size</td>
</tr>
<tr>
<td>MS</td>
<td>00000b - 4KB</td>
</tr>
<tr>
<td></td>
<td>00001b - 8KB</td>
</tr>
<tr>
<td></td>
<td>00010b - 16KB</td>
</tr>
<tr>
<td></td>
<td>00011b - 32KB</td>
</tr>
<tr>
<td></td>
<td>00100b - 64KB</td>
</tr>
<tr>
<td></td>
<td>00101b - 128KB</td>
</tr>
<tr>
<td></td>
<td>00110b - 256KB</td>
</tr>
<tr>
<td></td>
<td>00111b - 512KB</td>
</tr>
<tr>
<td></td>
<td>01000b - 1MB</td>
</tr>
<tr>
<td></td>
<td>01001b - 2MB</td>
</tr>
<tr>
<td></td>
<td>01010b - 4MB</td>
</tr>
<tr>
<td></td>
<td>01011b - 8MB</td>
</tr>
<tr>
<td></td>
<td>01100b - 16MB</td>
</tr>
<tr>
<td></td>
<td>01101b - 32MB</td>
</tr>
<tr>
<td></td>
<td>01110b - 64MB</td>
</tr>
<tr>
<td></td>
<td>01111b - 128MB</td>
</tr>
<tr>
<td></td>
<td>10000b - 256MB</td>
</tr>
<tr>
<td></td>
<td>10001b - 512MB</td>
</tr>
<tr>
<td></td>
<td>10010b - 1GB</td>
</tr>
<tr>
<td></td>
<td>10011b - 2GB</td>
</tr>
<tr>
<td></td>
<td>10100-11111b - 4GB</td>
</tr>
<tr>
<td>0</td>
<td>Valid</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
25.4.1.14 Base Register 8 (For NAND device) (BR8)

25.4.1.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BR8</td>
<td>30h</td>
</tr>
</tbody>
</table>

25.4.1.14.2 Function

This configuration register applied to IP command only. When IPCMD's KEY is 0xA55A, the configuration of BA and MS is valid. When IPCMD's KEY is 0x5AA5, base address is forced to 0x0 and memory size is not limited by MS.

25.4.1.14.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>VLD</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.14.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Base Address</td>
</tr>
<tr>
<td>BA</td>
<td>This field determines high position 20 bits of SoC level Base Address. SoC level Base Address low position 12 bits are all zero.</td>
</tr>
<tr>
<td>11-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-1</td>
<td>Memory size</td>
</tr>
<tr>
<td>MS</td>
<td>00000b - 4KB</td>
</tr>
<tr>
<td></td>
<td>00001b - 8KB</td>
</tr>
<tr>
<td></td>
<td>00010b - 16KB</td>
</tr>
<tr>
<td></td>
<td>00011b - 32KB</td>
</tr>
<tr>
<td></td>
<td>00100b - 64KB</td>
</tr>
<tr>
<td></td>
<td>00101b - 128KB</td>
</tr>
<tr>
<td></td>
<td>00110b - 256KB</td>
</tr>
<tr>
<td></td>
<td>00111b - 512KB</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Memory Map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>01000b</td>
<td>1MB</td>
</tr>
<tr>
<td>01001b</td>
<td>2MB</td>
</tr>
<tr>
<td>01010b</td>
<td>4MB</td>
</tr>
<tr>
<td>01011b</td>
<td>8MB</td>
</tr>
<tr>
<td>01100b</td>
<td>16MB</td>
</tr>
<tr>
<td>01101b</td>
<td>32MB</td>
</tr>
<tr>
<td>01110b</td>
<td>64MB</td>
</tr>
<tr>
<td>01111b</td>
<td>128MB</td>
</tr>
<tr>
<td>10000b</td>
<td>256MB</td>
</tr>
<tr>
<td>10001b</td>
<td>512MB</td>
</tr>
<tr>
<td>10010b</td>
<td>1GB</td>
</tr>
<tr>
<td>10011b</td>
<td>2GB</td>
</tr>
<tr>
<td>10100b-11111b</td>
<td>4GB</td>
</tr>
</tbody>
</table>

| 0 | VLD |

25.4.1.15 DLL Control Register (DLLCR)

25.4.1.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DLLCR</td>
<td>34h</td>
</tr>
</tbody>
</table>

25.4.1.15.2 Function
This register provides the configuration fields for sample clock from DLL. It is for NAND only.

25.4.1.15.3 Diagram

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### 25.4.1.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14-9</td>
<td>OVRDVAL</td>
</tr>
<tr>
<td></td>
<td>Slave clock delay line delay cell number selection override value. When OVRDEN is set 0x1, the delay cell number in DLL is OVRDVAL+1.</td>
</tr>
<tr>
<td>8</td>
<td>OVRDEN</td>
</tr>
<tr>
<td></td>
<td>Slave clock delay line delay cell number selection override enable.</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6-3</td>
<td>SLVDLYTARGET</td>
</tr>
<tr>
<td></td>
<td>The delay target for slave delay line is: ((SLVDLYTARGET+1) * 1/32 * clock cycle of reference clock (ipgclock).</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>DLLRESET</td>
</tr>
<tr>
<td></td>
<td>Software could force a reset on DLL by setting this field to 0x1. This causes the DLL to lose lock and recalibrate to detect an ref_clock half period phase shift. The reset action is edge triggered, so software need to clear this bit after set this bit (no delay limitation).</td>
</tr>
<tr>
<td>0</td>
<td>DLEN</td>
</tr>
<tr>
<td></td>
<td>DLL calibration enable. When this bit is cleared, DLL calibration is disabled and the delay cell number in slave delay line is always 1. Please note that SLV delay line is overridden when OVRDEN bit is set and this bit field setting is ignored.</td>
</tr>
</tbody>
</table>

### 25.4.1.16 Interrupt Enable Register (INTEN)

#### 25.4.1.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INTEN</td>
<td>38h</td>
</tr>
</tbody>
</table>
### 25.4.1.16.2 Diagram

#### Bits

<table>
<thead>
<tr>
<th>Bits</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
<td></td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
<td></td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

#### Bit Descriptions

**R** Reserved

**W** Reset

**Reset**

<table>
<thead>
<tr>
<th>Bits</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>NAND no pending AXI access interrupt enable</td>
</tr>
<tr>
<td>4</td>
<td>NAND page end interrupt enable</td>
</tr>
<tr>
<td>3</td>
<td>AXI bus error interrupt enable</td>
</tr>
<tr>
<td>2</td>
<td>AXI command error interrupt enable</td>
</tr>
<tr>
<td>1</td>
<td>IP command error interrupt enable</td>
</tr>
<tr>
<td>0</td>
<td>IP command done interrupt enable</td>
</tr>
</tbody>
</table>

#### Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>NAND no pending AXI access interrupt enable</td>
</tr>
<tr>
<td>4</td>
<td>NAND page end interrupt enable</td>
</tr>
<tr>
<td>3</td>
<td>AXI bus error interrupt enable</td>
</tr>
<tr>
<td>2</td>
<td>AXI command error interrupt enable</td>
</tr>
<tr>
<td>1</td>
<td>IP command error interrupt enable</td>
</tr>
<tr>
<td>0</td>
<td>IP command done interrupt enable</td>
</tr>
</tbody>
</table>

**NDNOPENDEN**

This bit enable/disable the NDNOPEND interrupt generation.

- 0b - Interrupt is disabled
- 1b - Interrupt is enabled

**NDPAGEENDEN**

This bit enable/disable the NDPAGEEND interrupt generation.

- 0b - Interrupt is disabled
- 1b - Interrupt is enabled

**AXIBUSERREN**

AXI bus error interrupt enable

- 0b - Interrupt is disabled
- 1b - Interrupt is enabled

**AXICMDERREN**

AXI command error interrupt enable

- 0b - Interrupt is disabled
- 1b - Interrupt is enabled

**IPCMDERREN**

IP command error interrupt enable

- 0b - Interrupt is disabled
- 1b - Interrupt is enabled

**IPCMDDONEEN**

IP command done interrupt enable

- 0b - Interrupt is disabled
- 1b - Interrupt is enabled

---

**Memory Map and register definition**

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

1406 NXP Semiconductors
25.4.1.17 Interrupt Enable Register (INTR)

25.4.1.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INTR</td>
<td>3Ch</td>
</tr>
</tbody>
</table>

25.4.1.17.2 Diagram

```
| Bits | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

25.4.1.17.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>NAND no pending AXI access interrupt</td>
</tr>
<tr>
<td>NDNOPEND</td>
<td>This interrupt is generated when all pending AXI write command to NAND is finished on NAND interface.</td>
</tr>
<tr>
<td>4</td>
<td>NAND page end interrupt</td>
</tr>
<tr>
<td>NDPAGEEND</td>
<td>This interrupt is generated when the last address of one page in NAND device is written by AXI command.</td>
</tr>
<tr>
<td>3</td>
<td>AXI bus error interrupt</td>
</tr>
<tr>
<td>AXIBUSERR</td>
<td>AXI Bus error interrupt is generated in following cases:</td>
</tr>
<tr>
<td></td>
<td>• AXI address is invalid</td>
</tr>
<tr>
<td></td>
<td>• AXI write to NOR flash</td>
</tr>
<tr>
<td></td>
<td>• AXI 8-bit write to 16-bit NAND flash</td>
</tr>
<tr>
<td></td>
<td>• AXI 8-bit or 16-bit WRAP write/read</td>
</tr>
<tr>
<td>2</td>
<td>AXI command error interrupt</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>AXICMDERR</td>
<td>AXI command error interrupt is generated when AXI command execution timeout.</td>
</tr>
<tr>
<td>1</td>
<td>IP command error done interrupt</td>
</tr>
<tr>
<td>IPCMDERR</td>
<td>IP command error interrupt is generated in following case:</td>
</tr>
<tr>
<td></td>
<td>• IP Command Address target invalid device space</td>
</tr>
<tr>
<td></td>
<td>• IP Command Code unsupported</td>
</tr>
<tr>
<td></td>
<td>• IP Command triggered when previous command not finished yet</td>
</tr>
<tr>
<td></td>
<td>• IP Command Execution timeout</td>
</tr>
<tr>
<td>0</td>
<td>IP command normal done interrupt</td>
</tr>
</tbody>
</table>

### 25.4.1.18 SDRAM control register 0 (SDRAMCR0)

#### 25.4.1.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDRAMCR0</td>
<td>40h</td>
</tr>
</tbody>
</table>

#### 25.4.1.18.2 Diagram

```
| Bits | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    | Reserved |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>T8</td>
<td>COL</td>
<td>COL8</td>
<td>B</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>P</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>
```

#### 25.4.1.18.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>2 Bank selection bit</td>
</tr>
<tr>
<td></td>
<td>0b - SDRAM device has 4 banks.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>BANK2</td>
<td>1b - SDRAM device has 2 banks.</td>
</tr>
<tr>
<td>13-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-10</td>
<td>CAS Latency</td>
</tr>
<tr>
<td>CL</td>
<td>00b - 1</td>
</tr>
<tr>
<td></td>
<td>01b - 1</td>
</tr>
<tr>
<td></td>
<td>10b - 2</td>
</tr>
<tr>
<td></td>
<td>11b - 3</td>
</tr>
<tr>
<td>9-8</td>
<td>Column address bit number</td>
</tr>
<tr>
<td>COL</td>
<td>00b - 12 bit</td>
</tr>
<tr>
<td></td>
<td>01b - 11 bit</td>
</tr>
<tr>
<td></td>
<td>10b - 10 bit</td>
</tr>
<tr>
<td></td>
<td>11b - 9 bit</td>
</tr>
<tr>
<td>7-4</td>
<td>Column 8 selection bit</td>
</tr>
<tr>
<td>COL8</td>
<td>0b - Column address bit number is decided by COL field.</td>
</tr>
<tr>
<td></td>
<td>1b - Column address bit number is 8. COL field is ignored.</td>
</tr>
<tr>
<td>6-4</td>
<td>Burst Length</td>
</tr>
<tr>
<td>BL</td>
<td>000b - 1</td>
</tr>
<tr>
<td></td>
<td>001b - 2</td>
</tr>
<tr>
<td></td>
<td>010b - 4</td>
</tr>
<tr>
<td></td>
<td>011b - 8</td>
</tr>
<tr>
<td></td>
<td>100b - 8</td>
</tr>
<tr>
<td></td>
<td>101b - 8</td>
</tr>
<tr>
<td></td>
<td>110b - 8</td>
</tr>
<tr>
<td></td>
<td>111b - 8</td>
</tr>
<tr>
<td>3-1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Port Size</td>
</tr>
<tr>
<td>PS</td>
<td>0b - 8bit</td>
</tr>
<tr>
<td></td>
<td>1b - 16bit</td>
</tr>
</tbody>
</table>

### 25.4.1.19 SDRAM control register 1 (SDRAMCR1)

#### 25.4.1.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDRAMCR1</td>
<td>44h</td>
</tr>
</tbody>
</table>
### 25.4.1.19.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td></td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 25.4.1.19.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-20</td>
<td>ACT to Precharge minimum time</td>
</tr>
<tr>
<td>ACT2PRE</td>
<td>SEMC promises ACT2PRE+1 clock cycles delay between ACTIVE command to PRECHARGE/PRECHARGE_ALL command.</td>
</tr>
<tr>
<td>19-16</td>
<td>CKE OFF minimum time</td>
</tr>
<tr>
<td>CKEOFF</td>
<td>SEMC promises clock suspend last at least CKEOFF+1 clock cycles.</td>
</tr>
<tr>
<td>15-13</td>
<td>Write recovery time</td>
</tr>
<tr>
<td>WRC</td>
<td>SEMC promises WRC+1 clock cycles delay between WRITE command to PRECHARGE/PRECHARGE_ALL command. This could help to meet tWR timing requirement by SDRAM device.</td>
</tr>
<tr>
<td>12-8</td>
<td>Refresh recovery time</td>
</tr>
<tr>
<td>RFRC</td>
<td>SEMC promises RFRC+1 clock cycles delay between REFRESH command to ACTIVE command. This could help to meet tRFC timing requirement by SDRAM device.</td>
</tr>
<tr>
<td>7-4</td>
<td>ACT to Read/Write wait time</td>
</tr>
<tr>
<td>ACT2RW</td>
<td>SEMC promises ACT2RW+1 clock cycles delay between ACTIVE command to READ/WRITE command. This could help to meet tRCD timing requirement by SDRAM device.</td>
</tr>
<tr>
<td>3-0</td>
<td>PRECHARGE to ACT/Refresh wait time</td>
</tr>
<tr>
<td>PRE2ACT</td>
<td>SEMC promises PRE2ACT+1 clock cycles delay between PRECHARGE/PRECHARGE_ALL command to ACTIVE/REFRESH command. This could help to meet tRP timing requirement by SDRAM device.</td>
</tr>
</tbody>
</table>

### 25.4.1.20 SDRAM control register 2 (SDRAMCR2)
### 25.4.1.20.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDRAMCR2</td>
<td>48h</td>
</tr>
</tbody>
</table>

### 25.4.1.20.2 Diagram

#### Bits 31-24

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>ITO</td>
<td>1 0 0 0 0 0 0 0</td>
</tr>
<tr>
<td></td>
<td>ACT2ACT</td>
<td>0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

#### Bits 15-8

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>REF2REF</td>
<td>0 0 0 1 1 1 1 0</td>
</tr>
<tr>
<td></td>
<td>SRRC</td>
<td>1 1 1 0 1 1 1 0</td>
</tr>
</tbody>
</table>

### 25.4.1.20.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31-24 ITO | SDRAM Idle timeout  
SEMC closes all opened pages if the SDRAM idle time lasts more than idle timeout period. SDRAM is considered idle when there is no AXI Bus transfer and no SDRAM command pending.  
00000000b - IDLE timeout period is 256*Prescale period.  
00000001-11111111b - IDLE timeout period is ITO*Prescale period. |

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 23-16 ACT2ACT | ACT to ACT wait time  
SEMC promises ACT2ACT+1 clock cycles delay between ACTIVE command to ACTIVE command. This could help to meet tRRD timing requirement by SDRAM device. |

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15-8 REF2REF | Refresh to Refresh wait time  
SEMC promises REF2REF+1 clock cycles delay between REFRESH command to REFRESH command. This could help to meet tRFC timing requirement by SDRAM device. |

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 7-0 SRRC | Self Refresh Recovery time  
SEMC promises SRRC+1 clock cycles delay between Self-REFRESH command to any command. |

### 25.4.1.21 SDRAM control register 3 (SDRAMCR3)
# 25.4.1.21.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDRAMCR3</td>
<td>4Ch</td>
</tr>
</tbody>
</table>

# 25.4.1.21.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

# 25.4.1.21.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Refresh urgent threshold</td>
</tr>
<tr>
<td>UT</td>
<td>Internal refresh request is generated on every Refresh period. Before internal request timer count up to urgent request threshold, the refresh request is considered as normal refresh request. Normal refresh request is handled in lower priority than any pending AXI command or IP command to SDRAM device. When internal request timer count up to this urgent threshold, refresh request is considered as urgent refresh request. Urgent refresh request is handled in higher priority than any pending AXI command or IP command to SDRAM device.</td>
</tr>
<tr>
<td>NOTE: When urgent threshold is no less than refresh period, refresh request is always considered as urgent refresh request.</td>
<td></td>
</tr>
<tr>
<td>Refresh urgent threshold is as following:</td>
<td></td>
</tr>
<tr>
<td>00000000b - 256*Prescaler period</td>
<td></td>
</tr>
<tr>
<td>00000001-11111111b - UT*Prescaler period</td>
<td></td>
</tr>
</tbody>
</table>

| 23-16 | Refresh timer period |
| RT    | Refresh timer period is as following: |
|       | 00000000b - 256*Prescaler period |
|       | 00000001-11111111b - RT*Prescaler period |

| 15-8  | Prescaler timer period |
| PRESCALE | Prescaler timer period is as following: |
|       | 00000000b - 256*16 clock cycles |
|       | 00000001-11111111b - PRESCALE*16 clock cycles |

| 7-4  | Reserved |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>3-1</td>
<td>Refresh burst length</td>
</tr>
<tr>
<td>REBL</td>
<td>SEMC could send multiple Auto-Refresh command in one burst when REBL is set to non-zero. The number of Auto-Refresh command cycle sent to all SDRAM device in one refresh period is as following.</td>
</tr>
<tr>
<td>0</td>
<td>Refresh enable</td>
</tr>
</tbody>
</table>

000b - 1
001b - 2
010b - 3
011b - 4
100b - 5
101b - 6
110b - 7
111b - 8

---

**25.4.1.22 NAND control register 0 (NANDCR0)**

**25.4.1.22.1 Offset**

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NANDCR0</td>
<td>50h</td>
</tr>
</tbody>
</table>

**25.4.1.22.2 Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Res</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**25.4.1.22.3 Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-11</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>_</td>
<td></td>
</tr>
</tbody>
</table>
| 10-8 COL | Column address bit number  
| 000b - 16  
| 001b - 15  
| 010b - 14  
| 011b - 13  
| 100b - 12  
| 101b - 11  
| 110b - 10  
| 111b - 9   |
| 7 EDO | EDO mode enabled  
| 0b - EDO mode disabled  
| 1b - EDO mode enabled |
| 6-4 BL | Burst Length  
| 000b - 1   
| 001b - 2   
| 010b - 4   
| 011b - 8   
| 100b - 16  
| 101b - 32  
| 110b - 64  
| 111b - 64  |
| 3-2 _ | Reserved |
| 1 SYNCEN | Select NAND controller mode.  
| 0b - ASYNC mode is enabled.  
| 1b - SYNC mode is enabled.  |
| 0 PS | Port Size  
| 0b - 8bit   
| 1b - 16bit  |

**25.4.1.23 NAND control register 1 (NANDCR1)**

**25.4.1.23.1 Offset**

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NANDCR1</td>
<td>54h</td>
</tr>
</tbody>
</table>
### 25.4.1.23.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>CEITV</td>
<td>TA</td>
<td></td>
<td></td>
<td></td>
<td>REH</td>
<td></td>
<td>REL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>WEH</td>
<td>WEL</td>
<td></td>
<td></td>
<td></td>
<td>CEH</td>
<td></td>
<td>CES</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 25.4.1.23.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>CE# interval time</td>
</tr>
<tr>
<td>CEITV</td>
<td>CE# interval minimum time is CEITV+1 clock cycles.</td>
</tr>
<tr>
<td>27-24</td>
<td>Turnaround time</td>
</tr>
<tr>
<td>TA</td>
<td>Turnaround time is TA+1 clock cycles. Both SEMC and Device would not drive Data Lines to avoid bus confliction. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>23-20</td>
<td>RE# high time</td>
</tr>
<tr>
<td>REH</td>
<td>RE# high time is REH+1 clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>19-16</td>
<td>RE# low time</td>
</tr>
<tr>
<td>REL</td>
<td>RE# low time is REL+1 clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>15-12</td>
<td>WE# high time</td>
</tr>
<tr>
<td>WEH</td>
<td>WE# high time is WEH+1 clock cycles in ASYNC mode. It is used as command and address hold time in SYNC mode. WEH must be even number in SYNC mode, and command/address hold time is WEH clock cycles.</td>
</tr>
<tr>
<td>11-8</td>
<td>WE# low time</td>
</tr>
<tr>
<td>WEL</td>
<td>WE# low time is WEL+1 clock cycles in ASYNC mode. It is used as command and address setup time in SYNC mode. WEL must be even number in SYNC mode, and command/address setup time is WEL+2 clock cycles.</td>
</tr>
<tr>
<td>7-4</td>
<td>CE hold time</td>
</tr>
<tr>
<td>CEH</td>
<td>CE hold minimum time is CEH+1 clock cycles. CEH must be odd number in SYNC mode. CE hold time may be larger than this time to wait all read data sampled.</td>
</tr>
<tr>
<td>3-0</td>
<td>CE setup time</td>
</tr>
<tr>
<td>CES</td>
<td>CE setup time is CES+1 clock cycles. CES must be odd number in SYNC mode.</td>
</tr>
</tbody>
</table>

### 25.4.1.24 NAND control register 2 (NANDCR2)


25.4.1.24.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NANDCR2</td>
<td>58h</td>
</tr>
</tbody>
</table>

25.4.1.24.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>TWB</td>
<td>TR</td>
<td>TADL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>TADL</td>
<td>TRHW</td>
<td>TWHR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.24.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29-24</td>
<td>WE# high to busy wait time</td>
</tr>
<tr>
<td></td>
<td>TWB</td>
</tr>
<tr>
<td>23-18</td>
<td>WE# high to busy wait time is TWB+1 clock cycles</td>
</tr>
<tr>
<td>TRR</td>
<td>Ready to RE# low wait time</td>
</tr>
<tr>
<td></td>
<td>Ready to RE# low minimum wait time is TRR+1 clock cycles. Actual wait time may be 1 or 2 clock cycles more than this because of synchronizer logic. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>17-12</td>
<td>ALE to write data start wait time</td>
</tr>
<tr>
<td>TADL</td>
<td>ALE to write data wait time is TADL+1 clock cycles. Timing for TADL begins in the address cycle on the final rising edge of WE#, and ends with the first rising edge of WE# for data input.</td>
</tr>
<tr>
<td>11-6</td>
<td>RE# high to WE# low wait time</td>
</tr>
<tr>
<td>TRHW</td>
<td>RE# high to WE# low wait time is TRHW+1 clock cycles</td>
</tr>
<tr>
<td>5-0</td>
<td>WE# high to RE# low wait time</td>
</tr>
<tr>
<td>TWHR</td>
<td>WE# high to RE# low wait time is TWHR+1 clock cycles</td>
</tr>
</tbody>
</table>
25.4.1.25 NAND control register 3 (NANDCR3)

25.4.1.25.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NANDCR3</td>
<td>5Ch</td>
</tr>
</tbody>
</table>

25.4.1.25.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.25.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Write Data Hold time. Write data hold time is WDH+2 clock cycles, and WDH must be even number. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>WDH</td>
<td>Write Data Setup time. Write data setup time is WDS+2 clock cycles, and WDS must be even number. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>27-24</td>
<td>Read Data Hold time. Read data hold time is RDH+2 clock cycles, and RDH must be even number. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>WDS</td>
<td>Read Data Setup time. Read data setup time is RDS+2 clock cycles, and RDS must be even number. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>19-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>RDS</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>NAND option bit 3</td>
</tr>
</tbody>
</table>

Table continues on the next page...
25.4.1.26  NOR control register 0 (NORCR0)

25.4.1.26.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NORCR0</td>
<td>60h</td>
</tr>
</tbody>
</table>

25.4.1.26.2  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

25.4.1.26.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-12</td>
<td>Column Address bit width</td>
</tr>
</tbody>
</table>

*NOTE: Please refer to NAND Flash access address type*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>COL</td>
<td>0000b - 12 Bits</td>
</tr>
<tr>
<td></td>
<td>0001b - 11 Bits</td>
</tr>
<tr>
<td></td>
<td>0010b - 10 Bits</td>
</tr>
<tr>
<td></td>
<td>0011b - 9 Bits</td>
</tr>
<tr>
<td></td>
<td>0100b - 8 Bits</td>
</tr>
<tr>
<td></td>
<td>0101b - 7 Bits</td>
</tr>
<tr>
<td></td>
<td>0110b - 6 Bits</td>
</tr>
<tr>
<td></td>
<td>0111b - 5 Bits</td>
</tr>
<tr>
<td></td>
<td>1000b - 4 Bits</td>
</tr>
<tr>
<td></td>
<td>1001b - 3 Bits</td>
</tr>
<tr>
<td></td>
<td>1010b - 2 Bits</td>
</tr>
<tr>
<td></td>
<td>1011b - 12 Bits</td>
</tr>
<tr>
<td></td>
<td>1100b - 12 Bits</td>
</tr>
<tr>
<td></td>
<td>1101b - 12 Bits</td>
</tr>
<tr>
<td></td>
<td>1110b - 12 Bits</td>
</tr>
<tr>
<td></td>
<td>1111b - 12 Bits</td>
</tr>
<tr>
<td>11</td>
<td>ADV# level control during address hold state</td>
</tr>
<tr>
<td>ADVH</td>
<td>0b - ADV# is high during address hold state.</td>
</tr>
<tr>
<td></td>
<td>1b - ADV# is low during address hold state.</td>
</tr>
<tr>
<td>10</td>
<td>ADV# polarity</td>
</tr>
<tr>
<td>ADVP</td>
<td>0b - ADV# is active low.</td>
</tr>
<tr>
<td></td>
<td>1b - ADV# is active high.</td>
</tr>
<tr>
<td>9-8</td>
<td>Address Mode</td>
</tr>
<tr>
<td>AM</td>
<td>00b - Address/Data MUX mode (ADMUX)</td>
</tr>
<tr>
<td></td>
<td>01b - Advanced Address/Data MUX mode (AADM)</td>
</tr>
<tr>
<td></td>
<td>10b - Reserved</td>
</tr>
<tr>
<td></td>
<td>11b - Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6-4</td>
<td>Burst Length</td>
</tr>
<tr>
<td>BL</td>
<td>00b - 1</td>
</tr>
<tr>
<td></td>
<td>001b - 2</td>
</tr>
<tr>
<td></td>
<td>010b - 4</td>
</tr>
<tr>
<td></td>
<td>011b - 8</td>
</tr>
<tr>
<td></td>
<td>100b - 16</td>
</tr>
<tr>
<td></td>
<td>101b - 32</td>
</tr>
<tr>
<td></td>
<td>110b - 64</td>
</tr>
<tr>
<td></td>
<td>111b - 64</td>
</tr>
<tr>
<td>3-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Select NOR controller mode.</td>
</tr>
<tr>
<td>SYNCEN</td>
<td>0b - ASYNC mode is enabled.</td>
</tr>
<tr>
<td></td>
<td>1b - SYNC mode is enabled.</td>
</tr>
<tr>
<td>0</td>
<td>Port Size</td>
</tr>
<tr>
<td>PS</td>
<td>0b - 8bit</td>
</tr>
<tr>
<td></td>
<td>1b - 16bit</td>
</tr>
</tbody>
</table>

**25.4.1.27 NOR control register 1 (NORCR1)**
25.4.1.27.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NORCR1</td>
<td>64h</td>
</tr>
</tbody>
</table>

25.4.1.27.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>REH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>REL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>WEH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>WEL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CEH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CES</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

25.4.1.27.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>RE high time</td>
</tr>
<tr>
<td>REH</td>
<td>RE high time is REH+1 clock cycles for ASYNC mode.</td>
</tr>
<tr>
<td>27-24</td>
<td>RE low time</td>
</tr>
<tr>
<td>REL</td>
<td>RE low time is REL+1 clock cycles for ASYNC mode.</td>
</tr>
<tr>
<td>23-20</td>
<td>WE high time</td>
</tr>
<tr>
<td>WEH</td>
<td>WE high time is WEH+1 clock cycles for ASYNC mode.</td>
</tr>
<tr>
<td>19-16</td>
<td>WE low time</td>
</tr>
<tr>
<td>WEL</td>
<td>WE low time is WEL+1 clock cycles for ASYNC mode.</td>
</tr>
<tr>
<td>15-12</td>
<td>Address hold time</td>
</tr>
<tr>
<td>AH</td>
<td>Address hold time is AH+1 clock cycles for ASYNC mode.</td>
</tr>
<tr>
<td>11-8</td>
<td>Address setup time</td>
</tr>
<tr>
<td>AS</td>
<td>Address setup time is AS+1 clock cycles</td>
</tr>
<tr>
<td>7-4</td>
<td>CE hold time</td>
</tr>
<tr>
<td>CEH</td>
<td>CE Hold time is CEH+1 clock cycles</td>
</tr>
<tr>
<td></td>
<td>This field determines the minimum hold time. Actual hold time may be longer in order to wait all read data sampled.</td>
</tr>
<tr>
<td>3-0</td>
<td>CE setup time</td>
</tr>
<tr>
<td>CES</td>
<td>CE setup time is CES+1 clock cycles.</td>
</tr>
</tbody>
</table>
25.4.1.28  NOR control register 2 (NORCR2)

25.4.1.28.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NORCR2</td>
<td>68h</td>
</tr>
</tbody>
</table>

25.4.1.28.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RDH</td>
<td></td>
<td>CEITV</td>
<td></td>
<td>RD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>AWDH</td>
<td></td>
<td>TA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.28.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Read hold time</td>
</tr>
<tr>
<td>RDH</td>
<td>Read hold time is RDH clock cycles. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>27-24</td>
<td>CE# interval time</td>
</tr>
<tr>
<td>CEITV</td>
<td>CE# interval minimum time is CEITV+1 clock cycles.</td>
</tr>
<tr>
<td>23-20</td>
<td>Read time</td>
</tr>
<tr>
<td>RD</td>
<td>Read time is RD+1 clock cycles. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>19-16</td>
<td>Latency count</td>
</tr>
<tr>
<td>LC</td>
<td>Latency count is LC clock cycles. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>15-12</td>
<td>Address to write data hold time</td>
</tr>
<tr>
<td>AWDH</td>
<td>Address to write data hold time is AWDH clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>11-8</td>
<td>Turnaround time</td>
</tr>
<tr>
<td>TA</td>
<td>Turnaround time is TA+1 clock cycles. Both SEMC and Device would not drive Data Lines to avoid bus confliction. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>7-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
25.4.1.29  NOR control register 3 (NORCR3)

25.4.1.29.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>NORCR3</td>
<td>6Ch</td>
</tr>
</tbody>
</table>

25.4.1.29.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>AHSR</td>
<td></td>
<td>ASSR</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.29.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-4</td>
<td>Address hold time for SYNC read</td>
</tr>
<tr>
<td>AHSR</td>
<td>Address hold time is AHSR clock cycles for SYNC read.</td>
</tr>
<tr>
<td>3-0</td>
<td>Address setup time for SYNC read</td>
</tr>
<tr>
<td>ASSR</td>
<td>Address setup time ASSR+1 clock cycles for SYNC read.</td>
</tr>
</tbody>
</table>

25.4.1.30  SRAM control register 0 (SRAMCR0)

25.4.1.30.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRAMCR0</td>
<td>70h</td>
</tr>
</tbody>
</table>
25.4.1.30.2 Function
This register configures PSRAM device 0

25.4.1.30.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>COL</td>
<td>ADH</td>
<td>ADVP</td>
<td>AM</td>
<td>Reserved</td>
<td>B</td>
<td>L</td>
<td>Reserved</td>
<td>SYNCE</td>
<td>N</td>
<td>P</td>
<td>S</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.30.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15-12 | Column Address bit width  
   0000b - 12 Bits  
   0001b - 11 Bits  
   0010b - 10 Bits  
   0011b - 9 Bits  
   0100b - 8 Bits  
   0101b - 7 Bits  
   0110b - 6 Bits  
   0111b - 5 Bits  
   1000b - 4 Bits  
   1001b - 3 Bits  
   1010b - 2 Bits  
   1011b - 12 Bits  
   1100b - 12 Bits  
   1101b - 12 Bits  
   1110b - 12 Bits  
   1111b - 12 Bits  |

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 11    | ADV# level control during address hold state  
   0b - ADV# is high during address hold state.  
   1b - ADV# is low during address hold state.  |

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 10    | ADV# polarity  
   0b - ADV# is active low.  
   1b - ADV# is active high.  |
### Memory Map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 9-8 AM | Address Mode  
00b - Address/Data MUX mode (ADMUX)  
01b - Advanced Address/Data MUX mode (AADM)  
10b - Reserved  
11b - Reserved |
| 7     | Reserved |
| 6-4 BL | Burst Length  
000b - 1  
001b - 2  
010b - 4  
011b - 8  
100b - 16  
101b - 32  
110b - 64  
111b - 64 |
| 3-2 | Reserved |
| 1 SYNREN | Select SRAM controller mode.  
0b - ASYNC mode is enabled.  
1b - SYNC mode is enabled. |
| 0 PS | Port Size  
0b - 8bit  
1b - 16bit |

### 25.4.1.31 SRAM control register 1 (SRAMCR1)

#### 25.4.1.31.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRAMCR1</td>
<td>74h</td>
</tr>
</tbody>
</table>

#### 25.4.1.31.2 Function

This register configures PSRAM device 0
25.4.1.31.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>REH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>REL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>AH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>AS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.31.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>RE high time</td>
</tr>
<tr>
<td>REH</td>
<td>RE high time is REH+1 clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>27-24</td>
<td>RE low time</td>
</tr>
<tr>
<td>REL</td>
<td>RE low time is REL+1 clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>23-20</td>
<td>WE high time</td>
</tr>
<tr>
<td>WEH</td>
<td>WE high time is WEH+1 clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>19-16</td>
<td>WE low time</td>
</tr>
<tr>
<td>WEL</td>
<td>WE low time is WEL+1 clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>15-12</td>
<td>Address hold time</td>
</tr>
<tr>
<td>AH</td>
<td>Address hold time is AH+1 clock cycles for ASYNC mode. Address hold time is AH clock cycles for SYNC mode.</td>
</tr>
<tr>
<td>11-8</td>
<td>Address setup time</td>
</tr>
<tr>
<td>AS</td>
<td>Address setup time is AS+1 clock cycles</td>
</tr>
<tr>
<td>7-4</td>
<td>CE hold time</td>
</tr>
<tr>
<td>CEH</td>
<td>CE Hold time is CEH+1 clock cycles. This field determines the minimum hold time. Actual hold time may be larger in order to wait all read data sampled.</td>
</tr>
<tr>
<td>3-0</td>
<td>CE setup time</td>
</tr>
<tr>
<td>CES</td>
<td>CE setup time is CES+1 clock cycles.</td>
</tr>
</tbody>
</table>

25.4.1.32  SRAM control register 2 (SRAMCR2)
25.4.1.32.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRAMCR2</td>
<td>78h</td>
</tr>
</tbody>
</table>

25.4.1.32.2 Function

This register configures PSRAM device 0

25.4.1.32.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RDH</td>
<td>CEITV</td>
<td>RD</td>
<td>LC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>AWDH</td>
<td>TA</td>
<td>WDH</td>
<td>WDS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

25.4.1.32.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Read hold time</td>
</tr>
<tr>
<td>RDH</td>
<td>Read hold time is RDH clock cycles. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>27-24</td>
<td>CE# interval time</td>
</tr>
<tr>
<td>CEITV</td>
<td>CE# interval minimum time is CEITV+1 clock cycles.</td>
</tr>
<tr>
<td>23-20</td>
<td>Read time</td>
</tr>
<tr>
<td>RD</td>
<td>Read time is RD+1 clock cycles. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>19-16</td>
<td>Latency count</td>
</tr>
<tr>
<td>LC</td>
<td>Latency count is LC clock cycles. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>15-12</td>
<td>Address to write data hold time</td>
</tr>
<tr>
<td>AWDH</td>
<td>Address to write data hold time is AWDH clock cycles. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>11-8</td>
<td>Turnaround time</td>
</tr>
<tr>
<td>TA</td>
<td>Turnaround time is TA+1 clock cycles. Both SEMC and Device would not drive Data Lines to avoid bus confliction. This field applied to ASYNC mode only.</td>
</tr>
<tr>
<td>7-4</td>
<td>Write Data hold time</td>
</tr>
<tr>
<td>WDH</td>
<td>Write data hold time is WDH clock cycles. This field applied to SYNC mode only.</td>
</tr>
<tr>
<td>3-0</td>
<td>Write Data setup time</td>
</tr>
</tbody>
</table>
25.4.1.33  SRAM control register 3 (SRAMCR3)

25.4.1.33.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRAMCR3</td>
<td>7Ch</td>
</tr>
</tbody>
</table>

25.4.1.33.2  Function

This register configures PSRAM device 0

25.4.1.33.3  Diagram

![Diagram of SRAM control register 3 (SRAMCR3)]

25.4.1.33.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

25.4.1.34  DBI-B control register 0 (DBICR0)
## 25.4.1.34.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DBICR0</td>
<td>80h</td>
</tr>
</tbody>
</table>

## 25.4.1.34.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- **R** = Readable
- **W** = Writable
- **Reserved**
- **COL** = Column Address bit width

### 15-12 COL

- **0000b** - 12 Bits
- **0001b** - 11 Bits
- **0010b** - 10 Bits
- **0011b** - 9 Bits
- **0100b** - 8 Bits (Reserved)
- **0101b** - 7 Bits
- **0110b** - 6 Bits
- **0111b** - 5 Bits
- **1000b** - 4 Bits
- **1001b** - 3 Bits
- **1010b** - 2 Bits
- **1011b** - 12 Bits
- **1100b** - 12 Bits
- **1101b** - 12 Bits
- **1110b** - 12 Bits
- **1111b** - 12 Bits

### 11-7 Reserved

### 6-4 BL

- **000b** - 1
- **001b** - 2
- **010b** - 4

*Table continues on the next page...*
### 25.4.1.35 DBI-B control register 1 (DBICR1)

#### 25.4.1.35.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DBICR1</td>
<td>84h</td>
</tr>
</tbody>
</table>

#### 25.4.1.35.2 Diagram

![Diagram](image)

#### 25.4.1.35.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>RDX High Time bit [5:4]</td>
</tr>
<tr>
<td>REH2</td>
<td>RDX High time is REH+1 clock cycles</td>
</tr>
<tr>
<td>29-28</td>
<td>RDX Low Time bit [5:4]</td>
</tr>
<tr>
<td>REL2</td>
<td>RDX Low time is REL+1 clock cycles</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>27-24</td>
<td>CSX interval time</td>
</tr>
<tr>
<td>CEITV</td>
<td>CSX interval minimum time is CEITV+1 clock cycles.</td>
</tr>
<tr>
<td>23-20</td>
<td>RDX High Time bit [3:0]</td>
</tr>
<tr>
<td>REH</td>
<td>RDX High time is REH+1 clock cycles</td>
</tr>
<tr>
<td>19-16</td>
<td>RDX Low Time bit [3:0]</td>
</tr>
<tr>
<td>REL</td>
<td>RDX Low time is REL+1 clock cycles</td>
</tr>
<tr>
<td>15-12</td>
<td>WRX High Time</td>
</tr>
<tr>
<td>WEH</td>
<td>WRX High time is WEH+1 clock cycles</td>
</tr>
<tr>
<td>11-8</td>
<td>WRX Low Time</td>
</tr>
<tr>
<td>WEL</td>
<td>WRX Low time is WEL+1 clock cycles</td>
</tr>
<tr>
<td>7-4</td>
<td>CSX Hold Time</td>
</tr>
<tr>
<td>CEH</td>
<td>CSX Hold minimum time is CEH+1 clock cycles.</td>
</tr>
<tr>
<td></td>
<td>This field determines the minimum hold time. Actual hold time may be larger in order to wait all read data sampled.</td>
</tr>
<tr>
<td>3-0</td>
<td>CSX Setup Time</td>
</tr>
<tr>
<td>CES</td>
<td>CSX Setup time is CES+1 clock cycles</td>
</tr>
</tbody>
</table>

### 25.4.1.36 IP Command control register 0 (IPCR0)

#### 25.4.1.36.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPCR0</td>
<td>90h</td>
</tr>
</tbody>
</table>

#### 25.4.1.36.2 Function

Slave address
25.4.1.36.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.36.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Slave address</td>
</tr>
<tr>
<td>SA</td>
<td></td>
</tr>
</tbody>
</table>

25.4.1.37  IP Command control register 1 (IPCR1)

25.4.1.37.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPCR1</td>
<td>94h</td>
</tr>
</tbody>
</table>

25.4.1.37.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
Memory Map and register definition

25.4.1.37.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-8</td>
<td>NAND Extended Address</td>
</tr>
<tr>
<td>NAND_EXT_AD DR</td>
<td>NAND IP command address is extended to 40-bit while IPCMD's KEY is 0x5AA5. High 8-bit is NAND_EXT_ADDR, and low 32-bit is IPCR0.</td>
</tr>
<tr>
<td>7-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2-0</td>
<td>Data Size in Byte</td>
</tr>
<tr>
<td>DATSZ</td>
<td>When IP command is not a write/read operation, DATSZ field would be ignored.</td>
</tr>
<tr>
<td></td>
<td>000b - 4</td>
</tr>
<tr>
<td></td>
<td>001b - 1</td>
</tr>
<tr>
<td></td>
<td>010b - 2</td>
</tr>
<tr>
<td></td>
<td>011b - 3</td>
</tr>
<tr>
<td></td>
<td>100b - 4</td>
</tr>
<tr>
<td></td>
<td>101b - 4</td>
</tr>
<tr>
<td></td>
<td>110b - 4</td>
</tr>
<tr>
<td></td>
<td>111b - 4</td>
</tr>
</tbody>
</table>

25.4.1.38 IP Command control register 2 (IPCR2)

25.4.1.38.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPCR2</td>
<td>98h</td>
</tr>
</tbody>
</table>

25.4.1.38.2 Diagram

```
+-------------+-----------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------+-------------|             |
| Bits       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Reset      |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits       | 15 | 14 | 13 | 12 | 11 | 10 |  9 |  8 |  7 |  6 |  5 |  4 |  3 |  2 |  1 |  0 |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset      |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
```
### 25.4.1.38.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>BM3</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>BM2</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>BM1</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>BM0</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 25.4.1.39 IP Command register (IPCMD)

#### 25.4.1.39.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPCMD</td>
<td>9Ch</td>
</tr>
</tbody>
</table>

#### 25.4.1.39.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Key</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cmd</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```
### 25.4.1.39.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31-16 KEY | This field should be written with 0xA55A when triggering an IP command for all device types. The memory device is selected by BRx settings and IPCR0 registers.  
This field should be written with 0x5AA5 when triggering an IP command for NAND only. The address is extended to 40-bit with the use of NAND_EXT_ADDR. NAND IP base address is from 0x0 and memory size is not limited by BR8.MS. |
| 15-0 CMD | SDRAM Commands:  
- 0x8: READ  
- 0x9: WRITE  
- 0xA: MODESET  
- 0xB: ACTIVE  
- 0xC: AUTO REFRESH  
- 0xD: SELF REFRESH  
- 0xE: PRECHARGE  
- 0xF: PRECHARGE ALL  
- Others: RSVD  

**NOTE:** SELF REFRESH is sent to all SDRAM devices because they shared same SEMC_CLK pin.  
NAND Commands:  
Bit 15-8 (Command Code)  
Bit 7-4 (Address mode):  
- 0x0: Column and Row address(5 Byte-CA0/CA1/RA0/RA1/RA2)  
- 0x1: Column address only (1 Byte-CA0)  
- 0x2: Column address only (2 Byte-CA0/CA1)  
- 0x3: Row address only (1 Byte-RA0)  
- 0x4: Row address only (2 Byte-RA0/RA1)  
- 0x5: Row address only (3 Byte-RA0/RA1/RA2)  
- Others: RSVD  

Bit 3-0 (Command mode):  
- 0x0: Command(0x05)-Address-Command-Read (Reserved for AXI Read)  
- 0x1: Command(0x85)-Address-Write (Reserved for AXI Write)  
- 0x2: Command  
- 0x3: Command-Hold  
- 0x4: Command-Address  
- 0x5: Command-Address-Hold  
- 0x6: Command-Address-Read  
- 0x7: Command-Address-Write  
- 0x8: Command-Read  
- 0x9: Command-Write  
- 0xA: Read  
- 0xB: Write  
- Others: RSVD  

NOR Commands:  
- 0x2: READ  
- 0x3: WRITE  
- Others: RSVD  

SRAM Commands:  
- 0x2: Memory ARRAY READ  
- 0x3: Memory ARRAY WRITE
### Field | Function
---|---
• 0x4: Memory register READ
• 0x5: Memory register WRITE
• Others: RSVD

**DBI_B Commands:**
• Others: RSVD
• 0x2: Read
• 0x3: Write

---

### 25.4.1.40  TX DATA register (for IP Command) (IPTXDAT)

#### 25.4.1.40.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPTXDAT</td>
<td>A0h</td>
</tr>
</tbody>
</table>

#### 25.4.1.40.2  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAT</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAT</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAT</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DAT</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

#### 25.4.1.40.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>data</td>
</tr>
<tr>
<td>DAT</td>
<td></td>
</tr>
</tbody>
</table>
25.4.1.41  RX DATA register (for IP Command) (IPRXDAT)

25.4.1.41.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPRXDAT</td>
<td>B0h</td>
</tr>
</tbody>
</table>

25.4.1.41.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.41.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>data</td>
</tr>
<tr>
<td>DAT</td>
<td></td>
</tr>
</tbody>
</table>

25.4.1.42  Status register 0 (STS0)

25.4.1.42.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS0</td>
<td>C0h</td>
</tr>
</tbody>
</table>
### 25.4.1.42.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

### 25.4.1.42.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Indicating NAND device Ready/WAIT# pin level.</td>
</tr>
<tr>
<td>NARDY</td>
<td>0b - NAND device is not ready</td>
</tr>
<tr>
<td></td>
<td>1b - NAND device is ready</td>
</tr>
<tr>
<td>0</td>
<td>Indicating whether SEMC is in IDLE state.</td>
</tr>
<tr>
<td>IDLE</td>
<td>When IDLE=1, SEMC is in IDLE state. There is no pending AXI command in</td>
</tr>
<tr>
<td></td>
<td>internal queue and no pending device access.</td>
</tr>
</tbody>
</table>

### 25.4.1.43 Status register 1 (STS1)

#### 25.4.1.43.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS1</td>
<td>C4h</td>
</tr>
</tbody>
</table>
25.4.1.43.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.43.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
</tbody>
</table>

25.4.1.44  Status register 2 (STS2)

25.4.1.44.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS2</td>
<td>C8h</td>
</tr>
</tbody>
</table>
### 25.4.1.44.2 Diagram

#### Bits

<table>
<thead>
<tr>
<th></th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### Bits

<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 25.4.1.44.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>NDWRPEND</td>
</tr>
<tr>
<td></td>
<td>This field indicating whether there is pending AXI command (write) to NAND device. 0b - No pending 1b - Pending</td>
</tr>
<tr>
<td>2-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 25.4.1.45 Status register 3 (STS3)

#### 25.4.1.45.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS3</td>
<td>CCh</td>
</tr>
</tbody>
</table>
Memory Map and register definition

25.4.1.45.2  Diagram

Bits  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16
---   |-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----
R     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
W     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
Reset| 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

Bits  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0
---   |-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----
R     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
W     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
Reset| 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

25.4.1.45.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

25.4.1.46  Status register 4 (STS4)

25.4.1.46.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS4</td>
<td>D0h</td>
</tr>
</tbody>
</table>

25.4.1.46.2  Diagram
25.4.1.46.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

25.4.1.47 Status register 5 (STS5)

25.4.1.47.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS5</td>
<td>D4h</td>
</tr>
</tbody>
</table>

25.4.1.47.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.47.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

25.4.1.48 Status register 6 (STS6)
25.4.1.48.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS6</td>
<td>D8h</td>
</tr>
</tbody>
</table>

25.4.1.48.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.48.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

25.4.1.49 Status register 7 (STS7)

25.4.1.49.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS7</td>
<td>DCh</td>
</tr>
</tbody>
</table>
25.4.1.49.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.49.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
</tbody>
</table>

25.4.1.50  Status register 8 (STS8)

25.4.1.50.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS8</td>
<td>E0h</td>
</tr>
</tbody>
</table>

25.4.1.50.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### 25.4.1.50.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 25.4.1.51 Status register 9 (STS9)

#### 25.4.1.51.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS9</td>
<td>E4h</td>
</tr>
</tbody>
</table>

#### 25.4.1.51.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 25.4.1.51.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 25.4.1.52 Status register 10 (STS10)
25.4.1.52.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS10</td>
<td>E8h</td>
</tr>
</tbody>
</table>

25.4.1.52.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.52.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

25.4.1.53 Status register 11 (STS11)

25.4.1.53.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS11</td>
<td>ECh</td>
</tr>
</tbody>
</table>
25.4.1.53.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.53.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

25.4.1.54  Status register 12 (STS12)

25.4.1.54.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS12</td>
<td>F0h</td>
</tr>
</tbody>
</table>

25.4.1.54.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
25.4.1.54.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0 NDADDR</td>
<td>This field indicating the last write address (AXI command) to NAND device (without base address in SEMC_BR4).</td>
</tr>
</tbody>
</table>

25.4.1.55  Status register 13 (STS13)

25.4.1.55.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS13</td>
<td>F4h</td>
</tr>
</tbody>
</table>

25.4.1.55.2  Function

This register indicates the status of sample clock DLLs.

25.4.1.55.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

25.4.1.55.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-14</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Memory Map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>13-8 REFSEL</td>
<td>Sample clock reference delay line delay cell number selection.</td>
</tr>
<tr>
<td>7-2 SLVSEL</td>
<td>Sample clock slave delay line delay cell number selection.</td>
</tr>
<tr>
<td>1 REFLOCK</td>
<td>Sample clock reference delay line locked.</td>
</tr>
<tr>
<td>0 SLVLOCK</td>
<td>Sample clock slave delay line locked.</td>
</tr>
</tbody>
</table>

### 25.4.1.56 Status register 14 (STS14)

#### 25.4.1.56.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS14</td>
<td>F8h</td>
</tr>
</tbody>
</table>

#### 25.4.1.56.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

#### 25.4.1.56.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
25.4.1.57 Status register 15 (STS15)

25.4.1.57.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS15</td>
<td>FCh</td>
</tr>
</tbody>
</table>

25.4.1.57.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

25.4.1.57.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

25.5 Functional description

The following sections describe functional details of the SEMC module.

25.5.1 Clocks

This section describes clocks and special clocking requirements of the SEMC module.
There is only one clock domain which is used for AXI bus interface, IP bus interface, internal logic and external interface.

### 25.5.2 Reset

This section describes how to reset the SEMC module and explains special requirements related to reset.

### 25.5.3 Pin Mux in SEMC

Following table describes the pin mux in SEMC module.

<table>
<thead>
<tr>
<th>Signal</th>
<th>SDRAM</th>
<th>NAND</th>
<th>NOR (ADMUX 16bit)</th>
<th>SRAM (ADMUX 16bit)</th>
<th>DBI</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC_DATA00</td>
<td>D0</td>
<td>D0</td>
<td>D0/A0</td>
<td>D0/A0</td>
<td>D0</td>
<td>Hardware MUX</td>
</tr>
<tr>
<td>SEMC_DATA01</td>
<td>D1</td>
<td>D1</td>
<td>D1/A1</td>
<td>D1/A1</td>
<td>D1</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA02</td>
<td>D2</td>
<td>D2</td>
<td>D2/A2</td>
<td>D2/A2</td>
<td>D2</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA03</td>
<td>D3</td>
<td>D3</td>
<td>D3/A3</td>
<td>D3/A3</td>
<td>D3</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA04</td>
<td>D4</td>
<td>D4</td>
<td>D4/A4</td>
<td>D4/A4</td>
<td>D4</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA05</td>
<td>D5</td>
<td>D5</td>
<td>D5/A5</td>
<td>D5/A5</td>
<td>D5</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA06</td>
<td>D6</td>
<td>D6</td>
<td>D6/A6</td>
<td>D6/A6</td>
<td>D6</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA07</td>
<td>D7</td>
<td>D7</td>
<td>D7/A7</td>
<td>D7/A7</td>
<td>D7</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA08</td>
<td>D8</td>
<td>D8</td>
<td>D8/A8</td>
<td>D8/A8</td>
<td>D8</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA09</td>
<td>D9</td>
<td>D9</td>
<td>D9/A9</td>
<td>D9/A9</td>
<td>D9</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA10</td>
<td>D10</td>
<td>D10</td>
<td>D10/A10</td>
<td>D10/A10</td>
<td>D10</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA11</td>
<td>D11</td>
<td>D11</td>
<td>D11/A11</td>
<td>D11/A11</td>
<td>D11</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA12</td>
<td>D12</td>
<td>D12</td>
<td>D12/A12</td>
<td>D12/A12</td>
<td>D12</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA13</td>
<td>D13</td>
<td>D13</td>
<td>D13/A13</td>
<td>D13/A13</td>
<td>D13</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA14</td>
<td>D14</td>
<td>D14</td>
<td>D14/A14</td>
<td>D14/A14</td>
<td>D14</td>
<td></td>
</tr>
<tr>
<td>SEMC_DATA15</td>
<td>D15</td>
<td>D15</td>
<td>D15/A15</td>
<td>D15/A15</td>
<td>D15</td>
<td></td>
</tr>
<tr>
<td>SEMC_DM1</td>
<td>DQM1</td>
<td>-</td>
<td>-</td>
<td>UB#</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_DM0</td>
<td>DQM0</td>
<td>-</td>
<td>-</td>
<td>LB#</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR00</td>
<td>A0</td>
<td>-</td>
<td>A16</td>
<td>A16</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR01</td>
<td>A1</td>
<td>-</td>
<td>A17</td>
<td>A17</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR02</td>
<td>A2</td>
<td>-</td>
<td>A18</td>
<td>A18</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR03</td>
<td>A3</td>
<td>-</td>
<td>A19</td>
<td>A19</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR04</td>
<td>A4</td>
<td>-</td>
<td>A20</td>
<td>A20</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR05</td>
<td>A5</td>
<td>-</td>
<td>A21</td>
<td>A21</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR06</td>
<td>A6</td>
<td>-</td>
<td>A22</td>
<td>A22</td>
<td>-</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Signal</th>
<th>SDRAM</th>
<th>NAND (ADMUX 16bit)</th>
<th>NOR (ADMUX 16bit)</th>
<th>SRAM (ADMUX 16bit)</th>
<th>DBI</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEMC_ADDR07</td>
<td>A7</td>
<td>-</td>
<td>A23</td>
<td>A23</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_ADDR08</td>
<td>A8</td>
<td>CE#</td>
<td>CE#/A24</td>
<td>CE#/A24</td>
<td>CSX</td>
<td>Configured by IOCR.MUX_A8</td>
</tr>
<tr>
<td>SEMC_ADDR09</td>
<td>A9</td>
<td>CLE</td>
<td>-</td>
<td>CRE</td>
<td>-</td>
<td>Hardware MUX</td>
</tr>
<tr>
<td>SEMC_ADDR10</td>
<td>A10</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>SEMC determines the pin function according to its internal state</td>
</tr>
<tr>
<td>SEMC_ADDR11</td>
<td>A11</td>
<td>WE#</td>
<td>WE#</td>
<td>WE#</td>
<td>WRX</td>
<td>SEMC_ADDR11 works as CLK signal in NAND synchronous mode</td>
</tr>
<tr>
<td>SEMC_ADDR12</td>
<td>A12</td>
<td>RE#</td>
<td>OE#</td>
<td>OE#</td>
<td>RDX</td>
<td>SEMC_ADDR12 works as W/R# signal in NAND synchronous mode</td>
</tr>
<tr>
<td>SEMC_BA0</td>
<td>BA0</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Hardware MUX</td>
</tr>
<tr>
<td>SEMC_BA1</td>
<td>BA1</td>
<td>ALE</td>
<td>ADV#</td>
<td>ADV#</td>
<td>DCX</td>
<td>SEMC determines the pin function according to its internal state</td>
</tr>
<tr>
<td>SEMC_CAS</td>
<td>CAS#</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_RAS</td>
<td>RAS#</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_WE</td>
<td>WE#</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_CKE</td>
<td>CKE</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_CLK</td>
<td>CLK</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_CS0</td>
<td>CS0</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td></td>
</tr>
<tr>
<td>SEMC_CSX0</td>
<td>CS</td>
<td>CE#</td>
<td>CE#</td>
<td>CE#</td>
<td>CSX</td>
<td>Configured by IOCR.MUX_CSX0</td>
</tr>
<tr>
<td>SEMC_CSX1</td>
<td>CS</td>
<td>CE#</td>
<td>CE#</td>
<td>CE#</td>
<td>CSX</td>
<td>Configured by IOCR.MUX_CSX1</td>
</tr>
<tr>
<td>SEMC_CSX2</td>
<td>CS</td>
<td>CE#</td>
<td>CE#</td>
<td>CE#</td>
<td>CSX</td>
<td>Configured by IOCR.MUX_CSX2</td>
</tr>
<tr>
<td>SEMC_CSX3</td>
<td>CS</td>
<td>CE#</td>
<td>CE#</td>
<td>CE#</td>
<td>CSX</td>
<td>Configured by IOCR.MUX_CSX3</td>
</tr>
<tr>
<td>SEMC_RDY</td>
<td>CS</td>
<td>R/B#</td>
<td>CE#</td>
<td>CE#</td>
<td>CSX</td>
<td>Configured by IOCR.MUX_RDY</td>
</tr>
<tr>
<td>SEMC_DQS</td>
<td>DQS</td>
<td>-</td>
<td>DQS</td>
<td>DQS</td>
<td>-</td>
<td>Hardware MUX</td>
</tr>
<tr>
<td>SEMC_DQS4</td>
<td>-</td>
<td>DQS</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>Hardware MUX</td>
</tr>
<tr>
<td>SEMC_CLKX0</td>
<td>-</td>
<td>CLK</td>
<td>CLK</td>
<td>-</td>
<td>-</td>
<td>Configured by IOCR.MUX_CLKX0</td>
</tr>
<tr>
<td>SEMC_CLKX1</td>
<td>-</td>
<td>CLK</td>
<td>CLK</td>
<td>-</td>
<td>-</td>
<td>Configured by IOCR.MUX_CLKX1</td>
</tr>
</tbody>
</table>

**NOTE**

- Configure register field should be static.
- NOR and SRAM pins are configured as 16 bit ADMUX mode in above table. It is the recommended configuration.

### 25.5.4 Device access by AXI Command

Devices could be read/written by AXI bus access directly. AXI command is the device access sequence triggered by AXI bus access. The device access sequence for AXI command is described in the following sections.
NOTE

- The AXI bus memory map for each device is defined by SEMC_BRx registers.
- There is no software configuration or polling needed for AXI command except SEMC initialization. AXI master access external flash device transparently similar as normal AXI slave.
- AXI command is normally used to read/write access device memory space. IP command should be used to any other access, such as device register/OTP space access, device initialization.
- IP command could be used for memory read/write also similar as AXI command. But it is not recommended if only AXI command is available.

25.5.4.1 BMCR Registers Configuration

BMCR registers can be used to balance external memory access efficiency, urgency and latency based on requirement of a specific applications.

25.5.4.1.1 BMCR0 Registers Configuration

For Queue A controlled by BMCR0, the arbitration logic adopts a weight based algorithm that assigns each command in the reordering queue with a final score.

The arbitration logic calculates a SCORE for each command based on the formula below. The command with the highest SCORE is served first.

\[
\text{SCORE} = \text{QOS} \times \text{WQOS} + \text{AGE} \times \text{WAGE}/4 + \text{WSH} + \text{WRWS}
\]

1. QOS stands for AxQOS of AXI bus, and WQOS is the weight factor of QOS.
2. AGE stands for the wait period for each command in queue, and WAGE is the weight factor of AGE.
3. WSH stands for weight of slave hit without read/write switch scenario.
4. WRWS stands for weight of slave hit with read/write switch scenario.

25.5.4.1.2 BMCR1 Registers Configuration

For Queue B controlled by BMCR1, the arbitration logic adopts a weight based algorithm that assigns each command in the reordering queue with a final score.
The arbitration logic calculates SCORE for each SDRAM command based on the formula below. The command with the highest SCORE is served first.

\[
\text{SCORE} = \text{QOS} \times \text{WQOS} + \text{AGE} \times \text{WAGE}/4 + \text{WPH} + \text{WBR} + \text{WRWS}
\]

1. QOS stands for AxQOS of AXI bus, and WQOS is the weight factor of QOS.
2. AGE stands for the wait period for each command in queue, and WAGE is the weight factor of AGE.
3. WPH stands for weight of page hit scenario.
4. WBR stands for weight of bank rotation scenario.
5. WRWS stands for weight of slave hit without read/write switch scenario.

### 25.5.5 Device access by IP Command

Device could be accessed (initialized/configured/read/written) by IP bus access also. IP command is the device access sequence triggered by IP bus access. The device access sequence for IP command is described in the following sections.

Device access could be triggered by IP command in following steps:

1. Set register IPCR0/IPCR1/IPCR2/IPTXD for Device address/Data Size/Write Data/Write Mask.
2. Set register IPCMD with valid command code (IPCMD.CMD) and command key (IPCMD.KEY).
3. Wait for IP Command Done (Wait for interrupt IPCMDDONE generated).
4. Read the device data from IPRXD. This is needed for read access only.

**NOTE**

- If device address or command code setting is not valid, IP command error interrupt is generated (INTR.IPCMDERR) and no device access at all.
- If another IP command triggered when the previous IP command not finished yet, IP command error interrupt is generated.
- IPCR0/IPCR1/IPCR2/IPTXD is protected when IP command triggered by not finished yet. Any write access to these register is ignored.
- IPCR0 device address field should be configured even the device don't need any address bit information such as WRITE ENABLE command. SEMC need the device address to determine which device should be accessed.
- SEMC can access NAND only if the KEY is 0x5AA5.
25.5.6  SDRAM Controller Operations

This section describes the SDRAM controller module’s operations.

25.5.6.1  SDRAM address map

SDRAM device address map on SoC is indicated in following diagram:

![SDRAM device address map](image)

**Figure 25-2. SDRAM device address map**

25.5.6.2  SDRAM device access by IP Command

Following SDRAM device access could be triggered by IP command:

1. SELF REFRESH  
2. AUTO REFRESH  
3. MODE REGISTER SET  
4. PRECHARGE  
5. PRECHARGE ALL  
6. ACTIVE  
7. READ  
8. WRITE

25.5.6.2.1  IP command - SDRAM Self Refresh

When IP command triggered with command code - SELF REFRESH to any SDRAM device, SEMC would send SELF REFRESH command to all SDRAM devices. After SELF REFRESH command finished, all SDRAM device should be in self refresh state and SEMC keeps this state on SDRAM interface (SEMC_CKE=0x0 and SEMC_CLK=0x0).
SEMC brings all SDRAM device out from self refresh state when there is any new IP command or AXI command triggered to SDRAM device.

Following timing diagram illustrates the sequence for self-refresh entering and exiting by AXI command.

![Figure 25-3. IP command - SDRAM Self Refresh](image)

### 25.5.6.2.2 IP command - SDRAM Auto Refresh

When IP command triggered with command code - AUTO REFRESH, SEMC would send AUTO REFRESH command to the SDRAM device accessed.

Following timing diagram illustrates the sequence for IP command - AUTO REFRESH.

![Figure 25-4. IP command - SDRAM Auto Refresh](image)

### 25.5.6.2.3 IP command - SDRAM Mode Register Set

When IP command triggered with command code - Mode Register Set, SEMC would send MODE REGISTER SET command to the SDRAM device accessed.

Following timing diagram illustrates the sequence for IP command - MODE REGISTER SET.
25.5.6.2.4 IP command - SDRAM Precharge

When IP command triggered with command code - Precharge, SEMC would send PRECHARGE command to the SDRAM device accessed.

Following timing diagram illustrates the sequence for IP command - PRECHARGE.

25.5.6.2.5 IP command - SDRAM Precharge ALL

When IP command triggered with command code - Precharge ALL, SEMC would send PRECHARGE ALL command to the SDRAM device accessed.

Following timing diagram illustrates the sequence for IP command - PRECHARGE ALL.
25.5.6.2.6 IP command - SDRAM Active

When IP command triggered with command code - Active, SEMC would send ACTIVE command to the SDRAM device accessed.

Following timing diagram illustrates the sequence for IP command - ACTIVE.

25.5.6.2.7 IP command - SDRAM READ

When IP command triggered with command code - READ, SEMC would send READ command to the SDRAM device accessed.

Following timing diagram illustrates the sequence for IP command - READ.
25.5.6.2.8 IP command - SDRAM WRITE

When IP command triggered with command code - WRITE, SEMC would send WRITE command to the SDRAM device accessed.

Following timing diagram illustrates the sequence for IP command - WRITE.

25.5.6.3 SDRAM device access by AXI Command

SDRAM device read/write access could be triggered by AXI Command. For AXI read access, SEMC would send READ commands to SDRAM device automatically and return data on AXI bus. For AXI write access, SEMC would save AXI bus write data and send WRITE commands to SDRAM device automatically.
25.5.6.3.1 SDRAM device read access by AXI Command

Following timing diagram illustrates the SDRAM device access triggered by AXI command (Read).

![Figure 25-11. AXI command - SDRAM Read](image)

25.5.6.3.2 SDRAM device write access by AXI Command

Following timing diagram illustrates the SDRAM device access triggered by AXI command (Write).

![Figure 25-12. AXI command - SDRAM Write](image)

25.5.6.3.3 SDRAM device pipelined access by AXI Command

Following timing diagram illustrates the SDRAM device pipelined read access triggered by AXI command (Read).
Following timing diagram illustrates the SDRAM device pipelined write access triggered by AXI command (Write).

25.5.6.3.4  SDRAM back-to-back access

This section describes the SDRAM back-to-back access.

25.5.6.3.4.1  SDRAM read-to-read access

SDRAM read-to-read access timing when CL=1 is as following:
SDRAM read-to-read access timing when CL=2 is as following:

**Figure 25-16. SDRAM Read-to-Read access (CL=2)**

SDRAM read-to-read access timing when CL=3 is as following:

**Figure 25-17. SDRAM Read-to-Read access (CL=3)**
SDRAM read-to-write access timing when CL=1 is as following:

![Figure 25-18. SDRAM Read-to-Write access (CL=1)](image)

SDRAM read-to-write access timing when CL=2 is as following:

![Figure 25-19. SDRAM Read-to-Write access (CL=2)](image)

SDRAM read-to-write access timing when CL=3 is as following:

![Figure 25-20. SDRAM Read-to-Write access (CL=3)](image)
25.5.6.3.4.3 SDRAM write-to-write access

SDRAM write-to-write access timing is as following:

![Figure 25-21. SDRAM Write-to-Write access](image)

25.5.6.3.4.4 SDRAM write-to-read access

SDRAM write-to-read access timing when CL=1 is as following:

![Figure 25-22. SDRAM Write-to-Read access (CL=1)](image)

SDRAM write-to-read access timing when CL=2 is as following:
SDRAM write-to-read access timing when CL=3 is as following:

![Figure 25-24. SDRAM Write-to-Read access (CL=3)](image)

25.5.6.4 Refresh command - SDRAM AUTO Refresh

SEMC would send AUTO REFRESH command to all SDRAM devices when the refresh timer expired and SDRAM Refresh enabled (SDRAMCR3.REN=0x1). Multiple AUTO REFRESH command could be sent if refresh burst is not set to one (SDRAMCR3.REBL!=0x0).

Refresh command is triggered by interval refresh timer period.

Following timing diagram illustrates the sequence for Refresh Command.
25.5.6.5 SDRAM low power feature

This section describes the low power feature implemented for SDRAM.

25.5.6.5.1 Stop mode - SDRAM

When system enter STOP mode, SEMC puts all SDRAM device into self refresh state automatically. When system exit STOP mode, SEMC brings SDRAM device out from self refresh state.

Following timing diagram illustrates the sequence for stop mode entering and exiting.

25.5.6.5.2 BUS Idle - SDRAM

When there is no IP/AXI/Refresh command, SDRAM interface would be in IDLE state (NOP command and chip select invalid). When SDRAM interface bus idle timer expired, SEMC closes all pages opened on all SDRAM devices. Please see SDRAMCR2.ITO for more detail about bus idle timer.
25.5.6.6 SDRAM Page Management

This section describes the SDRAM page management.

There are 8 pages row address saved internally: 4 pages for CS0/CS2 (4 bank), 4 pages for CS1/CS3 (4 bank). Device CS0 and CS2 page is never opened at the same time. Before SEMC open pages on CS2, it closes all opened pages on CS0. This is similar for CS1/CS3.

SEMC close all pages on all CS in following cases:

1. SELF REFRESH triggered by IP command
2. SELF REFRESH triggered by stop mode enter
3. The idle time on AXI bus and SDRAM interface is longer than SDRAM idle timeout time (SDRAMCR2.ITO).

NOTE

SEMC does not sent out PRECHARGE-ALL command if there is no page opened on any bank/CS.

SEMC close all pages on one CS in following cases:

1. PRECHARGE ALL command triggered by IP command
2. AUTO REFRESH command triggered by IP command
3. ACTIVE/WRITE/READ command triggered by IP command and CS miss
4. WRITE/READ command triggered by current AXI command and CS miss
5. WRITE/READ command triggered by next AXI command (not accepted yet), CS miss and not same CS as current AXI command

NOTE

One example for CS miss: Current IP command access CS2 but there is page opened on CS0 already.

SEMC close one page on one CS in following cases:

1. PRECHARGE command triggered by IP command and this bank is opened
2. ACTIVE/READ/WRITE command triggered by IP command, this bank is opened and page missed.
3. WRITE/READ command triggered by current AXI command this bank is opened and page missed.
4. WRITE/READ command triggered by next AXI command (not accepted yet), this bank is opened, page missed and different bank accessed with current AXI command.
NOTE

One example for page miss: current bank is opened but the opened page row address is different with current SDRAM command access.

SEMC open one page on one CS in following cases:

1. ACTIVE/READ/WRITE command triggered by IP command, this bank is not opened.
2. WRITE/READ command triggered by current AXI command this bank is not opened.
3. WRITE/READ command triggered by next AXI command (not accepted yet), this bank is not opened and different bank accessed with current AXI command.

NOTE

One example for page miss: current bank is opened but the opened page row address is different with current SDRAM command access.

25.5.6.7 SDRAM Timers

This section describes the timers used for SDRAM operation

25.5.6.7.1 Prescaler

The prescaler timer in SDRAM controller count freely with the period defined by SDRAM3.PRESCALE. When the prescaler timer expired, urgent refresh timer and SDRAM BUS IDLE timer count by 1.

25.5.6.7.2 Refresh interval timer

The refresh interval timer also count when prescaler timer expires. The timer period is determined by SDRAMCR3.RT and SDRAMCR3.PRESCALE. When refresh interval timer expired, an internal refresh command is triggered and SEMC sends one or multiple AUTO REFRESH command on SDRAM interface.
25.5.6.7.3 Urgent Refresh timer

Urgent refresh timer is used to determine whether current refresh request is urgent or normal. Before urgent refresh timer timeout, refresh request is handled in lower priority than AXI/IP command. When urgent refresh timer timed out, refresh request becomes urgent. SDRAM handles Auto-Refresh command in higher priority than AXI/IP command.

25.5.6.7.4 Beat timer

The beat timer is used to control SDRAM read/write/Auto Refresh command burst length.

25.5.6.7.5 ACTIVE to READ/WRITE timer

The ACTIVE to READ/WRITE timer is used to promise the minimum cycle number between ACITVE command and READ/WRITE command on SDRAM interface.

25.5.6.7.6 PRECHARGE to ACTIVE timer

The PRECHARGE to ACTIVE timer is used to promise the minimum cycle number between PRECHARGE/PRECHARGE ALL command and ACTIVE/AUTO REFRESH/SELF REFRESH command on SDRAM interface.

25.5.6.7.7 CKE OFF timer

The CKEOFF timer is used to promise the minimum cycle of SDRAM CLK off state.

25.5.6.7.8 SELF REFRESH recover timer

The SRRC timer is used to promise the wait time between SDRAM device exit Self Refresh state and sending new Commands to device. SDRAM device may have limitation on Self Refresh recovery time. Before this recovery time expire, any command to device may cause unexpected behavior.

25.5.6.7.9 AUTO REFRESH recover timer

The RFRC timer is used to promise the minimum cycle number between Auto Refresh command and ACTIVE command on SDRAM interface. SDRAM device may have limitation on Refresh recovery time. Before this recovery time expire, any command to device may cause unexpected behavior.
25.5.6.7.10 Refresh to Refresh timer

The refresh to refresh timer is used to promise the minimum cycle number between Auto Refresh command and Auto Refresh command on SDRAM interface.

25.5.6.7.11 ACTIVE to ACTIVE timer

There are two ACT2ACT timer in SDRAM controller. ACT2ACT0 timer is used to promise the minimum cycle number between ACTIVE command and ACTIVE command on CS0/2 device. ACT2ACT1 timer is used to promise the minimum cycle number between ACTIVE command and ACTIVE command on CS1/3 device.

25.5.6.7.12 ACTIVE to PRECHARGE timer

There are two ACT2PRE timer in SDRAM controller. ACT2PRE0 timer is used to promise the minimum cycle number between ACTIVE command and PRECHARGE/PRECHARGE ALL command on CS0/2 device. ACT2PRE1 timer is used to promise the minimum cycle number between ACTIVE command and PRECHARGE/PRECHARGE ALL command on CS1/3 device.

25.5.6.7.13 Write recovery timer

The WRC timer is used to promise the minimum cycle number between WRITE command and PRECHARGE/PRECHARGE ALL command on SDRAM interface. SDRAM device may have limitation on WRITE recovery time. Before this recovery time expire, PRECHARGE/PRECHARGE ALL command to device may cause the write process failed.

25.5.7 NAND Flash Controller Operations

This section describes the NAND Flash controller module’s operations.

25.5.7.1 NAND Flash address map

NAND Flash device address map on SoC is indicated in the following diagram:
25.5.7.2 NAND Flash access address type

There are 6 type address type access provided:

- One Byte Column address
- Two Byte Column address
- One Byte Row address
- Two Byte Row address
- Three Byte Row address
- Five Byte Row/Column address

For IP command, address type is determined by IPCMD register; For AXI command, address type is fixed to "Two Byte Column Address" because all NAND Flash access is in NAND page boundary.

25.5.7.2.1 One Byte Column Address

One Byte column address type access is indicated as following:
25.5.7.2.2 Two Byte Column Address

Two Byte column address type access is indicated as following:

![Diagram of Two Byte Column Address]

Figure 25-29. NAND Flash access Address type - Two Byte Column Address

25.5.7.2.3 One Byte Row Address

One Byte row address type access is indicated as following:
25.5.7.2.4  Two Byte Row Address

Two Byte row address type access is indicated as following:

![Figure 25-31. NAND Flash access Address type - Two Byte Row Address](image)

25.5.7.2.5  Three Byte Row Address

Three Byte row address type access is indicated as following:

![Figure 25-31. NAND Flash access Address type - Two Byte Row Address](image)
25.5.7.2.6 Five Byte Row/Column Address

Five Byte row/column address type access is indicated as following:

There are some option bits provide to support more NAND address type access. Five byte row/column address type could be overried as following:

Table 25-2. Address byte order for Row/Column Address five Byte mode

<table>
<thead>
<tr>
<th>NDOPT3</th>
<th>NDOPT2</th>
<th>NDOPT1</th>
<th>Address byte order</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>CA0/CA1/RA0/RA1/RA2</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 25-2. Address byte order for Row/Column Address five Byte mode (continued)

<table>
<thead>
<tr>
<th>NDOPT3</th>
<th>NDOPT2</th>
<th>NDOPT1</th>
<th>Address byte order</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>CA0/RA0/RA1/RA2</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>CA0/CA1/RA0/RA1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>CA0/RA0/RA1</td>
</tr>
<tr>
<td>1</td>
<td>-</td>
<td>0</td>
<td>CA0/CA1/RA0</td>
</tr>
<tr>
<td>1</td>
<td>-</td>
<td>1</td>
<td>CA0/RA0</td>
</tr>
</tbody>
</table>

25.5.7.3 NAND Flash access command type

NAND Flash access support following command types:

1. Command Phase Only
2. Command + Wait Phase
3. Command + Address Phase
4. Command + Address + Wait Phase
5. Command + Address + Read Phase
6. Command + Address + Write Phase (For IP command)
7. Command + Write Phase
8. Command + Read Phase
9. Write Phase Only
10. Read Phase Only
11. Command + Address + Command + Read Phase (For AXI command - Read)
12. Command + Address + Write Phase (For AXI command - Write)

25.5.7.3.1 Command Phase Only

NAND Flash Command Phase Only access is indicated as following:
25.5.7.3.2 Command + Wait Phase

NAND Flash Command + Wait Phase access is indicated as following:

25.5.7.3.3 Command + Address Phase

NAND Flash Command + Address Phase access is indicated as following:
25.5.7.3.4 Command + Address + Wait Phase

NAND Flash Command + Address + Wait Phase access is indicated as following:

![Diagram of Command + Address + Wait Phase](image)

**Figure 25-37. NAND Flash access command type - Command + Address + Wait Phase**

25.5.7.3.5 Command + Address + Read Phase

NAND Flash Command + Address + Read Phase access is indicated as following:

![Diagram of Command + Address + Read Phase](image)
25.5.7.3.6 Command + Address + Write Phase (For IP command)

NAND Flash Command + Address + Write Phase access is indicated as following:

Figure 25-39. NAND Flash access command type - Command + Address + Write Phase

25.5.7.3.7 Command + Read Phase

NAND Flash Command + Read Phase access is indicated as following:
25.5.7.3.8 Command + Write Phase

NAND Flash Command + Write Phase access is indicated as following:

Figure 25-41. NAND Flash access command type - Command + Write Phase

25.5.7.3.9 Read Phase Only

NAND Flash Read Phase Only access is indicated as following:
Figure 25-42. NAND Flash access command type - Read Phase Only

25.5.7.3.10 Write Phase Only

NAND Flash Write Phase Only access is indicated as following:

Figure 25-43. NAND Flash access command type - Write Phase Only

25.5.7.3.11 Command + Address + Command + Read Phase
NAND Flash Command + Address + Command + Read Phase access is indicated as follows:

**Figure 25-44. NAND Flash access command type - Command + Address + Command + Read Phase**

### 25.5.7.3.12 Command + Address + Write Phase (For AXI command)

NAND Flash Command + Address + Write Phase access is indicated as following:

**Figure 25-45. NAND Flash access command type - Command + Address + Write Phase**

### 25.5.7.4 NAND Flash read access EDO and non-EDO mode

NAND Flash read access could be done in EDO or non-EDO mode. The timing indicated as following:

**Figure 25-46. NAND Flash Read Access in EDO or non-EDO mode**
25.5.7.5 NAND Flash access in SYNC mode

NAND Flash supports SYNC mode, the timings are indicated as followings:

25.5.7.5.1 NAND Read Operation in SYNC Mode

NAND read operation in SYNC mode is indicated in following diagram:

![Figure 25-47. NAND Read in SYNC mode](image)

25.5.7.5.2 NAND Write Operation in SYNC Mode

NAND write operation in SYNC mode is indicated in following diagram:

![Figure 25-48. NAND Write in SYNC mode](image)

25.5.7.5.3 NAND Command + Address + Command + Read Operation in SYNC Mode

NAND Command + Address + Command + Read operation in SYNC mode is indicated in following diagram:
25.5.7.5.4 NAND Command + Address + Write Operation in SYNC Mode

NAND Command + Address + Write operation in SYNC mode is indicated in following diagram:

**Figure 25-50. NAND Command + Address + Write in SYNC mode**

25.5.8 NOR Flash Controller Operations

This section describes the NOR Flash controller module’s operations.

25.5.8.1 NOR Flash address map

NOR Flash device address map on SoC is indicated in the following diagram:
NOR device address map when NORCR0.PS=0x1 (16 bit mode)

<table>
<thead>
<tr>
<th>31</th>
<th>1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>ROW</td>
<td>COL</td>
</tr>
</tbody>
</table>

NOR device address map when NORCR0.PS=0x0 (8 bit mode)

<table>
<thead>
<tr>
<th>31</th>
<th>1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>ROW</td>
<td>COL</td>
</tr>
</tbody>
</table>

Figure 25-51. NOR Flash Address Map

25.5.8.2 NOR Flash Read Operation in ASYNC Mode

Flash read operation in ASYNC mode is indicated in following diagrams:

Figure 25-52. Flash Read in ASYNC mode (ADMUX)

Figure 25-53. Flash Read in ASYNC mode (AADM)

25.5.8.3 NOR Flash Write Operation in ASYNC mode

Flash write operation in ASYNC mode is indicated in following diagrams:
25.5.8.4  NOR Flash Read Operation in SYNC mode

Flash read operation in SYNC mode is indicated in following diagrams:

Figure 25-56. Flash Read in SYNC mode (ADMUX)
25.5.8.5 NOR Flash Write Operation in SYNC mode

Flash write operation in SYNC mode is same as asynchronous.

25.5.9 SRAM Controller Operations

This section describes the SRAM controller module’s operations.

25.5.9.1 SRAM Flash address map

SRAM Flash device address map on SoC is indicated in the following diagram:

SRAM device address map when SRAMCR0.PS=0x1 (16 bit mode)

<table>
<thead>
<tr>
<th>31</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>ROW</td>
<td>COL</td>
<td></td>
</tr>
</tbody>
</table>

SRAM device address map when SRAMCR0.PS=0x0 (8 bit mode)

<table>
<thead>
<tr>
<th>31</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>ROW</td>
<td>COL</td>
</tr>
</tbody>
</table>
25.5.9.2  SRAM Read Operation in ASYNC Mode

SRAM read operation in ASYNC mode is indicated in following diagrams:

Figure 25-59. SRAM Read in ASYNC mode (ADMUX)

Figure 25-60. SRAM Read in ASYNC mode (AADM)

25.5.9.3  SRAM Write Operation in ASYNC mode

SRAM write operation in ASYNC mode is indicated in following diagrams:

Figure 25-61. SRAM Write in ASYNC mode (ADMUX)
25.5.9.4  SRAM Read Operation in SYNC mode

SRAM read operation in SYNC mode is indicated in following diagrams:

![Figure 25-63. SRAM Read in SYNC mode (ADMUX)](image)

25.5.9.5  SRAM Write Operation in SYNC mode

SRAM write operation in SYNC mode is indicated in following diagrams:
25.5.10 Display Bus Interface Controller Operations

DBI read/write operation indicated as following.

---

**Figure 25-65. DBI Write Operation**

---

**Figure 25-66. DBI Read Operation**
NOTE

- Read access to DBI is always handled as DBI DATA READ transaction.
- Write access to DBI is handled as DBI COMMAND WRITE transaction if address is higher than 0x10000 (with DBI Base address removed). Otherwise, it is handled as DBI DATA WRITE transaction.
- DBI address is not sent to device at all. Only used to determine DBI COMMAND or DATA WRITE.
- DBI bus never sent out address information for COMMAND WRITE, DATA WRITE and DATA READ command.
- AXI WRAP write access to DBI is supported.
- AXI WRAP read access to DBI is not supported except when the first beat address offset is zero in the burst.
- DBI bus interface doesn't support WRITE MASK feature.
- All write strobe in AXI write access to DBI should be valid (one). If AXI write strobe is invalid (zero), SEMC sends write data 8'h00 instead of original write data.
- When DBI bus is 16 bit (DBICR0.PS=0x1), AXI command or IP command access (both read and write) start address to DBI bus should be 16 bit aligned. Otherwise the read data is unknown or the write data to DBI may be wrong. There is no bus error response or internal error status generated for this case.
Chapter 26
Ultra Secured Digital Host Controller (uSDHC)

26.1 Chip-specific uSDHC information

Table 26-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

On this device, for data transfer modes, uSDHC1 only supports 1-bit and 4-bit modes, while uSDHC2 can support 1-bit, 4-bit and 8-bit modes.

NOTE
HS400 mode is not supported on this device.

26.2 Overview

The Ultra Secured Digital Host Controller (uSDHC) provides the interface between the host system and the SD/SDIO/MMC cards, as depicted in Figure 26-1.

The uSDHC acts as a bridge, passing host bus transactions to the SD/SDIO/MMC cards by sending commands and performing data accesses to/from the cards.

It handles the SD/SDIO/MMC protocols at the transmission level.

The following are brief descriptions of the cards supported by the uSDHC:
The Multi Media Card (MMC) is a universal low cost data storage and communication media designed to cover a wide array of applications including mobile video and gaming. Previous MMC cards were based on a 7-pin serial bus with a single data pin, while the new high speed MMC communication is based on an advanced 11-pin serial bus designed to operate in the low voltage range.

The Secure Digital Card (SD) is an evolution of the old MMC technology. It is specifically designed to meet the security, capacity, performance, and environment requirements inherent in newly-emerging audio and video consumer electronic devices. The physical form factor, pin assignment and data transfer protocol are forward-compatible with the old MMC (with some additions).

Under the SD protocol, it can be categorized into Memory card, I/O card and Combo card, which has both memory and I/O functions. The memory card invokes a copyright protection mechanism that complies with the security of the SDMI standard. The I/O card, which is also known as SDIO card, provides high-speed data I/O with low power consumption for mobile electronic devices. For the sake of simplicity, the following figure does not show cards with reduced size or mini cards.
Figure 26-2. ultra Secure Digital Host Controller Block Diagram
26.2.1 Features

The features of the uSDHC module include the following:

- Conforms to the SD Host Controller Standard Specification version 2.0/3.0
- Compatible with the MMC System Specification version 4.2/4.3/4.4/4.41/4.5
- Compatible with the SD Memory Card Specification version 3.0 and supports the Extended Capacity SD Memory Card
- Compatible with the SDIO Card Specification version 2.0/3.0
- Designed to work with SD Memory, miniSD Memory, SDIO, miniSDIO, SD Combo, MMC, MMC plus, and MMC RS cards
- Card bus clock frequency up to 208 MHz
- Supports 1-bit / 4-bit SD and SDIO modes, 1-bit / 4-bit / 8-bit MMC modes
  - Up to 832 Mbps of data transfer for SDIO cards using 4 parallel data lines in SDR(Single Data Rate) mode
  - Up to 400 Mbps of data transfer for SDIO card using 4 parallel data lines in DDR(Dual Data Rate) mode
  - Up to 832 Mbps of data transfer for SDXC cards using 4 parallel data lines in SDR(Single Data Rate) mode
  - Up to 400 Mbps of data transfer for SDXC card using 4 parallel data lines in DDR(Dual Data Rate) mode
  - Up to 1600 Mbps of data transfer for MMC cards using 8 parallel data lines in SDR(Single Data Rate) mode
  - Up to 832 Mbps of data transfer for MMC cards using 8 parallel data lines in DDR(Dual Data Rate) mode
- Supports single block/multi-block read and write
- Supports block sizes of 1 ~ 4096 bytes
- Supports the write protection switch for write operations
- Supports both synchronous and asynchronous abort
- Supports pause during the data transfer at block gap
- Supports SDIO Read Wait and Suspend Resume operations
- Supports Auto CMD12 for multi-block transfer
- Host can initiate non-data transfer command while data transfer is in progress
- Allows cards to interrupt the host in 1-bit and 4-bit SDIO modes, also supports interrupt period
- Embodies a fully configurable 128x32-bit FIFO for read/write data
- Supports internal DMA capabilities
- Support voltage selection by configuring vendor specific register bit
- Supports Advanced DMA to perform linked memory access
26.2.2 Modes and Operations

26.2.2.1 Data transfer Modes

The uSDHC can select the following modes for data transfer:

- SD 1-bit
- SD 4-bit
- MMC 1-bit
- MMC 4-bit
- MMC 8-bit
- Identification Mode (up to 400 kHz)
- MMC full speed mode (up to 26 MHz)
- MMC high speed mode (up to 52 MHz)
- MMC HS200 mode (up to 200 MHz)
- MMC DDR mode (52 MHz both edges)
- SD/SDIO full speed mode (up to 25 MHz)
- SD/SDIO high speed mode (up to 50 MHz)
- SD/SDIO UHS-I mode (up to 208 MHz in SDR mode, up to 50 MHz in DDR mode)

Note: IP can support the above-listed speed mode and max clock frequency. For SOC, speed mode and max clock frequency should be specific to chip. See the corresponding chip description for details.

26.3 External Signals

The following table describes the external signals of uSDHC:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK</td>
<td>Clock for MMC/SD/SDIO card</td>
<td>O</td>
</tr>
<tr>
<td>CMD</td>
<td>CMD line connect to card</td>
<td>I/O</td>
</tr>
<tr>
<td>DATA7</td>
<td>DAT7 line in 8-bit mode</td>
<td>I/O</td>
</tr>
<tr>
<td></td>
<td>Not used in other modes</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 26-2. uSDHC External Signals (continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATA6</td>
<td>DAT6 line in 8-bit mode&lt;br&gt;Not used in other modes</td>
<td>I/O</td>
</tr>
<tr>
<td>DATA5</td>
<td>DAT5 line in 8-bit mode&lt;br&gt;Not used in other modes</td>
<td>I/O</td>
</tr>
<tr>
<td>DATA4</td>
<td>DAT4 line in 8-bit mode&lt;br&gt;Not used in other modes</td>
<td>I/O</td>
</tr>
<tr>
<td>DATA3</td>
<td>DAT3 line in 4/8-bit mode or configured as card detection pin&lt;br&gt;May be configured as card detection pin in 1-bit mode</td>
<td>I/O</td>
</tr>
<tr>
<td>DATA2</td>
<td>DAT2 line or Read Wait in 4-bit mode&lt;br&gt;Read Wait in 1-bit mode</td>
<td>I/O</td>
</tr>
<tr>
<td>DATA1</td>
<td>DAT1 line in 4/8-bit mode&lt;br&gt;Also used to detect interrupt in 1/4-bit mode</td>
<td>I/O</td>
</tr>
<tr>
<td>DATA0</td>
<td>DAT0 line in all modes&lt;br&gt;Also used to detect busy state</td>
<td>I/O</td>
</tr>
<tr>
<td>CD_B</td>
<td>Card detection pin&lt;br&gt;If not used(for the embedded memory), tie low to indicate there is a card attached.</td>
<td>I</td>
</tr>
<tr>
<td>WP</td>
<td>Card write protect detect&lt;br&gt;If not used(for the embedded memory), tie low to indicate it's not write protected.</td>
<td>I</td>
</tr>
<tr>
<td>LCTL</td>
<td>LED control used to drive an external LED Active high&lt;br&gt;Fully controlled by the driver&lt;br&gt;Optional output</td>
<td>O</td>
</tr>
<tr>
<td>RESET_B</td>
<td>Card hardware reset signal, active LOW</td>
<td>O</td>
</tr>
<tr>
<td>VSELECT</td>
<td>IO power voltage selection signal</td>
<td>O</td>
</tr>
</tbody>
</table>

### 26.3.1 Signals Overview

The uSDHC has 14 associated I/O signals.

- The CLK is an internally generated clock used to drive the MMC, SD, SDIO cards.
- The CMD I/O is used to send commands and receive responses to and from the card. Eight data lines (DAT7~DAT0) are used to perform data transfers between the uSDHC and the card.
- The CD and WP are card detection and write protection signals directly routed from the socket. These two signals are active low (0). A low on CD_B means that a card is inserted, and a high on WP means that the write protect switch is active.
• LCTL is an output signal used to drive an external LED to indicate that the SD interface is busy.
• RST is an output signal used to reset the MMC card.
• VSELECT is an output signal used to change the voltage of the external power supplier.

CD, WP, LCTL, RST and VSELECT are all optional for system implementation. If the uSDHC needs to support a 4-bit data transfer, DAT7~DAT4 can also be optional and tied to high. If the uSDHC does not support HS400 mode, STROBE can also be optional and tied to low.

26.4 Clocks

The table found here describes the clock sources for uSDHC.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>hclk</td>
<td>ahb_clk_root</td>
<td>AHB bus clock</td>
</tr>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_perclk</td>
<td>usdhc_clk_root</td>
<td>Base clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock for register accesses</td>
</tr>
</tbody>
</table>

26.5 Functional Description

The following sections provide a brief functional description of the major system blocks, including the Data Buffer, DMA AHB interface, register bank as well as IP Bus interface, dual-port memory wrapper, data/command controller, clock & reset manager and clock generator.

26.5.1 Data Buffer

The uSDHC uses one configurable data buffer to transfer data between the system bus (IP Bus or AHB Bus) and the SD card in an optimized manner, maximizing throughput between the two clock domains (IP peripheral clock and the master clock).
The buffer is used as temporary storage for data being transferred between the host system and the card. The watermark levels for read and write are both configurable and can be from 1 to 128 words. The burst lengths for read and write are also configurable and can be from 1 to 31 words.

There are 2 transfer modes to access the data buffer:

- **CPU polling mode:**
  - For a host read operation, when the number of words received in the buffer meets or exceeds the RD_WML watermark value, by polling the BRR bit, the Host Driver can read the Buffer Data Port register to fetch the amount of words set in the RD_WML register from the buffer. The write operation is similar.

- **Internal DMA mode (includes simple and advanced DMA accesses):**
  - The internal DMA access, either by simple or advanced DMA, is over the AHB bus.
  - The burst type is always INCR mode and the burst length depends on the shortest of following factors:
    - Burst length configured in the burst length field of the Watermark Level register
    - Watermark Level boundary

![Figure 26-3. uSDHC Buffer Scheme](image-url)
• Block size boundary
• Data boundary configured in the current descriptor (if the ADMA is active)
• 1 Kbyte address boundary defined in the AHB protocol

Write operation is similar.

Sequential and contiguous access is necessary to ensure the pointer address value is correct. Random or skipped access is not possible. The byte order, by reset, is little endian mode. The actual byte order is swapped inside the buffer, according to the endian mode configured by software (see the following figures). For a host write operation, byte order is swapped after data is fetched from the buffer and ready to send to the SD Bus. For a host read operation, byte order is swapped before the data is stored in the buffer.

![Figure 26-4. Data Swap between System Bus and uSDHC Data Buffer in Byte Little Endian Mode](image1)

![Figure 26-5. Data Swap between System Bus and uSDHC Data Buffer in Half Word Big Endian Mode](image2)

### 26.5.1.1 Write Operation Sequence

There are 2 ways to write data into the buffer when the user transfers data to the card:

- Processor core polling through the BWR bit in Interrupt Status register (interrupt or polling)
- Internal DMA
When the internal DMA is not used, (the DMAEN bit in the Transfer Type register is not set when the command is sent), the uSDHC asserts a DMA request when the amount of buffer space exceeds the value set in the WR_WML register, and is ready for receiving new data. At the same time, the uSDHC sets the BWR bit. The buffer write ready interrupt will be generated if it is enabled by software.

When internal DMA is used, the uSDHC will not inform the system before all the required number of bytes are transferred (if no error was encountered). When an error occurs during the data transfer, the uSDHC will abort the data transfer and abandon the current block. The Host Driver should read the contents of the DMA System Address register to obtain the starting address of the abandoned data block. If the current data transfer is in multi-block mode, the uSDHC will not automatically send CMD12, even though the AC12EN bit in the Transfer Type register is set. The Host Driver sends CMD12 in this scenario and re-starts the write operation from that address. It is recommended that a Software Reset for Data be applied before the transfer is re-started.

The uSDHC will not start data transmission until the number of words set in the WR_WML register can be held in the buffer. If the buffer is empty and the Host System does not write data in time, the uSDHC will stop the CLK to avoid the data buffer under-run situation.

26.5.1.2 Read Operation Sequence

There are 2 ways to read data from the buffer when the user transfers data to the card:

- Processor core polling through the BRR bit in Interrupt Status register (interrupt or polling)
- Internal DMA

When internal DMA is not used (DMAEN bit in Transfer Type register is not set when the command is sent), the uSDHC asserts a DMA request when the amount of data exceeds the value set in the RD_WML register, that is available and ready for system fetching data. At the same time, the uSDHC sets the BRR bit. The buffer read ready interrupt will be generated if it is enabled by software.

When internal DMA is used, the uSDHC will not inform the system before all the required number of bytes are transferred (if no error was encountered). When an error occurs during the data transfer, the uSDHC will abort the data transfer and abandon the current block. The Host Driver should read the content of the DMA System Address register to get the starting address of the abandoned data block. If the current data transfer is in multi-block mode, the uSDHC will not automatically send CMD12, even though the
AC12EN bit in the Transfer Type register is set. The Host Driver sends CMD12 in this scenario and re-starts the read operation from that address. It is recommended that a Software Reset for Data be applied before the transfer is re-started.

For any write transfer mode, the uSDHC will not start data transmission until the number of words set in the RD_WML register are in the buffer. If the buffer is full and the Host System does not read data in time, the uSDHC will stop the CLK to avoid the data buffer over-run situation.

### 26.5.1.3 Data Buffer and Block Size

The user needs to know the buffer size for the buffer operation during a data transfer to utilize it in the most optimized way. In the uSDHC, the only data buffer can hold up to 128 words (32-bit) and the watermark levels for write and read can be configured accordingly.

For both read and write, the watermark level can be from 1 to 128 words. For both read and write the burst length can be from 1 to 31 words. The Host Driver may configure the value according to the system situation and requirement.

During a multi-block data transfer, the block length can be set to any value between 1 and 4096 bytes, satisfying the requirements of the external card. The only restriction is from the external card, which can be limited in size or support of a partial block access (which is not the integer times of 512 bytes).

As uSDHC treats each block individually, for block sizes which are not multiples of four (not word-aligned) stuffed bytes are required at the end of each block. For example, if the block size is 7 bytes and there are 12 blocks to write, the system side must write two times for each block. For each block the ending byte will be abandoned by uSDHC because it only sends 7 bytes to the card and picks data from the following system write, resulting in 24 beats of write access in total.

### 26.5.1.4 Dividing Large Data Transfer

This SDIO command CMD53 definition limits the maximum data size of data transfers according to the following formula:

\[
\text{Max data size} = \text{Block size} \times \text{Block count}
\]

The length of a multiple block transfer needs to be in block size units. If the total data length can't be divided evenly into a multiple of the block size, then there are two ways to transfer the data which depend on the function and the card design. Option 1 is for the Host Driver to split the transaction. The remainder of the block size data is then
transferred by using a single block command at the end. Option 2 is to add dummy data in the last block to fill the block size. For option 2, the card must manage the removal of the dummy data.

See the figure below for an example showing the dividing of large data transfers, assuming a kind of WLAN SDIO card that only supports a block size up to 64 bytes. Although the uSDHC supports a block size of up to 4096 bytes, the SDIO can only accept a block size less than 64 bytes, so the data must be divided (see example below).
26.5.2 DMA AHB Interface

The internal DMA implements a DMA engine and the AHB master. When the internal DMA is enabled, the uSDHC_dreq_b will not be asserted during the transfer, but the BWR and BRR bits will be set if the BWRSEN and BRRSEN bits have been set in the Interrupt Status Enable register.

See the figure below for an illustration of the DMA AHB interface block.

![Diagram of DMA AHB Interface Block](image)

**Figure 26-7. DMA AHB Interface Block**

26.5.2.1 Internal DMA Request

If the watermark level requirement is met in data transfer or if the last data of current block is ready in the data buffer, and the Internal DMA is enabled, the Data Buffer block will send a DMA request to AHB interface.

The delay in response from the internal DMA engine depends on the system AHB bus loading and the priority assigned to the uSDHC. The DMA engine does not respond to the request during its burst transfer, but is ready to serve as soon as the burst is over. The Data Buffer de-asserts the request if the data buffer space (for write) or bytes in data buffer is smaller than the watermark level. Upon access to the buffer by internal DMA, the Data Buffer updates its internal buffer pointer, and when the watermark level is satisfied or the last data of current block is ready in the data buffer, another DMA request is sent.
The data transfer is in the block unit, and the subsequent watermark level is always set as the remaining number of words. For instance, for a multi block data read with each block size of 31 bytes, and the burst length set to 6 words. After the first burst transfer, if there are more than 2 words in the buffer (which might contain some data of the next block), another DMA request is sent. This is because the remaining number of words to send for the current block is \((31 - 6 \times 4) / 4 = 2\). The uSDHC will read 2 words out of the buffer, with 7 valid bytes and 1 stuffed byte.

26.5.2.2 DMA Burst Length

Just like a CPU polling access, the DMA burst length for the internal DMA engine can be from 1 to 16 words. The actual burst length for the DMA depends on the lesser of the configured burst length or the remaining words of the current block.

See the example in Internal DMA Request. After 6 words are read, the burst length will be 2 words, then the next burst length will be 6 words. This is because the next block starts, which is 31 bytes, more than 6 words. The Host Driver may take this variable burst length into account. It is also acceptable to configure the burst length as the divisor of the block size, so that each time the burst length will be the same.

26.5.2.3 AHB Master Interface

It is possible that the internal AHB DMA engine could fail during the data transfer. Upon detection of an AHB bus error during DMA transfer, the DMA engine stops the transfer and goes to the idle state. At that point, the internal data buffer stops receiving incoming data and sending out data. The DMAE bit in the Interrupt Status register will be generated to host CPU to report a bus error condition.

Once the DMAE interrupt is received, the software shall send a CMD12 to abort the current transfer and read the DS_ADDR bits of the DMA System Address register to get the starting address of the corrupted block. After the DMA error is fixed, the software should apply a data reset and re-start the transfer from this address to recover the corrupted block. DMA operation will resume when the interrupt is serviced by software.

26.5.2.4 ADMA Engine

In the SD Host Controller Standard, a new DMA transfer algorithm called the ADMA (Advanced DMA) is defined. For Simple DMA, once the page boundary is reached, a DMA interrupt will be generated and the new system address shall be programmed by the Host Driver.
The ADMA defines the programmable descriptor table in the system memory. The Host Driver can calculate the system address at the page boundary and program the descriptor table before executing ADMA. It reduces the frequency of interrupts to the host system. Therefore, higher speed DMA transfers could be realized since the Host MCU intervention would not be needed during long DMA based data transfers.

There are two types of ADMA: ADMA1 and ADMA2 in Host Controller. ADMA1 can support data transfer of 4KB aligned data in system memory. ADMA2 improves the restriction so that data of any location and any size can be transferred in system memory. Their formats of Descriptor Table are different.

ADMA can recognize all kinds of descriptors define in SD Host Controller Standard, and if 'End' flag is detected in the descriptor, ADMA will stop after this descriptor is processed.

### 26.5.2.4.1 ADMA Concept and Descriptor Format

For ADMA1, including the following descriptors:

- Valid/Invalid descriptor.
- Nop descriptor.
- Set data length descriptor.
- Set data address descriptor.
- Link descriptor.
- Interrupt flag and End flag in descriptor.

For ADMA2, including the following descriptors:

- Valid/Invalid descriptor.
- Nop descriptor.
- Rsv descriptor.
- Set data length & address descriptor.
- Link descriptor.
- Interrupt flag and End flag in descriptor.

ADMA will start read/write operation after it reaches the Tran state, using the data length and data address analyzed from most recent descriptor(s).

For ADMA1, the valid data length descriptor is the last Set type descriptor before Tran type descriptor. Every Tran type will trigger a transfer, and the transfer data length is extracted from the most recent Set type descriptor. If there is no Set type descriptor after the previous Trans descriptor, the data length will be the value for previous transfer, or 0 if no Set descriptor is ever met.
Functional Description

For ADMA2, Tran type descriptor contains both data length and transfer data address, so only a Tran type descriptor can start a data transfer.

See the figure below for the format of the descriptor table for ADMA1.

<table>
<thead>
<tr>
<th>Address/ Page Field</th>
<th>Address/ Page Field</th>
<th>Attribute Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>12</td>
<td>6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>5</td>
</tr>
<tr>
<td>Address or Data Length</td>
<td>000000</td>
<td>Act 2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Act 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Int</td>
</tr>
<tr>
<td></td>
<td></td>
<td>End</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Valid</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Act 2</th>
<th>Act1</th>
<th>Symbol</th>
<th>Comment</th>
<th>31-28</th>
<th>27-12</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Nop</td>
<td>No Operation</td>
<td>Don't Care</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Set</td>
<td>Set Data Length</td>
<td>0000</td>
<td>Data Length</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Tran</td>
<td>Transfer Data</td>
<td></td>
<td>Data Address</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Link</td>
<td>Link Descriptor</td>
<td></td>
<td>Descriptor Address</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Valid</th>
<th>End</th>
<th>Int</th>
</tr>
</thead>
<tbody>
<tr>
<td>Valid = 1 indicates this line of descriptor is effective. If Valid = 0 generate ADMA Error Interrupt and stop ADMA.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>End = 1 indicates current descriptor is the ending one.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Int = 1 generates DMA Interrupt when this descriptor is processed.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Figure 26-8. Format of the ADMA1 Descriptor Table**
Figure 26-9. Concept and Access Method of ADMA1 Descriptor Table

The figure below explains the ADMA2 format. ADMA2 deals with the lower 32-bit first, and then the higher 32-bit. If the 'Valid' flag of descriptor is 0, it will ignore the high 32-bit. Address field shall be set on word aligned(lower 2-bit is always set to 0). Data length is in byte unit.
### Functional Description

<table>
<thead>
<tr>
<th>Address Field</th>
<th>Length</th>
<th>Reserved</th>
<th>Attribute Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>63:32</td>
<td>31:16</td>
<td>15:06</td>
<td>05:04</td>
</tr>
<tr>
<td>32-bit Address</td>
<td>16-bit length</td>
<td>0000000000</td>
<td>Act 2: Act 1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>0: Int: End: Valid</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Act 2</th>
<th>Act1</th>
<th>Symbol</th>
<th>Comment</th>
<th>Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Nop</td>
<td>No Operation</td>
<td>Don't Care</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Rsv</td>
<td>Reserved</td>
<td>Same as Nop. Read this line and go to next one</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Tran</td>
<td>Transfer Data</td>
<td>Transfer data with address and length set in this descriptor line</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Link</td>
<td>Link Descriptor</td>
<td>Link to another descriptor</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Valid</th>
</tr>
</thead>
<tbody>
<tr>
<td>Valid = 1 indicates this line of descriptor is effective. If Valid = 0 generate ADMA Error Interrupt and stop ADMA.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>End</th>
</tr>
</thead>
<tbody>
<tr>
<td>End = 1 indicates current descriptor is the ending one.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Int</th>
</tr>
</thead>
<tbody>
<tr>
<td>Int = 1 generates DMA Interrupt when this descriptor is processed.</td>
</tr>
</tbody>
</table>

---

**Figure 26-10. Format of the ADMA2 Descriptor Table**
26.5.2.4.2 ADMA Interrupt

If the interrupt flag descriptor is set, ADMA will generate an interrupt according to various types of descriptors:

For ADMA1:

- Set type of descriptor: interrupt is generated when data length is set.
- Tran type descriptor: interrupt is generated when this transfer is complete.
- Link type of descriptor: interrupt is generated when new descriptor address is set.
- Nop type of descriptor: interrupt is generated just after this descriptor is fetched.

For ADMA2:

- Tran type of descriptor: interrupt is generated when this transfer is complete.
- Link type of descriptor: interrupt is generated when new descriptor address is set.
- Nop/Rsv type of descriptor: interrupt is generated just after this descriptor is fetched.
26.5.2.4.3 ADMA Error

The ADMA will stop whenever any error is encountered. These errors include:

- Fetching descriptor error
- AHB response error
- Data length mismatch error

An ADMA descriptor error will be generated when it fails to detect a 'Valid' flag in the descriptor. If an ADMA descriptor error occurs, the interrupt is not generated even if the 'Interrupt' flag of this descriptor is set.

When BLKCNTEN bit is set, data length set in buffer must be equal to the whole data length set in descriptor nodes, otherwise data length mismatch error will be generated.

When BLKCNTEN bit is not set, then whole data length set in descriptor should be a multiple of block lengths; otherwise, when data set in the descriptor nodes are not performed at block boundaries, then data mismatch errors will occur.

26.5.3 Register Bank with IP Bus Interface

Register accesses via the IP Bus interface are actually on the Register Bank.

See the figure below for the block diagram.
Only 32-bit access is allowed, and no partial read / write is supported, thus all accesses are word aligned.

### 26.5.3.1 SD Protocol Unit

The SD protocol unit deals with all SD protocol affairs.

The SD Protocol Unit performs the following functions:

- Acts as the bridge between the internal buffer and the SD bus
- Sends the command data as well as its argument serially
- Stores the serial response bit stream into corresponding registers
- Detects the bus state on the CMD/DAT lines
- Monitors the interrupt from the SDIO card
- Asserts the read wait signal
- Gates off the SD clock when buffer is announcing danger status
- Detects the write protect state

The SD Protocol Unit consists of four sub modules:

1. SD control misc.
2. Command control.
3. Data control.
4. Clock control

26.5.3.2 SD control misc

In the SD control misc unit, the card detect (include the CD_B and DATA3 used as Card Detection), write protection and card interrupt are implemented.

This module monitors the signal level on all 8 data lines, the command lines, and directly routes the level values into the Register Bank. The driver can use this for debug purposes.

The module also detects the WP (Write Protect) line. If WP is active, writes to the register bank will be ignored.

This module also drives the LCTL output signal when the LCTL bit is set by the driver.

26.5.3.3 SD Clock control

If the internal data buffer is near full (for read) or near empty (for write), the SD clock must be gated off to avoid buffer over/under-run, this module will assert the gate of the output SD clock to shut the clock off. After the buffer has space (for read) or has data (for write), the clock gate of this module will open and the SD clock will be active again.

26.5.3.4 Command control

The Command Control module deals with the transactions on the CMD line.

See the figure below for an illustration of the structure for the Command CRC Shift Register.
The CRC polynomials for the CMD are as follows:

Generator polynomial: \( G(x) = x^7 + x^3 + 1 \)
\( M(x) = \text{(first bit)} \cdot x^n + \text{(second bit)} \cdot x^{n-1} + \ldots + \text{(last bit)} \cdot x^0 \)
\( \text{CRC}[6:0] = \text{Remainder} \left[ (M(x) \cdot x^7) / G(x) \right] \)

26.5.3.5 Data control

The Data Agent deals with the transactions on the eight data lines. Moreover, this module also detects the busy state on the DATA0 line, and generates the Read Wait state by the request from the Transceiver.

The CRC polynomials for the DATA are as follows:

Generator polynomial: \( G(x) = x^{16} + x^{12} + x^5 + 1 \)
\( M(x) = \text{(first bit)} \cdot x^n + \text{(second bit)} \cdot x^{n-1} + \ldots + \text{(last bit)} \cdot x^0 \)
\( \text{CRC}[15:0] = \text{Remainder} \left[ (M(x) \cdot x^{16}) / G(x) \right] \)

26.5.4 Clock & Reset Manager

This module controls all the reset signals within the uSDHC.

There are four kinds of reset signals within uSDHC:

1. Hardware reset.
2. Software reset for all logic.
3. Software reset for the data logic.
4. Software reset for the command logic.

All these signals are fed into this module and stable signals are generated inside the module to reset all other modules. The module also gates off all the inside signals.
26.5.5 Clock Generator

The Clock Generator generates the card CLK by peripheral source clock in two stages. Refer to the figure below for the structure of the divider. The term "Base" represents the frequency of peripheral source clock.

![Figure 26-14. Two Stages of the Clock Divider](image)

The first stage outputs an intermediate clock (DIV), which can be Base, Base/2, Base/3, ..., or Base/16.

The second stage is a prescaler, and outputs the actual internal working clock (card_clk). This clock is the driving clock for all sub modules of the SD Protocol Unit, and the sync FIFOs (see Figure 26-3) to synchronize with the data rate from the internal data buffer. The frequency of the clock output from this stage, can be DIV, DIV/2, DIV/4, ..., or DIV/256. Thus the highest frequency of the card_clk is Base, and the next highest is Base/2, while the lowest frequency is Base/4096. If the duty cycle of Base clock is 50%, the duty cycle of card_clk is also 50%, even when the compound divisor is an odd value.

Please note, in SDR mode and DDR mode, the CLK are different.
- In SDR mode, CLK is equal to the internal working clock(card_clk).
- In DDR mode, CLK is equal to the card_clk/2.

26.5.6 SDIO Card Interrupt

Information on Interrupts in 1-bit Mode, Interrupts in 4-bit Mode, and Card Interrupt Handling are detailed in the sections below.

26.5.6.1 Interrupts in 1-bit Mode

In this case the DATA1 pin is dedicated to providing the interrupt function. An interrupt is asserted by pulling the DATA1 low from the SDIO card, until the interrupt service is finished to clear the interrupt.
26.5.6.2 Interrupt in 4-bit Mode

Since the interrupt and data line 1 share Pin 8 in 4-bit mode, an interrupt will only be sent by the card and recognized by the host during a specific time. This is known as the Interrupt Period. The uSDHC will only sample the level on Pin 8 during the Interrupt Period. At all other times, the host will ignore the level on Pin 8, and treat it as the data signal. The definition of the Interrupt Period is different for operations with single block and multiple block data transfers.

In the case of normal single data block transmissions, the Interrupt Period becomes active two clock cycles after the completion of a data packet. This Interrupt Period lasts until after the card receives the end bit of the next command that has a data block transfer associated with it.

For multiple block data transfers in 4-bit mode, there is only a limited period of time that the Interrupt Period can be active due to the limited period of data line availability between the multiple blocks of data. This requires a more strict definition of the Interrupt Period. For this case, the Interrupt Period is limited to two clock cycles. This begins two clocks after the end bit of the previous data block. During this 2-clock cycle interrupt period, if an interrupt is pending, the DATA1 line will be held low for one clock cycle with the last clock cycle pulling DATA1 high. On completion of the Interrupt Period, the card releases the DATA1 line into the high Z state. The uSDHC samples the DATA1 during the Interrupt Period when the IABG bit in the Protocol Control register is set.

Refer to SDIO Card Specification v1.10f for further information about the SDIO card interrupt.

26.5.6.3 Card Interrupt Handling

When the CINTIEN bit in the Interrupt Signal Enable Register is set to 0, the uSDHC clears the interrupt request to the Host System. The Host Driver should clear this bit before servicing the SDIO Interrupt and should set this bit again after all interrupt requests from the card are cleared to prevent inadvertent interrupts.

The SDIO Card Interrupt Status can be cleared by writing 1 to this bit. But as the interrupt source from the SDIO card does not clear, this bit is set again. In order to clear this bit, it is required to reset the interrupt source from the external card followed by a writing 1 to this bit. In 1-bit mode, the uSDHC will detect the SDIO Interrupt with or without the SD clock (to support wakeup). In 4-bit mode, the interrupt signal is sampled during the Interrupt Period, so there are some sample delays between the interrupt signal from the SDIO card and the interrupt to the Host System Interrupt Controller. When the
SDIO status has been set, and the Host Driver needs to service this interrupt, so the SDIO bit in the Interrupt Control Register of SDIO card will be cleared. This is required to clear the SDIO interrupt status latched in the uSDHC and to stop driving the interrupt signal to the System Interrupt Controller. The Host Driver must issue a CMD52 to clear the card interrupt. After completion of the card interrupt service, the SDIO Interrupt Status Enable bit is set to 1, and the uSDHC starts sampling the interrupt signal again.

See the figure below for an illustration of the SDIO card interrupt scheme and for the sequences of software and hardware events that take place during a card interrupt handling procedure.

**Figure 26-15. Card Interrupt Scheme and Card Interrupt Detection and Handling Procedure**
26.5.7 Card Insertion and Removal Detection

The uSDHC uses either the DATA3 pin or the CD_B pin to detect card insertion or removal. When there is no card on the MMC/SD bus, the DATA3 will be pulled to a low voltage level by default.

When any card is inserted to or removed from the socket, the uSDHC detects the logic value changes on the DATA3 pin and generates an interrupt. When the DATA3 pin is not used for card detection (for example, it is implemented in GPIO), the CD_B pin must be connected for card detection. Whether DATA3 is configured for card detection or not, the CD_B pin is always a reference for card detection. Whether the DATA3 pin or the CD_B pin is used to detect card insertion, the uSDHC will send an interrupt (if enabled) to inform the Host system that a card is inserted.

26.5.8 Power Management and Wake Up Events

When there is no operation between the uSDHC and the card through the SD bus, the user can completely disable the ipg_clk and ipg_perclk in the chip level clock control module to save power. When the user needs to use the uSDHC to communicate with the card, it can enable the clock and start the operation.

In some circumstances, when the clocks to the uSDHC are disabled, for instance, when the system is in low power mode, there are some events for which the user needs to enable the clock and handle the event. These events are called wakeup interrupts. The uSDHC can generate these interrupt even when there are no clocks enabled. The three interrupts which can be used as wake up events are:
1. Card Removal Interrupt
2. Card Insertion Interrupt
3. Interrupt from SDIO card

The uSDHC offers a power management feature. By clearing the clock enabled bits in the System Control Register, the clocks are gated in the low position to the uSDHC. For maximum power saving, the user can disable all the clocks to the uSDHC when there is no operation in progress.

These three wake up events (or wakeup interrupts) can also be used to wake up the system from low-power modes.

**NOTE**

To make the interrupt a wakeup event, when all the clocks to the uSDHC are disabled or when the whole system is in low power mode, the corresponding wake up enabled bit needs to be
set. Refer to Protocol Control (PROT_CTRL) for more information on the uSDHC Protocol Control register.

26.5.8.1 Setting Wake Up Events

For the uSDHC to respond to a wakeup event, the software must set the respective wakeup enable bit before the CPU enters sleep mode.

Before the software disables the host clock, it should ensure that all of the following conditions have been met:

- No Read or Write Transfer is active
- Data and Command lines are not active
- No interrupts are pending
- Internal data buffer is empty

26.5.9 MMC fast boot

The Embedded MultiMediaCard (eMMC4.3) specification adds a fast boot feature which requires hardware support. There are two types of fast boot mode, boot operation, and alternative boot operation in the eMMC4.3 specification. Each type also has with-acknowledge and without-acknowledge modes.

In boot operation mode, the master (MultiMediaCard host) can read boot data from the slave (MMC device) by keeping CMD line low after power-on, or sending CMD0 with argument + 0xFFFFFFFFFA (optional for slave), before issuing CMD1.

NOTE
For the eMMC4.3 card setting, please see the eMMC4.3 specification.

26.5.9.1 Boot operation

NOTE
For the purposes of this documentation, fast boot is called "normal fast boot mode".

If the CMD line is held LOW for 74 clock cycles and more after power-up before the first command is issued, the slave recognizes that boot mode is being initiated and starts preparing boot data internally.
Within 1 second after the CMD line goes LOW, the slave starts to send the first boot data to the master on the DATA line(s). The master must keep the CMD line LOW to read all of the boot data.

If boot acknowledge is enabled, the slave has to send acknowledge pattern '010' to the master within 50ms after the CMD line goes LOW. If boot acknowledge is disabled, the slave will not send out acknowledge pattern '010'.

The master can terminate boot mode with the CMD line HIGH.

Boot operation will be terminated when all contents of the enabled boot data are sent to the master. After boot operation is executed, the slave shall be ready for CMD1 operation and the master needs to start a normal MMC initialization sequence by sending CMD1.

Figure 26-16. MultiMediaCard state diagram (normal boot mode)

26.5.9.2 Alternative boot operation

This boot function is optional for the device. If bit 0 in the extended CSD byte[228] is set to '1', the device supports the alternative boot operation.

After power-up, if the host issues CMD0 with the argument of 0xFFFFFFFFA after 74 clock cycles, before CMD1 is issued or the CMD line goes low, the slave recognizes that boot mode is being initiated and starts preparing boot data internally.

Within 1 second after CMD0 with the argument of 0xFFFFFFFFA is issued, the slave starts to send the first boot data to the master on the DATA line(s).

If boot acknowledge is enabled, the slave has to send the acknowledge pattern '010' to the master within 50ms after the CMD0 with the argument of 0xFFFFFFFFA is received. If boot acknowledge is disabled, the slave will not send out acknowledge pattern '010'.

The master can terminate boot mode by issuing CMD0 (Reset).
Boot operation will be terminated when all contents of the enabled boot data are sent to the master. After boot operation is executed, the slave shall be ready for CMD1 operation and the master needs to start a normal MMC initialization sequence by sending CMD1.

NOTE 1. CMD0 with argument 0xFFFFFFFFFA

Figure 26-17. MultiMediaCard state diagram (alternative boot mode)

26.6 Initialization/Application of uSDHC

All communication between the system and cards are controlled by the host. The host sends commands of two types: broadcast and addressed (point-to-point).

Broadcast commands are intended for all cards, such as GO_IDLE_STATE, SEND_OP_COND, ALL_SEND_CID. In Broadcast mode, all cards are in the open-drain mode to avoid bus contention. Refer to Commands for MMC/SD/SDIO for the commands of bc and bcr categories.

After the Broadcast command CMD3 is issued, the cards enter standby mode. Addressed type commands are used from this point. In this mode, the CMD/DATA I/O pads will turn to push-pull mode, to have the driving capability for maximum frequency operation. Refer to Commands for MMC/SD/SDIO for the commands of ac and adtc categories.
26.6.1 Command Send & Response Receive Basic Operation

Assuming the data type WORD is an unsigned 32-bit integer, the below flow is a guideline for sending a command to the card(s):

```c
send_command(cmd_index, cmd_arg, other requirements)
{
    WORD wCmd; // 32-bit integer to make up the data to write into Transfer Type register, it is recommended to implement in a bit-field manner
    wCmd = (<cmd_index> & 0x3f) >> 24; // set the first 8 bits as '00'+<cmd_index>
    set CMDTYP, DPSEL, CICEN, CCCEN, RSTTYP, DTDSEL according to the command index;
    if (internal DMA is used) wCmd |= 0x1;
    if (multi-block transfer) {
        set MSBSEL bit;
        if (finite block number) {
            set BCEN bit;
            if (auto12 command is to use) set AC12EN bit;
        }
    }
    write_reg(CMDARG, <cmd_arg>); // configure the command argument
    write_reg(XFERTYP, wCmd); // set Transfer Type register as wCmd value to issue the command
}
wait_for_response(cmd_index)
{
    while (CC bit in IRQ Status register is not set); // wait until Command Complete bit is set
    read IRQ Status register and check if any error bits about Command are set
    if (any error bits are set) report error;
    write 1 to clear CC bit and all Command Error bits;
}
```

For the sake of simplicity, the function wait_for_response is implemented here by means of polling. For an effective and formal way, the response is usually checked after the Command Complete Interrupt is received. When doing this, make sure the corresponding interrupt status bits are enabled.

For some scenarios, the response time-out is expected. For instance, after all cards respond to CMD3 and go to the Standby State, no response to the Host when CMD2 is sent. The Host Driver will deal with "fake" errors like this with caution.

26.6.2 Card Identification Mode

When a card is inserted to the socket or the card was reset by the host, the host needs to validate the operation voltage range, identify the cards, request the cards to publish the Relative Card Address (RCA) or to set the RCA for the MMC cards.

26.6.2.1 Card Detect

See the figure below for a flow diagram showing the detection of MMC, SD and SDIO cards using the uSDHC.
Enable card detection irq

Wait for uSDHC interrupt

Check CINS bit

Yes cards present

Clear CINSIEN to disable card detection irq

Voltage validation

No cards present

Figure 26-18. Flow Diagram for Card Detection

Here is the card detect sequence:

- Set the CINSIEN bit to enable card detection interrupt
- When an interrupt from the uSDHC is received, check the CINS bit in the Interrupt Status register to see if it was caused by card insertion
- Clear the CINSIEN bit to disable the card detection interrupt and ignore all card insertion interrupts afterwards

26.6.2.2 Reset

The host consists of three types of resets:

- Hardware reset (Card and Host) which is driven by POR (Power On Reset)
• Software reset (Host Only) is initiated by the write operation on the RSTD, RSTC, or RSTA bits of the System Control register to reset the data part, command part, or all parts of the Host Controller, respectively
• Card reset (Card Only). The command, "Go_Idle_State" (CMD0), is the software reset command for all types of MMC cards, SD Memory cards. This command sets each card into the Idle State regardless of the current card state. For an SD I/O Card, CMD52 is used to write an I/O reset in the CCCR. The cards are initialized with a default relative card address (RCA=0x0000) and with a default driver stage register setting (lowest speed, highest driving current capability).

After the card is reset, the host needs to validate the voltage range of the card. See the figure below for the software flow to reset both the uSDHC and the card.

Figure 26-19. Flow Chart for Reset of the uSDHC and SD I/O Card

```c
software_reset()
{
    set_bit(SYSCTRL, RSTA); // software reset the Host
    set DTOCV and SDCLKFS bit fields to get the CLK of frequency around 400kHz
    configure IO pad to set the power voltage of external card to around 3.0V
    poll bits CIHB and CDIHB bits of PRSSTAT to wait both bits are cleared
    set_bit(SYSCTRL, INTIA); // send 80 clock ticks for card to power up
    send_command(CMD_GO_IDLE_STATE, <other parameters>); // reset the card with CMD0
    or send_command(CMD_IO_RW_DIRECT, <other parameters>);
}
```

### 26.6.2.3 Voltage Validation

All cards should be able to establish communication with the host using any operation voltage in the maximum allowed voltage range specified in the card specification. However, the supported minimum and maximum values for Vdd are defined in the Operation Conditions Register (OCR) and may not cover the whole range.
Cards that store the CID and CSD data in the preload memory are only able to communicate this information under data transfer Vdd conditions. This means if the host and card have non-common Vdd ranges, the card will not be able to complete the identification cycle, nor will it be able to send CSD data.

Therefore, a special command Send_Op_Con (CMD1 for MMC), SD_Send_Op_Con (ACMD41 for SD Memory) and IO_Send_Op_Con (CMD5 for SD I/O) is used. The voltage validation procedure is designed to provide a mechanism to identify and reject cards which do not match the Vdd range(s) desired by the host. This is accomplished by the host sending the desired Vdd voltage window as the operand of this command. Cards that can't perform the data transfer in the specified range must discard themselves from further bus operations and go into the Inactive State. By omitting the voltage range in the command, the host can query each card and determine the common voltage range before sending out-of-range cards into the Inactive State. This query should be used if the host is able to select a common voltage range or if a notification shall be sent to the system when a non-usable card in the stack is detected.

The following steps show how to perform voltage validation when a card is inserted:

```c
voltage_validation(voltage_range_argument)
{
    label the card as UNKNOWN;
    send_command(IO_SEND_OP_COND, 0x0, <other parameters are omitted>); // CMD5, check SDIO operation voltage, command argument is zero
    if (RESP_TIMEOUT != wait_for_response(IO_SEND_OP_COND)) { // SDIO command is accepted
        if (0 < number of IO functions) {
            label the card as SDIO;
            IORDY = 0;
            while (!IORDY in IO OCR response)) { // set voltage range for each IO function
                send_command(IO_SEND_OP_COND, <voltage range>, <other parameter>);
                wait_for_response(IO_SEND_OP_COND);
            } // end of while ...
        } // end of if (0 < ...
        if (memory part is present inside SDIO card) Label the card as SDCombo; // this is an SD-Combo card
    } // end of if (RESP_TIMEOUT ...
    if (the card is labelled as SDIO card) return; // card type is identified and voltage range is set, so exit the function;
    send_command(APP_CMD, 0x0, <other parameters are omitted>); // CMD55, Application specific CMD prefix
    if (no error calling wait_for_response(APP_CMD, <...>) { // CMD55 is accepted
        send_command(SD_APP_OP_COND, <voltage range>, <...>); // ACMD41, to set voltage range
        for memory part or SD card
        wait_for_response(SD_APP_OP_COND); // voltage range is set
        if (card type is UNKNOWN) label the card as SD; return; //
    } // end of if (no error ...
    else if (errors other than time-out occur) { // command/response pair is corrupted deal with it by program specific manner;
} // of else if (response time-out
else { // CMD55 is refuse, it must be MMC card if (card is already labelled as SDCombo)
    change label
```
re-label the card as SDIO;
    ignore the error or report it;
    return; // card is identified as SDIO card
} // of if {card is ...
send_command(SEND_OP_COND, <voltage range>, <...>);
if (RESP_TIMEOUT == wait_for_response(SEND_OP_COND)) { // CMD1 is not accepted,
either
    label the card as UNKNOWN;
    return;
} // of if {RESP_TIMEOUT ...
} // of else

26.6.2.4 Card Registry

Card registry for the MMC and SD/SDIO/SD Combo cards are different. For the SD Card, the Identification process starts at a clock rate lower than 400 kHz and the power voltage higher than 2.7 V (as defined by the Card spec). At this time, the CMD line output drives are push-pull drivers instead of open-drain. After the bus is activated, the host will request the card to send their valid operation conditions.

The response to ACMD41 is the operation condition register of the card. The same command shall be send to all of the new cards in the system. Incompatible cards are put into the Inactive State. The host then issues the command, All_Send_CID (CMD2), to each card to get its unique card identification (CID) number. Cards that are currently unidentified (in the Ready State), send their CID number as the response. After the CID is sent by the card, the card goes into the Identification State.

The host then issues Send_Relative_Addr (CMD3), requesting the card to publish a new relative card address (RCA) that is shorter than the CID. This RCA will be used to address the card for future data transfer operations. Once the RCA is received, the card changes its state to the Standby State. At this point, if the host wants the card to have an alternative RCA number, it may ask the card to publish a new number by sending another Send_Relative_Addr command to the card. The last published RCA is the actual RCA of the card.

The host repeats the identification process with CMD2 and CMD3 for each card in the system until the last CMD2 gets no response from any of the cards in system.

For MMC operation, the host starts the card identification process in open-drain mode with the identification clock rate lower than 400 kHz and the power voltage higher than 2.7 V. The open drain driver stages on the CMD line allow parallel card operation during card identification. After the bus is activated the host will request the cards to send their valid operation conditions (CMD1). The response to CMD1 is the "wired OR" operation on the condition restrictions of all cards in the system. Incompatible cards are sent into the Inactive State. The host then issues the broadcast command All_Send_CID (CMD2), asking all cards for their unique card identification (CID) number. All unidentified cards
(the cards in Ready State) simultaneously start sending their CID numbers serially, while bit-wise monitoring their outgoing bit stream. Those cards, whose outgoing CID bits do not match the corresponding bits on the command line in any one of the bit periods, stop sending their CID immediately and must wait for the next identification cycle. Since the CID is unique for each card, only one card can be successfully send its full CID to the host. This card then goes into the Identification State. Thereafter, the host issues Set_Relative_Addr (CMD3) to assign to the card a relative card address (RCA). Once the RCA is received the card state changes to the Stand-by State, and the card does not react in further identification cycles, and its output driver switches from open-drain to push-pull. The host repeats the process, mainly CMD2 and CMD3, until the host receives a timeout condition to recognize the completion of the identification process.

For operation as MMC cards:

```c
void card_registry()
{
    do { // decide RCA for each card until response time-out
        if (card is labelled as SDCombo or SDIO) { // for SDIO card like device
            send_command(SET_RELATIVE_ADDR, 0x00, <...>); // ask SDIO card to publish its RCA
            retrieve RCA from response;
        } // end if (card is labelled as SDCombo ...
        else if (card is labelled as SD) { // for SD card
            send_command(ALL_SEND_CID, <...>);
            if (RESP_TIMEOUT == wait_for_response(ALL_SEND_CID)) break;
            send_command(SET_RELATIVE_ADDR, <...>);
            retrieve RCA from response;
        } // else if (card is labelled as SD ...
        else if (card is labelled as MMC) {
            send_command(ALL_SEND_CID, <...>);
            rca = 0x1; // arbitrarily set RCA, 1 here for example
            send_command(SET_RELATIVE_ADDR, 0x1 << 16, <...>); // send RCA at upper 16 bits
        } // end of else if (card is labelled as MMC ...
    } while (response is not time-out);
}
```

### 26.6.3 Card Access

Information about Block Write, Block Read, Suspense Resume, ADMA Usage, Transfer Error, and Card Interrupt are detailed in the sections below.

#### 26.6.3.1 Block Write

Information on Normal Write, DDR Write, and Write with Pause are detailed in the sections below.
26.6.3.1.1 Normal Write

During a block write (CMD24 - 27, CMD60, CMD61), one or more blocks of data are transferred from the host to the card with a CRC appended to the end of each block by the host. If the CRC fails, the card shall indicate the failure on the DATA line. The transferred data will be discarded and not written, and all further transmitted blocks (in multiple block write mode) will be ignored.

If the host uses partial blocks whose accumulated length is not block aligned and block misalignment is not allowed (CSD parameter WRITE_BLK_MISALIGN is not set), the card detects the block misalignment error and aborts the programming before the beginning of the first misaligned block. The card sets the ADDRESS_ERROR error bit in the status register, and while ignoring all further data transfer, waits in the Receive-data-State for a stop command. The write operation is also aborted if the host tries to write over a write protected area.

For MMC and SD cards, programming of the CID and CSD registers does not require a previous block length setting. The transferred data is also CRC protected. If a part of the CSD or CID register is stored in ROM, then this unchangeable part must match the corresponding part of the receive buffer. If this match fails, then the card will report an error and not change any register contents.

For all types of cards, some may require long and unpredictable periods of time to write a block of data. After receiving a block of data and completing the CRC check, the card will begin writing and hold the DATA line low if its write buffer is full and unable to accept new data from a new WRITE_BLOCK command. The host may poll the status of the card with a SEND_STATUS command (CMD13) or other means for SDIO cards at any time, and the card will respond with its status. The responded status indicates whether the card can accept new data or whether the write process is still in progress. The host may deselect the card by issuing a CMD7 (to select a different card) to place the card into the Standby State and release the DATA line without interrupting the write operation. When re-selecting the card, it will reactivate the busy indication by pulling DATA to low if the programming is still in progress and the write buffer is unavailable.

The software flow to write to a card incorporates the internal DMA and the write operation is a multi-block write with the Auto CMD12 enabled. For the other methods (CPU polling status) with different transfer methods, the internal DMA parts should be removed and the alternative steps should be straightforward.

The software flow to write to a card is described below:

1. Check the card status, wait until the card is ready for data.
2. Set the card block length/size:
For SD/MMC cards, use SET_BLOCKLEN (CMD16)
For SDIO cards or the I/O portion of SDCombo cards, use IO_RW_DIRECT (CMD52) to set the I/O Block Size bit field in the CCCR register (for function 0) or FBR register (for functions 1~7)

3. Set the uSDHC block length register to be the same as the block length set for the card in Step 2.
4. Set the uSDHC number block register (NOB), nob is 5 (for instance).
5. Disable the buffer write ready interrupt, configure the DMA settings and enable the uSDHC DMA when sending the command with data transfer. The AC12EN bit should also be set.
7. Check the status bit to see if a write CRC error occurred, or some another error, that occurred during the auto12 command sending and response receiving.

26.6.3.1.2 DDR Write

uSDHC supports dual data rate mode.

The software flow to write to a card in ddr mode is described as below:

1. Check the card status, wait until the card is ready for data.
2. For eMMC4.4 card, block length only can be set to 512byte.
3. Set the uSDHC number block register (NOB), nob is 5 (for instance).
4. Set eMMC4.4 card to high speed mode, use SWITCH(CMD6).
5. Set eMMC4.4 card bus with (4-bit /8-bit ddr mode), use SWITCH(CMD6).
6. Disable the buffer write ready interrupt, configure the DMA settings and enable the uSDHC DMA when sending the command with data transfer. The DDR_EN bit should be set. The AC12EN bit should also be set.
7. Wait for the Transfer Complete interrupt.
8. Check the status bit to see if a write CRC error occurred, or some another error, that occurred during the auto12 command sending and response receiving.

26.6.3.1.3 Write with Pause

The write operation can be paused during the transfer. Instead of stopping the CLK at any time to pause all the operations, which is also inaccessible to the Host Driver, the Driver can set the Stop At Block Gap Request(SABGREQ) bit in the Protocol Control register to pause the transfer between the data blocks. As there is no time-out condition in a write operation during the data blocks, a write to all types of cards can be paused in this way, and if the DATA0 line is not required to de-assert to release the busy state, no suspend command is needed.
Like in the flow described in **Normal Write**, the write with pause is shown with the same kind of write operation:

1. Check the card status, wait until card is ready for data.
2. Set the card block length/size:
   - For SD/MMC, use SET_BLOCKLEN (CMD16)
   - For SDIO cards or the I/O portion of SDCombo cards, use IO_RW_DIRECT(CMD52) to set the I/O Block Size bit field in the CCCR register (for function 0) or FBR register (for functions 1~7)
3. Set the uSDHC block length register to be the same as the block length set for the card in Step 2.
4. Set the uSDHC number block register (NOB), nob is 5 (for instance).
5. Disable the buffer write ready interrupt, configure the DMA settings and enable the uSDHC DMA when sending the command with data transfer. The AC12EN bit should also be set.
6. Set the SABGREQ bit.
7. Wait for the Transfer Complete interrupt.
8. Clear the SABGREQ bit.
9. Check the status bit to see if a write CRC error occurred.
10. Set the CREQ bit to continue the write operation.
12. Check the status bit to see if a write CRC error occurred, or some another error, that occurred during the auto12 command sending and response receiving.

The number of blocks left during the data transfer is accessible by reading the contents of the BLKCNT field in the Block Attribute register. As the data transfer and the setting of the SABGREQ bit are concurrent, and the delay of register read and the register setting, the actual number of blocks left may not be exactly the value read earlier. The Driver shall read the value of BLKCNT after the transfer is paused and the Transfer Complete interrupt is received.

It is also possible the last block has begun when the Stop At Block Gap Request is sent to the buffer. In this case, the next block gap is actually the end of the transfer. These types of requests are ignored and the Driver should treat this as a non-pause transfer and deal with it as a common write operation.

When the write operation is paused, the data transfer inside the Host System is not stopped, and the transfer is active until the data buffer is full. Because of this (if not needed), it is recommended to avoid using the Suspend Command for the SDIO card. This is because when such a command is sent, the uSDHC thinks the System will switch to another function on the SDIO card, and flush the data buffer. The uSDHC takes the Resume Command as a normal command with data transfer, and it is left for the Driver to set all the relevant registers before the transfer is resumed. If there is only one block to
send when the transfer is resumed, the MSBSEL and BCEN bits of the Transfer Type register are set as well as the AC12EN bit. However, the uSDHC will automatically send a CMD12 to mark the end of the multi-block transfer.

### 26.6.3.2 Block Read

Information about Normal Read, DDR Read, Read with Pause, and DLL (Delay Line) in Read Path are detailed in the sections below.

#### 26.6.3.2.1 Normal Read

For block reads, the basic unit of data transfer is a block whose maximum size is stored in areas defined by the corresponding card specification. A CRC is appended to the end of each block, ensuring data transfer integrity. The CMD17, CMD18, CMD53, CMD60, CMD61, and so on, can initiate a block read. After completing the transfer, the card returns to the Transfer State. For multi blocks read, data blocks will be continuously transferred until a stop command is issued.

The software flow to read from a card incorporates the internal DMA and the read operation is a multi-block read with the Auto CMD12 enabled. For the other methods (CPU polling status) with different transfer methods, the internal DMA parts should be removed and the alternative steps should be straightforward.

The software flow to read from a card is described below:

1. Check the card status, wait until card is ready for data.
2. Set the card block length/size:
   - For SD/MMC, use SET_BLOCKLEN (CMD16)
   - For SDIO cards or the I/O portion of SDCombo cards, use IO_RW_DIRECT(CMD52) to set the I/O Block Size bit field in the CCCR register (for function 0) or FBR register (for functions 1~7)
3. Set the uSDHC block length register to be the same as the block length set for the card in Step 2.
4. Set the uSDHC number block register (NOB), nob is 5 (for instance).
5. Disable the buffer read ready interrupt, configure the DMA settings and enable the uSDHC DMA when sending the command with data transfer. The AC12EN bit should also be set.
7. Check the status bit to see if a read CRC error occurred, or some another error, occurred during the auto12 command sending and response receiving.
26.6.3.2.2 DDR Read

uSDHC supports dual data rate mode.

The software flow to write to a card in ddr mode is described below:

1. Check the card status, wait until the card is ready for data.
2. For eMMC4.4 card, block length only can be set to 512byte.
3. Set the uSDHC number block register (NOB), nob is 5 (for instance).
4. Set eMMC4.4 card to high speed mode, use SWITCH(CMD6).
5. Set eMMC4.4 card bus with (4-bit/8-bit ddr mode), use SWITCH(CMD6).
6. Disable the buffer write ready interrupt, configure the DMA settings and enable the uSDHC DMA when sending the command with data transfer. The DDR_EN bit should be set. The AC12EN bit should also be set.
7. Wait for the Transfer Complete interrupt.
8. Check the status bit to see if a write CRC error occurred, or some another error, that occurred during the auto12 command sending and response receiving.

26.6.3.2.3 Read with Pause

The read operation is not generally able to pause. Only the SDIO card (and SDCombo card working under I/O mode) supporting the Read Wait feature can pause during the read operation. If the SDIO card supports Read Wait (SRW bit in CCCR register is 1), the Driver can set the SABGREQ bit in the Protocol Control register to pause the transfer between the data blocks.

Before setting the SABGREQ bit, make sure the RWCTL bit in the Protocol Control register is set, otherwise the uSDHC will not assert the Read Wait signal during the block gap and data corruption occurs. It is recommended to set the RWCTL bit once the Read Wait capability of the SDIO card is recognized.

Like in the flow described in Normal Read, the read with pause is shown with the same kind of read operation:

1. Check the SRW bit in the CCR register on the SDIO card to confirm the card supports Read Wait.
2. Set the RWCTL bit.
3. Check the card status and wait until the card is ready for data.
4. Set the card block length/size:
   - For SD/MMC, use SET_BLOCKLEN (CMD16)
   - For SDIO cards or the I/O portion of SDCombo cards, use IO_RW_DIRECT(CMD52) to set the I/O Block Size bit field in the CCCR register (for function 0) or FBR register (for functions 1~7)
5. Set the uSDHC block length register to be the same as the block length set for the card in Step 2.
6. Set the uSDHC number block register (NOB), nob is 5 (for instance).
7. Disable the buffer read ready interrupt, configure the DMA setting and enable the uSDHC DMA when sending the command with data transfer. The AC12EN bit should also be set.
8. Set the SABGREQ bit.
10. Clear the SABGREQ bit.
11. Check the status bit to see if read CRC error occurred.
12. Set the CREQ bit to continue the read operation.
14. Check the status bit to see if a read CRC error occurred, or some another error, occurred during the auto12 command sending and response receiving.

Like the write operation, it is possible to meet the ending block of the transfer when paused. In this case, the uSDHC will ignore the Stop At Block Gap Request and treat it as a command read operation.

Unlike the write operation, there is no remaining data inside the buffer when the transfer is paused. All data received before the pause will be transferred to the Host System. No matter if the Suspend Command is sent or not, the internal data buffer is not flushed.

If the Suspend Command is sent and the transfer is later resumed by means of a Resume Command, the uSDHC takes the command as a normal one accompanied with data transfer. It is left for the Driver to set all the relevant registers before the transfer is resumed. If there is only one block to send when the transfer is resumed, the MSBSEL and BCEN bits of the Transfer Type register are set, as well as the AC12EN bit.

However, the uSDHC will automatically send the CMD12 to mark the end of multi-block transfer.

### 26.6.3.2.4 DLL (Delay Line) in Read Path

The DLL (Delay Line) is newly added to assist in sampling read data. The DLL provides the ability to programatically select a quantized delay (in fractions of the clock period) regardless of on-chip variations such as process, voltage and temperature (PVT).

The reasons why the DLL is needed for uSDHC are 1.) the path of read data traveling from card to host varies. 2.) in SD/MMC DDR mode the minimum input setup and hold time are both at 2.5 ns. The data sampling window is so small that the delay of loopback clock needs to be accurate and consistent regardless of PVT. The DLL takes the divided card_clk as the reference clock and loopback clock as the input clock. It then generates a delayed version of the input clock according to the programmed target delay.
The DLL can be disabled or bypassed, and it can also be manually set for a fixed delay in override mode. The override value set is the number of delay cells. In override mode, there is no need to set the DLL_enable. Another DLL mode is target value mode. In this mode, the DLL will automatically adjust the number of delay cells according to target value set by user and PVT changes. Be aware that target value is in units of 1/32 of the clock reference period. If the card_clk is 100Mhz, then the reference clock period is 10ns, setting target value of 16 means 5ns = (16/32)*10ns. Software can disable automatic update by setting dll_gate_update bit.

Since the user may change the frequency of the card_clk from time to time by changing SDCLKFS[7:0]/DVS[3:0], the software must adjust the delay value to ensure it works correctly when the reference clock (card_clk) is changed. The following is the correct flow, which should be ignored if DLL_CTRL_ENABLE is not set.

Step 1: Set DLL_CTRL_RESET bit

Step 2: Configure the SDCLKFS[7:0] and DVS[3:0]

Step 3: Wait until SDSTB is asserted

Step 4: clear DLL_CTRL_RESET bit

Step 5: Wait until both DLL_STS_SLV_LOCK and DLL_STS_REF_LOCK are asserted

Step 6: set DLL_CTRL_SLV_FORCE_UPD

Step 7: clear DLL_CTRL_SLV_FORCE_UPD

NOTE

Software should make sure the DLL_CTRL_SLV_FORCE_UPD is lasted for at least one card_clk. So software may need to add some delay between Step6 and Step7.
26.6.3.3 Suspend Resume

The uSDHC supports the Suspend Resume operations of SDIO cards, although slightly differently than the suggested implementation of Suspend in the SDIO card specification.

26.6.3.3.1 Suspend

After setting the SABGREQ bit, the Host Driver may send a Suspend command to switch to another function of the SDIO card. The uSDHC does not monitor the content of the response, so it doesn't know if the Suspend command succeeded or not. Accordingly, it doesn't de-assert Read Wait for read pause. To solve this problem, the Driver shall not mark the Suspend command as a "Suspend", (i.e. setting the CMDTYP bits to 01). Instead, the Driver shall send this command as if it were a normal command, and only
when the command succeeds, and the BS bit is set in the response, can the Driver send another command marked as "Suspend" to inform the uSDHC that the current transfer is suspended. As shown in the following sequence for Suspend operation:

1. Set the SABREQ bit to pause the current data transfer at block gap.
2. After the BGE bit is set, send the Suspend command to suspend the active function. The CMDTYP bit field must be 2'b00.
3. Check the BS bit of the CCCR in the response. If it is 1, repeat this step until the BS bit is cleared or abandon the suspend operation according to the Driver strategy.
4. Send another normal I/O command to the suspended function. The CMDTYP of this command must be 2'b01, so the uSDHC can detect this special setting and be informed that the paused operation has successfully suspended. If the paused transfer is a read operation, the uSDHC stops driving DATA2 and goes to the idle state.
5. Save the context registers in the system memory for later use, including the DMA System Address Register (for internal DMA operation), and the Block Attribute Register.
6. Begin operation for another function on the SDIO card.

26.6.3.3.2 Resume

To resume the data transfer, a Resume command shall be issued:

1. To resume the suspended function, restore the context register with the saved value in step #5 of the Suspend operation above.
2. Send the Resume command. In the Transfer Type register, all bit fields are set to the value as if this were another ordinary data transfer, instead of a transfer resume (except the CMDTYP is set to 2'b10).
3. If the Resume command has responded, the data transfer will be resumed.

26.6.3.4 ADMA Usage

To use the ADMA in a data transfer, the Host Driver must prepare the correct descriptor chain prior to sending the read/write command.

The steps to prepare the correct descriptor chain are:

1. Create a descriptor to set the data length that the current descriptor group is about to transfer. The data length should be even numbers of the block size.
2. Create another descriptor to transfer the data from the address setting in this descriptor. The data address must be at a page boundary (4kB address aligned).
3. If necessary, create a Link descriptor containing the address of the next descriptor. The descriptor group is created in steps 1 ~ 3.
4. Repeat steps 1 ~ 3 until all descriptors are created.
5. In the last descriptor, set the End flag to 1 and make sure the total length of all
descriptors match the product of the block size and block number configured in the
Block Attribute Register.
6. Set the ADMA System Address Register to the address of the first descriptor and set
the DMAS field in the Protocol Control Register to 01 to select the ADMA.
7. Issue a write or read command with the DMAEN bit set to 1 in the Transfer Type
Register.

Steps 1 ~ 5 are independent of step 6, so step 6 can finish before steps 1 ~ 5. Regarding
the descriptor configuration, it is recommended not to use the Link descriptor as it
requires extra system memory access.

26.6.3.5 Transfer Error

Information about CRC, Internal DMA, Transfer ADMA, and Auto CMD12 Errors are
detailed in the sections below.

26.6.3.5.1 CRC Error

It is possible at the end of a block transfer, that a write CRC status error or read CRC
error occurs. For this type of error the latest block received shall be discarded. This is
because the integrity of the data block is not guaranteed. It is recommended to discard the
following data blocks and re-transfer the block from the corrupted one.

For a multi-block transfer, the Host Driver shall issue a CMD12 to abort the current
process and start the transfer by a new data command. In this scenario, even when the
AC12EN and BCEND bits are set, the uSDHC does not automatically send a CMD12
because the last block is not transferred. On the other hand, if it is within the last block
that the CRC error occurs, an Auto CMD12 will be sent by the uSDHC. In this case, the
Driver shall re-send or re-obtain the last block with a single block transfer.

26.6.3.5.2 Internal DMA Error

During the data transfer with internal Simple DMA, if the DMA engine encounters some
error on the AHB bus, the DMA operation is aborted and DMA Error interrupt is sent to
the Host System. When acknowledged by such an interrupt, the Driver shall calculate the
start address of data block in which the error occurs.

The start address can be calculated by either:

1. Reading the DMA System Address register. The error occurs during the previous
   burst. Taking the block size, the previous burst length and the start address of the
next burst transfer into account, it is straightforward to obtain the start address of the corrupted block.

2. Reading the BLKCNT field of the Block Attribute register. By the number of blocks left, the total number to transfer, the start address of transfer, and the size of each block, the start address of corrupted block can be determined. When the BCEN bit is not set, the contents of the Block Attribute register does not change, so this method does not work.

When a DMA error occurs, it is recommended to abort the current transfer by means of a CMD12 (for multi block transfer), apply a reset for data, and re-start the transfer from the corrupted block to recover from the error.

### 26.6.3.5.3 Transfer ADMA Error

There are 3 kinds of possible ADMA errors. The AHB transfer, invalid descriptor, and data-length mismatch errors. Whenever these errors occur, the DMA transfer stops and the corresponding error status bit is set.

For acknowledging the status, the Host Driver should recover the error as shown below and re-transfer from the place of interruption.

1. AHB transfer error: Such errors may occur during data transfer or descriptor fetch. For either scenario, it is recommended to retrieve the transfer context, reset for the data part and re-transfer the block that was corrupted, or the next block if no block is corrupted.
2. Invalid descriptor error: For such errors, it is recommended to retrieve the transfer context, reset for the data part and re-create the descriptor chain from the invalid descriptor and issue a new transfer. As the data to transfer now may be less than the previous setting, the data length configured in the new descriptor chain should match the new value.
3. Data-length mismatch error: It is similar to recover from this error. The Host Driver polls relating registers to retrieve the transfer context, apply a reset for the data part, configure a new descriptor chain, and make another transfer if there is data left. Like the previous scenario of the invalid descriptor error, the data length must match the new transfer.

### 26.6.3.5.4 Auto CMD12 Error

After the last block of the multi block transfer is sent or received, and the AC12EN bit is set when the data transfer is initiated by the data command, the uSDHC automatically sends a CMD12 to the card to stop the transfer.
When errors with this command occur, it is recommended to the Driver to deal with the situations in the following manner:

1. Auto CMD12 response time-out. It is not certain whether the command is accepted by the card or not. The Driver should clear the Auto CMD12 error status bits and re-send the CMD12 until it is accepted by the card.
2. Auto CMD12 response CRC error. Since card responds to the CMD12, the card will abort the transfer. The Driver may ignore the error and clear the error status bit.
3. Auto CMD12 conflict error or not sent. The command is not sent, so the Driver shall send a CMD12 manually.

### 26.6.3.6 Card Interrupt

The external cards can inform the Host Controller by means of some special signals. For the SDIO card, it can be the low level on the DATA1 line during some special period. The uSDHC only monitors the DATA1 line and supports the SDIO interrupt.

When the SDIO interrupt is captured by the uSDHC, and the Host System is informed by the uSDHC asserting the uSDHC interrupt line, the interrupt service from the Host Driver is called.

As the interrupt source is controlled by the external card, the interrupt from the SDIO card must be serviced before the CINT bit is cleared by written. Refer to Card Interrupt Handling for the card interrupt handling flow.

### 26.6.4 Switch Function

A switch command shall be issued by the Host Driver to enable new features added to the SD/MMC spec. SD/MMC cards can transfer data at bus widths other than 1-bit. Different speed mode are also defined. To enable these features, a switch command shall be issued by the Host Driver.

For SDIO cards, the high speed mode/DDR50/SDR50/SDR104 are enabled by writing the EHS bit in the CCCR register after the SHS bit is confirmed. For SD cards, the high speed mode/DDR50/SDR50/SDR104 are queried and enabled by a CMD6 (with the mnemonic symbol as SWITCH_FUNC). For MMC cards, the high speed mode/HS200 are queried by a CMD8 and enabled by a CMD6 (with the mnemonic symbol as SWITCH).

The SDR4-bit, SDR8-bit, DDR4-bit and DDR8-bit width of the MMC is also enabled by the SWITCH command, but with a different argument.
These new functions can also be disabled by a software reset. For SDIO cards it can be done by setting the RES bit in the CCCR register. For other cards, it can be accomplished by issuing a CMD0. This method of restoring to the normal mode is not recommended because a complete identification process is needed before the card is ready for data transfer.

For the sake of simplicity, the following pseudocode examples do not show current capability check, which is recommended in the function switch process.

### 26.6.4.1 Query, Enable and Disable SDIO High Speed Mode

```
enable_sdio_high_speed_mode(void)
{
    send CMD52 to query bit SHS at address 0x13;
    if (SHS bit is '0') report the SDIO card does not support high speed mode and return;
    send CMD52 to set bit EHS at address 0x13 and read after write to confirm EHS bit is set;
    change clock divisor value or configure the system clock feeding into uSDHC to generate the card_clk of around 50MHz;
    (data transactions like normal peers)
}
disable_sdio_high_speed_mode(void)
{
    send CMD52 to clear bit EHS at address 0x13 and read after write to confirm EHS bit is cleared;
    change clock divisor value or configure the system clock feeding into uSDHC to generate the card_clk of the desired value below 25MHz;
    (data transactions like normal peers)
}
```

### 26.6.4.2 Query, Enable and Disable SD High Speed Mode/SDR50/SDF104/DDR50

```
enable_sd_speed_mode(void)
{
    set BLKCNT field to 1 (block), set BLKSIZE field to 64 (bytes);
    send CMD6, with argument 0xFFFFFx and read 64 bytes of data accompanying the R1 response;
    (high speed mode,x=1; SDR50,x=2; SDR104,x=3; DDR50,x=4;)
    wait data transfer done bit is set;
    check if the bit x of received 512 bits is set;
    if (bit 401 is '0') report the SD card does not support high speed mode and return;
    if (bit 402 is '0') report the SD card does not support SDR50 mode and return;
    if (bit 403 is '0') report the SD card does not support SDR104 mode and return;
    if (bit 404 is '0') report the SD card does not support DDR50 mode and return;
    send CMD6, with argument 0x80FFFFFx and read 64 bytes of data accompanying the R1 response;
    (high speed mode,x=1; SDR50,x=2; SDR104 x=3; DDR50 x=4;)
    check if the bit field 379~376 is 0xF;
    if (the bit field is 0xF) report the function switch failed and return;
    change clock divisor value or configure the system clock feeding into uSDHC to generate the card_clk of around 50MHz for high speed mode, 100Mhz for SDR50, 200Mhz for SDR104, 50Mhz for DDR50;
    (data transactions like normal peers)
}
disable_sd_speed_mode(void)
{
    set BLKCNT field to 1 (block), set BLKSIZE field to 64 (bytes);
    send CMD6, with argument 0x80FFFFF0 and read 64 bytes of data accompanying the R1 response;
    check if the bit field 379~376 is 0xF;
```
if (the bit field is 0xF) report the function switch failed and return;
change clock divisor value or configure the system clock feeding into uSDHC to generate the
card_clk of the desired value below 25MHz;
(data transactions like normal peers)

26.6.4.3 Query, Enable and Disable MMC High Speed Mode

enable_mmc_high_speed_mode(void)
{
    send CMD9 to get CSD value of MMC;
    check if the value of SPEC_VER field is 4 or above;
    if (SPEC_VER value is less than 4) report the MMC does not support high speed mode and
    return;
    set BLKCNT field to 1 (block), set BLKSIZE field to 512 (bytes);
    send CMD8 to get EXT_CSD value of MMC;
    extract the value of CARD_TYPE field to check the 'high speed mode' in this MMC is 26MHz or
    52MHz;
    send CMD6 with argument 0x1B90100;
    send CMD13 to wait card ready (busy line released);
    send CMD8 to get EXT_CSD value of MMC;
    check if HS_TIMING byte (byte number 185) is 1;
    if (HS_TIMING is not 1) report MMC switching to high speed mode failed and return;
    change clock divisor value or configure the system clock feeding into uSDHC to generate the
card_clk of around 26MHz or 52MHz according to the CARD_TYPE;
    (data transactions like normal peers)
}
disable_mmc_high_speed_mode(void)
{
    send CMD6 with argument 0x2B90100;
    set BLKCNT field to 1 (block), set BLKSIZE field to 512 (bytes);
    send CMD8 to get EXT_CSD value of MMC;
    check if HS_TIMING byte (byte number 185) is 0;
    if (HS_TIMING is not 0) report the function switch failed and return;
    change clock divisor value or configure the system clock feeding into uSDHC to generate the
card_clk of the desired value below 20MHz;
    (data transactions like normal peers)
}

26.6.4.4 Set MMC Bus Width

change_mmc_bus_width(void)
{
    send CMD9 to get CSD value of MMC;
    check if the value of SPEC_VER field is 4 or above;
    if (SPEC_VER value is less than 4) report the MMC does not support multiple bit width and
    return;
    send CMD6 with argument 0x3B70x00; (8-bit(dual data rate), x=6; 4-bit(dual data rate), x=5; 8-
    bit, x=2; 4-bit, x=1; 1-bit, x=0)
    send CMD13 to wait card ready (busy line released);
    (data transactions like normal peers)
}

26.6.5 ADMA Operation

Code for ADMA1 Operation and ADMA2 Operation can be found here.
26.6.5.1 ADMA1 Operation

Set_adma1_descriptor
{
    if (to start data transfer) {
        // Make sure the address is 4KB align.
        Set 'Set' type descriptor;
        {
            Set Act bits to 01;
            Set [31:12] bits data length (byte unit);
        }
        Set 'Tran' type descriptor;
        {
            Set Act bits to 10;
            Set [31:12] bits address (4KB align);
        }
    } else if (to fetch descriptor at non-continuous address) {
        Set Act bits to 11;
        Set [31:12] bits the next descriptor address (4KB aligned);
    } else { // other types of descriptor
        Set Act bits accordingly
    }
    if (this descriptor is the last one) {
        Set End bit to 1;
    }
    if (to generate interrupt for this descriptor) {
        Set Int bit to 1;
    }
    Set Valid bit to 1;
}

26.6.5.2 ADMA2 Operation

Set_adma2_descriptor
{
    if (to start data transfer) {
        // Make sure the address is a 32-bit boundary (lower 2-bit are always '00').
        Set higher 32-bit of descriptor for this data transfer initial address;
        Set [31:16] bits data length (byte unit);
        Set Act bits to '10';
    } else if (to fetch descriptor at non-continuous address) {
        Set Act bits to '11';
        // Make sure the address is 32-bit boundary (lower 2-bit are always set to '00').
        Set higher 32-bit of descriptor for the next descriptor address;
    } else { // other types of descriptor
        Set Act bits accordingly
    }
    if (this descriptor is the last one) {
        Set 'End' bit '1';
    }
    if (to generate interrupt for this descriptor) {
        Set 'Int' bit '1';
    }
    Set the 'Valid' bit to '1';
}
26.6.6 Fast Boot Operation

26.6.6.1 Normal fast boot flow
1. Software must configure init_active bit (system control register bit 27) to make sure 74 card clocks are finished.
2. Software must configure the MMC Boot Register (offset 0xc4) bit 6 to 1 (enable boot), and bit 5 to 0 (normal fast boot), and bit 4 to select the ack mode or not. If the data will be sent through DMA mode, the software should configure bit 7 to enable the automatic stop at block gap feature, and configure bit 3-bit 0 to select the ack timeout value according to the SD CLK frequency.
3. Software then needs to configure the Block Attributes Register to set the block size and count. If in DDR fast boot mode, the block size only can be configured to 512 bytes.
4. Software must configure the Protocol control register to set DTW (data transfer width). If in DDR fast boot mode, DTW only can be configured to 4-bit/8-bit dataline mode.
5. Software needs to configure the Command Argument Register to set argument if needed (no need in normal fast boot).
6. Software must configure the Transfer Type Register to start the boot process. In normal boot mode, CMDINX, CMDTYP, RSPTYP, CICEN, CCCEN, AC12EN, BCEN and DMAEN are kept at the default value. DPSEL bit is set to 1, DTDSEL is set to 1, MSBSEL is set to 1.
7. DMAEN should be configured as 0 in polling mode. And if BCEN is configured as 1, it is recommended to configure the number of blocks in the Block Attributes Register to the maximum value. If in DDR fast boot mode, DDR_EN needs to be set to 1.
8. When the step 6 is configured, the boot process will begin. Software needs to poll the data buffer ready status to read the data from the buffer in time. If a boot timeout happens (ack times out or the first data read times out), an interrupt will be triggered, and software must configure MMC Boot Register to bit 6 to 0 to disable boot. This makes CMD high, then after at least 56 clocks, it is ready to begin a normal initialization process.
9. If there is no timeout, software needs to determine when the data read is finished and then configure MMC Boot Register bit 6 to 0 to disable boot. This will make CMD line high and command completed asserted. After at least 56 clocks, it is ready to begin normal initialization process.
10. Reset the host and then can begin the normal process.
26.6.6.2 Alternative fast boot flow

1. Software needs to configure init_active bit (system control register bit 27) to make sure 74 card clocks are finished.
2. Software needs to configure MMC Boot Register (offset 0xc4) bit 6 to 1 (enable boot), and bit 5 to 1 (alternative boot), and bit 4 to select the ack mode or not. If data needs to be sent through DMA mode, then configure bit 7 to enable the automatic stop at block gap feature. Software should also configure bit 3-bit 0 to select the ack timeout value according to the SD clock frequency.
3. Software then needs to configure Block Attributes Register to set the block size and count. If in DDR fast boot mode, the block size only can be configured to 512 bytes.
4. Software needs to configure the Protocol control register to set the DTW (data transfer width). If in ddr fast boot mode, DTW only can be configure to 4-bit/8-bit dataline mode.
5. Software needs to configure Command Argument Register to set argument to 0xFFFFFFF.
6. Software needs to configure the Transfer Type Register to start the boot process by CMD0 with 0xFFFFFFF argument. In alternative boot, CMDINX, CMDTYP, RSPTYP, CICEN, CCCEN, AC12EN, BCEN and DMAEN are kept default value. DPSEL bit is set to 1, DTDSEL is set to 1, MSBSEL is set to 1. Note DMAEN should be configured as 0 in polling mode. And if BCEN is configured as 1 in polling mode, it is recommended to configure the block count in the Block Attributes Register to the maximum value. If in DDR fast boot mode, DDR_EN needs to be set to 1.
7. When the step 6 is configured, the boot process will begin. Software needs to poll the data buffer ready status to read the data from the buffer in time. If there is a boot timeout (ack data timeout in 50ms or data timeout in 1s), the host will send out the interrupt and software needs to send CMD0 with reset and then configure the boot enable bit to 0 to stop this process.
8. If there is no time out, software needs to decide when to stop the boot process, and send out the CMD0 with reset and then after the command is completed, configure the MMC Boot Register bit 6 to stop the process. After 8 clocks from the command completion, the slave (card) is ready for the identification step.
9. Reset the host and then begin the normal process.

26.6.6.3 Fast boot application case (in DMA mode)

In the boot application case, because the image destination and the image size are contained in the beginning of the image, it is necessary to switch DMA parameters on the fly during MMC fast boot.
In fast boot, the host can use ADMA2 (Advanced DMA2) with two destinations.

The detail flow is described below:

1. Software needs to configure INIT_ACTIVE bit (system control register bit 27) to make sure 74 card clocks are finished.
2. Software needs to configure the MMC Boot Register (offset 0xc4) bit 6 to 1 (enable boot); and bit 5 to 0 (normal fast boot) or 1 (alternative boot); and bit 4 to select the ack mode or not. In DMA mode, configure bit 7 to 1 to enable the automatic stop at block gap feature. Also configure bits[31-16] to set the (BLK_CNT - VALUE1). Here VALUE1 is the value of the block count that needs to transfer the first time, so that the host will stop at the block gap when the uSDHC controller gets VAULE1 blocks from the device. Also configure bits[3-0] to select the ack timeout value according to the SD clock frequency.
3. Software then needs to configure the Block Attributes Register to set block size and count. If in DDR fast boot mode, the block size only can be configured to 512 bytes. In DMA mode, it is recommended to set the block count (BLK_CNT) to the max value (16'hffff). Software needs to configure Protocol Control Register to set DTW (data transfer width). If in DDR fast boot mode, the DTW only can be configured to 4-bit/8-bit dataline mode.
4. Software enable ADMA2 by configuring Protocol Control Register bits [9-8].
5. Software need to set at least three pairs ADMA2 descriptor in boot memory (ie, in IRAM, at least 6 word). The first pair descriptor define the start address (ie, IRAM) and data length (ie, 512 byte * VALUE1) of fisrt part boot code. Software also need to set the second pair descriptor, the second start address (any value that is writeable), data length is suggest to set 1~2word(record as VALUE2). Note: the second couple desc also transfer useful data even at lease 1 word. Because our ADMA2 can't support 0 data_length data transfer descriptor.
6. Software needs to configure Command Argument Register to set argument to 0xFFFFFFFF in alternative fast boot, and don't need set in normal fast boot.
7. Software needs to configure Transfer Type Register to start the boot process. CMDINX, CMDTYP, RSPTYP, CICEN, CCCEN, AC12EN, BCEN and DMAEN are kept default value. DPSEL bit is set to 1, DTDSEL is set to 1, MSBSEL is set to 1. DMAEN is configured as 1 in DMA mode. And if BCEN is configured as 1, better to configure blk no in Bock Attributes Register to the max value. And if in ddr fast boot mode, DDR_EN need to be set to 1.
8. When the step 8 is configured, boot process will begin, the first VALUE1 block number data has transfer. Software need to polling TC bit (bit1 in Interrupt Status Register) to determine first transfer is end. Also software need to polling BGE bit (bit2 in Interrupt Status Register) to determine if first transfer stop at block gap.
10. When TC, BGE bit is 1, SW can analyzes the first code of VALUE1 block, initializes the new memory device, if required, and sets the third pair of descriptors to define the start address and length of the remaining part of boot code (VALUE3 the remain boot code block). Remember set the last descriptor with END.

11. Software needs to configure MMC Boot Register (offset 0xc4) again. Set bit 6 to 1 (enable boot); and bit 5 to 0 (normal fast boot), to 1 (alternative boot); and bit 4 to select the ack mode or not. In DMA mode, configure bit 7 to 1 for enable automatically stop at block gap feature. Also configure bit31-bit16 to set the \((BLK_CNT - (VALUE1+1+VALUE3))\), that host will stop at block gap when the uSDHC controller gets \((VALUE1+1+VALUE3)) blocks from device totally include the blocks received in step 9. And need to configure bit 3-bit0 to select the ack timeout value according to the sd clk frequency. Please note, Software doesn't need to configure the \(BLK_CNT\) again, because it's counted down automatically by the uSDHC controller.

12. Software needs to clear TC and BGE bit. And software needs to clear SABGREQ(bit 16 in Protocol control register), and set CREQ(bit17 Protocol control register) to 1 to resume the data transfer. Host will transfer the VALUE2 and VALUE3 data to the destination that is set by descriptor.

13. Software need to polling BGE bit to determine if the fast boot is over.

Note:

1. When ADMA boot flow is started, for uSDHC, it is like a normal ADMA read operation. So setting ADMA2 descriptor as the normal ADMA2 transfer.
2. Need a few words length memory to keep descriptor.
3. For the 1~2 word data in second descriptor setting, it is the useful data, so software need to deal the data due to the application case.

26.7 Commands for MMC/SD/SDIO

A table containing the list of commands for the MMC/SD/SDIO cards can be found here. Refer to the corresponding specifications for more details about the command information.

There are four kinds of commands defined to control the MultiMediaCard:

1. broadcast commands (bc), no response.
2. broadcast commands with response (bcr), response from all cards simultaneously.
3. addressed (point-to-point) commands (ac), no data transfer on the DATA.
4. addressed (point-to-point) data transfer commands (adtc).
Response: a response is a token which is sent from the card to the host as an answer to a previously received command. A response is transferred serially on the CMD line.

Table 26-4. Commands for MMC/SD/SDIO Cards

<table>
<thead>
<tr>
<th>CMD INDEX</th>
<th>Type</th>
<th>Argument</th>
<th>Response type</th>
<th>Abbreviation</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD0</td>
<td>bc</td>
<td>[31:0] stuff bits</td>
<td>-</td>
<td>GO_IDLE_STATE</td>
<td>Resets all MMC and SD memory cards to idle state.</td>
</tr>
<tr>
<td>CMD1</td>
<td>bcr</td>
<td>[31:0] OCR without busy</td>
<td>R3</td>
<td>SEND_OP_COND</td>
<td>Asks all MMC and SD Memory cards in idle state to send their operation conditions register contents in the response on the CMD line.</td>
</tr>
<tr>
<td>CMD2</td>
<td>bcr</td>
<td>[31:0] stuff bits</td>
<td>R2</td>
<td>ALL_SEND_CID</td>
<td>Asks all cards to send their CID numbers on the CMD line.</td>
</tr>
<tr>
<td>CMD3</td>
<td>ac</td>
<td>[31:6] RCA [15:0] stuff bits</td>
<td>R1</td>
<td>SET_SEND_RELATIVE_AD_R</td>
<td>Assigns relative address to the card.</td>
</tr>
<tr>
<td>CMD4</td>
<td>bc</td>
<td>[31:0] DSR [15:0] stuff bits</td>
<td>-</td>
<td>SET_DSR</td>
<td>Programs the DSR of all cards.</td>
</tr>
<tr>
<td>CMD5</td>
<td>bc</td>
<td>[31:0] OCR without busy</td>
<td>R4</td>
<td>IO_SEND_OP_COND</td>
<td>Asks all SDIO cards in idle state to send their operation conditions register contents in the response on the CMD line.</td>
</tr>
<tr>
<td>CMD6^2</td>
<td>adtc</td>
<td>[31] Mode [30:8] Reserved for function groups 6 ~ 3 (All 0 or 0xFFFF) [7:4] Function group1 for command system [3:0] Function group2 for access mode</td>
<td>R1</td>
<td>SWITCH_FUNC</td>
<td>Checks switch ability (mode 0) and switch card function (mode 1). Refer to &quot;SD Physical Specification V1.1&quot; for more details.</td>
</tr>
<tr>
<td>CMD7</td>
<td>ac</td>
<td>[31:6] RCA [15:0] stuff bits</td>
<td>R1b</td>
<td>SELECT_DESELECT_CARD</td>
<td>Toggles a card between the standby and transfer states or between the programming and disconnect states. In both cases, the card is selected by its own relative address and gets deselected by any other address. Address 0 deselects all.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 26-4. Commands for MMC/SD/SDIO Cards (continued)

<table>
<thead>
<tr>
<th>CMD INDEX</th>
<th>Type</th>
<th>Argument</th>
<th>Response type</th>
<th>Abbreviation</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD8</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1</td>
<td>SEND_EXT_CSD</td>
<td>The card sends its EXT_CSD register as a block of data, with a block size of 512 bytes.</td>
</tr>
<tr>
<td>CMD11</td>
<td>adtc</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>READ_DAT_UNTIL_STOP</td>
<td>Reads data stream from the card, starting at the given address, until a STOP_TRANSMISSION follows.</td>
</tr>
<tr>
<td>CMD12</td>
<td>ac</td>
<td>[31:0] stuff bits</td>
<td>R1b</td>
<td>STOP_TRANSMISSION</td>
<td>Forces the card to stop transmission.</td>
</tr>
<tr>
<td>CMD14</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CMD15</td>
<td>ac</td>
<td>[31:6] RCA [15:0] stuff bits</td>
<td>-</td>
<td>GO_INACTIVE_STATE</td>
<td>Sets the card to inactive state in order to protect the card stack against communication breakdowns.</td>
</tr>
<tr>
<td>CMD16</td>
<td>ac</td>
<td>[31:0] block length</td>
<td>R1</td>
<td>SET_BLOCKLEN</td>
<td>Sets the block length (in bytes) for all following block commands (read and write). Default block length is specified in the CSD.</td>
</tr>
<tr>
<td>CMD17</td>
<td>adtc</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>READ_SINGLE_BLOCK</td>
<td>Reads a block of the size selected by the SET_BLOCKLEN command.</td>
</tr>
<tr>
<td>CMD18</td>
<td>adtc</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>READ_MULTIPLE_BLOCK</td>
<td>Continuously transfers data blocks from card to host until interrupted by a stop command.</td>
</tr>
<tr>
<td>CMD19</td>
<td>adtc</td>
<td>[31:0] reserved bits(all 0)</td>
<td>R1</td>
<td>SEND_TUNING_BLOCK</td>
<td>64 bytes tuning pattern is sent for SDR50 and SDR104.</td>
</tr>
<tr>
<td>CMD20</td>
<td>adtc</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>WRITE_DAT_UNTIL_STOP</td>
<td>Writes data stream from the host, starting at the given address, until a STOP_TRANSMISSION follows.</td>
</tr>
<tr>
<td>CMD21</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1</td>
<td>SEND_TUNING_BLOCK</td>
<td>128 clocks of tuning pattern (64 byte in 4 bit mode or 128 byte in 8 bit mode) is sent for HS200 optimal sampling point detection.</td>
</tr>
<tr>
<td>CMD22-23</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CMD24</td>
<td>adtc</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>WRITE_BLOCK</td>
<td>Writes a block of the size selected by the SET_BLOCKLEN command.</td>
</tr>
<tr>
<td>CMD25</td>
<td>adtc</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>WRITE_MULTIPLE_BLOCK</td>
<td>Continuously writes blocks of data until a STOP_TRANSMISSION follows.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>CMD INDEX</th>
<th>Type</th>
<th>Argument</th>
<th>Response type</th>
<th>Abbreviation</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD26</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1</td>
<td>PROGRAM_CID</td>
<td>Programming of the card identification register. This command shall be issued only once per card. The card contains hardware to prevent this operation after the first programming. Normally this command is reserved for the manufacturer.</td>
</tr>
<tr>
<td>CMD27</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1</td>
<td>PROGRAM_CSD</td>
<td>Programming of the programmable bits of the CSD.</td>
</tr>
<tr>
<td>CMD28</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1b</td>
<td>SET_WRITE_PROT</td>
<td>If the card has write protection features, this command sets the write protection bit of the addressed group. The properties of write protection are coded in the card specific data (WP_GRP_SIZE).</td>
</tr>
<tr>
<td>CMD29</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1b</td>
<td>CLR_WRITE_PROT</td>
<td>If the card provides write protection features, this command clears the write protection bit of the addressed group.</td>
</tr>
<tr>
<td>CMD30</td>
<td>adtc</td>
<td>[31:0] write protect data address</td>
<td>R1</td>
<td>SEND_WRITE_PROT</td>
<td>If the card provides write protection features, this command asks the card to send the status of the write protection bits.</td>
</tr>
<tr>
<td>CMD31</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>CMD32</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>TAG_SECTOR_STAR</td>
<td>Sets the address of the first sector of the erase group.</td>
</tr>
<tr>
<td>CMD33</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>TAG_SECTOR_END</td>
<td>Sets the address of the last sector in a continuous range within the selection of a single sector to be selected for erase.</td>
</tr>
<tr>
<td>CMD34</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>UNTAG_SECTOR</td>
<td>Removes one previously selected sector from the erase selection.</td>
</tr>
<tr>
<td>CMD35</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>TAG_ERASE_GROUP_START</td>
<td>Sets the address of the first erase group within a range to be selected for erase.</td>
</tr>
<tr>
<td>CMD36</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>TAG_ERASE_GROUP_END</td>
<td>Sets the address of the last erase group within a continuous range to be selected for erase.</td>
</tr>
<tr>
<td>CMD37</td>
<td>ac</td>
<td>[31:0] data address</td>
<td>R1</td>
<td>UNTAG_ERASE_GROUP</td>
<td>Removes one previously selected erase group from the erase selection.</td>
</tr>
<tr>
<td>CMD38</td>
<td>ac</td>
<td>[31:0] stuff bits</td>
<td>R1b</td>
<td>ERASE</td>
<td>Erase all previously selected sectors.</td>
</tr>
<tr>
<td>CMD39</td>
<td>ac</td>
<td>[31:0] RCA [15] register write flag</td>
<td>R4</td>
<td>FAST_IO</td>
<td>Used to write and read 8-bit (register) data fields. The command addresses a card, and a register, and provides the data for writing if</td>
</tr>
<tr>
<td>CMD INDEX</td>
<td>Type</td>
<td>Argument</td>
<td>Response type</td>
<td>Abbreviation</td>
<td>Description</td>
</tr>
<tr>
<td>-----------</td>
<td>------</td>
<td>----------</td>
<td>---------------</td>
<td>--------------</td>
<td>-------------</td>
</tr>
<tr>
<td>CMD40</td>
<td>bcr</td>
<td>[31:0] stuff bits</td>
<td>R5</td>
<td>GO_IRQ_STATE</td>
<td>Sets the system into interrupt mode.</td>
</tr>
<tr>
<td>CMD41</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>CDM42</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1b</td>
<td>LOCK_UNLOCK</td>
<td>Used to set/reset the password or lock/unlock the card. The size of the data block is set by the SET_BLOCK_LEN command.</td>
</tr>
<tr>
<td>CMD43-51</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>CMD52</td>
<td>ac</td>
<td>[31:0] stuff bits</td>
<td>R5</td>
<td>IO_RW_DIRECT</td>
<td>Access a single register within the total 128k of register space in any I/O function.</td>
</tr>
<tr>
<td>CMD53</td>
<td>ac</td>
<td>[31:0] stuff bits</td>
<td>R5</td>
<td>IO_RW_EXTENDED</td>
<td>Accesses a multiple I/O register with a single command. Allows the reading or writing of a large number of I/O registers.</td>
</tr>
<tr>
<td>CMD54</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>CMD55</td>
<td>ac</td>
<td>[31:16] RCA [15:0] stuff bits</td>
<td>R1</td>
<td>APP_CMD</td>
<td>Indicates to the card that the next command is an application specific command rather that a standard command.</td>
</tr>
<tr>
<td>CMD56</td>
<td>adtc</td>
<td>[31:1] stuff bits [0]: RD/WR</td>
<td>R1b</td>
<td>GEN_CMD</td>
<td>Used either to transfer a data block to the card or to get a data block from the card for general purpose / application specific commands. The size of the data block is set by the SET_BLOCK_LEN command.</td>
</tr>
<tr>
<td>CMD57-59</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>CMD60</td>
<td>adtc</td>
<td>[31] WR [30:24] stuff bits [23:16] address [15:8] stuff bits [7:0] byte count</td>
<td>R1b</td>
<td>RW_MULTIPLE_REGISTER</td>
<td>These registers are used to control the behavior of the device and to retrieve status information regarding the operation of the device. All Status and Control registers are WORD (32-bit) in size and are WORD aligned. CMD60 shall be used to read and write these registers.</td>
</tr>
<tr>
<td>CMD61</td>
<td>adtc</td>
<td>[31] WR [30:16] stuff bits [15:0] data unit count</td>
<td>R1b</td>
<td>RW_MULTIPLE_BLOCK</td>
<td>The host issues a RW_MULTIPLE_BLOCK (CMD61) to begin the data transfer.</td>
</tr>
<tr>
<td>CMD62-63</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 26-4. Commands for MMC/SD/SDIO Cards (continued)

<table>
<thead>
<tr>
<th>CMD INDEX</th>
<th>Type</th>
<th>Argument</th>
<th>Response type</th>
<th>Abbreviation</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACMD6&lt;sup&gt;4&lt;/sup&gt;</td>
<td>ac</td>
<td>[31:2] stuff bits [1:0] bus width</td>
<td>R1</td>
<td>SET_BUS_WIDTH</td>
<td>Defines the data bus width ('00'=1bit or '10'=4bit bus) to be used for data transfer. The allowed data bus widths are given in SCR register.</td>
</tr>
<tr>
<td>ACMD13&lt;sup&gt;4&lt;/sup&gt;</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1</td>
<td>SD_STATUS</td>
<td>Send the SD Memory Card status.</td>
</tr>
<tr>
<td>ACMD22&lt;sup&gt;4&lt;/sup&gt;</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1</td>
<td>SEND_NUM_WR_SECTORS</td>
<td>Send the number of the written sectors (without errors). Responds with 32-bit plus the CRC data block.</td>
</tr>
<tr>
<td>ACMD23&lt;sup&gt;4&lt;/sup&gt;</td>
<td>ac</td>
<td>[31:23] stuff bits [22:0] Number of blocks</td>
<td>R1</td>
<td>SET_WR_BLK_ERASE_COUNT</td>
<td>Set the number of write blocks to be pre-erased before writing (to be used for fast Multiple Block WR command). *&quot;1&quot;=default(one write block).</td>
</tr>
<tr>
<td>ACMD41&lt;sup&gt;4&lt;/sup&gt;</td>
<td>bcr</td>
<td>[31:0] OCR</td>
<td>R3</td>
<td>SD_APP_OP_COND</td>
<td>Asks the accessed card to send its operating condition register (OCR) contents in the response on the CMD line.</td>
</tr>
<tr>
<td>ACMD42&lt;sup&gt;4&lt;/sup&gt;</td>
<td>ac</td>
<td>[31:1] stuff bits [0] set_cd</td>
<td>R1</td>
<td>SET_CLR_CARD_DETECT</td>
<td>Connect(1)/Disconnect(0) the 50KOhm pull-up resistor on CD_B/ DATA3 of the card.</td>
</tr>
<tr>
<td>ACMD51&lt;sup&gt;4&lt;/sup&gt;</td>
<td>adtc</td>
<td>[31:0] stuff bits</td>
<td>R1</td>
<td>SEND_SCR</td>
<td>Reads the SD Configuration Register (SCR).</td>
</tr>
</tbody>
</table>

1. CMD3 differs for MMC and SD cards. For MMC cards, it is referred to as SET_RELATIVE_ADDR, with a response type of R1. For SD cards, it is referred to as SEND_RELATIVE_ADDR, with a response type of R6 (with RCA inside).
2. CMD6 differs completely between high speed MMC cards and high speed SD cards. Command SWITCH_FUNC is for high speed SD cards.
3. Command SWITCH is for high speed MMC cards. The Index field can contain any value from 0-255, but only values 0-191 are valid. If the Index value is in the 192-255 range the card does not perform any modification and the SWITCH_ERROR status bit in the EXT_CSD register is set. The Access Bits are shown in Table 2.
4. ACMDs shall be preceded with the APP_CMD command. (Commands listed are used for SD only, other SD commands not listed are not supported on this module).

The Access Bits for the EXT_CSD Access Modes are shown below.

Table 26-5. EXT_CSD Access Modes

<table>
<thead>
<tr>
<th>Bits</th>
<th>Access Name</th>
<th>Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Command Set</td>
<td>The command set is changed according to the Cmd Set field of the argument</td>
</tr>
<tr>
<td>01</td>
<td>Set Bits</td>
<td>The bits in the pointed byte are set, according to the 1 bits in the Value field.</td>
</tr>
<tr>
<td>10</td>
<td>Clear Bits</td>
<td>The bits in the pointed byte are cleared, according to the 1 bits in the Value field.</td>
</tr>
<tr>
<td>11</td>
<td>Write Byte</td>
<td>The Value field is written into the pointed byte.</td>
</tr>
</tbody>
</table>
26.8 Software Restrictions

26.8.1 Initialization Active
The driver cannot set INITA bit in System Control register when any of the command line or data lines is active, so the driver must ensure both CDIHB and CIHB bits are cleared.

26.8.2 Software Polling Procedure
For polling read or write, once the software begins a buffer read or write, it must access exactly the number of times as the values set in the Watermark Level Register; moreover, if the block size is not a multiple of the value in Watermark Level Register (read and write respectively), the software must access exactly the remaining number of words at the end of each block.

For example, for a read operation, if the RD_WML is 4, indicating the watermark level is 16 bytes, block size is 40 bytes, and the block number is 2, then the access times for the burst sequence in the whole transfer process must be 4, 4, 2, 4, 4, 2.

26.8.3 Suspend Operation
In order to suspend the data transfer, the software must inform uSDHC that the suspend command is successfully accepted. To achieve this, after the Suspend command is accepted by the SDIO card, software must send another normal command marked as suspend command (CMDTYP bits set as '01') to inform uSDHC that the transfer is suspended.

If software needs to resume the suspended trasnfer, it should read the value in BLKCNT register to save the remaining number of blocks before sending the normal command marked as suspend, otherwise on sending such 'suspend' command, uSDHC will regard the current transfer is aborted and change BLKCNT register to its original value, instead of keeping the remained number of blocks.
26.8.4  Data Length Setting

For either ADMA (ADMA1 or ADMA2) transfer, the data in the data buffer must be word aligned, so the data length set in the descriptor must be a multiple of 4.

26.8.5  (A)DMA Address Setting

To configure ADMA1/ADMA2/DMA address register, when TC bit is set, the register will always update itself with the internal address value to support dynamic address synchronization, so the software must ensure that the TC bit is cleared prior to configuring ADMA1/ADMA2/DMA address register.

26.8.6  Data Port Access

Data Port does not support parallel access. For example, during an internal DMA access, it is not allowed to write any data to the Data Port by CPU; or during a CPU read operation, it is also prohibited to write any data to the Data Port, by either CPU or internal DMA. Otherwise the data would be corrupted inside the uSDHC buffer.

26.8.7  Change Clock Frequency

uSDHC does not automatically gate off the card clock when the Host Driver changes the clock frequency. To prevent possible glitch on the card clock, clear the FRC_SDCLK_ON bit when changing clock divisor value(SDCLKFS or DVS in System Control Register) or setting RSTA bit.

Also before changing the clock divisor value, Host Driver should make sure the SDSTB bit is high.

26.8.8  Multi-block Read

For pre-defined multi-block read operation, i.e., the number of blocks to read has been defined by previous CMD23 for MMC, or pre-defined number of blocks in CMD53 for SDIO/SDCombo, or whatever multi-block read without abort command at card side, an abort command, either automatic or manual CMD12/CMD52, is still required by uSDHC after the pre-defined number of blocks are done, to drive the internal state machine to idle mode.
In this case, the card may not respond to this extra abort command and uSDHC will get Response Timeout. It is recommended to manually send an abort command with RSPTYP[1:0] both bits cleared.

## 26.9 uSDHC Memory Map/Register Definition

### 26.9.1 uSDHC register descriptions

This section includes the module memory map and detailed descriptions of all registers. See the table below for the register memory map for the uSDHC. All these registers only support 32-bit accesses.

**NOTE**

The uSDHC registers are 32-bit wide and only support 32-bit access.

### 26.9.1.1 uSDHC Memory map

Base address: 402C_0000h for uSDHC1, 402C_4000h for uSDHC2.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>DMA System Address (DS_ADDR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>4h</td>
<td>Block Attributes (BLK_ATT)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8h</td>
<td>Command Argument (CMD_ARG)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>Command Transfer Type (CMD_XFR_TYP)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>Command Response0 (CMD_RSP0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Command Response1 (CMD_RSP1)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>18h</td>
<td>Command Response2 (CMD_RSP2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>Command Response3 (CMD_RSP3)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>20h</td>
<td>Data Buffer Access Port (DATA_BUFF_ACC_PORT)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>24h</td>
<td>Present State (PRES_STATE)</td>
<td>32</td>
<td>RO</td>
<td>See description.</td>
</tr>
<tr>
<td>28h</td>
<td>Protocol Control (PROT_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0880_0020h</td>
</tr>
<tr>
<td>2Ch</td>
<td>System Control (SYS_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0080_800Fh</td>
</tr>
<tr>
<td>30h</td>
<td>Interrupt Status (INT_STATUS)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>34h</td>
<td>Interrupt Status Enable (INT_STATUS_EN)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>38h</td>
<td>Interrupt Signal Enable (INT_SIGNAL_EN)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>3Ch</td>
<td>Auto CMD12 Error Status (AUTOCMD12_ERR_STATUS)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>40h</td>
<td>Host Controller Capabilities (HOST_CTRL_CAP)</td>
<td>32</td>
<td>RW</td>
<td>07F3_B407h</td>
</tr>
<tr>
<td>44h</td>
<td>Watermark Level (WTMK_LVL)</td>
<td>32</td>
<td>RW</td>
<td>0810_0810h</td>
</tr>
<tr>
<td>48h</td>
<td>Mixer Control (MIX_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>8000_0000h</td>
</tr>
<tr>
<td>50h</td>
<td>Force Event (FORCE_EVENT)</td>
<td>32</td>
<td>WORZ</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>54h</td>
<td>ADMA Error Status Register (ADMA_ERR_STATUS)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>58h</td>
<td>ADMA System Address (ADMA_SYS_ADDR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>60h</td>
<td>DLL (Delay Line) Control (DLL_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>64h</td>
<td>DLL Status (DLL_STATUS)</td>
<td>32</td>
<td>RO</td>
<td>0000_0200h</td>
</tr>
<tr>
<td>68h</td>
<td>CLK Tuning Control and Status (CLK_TUNE_CTRL_STATUS)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C0h</td>
<td>Vendor Specific Register (VEND_SPEC)</td>
<td>32</td>
<td>RW</td>
<td>2000_7809h</td>
</tr>
<tr>
<td>C4h</td>
<td>MMC Boot Register (MMC_BOOT)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C8h</td>
<td>Vendor Specific 2 Register (VEND_SPEC2)</td>
<td>32</td>
<td>RW</td>
<td>0000_1006h</td>
</tr>
<tr>
<td>CCh</td>
<td>Tuning Control Register (TUNING_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0021_2800h</td>
</tr>
</tbody>
</table>

### 26.9.1.2 DMA System Address (DS_ADDR)

#### 26.9.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DS_ADDR</td>
<td>0h</td>
</tr>
</tbody>
</table>

#### 26.9.1.2.2 Function

This register contains the physical system memory address used for DMA transfers.
26.9.1.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>DS_ADDR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>DS_ADDR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

26.9.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>DS_ADDR</td>
</tr>
<tr>
<td>DS_ADDR</td>
<td><strong>DMA System Address / Argument 2</strong></td>
</tr>
<tr>
<td></td>
<td>When ACMD23_ARGU2_EN is set to 0, SDMA uses this register as system address and supports only 32-bit addressing mode. Auto CMD23 cannot be used with SDMA. When ACMD23_ARGU2_EN is set to 1, SDMA uses ADMA System Address register (05Fh – 058h) instead of this register to support both 32-bit and 64-bit addressing. This register is used only for Argument2 and SDMA may use Auto CMD23.</td>
</tr>
</tbody>
</table>

1. **SDMA System Address**

   Since the address must be word (4 bytes) aligned, the least 2 bits are reserved, always 0. When the uSDHC stops a DMA transfer, this register points out the system address of the next contiguous data position. It can be accessed only when no transaction is executing (i.e. after a transaction has stopped). Read operation during transfers may return an invalid value. The Host Driver shall initialize this register before starting a DMA transaction. After DMA has stopped, the system address of the next contiguous data position can be read from this register.

   This register is protected during a data transfer. When data lines are active, write to this register is ignored. The Host driver shall wait, until the DLA bit in the Present State register is cleared, before writing to this register.

   The uSDHC internal DMA does not support a virtual memory system. It only supports continuous physical memory access. And due to AHB burst limitations, if the burst must cross the 1 KB boundary, uSDHC will automatically change SEQ burst type to NSEQ.

   Since this register supports dynamic address reflecting, when TC bit is set, it automatically alters the value of internal address counter, so SW cannot change this register when TC bit is set. Such restriction is also listed in Software Restrictions.

2. **Argument 2**

   This register is used with the Auto CMD23 to set a 32-bit block count value to the argument of the CMD23 while executing Auto CMD23.

   If Auto CMD23 is used with ADMA, the full 32-bit block count value can be used. If Auto CMD23 is used without ADMA, the available block count value is limited by the Block Count register. 65535 blocks is the maximum value in this case.
26.9.1.3 Block Attributes (BLK_ATT)

26.9.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BLK_ATT</td>
<td>4h</td>
</tr>
</tbody>
</table>

26.9.1.3.2 Function

This register is used to configure the number of data blocks and the number of bytes in each block.

26.9.1.3.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

26.9.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Block Count For Current Transfer:</td>
</tr>
<tr>
<td>BLKCNT</td>
<td>This register is enabled when the Block Count Enable bit in the Transfer Mode register is set to 1 and is valid only for multiple block transfers. For single block transfer, this register will always read as 1. The Host Driver shall set this register to a value between 1 and the maximum block count. The uSDHC decrements the block count after each block transfer and stops when the count reaches zero. Setting the block count to 0 results in no data blocks being transferred.</td>
</tr>
</tbody>
</table>

This register should be accessed only when no transaction is executing (i.e. after transactions are stopped). During data transfer, read operations on this register may return an invalid value and write operations are ignored.

When saving transfer content as a result of a Suspend command, the number of blocks yet to be transferred can be determined by reading this register. The reading of this register should be applied after transfer is paused by stop at block gap operation and before sending the command marked as suspend.

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This is because when Suspend command is sent out, uSDHC will regard the current transfer is aborted and change BLKCNT register back to its original value instead of keeping the dynamical indicator of remained block count. When restoring transfer content prior to issuing a Resume command, the Host Driver shall restore the previously saved block count. <strong>NOTE:</strong> Although the BLKCNT field is 0 after reset, the read of reset value is 0x1. This is because when MSBSEL bit is indicating a single block transfer, the read value of BLKCNT is always 1.</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>15-13</td>
<td>Reserved.</td>
</tr>
<tr>
<td>12-0</td>
<td>Block Size</td>
</tr>
<tr>
<td>BLKSIZE</td>
<td>Transfer Block Size: This register specifies the block size for block data transfers. Values ranging from 1 byte up to the maximum buffer size can be set. It can be accessed only when no transaction is executing (i.e. after a transaction has stopped). Read operations during transfers may return an invalid value, and write operations will be ignored.</td>
</tr>
<tr>
<td></td>
<td>0000000000000b - No data transfer</td>
</tr>
<tr>
<td></td>
<td>0000000000001b - 1 Byte</td>
</tr>
<tr>
<td></td>
<td>0000000000010b - 2 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000000011b - 3 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000000100b - 4 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000000101b - 5 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000000110b - 6 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000000111b - 7 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000001000b - 8 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000001001b - 9 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000001010b - 10 Bytes</td>
</tr>
<tr>
<td></td>
<td>0000000001011b - 11 Bytes</td>
</tr>
<tr>
<td></td>
<td>0100000000000b - 256 Bytes</td>
</tr>
<tr>
<td></td>
<td>1000000000000b - 4096 Bytes</td>
</tr>
</tbody>
</table>

### 26.9.1.4 Command Argument (CMD_ARG)

#### 26.9.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD_ARG</td>
<td>8h</td>
</tr>
</tbody>
</table>

#### 26.9.1.4.2 Function

This register contains the SD / MMC Command Argument.
26.9.1.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>CMDARG</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CMDARG</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CMDARG</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

26.9.1.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Command Argument</td>
</tr>
<tr>
<td>CMDARG</td>
<td>The SD / MMC Command Argument is specified as bits 39-8 of the Command Format in the SD or MMC Specification. This register is write protected when the Command Inhibit (CMD) bit in the Present State register is set.</td>
</tr>
</tbody>
</table>

26.9.1.5 Command Transfer Type (CMD_XFR_TYP)

26.9.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD_XFR_TYP</td>
<td>Ch</td>
</tr>
</tbody>
</table>

26.9.1.5.2 Function

This register is used to control the operation of data transfers. The Host Driver shall set this register before issuing a command followed by a data transfer, or before issuing a Resume command. To prevent data loss, the uSDHC prevents writing to the bits, that are involved in the data transfer of this register, when data transfer is active. These bits are DPSEL, MBSEL, DTDSEL, AC12EN, BCEN and DMAEN.
The Host Driver shall check the Command Inhibit DAT bit (CDIHB) and the Command Inhibit CMD bit (CIHB) in the Present State register before writing to this register. When the CDIHB bit in the Present State register is set, any attempt to send a command with data by writing to this register is ignored; when the CIHB bit is set, any write to this register is ignored.

On sending commands with data transfer involved, it is mandatory that the block size is non-zero. Block count must also be non-zero, or indicated as single block transfer (bit 5 of this register is '0' when written), or block count is disabled (bit 1 of this register is '0' when written), otherwise uSDHC will ignore the sending of this command and do nothing. For write command, with all above restrictions, it is also mandatory that the write protect switch is not active (WPSPL bit of Present State Register is '1'), otherwise uSDHC will also ignore the command.

If the commands with data transfer does not receive the response in 64 clock cycles, i.e., response time-out, uSDHC will regard the external device does not accept the command and abort the data transfer. In this scenario, the driver should issue the command again to re-try the transfer. It is also possible that for some reason the card responds the command but uSDHC does not receive the response, and if it is internal DMA (either simple DMA or ADMA) read operation, the external system memory is over-written by the internal DMA with data sent back from the card.

The table below shows the summary of how register settings determine the type of data transfer.

**Table 26-6. Transfer Type Register Setting for Various Transfer Types**

<table>
<thead>
<tr>
<th>Multi/Single Block Select</th>
<th>Block Count Enable</th>
<th>Block Count</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Don't Care</td>
<td>Don't Care</td>
<td>Single Transfer</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Don't Care</td>
<td>Infinite Transfer</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Positive Number</td>
<td>Multiple Transfer</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Zero</td>
<td>No Data Transfer</td>
</tr>
</tbody>
</table>

The table below shows the relationship between the Command Index Check Enable and the Command CRC Check Enable, in regards to the Response Type bits as well as the name of the response type.

**Table 26-7. Relationship Between Parameters and the Name of the Response Type**

<table>
<thead>
<tr>
<th>Response Type</th>
<th>Index Check Enable</th>
<th>CRC Check Enable</th>
<th>Name of Response Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>0</td>
<td>No Response</td>
</tr>
<tr>
<td>01</td>
<td>0</td>
<td>1</td>
<td>R2</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>R3,R4</td>
</tr>
<tr>
<td>10</td>
<td>1</td>
<td>1</td>
<td>R1,R5,R6</td>
</tr>
<tr>
<td>11</td>
<td>1</td>
<td>1</td>
<td>R1b,R5b</td>
</tr>
</tbody>
</table>
• In the SDIO specification, response type notation for R5b is not defined. R5 includes R5b in the SDIO specification. But R5b is defined in this specification to specify that the uSDHC will check the busy status after receiving a response. For example, usually CMD52 is used with R5, but the I/O abort command shall be used with R5b.
• The CRC field for R3 and R4 is expected to be all 1 bits. The CRC check shall be disabled for these response types.

### 26.9.1.5.3 Diagram

![Diagram Image]

### 26.9.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>-</td>
</tr>
<tr>
<td>29-24</td>
<td>Command Index</td>
</tr>
<tr>
<td>CMDINX</td>
<td>These bits shall be set to the command number that is specified in bits 45-40 of the Command-Format in the SD Memory Card Physical Layer Specification and SDIO Card Specification.</td>
</tr>
<tr>
<td>23-22</td>
<td>Command Type</td>
</tr>
<tr>
<td>CMDTYP</td>
<td>There are three types of special commands: Suspend, Resume and Abort. These bits shall be set to 00b for all other commands.</td>
</tr>
<tr>
<td></td>
<td>• Suspend Command: If the Suspend command succeeds, the uSDHC shall assume that the card bus has been released and that it is possible to issue the next command which uses the DATA line. Since the uSDHC does not monitor the content of command response, it does not know if the Suspend command succeeded or not. It is the Host Driver's responsibility to check the status of the Suspend command and send another command marked as Suspend to inform the uSDHC that a Suspend command was successfully issued. Refer to Suspend Resume for more details. After the end bit of command is sent, the uSDHC de-asserts Read Wait for read transactions and stops checking busy for write transactions. In 4-bit mode, the interrupt cycle starts. If the Suspend command fails, the uSDHC will maintain its current state, and the Host Driver shall restart the transfer by setting the Continue Request bit in the Protocol Control register.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
| | • Resume Command: The Host Driver re-starts the data transfer by restoring the registers saved before sending the Suspend Command and then sends the Resume Command. The uSDHC will check for a pending busy state before starting write transfers.  
• Abort Command: If this command is set when executing a read transfer, the uSDHC will stop reads to the buffer. If this command is set when executing a write transfer, the uSDHC will stop driving the DATA line. After issuing the Abort command, the Host Driver should issue a software reset (Abort Transaction).  
00b - Normal Other commands  
01b - Suspend CMD52 for writing Bus Suspend in CCCR  
10b - Resume CMD52 for writing Function Select in CCCR  
11b - Abort CMD12, CMD52 for writing I/O Abort in CCCR
| 21 | DPSEL | Data Present Select  
This bit is set to 1 to indicate that data is present and shall be transferred using the DATA line. It is set to 0 for the following:  
• Commands using only the CMD line (e.g. CMD52).  
• Commands with no data transfer, but using the busy signal on DATA0 line (R1b or R5b e.g. CMD38)  
**NOTE:** In resume command, this bit shall be set, and other bits in this register shall be set the same as when the transfer was initially launched. When the Write Protect switch is on, (i.e. the WPSPL bit is active as ‘0’), any command with a write operation will be ignored. That is to say, when this bit is set, while the DTDSEL bit is 0, writes to the register Transfer Type are ignored.  
0b - No Data Present  
1b - Data Present
| 20 | CICEN | Command Index Check Enable  
If this bit is set to 1, the uSDHC will check the Index field in the response to see if it has the same value as the command index. If it is not, it is reported as a Command Index Error. If this bit is set to 0, the Index field is not checked.  
0b - Disable  
1b - Enable
| 19 | CCCEN | Command CRC Check Enable  
If this bit is set to 1, the uSDHC shall check the CRC field in the response. If an error is detected, it is reported as a Command CRC Error. If this bit is set to 0, the CRC field is not checked. The number of bits checked by the CRC field value changes according to the length of the response. (Refer to RSPTYP[1:0] and Command Transfer Type (CMD_XFR_TYP).)  
0b - Disable  
1b - Enable
| 18 | — | Reserved
| 17-16 | RSPTYP | Response Type Select  
00b - No Response  
01b - Response Length 136  
10b - Response Length 48  
11b - Response Length 48, check Busy after response
| 15-0 | — | Reserved
26.9.1.6  Command Response0 (CMD_RSP0)

26.9.1.6.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD_RSP0</td>
<td>10h</td>
</tr>
</tbody>
</table>

26.9.1.6.2  Function

This register is used to store part 0 of the response bits from the card.

26.9.1.6.3  Diagram

```
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| R    |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W    |     |     |     |     |     |     |     |     | CMDRSP0 |     |     |     |     |     |     |
| Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| R    |     |     |     |     |     |     |     | CMDRSP0 |     |     |     |     |     |     |     |
| W    |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
```

26.9.1.6.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Command Response 0</td>
</tr>
<tr>
<td>CMDRSP0</td>
<td>Refer to Command Response3 (CMD_RSP3) for the mapping of command responses from the SD Bus to this register for each response type.</td>
</tr>
</tbody>
</table>

26.9.1.7  Command Response1 (CMD_RSP1)

26.9.1.7.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD_RSP1</td>
<td>14h</td>
</tr>
</tbody>
</table>
26.9.1.7.2  Function

This register is used to store part 1 of the response bits from the card.

26.9.1.7.3  Diagram

![Diagram of register](image)

26.9.1.7.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Command Response 1</td>
</tr>
<tr>
<td>CMDRSP1</td>
<td>Refer to Command Response3 (CMD_RSP3) for the mapping of command responses from the SD Bus to this register for each response type.</td>
</tr>
</tbody>
</table>

26.9.1.8  Command Response2 (CMD_RSP2)

26.9.1.8.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD_RSP2</td>
<td>18h</td>
</tr>
</tbody>
</table>

26.9.1.8.2  Function

This register is used to store part 2 of the response bits from the card.
26.9.1.8.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CMDRSP2</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CMDRSP2</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

26.9.1.8.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Command Response 2</td>
</tr>
<tr>
<td>CMDRSP2</td>
<td>Refer to Command Response3 (CMD_RSP3) for the mapping of command responses from the SD Bus to this register for each response type.</td>
</tr>
</tbody>
</table>

26.9.1.9  Command Response3 (CMD_RSP3)

26.9.1.9.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD_RSP3</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

26.9.1.9.2  Function

This register is used to store part 3 of the response bits from the card.

The table below describes the mapping of command responses from the SD Bus to Command Response registers for each response type. In the table, R[ ] refers to a bit range within the response data as transmitted on the SD Bus.

### Table 26-8. Response Bit Definition for Each Response Type

<table>
<thead>
<tr>
<th>Response Type</th>
<th>Meaning of Response</th>
<th>Response Field</th>
<th>Response Register</th>
</tr>
</thead>
<tbody>
<tr>
<td>R1,R1b (normal response)</td>
<td>Card Status</td>
<td>R[39:8]</td>
<td>CMDRSP0</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 26-8. Response Bit Definition for Each Response Type (continued)

<table>
<thead>
<tr>
<th>Response Type</th>
<th>Meaning of Response</th>
<th>Response Field</th>
<th>Response Register</th>
</tr>
</thead>
<tbody>
<tr>
<td>R2 (CID, CSD register)</td>
<td>CID/CSD register [127:8]</td>
<td>R[127:8]</td>
<td>{CMDRSP3[23:0], CMDRSP2, CMDRSP1, CMDRSP0}</td>
</tr>
<tr>
<td>R3 (OCR register)</td>
<td>OCR register for memory</td>
<td>R[39:8]</td>
<td>CMDRSP0</td>
</tr>
<tr>
<td>R4 (OCR register)</td>
<td>OCR register for I/O etc.</td>
<td>R[39:8]</td>
<td>CMDRSP0</td>
</tr>
<tr>
<td>R5, R5b</td>
<td>SDIO response</td>
<td>R[39:8]</td>
<td>CMDRSP0</td>
</tr>
<tr>
<td>R6 (Publish RCA)</td>
<td>New Published RCA[31:16] and card status[15:0]</td>
<td>R[39:9]</td>
<td>CMDRSP0</td>
</tr>
</tbody>
</table>

This table shows that most responses with a length of 48 (R[47:0]) have 32-bits of the response data (R[39:8]) stored in the CMDRSP0 register. Responses of type R1b (Auto CMD12 responses) have response data bits (R[39:8]) stored in the CMDRSP3 register. Responses with length 136 (R[135:0]) have 120-bits of the response data (R[127:8]) stored in the CMDRSP0, 1, 2, and 3 registers.

To be able to read the response status efficiently, the uSDHC only stores part of the response data in the Command Response registers. This enables the Host Driver to efficiently read 32-bits of response data in one read cycle on a 32-bit bus system. Parts of the response, the Index field and the CRC, are checked by the uSDHC (as specified by the Command Index Check Enable and the Command CRC Check Enable bits in the Transfer Type register) and generate an error interrupt if any error is detected. The bit range for the CRC check depends on the response length. If the response length is 48, the uSDHC will check R[47:1], and if the response length is 136 the uSDHC will check R[119:1].

Since the uSDHC may have a multiple block data transfer executing concurrently with a CMD_wo_DAT command, the uSDHC stores the Auto CMD12 response in the CMDRSP3 register. The CMD_wo_DAT response is stored in CMDRSP0. This allows the uSDHC to avoid overwriting the Auto CMD12 response with the CMD_wo_DAT and vice versa. When the uSDHC modifies part of the Command Response registers, as shown in the table above, it preserves the unmodified bits.
26.9.1.9.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CMDRSP3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

26.9.1.9.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Command Response 3</td>
</tr>
<tr>
<td>CMDRSP3</td>
<td>Refer to Command Response3 (CMD_RSP3) for the mapping of command responses from the SD Bus to this register for each response type.</td>
</tr>
</tbody>
</table>

26.9.1.10  Data Buffer Access Port (DATA_BUFF_ACC_PORT)

26.9.1.10.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATA_BUFF_ACC_PORT</td>
<td>20h</td>
</tr>
</tbody>
</table>

26.9.1.10.2  Function

This is a 32-bit data port register used to access the internal buffer.
### 26.9.1.10.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 26.9.1.10.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Data Content</td>
</tr>
<tr>
<td>DATCONT</td>
<td>The Buffer Data Port register is for 32-bit data access by the ARM platform. When the internal DMA is enabled, any write to this register is ignored, and any read from this register will always yield 0s.</td>
</tr>
</tbody>
</table>

### 26.9.1.11 Present State (PRES_STATE)

#### 26.9.1.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PRES_STATE</td>
<td>24h</td>
</tr>
</tbody>
</table>

#### 26.9.1.11.2 Function

The Host Driver can get status of the uSDHC from this 32-bit read only register.

- The Host Driver can issue CMD0, CMD12, CMD13 (for memory) and CMD52 (for SDIO) when the DATA lines are busy during a data transfer. These commands can be issued when Command Inhibit (CMD) is set to zero. Other commands shall be issued when Command Inhibit (DATA) is set to zero. Possible changes to the SD Physical Specification may add other commands to this list in the future.
- Note: the reset value of Present State Register depend on board connectivity.
26.9.1.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>DATA[7:0] Line Signal Level</td>
</tr>
<tr>
<td>DLS</td>
<td>This status is used to check the DATA line level to recover from errors, and for debugging. This is especially useful in detecting the busy signal level from DATA0. The reset value is affected by the external pull-up / pull-down resistors. By default, the read value of this bit field after reset is 8'b11110111, when DATA3 is pulled down and the other lines are pulled up.</td>
</tr>
<tr>
<td></td>
<td>00000000b - Data 0 line signal level</td>
</tr>
<tr>
<td></td>
<td>00000001b - Data 1 line signal level</td>
</tr>
<tr>
<td></td>
<td>00000010b - Data 2 line signal level</td>
</tr>
<tr>
<td></td>
<td>00000011b - Data 3 line signal level</td>
</tr>
<tr>
<td></td>
<td>00000100b - Data 4 line signal level</td>
</tr>
<tr>
<td></td>
<td>00000101b - Data 5 line signal level</td>
</tr>
<tr>
<td></td>
<td>00000110b - Data 6 line signal level</td>
</tr>
<tr>
<td></td>
<td>00000111b - Data 7 line signal level</td>
</tr>
<tr>
<td>23</td>
<td>CMD Line Signal Level</td>
</tr>
<tr>
<td>CLSL</td>
<td>This status is used to check the CMD line level to recover from errors, and for debugging. The reset value is affected by the external pull-up / pull-down resistor, by default, the read value of this bit after reset is 1'b1, when the command line is pulled up.</td>
</tr>
<tr>
<td>19</td>
<td>Write Protect Switch Pin Level</td>
</tr>
<tr>
<td>WPSPL</td>
<td>The Write Protect Switch is supported for memory and combo cards. This bit reflects the inverted value of the WP pin of the card socket. A software reset does not affect this bit. The reset value is affected by the external write protect switch. If the WP pin is not used, it should be tied low, so that the reset value of this bit is high and write is enabled.</td>
</tr>
<tr>
<td></td>
<td>0b - Write protected (WP = 1)</td>
</tr>
<tr>
<td></td>
<td>1b - Write enabled (WP = 0)</td>
</tr>
<tr>
<td>18</td>
<td>Card Detect Pin Level</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>CDPL</td>
<td>This bit reflects the inverse value of the CD_B pin for the card socket. Debouncing is not performed on this bit. This bit may be valid, but is not guaranteed, because of propagation delay. Use of this bit is limited to testing since it must be debounced by software. A software reset does not affect this bit. A write to the Force Event Register does not affect this bit. The reset value is effected by the external card detection pin. This bit shows the value on the CD_B pin (i.e. when a card is inserted in the socket, it is 0 on the CD_B input, and consequently the CDPL reads 1.)</td>
</tr>
</tbody>
</table>
|       | 0b - No card present (CD_B = 1)  
|       | 1b - Card present (CD_B = 0)  |
| 17    | -  
|       | Reserved  |
| 16    | Card Inserted  
| CINST | This bit indicates whether a card has been inserted. The uSDHC debounces this signal so that the Host Driver will not need to wait for it to stabilize. Changing from a 0 to 1 generates a Card Insertion interrupt in the Interrupt Status register. Changing from a 1 to 0 generates a Card Removal interrupt in the Interrupt Status register. A write to the Force Event Register does not affect this bit. |
|       | 0b - Power on Reset or No Card  
|       | 1b - Card Inserted  |
| 15    | Tape Select Change Done  
| TSCD  | This bit indicates the dealy setting is effective after write CLK_TUNE_CTRL_STATUS register.  
|       | 0b - Delay cell select change is not finished.  
|       | 1b - Delay cell select change is finished.  |
| 14-13 | -  
|       | Reserved  |
| 12    | Re-Tuning Request (only for SD3.0 SDR104 mode and EMMC HS200 mode)  
| RTR   | Host Controller may request Host Driver to execute re-tuning sequence by setting this bit when the data window is shifted by temperature drift and a tuned sampling point does not have a good margin to receive correct data.  
|       | This bit is cleared when a command is issued with setting Execute Tuning bit in MIXER_CTRL register.  
|       | Changing of this bit from 0 to 1 generates Re-Tuning Event. Refer to Interrupt status registers for more detail.  
|       | This bit isn't set to 1 if Sampling Clock Select in the MIXER_CTRL register is set to 0 (using fixed sampling clock).  
|       | 0b - Fixed or well tuned sampling clock  
|       | 1b - Sampling clock needs re-tuning  |
| 11    | Buffer Read Enable  
| BREN  | This status bit is used for non-DMA read transfers. The uSDHC implements an internal buffer to transfer data efficiently. This read only flag indicates that valid data exists in the host side buffer. If this bit is high, valid data greater than the watermark level exist in the buffer. A change of this bit from 1 to 0 occurs when some reads from the buffer(read DATPORT (Base + 0x20)) are made and the buffer hasn't valid data greater than the watermark level. A change of this bit from 0 to1 occurs when there is enough valid data ready in the buffer and the Buffer Read Ready interrupt has been generated and enabled.  
|       | 0b - Read disable  
|       | 1b - Read enable  |
| 10    | Buffer Write Enable  

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| BWEN  | This status bit is used for non-DMA write transfers. The uSDHC implements an internal buffer to transfer data efficiently. This read only flag indicates if space is available for write data. If this bit is 1, valid data greater than the watermark level can be written to the buffer. A change of this bit from 1 to 0 occurs when some writes to the buffer(write DATPORT(Base + 0x20)) are made and the buffer hasn’t valid space greater than the watermark level. A change of this bit from 0 to 1 occurs when the buffer can hold valid data greater than the write watermark level and the Buffer Write Ready interrupt is generated and enabled.  
0b - Write disable  
1b - Write enable |
| 9     | Read Transfer Active  
This status bit is used for detecting completion of a read transfer.  
This bit is set for either of the following conditions:  
• After the end bit of the read command.  
• When writing a 1 to the Continue Request bit in the Protocol Control register to restart a read transfer.  
A Transfer Complete interrupt is generated when this bit changes to 0. This bit is cleared for either of the following conditions:  
• When the last data block as specified by block length is transferred to the System, i.e. all data are read away from uSDHC internal buffer.  
• When all valid data blocks have been transferred from uSDHC internal buffer to the System and no current block transfers are being sent as a result of the Stop At Block Gap Request being set to 1.  
0b - No valid data  
1b - Transferring data |
| 8     | Write Transfer Active  
This status bit indicates a write transfer is active. If this bit is 0, it means no valid write data exists in the uSDHC.  
This bit is set in either of the following cases:  
• After the end bit of the write command.  
• When writing 1 to the Continue Request bit in the Protocol Control register to restart a write transfer.  
This bit is cleared in either of the following cases:  
• After getting the CRC status of the last data block as specified by the transfer count (Single and Multiple).  
• After getting the CRC status of any block where data transmission is about to be stopped by a Stop At Block Gap Request.  
During a write transaction, a Block Gap Event interrupt is generated when this bit is changed to 0, as result of the Stop At Block Gap Request being set. This status is useful for the Host Driver in determining when to issue commands during Write Busy state.  
0b - No valid data  
1b - Transferring data |
| 7     | SD Clock Gated Off Internally  
This status bit indicates that the SD Clock is internally gated off, because of buffer over / under-run or read pause without read wait assertion, or the driver set FRC_SDCLK_ON bit is 0 to stop the SD clock in idle status. Set IPG_PERCLK_SOFT_EN and CARD_CLK_SOFT_EN to 0 also gate off SD clock. This bit is for the Host Driver to debug data transaction on the SD bus.  
0b - SD Clock is active.  

"Table continues on the next page..."
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>6 PEROFF</td>
<td>IPG_PERCLK Gated Off Internally</td>
</tr>
<tr>
<td></td>
<td>This status bit indicates that the IPG_PERCLK is internally gated off. This bit is for the Host Driver to debug transaction on the SD bus. When IPG_CLK_SOFT_EN is cleared, IPG_PERCLK will be gated off, otherwise IPG_PERCLK will be always active.</td>
</tr>
<tr>
<td></td>
<td>0b - IPG_PERCLK is active.</td>
</tr>
<tr>
<td></td>
<td>1b - IPG_PERCLK is gated off.</td>
</tr>
<tr>
<td>5 HCKOFF</td>
<td>HCLK Gated Off Internally</td>
</tr>
<tr>
<td></td>
<td>This status bit indicates that the HCLK is internally gated off. This bit is for the Host Driver to debug during a data transfer.</td>
</tr>
<tr>
<td></td>
<td>0b - HCLK is active.</td>
</tr>
<tr>
<td></td>
<td>1b - HCLK is gated off.</td>
</tr>
<tr>
<td>4 IPGOFF</td>
<td>IPG_CLK Gated Off Internally</td>
</tr>
<tr>
<td></td>
<td>This status bit indicates that the ipg_clk is internally gated off. This bit is for the Host Driver to debug.</td>
</tr>
<tr>
<td></td>
<td>0b - IPG_CLK is active.</td>
</tr>
<tr>
<td></td>
<td>1b - IPG_CLK is gated off.</td>
</tr>
<tr>
<td>3 SDSTB</td>
<td>SD Clock Stable</td>
</tr>
<tr>
<td></td>
<td>This status bit indicates that the internal card clock is stable. This bit is for the Host Driver to poll clock status when changing the clock frequency. It is recommended to clear FRC_SDCLK_ON bit in System Control register to remove glitches on the card clock when the frequency is changing.</td>
</tr>
<tr>
<td></td>
<td>Before changing clock divisor value(SDCLKFS or DVS), Host Driver should make sure the SDSTB bit is high.</td>
</tr>
<tr>
<td></td>
<td>0b - Clock is changing frequency and not stable.</td>
</tr>
<tr>
<td></td>
<td>1b - Clock is stable.</td>
</tr>
<tr>
<td>2 DLA</td>
<td>Data Line Active</td>
</tr>
<tr>
<td></td>
<td>This status bit indicates whether one of the DATA lines on the SD Bus is in use.</td>
</tr>
<tr>
<td></td>
<td>In the case of read transactions:</td>
</tr>
<tr>
<td></td>
<td>This status indicates if a read transfer is executing on the SD Bus. Changes in this value from 1 to 0, between data blocks, generates a Block Gap Event interrupt in the Interrupt Status register.</td>
</tr>
<tr>
<td></td>
<td>This bit will be set in either of the following cases:</td>
</tr>
<tr>
<td></td>
<td>• After the end bit of the read command.</td>
</tr>
<tr>
<td></td>
<td>• When writing a 1 to the Continue Request bit in the Protocol Control register to restart a read transfer.</td>
</tr>
<tr>
<td></td>
<td>This bit will be cleared in either of the following cases:</td>
</tr>
<tr>
<td></td>
<td>(1) When the end bit of the last data block is sent from the SD Bus to the uSDHC.</td>
</tr>
<tr>
<td></td>
<td>(2) When the Read Wait state is stopped by a Suspend command and the DATA2 line is released.</td>
</tr>
<tr>
<td></td>
<td>The uSDHC will wait at the next block gap by driving Read Wait at the start of the interrupt cycle. If the Read Wait signal is already driven (data buffer cannot receive data), the uSDHC can wait for a current block gap by continuing to drive the Read Wait signal. It is necessary to support Read Wait in order to use the suspend / resume function. This bit will remain 1 during Read Wait.</td>
</tr>
<tr>
<td></td>
<td>In the case of write transactions:</td>
</tr>
<tr>
<td></td>
<td>This status indicates that a write transfer is executing on the SD Bus. Changes in this value from 1 to 0 generate a Transfer Complete interrupt in the Interrupt Status register.</td>
</tr>
<tr>
<td></td>
<td>This bit will be set in either of the following cases:</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
|  | After the end bit of the write command. When writing to 1 to the Continue Request bit in the Protocol Control register to continue a write transfer.
|  | This bit will be cleared in either of the following cases:
|  | When the SD card releases Write Busy of the last data block, the uSDHC will also detect if the output is not busy. If the SD card does not drive the busy signal after the CRC status is received, the uSDHC shall assume the card drive "Not Busy".
|  | When the SD card releases write busy, prior to waiting for write transfer, and as a result of a Stop At Block Gap Request.
|  | In the case of command with busy pending:
|  | This status indicates that a busy state follows the command and the data line is in use. This bit will be cleared when the DATA0 line is released.
|  | NOTE: The SD Host Driver can save registers for a suspend transaction after this bit has changed from 1 to 0.
|  | Changing from 1 to 0 generates a Transfer Complete interrupt in the Interrupt Status register.
| 0 | Command Inhibit (DATA)
| CDIH B | This status bit is generated if either the DAT Line Active or the Read Transfer Active is set to 1. If this bit is 0, it indicates that the uSDHC can issue the next SD / MMC Command. Commands with a busy signal belong to Command Inhibit (DATA) (for example. R1b, R5b type). Changing from 1 to 0 generates a Transfer Complete interrupt in the Interrupt Status register.
|  | NOTE: The SD Host Driver can save registers for a suspend transaction after this bit has changed from 1 to 0.
|  | 0b - Can issue command which uses the DATA line
|  | 1b - Cannot issue command which uses the DATA line
| 0 | Command Inhibit (CMD)
| CIHB | If this status bit is 0, it indicates that the CMD line is not in use and the uSDHC can issue a SD / MMC Command using the CMD line.
|  | This bit is set also immediately after the Transfer Type register is written. This bit is cleared when the command response is received. Even if the Command Inhibit (DATA) is set to 1, Commands using only the CMD line can be issued if this bit is 0. Changing from 1 to 0 generates a Command Complete interrupt in the Interrupt Status register. If the uSDHC cannot issue the command because of a command conflict error (Refer to Command CRC Error) or because of a Command Not Issued By Auto CMD12 Error, this bit will remain 1 and the Command Complete is not set. The Status of issuing an Auto CMD12 does not show on this bit.
|  | NOTE: The SD Host Driver can save registers for a suspend transaction after this bit has changed from 1 to 0.
|  | 0b - Can issue command using only CMD line
|  | 1b - Cannot issue command

# 26.9.1.12 Protocol Control (PROT_CTRL)

## 26.9.1.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PROT_CTRL</td>
<td>28h</td>
</tr>
</tbody>
</table>
26.9.1.12.2 Function

There are three cases to restart the transfer after stop at the block gap. Which case is appropriate depends on whether the uSDHC issues a Suspend command or the SD card accepts the Suspend command.

1. If the Host Driver does not issue a Suspend command, the Continue Request shall be used to restart the transfer.
2. If the Host Driver issues a Suspend command and the SD card accepts it, a Resume command shall be used to restart the transfer.
3. If the Host Driver issues a Suspend command and the SD card does not accept it, the Continue Request shall be used to restart the transfer.

Any time Stop At Block Gap Request stops the data transfer, the Host Driver shall wait for a Transfer Complete (in the Interrupt Status register), before attempting to restart the transfer. When restarting the data transfer by Continue Request, the Host Driver shall clear the Stop At Block Gap Request before or simultaneously.

26.9.1.12.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>NON_EXACT_BLK_RD</td>
<td>BURST_LEN_E</td>
<td>WECRM</td>
<td>WECINS</td>
<td>WECINT</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>RD_DONE_NO_8CLK</td>
<td>IABG</td>
<td>RWCTL</td>
<td>CREQ</td>
<td>SABGRE</td>
<td>Q</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

26.9.1.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>-</td>
</tr>
<tr>
<td>—</td>
<td>Reserved. Always write as 0</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>30</td>
<td>NON_EXACT_BLK_RD</td>
</tr>
<tr>
<td>29-27</td>
<td>BURST_LEN_E</td>
</tr>
<tr>
<td>26</td>
<td>WECRM</td>
</tr>
<tr>
<td>25</td>
<td>WECINS</td>
</tr>
<tr>
<td>24</td>
<td>WECINT</td>
</tr>
<tr>
<td>23-21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>RD_DONE_NO_8CLK</td>
</tr>
</tbody>
</table>

**Field: NON_EXACT_BLK_RD**
Current block read is non-exact block read. It is only used for SDIO.

- **0b**: The block read is exact block read. Host driver doesn’t need to issue abort command to terminate this multi-block read.
- **1b**: The block read is non-exact block read. Host driver needs to issue abort command to terminate this multi-block read.

**Field: BURST_LEN_E**
BURST length enable for INCR, INCR4 / INCR8 / INCR16, INCR4-WRAP / INCR8-WRAP / INCR16-WRAP

This is used to enable / disable the burst length for the external AHB2AXI bridge. It is useful especially for INCR transfer because without burst length indicator, the AHB2AXI bridge does not know the burst length in advance. Without burst length indicator, AHB INCR transfers can only be converted to SINGLEs on the AXI side.

- **1xxb**: Burst length is enabled for INCR4-WRAP / INCR8-WRAP / INCR16-WRAP
- **x1xb**: Burst length is enabled for INCR4 / INCR8 / INCR16
- **xx1b**: Burst length is enabled for INCR

**Field: WECRM**
Wakeup Event Enable On SD Card Removal

This bit enables a wakeup event, via a Card Removal, in the Interrupt Status register. FN_WUS (Wake Up Support) in CIS does not effect this bit. When this bit is set, the Card Removal Status and the uSDHC interrupt can be asserted without CLK toggling. When the wakeup feature is not enabled, the CLK must be active in order to assert the Card Removal Status and the uSDHC interrupt.

- **0b**: Disable
- **1b**: Enable

**Field: WECINS**
Wakeup Event Enable On SD Card Insertion

This bit enables a wakeup event, via a Card Insertion, in the Interrupt Status register. FN_WUS (Wake Up Support) in CIS does not effect this bit. When this bit is set, the Card Insertion Status and the uSDHC interrupt can be asserted without CLK toggling. When the wakeup feature is not enabled, the CLK must be active in order to assert the Card Insertion Status and the uSDHC interrupt.

- **0b**: Disable
- **1b**: Enable

**Field: WECINT**
Wakeup Event Enable On Card Interrupt

This bit enables a wakeup event, via a Card Interrupt, in the Interrupt Status register. This bit can be set to 1 if FN_WUS (Wake Up Support) in CIS is set to 1. When this bit is set, the Card Interrupt Status and the uSDHC interrupt can be asserted without CLK toggling. When the wakeup feature is not enabled, the CLK must be active in order to assert the Card Interrupt Status and the uSDHC interrupt.

- **0b**: Disable
- **1b**: Enable

**Field: RD_DONE_NO_8CLK**
Read done no 8 clock:

According to the SD/MMC spec, for read data transaction, 8 clocks are needed after the end bit of the last data block. So, by default(RD_DONE_NO_8CLK=0), 8 clocks will be active after the end bit of the last read data transaction.

However, this 8 clocks should not be active if user wants to use stop at block gap(include the auto stop at block gap in boot mode) feature for read and the RWCTL bit(bit18) is not enabled. In this case, software should set RD_DONE_NO_8CLK to avoid this 8 clocks. Otherwise, the device may send extra data to uSDHC while uSDHC ignores these data.

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>19 IABG</td>
<td>Interrupt At Block Gap</td>
</tr>
<tr>
<td></td>
<td>This bit is valid only in 4-bit mode, of the SDIO card, and selects a sample point in the interrupt cycle. Setting to 1 enables interrupt detection at the block gap for a multiple block transfer. Setting to 0 disables interrupt detection during a multiple block transfer. If the SDIO card cannot signal an interrupt during a multiple block transfer, this bit should be set to 0 to avoid an inadvertent interrupt. When the Host Driver detects an SDIO card insertion, it shall set this bit according to the CCCR of the card.</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>18 RWCTL</td>
<td>Read Wait Control</td>
</tr>
<tr>
<td></td>
<td>The read wait function is optional for SDIO cards. If the card supports read wait, set this bit to enable use of the read wait protocol to stop read data using the DATA2 line. Otherwise the uSDHC has to stop the SD Clock to hold read data, which restricts commands generation. When the Host Driver detects an SDIO card insertion, it shall set this bit according to the CCCR of the card. If the card does not support read wait, this bit shall never be set to 1, otherwise DATA line conflicts may occur. If this bit is set to 0, stop at block gap during read operation is also supported, but the uSDHC will stop the SD Clock to pause reading operation.</td>
</tr>
<tr>
<td></td>
<td>0b - Disable Read Wait Control, and stop SD Clock at block gap when SABGREQ bit is set</td>
</tr>
<tr>
<td></td>
<td>1b - Enable Read Wait Control, and assert Read Wait without stopping SD Clock at block gap when SABGREQ bit is set</td>
</tr>
<tr>
<td>17 CREQ</td>
<td>Continue Request</td>
</tr>
<tr>
<td></td>
<td>This bit is used to restart a transaction which was stopped using the Stop At Block Gap Request. When a Suspend operation is not accepted by the card, it is also by setting this bit to restart the paused transfer. To cancel stop at the block gap, set Stop At Block Gap Request to 0 and set this bit to 1 to restart the transfer.</td>
</tr>
<tr>
<td></td>
<td>The uSDHC automatically clears this bit, therefore it is not necessary for the Host Driver to set this bit to 0. If both Stop At Block Gap Request and this bit are 1, the continue request is ignored.</td>
</tr>
<tr>
<td></td>
<td>0b - No effect</td>
</tr>
<tr>
<td></td>
<td>1b - Restart</td>
</tr>
<tr>
<td>16 SABGREQ</td>
<td>Stop At Block Gap Request</td>
</tr>
<tr>
<td></td>
<td>This bit is used to stop executing a transaction at the next block gap for both DMA and non-DMA transfers. Until the Transfer Complete is set to 1, indicating a transfer completion, the Host Driver shall leave this bit set to 1. Clearing both the Stop At Block Gap Request and Continue Request does not cause the transaction to restart. Read Wait is used to stop the read transaction at the block gap. The uSDHC will honor the Stop At Block Gap Request for write transfers, but for read transfers it requires that the SDIO card support Read Wait. Therefore, the Host Driver shall not set this bit during read transfers unless the SDIO card supports Read Wait and has set the Read Wait Control to 1, otherwise the uSDHC will stop the SD bus clock to pause the read operation during block gap. In the case of write transfers in which the Host Driver writes data to the Data Port register, the Host Driver shall set this bit after all block data is written. If this bit is set to 1, the Host Driver shall not write data to the Data Port register after a block is sent. Once this bit is set, the Host Driver shall not clear this bit before the Transfer Complete bit in Interrupt Status Register is set, otherwise the uSDHCs behavior is undefined.</td>
</tr>
<tr>
<td></td>
<td>This bit effects Read Transfer Active, Write Transfer Active, DATA Line Active and Command Inhibit (DATA) in the Present State register.</td>
</tr>
<tr>
<td></td>
<td>0b - Transfer</td>
</tr>
<tr>
<td></td>
<td>1b - Stop</td>
</tr>
<tr>
<td>15-10</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>
### uSDHC Memory Map/Register Definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>9-8</td>
<td>DMA Select</td>
</tr>
<tr>
<td>DMASEL</td>
<td>This field is valid while DMA (SDMA or ADMA) is enabled and selects the DMA operation.</td>
</tr>
<tr>
<td></td>
<td>00b - No DMA or Simple DMA is selected</td>
</tr>
<tr>
<td></td>
<td>01b - ADMA1 is selected</td>
</tr>
<tr>
<td></td>
<td>10b - ADMA2 is selected</td>
</tr>
<tr>
<td></td>
<td>11b - reserved</td>
</tr>
<tr>
<td>7</td>
<td>Card Detect Signal Selection</td>
</tr>
<tr>
<td>CDSS</td>
<td>This bit selects the source for the card detection.</td>
</tr>
<tr>
<td></td>
<td>0b - Card Detection Level is selected (for normal purpose).</td>
</tr>
<tr>
<td></td>
<td>1b - Card Detection Test Level is selected (for test purpose).</td>
</tr>
<tr>
<td>6</td>
<td>Card Detect Test Level</td>
</tr>
<tr>
<td>CDTL</td>
<td>This bit is enabled while the Card Detection Signal Selection is set to 1 and it indicates card insertion.</td>
</tr>
<tr>
<td></td>
<td>0b - Card Detect Test Level is 0, no card inserted</td>
</tr>
<tr>
<td></td>
<td>1b - Card Detect Test Level is 1, card inserted</td>
</tr>
<tr>
<td>5-4</td>
<td>Endian Mode</td>
</tr>
<tr>
<td>EMODE</td>
<td>The uSDHC supports all three endian modes in data transfer. Refer to Data Buffer for more details.</td>
</tr>
<tr>
<td></td>
<td>00b - Big Endian Mode</td>
</tr>
<tr>
<td></td>
<td>01b - Half Word Big Endian Mode</td>
</tr>
<tr>
<td></td>
<td>10b - Little Endian Mode</td>
</tr>
<tr>
<td></td>
<td>11b - Reserved</td>
</tr>
<tr>
<td>3</td>
<td>DATA3 as Card Detection Pin</td>
</tr>
<tr>
<td>D3CD</td>
<td>If this bit is set, DATA3 should be pulled down to act as a card detection pin. Be cautious when using this feature, because DATA3 is also a chip-select for the SPI mode. A pull-down on this pin and CMD0 may set the card into the SPI mode, which the uSDHC does not support.</td>
</tr>
<tr>
<td></td>
<td>0b - DATA3 does not monitor Card Insertion</td>
</tr>
<tr>
<td></td>
<td>1b - DATA3 as Card Detection Pin</td>
</tr>
<tr>
<td>2-1</td>
<td>Data Transfer Width</td>
</tr>
<tr>
<td>DTW</td>
<td>This bit selects the data width of the SD bus for a data transfer. The Host Driver shall set it to match the data width of the card. Possible Data transfer Width is 1-bit, 4-bits or 8-bits.</td>
</tr>
<tr>
<td></td>
<td>00b - 1-bit mode</td>
</tr>
<tr>
<td></td>
<td>01b - 4-bit mode</td>
</tr>
<tr>
<td></td>
<td>10b - 8-bit mode</td>
</tr>
<tr>
<td></td>
<td>11b - Reserved</td>
</tr>
<tr>
<td>0</td>
<td>LED Control</td>
</tr>
<tr>
<td>LCTL</td>
<td>This bit, fully controlled by the Host Driver, is used to caution the user not to remove the card while the card is being accessed. If the software is going to issue multiple SD commands, this bit can be set during all these transactions. It is not necessary to change for each transaction. When the software issues multiple SD commands, setting the bit once before the first command is sufficient: it is not necessary to reset the bit between commands.</td>
</tr>
<tr>
<td></td>
<td>0b - LED off</td>
</tr>
<tr>
<td></td>
<td>1b - LED on</td>
</tr>
</tbody>
</table>
26.9.1.13 System Control (SYS_CTRL)

26.9.1.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SYS_CTRL</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

26.9.1.13.2 Diagram

![Diagram](image)

26.9.1.13.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>RSTT</td>
</tr>
<tr>
<td></td>
<td>Reset Tuning</td>
</tr>
<tr>
<td></td>
<td>When set this bit to 1, it will reset tuning circuit. After tuning circuits are reset, bit value is 0. Clearing execute_tuning bit in AUTOCMD12_ERR_STATUS will also set this bit to 1 to reset tuning circuit</td>
</tr>
<tr>
<td>27</td>
<td>INITA</td>
</tr>
<tr>
<td></td>
<td>Initialization Active</td>
</tr>
<tr>
<td></td>
<td>When this bit is set, 80 SD-Clocks are sent to the card. After the 80 clocks are sent, this bit is self cleared. This bit is very useful during the card power-up period when 74 SD-Clocks are needed and the clock auto gating feature is enabled. Writing 1 to this bit when this bit is already 1 has no effect. Writing 0 to this bit at any time has no effect. When either of the CIHB and CDIHB bits in the Present State Register are set, writing 1 to this bit is ignored (i.e. when command line or data lines are active, write to this bit is not allowed). On the otherhand, when this bit is set, i.e., during initialization active period, it is allowed to issue command, and the command bit stream will appear on the CMD pad after all 80 clock cycles are done. So when this command ends, the driver can make sure the 80 clock cycles are sent out. This is very useful when the driver needs send 80 cycles to the card and does not want to wait till this bit is self cleared.</td>
</tr>
<tr>
<td>26</td>
<td>Software Reset For DATA Line</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>RSTD</td>
<td>Only part of the data circuit is reset. DMA circuit is also reset. After this bit is set, SW waits for self-clear. The following registers and bits are cleared by this bit:</td>
</tr>
<tr>
<td></td>
<td>• Data Port register</td>
</tr>
<tr>
<td></td>
<td>• Buffer is cleared and initialized.</td>
</tr>
<tr>
<td></td>
<td>• Present State register</td>
</tr>
<tr>
<td></td>
<td>• Buffer Read Enable</td>
</tr>
<tr>
<td></td>
<td>• Buffer Write Enable</td>
</tr>
<tr>
<td></td>
<td>• Read Transfer Active</td>
</tr>
<tr>
<td></td>
<td>• Write Transfer Active</td>
</tr>
<tr>
<td></td>
<td>• DATA Line Active</td>
</tr>
<tr>
<td></td>
<td>• Command Inhibit (DATA) Protocol Control register</td>
</tr>
<tr>
<td></td>
<td>• Continue Request</td>
</tr>
<tr>
<td></td>
<td>• Stop At Block Gap Request Interrupt Status register</td>
</tr>
<tr>
<td></td>
<td>• Buffer Read Ready</td>
</tr>
<tr>
<td></td>
<td>• Buffer Write Ready</td>
</tr>
<tr>
<td></td>
<td>• DMA Interrupt</td>
</tr>
<tr>
<td></td>
<td>• Block Gap Event</td>
</tr>
<tr>
<td></td>
<td>• Transfer Complete</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> When reset, SW must make sure there is no incomplete data transferring. If there is data transfer going on, SW need wait TC or DC INT_STATUS register is set.</td>
</tr>
<tr>
<td></td>
<td>0b - No Reset</td>
</tr>
<tr>
<td></td>
<td>1b - Reset</td>
</tr>
<tr>
<td>25</td>
<td>Software Reset For CMD Line</td>
</tr>
<tr>
<td>RSTC</td>
<td>Only part of the command circuit is reset. After this bit is set, SW waits for self-clear. The following registers and bits are cleared by this bit:</td>
</tr>
<tr>
<td></td>
<td>• Present State register Command Inhibit (CMD)</td>
</tr>
<tr>
<td></td>
<td>• Interrupt Status register Command Complete</td>
</tr>
<tr>
<td></td>
<td>0b - No Reset</td>
</tr>
<tr>
<td></td>
<td>1b - Reset</td>
</tr>
<tr>
<td>24</td>
<td>Software Reset For ALL</td>
</tr>
<tr>
<td>RSTA</td>
<td>This reset effects the entire Host Controller except for the card detection circuit. Register bits of type ROC, RW, RW1C, RWAC are cleared. During its initialization, the Host Driver shall set this bit to 1 to reset the uSDHC. The uSDHC shall reset this bit to 0 when the capabilities registers are valid and the Host Driver can read them. Additional use of Software Reset For All does not affect the value of the Capabilities registers. After this bit is set, it is recommended that the Host Driver reset the external card and re-initialize it. After this bit is set, SW should wait for self-clear. In tuning process, after every CMD19 is finished, this bit will be set to retest the uSDHC. <strong>NOTE:</strong> When reset, SW must make sure there is no incomplete data transferring. If there is data transfer going on, SW need wait TC or DC INT_STATUS register is set.</td>
</tr>
<tr>
<td></td>
<td>0b - No Reset</td>
</tr>
<tr>
<td></td>
<td>1b - Reset</td>
</tr>
<tr>
<td>23</td>
<td>IPP_RST_N</td>
</tr>
<tr>
<td></td>
<td>This register’s value will be output to CARD from pad directly for hardware reset of the card if the card supports this feature.</td>
</tr>
<tr>
<td>22</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>—</td>
</tr>
<tr>
<td>21</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>—</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>20</td>
<td>- Reserved</td>
</tr>
<tr>
<td>19-16</td>
<td>DTOCV Data Timeout Counter Value</td>
</tr>
<tr>
<td></td>
<td>This value determines the interval by which DAT line timeouts are detected. Refer to the Data Timeout Error bit in the Interrupt Status register for information on factors that dictate time-out generation. Time-out clock frequency will be generated by dividing the base clock SDCLK value by this value. The Host Driver can clear the Data Timeout Error Status Enable (in the Interrupt Status Enable register) to prevent inadvertent time-out events.</td>
</tr>
</tbody>
</table>
|       | 0000b - SDCLK x $2^{14}$  
|       | 0001b - SDCLK x $2^{15}$  
|       | 1101b - SDCLK x $2^{27}$  
|       | 1110b - SDCLK x $2^{28}$  
|       | 1111b - SDCLK x $2^{29}$  |
| 15-8  | SDCLK Frequency Select |
|       | This register is used to select the frequency of the SDCLK pin. The frequency is not programmed directly, rather this register holds the prescaler (this register) and divisor (next register) of the Base Clock Frequency register. In Single Data Rate mode (DDR_EN bit of MIXERCTRL is '0') Only the following settings are allowed:  
|       | 80h) Base clock divided by 256  
|       | 40h) Base clock divided by 128  
|       | 20h) Base clock divided by 64  
|       | 10h) Base clock divided by 32  
|       | 08h) Base clock divided by 16  
|       | 04h) Base clock divided by 8  
|       | 02h) Base clock divided by 4  
|       | 01h) Base clock divided by 2  
|       | 00h) Base clock divided by 1  
|       | While in Dual Data Rate mode (DDR_EN bit of MIXERCTRL is '1') Only the following settings are allowed:  
|       | 80h) Base clock divided by 512  
|       | 40h) Base clock divided by 256  
|       | 20h) Base clock divided by 128  
|       | 10h) Base clock divided by 64  
|       | 08h) Base clock divided by 32  
|       | 04h) Base clock divided by 16  
|       | 02h) Base clock divided by 8  
|       | 01h) Base clock divided by 4  
|       | 00h) Base clock divided by 2  
|       | When S/W changes the DDR_EN bit, SDCLKFS may need to be changed also! In Single Data Rate mode, setting 00h bypasses the frequency prescaler of the SD Clock. |

Table continues on the next page...
Multiple bits must not be set, or the behavior of this prescaler is undefined. The two default divider values can be calculated by the frequency of ipg_perclk and the following Divisor bits.

The frequency of SDCLK is set by the following formula:

\[
\text{Clock Frequency} = \frac{\text{Base Clock}}{(\text{prescaler} \times \text{divisor})}
\]

For example, in Single Data Rate mode, if the Base Clock Frequency is 96 MHz, and the target frequency is 25 MHz, then choosing the prescaler value of 01h and divisor value of 1h will yield 24 MHz, which is the nearest frequency less than or equal to the target. Similarly, to approach a clock value of 400 kHz, the prescaler value of 08h and divisor value of eh yields the exact clock value of 400 kHz.

The reset value of this bit field is 80h, so if the input Base Clock (ipg_perclk) is about 96 MHz, the default SD Clock after reset is 375 kHz.

According to the SD Physical Specification Version 1.1 and the SDIO Card Specification Version 1.2, the maximum SD Clock frequency is 50 MHz and shall never exceed this limit.

Before changing clock divisor value (SDCLKFS or DVS), Host Driver should make sure the SDSTB bit is high.

If setting SDCLKFS and DVS can generate same clock frequency,(For example, in SDR mode, SDCLKFS = 01h is same as DVS = 01h.) SDCLKFS is highly recommended.

### 26.9.1.14 Interrupt Status (INT_STATUS)

#### 26.9.1.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_STATUS</td>
<td>30h</td>
</tr>
</tbody>
</table>

#### 26.9.1.14.2 Function

An interrupt is generated when the Normal Interrupt Signal Enable is enabled and at least one of the status bits is set to 1. For all bits, writing 1 to a bit clears it; writing to 0 keeps the bit unchanged. More than one status can be cleared with a single register write. For
Card Interrupt, before writing 1 to clear, it is required that the card stops asserting the interrupt, meaning that when the Card Driver services the interrupt condition, otherwise the CINT bit will be asserted again.

The table below shows the relationship between the Command Timeout Error and the Command Complete.

**Table 26-9. uSDHC Status for Command Timeout Error/Command Complete Bit Combinations**

<table>
<thead>
<tr>
<th>Command Complete</th>
<th>Command Timeout Error</th>
<th>Meaning of the Status</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>X</td>
</tr>
<tr>
<td>X</td>
<td>1</td>
<td>Response not received within 64 SDCLK cycles</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Response received</td>
</tr>
</tbody>
</table>

The table below shows the relationship between the Transfer Complete and the Data Timeout Error.

**Table 26-10. uSDHC Status for Data Timeout Error/Transfer Complete Bit Combinations**

<table>
<thead>
<tr>
<th>Transfer Complete</th>
<th>Data Timeout Error</th>
<th>Meaning of the Status</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>X</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Timeout occurred during transfer</td>
</tr>
<tr>
<td>1</td>
<td>X</td>
<td>Data Transfer Complete</td>
</tr>
</tbody>
</table>

The table below shows the relationship between the Command CRC Error and Command Timeout Error.

**Table 26-11. uSDHC Status for Command CRC Error/Command Timeout Error Bit Combinations**

<table>
<thead>
<tr>
<th>Command Complete</th>
<th>Command Timeout Error</th>
<th>Meaning of the Status</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>No error</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Response Timeout Error</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Response CRC Error</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>CMD line conflict</td>
</tr>
</tbody>
</table>
### 26.9.1.14.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 26.9.1.14.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>DMAE</td>
</tr>
<tr>
<td>DMAE</td>
<td>DMA Error</td>
</tr>
<tr>
<td></td>
<td>Occurs when an Internal DMA transfer has failed. This bit is set to 1, when some error occurs in the data transfer. This error can be caused by either Simple DMA or ADMA, depending on which DMA is in use. The value in DMA System Address register is the next fetch address where the error occurs. Since any error corrupts the whole data block, the Host Driver shall re-start the transfer from the corrupted block boundary. The address of the block boundary can be calculated either from the current DS_ADDR value or from the remaining number of blocks and the block size.</td>
</tr>
<tr>
<td></td>
<td>0b - No Error</td>
</tr>
<tr>
<td></td>
<td>1b - Error</td>
</tr>
<tr>
<td>27</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>TNE</td>
</tr>
<tr>
<td>TNE</td>
<td>Tuning Error: (only for SD3.0 SDR104 mode and EMMC HS200 mode)</td>
</tr>
<tr>
<td></td>
<td>This bit is set when an unrecoverable error is detected in a tuning circuit. By detecting Tuning Error, Host Driver needs to abort a command executing and perform tuning.</td>
</tr>
<tr>
<td>25</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>AC12E</td>
</tr>
<tr>
<td>AC12E</td>
<td>Auto CMD12 Error</td>
</tr>
<tr>
<td></td>
<td>Occurs when detecting that one of the bits in the Auto CMD12 Error Status register has changed from 0 to 1. This bit is set to 1, not only when the errors in Auto CMD12 occur, but also when the Auto CMD12 is not executed due to the previous command error.</td>
</tr>
<tr>
<td></td>
<td>0b - No Error</td>
</tr>
<tr>
<td></td>
<td>1b - Error</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 22    | DEBE     | Data End Bit Error  
Occurs either when detecting 0 at the end bit position of read data, which uses the DATA line, or at the end bit position of the CRC.  
This bit will be not asserted in tuning process.  
0b - No Error  
1b - Error |
| 21    | DCE      | Data CRC Error  
Occurs when detecting a CRC error when transferring read data, which uses the DATA line, or when detecting the Write CRC status having a value other than 010.  
This bit will be not asserted in tuning process.  
0b - No Error  
1b - Error |
| 20    | DTOE     | Data Timeout Error  
Occurs when detecting one of following time-out conditions.  
- Busy time-out for R1b, R5b type  
- Busy time-out after Write CRC status  
- Read Data time-out.  
This bit will be not asserted in tuning process.  
0b - No Error  
1b - Time out |
| 19    | CIE      | Command Index Error  
Occurs if a Command Index error occurs in the command response.  
This bit will be not asserted in tuning process.  
0b - No Error  
1b - Error |
| 18    | CEBE     | Command End Bit Error  
Occurs when detecting that the end bit of a command response is 0.  
This bit will be not asserted in tuning process.  
0b - No Error  
1b - End Bit Error Generated |
| 17    | CCE      | Command CRC Error  
Command CRC Error is generated in two cases.  
- If a response is returned and the Command Timeout Error is set to 0 (indicating no time-out), this bit is set when detecting a CRC error in the command response.  
- The uSDHC detects a CMD line conflict by monitoring the CMD line when a command is issued. If the uSDHC drives the CMD line to 1, but detects 0 on the CMD line at the next SDCLK edge, then the uSDHC shall abort the command (Stop driving CMD line) and set this bit to 1. The Command Timeout Error shall also be set to 1 to distinguish CMD line conflict.  
This bit will be not asserted in tuning process.  
0b - No Error  
1b - CRC Error Generated. |
| 16    |          | Command Timeout Error  
*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTOE</td>
<td>Occurs only if no response is returned within 64 SDCLK cycles from the end bit of the command. If the uSDHC detects a CMD line conflict, in which case a Command CRC Error shall also be set (as shown in Interrupt Status (INT_STATUS)), this bit shall be set without waiting for 64 SDCLK cycles. This is because the command will be aborted by the uSDHC. This bit will be not asserted in tuning process.</td>
</tr>
<tr>
<td></td>
<td>0b - No Error</td>
</tr>
<tr>
<td></td>
<td>1b - Time out</td>
</tr>
<tr>
<td>15</td>
<td>- Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Tuning Pass: (only for SD3.0 SDR104 mode and EMMC HS200 mode)</td>
</tr>
<tr>
<td></td>
<td>Current CMD19 transfer is done successfully. That is, current sampling point is correct.</td>
</tr>
<tr>
<td>13</td>
<td>- Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Re-Tuning Event: (only for SD3.0 SDR104 mode and EMMC HS200 mode)</td>
</tr>
<tr>
<td></td>
<td>This status is set if Re-Tuning Request in the Present State register changes from 0 to 1. Host Controller requests Host Driver to perform re-tuning for next data transfer. Current data transfer (not large block count) can be completed without re-tuning.</td>
</tr>
<tr>
<td></td>
<td>0b - Re-Tuning is not required</td>
</tr>
<tr>
<td></td>
<td>1b - Re-Tuning should be performed</td>
</tr>
<tr>
<td>8</td>
<td>Card Interrupt</td>
</tr>
<tr>
<td></td>
<td>This status bit is set when an interrupt signal is detected from the external card. In 1-bit mode, the uSDHC will detect the Card Interrupt without the SD Clock to support wakeup. In 4-bit mode, the card interrupt signal is sampled during the interrupt cycle, so the interrupt from card can only be sampled during interrupt cycle, introducing some delay between the interrupt signal from the SDIO card and the interrupt to the Host System. Writing this bit to 1 can clear this bit, but as the interrupt source from the SDIO card does not clear, this bit is set again. In order to clear this bit, it is required to reset the interrupt source from the external card followed by a writing 1 to this bit. When this status has been set, and the Host Driver needs to service this interrupt, the Card Interrupt Signal Enable in the Interrupt Signal Enable register should be 0 to stop driving the interrupt signal to the Host System. After completion of the card interrupt service (It should reset the interrupt sources in the SDIO card and the interrupt signal may not be asserted), write 1 to clear this bit, set the Card Interrupt Signal Enable to 1, and start sampling the interrupt signal again.</td>
</tr>
<tr>
<td></td>
<td>0b - No Card Interrupt</td>
</tr>
<tr>
<td></td>
<td>1b - Generate Card Interrupt</td>
</tr>
<tr>
<td>7</td>
<td>Card Removal</td>
</tr>
<tr>
<td></td>
<td>This status bit is set if the Card Inserted bit in the Present State register changes from 1 to 0. When the Host Driver writes this bit to 1 to clear this status, the status of the Card Inserted in the Present State register should be confirmed. Because the card state may possibly be changed when the Host Driver clears this bit and the interrupt event may not be generated. When this bit is cleared, it will be set again if no card is inserted. In order to leave it cleared, clear the Card Removal Status Enable bit in Interrupt Status Enable register.</td>
</tr>
<tr>
<td></td>
<td>0b - Card state unstable or inserted</td>
</tr>
<tr>
<td></td>
<td>1b - Card removed</td>
</tr>
<tr>
<td>6</td>
<td>Card Insertion</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Field</strong></td>
<td><strong>Function</strong></td>
</tr>
<tr>
<td>5</td>
<td>Buffer Read Ready</td>
</tr>
<tr>
<td>BRR</td>
<td>This status bit is set if the Buffer Read Enable bit, in the Present State register, changes from 0 to 1. Refer to the Buffer Read Enable bit in the Present State register for additional information.</td>
</tr>
<tr>
<td></td>
<td>This bit indicates that cmd19 is finished in tuning process.</td>
</tr>
<tr>
<td></td>
<td>0b - Not ready to read buffer</td>
</tr>
<tr>
<td></td>
<td>1b - Ready to read buffer</td>
</tr>
<tr>
<td>4</td>
<td>Buffer Write Ready</td>
</tr>
<tr>
<td>BWR</td>
<td>This status bit is set if the Buffer Write Enable bit, in the Present State register, changes from 0 to 1. Refer to the Buffer Write Enable bit in the Present State register for additional information.</td>
</tr>
<tr>
<td></td>
<td>0b - Not ready to write buffer</td>
</tr>
<tr>
<td></td>
<td>1b - Ready to write buffer:</td>
</tr>
<tr>
<td>3</td>
<td>DMA Interrupt</td>
</tr>
<tr>
<td>DINT</td>
<td>Occurs only when the internal DMA finishes the data transfer successfully. Whenever errors occur during data transfer, this bit will not be set. Instead, the DMAE bit will be set. Either Simple DMA or ADMA finishes data transferring, this bit will be set.</td>
</tr>
<tr>
<td></td>
<td>0b - No DMA Interrupt</td>
</tr>
<tr>
<td></td>
<td>1b - DMA Interrupt is generated</td>
</tr>
<tr>
<td>2</td>
<td>Block Gap Event</td>
</tr>
<tr>
<td>BGE</td>
<td>If the Stop At Block Gap Request bit in the Protocol Control register is set, this bit is set when a read or write transaction is stopped at a block gap. If Stop At Block Gap Request is not set to 1, this bit is not set to 1.</td>
</tr>
<tr>
<td></td>
<td>In the case of a Read Transaction: This bit is set at the falling edge of the DATA Line Active Status (When the transaction is stopped at SD Bus timing). The Read Wait must be supported in order to use this function.</td>
</tr>
<tr>
<td></td>
<td>In the case of Write Transaction: This bit is set at the falling edge of Write Transfer Active Status (After getting CRC status at SD Bus timing).</td>
</tr>
<tr>
<td></td>
<td>0b - No block gap event</td>
</tr>
<tr>
<td></td>
<td>1b - Transaction stopped at block gap</td>
</tr>
<tr>
<td>1</td>
<td>Transfer Complete</td>
</tr>
<tr>
<td>TC</td>
<td>This bit is set when a read or write transfer is completed.</td>
</tr>
<tr>
<td></td>
<td>In the case of a Read Transaction: This bit is set at the falling edge of the Read Transfer Active Status. There are two cases in which this interrupt is generated. The first is when a data transfer is completed as specified by the data length (after the last data has been read to the Host System). The second is when data has stopped at the block gap and completed the data transfer by setting the Stop At Block Gap Request bit in the Protocol Control register (after valid data has been read to the Host System).</td>
</tr>
<tr>
<td></td>
<td>In the case of a Write Transaction: This bit is set at the falling edge of the DATA Line Active Status. There are two cases in which this interrupt is generated. The first is when the last data is written to the SD card as specified by the data length and the busy signal is released. The second is when data transfers are...</td>
</tr>
</tbody>
</table>

Table continues on the next page...
stopped at the block gap, by setting the Stop At Block Gap Request bit in the Protocol Control register, and the data transfers are completed. (after valid data is written to the SD card and the busy signal released).

In the case of a command with busy, this bit is set when busy is deasserted.

This bit will be not asserted in tuning process.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>Transfer not complete</td>
</tr>
<tr>
<td>1b</td>
<td>Transfer complete</td>
</tr>
</tbody>
</table>

Command Complete

This bit is set when you receive the end bit of the command response (except Auto CMD12). Refer to the Command Inhibit (CMD) in the Present State register.

This bit will be not asserted in tuning process.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>Command not complete</td>
</tr>
<tr>
<td>1b</td>
<td>Command complete</td>
</tr>
</tbody>
</table>

### 26.9.1.15 Interrupt Status Enable (INT_STATUS_EN)

### 26.9.1.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_STATUS_EN</td>
<td>34h</td>
</tr>
</tbody>
</table>

### 26.9.1.15.2 Function

Setting the bits in this register to 1 enables the corresponding Interrupt Status to be set by the specified event. If any bit is cleared, the corresponding Interrupt Status bit is also cleared (i.e. when the bit in this register is cleared, the corresponding bit in Interrupt Status Register is always 0).

- Depending on IABG bit setting, uSDHC may be programmed to sample the card interrupt signal during the interrupt period and hold its value in the flip-flop. There will be some delays on the Card Interrupt, asserted from the card, to the time the Host System is informed.
- To detect a CMD line conflict, the Host Driver must set both Command Timeout Error Status Enable and Command CRC Error Status Enable to 1.
26.9.1.15.3 Diagram

26.9.1.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>DMA Error Status Enable</td>
</tr>
<tr>
<td>DMAESEN</td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>27</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Tuning Error Status Enable</td>
</tr>
<tr>
<td>TNESEN</td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>25</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Auto CMD12 Error Status Enable</td>
</tr>
<tr>
<td>AC12ESEN</td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>23</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Data End Bit Error Status Enable</td>
</tr>
<tr>
<td>DEBESEN</td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>21</td>
<td>Data CRC Error Status Enable</td>
</tr>
<tr>
<td>DCESEN</td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>20</td>
<td>Data Timeout Error Status Enable</td>
</tr>
<tr>
<td>DTOESEN</td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>19</td>
<td>Command Index Error Status Enable</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>CIESEN</td>
<td>0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>18 CEBSEN</td>
<td>Command End Bit Error Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>17 CCESEN</td>
<td>Command CRC Error Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>16 CTOESEN</td>
<td>Command Timeout Error Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>15 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>14 TPSEN</td>
<td>Tuning Pass Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>13 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>12 RTESEN</td>
<td>Re-Tuning Event Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>11-9 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>8 CINTSEN</td>
<td>Card Interrupt Status Enable</td>
</tr>
<tr>
<td></td>
<td>If this bit is set to 0, the uSDHC will clear the interrupt request to the system. The Card Interrupt detection is stopped when this bit is cleared and restarted when this bit is set to 1. The Host Driver should clear the Card Interrupt Status Enable before servicing the Card Interrupt and should set this bit again after all interrupt requests from the card are cleared to prevent inadvertent interrupts. 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>7 CRMSEN</td>
<td>Card Removal Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>6 CINSSEN</td>
<td>Card Insertion Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>5 BRRSEN</td>
<td>Buffer Read Ready Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>4 BWRSNEN</td>
<td>Buffer Write Ready Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>3 DINSESEN</td>
<td>DMA Interrupt Status Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>2 BGESEN</td>
<td>Block Gap Event Status Enable 0b - Masked 1b - Enabled</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 26.9.1.16 Interrupt Signal Enable (INT_SIGNAL_EN)

#### 26.9.1.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_SIGNAL_EN</td>
<td>38h</td>
</tr>
</tbody>
</table>

#### 26.9.1.16.2 Function

This register is used to select which interrupt status is indicated to the Host System as the interrupt. These status bits all share the same interrupt line. Setting any of these bits to 1 enables interrupt generation. The corresponding Status register bit will generate an interrupt when the corresponding interrupt signal enable bit is set.

#### 26.9.1.16.3 Diagram

![Diagram of Interrupt Signal Enable (INT_SIGNAL_EN) register](image)

**Reset**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

**Reset**

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

(Continue with more detailed explanation as needed)
### Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>DMA Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enable</td>
</tr>
<tr>
<td>27</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Tuning Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>25</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Auto CMD12 Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>23</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Data End Bit Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>21</td>
<td>Data CRC Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>20</td>
<td>Data Timeout Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>19</td>
<td>Command Index Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>18</td>
<td>Command End Bit Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>17</td>
<td>Command CRC Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>16</td>
<td>Command Timeout Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>15</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Tuning Pass Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>13</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>12 RTEIEN</td>
<td>Re-Tuning Event Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>11-9 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>8 CINTIEN</td>
<td>Card Interrupt Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>7 CRMIEN</td>
<td>Card Removal Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>6 CINSIEN</td>
<td>Card Insertion Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>5 BRIEN</td>
<td>Buffer Read Ready Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>4 BWRIEN</td>
<td>Buffer Write Ready Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>3 DINIEN</td>
<td>DMA Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>2 BGEIEN</td>
<td>Block Gap Event Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>1 TCIEN</td>
<td>Transfer Complete Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>0 CCIEN</td>
<td>Command Complete Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
</tbody>
</table>

### 26.9.1.17 Auto CMD12 Error Status (AUTOCMD12_ERR_STATUS)

#### 26.9.1.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AUTOCMD12_ERR_STATUS</td>
<td>3Ch</td>
</tr>
</tbody>
</table>
26.9.1.17.2 Function

When the Auto CMD12 Error Status bit in the Status register is set, the Host Driver shall check this register to identify what kind of error the Auto CMD12 / CMD 23 indicated. Auto CMD23 errors are indicated in bit 04-01. This register is valid only when the Auto CMD12 Error status bit is set.

The table below shows the relationship between the Auto CMGD12 CRC Error and the Auto CMD12 Command Timeout Error.

**Table 26-12. Relationship Between Command CRC Error and Command Timeout Error for Auto CMD12**

<table>
<thead>
<tr>
<th>Auto CMD12 CRC Error</th>
<th>Auto CMD12 Timeout Error</th>
<th>Type of Error</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>No Error</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Response Timeout Error</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Response CRC Error</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>CMD line conflict</td>
</tr>
</tbody>
</table>

Changes in Auto CMD12 Error Status register can be classified in three scenarios:

1. When the uSDHC is going to issue an Auto CMD12.
   - Set bit 0 to 1 if the Auto CMD12 can't be issued due to an error in the previous command
   - Set bit 0 to 0 if the Auto CMD12 is issued
2. At the end bit of an Auto CMD12 response.
   - Check errors correspond to bits 1-4.
   - Set bits 1-4 corresponding to detected errors.
   - Clear bits 1-4 corresponding to detected errors
   - Set bit 7 to 1 if there is a command that can't be issued
   - Clear bit 7 if there is no command to issue

The timing for generating the Auto CMD12 Error and writing to the Command register are asynchronous. After that, bit 7 shall be sampled when the driver is not writing to the Command register. So it is suggested to read this register only when the AC12E bit in Interrupt Status register is set. An Auto CMD12 Error Interrupt is generated when one of the error bits (0-4) is set to 1. The Command Not Issued By Auto CMD12 Error does not generate an interrupt.
26.9.1.17.3  Diagram

Table continues on the next page...

26.9.1.17.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>- Reserved</td>
</tr>
<tr>
<td>23</td>
<td>SMP_CLK_SEL Sample Clock Select</td>
</tr>
<tr>
<td></td>
<td>When std_tuning_en bit is set, this bit is used to select sampling clock to receive CMD and DATA. Otherwise, this bit is reserved. This bit is set by tuning procedure and valid after the completion of tuning(When Execute Tuning is cleared). Setting 1 means that tuning is completed successfully and setting 0 means that tuning is failed. Writing 1 to this bit is meaningless and ignored. A tuning circuit is reset by writing to 0. This bit can be cleared with setting Execute Tuning. Once the tuning circuit is reset, it will take time to complete tuning sequence. Therefore, Host Driver should keep this bit to 1 to perform re-tuning sequence to complete re-tuning sequence in a short time. Change of this bit is not allowed while the Host controller is receiving response or a read data block.</td>
</tr>
<tr>
<td>22</td>
<td>EXECUTE_TUNING Execute Tuning</td>
</tr>
<tr>
<td></td>
<td>When std_tuning_en bit is set, this bit is used to start tuning procedure. Otherwise, this bit is reserved. This bit is set to start tuning procedure and automatically cleared when running procedure is completed. The result of tuning is indicated to sam_clk_sel bit. Tuning procedure is aborted by writing 0.</td>
</tr>
<tr>
<td>21-8</td>
<td>- Reserved</td>
</tr>
<tr>
<td>7</td>
<td>CNIBAC12E Command Not Issued By Auto CMD12 Error</td>
</tr>
<tr>
<td></td>
<td>Setting this bit to 1 means CMD_wo_DAT is not executed due to an Auto CMD12 Error (D04-D01) in this register.</td>
</tr>
</tbody>
</table>
### Field | Function
--- | ---
0b - No error | 1b - Not Issued

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 6-5 | -
--- | Reserved

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 4 | Auto CMD12 / 23 Index Error
--- | Occurs if the Command Index error occurs in response to a command.
--- | 0b - No error
--- | 1b - Error, the CMD index in response is not CMD12/23

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 3 | Auto CMD12 / 23 CRC Error
--- | Occurs when detecting a CRC error in the command response.
--- | 0b - No CRC error
--- | 1b - CRC Error Met in Auto CMD12/23 Response

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 2 | Auto CMD12 / 23 End Bit Error
--- | Occurs when detecting that the end bit of command response is 0 which should be 1.
--- | 0b - No error
--- | 1b - End Bit Error Generated

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 1 | Auto CMD12 / 23 Timeout Error
--- | Occurs if no response is returned within 64 SDCLK cycles from the end bit of the command. If this bit is set to 1, the other error status bits (2-4) have no meaning.
--- | 0b - No error
--- | 1b - Time out

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 0 | Auto CMD12 Not Executed
--- | If memory multiple block data transfer is not started, due to a command error, this bit is not set because it is not necessary to issue an Auto CMD12. Setting this bit to 1 means the uSDHC cannot issue the Auto CMD12 to stop a memory multiple block data transfer due to some error. If this bit is set to 1, other error status bits (1-4) have no meaning.
--- | 0b - Executed
--- | 1b - Not executed

### 26.9.1.18 Host Controller Capabilities (HOST_CTRL_CAP)

#### 26.9.1.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>HOST_CTRL_CAP</td>
<td>40h</td>
</tr>
</tbody>
</table>
26.9.1.18.2 Function

This register provides the Host Driver with information specific to the uSDHC implementation. The value in this register is the power-on-reset value, and does not change with a software reset.

26.9.1.18.3 Diagram

![Diagram]

26.9.1.18.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-27</td>
<td>-</td>
</tr>
<tr>
<td>26</td>
<td>Voltage Support 1.8 V</td>
</tr>
<tr>
<td>VS18</td>
<td>This bit shall depend on the Host System ability.</td>
</tr>
<tr>
<td></td>
<td>0b - 1.8V not supported</td>
</tr>
<tr>
<td></td>
<td>1b - 1.8V supported</td>
</tr>
<tr>
<td>25</td>
<td>Voltage Support 3.0 V</td>
</tr>
<tr>
<td>VS30</td>
<td>This bit shall depend on the Host System ability.</td>
</tr>
<tr>
<td></td>
<td>0b - 3.0V not supported</td>
</tr>
<tr>
<td></td>
<td>1b - 3.0V supported</td>
</tr>
<tr>
<td>24</td>
<td>Voltage Support 3.3V</td>
</tr>
<tr>
<td>VS33</td>
<td>This bit shall depend on the Host System ability.</td>
</tr>
<tr>
<td></td>
<td>0b - 3.3V not supported</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>23</td>
<td>Suspend / Resume Support</td>
</tr>
<tr>
<td>SRS</td>
<td>This bit indicates whether the uSDHC supports Suspend / Resume functionality. If this bit is 0, the Suspend and Resume mechanism, as well as the Read Wait, are not supported, and the Host Driver shall not issue either Suspend or Resume commands.</td>
</tr>
<tr>
<td></td>
<td>0b - Not supported</td>
</tr>
<tr>
<td></td>
<td>1b - Supported</td>
</tr>
<tr>
<td>22</td>
<td>DMA Support</td>
</tr>
<tr>
<td>DMAS</td>
<td>This bit indicates whether the uSDHC is capable of using the internal DMA to transfer data between system memory and the data buffer directly.</td>
</tr>
<tr>
<td></td>
<td>0b - DMA not supported</td>
</tr>
<tr>
<td></td>
<td>1b - DMA Supported</td>
</tr>
<tr>
<td>21</td>
<td>High Speed Support</td>
</tr>
<tr>
<td>HSS</td>
<td>This bit indicates whether the uSDHC supports High Speed mode and the Host System can supply a SD Clock frequency from 25 MHz to 50 MHz.</td>
</tr>
<tr>
<td></td>
<td>0b - High Speed Not Supported</td>
</tr>
<tr>
<td></td>
<td>1b - High Speed Supported</td>
</tr>
<tr>
<td>20</td>
<td>ADMA Support</td>
</tr>
<tr>
<td>ADMAS</td>
<td>This bit indicates whether the uSDHC supports the ADMA feature.</td>
</tr>
<tr>
<td></td>
<td>0b - Advanced DMA Not supported</td>
</tr>
<tr>
<td></td>
<td>1b - Advanced DMA Supported</td>
</tr>
<tr>
<td>19</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>18-16</td>
<td>Max Block Length</td>
</tr>
<tr>
<td>MBL</td>
<td>This value indicates the maximum block size that the Host Driver can read and write to the buffer in the uSDHC. The buffer shall transfer block size without wait cycles.</td>
</tr>
<tr>
<td></td>
<td>000b - 512 bytes</td>
</tr>
<tr>
<td></td>
<td>001b - 1024 bytes</td>
</tr>
<tr>
<td></td>
<td>010b - 2048 bytes</td>
</tr>
<tr>
<td></td>
<td>011b - 4096 bytes</td>
</tr>
<tr>
<td>15-14</td>
<td>Retuning Mode</td>
</tr>
<tr>
<td>RETUNING_MODE</td>
<td>This bit selects retuning method.</td>
</tr>
<tr>
<td></td>
<td>00b - Mode 1</td>
</tr>
<tr>
<td></td>
<td>01b - Mode 2</td>
</tr>
<tr>
<td></td>
<td>10b - Mode 3</td>
</tr>
<tr>
<td></td>
<td>11b - Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Use Tuning for SDR50</td>
</tr>
<tr>
<td>USE_TUNING_SDR50</td>
<td>This bit is set to 1. Host controller requires tuning to operate SDR50</td>
</tr>
<tr>
<td></td>
<td>0b - SDR does not require tuning</td>
</tr>
<tr>
<td></td>
<td>1b - SDR50 requires tuning</td>
</tr>
<tr>
<td>12</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>11-8</td>
<td>Time Counter for Retuning</td>
</tr>
<tr>
<td>TIME_COUNT_RETUNING</td>
<td>This bit indicates an initial value of the Retuning Timer for Re-Tuning Mode1 and 3.Setting to 0 disables Retuning Timer.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field and Function

<table>
<thead>
<tr>
<th></th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-3</td>
<td>-</td>
</tr>
<tr>
<td>2</td>
<td>DDR50 support</td>
</tr>
<tr>
<td></td>
<td>This bit indicates support of DDR50 mode.</td>
</tr>
<tr>
<td>1</td>
<td>SDR104 support</td>
</tr>
<tr>
<td></td>
<td>This bit indicates support of SDR104 mode.</td>
</tr>
<tr>
<td>0</td>
<td>SDR50 support</td>
</tr>
<tr>
<td></td>
<td>This bit indicates support of SDR50 mode.</td>
</tr>
</tbody>
</table>

### 26.9.1.19 Watermark Level (WTMK_LVL)

#### 26.9.1.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WTMK_LVL</td>
<td>44h</td>
</tr>
</tbody>
</table>

#### 26.9.1.19.2 Function

Both write and read watermark levels (FIFO threshold) are configurable. There value can range from 1 to 128 words. Both write and read burst lengths are also configurable. There value can range from 1 to 31 words.

#### 26.9.1.19.3 Diagram

```

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>WR_BRST_LEN</th>
<th>WR_WML</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RD_BRST_LEN</th>
<th>RD_WML</th>
</tr>
</thead>
</table>
```
### 26.9.1.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>28-24</td>
<td>WR_BRST_LEN</td>
</tr>
<tr>
<td></td>
<td>Write Burst Length Due to system restriction, the actual burst length may not exceed 16. The number of words the uSDHC writes in a single burst. The write burst length must be less than or equal to the write watermark level, and all bursts within a watermark level transfer will be in back-to-back mode. On reset, this field will be 8. Writing 0 to this field will result in '01000' (i.e. it is not able to clear this field).</td>
</tr>
<tr>
<td>23-16</td>
<td>WR_WML</td>
</tr>
<tr>
<td></td>
<td>Write Watermark Level</td>
</tr>
<tr>
<td></td>
<td>The number of words used as the watermark level (FIFO threshold) in a DMA write operation. Also the number of words as a sequence of write bursts in back-to-back mode. The maximum legal value for the write watermark level is 128.</td>
</tr>
<tr>
<td>15-13</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>12-8</td>
<td>RD_BRST_LEN</td>
</tr>
<tr>
<td></td>
<td>Read Burst Length Due to system restriction, the actual burst length may not exceed 16. The number of words the uSDHC reads in a single burst. The read burst length must be less than or equal to the read watermark level, and all bursts within a watermark level transfer will be in back-to-back mode. On reset, this field will be 8. Writing 0 to this field will result in '01000' (i.e. it is not able to clear this field).</td>
</tr>
<tr>
<td>7-0</td>
<td>RD_WML</td>
</tr>
<tr>
<td></td>
<td>Read Watermark Level</td>
</tr>
<tr>
<td></td>
<td>The number of words used as the watermark level (FIFO threshold) in a DMA read operation. Also the number of words as a sequence of read bursts in back-to-back mode. The maximum legal value for the read watermark level is 128.</td>
</tr>
</tbody>
</table>

### 26.9.1.20 Mixer Control (MIX_CTRL)

#### 26.9.1.20.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MIX_CTRL</td>
<td>48h</td>
</tr>
</tbody>
</table>

#### 26.9.1.20.2 Function

This register is used to DMA and data transfer. To prevent data loss, the software should check if data transfer is active before writing this register. These bits are DPSEL, MBSEL, DTDSEL, AC12EN, BCEN, and DMAEN.
Table 26-13. Transfer Type Register Setting for Various Transfer Types

<table>
<thead>
<tr>
<th>Multi/Single Block Select</th>
<th>Block Count Enable</th>
<th>Block Count</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Don't Care</td>
<td>Don't Care</td>
<td>Single Transfer</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Don't Care</td>
<td>Infinite Transfer</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Positive Number</td>
<td>Multiple Transfer</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Zero</td>
<td>No Data Transfer</td>
</tr>
</tbody>
</table>

26.9.1.20.3  Diagram

26.9.1.20.4  Fields

Table continues on the next page...
## uSDHC Memory Map/Register Definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>FBCLK_SEL</td>
</tr>
</tbody>
</table>
| AUTO_TUNE_EN | Feedback Clock Source Selection (Only used for SD3.0, SDR104 mode and EMMC HS200 mode)  
| 0b - Feedback clock comes from the loopback CLK  
| 1b - Feedback clock comes from the ipp_card_clk_out |
| 24     | Auto Tuning Enable (Only used for SD3.0, SDR104 mode and and EMMC HS200 mode)  
| 0b - Disable auto tuning  
| 1b - Enable auto tuning |
| 23     | SMP_CLK_SEL |
| EXE_TUNE | When STD_TUNING_EN is 0, this bit is used to select Tuned clock or Fixed clock to sample data / cmd (Only used for SD3.0, SDR104 mode and EMMC HS200 mode)  
| 0b - Fixed clock is used to sample data / cmd  
| 1b - Tuned clock is used to sample data / cmd |
| 22     | Execute Tuning: (Only used for SD3.0, SDR104 mode and and EMMC HS200 mode)  
| 0b - Not Tuned or Tuning Completed  
| 1b - Execute Tuning |
| 21-8   | Reserved |
| 7      | AC23EN |
| 6      | NIBBLE_POS |
| 5      | MSBSEL |
| 4      | DTDSEL |
| 3      | DDR_EN |
| 2      | AC12EN |

---

Table continues on the next page...
### Field | Function
--- | ---
| | 0b - Disable  
1b - Enable |
| 1 | Block Count Enable  
This bit is used to enable the Block Count register, which is only relevant for multiple block transfers. When this bit is 0, the internal counter for block is disabled, which is useful in executing an infinite transfer.  
0b - Disable  
1b - Enable |
| 0 | DMA Enable  
This bit enables DMA functionality. If this bit is set to 1, a DMA operation shall begin when the Host Driver sets the DPSEL bit of this register. Whether the Simple DMA or the Advanced DMA is active depends on the DMA Select field of the Protocol Control register.  
0b - Disable  
1b - Enable |

#### 26.9.1.21 Force Event (FORCE_EVENT)

##### 26.9.1.21.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FORCE_EVENT</td>
<td>50h</td>
</tr>
</tbody>
</table>

##### 26.9.1.21.2 Function

The Force Event Register is not a physically implemented register. Rather, it is an address at which the Interrupt Status Register can be written if the corresponding bit of the Interrupt Status Enable Register is set. This register is a write only register and writing 0 to it has no effect. Writing 1 to this register actually sets the corresponding bit of Interrupt Status Register. A read from this register always results in 0's. In order to change the corresponding status bits in the Interrupt Status Register, make sure to set IPGEN bit in System Control Register so that IPG_CLK is always active.

Forcing a card interrupt will generate a short pulse on the DATA1 line, and the driver may treat this interrupt as a normal interrupt. The interrupt service routine may skip polling the card interrupt factor as the interrupt is self cleared.
### 26.9.1.21.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
<td>FEVTINT</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 26.9.1.21.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 FEVTINT</td>
<td>Force Event Card Interrupt</td>
</tr>
<tr>
<td></td>
<td>Writing 1 to this bit generates a short low-level pulse on the internal DATA1 line, as if a self clearing interrupt was received from the external card. If enabled, the CINT bit will be set and the interrupt service routine may treat this interrupt as a normal interrupt from the external card.</td>
</tr>
<tr>
<td>30-29</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>28 FEVTDMAE</td>
<td>Force Event DMA Error</td>
</tr>
<tr>
<td></td>
<td>Forces the DMAE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>27</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>26 FEVTNTE</td>
<td>Force Tuning Error</td>
</tr>
<tr>
<td></td>
<td>Forces the TNE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>25</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>24 FEVTAC12E</td>
<td>Force Event Auto Command 12 Error</td>
</tr>
<tr>
<td></td>
<td>Forces the AC12E bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>23</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Force Event Data End Bit Error</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>FEVTDEBE</td>
<td>Forces the DEBE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>21</td>
<td>Force Event Data CRC Error</td>
</tr>
<tr>
<td>FEVTDCE</td>
<td>Forces the DCE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>20</td>
<td>Force Event Data Time Out Error</td>
</tr>
<tr>
<td>FEVTDTOE</td>
<td>Force the DTOE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>19</td>
<td>Force Event Command Index Error</td>
</tr>
<tr>
<td>FEVTCIE</td>
<td>Forces the CCE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>18</td>
<td>Force Event Command End Bit Error</td>
</tr>
<tr>
<td>FEVTCEBE</td>
<td>Forces the CEBE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>17</td>
<td>Force Event Command CRC Error</td>
</tr>
<tr>
<td>FEVTCCE</td>
<td>Forces the CCE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>16</td>
<td>Force Event Command Time Out Error</td>
</tr>
<tr>
<td>FEVTCTOE</td>
<td>Forces the CTOE bit of Interrupt Status Register to be set.</td>
</tr>
<tr>
<td>15-8</td>
<td>-</td>
</tr>
<tr>
<td>7</td>
<td>Force Event Command Not Executed By Auto Command 12 Error</td>
</tr>
<tr>
<td>FEVTAC12C</td>
<td>Forces the CNIBAC12E bit in the Auto Command12 Error Status Register to be set.</td>
</tr>
<tr>
<td>6-5</td>
<td>-</td>
</tr>
<tr>
<td>4</td>
<td>Force Event Auto Command 12 Index Error</td>
</tr>
<tr>
<td>FEVTAC12IE</td>
<td>Forces the AC12IE bit in the Auto Command12 Error Status Register to be set.</td>
</tr>
<tr>
<td>3</td>
<td>Force Event Auto Command 12 End Bit Error</td>
</tr>
<tr>
<td>FEVTAC12EBE</td>
<td>Forces the AC12EBE bit in the Auto Command12 Error Status Register to be set.</td>
</tr>
<tr>
<td>2</td>
<td>Force Event Auto Command 12 CRC Error</td>
</tr>
<tr>
<td>FEVTAC12CE</td>
<td>Forces the AC12CE bit in the Auto Command12 Error Status Register to be set.</td>
</tr>
<tr>
<td>1</td>
<td>Force Event Auto Command 12 Time Out Error</td>
</tr>
<tr>
<td>FEVTAC12TOE</td>
<td>Forces the AC12TOE bit in the Auto Command12 Error Status Register to be set.</td>
</tr>
<tr>
<td>0</td>
<td>Force Event Auto Command 12 Not Executed</td>
</tr>
<tr>
<td>FEVTAC12NE</td>
<td>Forces the AC12NE bit in the Auto Command12 Error Status Register to be set.</td>
</tr>
</tbody>
</table>

### 26.9.1.22 ADMA Error Status Register (ADMA_ERR_STATUS)

#### 26.9.1.22.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADMA_ERR_STATUS</td>
<td>54h</td>
</tr>
</tbody>
</table>
26.9.1.22.2 Function

When an ADMA Error Interrupt has occurred, the ADMA Error States field in this register holds the ADMA state and the ADMA System Address register holds the address around the error descriptor.

For recovering from this error, the Host Driver requires the ADMA state to identify the error descriptor address as follows:

- **ST_STOP**: Previous location set in the ADMA System Address register is the error descriptor address.
- **ST_FDS**: Current location set in the ADMA System Address register is the error descriptor address.
- **ST_CADR**: This state is never set because it only increments the descriptor pointer and doesn't generate an ADMA error.
- **ST_TFR**: Previous location set in the ADMA System Address register is the error descriptor address.

In case of a write operation, the Host Driver should use the ACMD22 to get the number of the written block, rather than using this information, since unwritten data may exist in the Host Controller.

The Host Controller generates the ADMA Error Interrupt when it detects invalid descriptor data (Valid=0) in the ST_FDS state. The Host Driver can distinguish this error by reading the Valid bit of the error descriptor.

**Table 26-14. ADMA Error State Coding**

<table>
<thead>
<tr>
<th>D01-D00</th>
<th>ADMA Error State (when error has occurred)</th>
<th>Contents of ADMA System Address Register</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>ST_STOP (Stop DMA)</td>
<td>Holds the address of the next executable Descriptor command</td>
</tr>
<tr>
<td>01</td>
<td>ST_FDS (Fetch Descriptor)</td>
<td>Holds the valid Descriptor address</td>
</tr>
<tr>
<td>10</td>
<td>ST_CADR (Change Address)</td>
<td>No ADMA Error is generated</td>
</tr>
<tr>
<td>11</td>
<td>ST_TFR (Transfer Data)</td>
<td>Holds the address of the next executable Descriptor command</td>
</tr>
</tbody>
</table>
26.9.1.22.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

26.9.1.22.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>ADMADCE</td>
</tr>
<tr>
<td>ADMADCE</td>
<td>ADMA Descriptor Error</td>
</tr>
<tr>
<td></td>
<td>This error occurs when invalid descriptor fetched by ADMA.</td>
</tr>
<tr>
<td></td>
<td>• 0b - No Error</td>
</tr>
<tr>
<td></td>
<td>• 1b - Error</td>
</tr>
<tr>
<td>2</td>
<td>ADMALME</td>
</tr>
<tr>
<td>ADMALME</td>
<td>ADMA Length Mismatch Error</td>
</tr>
<tr>
<td></td>
<td>This error occurs in the following 2 cases:</td>
</tr>
<tr>
<td></td>
<td>• While the Block Count Enable is being set, the total data length specified by the Descriptor table is different from that specified by the Block Count and Block Length.</td>
</tr>
<tr>
<td></td>
<td>• Total data length cannot be divided by the block length.</td>
</tr>
<tr>
<td></td>
<td>• 0b - No Error</td>
</tr>
<tr>
<td></td>
<td>• 1b - Error</td>
</tr>
<tr>
<td>1-0</td>
<td>ADMAES</td>
</tr>
<tr>
<td>ADMAES</td>
<td>ADMA Error State (when ADMA Error is occurred)</td>
</tr>
<tr>
<td></td>
<td>This field indicates the state of the ADMA when an error has occurred during an ADMA data transfer.</td>
</tr>
<tr>
<td></td>
<td>Refer to ADMA Error Status Register (ADMA_ERR_STATUS) for more details.</td>
</tr>
</tbody>
</table>

26.9.1.23 ADMA System Address (ADMA_SYS_ADDR)
### 26.9.1.23.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADMA_SYS_ADDR</td>
<td>58h</td>
</tr>
</tbody>
</table>

### 26.9.1.23.2 Function

This register contains the physical system memory address used for ADMA transfers.

### 26.9.1.23.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### 26.9.1.23.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>ADMA System Address</td>
</tr>
<tr>
<td>ADS_ADDR</td>
<td>This register holds the word address of the executing command in the Descriptor table. At the start of ADMA, the Host Driver shall set the start address of the Descriptor table. The ADMA engine increments this register address whenever fetching a Descriptor command. When the ADMA is stopped at the Block Gap, this register indicates the address of the next executable Descriptor command. When the ADMA Error Interrupt is generated, this register shall hold the valid Descriptor address depending on the ADMA state. The lower 2 bits of this register is tied to '0' so the ADMA address is always word aligned. Since this register supports dynamic address reflecting, when TC bit is set, it automatically alters the value of internal address counter, so SW cannot change this register when TC bit is set. Such restriction is also listed in Software Restrictions.</td>
</tr>
<tr>
<td>1-0</td>
<td>- Reserved</td>
</tr>
</tbody>
</table>

### 26.9.1.24 DLL (Delay Line) Control (DLL_CTRL)
26.9.1.24.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DLL_CTRL</td>
<td>60h</td>
</tr>
</tbody>
</table>

26.9.1.24.2 Function
This register contains control bits for DLL.

26.9.1.24.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DLL_CTRL_REF_UPDATE_INT</td>
<td>DLL_CTRL_SLV_UPDATE_INT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DLL_CTRL_SLV_DLY_TARGET1</td>
</tr>
<tr>
<td>W</td>
<td>DLL_CTRL_SLV_OVERRIDE</td>
<td>DLL_CTRL_SLV_OVERRIDE</td>
<td>DLL_CTRL_GATE_UPDATE</td>
<td>DLL_CTRL_SLV_DLY_TARGET0</td>
<td>DLL_CTRL_SLV_FORCE_UPD</td>
<td>DLL_CTRL_RESET</td>
<td>DLL_CTRL_ENABLE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

26.9.1.24.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>DLL_CTRL_REF_UPDATE_INT</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| DLL_CTRL_REF_UPDATE_INT | DLL control loop update interval. The interval cycle is 
\[(2 + \text{REF\_UPDATE\_INT}) \times \text{REF\_CLOCK}\]. By default, the DLL control loop shall update every two \text{REF\_CLOCK} cycles. It should be noted that increasing the reference delay-line update interval reduces the ability of the DLL to adjust to fast changes in conditions that may effect the delay (such as voltage and temperature). |
| 27-20 | DLL_CTRL_SLV_UPDATE_INT |
| Slave delay line update interval. If default 0 is used, it means 256 cycles of \text{REF\_CLOCK}. A value of 0x0f results in 15 cycles and so on. Note that software can always cause an update of the slave-delay line using the SLV\_FORCE\_UPDATE register. Note that the slave delay line will also update automatically when the reference DLL transitions to a locked state (from an un-locked state). |
| 19 | - |
| Reserved |
| 18-16 | DLL_CTRL_SLV_DLY_TARGET1 |
| Refer to DLL_CTRL_SLV_DLY_TARGET0 below. |
| 15-9 | DLL_CTRL_SLV_OVERRIDE_VAL |
| When SLV\_OVER = 1 This field is used to select 1 of 128 physical taps manually. A value of 0 selects tap 1, and a value of 0x7f selects tap 128. |
| 8 | DLL_CTRL_SLV_OVERRIDE |
| Set this bit to 1 to Enable manual override for slave delay chain using SLV\_OVER\_VAL; to set 0 to disable manual override. This feature does not require the DLL to be enabled using the ENABLE bit. In fact to reduce power, if SLV\_OVER\_VAL is used, it is recommended to disable the DLL with ENABLE = 0. |
| 7 | DLL_CTRL_GATE_UPDATE |
| Set this bit to 1 to prevent the DLL from updating (since when clock_in exists, glitches may appear during DLL updates). This bit may be used by software if such a condition occurs. Clear the bit to 0 to allow the DLL to update automatically. |
| 6-3 | DLL_CTRL_SLV_DLY_TARGET0 |
| The delay target for the uSDHC loopback read clock can be programmed in 1/16th increments of an ref\_clock half-period. The delay is \[(({\text{DLL\_CTRL\_SLV\_DLY\_TARGET1}},\text{DLL\_CTRL\_SLV\_DLY\_TARGET0}) + 1) \times \text{REF\_CLOCK} / 2) / 16\] So the input read-clock can be delayed relative input data from \((\text{REF\_CLOCK} / 2) / 16\) to \((\text{REF\_CLOCK} / 2) / 4\). |
| 2 | DLL_CTRL_SLV_FORCE_UPD |
| Setting this bit to 1, forces the slave delay line to update to the DLL calibrated value immediately. The slave delay line shall update automatically based on the SLV\_UPDATE\_INT interval or when a DLL lock condition is sensed. Subsequent forcing of the slave-line update can only occur if SLV\_FORCE\_UP is set back to 0 and then asserted again (edge triggered). Be sure to use it when uSDHC is idle. This function may not work when uSDHC is working on data / cmd / response. |
| 1 | DLL_CTRL_RESET |
| Setting this bit to 1 force a reset on DLL. This will cause the DLL to lose lock and re-calibrate to detect an REF\_CLOCK half period phase shift. This signal is used by the DLL as edge-sensitive, so in order to create a subsequent reset, RESET must be taken low and then asserted again. |
| 0 | DLL_CTRL_ENABLE |
| Set this bit to 1 to enable the DLL and delay chain; otherwise; set to 0 to bypasses DLL. Note that using the slave delay line override feature with SLV\_OVER\_VAL, the DLL does not need to be enabled. |
26.9.1.25 DLL Status (DLL_STATUS)

26.9.1.25.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DLL_STATUS</td>
<td>64h</td>
</tr>
</tbody>
</table>

26.9.1.25.2 Function

This register contains the DLL status information. All bits are read only and will read the same as the power-reset value.

26.9.1.25.3 Diagram

![Diagram of DLL Status Register]

26.9.1.25.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16 Reserved</td>
<td>-</td>
</tr>
<tr>
<td>15-9 DLL_STS_REF_SEL</td>
<td>DLL_STS_REF_SEL</td>
</tr>
<tr>
<td>DLL_STS_REF_SEL</td>
<td>Reference delay line select taps. This is encoded by 7 bits for 127 taps.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8-2</td>
<td>DLL_STS_SLV_SEL</td>
<td>Slave delay line select status. This is the instant value generated from reference chain. Since the reference chain can only be updated when REF_CLOCK is detected, this value should be the right value to be updated when the reference is locked.</td>
</tr>
<tr>
<td>1</td>
<td>DLL_STS_REF_LOCK</td>
<td>Reference DLL lock status. This signifies that the DLL has detected and locked to a half-phase ref_clock shift, allowing the slave delay-line to perform programmed clock delays</td>
</tr>
<tr>
<td>0</td>
<td>DLL_STS_SLV_LOCK</td>
<td>Slave delay-line lock status. This signifies that a valid calibration has been set to the slave-delay line and that the slave-delay line is implementing the programmed delay value</td>
</tr>
</tbody>
</table>

### 26.9.1.26 CLK Tuning Control and Status (CLK_TUNE_CTRL_STATUS)

#### 26.9.1.26.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK_TUNE_CTRL_STATUS</td>
<td>68h</td>
</tr>
</tbody>
</table>

#### 26.9.1.26.2 Function

This register contains the Clock Tuning Control status information. All bits are read only and will read the same as the power-reset value. This register is added to support SD3.0 UHS-I SDR104 mode and EMMC HS200 mode.
### 26.9.1.26.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
</tr>
<tr>
<td>R</td>
</tr>
<tr>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
</tr>
<tr>
<td>R</td>
</tr>
<tr>
<td>W</td>
</tr>
<tr>
<td>Reset</td>
</tr>
</tbody>
</table>
```

### 26.9.1.26.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 PRE_ERR</td>
<td>PRE error which means the number of delay cells added on the feedback clock is too small. It is valid only when SMP_CLK_SEL of Mix control register (bit23 of 0x48) is enabled.</td>
</tr>
<tr>
<td>30-24 TAP_SEL_PRE</td>
<td>Reflects the number of delay cells added on the feedback clock between the feedback clock and CLK_PRE. When AUTO_TUNE_EN (bit24 of 0x48) is disabled, TAP_SEL_PRE is always equal to DLY_CELL_SET_PRE. When AUTO_TUNE_EN (bit24 of 0x48) is enabled, TAP_SEL_PRE will be updated automatically according to the status of the auto tuning circuit to adjust the sample clock phase.</td>
</tr>
<tr>
<td>23-20 TAP_SEL_OUT</td>
<td>Reflect the number of delay cells added on the feedback clock between CLK_PRE and CLK_OUT.</td>
</tr>
<tr>
<td>19-16 TAP_SEL_POST</td>
<td>Reflect the number of delay cells added on the feedback clock between CLK_OUT and CLK_POST.</td>
</tr>
<tr>
<td>15 NXT_ERR</td>
<td>NXT error which means the number of delay cells added on the feedback clock is too large. It’s valid only when SMP_CLK_SEL of Mix control register (bit23 of 0x48) is enabled.</td>
</tr>
<tr>
<td>14-8 DLY_CELL_SET_PRE</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 26.9.1.27 Vendor Specific Register (VEND_SPEC)

#### 26.9.1.27.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VEND_SPEC</td>
<td>C0h</td>
</tr>
</tbody>
</table>

#### 26.9.1.27.2 Function

This register contains the vendor specific control / status register.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>DLY_CELL_SET_PRE</td>
<td>Set the number of delay cells on the feedback clock between the feedback clock and CLK_PRE.</td>
</tr>
<tr>
<td>7-4 DLY_CELL_SET_OUT</td>
<td>DLY_CELL_SET_OUT Set the number of delay cells on the feedback clock between CLK_PRE and CLK_OUT.</td>
</tr>
<tr>
<td>3-0 DLY_CELL_SET_POST</td>
<td>DLY_CELL_SET_POST Set the number of delay cells on the feedback clock between CLK_OUT and CLK_POST.</td>
</tr>
</tbody>
</table>
26.9.1.27.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>CMD_BYTE_EN</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>W</td>
<td>CMD_BYTE_EN</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>CRC_CHK_DIS</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>CRC_CHK_DIS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

26.9.1.27.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 CMD_BYTE_EN</td>
<td>CMD_BYTE_EN</td>
</tr>
<tr>
<td></td>
<td>Byte access</td>
</tr>
<tr>
<td></td>
<td>0b - Disable</td>
</tr>
<tr>
<td></td>
<td>1b - Enable</td>
</tr>
<tr>
<td>30</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved. Always write as 0.</td>
</tr>
<tr>
<td>29</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved. Always write as 1.</td>
</tr>
<tr>
<td>28</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved. Always write as 0.</td>
</tr>
<tr>
<td>27-24</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved. Always write as 4'b0000.</td>
</tr>
<tr>
<td>23-16</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>Reserved. Always write as 8'h00.</td>
</tr>
<tr>
<td>15 CRC_CHK_DIS</td>
<td>CRC Check Disable</td>
</tr>
<tr>
<td></td>
<td>0b - Check CRC16 for every read data packet and check CRC bits for every write data packet</td>
</tr>
<tr>
<td></td>
<td>1b - Ignore CRC16 check for every read data packet and ignore CRC bits check for every write data packet</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 26.9.1.28 MMC Boot Register (MMC_BOOT)

#### 26.9.1.28.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MMC_BOOT</td>
<td>C4h</td>
</tr>
</tbody>
</table>

#### 26.9.1.28.2 Function

This register contains the MMC Fast Boot control register.

### Field | Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>14-11</td>
<td>-</td>
</tr>
<tr>
<td>10</td>
<td>-</td>
</tr>
<tr>
<td>9</td>
<td>-</td>
</tr>
</tbody>
</table>
| 8     | FRC_SDCLK_O N | Force CLK output active  
| |  - 0b - CLK active or inactive is fully controlled by the hardware.  
| |  - 1b - Force CLK active.  |
| 7-4   | -        |
| 3     | AC12_WR_CHK BUSY_EN | Check busy enable after auto CMD12 for write data packet  
| |  - 0b - Do not check busy after auto CMD12 for write data packet  
| |  - 1b - Check busy after auto CMD12 for write data packet  |
| 2     | CONFLICT_CHK_EN | Conflict check enable.  
| |  - 0b - Conflict check disable  
| |  - 1b - Conflict check enable  |
| 1     | VSELECT | Voltage Selection  
| |  - Change the value of output signal VSELECT, to control the voltage on pads for external card. There must be a control circuit out of uSDHC to change the voltage on pads.  
| |  - 0b - Change the voltage to high voltage range, around 3.0 V  
| |  - 1b - Change the voltage to low voltage range, around 1.8 V  |
| 0     | -        |

### 26.9.1.28 MMC Boot Register (MMC_BOOT)

This register contains the MMC Fast Boot control register.
26.9.1.28.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>BOOT_BLK_CNT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>DISABLE_TIME_OUT</td>
<td>AUTO_SABG_EN</td>
<td>BOOT_EN</td>
<td>BOOT_MODE</td>
<td>DTOCV_ACK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

26.9.1.28.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16 BOOT_BLK_CNT</td>
<td>The value defines the Stop At Block Gap value of automatic mode. When received card block cnt is equal to (BLK_CNT - BOOT_BLK_CNT) and AUTO_SABG_EN is 1, then Stop At Block Gap. Here, BLK_CNT is defined in the Block Attributes Register, bit31 - 16 of 0x04.</td>
</tr>
<tr>
<td>15-9 -</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 8 DISABLE_TIME_OUT | Disable Time Out

**NOTE:** When this bit is set, there is no timeout check no matter whether BOOT_EN is set or not.

- 0b - Enable time out
- 1b - Disable time out

| 7 AUTO_SABG_EN | During boot, enable auto stop at block gap function. This function will be triggered, and host will stop at block gap when received card block cnt is equal to (BLK_CNT - BOOT_BLK_CNT). |
| 6 BOOT_EN | Boot mode enable

- 0b - Fast boot disable
- 1b - Fast boot enable

| 5 BOOT_MODE | Boot mode select

- 0b - Normal boot
- 1b - Alternative boot

| 4 BOOT_ACK | |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>BOBT_ACK</td>
<td>Boot ACK mode select</td>
</tr>
<tr>
<td></td>
<td>0b - No ack</td>
</tr>
<tr>
<td></td>
<td>1b - Ack</td>
</tr>
<tr>
<td>3-0</td>
<td>DTOCV_ACK</td>
</tr>
<tr>
<td>DTOCV_ACK</td>
<td>Boot ACK time out counter value.</td>
</tr>
<tr>
<td></td>
<td>0000b - SDCLK x 2^14</td>
</tr>
<tr>
<td></td>
<td>0001b - SDCLK x 2^15</td>
</tr>
<tr>
<td></td>
<td>0010b - SDCLK x 2^16</td>
</tr>
<tr>
<td></td>
<td>0011b - SDCLK x 2^17</td>
</tr>
<tr>
<td></td>
<td>0100b - SDCLK x 2^18</td>
</tr>
<tr>
<td></td>
<td>0101b - SDCLK x 2^19</td>
</tr>
<tr>
<td></td>
<td>0110b - SDCLK x 2^20</td>
</tr>
<tr>
<td></td>
<td>0111b - SDCLK x 2^21</td>
</tr>
<tr>
<td></td>
<td>1110b - SDCLK x 2^28</td>
</tr>
<tr>
<td></td>
<td>1111b - SDCLK x 2^29</td>
</tr>
</tbody>
</table>

### 26.9.1.29 Vendor Specific 2 Register (VEND_SPEC2)

#### 26.9.1.29.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VEND_SPEC2</td>
<td>C8h</td>
</tr>
</tbody>
</table>

#### 26.9.1.29.2 Function

This register contains the vendor specific control 2 register.
**26.9.1.29.3  Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BUS_RST</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PART_DLL_DEBUG</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**26.9.1.29.4  Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>-</td>
</tr>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>BUS_RST</td>
</tr>
<tr>
<td>BUS_RST</td>
<td>Reset internal bus logic before RST_ALL or RST_DATA to avoid bus hang.</td>
</tr>
<tr>
<td>13</td>
<td>PART_DLL_DEBUG</td>
</tr>
<tr>
<td>PART_DLL_DEBUG</td>
<td>Use to debug for part dll.</td>
</tr>
<tr>
<td>12</td>
<td>ACMD23_ARGU2_EN</td>
</tr>
<tr>
<td>ACMD23_ARGU2_EN</td>
<td>Argument2 register enable for ACMD23</td>
</tr>
<tr>
<td></td>
<td>0b - Disable</td>
</tr>
<tr>
<td></td>
<td>1b - Argument2 register enable for ACMD23 sharing with SDMA system address register. Default is enable.</td>
</tr>
<tr>
<td>11-10</td>
<td>-</td>
</tr>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>-</td>
</tr>
<tr>
<td>8-7</td>
<td>-</td>
</tr>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>TUNING_CMD_EN</td>
</tr>
<tr>
<td>TUNING_CMD_EN</td>
<td>Enable the auto tuning circuit to check the CMD line.</td>
</tr>
<tr>
<td></td>
<td>0b - Auto tuning circuit does not check the CMD line.</td>
</tr>
<tr>
<td></td>
<td>1b - Auto tuning circuit checks the CMD line.</td>
</tr>
<tr>
<td>5</td>
<td>TUNING_1bit_EN</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
---|---
TUNING\_1bit\_EN | Enable the auto tuning circuit to check the DATA0 only. It is used with the TUNING\_8bit\_EN together.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| TUNING\_8bit\_EN | Enable the auto tuning circuit to check the DATA[7:0]. It is used with the TUNING\_1bit\_EN together.  
**NOTE:** The format of these two bits are [TUNNING\_8bit\_EN:TUNNING\_1bit\_EN].  
0b00 - Tuning circuit only checks the DATA[3:0].  
0b01 - Tuning circuit only checks the DATA0.  
0b10 - Tuning circuit checks the whole DATA[7:0].  
0b11 - Invalid.  

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| CARD\_INT\_D3\_TEST | Card Interrupt Detection Test  
This bit only uses for debugging.  
0b - Check the card interrupt only when DATA3 is high.  
1b - Check the card interrupt by ignoring the status of DATA3.  

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>2-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 26.9.1.30 Tuning Control Register (TUNING\_CTRL)

#### 26.9.1.30.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TUNING_CTRL</td>
<td>CCh</td>
</tr>
</tbody>
</table>

#### 26.9.1.30.2 Function

The register contains configuration of tuning circuit.
### 26.9.1.30.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>STD_TUNING_EN</td>
<td>Reserved</td>
<td>TUNING_WINDOW</td>
<td>Reserved</td>
<td>TUNING_STEP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>STD_TUNING_EN</td>
<td>TUNING_WINDOW</td>
<td>TUNING_STEP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>TUNING_COUNTER</td>
<td>TUNING_START_TAP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>TUNING_COUNTER</td>
<td>TUNING_START_TAP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### 26.9.1.30.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-25</td>
<td>-</td>
</tr>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>STD_TUNING_EN</td>
</tr>
<tr>
<td>STD_TUNING_EN</td>
<td>Standard tuning circuit and procedure enable:</td>
</tr>
<tr>
<td></td>
<td>This bit is used to enable standard tuning circuit and procedure.</td>
</tr>
<tr>
<td>23</td>
<td>-</td>
</tr>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>22-20</td>
<td>TUNING_WINDOW</td>
</tr>
<tr>
<td>TUNING_WINDOW</td>
<td>Select data window value for auto tuning</td>
</tr>
<tr>
<td>19</td>
<td>-</td>
</tr>
<tr>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>18-16</td>
<td>TUNING_STEP</td>
</tr>
<tr>
<td>TUNING_STEP</td>
<td>The increasing delay cell steps in tuning procedure.</td>
</tr>
<tr>
<td>15-8</td>
<td>TUNING_COUNTER</td>
</tr>
<tr>
<td>TUNING_COUNTER</td>
<td>The MAX repeat CMD19 times in tuning procedure.</td>
</tr>
<tr>
<td>7-0</td>
<td>TUNING_START_TAP</td>
</tr>
<tr>
<td>TUNING_START_TAP</td>
<td>The start dealy cell point when send first CMD19 in tuning procedure.</td>
</tr>
</tbody>
</table>
Chapter 27
FlexSPI Controller

27.1 Chip-specific FlexSPI information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

**NOTE**
The soft reset bit (MCR_SWRESET) should be set, to enable the inverted clock, after setting the SCKBDIFFOPT bit.

**NOTE**
Octal mode is supported by combining SIOA[3:0] and SIOB[3:0], on this device.

27.1.1 Master ID allocation

This table summarizes the master IDs for all system master modules:

<table>
<thead>
<tr>
<th>Module</th>
<th>Master ID</th>
</tr>
</thead>
<tbody>
<tr>
<td>Core Platform</td>
<td>000b</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 27-2. Master IDs (continued)

<table>
<thead>
<tr>
<th>Module</th>
<th>Master ID</th>
</tr>
</thead>
<tbody>
<tr>
<td>eDMA</td>
<td>001b</td>
</tr>
<tr>
<td>DCP</td>
<td>010b</td>
</tr>
<tr>
<td>All others</td>
<td>011b</td>
</tr>
</tbody>
</table>

27.2 Overview

Flexible Serial Peripheral Interface (FlexSPI) host controller supports two SPI channels and up to 4 external devices. Each channel supports Single/Dual/Quad/Octal mode data transfer (1/2/4/8 bidirectional data lines).

NOTE

FlexSPI configuration is dependent on the chip configuration. Please refer to the system-level sections for boot and pinmux for chip specific information regarding the modes and number of devices supported.

27.2.1 Features

FlexSPI block supports following features:

- Flexible sequence engine (LUT table) to support various vendor devices
  - Serial NOR Flash or other device with similar SPI protocol as Serial NOR Flash
  - Serial NAND Flash
  - HyperBus device (HyperFlash/HyperRAM)
  - FPGA device
- Flash access mode
  - Single/Dual/Quad/Octal mode
  - SDR/DDR mode
  - Individual/Parallel mode
- Support sampling clock mode:
  - Internal dummy read strobe loopbacked internally
  - Internal dummy read strobe loopbacked from pad
  - Flash provided read strobe
- Memory mapped read/write access by AHB Bus
  - AHB RX Buffer implemented to reduce read latency. See the chip-specific section for AHB buffer size.
  - 16 AHB masters supported with priority for read access
• 4 flexible and configurable buffers in AHB RX Buffer
• AHB TX Buffer implemented to buffer all write data from one AHB burst. AHB TX Buffer size: 8 * 64 Bits
• All AHB masters share this AHB TX Buffer. No AHB master number limitation for Write Access.
• Software triggered Flash read/write access by IP Bus
• IP RX FIFO implemented to buffer all read data from External device. FIFO size: 16 * 64 Bits
• IP TX FIFO implemented to buffer all Write data to External device. FIFO size: 16 * 64 Bits
• DMA support to fill IP TX FIFO
• DMA support to read IP RX FIFO
• SCLK stopped when reading flash data and IP RX FIFO is full
• SCLK stopped when writing flash data and IP TX FIFO is empty

27.2.2 Block diagram

The block diagram of FlexSPI is indicated in following figure:

![FlexSPI Block Diagram](image)

Figure 27-1. FlexSPI block diagram

27.2.3 Operation Modes

This section provides information about the modes FlexSPI could be used.

• Module Disable mode

  This mode is low power mode in FlexSPI module.
In module disable mode, AHB clock and serial clock domain will be gated off internally, but IPS Bus clock is not gated off. Control and status register read/write access is available except LUT/IP RX FIFO/IP TX FIFO read/write access. Serial Flash Memory access is also not available.

This mode is entered by setting MCR0[MDIS], and exited by clearing MCR0[MDIS].

• Doze mode

This mode is low power mode in SOC system.

When the system requires FlexSPI to enter doze mode and MCR0[DOZEEN] is set, the FlexSPI will wait for all transactions to complete (STS0[ARBIDLE]=0x1) and enter doze mode. In doze mode, the AHB clock and serial clock domain will be gated off internally, but IPS Bus clock is not gated off. Control and status register read/write access is available except LUT/IP RX FIFO/IP TX FIFO read/write access. Serial Flash Memory access is also not available.

This mode is entered by system request, and exited by deasserting this system request.

• Stop mode

This mode is low power mode in SOC system.

When the system requires FlexSPI to enter stop mode, FlexSPI will wait for all transactions to complete (STS0[ARBIDLE]=0x1) and return ACK handshake to system. After ACK handshake returned, IP will gate off the AHB clock and serial clock domain internally, the system can gate the AHB Bus clock, IPS Bus clock and serial clock in system level.

This mode is entered by system stop mode request. When all command sequences finish, FlexSPI enters stop mode and returns ACK handshake. This mode is exited by deasserting system stop mode request, the ACK handshake is also deasserted immediately.

• Normal mode

In normal mode, all clocks are not gated internally. Normal register access and serial flash memory access is available.
## 27.3 Glossary for FlexSPI module

### Table 27-3. Glossary

<table>
<thead>
<tr>
<th>Term</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>AHB Command</td>
<td>AHB Command is one or several Serial Flash Memory access command sequences triggered by AHB read/write access to AHB address ranged mapped for Serial Flash Memory.</td>
</tr>
<tr>
<td>ASFM_BASE</td>
<td>Base address of AHB address space mapped to Serial Flash Memory.</td>
</tr>
<tr>
<td>Set</td>
<td>Write 1 to register bit to establish logic level one on the bit.</td>
</tr>
<tr>
<td>Clear</td>
<td>Write 0 to register bit to establish logic level zero on the bit.</td>
</tr>
<tr>
<td>Command Sequence</td>
<td>A command sequence is 4*32 bits sequence code consisting of up to 8 instructions.</td>
</tr>
<tr>
<td></td>
<td>Command sequence should be programmed in LUT according to Flash command.</td>
</tr>
<tr>
<td></td>
<td>When a command sequence executed, the chip selection signal becomes asserted.</td>
</tr>
<tr>
<td></td>
<td>When a command sequence execution finished, the chip selection signal becomes negated.</td>
</tr>
<tr>
<td>DDR</td>
<td>Dual data transfer rate for flash access mode</td>
</tr>
<tr>
<td></td>
<td>Flash receive data on both SCLK rise and fall edge and transmit data on both SCLK rise and fall edge.</td>
</tr>
<tr>
<td>Endianness</td>
<td>Byte Ordering scheme.</td>
</tr>
<tr>
<td>Field</td>
<td>Two or more register bits grouped together.</td>
</tr>
<tr>
<td>Fill</td>
<td>To add entries to a FIFO by software or hardware.</td>
</tr>
<tr>
<td>Instruction Code</td>
<td>16 bits code defining the type of command to be executed on FlexSPI interface.</td>
</tr>
<tr>
<td>IP Command</td>
<td>IP Command is one or several Serial Flash Memory access command sequences triggered by set register bit IPCMD.TRG.</td>
</tr>
<tr>
<td>Negated</td>
<td>A signal that is negated is in its inactive state. An active low signal changes from logic level 0 to logic level 1 when negated, and an active high signal changes from logic level 1 to logic level 0.</td>
</tr>
<tr>
<td>SDR</td>
<td>Single data transfer rate for flash access mode</td>
</tr>
<tr>
<td></td>
<td>Flash receive data on SCLK rise edge and transmit data on SCLK fall edge.</td>
</tr>
<tr>
<td>Set</td>
<td>To set a bit or bits means to establish logic level one on the bit or bits.</td>
</tr>
<tr>
<td>SFM</td>
<td>Serial Flash Memory</td>
</tr>
<tr>
<td>Individual Mode</td>
<td>Access to a single, individual serial flash device at a time.</td>
</tr>
<tr>
<td>Parallel Mode</td>
<td>Read/Program Access to two serial flash devices in parallel (Port A and Port B).</td>
</tr>
<tr>
<td></td>
<td>FlexSPI will split flash program data before transmitting to Flash or merge flash read data before putting into IP RX FIFO or AHB RX Buffer automatically.</td>
</tr>
<tr>
<td>Memory Command</td>
<td>Serial access Command for reading/programming/configuring.</td>
</tr>
<tr>
<td></td>
<td>A memory command may consist one or several command sequences, for each command sequence the Chip selection signal will be asserted and deasserted once.</td>
</tr>
<tr>
<td>LUT</td>
<td>Look-up table to preserve command sequence.</td>
</tr>
<tr>
<td></td>
<td>LUT is programmed by software with command sequences which is used to issue memory commands.</td>
</tr>
</tbody>
</table>
### 27.4 External Signal Description

This section provides the external signal information of the FlexSPI module.

**Table 27-4. External Signal List**

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Function</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>A_SS0_B</td>
<td>Peripheral Chip Select Flash A1</td>
<td>O</td>
<td>This signal is the chip select for the serial flash device A1. Port name: PCSA1</td>
</tr>
<tr>
<td>A_SS1_B</td>
<td>Peripheral Chip Select Flash A2</td>
<td>O</td>
<td>This signal is the chip select for the serial flash device A2. Port name: PCSA2</td>
</tr>
<tr>
<td>B_SS0_B</td>
<td>Peripheral Chip Select Flash B1</td>
<td>O</td>
<td>This signal is the chip select for the serial flash device B1. Port name: PCSB1</td>
</tr>
<tr>
<td>B_SS1_B</td>
<td>Peripheral Chip Select Flash B2</td>
<td>O</td>
<td>This signal is the chip select for the serial flash device B2. Port name: PCSB2</td>
</tr>
<tr>
<td>A_SCLK</td>
<td>Serial Clock Flash A</td>
<td>O</td>
<td>This signal is the serial clock output to the serial flash device A. Half clock frequency of serial clock root in DDR mode, and same frequency as serial clock root in SDR mode. Clock output toggles during the whole flash access sequence. Port name: SCKA</td>
</tr>
<tr>
<td>B_SCLK</td>
<td>Serial Clock Flash B</td>
<td>O</td>
<td>This signal is the serial clock output to the serial flash device B. Half clock frequency of serial clock root in DDR mode, and same frequency as serial clock root in SDR mode. Clock output toggles during the whole flash access sequence.</td>
</tr>
<tr>
<td>A_DATAn</td>
<td>Serial I/O Flash A</td>
<td>I/O</td>
<td>These signals are the data I/O lines to/from the serial flash device A. Port name: SIOAn</td>
</tr>
<tr>
<td>B_DATAn</td>
<td>Serial I/O Flash B</td>
<td>I/O</td>
<td>These signals are the data I/O lines to/from the serial flash device B. Port name: SIOBn</td>
</tr>
<tr>
<td>A_DQS</td>
<td>Data Strobe signal Flash A</td>
<td>I/O</td>
<td>Data strobe signal for port A. There are three functions for this signal:</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 27-4. External Signal List (continued)

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Function</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Driven with Read Strobe by external device:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Some flash devices provide the Read Strobe signal together with Read data. In this case, this pad may need a pull down resistor if external device drives this pad only when reading flash data.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Driven with Latency Information by external device:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Certain devices use this pin to indicate the dummy cycles needed (before Program/Read data transfer) such as HyperRAM/HyperFlash.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• Loopback dummy read strobe:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>FlexSPI controller provides internal dummy read strobe for flash read data. Higher read frequency can be achieved by looping back this dummy read strobe from pad. This pin can be floated or put some cap loads on board level to compensate DATA/SCLK pins load.</td>
</tr>
<tr>
<td>B_DQS</td>
<td>Data Strobe signal Flash B</td>
<td>I/O</td>
<td>Similar to A_DQS.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Port name: DQSA</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Port name: DQSB</td>
</tr>
</tbody>
</table>

27.5 Functional description

The following sections describe functional details of the FlexSPI module.

27.5.1 Clocks

This section describes clocks and special clocking requirements of the FlexSPI module.

Table 27-5. Clock Usage

<table>
<thead>
<tr>
<th>Clock Name</th>
<th>Description</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>serial clock root (ipg_clk_sfck)</td>
<td>Root clock for Serial domain</td>
<td>-</td>
</tr>
<tr>
<td>ahb clock (hclk)</td>
<td>AHB Bus clock</td>
<td>-</td>
</tr>
<tr>
<td>ipg clock (ipg_clk)</td>
<td>IPS Bus clock</td>
<td>-</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 27-5. Clock Usage (continued)

<table>
<thead>
<tr>
<th>Clock Name</th>
<th>Description</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>DQS_OUT</td>
<td>Dummy Read Strobe output</td>
<td>Same frequency as SCLK. Clock output toggles during READ/LEARN instructions.</td>
</tr>
<tr>
<td>DQS_IN</td>
<td>Sample clock for RX Data</td>
<td>Same frequency as SCLK. Sample clock comes from loopbacked dummy read strobe, loopbacked SCLK or Flash provided read strobe.</td>
</tr>
</tbody>
</table>

27.5.2 Interrupts

This section describes all the interrupts that the FlexSPI module generates.

- **IP command done interrupt**
  
  When IP command is finished, there will be interrupt generated if INTEN[IPCMDDONEEN] is set to 0x1.

- **IP command grant error interrupt**
  
  When IP command grant timeout (not grant after MCR0[IPGRANTWAIT] * 1024 ahb clock cycles), there will be interrupt generated if INTEN[IPCMCMDGEEN] is set to 0x1.

- **AHB command grant error interrupt**
  
  When AHB command grant timeout (not grant after MCR0[AHBGRANTWAIT] * 1024 ahb clock cycles), there will be interrupt generated if INTEN[AHBCMDGEEN] is set to 0x1.

- **IP command error interrupt**
  
  When there is command check error or command execution error for IP command, there will be interrupt generated if INTEN[IPCMDERREN] is set to 0x1. Refer Overview of Error Flags for more details.

- **AHB command error interrupt**
  
  When there is command check error or command execution error for AHB command, there will be interrupt generated if INTEN[AHBCMDERREN] is set to 0x1. Refer Overview of Error Flags for more details.

- **IP RX FIFO watermark available interrupt**
When the fill level of IP RX FIFO is no less than watermark level (IPRXFCR[RXWMRK]), there will be interrupt generated if INTEN[IPRXWAEN] is set to 0x1.

- **IP TX FIFO watermark exceed interrupt**
  When the empty level of IP TX FIFO is no less than watermark level (IPTXFCR[TXWMRK]), there will be interrupt generated if INTEN[IPRXWAEN] is set to 0x1.

- **Sequence execution timeout interrupt**
  When a sequence execution time exceeds the timeout wait time (MCRI[SEQWAIT]), an interrupt will be generated if INTEN[SEQTIMEOUTEN] is set to 0x1. For example, the following flash read command sequence will lasts about 8000000 cycle (ipg_clk_sfck). If SEQWAIT is set 0xFFFF, there will be sequence timeout interrupt generated.
    - Triggered by IP command
    - Flash read data size is 0x1000000 bytes
    - Flash accessed in Single mode and SDR mode,

- **AHB Bus timeout interrupt**
  When AHB bus response timeout, there will be interrupt generated if INTEN[AHBUSTIMEOUTEN] is set to 0x1. A typical case is AHB read sequence is not configured properly in LUT (such as without READ instruction). There will never be data read from external device, then FlexSPI will never hit the read data in AHB RX Buffers for AHB Read command.

- **SCLK stopped by write command interrupt**
  When IP TX FIFO is empty during write command sequence execution, FlexSPI will stop SCLK output clock toggling and wait for write data filling. At this time, this interrupt is generated if enabled by INTEN register.

- **SCLK stopped by read command interrupt**
  When IP RX FIFO is full during read command sequence execution, FlexSPI will stop SCLK output clock toggling and wait for read data read out from IP RX FIFO. At this time, this interrupt is generated if enabled by INTEN register.

### 27.5.3 Flash Connection

There are two FlexSPI interface ports (A port and B port). Each port supports 2 flash devices by providing 2 chip select outputs.
NOTE

FlexSPI configuration is dependent on the chip configuration. See the chip-specific FlexSPI information regarding the number of devices supported.

The connection diagram with 4 devices is as following:

![Flash connection diagram with four devices](image)

**Figure 27-2. Flash connection diagram with four devices**

NOTE

- Flash A1 and A2 could be two flash chip package or two flash die on the same package. There is no difference to FlexSPI. Same for Flash B1 and B2.
- Flash A1 and B1 could be accessed in parallel, using parallel mode. FlexSPI will merge/split the flash read/program data automatically. Same for A2 and B2.
- In parallel mode, A1 and A2 could not be accessed at the same time. Same for B1 and B2.
- In individual mode, A1, A2, B1 and B2 could not be accessed at the same time. But these four device could be accessed separately.

There is a combination mode to provide octal flash support by combining A port (A_DATA[3:0]) and B port (B_DATA[3:0]) together. The connection diagram for this combination mode is as following:
27.5.4 Flash Access mode

This section describes flash access mode.

27.5.4.1 SPI clock mode

FlexSPI supports only SPI clock mode 0: Clock polarity (CPOL)=0 and Clock Phase (CPHA)=0. SCLK will stay at logic low state when SPI bus is idle.

27.5.4.2 Flash Individual mode and Parallel mode

In individual mode, Flash read/write data is received/transmit on port A or port B.
In parallel mode, Flash read/write data is received/transmit on port A and B port parallely. FlexSPI will merge/split the flash read/program data automatically. Please note that only read/program data is merged/split (READ/WRITE instruction). For other instructions (such as Command/Address/Mode/Data size), same command code/address/mode bits/data size information will be transmit to port A and port B device. For more detail, please refer to Instruction execution on SPI interface.

Individual mode and parallel mode is determined statically by register field IPCR1[IPAREN] (for IP command) or AHBCR[APAREN] (for AHB command).

### 27.5.4.3 SDR mode and DDR mode

In SDR (Single Data transfer Rate) mode, Flash receives data on SCLK rise edge and transmit data on SCLK fall edge.

In DDR (Dual Data transfer Rate) mode, Flash receives data on both SCLK rise and fall edges and transmit data on both SCLK rise and fall edges.

SDR and DDR mode is determined by instruction (opcode) in LUT sequence dynamically. There is no static configuration register field setting for SDR and DDR mode. For more details about input and output timing, please refer to FlexSPI Input Timing and FlexSPI Output Timing.

### 27.5.4.4 Single, Dual, Quad, and Octal mode

In Single mode, flash transmit/receive data on 1 Data pin (DATA0 for transmitting, DATA1 for receiving).

In Dual mode, flash transmit/receive data on 2 Data pin (DATA0~DATA1 for both transmitting and receiving).

In Quad mode, flash transmit/receive data on 4 Data pin (DATA0~DATA3 for both transmitting and receiving).

In Octal mode, flash transmit/receive data on 8 Data pin (DATA0~DATA7 for both transmitting and receiving).

Single, Dual, Quad and Octal mode is determined by instruction (num_pads) in LUT sequence dynamically. There is no static configuration register field setting for Single, Dual, Quad and Octal mode.
27.5.5 Flash memory map

Flash memory map in individual and parallel mode is as following:

![Flash memory map in individual and parallel mode](image)

Flash memory map in individual mode:
- Flash A1 address range: 0x00000000 ~ FA1_SIZE
- Flash A2 address range: FA1_SIZE ~ (FA1_SIZE + FA2_SIZE)
- Flash B1 address range: (FA1_SIZE + FA2_SIZE) ~ (FA1_SIZE + FA2_SIZE + FB1_SIZE)
- Flash B2 address range: FA1_SIZE + FA2_SIZE + FB1_SIZE) ~ (FA1_SIZE + FA2_SIZE + FB1_SIZE + FB2_SIZE)

Flash memory map in parallel mode:
- Flash A1+B1 address range: 0x00000000 ~ FA1_SIZE*2
- Flash A2+B2 address range: FA1_SIZE*2 ~ (FA1_SIZE*2 + FA2_SIZE*2)

**NOTE**
- When MCR2[SAMEDEVICEEN] is set to 0x1, FA1_SIZE/FA2_SIZE/FB1_SIZE/FB2_SIZE = FLSHA1CR0[FLSHSZ] * 1KByte
- When MCR2[SAMEDEVICEEN] is set to 0x0, FA1_SIZE = FLSHA1CR0[FLSHSZ] * 1KByte; FA2_SIZE = FLSHA2CR0[FLSHSZ] * 1KByte; FB1_SIZE = FLSHB1CR0[FLSHSZ] * 1KByte; FB2_SIZE = FLSHB2CR0[FLSHSZ] * 1KByte
- Flash B1/B2 size setting are ignored in parallel mode (FLSB1CR0[FLSHSZ], FLSHB2CR0[FLSHSZ]). To
support parallel mode application, Flash B1 should be same device as A1 and Flash B2 should be same device as A2.

### 27.5.6 Flash address sent to Device

Flash access start address is determined by AHB address (AHB command) or IPCR0[SFAR] register (IP command). Refer Flash access by AHB Command and Flash access by IP Command for more details.

For AHB command, FlexSPI controller will remove flash base address automatically when sending flash address to devices. For IP command, the address in IPCR0[SFAR] should be the flash device’s address without base address. Flash address is sent to devices in two part: Row Address and Column Address. For flash devices not supporting Column address, please set register field FLSHxCR1[CAS] to 0. Then all flash address bits will be sent to Flash device as Row address. For flash device supporting word-addressable feature, the last bit of flash address is not needed because flash is read/programmed in terms of 2 bytes. For parallel mode, Flash A1/B1 (or A2/B2) is accessed parallely, so the flash address sent to flash device should be divided by 2. Following table indicates the relationship of Row/Column Address and flash address (FA)

<table>
<thead>
<tr>
<th>Parallel mode</th>
<th>Word-addressable</th>
<th>Row Address</th>
<th>Column Address</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>FA[31:Cas]</td>
<td>FA[CAS-1:0]</td>
<td>There is no limitation on FA and data size alignment.</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>FA[31:Cas+1]</td>
<td>FA[CAS:1]</td>
<td>FA and data size should be 2 byte aligned.</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>FA[31:Cas+1]</td>
<td>FA[CAS:1]</td>
<td>FA and data size should be 2 byte aligned.</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>FA[31:Cas+2]</td>
<td>FA[CAS+1:2]</td>
<td>FA and data size should be 4 byte aligned.</td>
</tr>
</tbody>
</table>

**NOTE**

- FA is the flash address with flash base address removed.
- If the Row/Column Flash Address bit number to be sent to Flash device defined in Instructions is more than valid Row/Column Flash Address bit number, high position bits will be supplemented with zero. Refer Programmable Sequence Engine for more details about Row/Column Address instruction.
When parallel mode enabled or word-addressable flash used, there is limitation on flash start address and data size. This requirement could be meet by aligning AHB bus access address (For AHB command) or IP command address IPCR0[SFAR] (For IP command) in software. There are two ways to avoid these limitation in specified case.

1. For **AHB Read Command** only:

   When AHBCR[READADDROPT] and AHBCR[PREFETCHEN] are both set to 1, FlexSPI will guarantee flash access start address and data size are 64 bit aligned by hardware.

   When AHBCR[READADDROPT] is set to 1, FlexSPI will fetch redundant data to guarantee flash start address aligned with 8 bytes. When prefetch enabled (AHBCR[PREFETCHEN] is set to 1), flash read data size is determined by AHB RX Buffer size which is 64 bit aligned.

2. For **AHB Write Command and Individual mode** only:

   By default, FlexSPI will guarantee flash write access start address and data size are 16 bit aligned by using DQS as write mask.

   This feature is not applied in parallel mode and should be used only if external device supports write mask feature.

### 27.5.7 Look Up Table

The LUT (Look Up Table) is an internal memory to preserve a number of pre-programmed sequences. Each sequence consists of up to 8 instructions which are executed sequentially. When a flash access is triggered by an IP command or an AHB command, FlexSPI controller will fetch the sequence from LUT according to sequence index/number and execute it to generate a valid flash transaction on SPI interface.

Following figure indicates the structure of LUT, sequence and instruction.
NOTE

If the instruction number needed is less than 8 for a flash transaction, STOP instruction should be programmed for the unneeded instructions (instruction code 8'h00).

For IP command and AHB write command, FlexSPI controller always executes from instruction pointer 0. For AHB read command, FlexSPI controller executes from a saved instruction start pointer. FlexSPI controller saves the instruction start pointers separately for each flash device. All these saved instruction pointer are zero before JMP_ON_CS instruction is executed,. When JMP_ON_CS instruction is executed, the operand in JMP_ON_CS instruction will be saved as instruction start pointer. Refer XIP Enhanced Mode for more details.

The reset value of LUT is unknown because it is implemented as internal memory. LUT should be programmed according to the device connected on board. In order to protect its contents during a code runover, the LUT could be locked/unlocked to avoid change by mistake after programmed. The key for locking or unlocking the LUT is 0x5AF05AF0. The process for locking and unlocking the LUT is as follows:

Locking the LUT

1. Write the key (0x5AF05AF0) in to the LUT Key Register (LUTKEY).
2. Write 1b1 to LUTCR[LOCK] and 1b0 to LUTCR[UNLOCK] fields of the LUT Control Register, immediately after the above KEY register writing. LUT is not
successfully locked if there is any other register write access to FlexSPI between these two write accesses.

Unlocking the LUT

1. Write the key (0x5AF05AF0) in to the LUT Key Register (LUTKEY).
2. Write 1b0 to LUTCR[LOCK] and 1b1 to LUTCR[UNLOCK] fields of the LUT Control Register, immediately after the above KEY register writing. LUT is not successfully unlocked if there is any other register write access to FlexSPI between these two write accesses.

The lock status of the LUT can be read from register field LUTCR[LOCK] and LUTCR[UNLOCK].

27.5.8 Programmable Sequence Engine

FlexSPI controller implements a programmable sequence engine that executes the sequence from LUT. FlexSPI controller executes the instructions sequentially and generates flash transaction on the SPI interface accordingly. The following table is a complete list of the supported instructions.

<table>
<thead>
<tr>
<th>Name</th>
<th>Opcode</th>
<th>Num_pads</th>
<th>Action on SPI interface</th>
<th>Transmit Data</th>
<th>Bits/Bytes/Cycle Number</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMD_SDR/CMD_DDR</td>
<td>6’h01/6’h21</td>
<td>2’h0 - one pad (Single mode)</td>
<td>Transmit Command code to Flash</td>
<td>Command code: Operand[7:0]</td>
<td>Bit number: 8</td>
</tr>
<tr>
<td>RADDR_SDR/RADDR_DDR</td>
<td>6’h02/6’h22</td>
<td>2’h1 - two pad (Dual mode)</td>
<td>Transmit Row Address to Flash</td>
<td>Row_Address[31:0]</td>
<td>Bit number: operand[7:0]</td>
</tr>
<tr>
<td>CADDR_SDR/CADDR_DDR</td>
<td>6’h03/6’h23</td>
<td>2’h2 - four pad (Quad mode)</td>
<td>Transmit Column Address to Flash</td>
<td>Column_Address[3 1:0]</td>
<td>Bit number: operand[7:0]</td>
</tr>
<tr>
<td>MODE1_SDR/MODE1_DDR</td>
<td>6’h04/6’h24</td>
<td>2’h3 - eight pad (Octal mode)</td>
<td>Transmit Mode bits to Flash</td>
<td>Mode bits: Operand[0]</td>
<td>Bit number: 1</td>
</tr>
<tr>
<td>MODE2_SDR/MODE2_DDR</td>
<td>6’h05/6’h25</td>
<td></td>
<td></td>
<td>Mode bits: Operand[1:0]</td>
<td>Bit number: 2</td>
</tr>
<tr>
<td>MODE4_SDR/MODE4_DDR</td>
<td>6’h06/6’h26</td>
<td></td>
<td></td>
<td>Mode bits: Operand[3:0]</td>
<td>Bit number: 4</td>
</tr>
<tr>
<td>MODE8_SDR/MODE8_DDR</td>
<td>6’h07/6’h27</td>
<td></td>
<td></td>
<td>Mode bits: Operand[7:0]</td>
<td>Bit number: 8</td>
</tr>
<tr>
<td>WRITE_SDR/WRITE_DDR</td>
<td>6’h08/6’h28</td>
<td></td>
<td>Transmit Programming Data to Flash</td>
<td>Programming Data in IP TX FIFO or AHB_TX_BUF</td>
<td>Byte number (data size) is determined by AHB burst size and burst type (AHB Command) or IPCR1[IDATSZ] (IP command). For more</td>
</tr>
<tr>
<td>Name</td>
<td>Opcode</td>
<td>Num_pads</td>
<td>Action on SPI interface</td>
<td>Transmit Data</td>
<td>Bits/Bytes/Cycle Number</td>
</tr>
<tr>
<td>----------------------</td>
<td>------------</td>
<td>----------</td>
<td>--------------------------------------------------------------------------------------------</td>
<td>---------------</td>
<td>-------------------------</td>
</tr>
<tr>
<td>READ_SDR/READ_DDR</td>
<td>6'h09/</td>
<td></td>
<td>Receive Read Data from Flash&lt;br&gt;Read Data is put into AHB_RX_BUF or IP_RX_FIFO.</td>
<td>-</td>
<td>detail about flash read/program data size, refer Flash access by AHB Command and Flash access by IP Command.</td>
</tr>
<tr>
<td></td>
<td>6'h29</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LEARN_SDR/LEARN_DDR</td>
<td>6'h0A/</td>
<td></td>
<td>Receive Read Data or Preamble bit from Flash device&lt;br&gt;FlexSPI Controller will compare the data line bits with DLPR register to determine a correct sampling clock phase.</td>
<td>-</td>
<td>Learning pattern bit number: operand[7:0]&lt;br&gt;Never set operand to zero for LEARN instruction. It indicates length of data learning pattern based on bits number. For example, 8bits pattern 0x5A on each data line needs to set operand to 8.</td>
</tr>
<tr>
<td></td>
<td>6'h2A</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DATSZ_SDR/DATSZ_DDR</td>
<td>6'h0B/</td>
<td></td>
<td>Transmit Read/Program Data size (byte number) to Flash&lt;br&gt;Internal Logic Read/Program data size for current command sequence.</td>
<td></td>
<td>Bit number: operand[7:0]&lt;br&gt;Please never set operand to zero or larger than 64 for DATSZ instruction.</td>
</tr>
<tr>
<td></td>
<td>6'h2B</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DUMMY_SDR/DUMMY_DDR</td>
<td>6'h0C/</td>
<td></td>
<td>Leave data lines undriven by FlexSPI controller. Provide turnaround cycles from host driving to device driving. num_pads will determine the number of pads in input mode.</td>
<td>-</td>
<td>Dummy cycle number (in serial root clock):&lt;br&gt;Operand[7:0]&lt;br&gt;Dummy cycle (N), described in the Flash device datasheet is in number of SCLK cycles and this number may be configurable.&lt;br&gt;In SDR mode, SCLK cycle is same as serial root clock. The operand value should be set as N.&lt;br&gt;In DDR mode, SCLK cycle is double the serial root clock cycle. The operand value should be set as 2^N, 2^N-1 or 2^N+1 depending on how dummy cycle defined in device datasheet. Please refer to Flash access sequence example and dummy cycle definition on device datasheet.</td>
</tr>
<tr>
<td></td>
<td>6'h2C</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DUMMY_RWDS_SDR/DUMMY_RWDS_DDR</td>
<td>6'h0D/6'h2D</td>
<td></td>
<td>This instruction is similar as DUMMY_SDR/DUMMY_DDR</td>
<td>-</td>
<td>For read command, dummy cycle number (in serial root clock):&lt;br&gt;(operand[7:0]*4-1) if RWDS (DQS pin) is high;</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 27-7. Instruction set (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Opcode</th>
<th>Num_pads</th>
<th>Action on SPI interface</th>
<th>Transmit Data</th>
<th>Bits/Bytes/Cycle Number</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>instruction. But the dummy cycle number is different. DQS pins is called &quot;RWDS&quot; in HyperBus specification. Refer Dummy instruction for more details. Set operand as &quot;Latency count&quot; for HyperBus devices.</td>
<td>(operand[7:0]*2-1) if RWDS (DQS pin) is low; For write command, dummy cycle number (in serial root clock): (operand[7:0]*4-2) if RWDS (DQS pin) is high; (operand[7:0]*2-2) if RWDS (DQS pin) is low;</td>
<td>-</td>
</tr>
<tr>
<td>JMP_ON_CS</td>
<td>6'h1F</td>
<td>Num_pads setting will be ignored. Always set num_pads to 2'h0.</td>
<td>Stop execution, deassert CS and save operand[7:0] as the instruction start pointer for next sequence. Normally this instruction is used to support Execute-In-Place enhance mode. Refer XIP Enhanced Mode for more details. This instruction is only allowed for AHB read command. If this instruction is used in IP command or AHB write command, there will be interrupt status bit set (INTR[IPCMDERR] or INTR[AHBCMDERR]).</td>
<td>-</td>
<td>No transaction on SPI interface.</td>
</tr>
<tr>
<td>STOP</td>
<td>6'h00</td>
<td></td>
<td>Stop execution, deassert CS. Next command sequence (to the same flash device) will started from instruction pointer 0.</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
The programmable sequence engine allows the software to configure the FlexSPI LUT according to external serial device connected on board. The flexible structure is easily adaptable to new command/protocol changes from different vendors.

DDR sequence is a flash access sequence that contain DDR instruction which is not DUMMY, it may contain SDR instructions optionally. SDR sequence is a flash access sequence that don't contain any DDR instruction. FlexSPI controller determines instruction SDR or DDR mode by decoding bit 5 of instruction opcode. The output/input timing on FlexSPI is different for SDR and DDR sequences. Especially note that SDR instruction in SDR sequence and DDR sequence is executed differently. Refer FlexSPI Input Timing and FlexSPI Output Timing for more details.

27.5.8.1 Instruction execution on SPI interface

This section describes the detail of instruction execution on SPI interface. For all instructions transmitting/receiving data bits to/from flash, the bit order in one byte is higher on DATA3 than DATA0, and higher on B port than A port.

1. Command Instruction

Command Instruction (CMD_SDR/CMD_DDR) is normally used to transmit command code to external flash device. Command code is the 8 bits operand in instruction. Command code will be send to both B port and A port in parallel mode. Refer Flash access sequence example for examples.

2. Address Instruction

Address Instructions (RADDR_SDR/RADDR_DDR/CADDR_SDR/CADDR_DDR) are normally used to send Flash access start address (Row/Column Address) to external flash device. Row/Column Address bits are determined by FlexSPI according to AHB access address or IP command address. Refer Flash address sent to Device for more details. The bit number is the operand value in instruction code. Row/Column address bits will be send to both B port and A port in parallel mode. For memories that read the flash address on 4 SCK edges, the sum of CADDR +RADDR must be 32. Otherwise, the FlexSPI will not generate 4 SCK edges of address phase. Refer Flash access sequence example for examples.

3. Mode Instruction

Mode Instructions (MODEx_SDR/MODEx_DDR) are normally used to send mode bits to external flash device. Mode bits are the (lower) bits value of the instruction operand. The transition bit number is 1 for MODE1_SDR/MODE1_DDR, 2 for MODE2_SDR/MODE2_DDR, 4 for MODE4_SDR/MODE4_DDR and 8 for MODE8_SDR/MODE8_DDR. Note that pad number should be no more than mode
bit number. For example, it is not allowed to set num_pads to 2'b11 (Octal mode) for MODE4_* instructions. Mode bits will be send to both B port and A port in parallel mode. Refer Flash access sequence example for examples.

4. **Data Size Instruction**

Data Size Instructions (DATSZ_SDR/DATSZ_DDR) are used to send program/read data size (byte number) to external device. This instruction is normally used in FPGA application when the memory space in external device acts similar as a FIFO. The device needs data size information to determine how much data will be popped from or pushed into internal FIFO. The bit number is the operation value in the instruction. Data size bits will be send to both B port and A port in parallel mode. Refer Flash access sequence example for examples.

5. **Write Instruction**

Write Instructions (WRITE_SDR/WRITE_DDR) are normally used to send program data to external device. Programming data are fetched from IP TX FIFO (IP Command) or AHB TX Buffer (AHB command). For more details about flash program data size, refer Flash access by AHB Command and Flash access by IP Command. The byte order for programming date is always from low to high. Odd bytes are send on A port and Even bytes are send on B port in parallel mode. Refer Flash access sequence example for examples.

6. **Read Instruction**

Read Instructions (READ_SDR/READ_DDR) are normally used to receive flash data from external device. Received data will be put into IP RX FIFO (IP Command) or AHB RX Buffer (AHB command). For more detail about flash read data size, refer Flash access by AHB Command and Flash access by IP Command. The byte order for reading date is always from low to high. Odd bytes are received from A port and Even bytes are received from B port in parallel mode. Refer Flash access sequence example for examples.

7. **Dummy Instruction**

Dummy Instructions (DUMMY_SDR/DUMMY_DDR/DUMMY_RWDS_SDR/ DUMMY_RWDS_DDR) are used to provide turnaround cycles on SPI interface. During dummy instruction, neither FlexSPI controller nor external device drives SPI interface. Refer Programmable Sequence Engine for more details about dummy cycle number.
DUMMY_RWDS_DDR could be used for HyperBus device which use "RWDS" pin to indicate whether extra latency count needed. DUMMY_RWDS_SDR is reserved for future. FlexSPI controller checks DQS pin input level at the 4th cycle after SCLK output toggling is enabled. DQS pins is called "RWDS" in HyperBus specification. Refer Flash access sequence example for examples.

NOTE
The FlexSPI releases the bus after at least one cycle. Therefore, to avoid data contention, number of dummy lines should be programmed more than 1 if data is transferred on more than 1 line.

27.5.8.2 Flash access sequence example

Following is an example for SDR single I/O Read sequence (Cypress Serial Nor Flash S25FS512S) in individual mode.

![Flash access sequence example](image)

**Figure 27-6. Flash access sequence example (SDR Single I/O Read sequence)**

NOTE
- FlexSPI dummy instruction starts and ends at serial root clock rise edge.
- Device dummy cycle starts and ends at SCLK fall edge (on Cypress S25FS512S datasheet).

Following is an example for SDR Quad I/O Read sequence (Cypress Serial Nor Flash S25FS512S) in individual mode.
Figure 27-7. Flash access sequence example (SDR Quad I/O Read sequence)

NOTE

- FlexSPI dummy instruction starts and ends at serial root clock rise edge.
- Device dummy cycle starts and ends at SCLK fall edge (on Cypress S25FS512S datasheet).

Following is an example for DDR Quad I/O Read sequence (Cypress Serial Nor Flash S25FS512S) in parallel mode.
Figure 27-8. Flash access sequence example (DDR Quad I/O Read sequence)

Following is an example for HyperBus device read transaction (Single latency count) in individual mode.
Figure 27-9. HyperBus device read transaction with single latency count

Following is an example for HyperBus device read transaction (Additional latency count) in individual mode.

Figure 27-10. HyperBus device read transaction with additional latency count
Following is an example for HyperBus device write transaction (Single latency count) in individual mode.

Figure 27-11. HyperBus device write transaction with single latency count

Following is an example for HyperBus device write transaction (Additional latency count) in individual mode.
27.5.9 Flash access by IP Command

Flash access could be triggered by IP command in following steps.

- Fill IP TX FIFO with programming data if this is a programming command (programming flash data, flash status registers etc.)
- Set flash access start address (IPCR0[SFAR]), read/program data size, sequence index in LUT and sequence number (IPCR1[ISEQNUM]).
- Trigger flash access command by writing 1 to register bit IPCMD[TRG]
- Polling register bit INTR[IPCMDDONE] to wait for this IP command to finish on FlexSPI interface.

**NOTE**

- IP TX FIFO could be filled before or after writing IPCR0/IPCR1/IPCMD register. If SFM command is started with IP TX FIFO empty, FlexSPI will stop SCLK toggling to wait for TX data ready automatically.
- IPCMD register must be written after writing IPCR0/IPCR1 register.
• Multiple Command sequences (8 at most) could be issued by one IP command.
• It is not allowed to issue another IP command before the previous IP command is finished. The behaviour is unknown in this case.

If this is a Reading command to Serial Flash Memory, all reading data from Flash will be put into IP RX FIFO. Software will need to read out data from IP RX FIFO by AHB bus or IP Bus. When IP RX FIFO is full and there is more data to be read from Flash device, FlexSPI will stop SCLK output clock toggling until IP RX FIFO is not full. Please refer to SCLK stop feature for more detail.

The detail of triggered Serial Flash Command is as following:

• Flash access start address:
  Determined by register field IPCR0[SFAR]

• Flash Chip Select:
  Determined by flash access address and Flash size setting (FLSHxCR0[FLSHSZ]).

• Flash command Sequence Index and Sequence Number:
  The sequences indexed from IPCR1[ISEQID] to (IPCR1[ISEQID] + IPCR1[ISEQNUM]) in LUT will be executed by FlexSPI sequentially.

• Flash Individual/Parallel access mode
  Determined by IPCR1[IPAREN].

• Flash Read/Program Data Size:
  • If IPCR1[IDATSZ] value is non-zero, flash read/program data size (in byte) is IPCR1[IDATSZ].
  • If IPCR1[IDATSZ] value is zero, flash read/program data size (in byte) will the operand value in the READ/WRITE instruction.

**NOTE**
• Software should make sure the last sequence index never exceeds the LUT sequence number (IPCR1[ISEQID] + IPCR1[ISEQNUM] < 16).
• Data size is applied to every command sequence if sequence number is more than one.
• Data size is ignored if there is no WRITE/READ instruction in the command sequence.
IP command request is sent to arbitrator after triggered by software. It is not executed on FlexSPI Interface until granted by arbitrator. Please refer to Command Arbitration for more details.

### 27.5.9.1 Reading Data from IP RX FIFO

FlexSPI put the read data from external device into IP RX FIFO for IP command. These data could be read out by following two memory space access.

- 0x100 - 0x180 (by IPS Bus)
- 0x7FC00000 - 0x7FC00080 (by AHB Bus)

If MCR0[ARDFEN] is set to 0x1, read data in IP RX FIFO could only be read out by AHB Bus, IP Bus read access to IP RX FIFO will always return with data zero and no bus error occur.

If MCR0[ARDFEN] is set to 0x0, read data in IP RX FIFO could only be read out by IPS Bus, AHB Bus read access to IP RX FIFO will trigger bus error.

FlexSPI push read data into IP RX FIFO in terms of 64 bits every time it receives 64 bits data from external device. When read data bits number is not 64 bits aligned, FlexSPI will push additional zero bits into IP RX FIFO for the last push.

IP RX FIFO could be read by processor or DMA. Following is the detail flow for processor and DMA reading:

1. **Reading by processor**

   To read by processor, following register settings are needed:
   
   - Set register field IPRXFCSR[RXDMAEN] to 0.
   - Set watermark level by IPRXFCSR[RXWMRK], watermark level is (IPRXFCR[RXWMRK]+1)*8 bytes.
   - Set register field INTEN[IPRXWAEN] to enable IP RX FIFO watermark available interrupt (optional).

   Processor needs to poll register INTR[IPRXWA] or wait for IP RX FIFO Watermark Available interrupt before reading IP RX FIFO. This is to make sure there is a watermark level Data filled in IP RX FIFO before reading.

   After reading a watermark level data from IP RX FIFO, software need to set register bit INTR[IPRXWA]. This set action will pop out a watermark level data from IP RX FIFO.

   Following digram indicates the reading flow from IP RX FIFO by processor.
Figure 27-13. Reading IP RX FIFO by processor

**NOTE**

- Processor need to read out a watermark level data from IP RX FIFO each time before set register bit INTR[IPRXWA].
- It's supported that the total flash read/program data size is not multiple of watermark level. In this case, the reading data size from IP RX FIFO will be less than a watermark level for the last time, software should poll IPRXSTS[FILL] field instead of polling INTR[IPRXWA]. After copying all the data from IP RX FIFO and all command sequences to Flash are finished (INTR[IPCMDDONE]=1), software should clear IP RX FIFO by setting IPRXFCR[CLRIPRXF]. Otherwise, the reading data will be wrong for the next reading command to Flash.
- IP RX FIFO data is not popped out by each reading access to IP RX FIFO, but popped by writing 0x1 to register INTR[IPRXWA] bit.

2. **Reading by DMA**

To read IP RX FIFO by DMA, following setting is needed:

- Set register field IPRXFCR[RXDMAEN] to 1.
- Set watermark level by IPRXFCR[RXWMRK], watermark level is (IPRXFCR[RXWMRK]+1)*8 bytes.
- Set DMA transfer Minor loop size to same watermark level.
Figure 27-14. Reading from IP RX FIFO by DMA

NOTE

• DMA request is generated when the fill level of IP RX FIFO is higher than (or equal) watermark level. This request is not pulse valid but level valid.
• DMA should read out watermark level data from IP RX FIFO each time (set minor loop size with the same value as watermark level).
• DMA need to return a Done handshake (pulse valid) to FlexSPI each time it finished reading a watermark level data.
• IP RX FIFO data is not popped out by each reading access, but popped by DMA done handshake.
• It is not supported that the total read/write data size (Major loop size) is not multiple of watermark level. Because the DMA does not know when the data is ready for the last reading. It makes the DMA driver too complex to poll IPRXFSTS [FILL] field.

27.5.9.2  Filling Data to IP TX FIFO

The programming should be put into IP TX FIFO and then transmit to Flash by FlexSPI. It could be filled by two memory space.

• 0x180 - 0x200 (by IP Bus)
• 0x7F800000 - 0x7F800080 (by AHB Bus)
To fill by AHB Bus, need to set MCR0[ATDFEN] to 1, IP Bus write access to IP TX FIFO will be ignored, but no bus error.

To fill by IP Bus, need to set MCR0[ATDFEN] to 0, AHB Bus write access to IP TX FIFO will return Bus Error.

IP TX FIFO is popped with 64 bits data every time FlexSPI fetch data for transmitting. If the programming data size is not multiple of 64 bits, last popped valid bits will be less than 64 bits. But there is no problem because these invalid bits are not transmitted to Flash at all.

IP TX FIFO could be filled by processor or DMA.

To fill by processor, need following setting:

- Set register field IPTXFCR[TXDMAEN] to 0.
- Set watermark level by IPTXFCR[TXWMRK], watermark level is (IPTXFCR[TXWMRK]+1)*8 bytes.
- Set register field INTEN[IPTXWEEN] to enable IP TX FIFO watermark empty interrupt (optional).

Processor needs to poll register INTR[IPTXWE] or wait for IP TX FIFO Watermark empty interrupt before filling IP TX FIFO. This is to make sure there is enough space for a watermark level Data filling before filling.

After filling a watermark level data to IP TX FIFO, need to set register bit INTR[IPTXWE]. This will push a watermark level data into IP TX FIFO (write pointer is incremented).

**NOTE**

IP TX FIFO data is not pushed by each write access, only pushed by set INTR[IPTXWE] bit.

Following diagram indicates the filling flow to IP TX FIFO by processor.
Figure 27-15. Filling IP TX FIFO by processor

NOTE

- Processor will need to fill a watermark level data to IP TX FIFO each time.
- It's allowed that total write data size is not multiple of watermark level. In this case, the writing size will be less than a watermark level for the last time. After filling all data into IP TX FIFO and all Command Sequences to Flash are finished (INTR[IPCMDDONE]=1), processor should clear IP TX FIFO by setting IPTXFCR[CLRIPTXF]. Otherwise, the programming data will be wrong for the next programming Command to Flash.

To fill IP TX FIFO by DMA, need following setting:

- Set register field IPTXFCR[TXDMAEN] to 1.
- Set watermark level by IPTXFCR[TXWMRK], watermark level is (IPTXFCR[TXWMRK]+1)*8 bytes.
- Set DMA transfer Minor loop size to same watermark level.
NOTE

- DMA request is generated when there is empty space more than watermark level in IP TX FIFO. This request is not pulse valid but level valid.
- DMA should fill watermark level data into IP TX FIFO each time (set minor loop size with the same value as watermark level.
- DMA need to return a Done handshake (pulse valid) to FlexSPI each time it finished filling a watermark level data.
- IP TX FIFO data is not pushed in by each reading access, but pushed by DMA done handshake.
- It's allowed that total program data size (Major loop size) is not multiple of watermark level. After filling all data into IP TXFIFO and all command sequences to Flash are finished (INTR[IPCMDDONE]=1), need to clear IP TX FIFO by setting IPTXFCR[CLRIPTXF]. Otherwise, the programming data will be wrong for the next programming Command to Flash.

27.5.10  Flash access by AHB Command

Flash could be accessed by AHB bus directly on AHB address space: 60000000~0x80000000. This address space is mapped to Serial Flash Memory in FlexSPI. AHB bus access to this address space may trigger Flash access command sequence as needed.
For AHB read access to Serial Flash Memory, FlexSPI will fetch data from flash into AHB RX Buffers and then return the data on AHB Bus. For AHB write access to Serial Flash Memory, FlexSPI will buffer AHB Bus write data into AHB TX Buffer and then transmit to Serial Flash memory.

There is no software configuration or polling need for AHB command except FlexSPI initialization. AHB master access external flash device transparently similar as normal AHB slave.

AHB command is normally used to access serial Flash memory space. IP command should be used to access the control and status registers or other spaces such as OTP in external flash device.

Following section described AHB command for read and write in more detail.

**NOTE**

When FlexSPI controller return AHB bus error for SFM access, AHB master should stop following access beats in current burst.

### 27.5.10.1 AHB write access to Flash

For AHB write access to Flash, FlexSPI will buffer the write data from AHB bus into internal AHB TX Buffer and then transmit them to Flash. FlexSPI only buffers write data for one AHB burst. Following diagram indicates the hardware operation in response to AHB write access to Flash.
Functional description

Figure 27-17. Hardware operation in response to AHB write access to Flash

FlexSPI triggers new AHB write command in following cases:

- This beat is the last one in current AHB burst (any burst type except INCR).
- AHB TX Buffer is full after buffering current beat data.
- AHB bus becomes IDLE or a new burst comes with AHB TX Buffer not empty.

The detail information about the triggered AHB write command:

- Flash Access Start Address:
  Determined by AHB burst address. FlexSPI will record the start address for the data in AHB TX Buffer and this address will be used as flash access start address
- Flash Chip Select:
FlexSPI determined the chip selection by flash access start address and flash size
setting.

- Flash Command Sequence Index:
  Determined by FLSHxCR2[AWRSEQID].

- Flash Command Sequence Number:
  Determined by FLSHxCR2[AWRSEQNUM]. If AWRSEQNUM is not zero,
  multiple flash access command sequences will be triggered every time for AHB write
  command. The sequences indexed from AWRSEQID to (AWRSEQID +
  AWRSEQNUM) in LUT will be executed sequentially.

- Flash access mode (Individual/Parallel)
  Determined by AHBCR[APAREN].

- Flash Data Size:
  Determined by byte number of buffered data in AHB TX Buffer.

Following examples indicates internal logic for AHB write access to Flash. In these
examples, AHB_TX_BUF is 64 Bytes (8*64bits).

- AHB INCR/64bit/Bufferable burst with address sequence 0x8, 0x10, 0x18, 0x20, ..., 0x50 (10 beat totally):

  Two AHB write command will be triggered: the first command with flash start
  address 0x8 and data size 0x40; the second command with flash start address 0x48
  and data size 0x10. See Figure 27-18.
**Functional description**

![Diagram of AHB write access (INCR/64bit/Bufferable)](image)

- AHB WRAP8/64bit/Bufferable burst with address sequence 0x28, 0x30, 0x38, 0x0, 0x8, 0x10, 0x18, 0x20:

  One AHB write command will be triggered with flash start address 0x0 and data size 0x40. See Figure 27-19.

---

**Figure 27-18. AHB write access (INCR/64bit/Bufferable)**
Figure 27-19. AHB write access (WRAP8/64bit/Bufferable)

- AHB WRAP8/64bit/Non-bufferable burst with address sequence 0x28, 0x30, 0x38, 0x0, 0x8, 0x10, 0x18, 0x20:

  One AHB write command will be triggered with flash start address 0x0 and data size 0x40;
Figure 27-20. AHB write access (WRAP8/64bit/Non-Bufferable)

NOTE
The wrapper burst is not supported if burst data size (in byte) is larger than AHB TX Buffer size (in byte). For example, if AHB_TX_BUF is 64 Bytes (8*64bits), AHB WRAP16 * 64bit writet burst access is not supported.

27.5.10.2 AHB read access to Flash

For AHB read access to Flash, FlexSPI will check whether hit AHB TX Buffer/AHB RX Buffer/pending AHB read command according to the burst access type and register setting. If all these miss, FlexSPI trigger a new AHB read command to fetch data from Flash. Following diagram indicates the hardware operation in response to AHB read access to Flash.
Figure 27-21. Hardware operation in response to AHB read access to Flash

**NOTE**

1. AHB prefetch is enabled when both
   - AHBCR[PREFETCHEN]=0x1 and
   - AHBRXBUFxCR0[PREFETCHEN]=0x1 (x is the ahb rx buffer ID for current AHB master).
2. AHB RX Buffer holds the data read from Flash. This data may become incoherent if the AHB writes to the same flash address.

The detail information about the triggered AHB read command:

- Flash Access Start Address and Data Size:
Determined by AHB address, burst type and burst size. FlexSPI will fetch read data from the start address for current burst or beat.

### Table 27-8. AHB read command flash start address and data size

<table>
<thead>
<tr>
<th>Prefetch Enable</th>
<th>Cross flash boundary</th>
<th>Burst Type</th>
<th>Flash start address [28:0]</th>
<th>Data Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Never cross flash boundary because AHB burst never cross 1K Byte boundary.</td>
<td>SINGLE/INCR4/INCR8/INCR16</td>
<td>hbeat_start_address</td>
<td>(hburst_end_address - hbeat_start_address)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>INCR</td>
<td>hbeat_start_address</td>
<td>byte size of current beat</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>For INCR burst with prefetch disabled, each beat is handled same as SINGLE burst.</td>
</tr>
<tr>
<td></td>
<td>WRAP4/WRAP8/WRAP16</td>
<td></td>
<td>hburst_start_address</td>
<td>(hburst_end_address - hburst_start_address)</td>
</tr>
<tr>
<td>1</td>
<td>No</td>
<td>SINGLE/INCR4/INCR8/INCR16</td>
<td>hbeat_start_address</td>
<td>ahb_rx_buf_sz</td>
</tr>
<tr>
<td></td>
<td>No</td>
<td>WRAP4/WRAP8/WRAP16</td>
<td>hburst_start_address</td>
<td>ahb_rx_buf_sz</td>
</tr>
<tr>
<td></td>
<td>Yes</td>
<td>SINGLE/INCR4/INCR8/INCR16</td>
<td>hbeat_start_address</td>
<td>(flash_top_address - hbeat_start_address)</td>
</tr>
<tr>
<td></td>
<td>Yes</td>
<td>WRAP4/WRAP8/WRAP16</td>
<td>hburst_start_address</td>
<td>(flash_top_address - hburst_start_address)</td>
</tr>
</tbody>
</table>

**NOTE**

- hbeat_start_address is HADDR input from AHB master for current beat.
- hburst_start_address (for e.g. 0x00) is the lowest address for current burst; hburst_end_address (for e.g. 0x10) is the highest address in current burst plus 1. For example, WRAP4 burst with HADDR 0x8,0xC, 0x0, 0x4.
• ahb_rx_buf_sz is the buffer size in byte of AHB RX Buffer which is used by current master.

• flash_top_address is the top address of currently accessed flash.

• Flash Chip Select:
  FlexSPI determined the chip selection by flash access start address and flash size setting.

• Flash Command Sequence Index:
  Determined by FLSHxCR2[ARDSEQID].

• Flash Command Sequence Number:
  Determined by FLSHxCR2[ARDSEQNUM]. If ARDSEQNUM is not zero, multiple flash access command sequences will be triggered every time for AHB read command. The sequences indexed from ARDSEQID to (ARDSEQID + ARDSEQNUM) in LUT will be executed sequentially.

• Flash access mode (Individual/Parallel):
  Determined by AHBCR[APAREN].

  **NOTE**
  • FlexSPI determines which ARDSEQNUM/ARDSEQID fields will be used as sequence ID by flash device chip selection automatically. See MCR2[SAMEDEVICEEN] for more details.
  • FlexSPI determines which AHB RX Buffer used for current AHB read access by master ID. For more details about the AHB RX buffer ID and AHB master ID mapping, see AHB RX Buffer Management.
  • It is not allowed to allocate AHB RX Buffer less than AHB Burst size. The behaviour is unknown for this case.

### 27.5.10.3 AHB RX Buffer Management

There are 4 buffers (Buffer 0 - Buffer 3) in AHB RX Buffer, which are transparent to AHB masters. FlexSPI fetch flash data and return on AHB Bus automatically. There is no status register polling needed for AHB read access to Serial Flash Memory.
See the chip-specific section for AHB buffer size. The buffer size is flexibly configurable for each buffer in AHB RX Buffers by register fields AHBRXBUF0CR0[BUFSZ]~AHBRXBUF6CR0[BUFSZ]. The buffer size for Buffer 0 to Buffer 3 could be set 0. If the buffer size is set to 0x0, the related MSTRID field setting (in same AHBRXBUFxCR0 register) is ignored by FlexSPI. Buffer 3 is used for all AHB masters which is not assigned to Buffer 0 - Buffer 2. Buffer 3 size setting field (AHBRXBUF3CR0[BUFSZ]) is ignored by FlexSPI, its buffer size is: AHB RX Buffer total size - sum of (Buffer 0 - Buffer 2 size).

When there is AHB read access to Serial Flash Memory, FlexSPI determines which AHB RX Buffer to use as following:

1. If master ID equal AHBRXBUF0CR0[MSTRID] and AHBRXBUF0CR0[BUFSZ] is not zero, Buffer 0 will be used.
2. If master ID equal AHBRXBUF1CR0[MSTRID] and AHBRXBUF1CR0[BUFSZ] is not zero, Buffer 1 will be used.
3. If master ID equal AHBRXBUF2CR0[MSTRID] and AHBRXBUF2CR0[BUFSZ] is not zero, Buffer 2 will be used.
4. If all above case not meet, Buffer 3 will be used

**NOTE**

- Software should make sure the buffer size of each buffer is no less than the max burst size of AHB Read access from the master using this buffer. Otherwise the behaviour is undefined.
- It is not supported to assign multiple buffers for single AHB master.
- When AHB read prefetch is enabled (AHBCR[PREFETCHEN] is set), the prefetch data size will be determined by buffer size. FlexSPI will fetch data from external Flash with buffer size if no flash boundary across.
- AHB master priority setting (register field AHBRXBUFxCR0[PRIORITY] is used only for the suspending control of AHB prefetching. See Command Abort and Suspend.

### 27.5.11 Command Arbitration

There are four Flash access command sources:

1. AHB Command (triggered by AHB Write access to SFM space)
2. AHB Command (triggered by AHB Read access to SFM space)
3. IP command (triggered by writing IPCMD[TRG])
4. Suspended command (AHB Read prefetch sequence which is suspended)

**NOTE**
- An AHB bus access never triggers a write command and a read command at the same time.
- AHB prefetch sequence is an AHB Command sequence triggered by AHB Read access when AHB prefetch is enabled. After all read data fetched for current AHB read burst, FlexSPI will prefetch more data to reduce the read latency for next AHB read access. AHB command for read is never aborted while fetching read data for current AHB read burst. But AHB read command could be aborted by any new IP command or AHB command request when it's prefetching data (not for current read burst).

The granted priority of these 4 command source is as following when Arbitrator is idle (STS0[ARBIDLE]=1):

1. AHB command (Read/Write)
2. IP Command
3. Suspended Command

**NOTE**
Suspended command is not granted immediately when arbitrator is idle and no AHB/IP command request. Arbitrator will wait for n AHB clock cycle idle state before resuming the suspended command (n is the register field value in MCR2[RESUMEWAIT]). This intend to avoid AHB prefetch sequence being resumed and suspended frequently.

All command request are not granted if Arbitrator is busy in executing AHB/IP command (not suspended command), and there will AHB/IP Command granted error if the grant is timeout.

If new AHB/IP command request comes while Arbitrator is executing AHB read prefetch sequence, AHB read prefetch sequence will be aborted (but not immediately). Arbitrator will grant AHB/IP command request after AHB read prefetch sequence is aborted on FlexSPI interface and saved all internal data pointers.
27.5.11.1  Command Abort and Suspend

This section describes command abort and suspend mechanism.

1. **Command Abort**
   
   As mentioned above, AHB read prefetch sequence could be aborted if new AHB/IP command request comes.

2. **Command Suspend**
   
   When AHB read prefetch sequence is aborted on FlexSPI interface, FlexSPI will save this suspended sequence in following cases and resume this sequence if arbitrator is idle for enough time:
   
   - There is no valid suspended command (Register field AHBSNDSTS[ACTIVE] is 0x0). This is possible if there is no suspended command yet or suspended command is resumed.
   - Aborted AHB read prefetch sequence is higher priority than current active suspend sequence.

   **NOTE**
   
   Original suspended sequence will be ignored and never resumed by FlexSPI.

3. **Suspended Command**
   
   The suspended command (internal status) turns active when there is any AHB prefetch command aborted and suspended. It turns inactive in following cases:
   
   - Suspended command is resumed by Arbitrator.
   - There is a new AHB read command request and it's triggered by AHB master using the same AHB RX Buffer (Buffer ID).

   **NOTE**
   
   - MCR0[SWRESET] can be used to clear any suspended command. It means saved suspended command will be dropped and no more resume will happen. Clearing suspended command is needed after flash page program/erase or any other command may lead period of time that flash can not support read command.

Following is an example indicating command abort/suspend/resume flow:
27.5.12 SCLK stop feature

FlexSPI will stop SCLK output toggling when programming data is not ready for programming command sequence or there is no space (in internal FIFO) to receive data for reading command sequence.

There may be certain devices that do not support SCLK stopped during command sequence (chip select is valid). SCLK stopping could be avoid as following:

- For flash reading triggered by IP command
  - Never trigger a read command with data size larger than IP RX FIFO size.
  - Internal async FIFO for flash reading should never be full.

  FlexSPI pop data from this async FIFO in 64 bits per AHB clock cycle, and receiving data from FlexSPI interface in serial root clock. The receiving speed is determined by Flash access mode (Single/Dual/Quad/Octal mode and Individual/Parallel mode). For example, in Octal mode and Parallel mode, FlexSPI receives 16 bits per serial root clock cycle. This async FIFO is never full if AHB clock frequency is higher than 1/4 of serial root clock.

- For flash programming triggered by IP command
  - Never trigger a program command with data size larger than IP TX FIFO size.
  - Fill all programming data into IP TX FIFO before trigger the IP command.
  - Internal async FIFO for flash programming should never be empty

  FlexSPI fetch programming data into this async FIFO in 64 bits per AHB clock cycle, and transmitting data to FlexSPI interface in serial root clock. The transmitting speed is determined by Flash access mode (Single/Dual/Quad/Octal mode and Individual/Parallel mode). For example, in Octal mode and Parallel mode, FlexSPI transmits 16 bits per serial root clock cycle. This async FIFO is never empty if AHB clock frequency is higher than 1/4 of serial root clock.

- For flash reading/programming triggered by AHB command
- Internal async FIFO for flash reading/programming should never be full/empty. The frequency ratio limitation is same as flash reading/programming triggered by IP command.

**NOTE**
- FlexSPI never trigger a AHB read command with data size larger than internal AHB RX buffer size.
- FlexSPI never trigger a AHB program command with data size larger than internal AHB TX buffer size.
- All programming data is buffered into AHB TX Buffer before triggering AHB program command in FlexSPI.

### 27.5.13 FlexSPI Output Timing

This section describes the output timing in FlexSPI.

#### 27.5.13.1 Output timing between Data and SCLK

This section describes the output timing relationship of data (on A_DATA/B_DATA) and SCLK. There are three cases for the data output timing:

- **SDR instruction in SDR sequence**
  SDR sequence is the sequence which contains only SDR instructions. In this case, all data bits last one serial root clock cycle on FlexSPI interface. Following diagram indicates the relationship of serial root clock, data and SCLK:

![Figure 27-23. SDR instruction in SDR sequence](image)

- **SDR instruction in DDR sequence**
  DDR sequence is a flash access command sequence that contain DDR instruction which is not DUMMY, it may contain SDR instructions optionally. In the case of SDR instruction in DDR sequence, all data bits last two serial root clock cycles on FlexSPI interface. Following diagram indicates the relationship of serial root clock, data and SCLK:
• DDR instruction in DDR sequence
In the case of DDR instruction in DDR sequence, all data bits last one serial root clock cycle on FlexSPI interface. Following diagram indicates the relationship of serial root clock, data and SCLK:

Figure 27-24. SDR instruction in DDR sequence

Figure 27-25. DDR instruction in DDR sequence

27.5.13.2 Output timing between Chip selection and SCLK
This section describes the output timing relationship of Chip select (on A_SS0_B/A_SS1_B/B_SS0_B/B_SS1_B) and SCLK. The timing relationship is a little different for SDR sequence and DDR sequence.

• Chip Select timing in SDR sequence
For SDR sequence, the delay from chip select assertion and the SCLK rising edge is (FLSHxCR1[TCSS]+0.5) cycles of serial root clock; The delay from SCLK falling edge and chip select deassertion is FLSHxCR1[TCSH] cycles of serial root clock. Following diagram indicates the timing relationship between chip selection and SCLK:
For DDR sequence, the delay from chip selection assertion and SCLK rise edge is (TCSS+0.5) cycles of serial root clock; The delay from SCLK fall edge and chip selection deassertion is (TCSH+0.5) cycles of serial root clock.

**NOTE**
When AHB RX prefetch is enabled, and prefetch can be aborted, set TCSH to be least 1 to guarantee positive chip select hold time after SCK falling edge.

Following diagram indicates the timing relationship between chip selection and SCLK:

For certain device (such as FPGA device), there is limitation on the interval between Chip Selection valid. FlexSPI will ensure a delay time between chip selection valid if register field FLSHxCR1[CSINTERVAL] is set to non-zero value. The delay time is: CSINTERVAL*1024 cycle of serial root clock no matter SDR or DDR sequence. Please set this register field value to zero if there is no this limitation for external device.
Following diagram indicates the timing of chip selection interval.
27.5.14 FlexSPI Input Timing

This section describes the input timing of FlexSPI.

27.5.14.1 RX Clock Source Features

This section describes the features of each RX clock source.

- **Internal dummy read strobe and loopback internally** (MCR0[RXCLKSRC]==0)
  
  Supporting legacy device with zero device output hold time.
  
  Saving one pad (DQS pad).
  
  Supporting low frequency clock for boot up usage.

- **Internal dummy read strobe and loopbacked from DQS pad** (MCR0[RXCLKSRC]==1)
  
  Supporting higher frequency than mode "MCR0[RXCLKSRC]==0".
  
  Supporting device doesn't provide read strobe.

- **Flash provided read strobe** (MCR0[RXCLKSRC]==3)
  
  Supporting the highest frequency.
  
  Supporting device provides read strobe.

27.5.14.2 Input timing for sampling with dummy read strobe

This section describes the input timing when sampling with internal dummy read strobe (MCR0[RXCLKSRC] is set to 0x0 or 0x1). The timing is very similar for sampling with dummy read strobe loopback internally and loopback from pad. But it could achieve...
higher read frequency by sampling with dummy read strobe loopback from DQS pad because it will compensate the delay of SCLK output path and Data pin input path. The input timing is different for SDR mode and DDR mode.

- **Input timing for sampling with dummy read strobe in SDR mode**

For SDR Read/Learn instruction, FlexSPI samples input data pins with the falling edge of dummy read strobe. Following diagram indicates the input timing for sampling with dummy read strobe in SDR mode.

![Input Timing for sampling with dummy read strobe in SDR mode](image)

**Figure 27-29. Input Timing for sampling with dummy read strobe in SDR mode**

- **Input timing for sampling with dummy read strobe in DDR mode**

For DDR Read/Learn instruction, FlexSPI sample input data pins with both rise and fall edge of dummy read strobe. Following diagram indicates the input timing for sampling with dummy read strobe in DDR mode.

![Input Timing for sampling with dummy read strobe in DDR mode](image)

**Figure 27-30. Input Timing for sampling with dummy read strobe in DDR mode**
27.5.14.3 Input timing for sampling with flash provided read strobe

This section describes the input timing when sampling with flash provided read strobe (MCR0[RXCLKSRC] is set to 0x3). The input timing is different for SDR mode and DDR mode.

**NOTE**

There are no known devices that provide read strobe and support SDR mode operation.

There are two kinds of Flash provided read strobe:

- **Flash provide read strobe with SCLK**

  For certain flash devices, it provides both read data and read strobes with SCLK. Then the read strobe edge is aligned with read data change. FlexSPI controller should delay read strobe by half cycle in serial root clock (with DLL) and then sample read data with delayed strobe. Refer [DLL configuration for sampling](#) for more details.

  Following diagrams indicates the input timing for sampling with flash read strobe in SDR mode and DDR mode:

![Diagram](image)

**Figure 27-31. Input Timing 2 for Flash provided read strobe in SDR mode**
Figure 27-32. Input Timing 2 for Flash provided read strobe in DDR mode

27.5.14.4 DLL configuration for sampling

The input timing is different for those four sampling clock source. This is handled by setting register DLLxCR differently according to the sampling clock source mode. DLL is a delay line chain, which could be set to a fixed number of delay cells or auto-adjusted to lock on a certain phase delay to the reference clock.

- In following cases, DLLxCR should be set 0x00000100 (1 fixed delay cells in DLL delay chain):
  - Sampling data with Dummy read strobe loopbacked internally (MCR0[RXCLKSRC]=0x0)
  - Sampling data with Dummy read strobe loopbacked from DQS pad (MCR0[RXCLKSRC]=0x1)
- When data is sampled with Flash provided read strobe (MCR0[RXCLKSRC]=0x3) and flash provides read strobe with SCLK, DLL should be set as following to lock on half cycle of the reference clock (serial root clock)
  - SLVDLYTARGET=0xF
• DLLEN=0x1
• OVRDEN=0x0
• Other fields in DLLxCR should be kept as reset value (all zero)

**NOTE**
If serial root clock is lower than 100 MHz, DLL is unable to lock on half cycle of serial root clock because the delay cell number is limited in delay chain. Then DLL should be configured as following instead:

- OVRDEN=0x1
- OVRDVAL=N: Each delay cell in DLL is about 75 ps~225 ps. The delay of DLL delay chain is (N * Delay_cell_delay), N should be set based on max. DDR frequency that current project supported, N = 21, please notice this is a recommended value. May need to adjust in real application if facing failure.
- Other fields in DLLxCR should be kept as reset value (all zero).

### 27.5.15 XIP Enhanced Mode

FlexSPI always supports Execute-In-Place (XIP), no matter external device provided XIP enhanced mode or not. Execute-In-Place is supported by putting program code on External device, then read/execute on external device directly by AHB read access to SFM space. There is no configuration or status polling needed during AHB read access to External device memory and AHB RX buffer is fully transparent to software.

Certain devices provide XIP enhanced mode to improve code execution. In this mode, there is no need to provide Command code for Read Sequence. It saves many cycles for Command Instructions and greatly improves code execution. This XIP enhanced mode is entered/exit by a special sequence which is device specified. Please refer to external device datasheet for more detail.

Normally, the XIP enhanced mode is entered by following sequence:

1. Enable XIP enhanced mode in External Flash by IP command
2. Send the first Read Sequence to External Flash device with correct Mode bits. Command code is needed in this Read sequence.
3. Send following Read sequences to External Flash device with correct Mode bits. Command code is not needed in these Read Sequences. But Mode bits should be sent according to Flash specified. Otherwise Flash will exit Execute-In-Place Enhanced mode.
The instruction JMP_ON_CS in FlexSPI should be used to support external device XIP enhanced mode. This instruction is only allowed in AHB Read command, otherwise there will be IPCMDERR or AHBCDMERR error interrupt generated if this interrupt is enabled. JMP_ON_CS should never be used if device doesn't support XIP enhanced mode. To support XIP enhanced mode, the first instruction in the Read Sequence should be Command instruction and the last valid instruction should be JMP_ON_CS (with operand 0x1).

For the first AHB read Command triggered, FlexSPI will execute the instructions from the instruction pointer 0 in the sequence (which is Command instruction). After this sequence executed FlexSPI will save operand in JMP_ON_CS instruction as start pointer for next Command to current device internally. For the following AHB read Command triggered, FlexSPI will execute from instruction pointer 0x1 and Command instruction is bypassed.

Following diagram indicates XIP operation with Flash XIP Enhanced mode:

![Figure 27-33. XIP Enhanced Mode operation](image)

### 27.6 Application information

This section describes applications supported by the FlexSPI module.

#### 27.6.1 FlexSPI Initialization

FlexSPI controller initialization sequence is as following:

- Enable controller clocks (AHB clock/IP Bus clock/Serial root clock) in System level.
- Power the FlexSPI SRAM using PDRUNCFG registers.
- Release FlexSPI from reset using PRSTCRL registers.
- Set MCR0[MDIS] to 0x1 (Make sure controller is configured in module stop mode)
- Configure module control registers: MCR0, MCR1, MCR2. (Don't change MCR0[MDIS])
- Configure AHB bus control register (AHBCR) and AHB RX Buffer control register (AHBRXBUFxCR0) optionally, if AHB command will be used
- Configure Flash control registers (FLSHxCR0, FLSHxCR1, FLSHxCR2) according to external device type
• Configure DLL control register (DLLxCR) according to sample clock source selection
• set MCR0[MDIS] to 0x0 (Exit module stop mode)
• Configure LUT as needed (For AHB command or IP command)
• Reset controller optionally (by set MCR0[SWRESET] to 0x1)

External device needs configuration by IP command normally after controller initialization. For example, the device configuration is done by WRITE STATUS command for most serial NOR Flash.

### 27.6.2 Overview of Error Flags

The following table gives an overview of error category, flags and triggered source.

**Table 27-9. Error category and flags in FlexSPI**

<table>
<thead>
<tr>
<th>Error Category</th>
<th>Triggered Source</th>
<th>Description</th>
<th>Error Flags</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command grant error</td>
<td>AHB write command</td>
<td>Command grant timeout</td>
<td>INTR[AHBCMDGE] will be set</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>AHB bus error response</td>
</tr>
<tr>
<td></td>
<td>AHB read command</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>IP command</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Command check error</td>
<td>AHB write command</td>
<td>• AHB write command with JMP_ON_CS instruction used in the sequence</td>
<td>INTR[AHBCMDERR] will be set</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• There is unknown instruction opcode in the sequence.</td>
<td>Command is not executed when error detected in command check</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Instruction DUMMY_SDR/DUMMY_RWDS_SDR used in DDR sequence.</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Instruction DUMMY_DDR/DUMMY_RWDS_DDR used in SDR sequence.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>AHB read command</td>
<td>• There is unknown instruction opcode in the sequence.</td>
<td>INTR[AHBCMDERR] will be set</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Instruction DUMMY_SDR/DUMMY_RWDS_SDR used in DDR sequence.</td>
<td>Command is not executed when error detected in command check</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• Instruction DUMMY_DDR/DUMMY_RWDS_DDR used in SDR sequence.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>IP command</td>
<td>• IP command with JMP_ON_CS instruction used in the sequence</td>
<td>INTR[IPCMDERR] will be set</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• There is unknown instruction opcode in the sequence.</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Error Category</th>
<th>Triggered Source</th>
<th>Description</th>
<th>Error Flags</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command execution</td>
<td>AHB write command</td>
<td>Command timeout during execution</td>
<td>INTR[AHBCMDERR] will be set</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>INTR[SEQTIMEOUT] will be set</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>There will be AHB bus error response except following case:</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• AHB write command is triggered by flush (INCR burst ended with AHB_TX_BUF not empty)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>• AHB bufferable write access and bufferable enabled (AHBCR[BUFFABLEN]=0x1)</td>
</tr>
<tr>
<td></td>
<td>AHB read command</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>IP command</td>
<td></td>
<td></td>
</tr>
<tr>
<td>AHB Bus timeout</td>
<td>AHB write command</td>
<td>AHB bus timeout (no bus ready return)</td>
<td>INTR[AHBBUSTIMEOUT] will be set</td>
</tr>
<tr>
<td></td>
<td>AHB read command</td>
<td></td>
<td>There will be AHB bus error response</td>
</tr>
</tbody>
</table>

**NOTE**

- flash_top_address is the top address of currently accessed flash
27.6.3 Application on Serial NOR Flash device

This section provides the example sequences for serial NOR Flash device (Cypress Flash S25FS128S).

27.6.3.1 Write Enable command

The following table shows WRITE ENABLE command sequence.

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0</td>
<td>0x06</td>
<td>command name:WREN</td>
</tr>
<tr>
<td>1–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

27.6.3.2 Write Registers command

The following table shows Write Registers command sequence.

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0x01</td>
<td>command name:WRR</td>
</tr>
<tr>
<td>1</td>
<td>WRITE_SDR</td>
<td>0x0 (Single)</td>
<td>0x1 or 0x2</td>
<td>Data size is 1 or 2 byte. Byte 0 write data for Status Register 1; Byte 1 write data for Configuration Register 1 This value could be overridden by IPCR1[IDATSZ].</td>
</tr>
<tr>
<td>2–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

27.6.3.3 Page Program command

The following table shows Page Program command sequence.
Table 27-12. PAGE PROGRAM command (Cypress serial NOR flash)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0x02 or 0x12</td>
<td>command name: PP or 4PP</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PP is 3-Byte address mode.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>4PP is 4-Byte address mode.</td>
</tr>
<tr>
<td>1</td>
<td>ADDR_SDR</td>
<td>0x0 (Single)</td>
<td>0x18 or 0x20</td>
<td>Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode.</td>
</tr>
<tr>
<td>2</td>
<td>WRITE_SDR</td>
<td>0x0 (Single)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default programming data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>3–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

The following table shows Page Program command sequence (QPI mode).

Table 27-13. PAGE PROGRAM (QPI mode) command (Cypress serial NOR flash)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x2 (Quad)</td>
<td>0x02 or 0x12</td>
<td>command name: PP or 4PP</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PP is 3-Byte address mode.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>4PP is 4-Byte address mode.</td>
</tr>
<tr>
<td>1</td>
<td>ADDR_SDR</td>
<td>0x2 (Quad)</td>
<td>0x18 or 0x20</td>
<td>Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode.</td>
</tr>
<tr>
<td>2</td>
<td>WRITE_SDR</td>
<td>0x2 (Quad)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default programming data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>3–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

27.6.3.4 Read Status 1 command

The following table shows READ STATUS 1 command sequence.

Table 27-14. READ STATUS 1 command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0x05</td>
<td>command name: RDSR1</td>
</tr>
<tr>
<td>1</td>
<td>READ_SDR</td>
<td>0x0 (Single)</td>
<td>0x1</td>
<td>1 Byte for Status register 1</td>
</tr>
<tr>
<td>2–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>
27.6.3.5 Read command

The following table shows READ command sequence.

Table 27-15. READ command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0x03 or 0x13</td>
<td>command name: READ or 4READ. READ is 3-Byte address mode. 4READ is 4-Byte address mode</td>
</tr>
<tr>
<td>1</td>
<td>ADDR_SDR</td>
<td>0x0 (Single)</td>
<td>0x18 or 0x20</td>
<td>Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode.</td>
</tr>
<tr>
<td>2</td>
<td>READ_SDR</td>
<td>0x0 (Single)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>3–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

27.6.3.6 Fast Read command

The following table shows Fast Read command sequence (In the case of Cypress SPI Configuration Register bits CR2V[7]=0, CR2V[3:0]=0x8).

Table 27-16. FAST_READ command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0x0B or 0x0C</td>
<td>command name: FAST_READ or 4FAST_READ. FAST_READ is 3-Byte address mode. 4FAST_READ is 4-Byte address mode</td>
</tr>
<tr>
<td>1</td>
<td>ADDR_SDR</td>
<td>0x0 (Single)</td>
<td>0x18 or 0x20</td>
<td>Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode.</td>
</tr>
<tr>
<td>2</td>
<td>DUMMY_SDR</td>
<td>0x0 (Single)</td>
<td>0x08</td>
<td>Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8.</td>
</tr>
<tr>
<td>3</td>
<td>READ_SDR</td>
<td>0x0 (Single)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>4–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>
27.6.3.7 Dual IO Fast Read command

The following table shows Dual IO FAST_READ command sequence (In the case of Cypress SPI Configuration Register bits CR2V[7]=0, CR2V[3:0]=0x8, Continuous Read mode).

**Table 27-17. Dual IO FAST_READ command (Continuous Read mode)**

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0               | CMD_SDR                | 0x0 (Single)             | 0xBB or 0xBC            | command name: DIOR or 4DIOR  
DIOR is 3-Byte address mode.  
4DIOR is 4-Byte address mode |
| 1               | ADDR_SDR               | 0x1 (Dual)               | 0x18 or 0x20            | Address bit number (operand value)  
should be 24 in 3-Byte address mode  
and 32 in 4-Byte address mode. |
| 2               | MODE8_SDR              | 0x1 (Dual)               | 0Ax                     | Enter continuous read mode or keep in  
continuous read mode. |
| 3               | DUMMY_SDR              | 0x1 (Dual)               | 0x08                    | Dummy cycle is 8 (in serial root clock) as  
CR2V[3:0]=0x8. |
| 4               | READ_SDR               | 0x1 (Dual)               | Any non-zero value      | This operand value could be used as  
default reading data size if  
IPCR1[IDATSZ] is zero. This value is  
ignored for AHB command. |
| 5               | JMP_ON_CS              | 0x0 (or Dont care)       | 0x01                    | The CMD instruction will be bypassed  
after the first read access. |
| 6-7             | STOP (0x00)            |                          | 0x00                    |                                  |

The following table shows Dual IO FAST_READ command sequence (In the case of Cypress SPI Configuration Register bits CR2V[7]=0, CR2V[3:0]=0x8, Non-continuous Read mode).

**Table 27-18. Dual IO FAST_READ command (Non-continuous Read mode)**

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0               | CMD_SDR                | 0x0 (Single)             | 0xBB or 0xBC            | command name: DIOR or 4DIOR  
DIOR is 3-Byte address mode.  
4DIOR is 4-Byte address mode |
| 1               | ADDR_SDR               | 0x1 (Dual)               | 0x18 or 0x20            | Address bit number (operand value)  
should be 24 in 3-Byte address mode  
and 32 in 4-Byte address mode. |
| 2               | MODE8_SDR              | 0x1 (Dual)               | Any value other than 0xAx | Exit continuous read mode or keep in  
non-continuous read mode. |

*Table continues on the next page...*
Table 27-18. Dual IO FAST_READ command (Non-continuous Read mode) (continued)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>DUMMY_SDR</td>
<td>0x1 (Dual)</td>
<td>0x08</td>
<td>Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8.</td>
</tr>
<tr>
<td>4</td>
<td>READ_SDR</td>
<td>0x1 (Dual)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default reading data size if IPCR1[1DATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>5–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

27.6.3.8 Quad IO Fast Read command

The following table shows Quad IO FAST_READ command sequence (In the case of Cypress SPI Configuration Register bits CR2V[7]=0, CR2V[6]=0, CR2V[3:0]=0x8, Non-QPI mode, Non-continuous read mode).

Table 27-19. Quad IO FAST_READ command (Non-QPI mode, Non-continuous read mode)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0xEB or 0xEC</td>
<td>command name:QIOR or 4QIOR QIOR is 3-Byte address mode. 4QIOR is 4-Byte address mode</td>
</tr>
<tr>
<td>1</td>
<td>ADDR_SDR</td>
<td>0x2 (Quad)</td>
<td>0x18 or 0x20</td>
<td>Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode.</td>
</tr>
<tr>
<td>2</td>
<td>MODE8_SDR</td>
<td>0x2 (Quad)</td>
<td>Any value other than 0xAx</td>
<td>Exit continuous read mode or keep in non-continuous read mode.</td>
</tr>
<tr>
<td>3</td>
<td>DUMMY_SDR</td>
<td>0x2 (Quad)</td>
<td>0x08</td>
<td>Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8.</td>
</tr>
<tr>
<td>4</td>
<td>READ_SDR</td>
<td>0x2 (Quad)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default reading data size if IPCR1[1DATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>5–7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

The following table shows Quad IO FAST_READ command sequence (In the case of Cypress SPI Configuration Register bits CR2V[7]=0, CR2V[6]=0, CR2V[3:0]=0x8, Non-QPI mode, Continuous read mode).
Table 27-20. Quad IO FAST_READ command (Non-QPI mode, Continuous read mode)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction name</th>
<th>opcode[5:0]</th>
<th>num_pads[1:0]</th>
<th>operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0               | CMD_SDR         | 0x0 (Single)| 0xEB or 0xEC  | 0xEB or 0xEC| command name:QIOR or 4QIOR  
QIOR is 3-Byte address mode.  
4QIOR is 4-Byte address mode |
| 1               | ADDR_SDR        | 0x2 (Quad)  | 0x18 or 0x20  | 0x18 or 0x20| Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode. |
| 2               | MODE8_SDR       | 0x2 (Quad)  | 0xA0          | 0xA0        | Enter continuous read mode or keep in continuous read mode. |
| 3               | DUMMY_SDR       | 0x2 (Quad)  | 0x08          | 0x08        | Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8. |
| 4               | READ_SDR        | 0x2 (Quad)  | Any non-zero value | Any non-zero value | This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command. |
| 5               | JMP_ON_CS       | 0x0 (or Don’t care) | 0x01        | 0x01        | The CMD instruction will be bypassed after the first read access. |
| 6~7             | STOP (0x00)     | 0x00        |               | 0x00        |         |


Table 27-21. Quad IO FAST_READ command (QPI mode, Continuous read mode)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction name</th>
<th>opcode[5:0]</th>
<th>num_pads[1:0]</th>
<th>operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0               | CMD_SDR         | 0x2 (Quad)  | 0xEB or 0xEC  | 0xEB or 0xEC| command name:QIOR or 4QIOR  
QIOR is 3-Byte address mode.  
4QIOR is 4-Byte address mode |
| 1               | ADDR_SDR        | 0x2 (Quad)  | 0x18 or 0x20  | 0x18 or 0x20| Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode. |
| 2               | MODE8_SDR       | 0x2 (Quad)  | 0xA0          | 0xA0        | Enter continuous read mode or keep in continuous read mode. |
| 3               | DUMMY_SDR       | 0x2 (Quad)  | 0x08          | 0x08        | Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8. |
| 4               | READ_SDR        | 0x2 (Quad)  | Any non-zero value | Any non-zero value | This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command. |
| 5               | JMP_ON_CS       | 0x0 (or Don’t care) | 0x01        | 0x01        | The CMD instruction will be bypassed after the first read access. |
| 6~7             | STOP (0x00)     | 0x00        |               | 0x00        |         |
27.6.3.9 DDR Quad IO Fast Read command

The following table shows DDR Quad IO FAST_READ command sequence (In the case of Cypress SPI Configuration Register bits CR2V[7]=0, CR2V[6]=0, CR2V[3:0]=0x8, Non-QPI mode, Non-continuous read mode).

Table 27-22. DDR Quad IO FAST_READ command (Non-QPI mode, Non-continuous read mode)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0xED or 0xEE</td>
<td>command name:QIOR_DDR or 4QIOR_DDR</td>
<td>QIOR_DDR is 3-Byte address mode. 4QIOR_DDR is 4-Byte address mode</td>
</tr>
<tr>
<td>1</td>
<td>ADDR_DDR</td>
<td>0x2 (Quad)</td>
<td>0x18 or 0x20</td>
<td>Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode.</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>MODE8_DDR</td>
<td>0x2 (Quad)</td>
<td>Any value other than 0xAx</td>
<td>Exit continuous read mode or keep in non-continuous read mode.</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>DUMMY_DDR</td>
<td>0x2 (Quad)</td>
<td>0x08</td>
<td>Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8.</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>LEARN_DDR</td>
<td>0x2 (Quad)</td>
<td>0x01</td>
<td>DLP (Data Learning Pattern is 8 bits).</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>READ_DDR</td>
<td>0x2 (Quad)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command.</td>
<td></td>
</tr>
<tr>
<td>6~7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The following table shows DDR Quad IO FAST_READ command sequence (In the case of Cypress SPI Configuration Register bits CR2V[7]=0, CR2V[6]=0, CR2V[3:0]=0x8, Non-QPI mode, Continuous read mode).

Table 27-23. DDR Quad IO FAST_READ command (Non-QPI mode, Continuous read mode)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x0 (Single)</td>
<td>0xED or 0xEE</td>
<td>command name:QIOR_DDR or 4QIOR_DDR</td>
<td>QIOR_DDR is 3-Byte address mode. 4QIOR_DDR is 4-Byte address mode</td>
</tr>
<tr>
<td>1</td>
<td>ADDR_DDR</td>
<td>0x2 (Quad)</td>
<td>0x18 or 0x20</td>
<td>Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode.</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>MODE8_DDR</td>
<td>0x2 (Quad)</td>
<td>0xA0</td>
<td>Enter continuous read mode or keep in continuous read mode.</td>
<td></td>
</tr>
</tbody>
</table>
Table 27-23. DDR Quad IO FAST_READ command (Non-QPI mode, Continuous read mode) (continued)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>DUMMY_DDR</td>
<td>0x2 (Quad)</td>
<td>0x08</td>
<td>Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8.</td>
</tr>
<tr>
<td>4</td>
<td>LEARN_DDR</td>
<td>0x2 (Quad)</td>
<td>0x1</td>
<td>DLP (Data Learning Pattern is 8 bits).</td>
</tr>
<tr>
<td>5</td>
<td>READ_DDR</td>
<td>0x2 (Quad)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>6</td>
<td>JMP_ON_CS</td>
<td>0x0 (or Dont care)</td>
<td>0x01</td>
<td>The CMD instruction will be bypassed after the first read access.</td>
</tr>
<tr>
<td>7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>


Table 27-24. DDR Quad IO FAST_READ command (QPI mode, Continuous read mode)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0               | CMD_SDR                 | 0x2 (Quad)               | 0xED or 0xEE             | command name:QIOR_DDR or 4QIOR_DDR  
QIOR_DDR is 3-Byte address mode.  
4QIOR_DDR is 4-Byte address mode |
| 1               | ADDR_DDR                | 0x2 (Quad)               | 0x18 or 0x20             | Address bit number (operand value) should be 24 in 3-Byte address mode and 32 in 4-Byte address mode. |
| 2               | MODE8_DDR               | 0x2 (Quad)               | 0xA0                     | Enter continuous read mode or keep in continuous read mode. |
| 3               | DUMMY_DDR               | 0x2 (Quad)               | 0x08                     | Dummy cycle is 8 (in serial root clock) as CR2V[3:0]=0x8. |
| 4               | LEARN_DDR               | 0x2 (Quad)               | 0x1                      | DLP (Data Learning Pattern is 8 bits). |
| 5               | READ_DDR                | 0x2 (Quad)               | Any non-zero value       | This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command. |
| 6               | JMP_ON_CS               | 0x0 (or Dont care)       | 0x01                     | The CMD instruction will be bypassed after the first read access. |
| 7               | STOP (0x00)             | 0x0                      | 0x00                     |                                  |
27.6.4 Application on HyperBus device

This section provides the example sequences for HyperBus device (Cypress RPC flash/HyperRam/HyperFlash).

27.6.4.1 HyperFlash

This section provides the example sequences for HyperFlash devices (Cypress S26KS series).

The following table shows Read Status command sequence.

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0       | CMD_DDR         | 0x3 (Octal)             | 0x20                     |                          | CA bit 47: (R/W#) = 0x0  
|         |                 |                         |                          |                         | CA bit 46: (Target) = 0x0  
|         |                 |                         |                          |                         | CA bit 45: (Burst Type) = 0x1  
|         |                 |                         |                          |                         | CA bit 44-40: All reserved = 0x0  
| 1       | CMD_DDR         | 0x3 (Octal)             | 0x00                     |                          | Row Address: 0x0000AA (24 bit)  
| 2       | CMD_DDR         | 0x3 (Octal)             | 0x00                     |                          |                     
| 3       | CMD_DDR         | 0x3 (Octal)             | 0xAA                     |                          |                     
| 4       | CMD_DDR         | 0x3 (Octal)             | 0x00                     |                          | Column Address: 0x05 (13 zero bits + 3 valid bits)  
| 5       | CMD_DDR         | 0x3 (Octal)             | 0x05                     |                          |                     
| 6       | CMD_DDR         | 0x3 (Octal)             | 0x00                     |                          | Write Data: 0x0070  
| 7       | CMD_DDR         | 0x3 (Octal)             | 0x70                     |                          |                     |

| 1       | RADDR_DDR       | 0x3 (Octal)             | 0xA0                     |                          | CA bit 47: (R/W#) = 0x1  
|         |                 |                         |                          |                         | CA bit 46: (Target) = 0x0  
|         |                 |                         |                          |                         | CA bit 45: (Burst Type) = 0x1  
|         |                 |                         |                          |                         | CA bit 44-40: All reserved = 0x0  
| 1       | CADDR_DDR       | 0x3 (Octal)             | 0x18                     |                          | Row Address: 24 bits  
| 2       | DUMMY_RWDS_DDR  | 0x3 (Octal)             | 0x0B                     |                          | In case of latency count=11  
| 4       | READ_DDR        | 0x3 (Octal)             | 0x4                      |                          | 4 Byte read  
| 5~7     | STOP (0x00)     | 0x0                      | 0x00                     |                          |                     |

The following table shows Read (memory) command sequence.
### Table 27-26. Read (memory) command

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0       | 0               | CMD_DDR                 | 0x3 (Octal)              | 0xA0                    | CA bit 47: (R/W#) = 0x1  
          |                 |                         |                          |                          | CA bit 46: (Target) = 0x0  
          |                 |                         |                          |                          | CA bit 45: (Burst Type) = 0x1  
          |                 |                         |                          |                          | CA bit 44-40: All reserved = 0x0  |
| 1       | 1               | RADDR_DDR               | 0x3 (Octal)              | 0x18                    | Row Address: 24 bits |
| 2       | 2               | CADDR_DDR               | 0x3 (Octal)              | 0x10                    | Column Address: (13 zero bits + 3 valid bits) |
| 3       | 3               | DUMMY_RWDS_DDR          | 0x3 (Octal)              | 0x0B                    | In case of latency count=11 |
| 4       | 4               | READ_DDR                | 0x3 (Octal)              | Any non-zero value      | This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command. |
| 5~7     | 5~7             | STOP (0x00)             | 0x0                      | 0x00                    |         |

The following table shows Word Program command sequence.

### Table 27-27. Word Program command

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0       | 0               | CMD_DDR                 | 0x3 (Octal)              | 0x20                    | CA bit 47: (R/W#) = 0x0  
          |                 |                         |                          |                          | CA bit 46: (Target) = 0x0  
          |                 |                         |                          |                          | CA bit 45: (Burst Type) = 0x1  
          |                 |                         |                          |                          | CA bit 44-40: All reserved = 0x0  |
| 1       | 1               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    | Row Address: 0x0000AA (24 bit) |
| 2       | 2               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    | Column Address: 0x05 (13 zero bits + 3 valid bits) |
| 3       | 3               | CMD_DDR                 | 0x3 (Octal)              | 0xAA                    | Write Data: 0x00AA |
| 4       | 4               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    |         |
| 5       | 5               | CMD_DDR                 | 0x3 (Octal)              | 0x05                    |         |
| 6       | 6               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    |         |
| 7       | 7               | CMD_DDR                 | 0x3 (Octal)              | 0xAA                    |         |

1

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
</table>
| 0       | 0               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    | CA bit 47: (R/W#) = 0x0  
          |                 |                         |                          |                          | CA bit 46: (Target) = 0x0  
          |                 |                         |                          |                          | CA bit 45: (Burst Type) = 0x1  
          |                 |                         |                          |                          | CA bit 44-40: All reserved = 0x0  |
| 1       | 1               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    | Row Address: 0x0000055 (24 bit) |
| 2       | 2               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    | Column Address: 0x02 (13 zero bits + 3 valid bits) |
| 3       | 3               | CMD_DDR                 | 0x3 (Octal)              | 0x55                    |         |
| 4       | 4               | CMD_DDR                 | 0x3 (Octal)              | 0x00                    |         |
### Table 27-27. Word Program command (continued)

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x02</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td>Write Data: 0x0055</td>
</tr>
<tr>
<td>7</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x55</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### 2 (Write - Addr=0x555, Data=0xAA)

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td></td>
<td>CA bit 47: (R/W#) = 0x0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 46: (Target) = 0x0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 45: (Burst Type) = 0x1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 44-40: All reserved = 0x0</td>
</tr>
<tr>
<td>1</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td>Row Address: 0x0000AA (24 bit)</td>
</tr>
<tr>
<td>2</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0xAA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td>Write Data: 0x00A0</td>
</tr>
<tr>
<td>5</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x55</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td>Write Data: 0x00A0</td>
</tr>
<tr>
<td>7</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0xA0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### 3 (Word Program)

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td></td>
<td>CA bit 47: (R/W#) = 0x0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 46: (Target) = 0x0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 45: (Burst Type) = 0x1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 44-40: All reserved = 0x0</td>
</tr>
<tr>
<td>1</td>
<td>RADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x18</td>
<td></td>
<td>Row Address: 24 bits</td>
</tr>
<tr>
<td>2</td>
<td>CADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x10</td>
<td></td>
<td>Column Address: (13 zero bits + 3 valid bits)</td>
</tr>
<tr>
<td>3</td>
<td>WRITE_DDR</td>
<td>0x3 (Octal)</td>
<td>0x02</td>
<td></td>
<td>2 Byte written data</td>
</tr>
<tr>
<td>4-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The following table shows Written-to-Buffer and Program-Buffer-to-Flash command sequence.

### Table 27-28. Written-to-Buffer and Program-Buffer-to-Flash command

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td></td>
<td>CA bit 47: (R/W#) = 0x0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 46: (Target) = 0x0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 45: (Burst Type) = 0x1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 44-40: All reserved = 0x0</td>
</tr>
<tr>
<td>1</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td>Row Address: 0x0000AA (24 bit)</td>
</tr>
<tr>
<td>2</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0xAA</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 27-28. Written-to-Buffer and Program-Buffer-to-Flash command (continued)

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td>Column Address: 0x05 (13 zero bits + 3 valid bits)</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x05</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td>Write Data: 0x00AA</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0xAA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td>CA bit 47: (R/W#) = 0x0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 46: (Target) = 0x0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 45: (Burst Type) = 0x1</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 44-40: All reserved = 0x0</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>RADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td>Row Address: 0x000055 (24 bit)</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>CADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x55</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td>Column Address: 0x02 (13 zero bits + 3 valid bits)</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td>Write Data: 0x0055</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x55</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td>CA bit 47: (R/W#) = 0x0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 46: (Target) = 0x0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 45: (Burst Type) = 0x1</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 44-40: All reserved = 0x0</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>RADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x18</td>
<td>Row Address: SA (24 bit)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SA is sector address. Please set IPCR0[SFAR]=SA</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>CADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x10</td>
<td>Column Address: 13 zero bits + 3 valid bits</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td>Write Data: 0x0025</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td>CA bit 47: (R/W#) = 0x0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 46: (Target) = 0x0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 45: (Burst Type) = 0x1</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 44-40: All reserved = 0x0</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>RADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x18</td>
<td>Row Address: SA (24 bit)</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SA is sector address. Please set IPCR0[SFAR]=SA</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>CADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x10</td>
<td>Column Address: 13 zero bits + 3 valid bits</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>WC</td>
<td>Write Data: WC</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>WC</td>
<td>WC is word count</td>
<td></td>
</tr>
<tr>
<td>3 - N</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td>CA bit 47: (R/W#) = 0x0</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CA bit 46: (Target) = 0x0</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 27-28. Written-to-Buffer and Program-Buffer-to-Flash command (continued)

<table>
<thead>
<tr>
<th>Seq No.</th>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>(Write - Addr=WBL, Data=PD) N is the word count + 2</td>
<td></td>
<td>0x3 (Octal)</td>
<td>0x18</td>
<td></td>
<td>Row Address: WBL (24 bit) WBL is write buffer location. Please set IPCR0[SFAR]=WBL</td>
</tr>
<tr>
<td>1</td>
<td>RADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x10</td>
<td></td>
<td>Column Address: 13 zero bits + 3 valid bits</td>
</tr>
<tr>
<td>2</td>
<td>CADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x02</td>
<td></td>
<td>2 Byte write data</td>
</tr>
<tr>
<td>3</td>
<td>WRITE_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>N+1 (Write - Addr=SA, Data=29) Program Buffer to Flash</td>
<td></td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td></td>
<td>CA bit 47: (R/W#) = 0x0</td>
</tr>
<tr>
<td>1</td>
<td>RADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x18</td>
<td></td>
<td>Row Address: SA (24 bit) SA is sector address. Please set IPCR0[SFAR]=SA</td>
</tr>
<tr>
<td>2</td>
<td>CADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x10</td>
<td></td>
<td>Column Address: 13 zero bits + 3 valid bits</td>
</tr>
<tr>
<td>3</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x00</td>
<td></td>
<td>Write Data: 0x29</td>
</tr>
<tr>
<td>4</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

27.6.4.2 HyperRAM

This section provides the example sequences for HyperRAM (Cypress S27KL series). Read (memory) command sequence is same as HyperFlash. The following table shows Write (memory) command sequence.

Table 27-29. Write (memory) command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_DDR</td>
<td>0x3 (Octal)</td>
<td>0x20</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>RADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x18</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 27-29. Write (memory) command (continued)

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>CADDR_DDR</td>
<td>0x3 (Octal)</td>
<td>0x10</td>
<td>Column Address: (13 zero bits + 3 valid bits)</td>
</tr>
<tr>
<td>3</td>
<td>DUMMY_RWDS_DDR</td>
<td>0x3 (Octal)</td>
<td>0x0B</td>
<td>In case of latency count=11</td>
</tr>
<tr>
<td>4</td>
<td>WRITE_DDR</td>
<td>0x3 (Octal)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default write data size if IPCR1[IDATSZ] is zero. This value is ignored for AHB command.</td>
</tr>
<tr>
<td>5-7</td>
<td>STOP (0x00)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

### 27.6.5 Application on Serial NAND Flash device

This section provides the example sequences for serial NAND flash device (Micron Flash MT29 series). The operation to serial NAND flash is quite similar to serial NOR flash.

READ operation sequence is as following:
- Page Read (Transfer the data from the NAND Flash array to the cache register)
- Get Feature to read the status
- Random Data Read

The following table shows Page Read command sequence.

#### Table 27-30. Page Read command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x1 (Single)</td>
<td>0x13</td>
<td>Command code: 0x13</td>
</tr>
<tr>
<td>1</td>
<td>RADDR_SDR</td>
<td>0x1 (Single)</td>
<td>0x18</td>
<td>Row Address: 24 bit</td>
</tr>
<tr>
<td>2-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

The following table shows Get Feature command sequence.

#### Table 27-31. Get Feature command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x1 (Single)</td>
<td>0x0F</td>
<td>Command code: 0x0F</td>
</tr>
<tr>
<td>1</td>
<td>CMD_SDR</td>
<td>0x1 (Single)</td>
<td>0xC0</td>
<td>Status register address (0xC0)</td>
</tr>
<tr>
<td>2</td>
<td>READ_SDR</td>
<td>0x1 (Single)</td>
<td>0x02</td>
<td>2 Byte read data</td>
</tr>
<tr>
<td>3-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>
The following table shows Random Data Read command sequence.

### Table 27-32. Read From Cache x4 command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x1 (Single)</td>
<td>0x6B</td>
<td>Command code: 0x6B</td>
</tr>
<tr>
<td>1</td>
<td>MODE4_SDR</td>
<td>0x1 (Single)</td>
<td>0x0 or 0x1</td>
<td>Software should decode the flash address and set mode bits as 0x1 if plane selection is one, or 0x0 if plane selection is zero. Plane selection bit is the 18th bit of flash address. If NAND flash size is less than 4Gbit, plane selection will always be zero.</td>
</tr>
<tr>
<td>2</td>
<td>CADDR_SDR</td>
<td>0x1 (Single)</td>
<td>0x0C</td>
<td>Column address: 12 bit</td>
</tr>
<tr>
<td>3</td>
<td>DUMMY_SDR</td>
<td>0x2 (Quad)</td>
<td>0x08</td>
<td>Dummy cycle number: 8 (serial root clock)</td>
</tr>
<tr>
<td>4</td>
<td>READ_SDR</td>
<td>0x2 (Quad)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default reading data size if IPCR1[IDATSZ] is zero.</td>
</tr>
<tr>
<td>5-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

Program operation sequence is as following:
- Write Enable
- Program Load (Transfer the write data to the cache register)
- Program Execute
- Get Feature to read the status

The following table shows Program Load command sequence.

### Table 27-33. Program Load command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x1 (Single)</td>
<td>0x02</td>
<td>Command code: 0x02</td>
</tr>
<tr>
<td>1</td>
<td>MODE4_SDR</td>
<td>0x1 (Single)</td>
<td>0x0 or 0x1</td>
<td>Software should decode the flash address and set mode bits as 0x1 if plane selection is one, or 0x0 if plane selection is zero. Plane selection bit is the 18th bit of flash address. If NAND flash size is less than 4Gbit, plane selection will always be zero.</td>
</tr>
<tr>
<td>2</td>
<td>CADDR_SDR</td>
<td>0x1 (Single)</td>
<td>0x0C</td>
<td>Column address: 12 bit</td>
</tr>
<tr>
<td>3</td>
<td>WRITE_SDR</td>
<td>0x1 (Single)</td>
<td>Any non-zero value</td>
<td>This operand value could be used as default write data size if IPCR1[IDATSZ] is zero.</td>
</tr>
<tr>
<td>4-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>
The following table shows Program Execute command sequence.

### Table 27-34. Program Execute command

<table>
<thead>
<tr>
<th>Instruction No.</th>
<th>Instruction opcode[5:0]</th>
<th>Instruction num_pads[1:0]</th>
<th>Instruction operand[7:0]</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMD_SDR</td>
<td>0x1 (Single)</td>
<td>0x10</td>
<td>Command code: 0x10</td>
</tr>
<tr>
<td>1</td>
<td>RADDR_SDR</td>
<td>0x1 (Single)</td>
<td>0x18</td>
<td>Row Address: 24 bit</td>
</tr>
<tr>
<td>2-7</td>
<td>STOP (0x0)</td>
<td>0x0</td>
<td>0x00</td>
<td></td>
</tr>
</tbody>
</table>

#### 27.6.6 Application on FPGA device

FPGA device should be accessed by AHB command. All AHB accesses to FPGA will be transparent to SW driver (no SW intervention). There may be some special requirements from FPGA device.

1. **Device type may be different on A1/A2/B1/B2**
   
   For this case, clear the MCR2[SAMEDEVICEEN] bit and configure FLShxCR0 and FLShxCR1 register separately for up to four external devices.

2. **Device needs different wait cycle for Programming.**
   
   The AHB write wait cycle number could be set separately for these four external devices (by register field FLShxCR2[AWRWAIT]). Software could configure the sequences in LUT with different DUMMY instructions (operand will determine dummy cycle). Note that FlexSPI will hold AHB bus ready for this wait time, so AHB Bus performance may become very low when this wait time is very long.

3. **Device needs different wait cycle for Reading.**
   
   The AHB Read Sequence index and Sequence Number could be set separately for these four external devices (by register field FLShxCR2[ARDSEQID] and FLShxCR2[ARDSEQNUM]). Software could configure the sequences in LUT with different DUMMY instruction (operand will determine dummy cycle).

4. **Device may be sensitive to read instruction clock cycle number**
   
   Device will be sensitive to read instruction clock cycle number if its internal memory is implemented similar as FIFO. For this case, software could send the data size information to external device by DATSZ instruction. FPGA device should decode the data size information and determine how much data bytes should be popped.

5. **Device may needs interval time between Chip selection valid**
This could be handled by register field FLSHxCR1[CSINTERVAL] setting.

6. **Device may use SCLK as reference clock for its internal PLL**

In this case, SCLK should be free-running and clock frequency should be stable. This could be achieved by setting MCR0[SCKFREERUNEN] and use SDR sequence only.

### 27.7 Memory Map and register definition

This section includes the FlexSPI module memory map and detailed descriptions of all registers.

#### 27.7.1 Register Access

All registers can be accessed with 8-bit, 16-bit, and 32-bit width operations. Never change the setting value of reserved fields in control registers. Changing the value of reserved fields may impact the normal functioning of the controller.

**NOTE**

For usage that FlexSPI is capable of accessing sensitive memory contents, protection should be done to FlexSPI controller using resource isolation (e.g. XRDC2, XRDC, RDC) or any kind of equivalent partition control via SCFW, to make sure only trusted software be allowed to access the FlexSPI controller register interface.

#### 27.7.2 FlexSPI register descriptions

##### 27.7.2.1 FlexSPI memory map

FlexSPI base address: 402A_8000h

FlexSPI2 base address: 402A_4000h
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Module Control Register 0 (MCR0)</td>
<td>32</td>
<td>RW</td>
<td>FFFF_80C2h</td>
</tr>
<tr>
<td>4h</td>
<td>Module Control Register 1 (MCR1)</td>
<td>32</td>
<td>RW</td>
<td>FFFF_FFFFh</td>
</tr>
<tr>
<td>8h</td>
<td>Module Control Register 2 (MCR2)</td>
<td>32</td>
<td>RW</td>
<td>2000_81F7h</td>
</tr>
<tr>
<td>Ch</td>
<td>AHB Bus Control Register (AHBCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0018h</td>
</tr>
<tr>
<td>10h</td>
<td>Interrupt Enable Register (INTEN)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Interrupt Register (INTR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>18h</td>
<td>LUT Key Register (LUTKEY)</td>
<td>32</td>
<td>RW</td>
<td>5AF0_5AF0h</td>
</tr>
<tr>
<td>1Ch</td>
<td>LUT Control Register (LUTCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_00002h</td>
</tr>
<tr>
<td>20h</td>
<td>AHB RX Buffer 0 Control Register 0 (AHBRXBUF0CR0)</td>
<td>32</td>
<td>RW</td>
<td>8000_0020h</td>
</tr>
<tr>
<td>24h</td>
<td>AHB RX Buffer 1 Control Register 0 (AHBRXBUF1CR0)</td>
<td>32</td>
<td>RW</td>
<td>8001_0020h</td>
</tr>
<tr>
<td>28h</td>
<td>AHB RX Buffer 2 Control Register 0 (AHBRXBUF2CR0)</td>
<td>32</td>
<td>RW</td>
<td>8002_0020h</td>
</tr>
<tr>
<td>2Ch</td>
<td>AHB RX Buffer 3 Control Register 0 (AHBRXBUF3CR0)</td>
<td>32</td>
<td>RW</td>
<td>8003_0020h</td>
</tr>
<tr>
<td>60h</td>
<td>Flash Control Register 0 (FLSHA1CR0)</td>
<td>32</td>
<td>RW</td>
<td>0001_0000h</td>
</tr>
<tr>
<td>64h</td>
<td>Flash Control Register 0 (FLSHA2CR0)</td>
<td>32</td>
<td>RW</td>
<td>0001_0000h</td>
</tr>
<tr>
<td>68h</td>
<td>Flash Control Register 0 (FLSHB1CR0)</td>
<td>32</td>
<td>RW</td>
<td>0001_0000h</td>
</tr>
<tr>
<td>6Ch</td>
<td>Flash Control Register 0 (FLSHB2CR0)</td>
<td>32</td>
<td>RW</td>
<td>0001_0000h</td>
</tr>
<tr>
<td>70h</td>
<td>Flash Control Register 1 (FLSHA1CR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0063h</td>
</tr>
<tr>
<td>74h</td>
<td>Flash Control Register 1 (FLSHA2CR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0063h</td>
</tr>
<tr>
<td>78h</td>
<td>Flash Control Register 1 (FLSHB1CR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0063h</td>
</tr>
<tr>
<td>7Ch</td>
<td>Flash Control Register 1 (FLSHB2CR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0063h</td>
</tr>
<tr>
<td>80h</td>
<td>Flash Control Register 2 (FLSHA1CR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>84h</td>
<td>Flash Control Register 2 (FLSHA2CR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>88h</td>
<td>Flash Control Register 2 (FLSHB1CR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8Ch</td>
<td>Flash Control Register 2 (FLSHB2CR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>94h</td>
<td>Flash Control Register 4 (FLSHCR4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>A0h</td>
<td>IP Control Register 0 (IPCR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>A4h</td>
<td>IP Control Register 1 (IPCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>B0h</td>
<td>IP Command Register (IPCMD)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>B8h</td>
<td>IP RX FIFO Control Register (IPRXFCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>BCh</td>
<td>IP TX FIFO Control Register (IPTXFCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C0h</td>
<td>DLL Control Register 0 (DLLACR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0100h</td>
</tr>
<tr>
<td>C4h</td>
<td>DLL Control Register 0 (DLLBCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0100h</td>
</tr>
<tr>
<td>E0h</td>
<td>Status Register 0 (STS0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0002h</td>
</tr>
<tr>
<td>E4h</td>
<td>Status Register 1 (STS1)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E8h</td>
<td>Status Register 2 (STS2)</td>
<td>32</td>
<td>RO</td>
<td>0100_0100h</td>
</tr>
<tr>
<td>ECh</td>
<td>AHB Suspend Status Register (AHBSPNDSTS)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>F0h</td>
<td>IP RX FIFO Status Register (IPRXFSTS)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>F4h</td>
<td>IP TX FIFO Status Register (IPTXFSTS)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>100h</td>
<td>IP RX FIFO Data Register a (RFDR0 - RFDR31)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>180h</td>
<td>IP TX FIFO Data Register a (TFDR0 - TFDR31)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 27.7.2.2 Module Control Register 0 (MCR0)

#### 27.7.2.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR0</td>
<td>0h</td>
</tr>
</tbody>
</table>

#### 27.7.2.2.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

#### 27.7.2.2.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Timeout wait cycle for AHB command grant.</td>
</tr>
</tbody>
</table>
| AHBGRANTWAIT | If AHB Triggered Command is not granted by arbitrator, it will timeout after AHBGRANNTIMEOUT * 1024 AHB Clock cycles. This grant timeout may occur when the pending command sequence is IP triggered and the read/write data size is too large. When an AHB command grant time out occurs, there will be an interrupt generated (INTR[AHBCMDGE]) if this interrupt is enabled (INTEGR[AHBCMDGEEN] is set) and AHB command is ignored by arbitrator. 

**NOTE:** This field is for debug only, please keep default value! It is not allowed to set this field to value 0x0.

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>23-16</td>
<td>Time out wait cycle for IP command grant. If IP Triggered Command is not granted by arbitrator, it will timeout after IPGRANTTIMEOUT * 1024 AHB Clock cycles. This grant timeout maybe occur when pending command sequence is AHB triggered and read/write data size is too large. When IP command grant time out occurs, there will be an interrupt generated (INTR[IPCMDGE]) if this interrupt is enabled (INTEN[IPCMDGEEN] is set 0x1) and IP command is ignored by arbitrator. <strong>NOTE:</strong> This field is for debug only, please keep default value! It is not allowed to set this field to value 0x0.</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>This bit is used to force SCLK output free-running. For FPGA applications, external device may use SCLK as reference clock to its internal PLL. If SCLK free-running is enabled, data sampling with loopback clock from SCLK pad is not supported (MCR0[RXCLKSRC]=2). 0b - Disable. 1b - Enable.</td>
</tr>
<tr>
<td>13</td>
<td>This bit is to support Flash Octal mode access by combining Port A and B Data pins (A_DATA[3:0] and B_DATA[3:0]). <strong>NOTE:</strong> Combination mode is not supported if Port A and Port B are 8 bit data width. This bit should be set to zero in this case. 0b - Disable. 1b - Enable.</td>
</tr>
<tr>
<td>12</td>
<td>Doze mode enable bit 0b - Doze mode support disabled. AHB clock and serial clock will not be gated off when there is doze mode request from system. 1b - Doze mode support enabled. AHB clock and serial clock will be gated off when there is doze mode request from system.</td>
</tr>
<tr>
<td>11</td>
<td>Half Speed Serial Flash access Enable. This bit enables the divide by 2 of the clock to external serial flash devices (A_SCLK/B_SCLK) for all commands (for both SDR and DDR mode). FlexSPI need to be set into MDIS mode before changing value of HSEN. Otherwise, it is possible to cause issue on internal logic/state machine. 0b - Disable divide by 2 of serial flash clock for half speed commands. 1b - Enable divide by 2 of serial flash clock for half speed commands.</td>
</tr>
<tr>
<td>10-8</td>
<td>The serial root clock could be divided inside FlexSPI. Refer Clocks chapter for more details on clocking. <strong>NOTE:</strong> Don't change this field during IP's normal operation mode. Alter the value after putting IP into stop mode. 000b - Divided by 1 001b - Divided by 2 010b - Divided by 3 011b - Divided by 4 100b - Divided by 5 101b - Divided by 6 110b - Divided by 7 111b - Divided by 8</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-4</td>
<td>Sample Clock source selection for Flash Reading Refer RX Clock Source Features for more details</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
00b | Dummy Read strobe generated by FlexSPI Controller and loopback internally.
01b | Dummy Read strobe generated by FlexSPI Controller and loopback from DQS pad.
10b | Reserved
11b | Flash provided Read strobe and input from DQS pad

<table>
<thead>
<tr>
<th>3-2</th>
<th>Reserved</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>0</th>
<th>Module Disable</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>When module disabled, AHB/serial clock will be gated off internally to save power. Only register access (except LUT/IP RX FIFO/IP TX FIFO) is allowed.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>0</th>
<th>Software Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>This bit is auto-cleared by hardware after software reset done. Configuration registers will not be reset.</td>
</tr>
</tbody>
</table>

### 27.7.2.3  Module Control Register 1 (MCR1)

#### 27.7.2.3.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR1</td>
<td>4h</td>
</tr>
</tbody>
</table>

#### 27.7.2.3.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>SEQUWAIT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>AHBUSBWAIT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

#### 27.7.2.3.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16 SEQUWAIT</td>
<td>Command Sequence Execution will timeout and abort after SEQUWAIT * 1024 Serial Root Clock cycles. When sequence execution time out occurs, there will be an interrupt generated (INTR[SEQTIMEOUT]) if...</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
27.7.2.4 Module Control Register 2 (MCR2)

### 27.7.2.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR2</td>
<td>8h</td>
</tr>
</tbody>
</table>

### 27.7.2.4.2 Diagram

![Diagram of Module Control Register 2 (MCR2)](attachment:diagram.png)

- **Bits 31 to 24**: .resumeWait
  - R: Read
  - W: Write
  - Reset: 0 0 0 0 0 0 0 0

- **Bits 23 to 16**: Reserved

- **Bits 15 to 8**: sameDeviceEn
  - R: Read
  - W: Write
  - Reset: 1 0 0 0 0 0 0 0

- **Bits 7 to 4**: clearLearnPhase
  - R: Read
  - W: Write
  - Reset: 1 1 1 1 1 1 1 1

- **Bits 3 to 0**: clraHbbUfopt
  - R: Read
  - W: Write
  - Reset: 1 1 1 1 1 1 1 1
### 27.7.2.4.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Wait cycle (in AHB clock cycle) for idle state before suspended command sequence resumed.</td>
</tr>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>B_SCLK pad can be used as A_SCLK differential clock output (inverted clock to A_SCLK). In this case, port B flash access is not available. After changing the value of this field, MCR0[SWRESET] should be set.</td>
</tr>
<tr>
<td>18-17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 15      | All external devices are same devices (both in types and size) for A1/A2/B1/B2.  
  0b - In Individual mode, FLSHA1CRx/FLSHA2CRx/FLSB1CRx/FLSB2CRx register setting will be applied to Flash A1/A2/B1/B2 separately. In Parallel mode, FLSHA1CRx register setting will be applied to Flash A1 and B1, FLSHA2CRx register setting will be applied to Flash A2 and B2. FLSB1CRx/FLSB2CRx register settings will be ignored.  
  1b - FLSHA1CR0/FLSHA1CR1/FLSHA1CR2 register settings will be applied to Flash A1/A2/B1/B2. FLSHA2CRx/FLSB1CRx/FLSB2CRx will be ignored. |
| 14      | The sampling clock phase selection will be reset to phase 0 when this bit is written with 0x1. This bit will be auto-cleared immediately. |
| 13      | Reserved                                                                 |
| 12      | Reserved                                                                 |
| 11      | This bit determines whether AHB RX Buffer and AHB TX Buffer will be cleaned automatically when FlexSPI returns STOP mode ACK. Software should set this bit if AHB RX Buffer or AHB TX Buffer will be powered off in STOP mode. Otherwise AHB read access after exiting STOP mode may hit AHB RX Buffer or AHB TX Buffer but their data entries are invalid.  
  0b - AHB RX/TX Buffer will not be cleaned automatically when FlexSPI return Stop mode ACK.  
  1b - AHB RX/TX Buffer will be cleaned automatically when FlexSPI return Stop mode ACK. |
| 8-0     | Reserved                                                                 |

### 27.7.2.5 AHB Bus Control Register (AHBCR)
## Memory Map and register definition

### 27.7.2.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AHBCR</td>
<td>Ch</td>
</tr>
</tbody>
</table>

### 27.7.2.5.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 27.7.2.5.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>28-19</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>14-13</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
</tbody>
</table>
| 6     | READADDROP | AHB Read Address option bit. This option bit is intend to remove AHB burst start address alignment limitation. When FlexSPI controller is used for FPGA application, there may be requirement that FlexSPI fetch exactly the byte number as AHB burst. In this case, FPGA device should be designed as non-wordaddressable and this option bit should be set 0.  
0b - There is AHB read burst start address alignment limitation when flash is accessed in parallel mode or flash is wordaddressable.  
1b - There is no AHB read burst start address alignment limitation. FlexSPI will fetch more data than AHB burst required to meet the alignment requirement. |
| 5     | PREFETCHEN | AHB Read Prefetch Enable. When AHB read prefetch is enabled, FlexSPI will fetch more flash read data than current AHB burst needed so that the read latency for next AHB read access will be reduced. |
| 4     | BUFFERABLEE | Enable AHB bus bufferable write access support. This field affects the last beat of AHB write access, refer for more details about AHB bufferable write.  
0b - Disabled. For all AHB write access (no matter bufferable or non-bufferable ), FlexSPI will return AHB Bus ready after all data is transmitted to External device and AHB command finished.  
1b - Enabled. For AHB bufferable write access, FlexSPI will return AHB Bus ready when the AHB command is granted by arbitrator and will not wait for AHB command finished. |
| 3     | CACHABLEEN | Enable AHB bus cachable read access support.  
0b - Disabled. When there is AHB bus cachable read access, FlexSPI will not check whether it hit AHB TX Buffer.  
1b - Enabled. When there is AHB bus cachable read access, FlexSPI will check whether it hit AHB TX Buffer first. |
| 2-1   | Reserved |
| 0     | APAREN | Parallel mode enabled for AHB triggered Command (both read and write) .  
0b - Flash will be accessed in Individual mode.  
1b - Flash will be accessed in Parallel mode. |

### 27.7.2.6 Interrupt Enable Register (INTEN)
27.7.2.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INTEN</td>
<td>10h</td>
</tr>
</tbody>
</table>

27.7.2.6.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SEQTIMEOUTEN</td>
<td>AHBBUSTIMEOUTEN</td>
<td>SCKSTOPBYWREN</td>
<td>SCKSTOPBYRDEN</td>
<td>Reserved</td>
<td>IPTXWEE N</td>
<td>IPRXWAEN</td>
<td>AHBCMDERREN</td>
<td>PCMDREN</td>
<td>AHBCMIDGEEN</td>
<td>PCMDGEEN</td>
<td>IPCMDREN</td>
<td>IPCMDGEEN</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

27.7.2.6.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Sequence execution timeout interrupt enable. Refer Interrupts chapter for more details.</td>
</tr>
<tr>
<td>SEQTImEOUTEN</td>
<td>AHB Bus timeout interrupt. Refer Interrupts chapter for more details.</td>
</tr>
<tr>
<td>10</td>
<td>AHB Bus timeout interrupt. Refer Interrupts chapter for more details.</td>
</tr>
<tr>
<td>AHBBUSTIMEOUTEN</td>
<td>SCLK is stopped during command sequence because Async TX FIFO empty interrupt enable.</td>
</tr>
<tr>
<td>9</td>
<td>SCLK is stopped during command sequence because Async TX FIFO full interrupt enable.</td>
</tr>
<tr>
<td>SCKSTOPBYWREN</td>
<td>SCLK is stopped during command sequence because Async RX FIFO full interrupt enable.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCKSTOPBYRDEN</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>IP TX FIFO WaterMark empty interrupt enable.</td>
</tr>
<tr>
<td></td>
<td>IP TX FIFO has no less empty space than WaterMark level interrupt enable.</td>
</tr>
<tr>
<td>5</td>
<td>IP RX FIFO WaterMark available interrupt enable.</td>
</tr>
<tr>
<td></td>
<td>IP RX FIFO has no less valid data than WaterMark level interrupt enable.</td>
</tr>
<tr>
<td>4</td>
<td>AHB triggered Command Sequences Error Detected interrupt enable.</td>
</tr>
<tr>
<td>3</td>
<td>IP triggered Command Sequences Error Detected interrupt enable.</td>
</tr>
<tr>
<td>2</td>
<td>AHB triggered Command Sequences Grant Timeout interrupt enable.</td>
</tr>
<tr>
<td>1</td>
<td>IP triggered Command Sequences Grant Timeout interrupt enable.</td>
</tr>
<tr>
<td>0</td>
<td>IP triggered Command Sequences Execution finished interrupt enable.</td>
</tr>
</tbody>
</table>

### 27.7.2.7 Interrupt Register (INTR)

#### 27.7.2.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INTR</td>
<td>14h</td>
</tr>
</tbody>
</table>
### 27.7.2.7.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 27.7.2.7.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Sequence execution timeout interrupt.</td>
</tr>
<tr>
<td>SEQTIMEOUT</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>AHB Bus timeout interrupt. Refer Interrupts chapter for more details.</td>
</tr>
<tr>
<td>AHBUSTIMEOUT</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>SCLK is stopped during command sequence because Async TX FIFO empty</td>
</tr>
<tr>
<td>SCKSTOPBYWR</td>
<td>interrupt.</td>
</tr>
<tr>
<td>8</td>
<td>SCLK is stopped during command sequence because Async RX FIFO full</td>
</tr>
<tr>
<td>SCKSTOPBYRD</td>
<td>interrupt.</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>IP TX FIFO watermark empty interrupt.</td>
</tr>
<tr>
<td>IPTXWE</td>
<td>IP TX FIFO has no less empty space than WaterMark level interrupt.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>5 IPRXWA</td>
<td>IP RX FIFO watermark available interrupt. IP RX FIFO has no less valid</td>
</tr>
<tr>
<td></td>
<td>data than WaterMark level interrupt.</td>
</tr>
<tr>
<td>4 AHBCMDERR</td>
<td>AHB triggered Command Sequences Error Detected interrupt. When an error</td>
</tr>
<tr>
<td></td>
<td>detected for AHB command, this command will be ignored and not executed</td>
</tr>
<tr>
<td></td>
<td>at all.</td>
</tr>
<tr>
<td>3 IPCMDERR</td>
<td>IP triggered Command Sequences Error Detected interrupt. When an error</td>
</tr>
<tr>
<td></td>
<td>detected for IP command, this command will be ignored and not executed</td>
</tr>
<tr>
<td></td>
<td>at all.</td>
</tr>
<tr>
<td>2 AHBCMDGE</td>
<td>AHB triggered Command Sequences Grant Timeout interrupt.</td>
</tr>
<tr>
<td>1 IPCMDGE</td>
<td>IP triggered Command Sequences Grant Timeout interrupt.</td>
</tr>
<tr>
<td>0 IPCMDDONE</td>
<td>IP triggered Command Sequences Execution finished interrupt. This</td>
</tr>
<tr>
<td></td>
<td>interrupt is also generated when there is IPCMDGE or IPCMDERR interrupt</td>
</tr>
<tr>
<td></td>
<td>generated.</td>
</tr>
</tbody>
</table>

### 27.7.2.8 LUT Key Register (LUTKEY)

#### 27.7.2.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LUTKEY</td>
<td>18h</td>
</tr>
</tbody>
</table>

#### 27.7.2.8.2 Function

The LUT Key Register contains the key to lock and unlock LUT. Refer to Look Up Table for details.

#### 27.7.2.8.3 Diagram

```
Bits   31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16  
R      W   KEY                  
Reset  0   1   0   1   1   0   1   0   1   1   1   1   0   0   0   0

Bits   15  14  13  12  11  10  9   8   7   6   5   4   3   2   1   0  
R      W   KEY                  
Reset  0   1   0   1   1   0   1   0   1   1   1   1   0   0   0   0
```
27.7.2.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>The Key to lock or unlock LUT.</td>
</tr>
<tr>
<td>KEY</td>
<td>The key is 0x5AF05AF0. Read value is always 0x5AF05AF0.</td>
</tr>
</tbody>
</table>

27.7.2.9 LUT Control Register (LUTCR)

27.7.2.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LUTCR</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

27.7.2.9.2 Function

The LUT control register is used along with LUTKEY register to lock or unlock LUT. This register has to be written immediately after writing 0x5AF05AF0 to LUTKEY register for the lock or unlock operation to be successful. Refer Look Up Table for details on locking/unlocking LUT. Setting both the LOCK and UNLOCK bits as "00" or "11" is not allowed.

27.7.2.9.3 Diagram

```
Bits 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16
R    W
Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

Bits 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0
R    W
Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 1 0
```

Reserved

LOCK

UNLOCK
27.7.2.9.4 **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Unlock LUT</td>
</tr>
<tr>
<td>UNLOCK</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Lock LUT</td>
</tr>
<tr>
<td>LOCK</td>
<td></td>
</tr>
</tbody>
</table>

27.7.2.10 **AHB RX Buffer 0 Control Register 0 (AHBRXBUF0CR0)**

### 27.7.2.10.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AHBRXBUF0CR0</td>
<td>20h</td>
</tr>
</tbody>
</table>

### 27.7.2.10.2 Diagram

```
  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
R  | R  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
W  | W  | R  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
PREFETCH | Prefetch Enable for current AHB RX Buffer corresponding Master. | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved |
 PRIORITY |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |
 BUFSZ |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |                        |
Reset | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
```

27.7.2.10.3 **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>PREFETCHEN</td>
<td>AHB Read Prefetch Enable for current AHB RX Buffer corresponding Master.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 27.7.2.11 AHB RX Buffer 1 Control Register 0 (AHBRXBUF1CR0)

#### 27.7.2.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AHBRXBUF1CR0</td>
<td>24h</td>
</tr>
</tbody>
</table>

#### 27.7.2.11.2 Diagram

```
+----------------+----------------+----------------+----------------+----------------+----------------+----------------+----------------+  
<table>
<thead>
<tr>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
<td>R</td>
<td>W</td>
</tr>
</tbody>
</table>
+----------------+----------------+----------------+----------------+----------------+----------------+----------------+----------------+  
| PREFETCHE      | Reserved        | PRIORITY       | Reserved        | MSTRID          | Reserved        | BUFSZ           |                |  
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |  
| 1              | 0              | 0              | 1              | 0              | 0              | 0              | 0              |  
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |  
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |  
+----------------+----------------+----------------+----------------+----------------+----------------+----------------+----------------+  
```

- **Field**
  - **Function**: The prefetch feature is disabled when AHBCR[PREFETCHEN] is set 0. This field allows prefetch disable/enable separately for each master.
  - **30-26**: Reserved
  - **25-24**: PRIORITY
    - This priority for AHB Master Read which this AHB RX Buffer is assigned. 7 is the highest priority, 0 the lowest.
    - Please refer to Command Abort and Suspend for more details.
  - **23-20**: Reserved
  - **19-16**: MSTRID
    - This AHB RX Buffer is assigned according to AHB Master with ID (MSTR_ID).
    - Please refer to AHB RX Buffer Management for AHB RX Buffer allocation.
  - **15-8**: Reserved
  - **7-0**: BUFSZ
    - AHB RX Buffer Size in 64 bits.
    - Please refer to AHB RX Buffer Management for more details.
27.7.2.11.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>AHB Read Prefetch Enable for current AHB RX Buffer corresponding Master.</td>
</tr>
<tr>
<td></td>
<td>The prefetch feature is disabled when AHBCR[PREFETCHEN] is set 0. This field allows prefetch disable/enable separately for each master.</td>
</tr>
<tr>
<td>30-26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25-24</td>
<td>This priority for AHB Master Read which this AHB RX Buffer is assigned. 7 is the highest priority, 0 the lowest. Please refer to Command Abort and Suspend for more details.</td>
</tr>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-16</td>
<td>This AHB RX Buffer is assigned according to AHB Master with ID (MSTR_ID). Please refer to AHB RX Buffer Management for AHB RX Buffer allocation.</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-0</td>
<td>AHB RX Buffer Size in 64 bits. Please refer to AHB RX Buffer Management for more details.</td>
</tr>
</tbody>
</table>

27.7.2.12 AHB RX Buffer 2 Control Register 0 (AHBRXBUF2CR0)

27.7.2.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AHBRXBUF2CR0</td>
<td>28h</td>
</tr>
</tbody>
</table>
### 27.7.2.12.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Prefetch Enable</td>
<td>Reserved</td>
<td>Priority</td>
<td>Reserved</td>
<td>MSTRID</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td>BUFSZ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 27.7.2.12.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>AHB Read Prefetch Enable for current AHB RX Buffer corresponding Master. The prefetch feature is disabled when AHBCR[PREFETCHEN] is set 0. This field allows prefetch disable/enable separately for each master.</td>
</tr>
<tr>
<td>30-26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25-24</td>
<td>Priority This priority for AHB Master Read which this AHB RX Buffer is assigned. 7 is the highest priority, 0 the lowest. Please refer to Command Abort and Suspend for more details.</td>
</tr>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-16</td>
<td>MSTRID This AHB RX Buffer is assigned according to AHB Master with ID (MSTR_ID). Please refer to AHB RX Buffer Management for AHB RX Buffer allocation.</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-0</td>
<td>BUFSZ AHB RX Buffer Size in 64 bits. Please refer to AHB RX Buffer Management for more details.</td>
</tr>
</tbody>
</table>

### 27.7.2.13 AHB RX Buffer 3 Control Register 0 (AHBRXBUF3CR0)
27.7.2.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AHBXBUF3CSR0</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

27.7.2.13.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

27.7.2.13.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>AHB Read Prefetch Enable for current AHB RX Buffer corresponding Master.</td>
</tr>
<tr>
<td>PREFETCHEN</td>
<td>The prefetch feature is disabled when AHBCR[PREFETCHEN] is set 0. This field allows prefetch disable/enable separately for each master.</td>
</tr>
<tr>
<td>30-26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25-24</td>
<td>This priority for AHB Master Read which this AHB RX Buffer is assigned. 7 is the highest priority, 0 the lowest. Please refer to Command Abort and Suspend for more details.</td>
</tr>
<tr>
<td>PRIORITY</td>
<td></td>
</tr>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-16</td>
<td>This AHB RX Buffer is assigned according to AHB Master with ID (MSTR_ID). Please refer to AHB RX Buffer Management for AHB RX Buffer allocation.</td>
</tr>
<tr>
<td>MSTRID</td>
<td></td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-0</td>
<td>AHB RX Buffer Size in 64 bits. Please refer to AHB RX Buffer Management for more details.</td>
</tr>
<tr>
<td>BUFSZ</td>
<td></td>
</tr>
</tbody>
</table>
27.7.2.14  Flash Control Register 0 (FLSHA1CR0 - FLSHB2CR0)

27.7.2.14.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLSHA1CR0</td>
<td>60h</td>
</tr>
<tr>
<td>FLSHA2CR0</td>
<td>64h</td>
</tr>
<tr>
<td>FLSHB1CR0</td>
<td>68h</td>
</tr>
<tr>
<td>FLSHB2CR0</td>
<td>6Ch</td>
</tr>
</tbody>
</table>

27.7.2.14.2  Function

The Flash control register 0 contains Flash size setting. FlexSPI determines which device is accessed with this register setting (Chip Selection).

27.7.2.14.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>FLSHZ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

27.7.2.14.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>30-23 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>22-0 FLSHZ</td>
<td>Flash Size in KByte.</td>
</tr>
</tbody>
</table>
The max flash size supported for each device is 512 MB. When FLHSZ setting value is greater than 0x400000, the device flash size would be taken as 512 MB. The max total flash size supported (for all 4 devices) is also 512 MB. If the total flash size is larger than 512 MB, only 512 MB address space is accessible.

### 27.7.2.15 Flash Control Register 1 (FLSHA1CR1 - FLSHB2CR1)

#### 27.7.2.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLSHA1CR1</td>
<td>70h</td>
</tr>
<tr>
<td>FLSHA2CR1</td>
<td>74h</td>
</tr>
<tr>
<td>FLSHB1CR1</td>
<td>78h</td>
</tr>
<tr>
<td>FLSHB2CR1</td>
<td>7Ch</td>
</tr>
</tbody>
</table>

#### 27.7.2.15.2 Function

The Flash control register 1 contains the setting for FlexSPI to meet Flash device specific timings and Flash internal address space.

#### 27.7.2.15.3 Diagram

The diagram shows the bits and their functions along with the reset values.

---
### 27.7.2.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16 CSINTERVAL</td>
<td>This field is used to set the minimum interval between flash device Chip selection deassertion and flash device Chip selection assertion. If external flash has a limitation on the interval between command sequences, this field should be set accordingly. If there is no limitation, set this field with value 0x0. When CSINTERVALUNIT is 0x0, the chip selection invalid interval is: CSINTERVAL * 1 serial clock cycle; When CSINTERVALUNIT is 0x1, the chip selection invalid interval is: CSINTERVAL * 256 serial clock cycle. <strong>NOTE:</strong> The chip selection interval is 2 cycle at least even if CSINTERVAL is less than 2.</td>
</tr>
</tbody>
</table>
| 15 CSINTERVALUNIT | CS interval unit  
0b - The CS interval unit is 1 serial clock cycle  
1b - The CS interval unit is 256 serial clock cycle |
| 14-11 CAS | Column Address Size.  
When external flash has separate address field for row address and column address, this field should be set to flash column address bit width. FlexSPI will automatically split flash mapped address to Row address and Column address according to CAS field and WA field setting. This bit should be set to 0x0 when external Flash don't support column address. FlexSPI will transmit all flash address bits as Row address. For flash address mapping, please refer to Flash memory map for more detail. |
| 10 WA | Word Addressable.  
This bit should be set when external Flash is word addressable. If Flash is word addressable, it should be access in terms of 16 bits. At this time, FlexSPI will not transmit Flash address bit 0 to external Flash. For flash address mapping, please refer to Flash memory map for more detail. |
| 9-5 TCSH | Serial Flash CS Hold time.  
This field is used to meet flash TCSH timing requirement. Serial flash CS Hold time promised by FlexSPI is: TCSH in serial root clock cycles (for both SDR and DDR mode). Please refer to FlexSPI Input Timing for more detail. |
| 4-0 TCSS | Serial Flash CS setup time.  
This field is used to meet flash TCSS timing requirement. Serial flash CS Setup time promised by FlexSPI is: (TCSS + 1/2) serial root clock cycles (for both SDR and DDR mode). Please refer to FlexSPI Input Timing for more detail. |

### 27.7.2.16 Flash Control Register 2 (FLSHA1CR2 - FLSHB2CR2)

#### 27.7.2.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLSHA1CR2</td>
<td>80h</td>
</tr>
<tr>
<td>FLSHA2CR2</td>
<td>84h</td>
</tr>
<tr>
<td>FLSHB1CR2</td>
<td>88h</td>
</tr>
<tr>
<td>FLSHB2CR2</td>
<td>8Ch</td>
</tr>
</tbody>
</table>
27.7.2.16.2 Function
Flash Control Register 2 contains setting field for AHB Bus access configuration. If the 4 external device are in different types, AHB read/write command may use different command sequences and AHB bus ready wait time may be also different.

27.7.2.16.3 Diagram

27.7.2.16.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>CLRINSTRPTR Clear the instruction pointer which is internally saved pointer by JMP_ON_CS. Refer Programmable Sequence Engine for details. This field is used for AHB Read access to external Flash supporting XIP (Execute-In-Place) mode.</td>
</tr>
<tr>
<td>30-28</td>
<td>AWRWAITUNIT AWRWAIT unit</td>
</tr>
<tr>
<td></td>
<td>000b - The AWRWAIT unit is 2 ahb clock cycle</td>
</tr>
<tr>
<td></td>
<td>001b - The AWRWAIT unit is 8 ahb clock cycle</td>
</tr>
<tr>
<td></td>
<td>010b - The AWRWAIT unit is 32 ahb clock cycle</td>
</tr>
<tr>
<td></td>
<td>011b - The AWRWAIT unit is 128 ahb clock cycle</td>
</tr>
<tr>
<td></td>
<td>100b - The AWRWAIT unit is 512 ahb clock cycle</td>
</tr>
<tr>
<td></td>
<td>101b - The AWRWAIT unit is 2048 ahb clock cycle</td>
</tr>
<tr>
<td></td>
<td>110b - The AWRWAIT unit is 8192 ahb clock cycle</td>
</tr>
<tr>
<td></td>
<td>111b - The AWRWAIT unit is 32768 ahb clock cycle</td>
</tr>
<tr>
<td>27-16</td>
<td>AWRWAIT For certain devices (such as FPGA), it need some time to write data into internal memory after the command sequences finished on FlexSPI interface. If another Read command sequence comes before previous programming finished internally, the read data may be wrong. This field is used to hold AHB Bus ready for AHB write access to wait the programming finished in external device. Then there will be no AHB read command triggered before the programming finished in external device. The Wait cycle between AHB triggered command sequences finished on FlexSPI interface and AHB return Bus ready: AWRWAIT * AWRWAITUNIT</td>
</tr>
</tbody>
</table>

Table continues on the next page...
27.7.2.17 Flash Control Register 4 (FLSHCR4)

27.7.2.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLSHCR4</td>
<td>94h</td>
</tr>
</tbody>
</table>

27.7.2.17.2 Function

The flash control register 4 provide the configuration for all external devices.
27.7.2.17.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

27.7.2.17.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>
| 3 WMENB| Write mask enable bit for flash device on port B. When write mask function is needed for memory device on port B, this bit must be set.  
0b - Write mask is disabled, DQS(RWDS) pin will be un-driven when writing to external device.  
1b - Write mask is enabled, DQS(RWDS) pin will be driven by FlexSPI as write mask output when writing to external device. |
| 2 WMENA| Write mask enable bit for flash device on port A. When write mask function is needed for memory device on port A, this bit must be set.  
0b - Write mask is disabled, DQS(RWDS) pin will be un-driven when writing to external device.  
1b - Write mask is enabled, DQS(RWDS) pin will be driven by FlexSPI as write mask output when writing to external device. |
| 1      | Reserved |
|        |          |
| 0 WMOPT1| Write mask option bit 1. This option bit could be used to remove AHB write burst start address alignment limitation.  
0b - DQS pin will be used as Write Mask when writing to external device. There is no limitation on AHB write burst start address alignment when flash is accessed in individual mode.  
1b - DQS pin will not be used as Write Mask when writing to external device. There is limitation on AHB write burst start address alignment when flash is accessed in individual mode. |
27.7.2.18 IP Control Register 0 (IPCR0)

27.7.2.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPCR0</td>
<td>A0h</td>
</tr>
</tbody>
</table>

27.7.2.18.2 Function

The IP control registers provide all the configuration required for IP commands. This register provides the flash device’s start address, instead of SoC address, to be accessed for IP command. FlexSPI will determine the chip select automatically according to this start address.

**NOTE**

- It’s not allowed to issue IP command crossing Flash device boundaries. Otherwise there will be IPCMDERR interrupt generated.
- This register should be set before IP command triggered.
- This register setting should not be changed while an IP command is in progress.

27.7.2.18.3 Diagram

```
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
| R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | W   | W   | W   | W   |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR| SFAR|
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+
| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+

27.7.2.18.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Serial Flash Address for IP command.</td>
</tr>
<tr>
<td>SFAR</td>
<td></td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
27.7.2.19 IP Control Register 1 (IPCR1)

27.7.2.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPCR1</td>
<td>A4h</td>
</tr>
</tbody>
</table>

27.7.2.19.2 Function
The IP control registers provide all the configuration required for IP command. This register provides the flash read/program data size, sequence index in LUT, sequence number and individual/parallel mode setting for IP command.

NOTE
- This register should be before IP command triggered.
- This register setting should not be changed before IP command finished.

27.7.2.19.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>IPAREN</td>
<td>Reserved</td>
<td>ISEQNUM</td>
<td>Reserved</td>
<td>ISEQID</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>IDATSZ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

27.7.2.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31    | Parallel mode Enabled for IP command.  
|       | 0b - Flash will be accessed in Individual mode.  
|       | 1b - Flash will be accessed in Parallel mode.  
| IPAREN| Reserved |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>26-24</td>
<td>Sequence Number for IP command: ISEQNUM+1.</td>
</tr>
<tr>
<td>ISEQNUM</td>
<td></td>
</tr>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>19-16</td>
<td>Sequence Index in LUT for IP command.</td>
</tr>
<tr>
<td>ISEQID</td>
<td></td>
</tr>
<tr>
<td>15-0</td>
<td>Flash Read/Program Data Size (in Bytes) for IP command.</td>
</tr>
<tr>
<td>IDATSZ</td>
<td></td>
</tr>
</tbody>
</table>

### 27.7.2.20 IP Command Register (IPCMD)

#### 27.7.2.20.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPCMD</td>
<td>B0h</td>
</tr>
</tbody>
</table>

#### 27.7.2.20.2 Function

This register is used to trigger an IP command to access an external flash device. IP command will be executed on FlexSPI interface after granted by arbitrator.

#### 27.7.2.20.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

Reserved

TRG
### 27.7.2.20.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>TRG</td>
</tr>
<tr>
<td></td>
<td>Setting this bit will trigger an IP Command.</td>
</tr>
</tbody>
</table>

**NOTE:** It's not allowed to trigger another IP command before previous IP command is finished on FlexSPI interface. Software need to poll register bit INTR_IP_CMD_DONE or wait for this interrupt in order to wait for IP command finished.

### 27.7.2.21 IP RX FIFO Control Register (IPRXFCR)

#### 27.7.2.21.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPRXFCR</td>
<td>B8h</td>
</tr>
</tbody>
</table>

#### 27.7.2.21.2 Function

This register provides the configuration fields for IP RX FIFO management.

#### 27.7.2.21.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 27.7.2.21.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Field | Function
--- | ---
5-2 RXWMRK | Watermark level is (RXWMRK+1)*64 Bits. Interrupt register bit IPRXWA is set when filling level in IP RX FIFO is no less than Watermark level by FlexSPI. There will be a DMA request when the filling level is no less than Watermark level and DMA read is enabled (register bit RXDMAEN is set). There will be an IPRXWA (IP RX FIFO watermark available) interrupt generated when the filling level is no less than Watermark level and IPRXWA interrupt is enabled (register bit INTEN_IPRXWA is set).

**NOTE:** After write-1-clear to INTR[IPRXWA], read address should be rolled back to start address (memory mapped).

1 RXDMAEN | IP RX FIFO reading by DMA enabled. 0b - IP RX FIFO would be read by processor. 1b - IP RX FIFO would be read by DMA.

0 CLRIPRXF | Clear all valid data entries in IP RX FIFO. The read/write pointers in IP RX FIFO will be reset.

### 27.7.2.22 IP TX FIFO Control Register (IPTXFCR)

#### 27.7.2.22.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPTXFCR</td>
<td>BCh</td>
</tr>
</tbody>
</table>

#### 27.7.2.22.2 Function

This register provides the configuration fields for IP TX FIFO management.

#### 27.7.2.22.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>TXWMRK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>TXDMAEN</td>
<td>CLRIPXF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### 27.7.2.22.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-2</td>
<td>TXWMRK</td>
</tr>
<tr>
<td></td>
<td>Watermark level is (TXWMRK+1)*64 Bits. Interrupt register bit IPTXWE is set when empty level in IP TX FIFO is no less than Watermark level by FlexSPI. There will be a DMA request when empty level is no less than Watermark level and DMA filling is enable (register bit TXDMAEN is set). There will be an IPTXWE (IP TX FIFO Watermark Empty) interrupt generated when empty level is no less than Watermark level and IPTXWE interrupt is enable (register bit INTEN_IPTXWE is set).</td>
</tr>
</tbody>
</table>
| NOTE: | • The watermark level should be no more than the write window.  
• The watermark level should be no more than IP TX FIFO size.  
• The write address to IP RX FIFO should roll back to the start address of write window after pushing IP TX FIFO by writing-one-clear to INTR[IPTXWE]. |

<table>
<thead>
<tr>
<th>1</th>
<th>TXDMAEN</th>
</tr>
</thead>
</table>
| IP TX FIFO filling by DMA enabled.  
0b - IP TX FIFO would be filled by processor.  
1b - IP TX FIFO would be filled by DMA. |

<table>
<thead>
<tr>
<th>0</th>
<th>CLRIPTXF</th>
</tr>
</thead>
</table>
| Clear all valid data entries in IP TX FIFO.  
The read/write pointers in IP TX FIFO will be reset. |

### 27.7.2.23 DLL Control Register 0 (DLLACR - DLLBCR)

#### 27.7.2.23.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DLLACR</td>
<td>C0h</td>
</tr>
<tr>
<td>DLLBCR</td>
<td>C4h</td>
</tr>
</tbody>
</table>

#### 27.7.2.23.2 Function

This register provides the configuration fields for Flash A/B sample clock DLL.
### 27.7.2.23.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 27.7.2.23.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>14-9</td>
<td>Slave clock delay line delay cell number selection override value.</td>
</tr>
<tr>
<td>OVRDVAL</td>
<td>When OVRDEN is set 0x1, the delay cell number in DLL is OVRDVAL+1.</td>
</tr>
<tr>
<td>8</td>
<td>Slave clock delay line delay cell number selection override enable.</td>
</tr>
<tr>
<td>OVRDEN</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>6-3</td>
<td>The delay target for slave delay line is: (SLVDLYTARGET+1) * 1/32 * clock cycle of reference clock (serial root clock). If serial root clock is &gt;= 100 MHz, DLLEN set to 0x1, OVRDEN set to =0x0, then SLVDLYTARGET setting of 0xF is recommended.</td>
</tr>
<tr>
<td>SLVDLYTARGET</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Software could force a reset on DLL by setting this field to 0x1. This will cause the DLL to lose lock and re-calibrate to detect an ref_clock half period phase shift. The reset action is edge triggered, so software need to clear this bit after set this bit (no delay limitation).</td>
</tr>
<tr>
<td>DLLRESET</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>DLL calibration enable.</td>
</tr>
<tr>
<td>DLLEN</td>
<td>When this bit is cleared, DLL calibration is disabled and the delay cell number in slave delay line is always 1. Please note that SLV delay line is overridden when OVRDEN bit is set and this bit field setting is ignored.</td>
</tr>
</tbody>
</table>
### 27.7.2.24 Status Register 0 (STS0)

#### 27.7.2.24.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS0</td>
<td>E0h</td>
</tr>
</tbody>
</table>

#### 27.7.2.24.2 Diagram

![Diagram of Status Register 0 (STS0)](image)

#### 27.7.2.24.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3-2</td>
<td>ARBCMDSRC</td>
</tr>
</tbody>
</table>

This status field indicates the trigger source of current command sequence granted by arbitrator. This field value is meaningless when ARB_CTL is not busy (STS0[ARBIDLE]=0x1).

- 00b - Triggered by AHB read command (triggered by AHB read).
- 01b - Triggered by AHB write command (triggered by AHB Write).
- 10b - Triggered by IP command (triggered by setting register bit IPCMD.TRG).
- 11b - Triggered by suspended command (resumed).

| 1          | ARBIDLE  |

This status bit indicates the state machine in ARB_CTL is busy and there is command sequence granted by arbitrator and not finished yet on FlexSPI interface. When ARB_CTL state (ARBIDLE=0x1) is idle, there will be no transaction on FlexSPI interface also (SEQIDLE=0x1). So this bit should be polled to wait for FlexSPI controller become idle instead of SEQIDLE.

Table continues on the next page...
**27.7.2.25 Status Register 1 (STS1)**

### 27.7.2.25.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS1</td>
<td>E4h</td>
</tr>
</tbody>
</table>

### 27.7.2.25.2 Diagram

#### Bits

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### Bits

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 27.7.2.25.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-24</td>
<td>Indicates the Error Code when IP command Error detected. This field will be cleared when INTR(IPCMDERR) is write-1-clear(w1c).</td>
</tr>
<tr>
<td>IPCMDERRCODE</td>
<td>0000b - No error. 0010b - IP command with JMP_ON_CS instruction used in the sequence.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
0011b | There is unknown instruction opcode in the sequence.
0100b | Instruction DUMMY_SDR/DUMMY_RWDS_SDR used in DDR sequence.
0101b | Instruction DUMMY_DDR/DUMMY_RWDS_DDR used in SDR sequence.
0110b | Flash access start address exceed the whole flash address range (A1/A2/B1/B2).
1110b | Sequence execution timeout.
1111b | Flash boundary crossed.
23-20 | Reserved
19-16 | Indicators the sequence Index when IP command error detected. This field will be cleared when INTR[IPCMDERR] is write-1-clear(w1c).
15-12 | Reserved
11-8 | Indicates the Error Code when AHB command Error detected. This field will be cleared when INTR[AHBCMDERR] is write-1-clear(w1c).
0000b | No error.
0010b | AHB Write command with JMP_ON_CS instruction used in the sequence.
0011b | There is unknown instruction opcode in the sequence.
0100b | Instruction DUMMY_SDR/DUMMY_RWDS_SDR used in DDR sequence.
0101b | Instruction DUMMY_DDR/DUMMY_RWDS_DDR used in SDR sequence.
1110b | Sequence execution timeout.
7-4 | Reserved
3-0 | Indicates the sequence index when an AHB command error is detected. This field will be cleared when INTR[AHBCMDERR] is write-1-clear(w1c).

### 27.7.2.26 Status Register 2 (STS2)

#### 27.7.2.26.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STS2</td>
<td>E8h</td>
</tr>
</tbody>
</table>

#### 27.7.2.26.2 Function

This register indicates the status of Flash A and B sample clock DLLs.
### 27.7.2.26.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>BREFSEL</td>
<td>L</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>AREFSEL</td>
<td>L</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### 27.7.2.26.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29-24</td>
<td>Flash B sample clock reference delay line delay cell number selection.</td>
</tr>
<tr>
<td>BREFSEL</td>
<td></td>
</tr>
<tr>
<td>23-18</td>
<td>Flash B sample clock slave delay line delay cell number selection.</td>
</tr>
<tr>
<td>BSLVSEL</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>Flash B sample clock reference delay line locked.</td>
</tr>
<tr>
<td>BREFLOCK</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>Flash B sample clock slave delay line locked.</td>
</tr>
<tr>
<td>BSLVLOCK</td>
<td></td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13-8</td>
<td>Flash A sample clock reference delay line delay cell number selection.</td>
</tr>
<tr>
<td>AREFSEL</td>
<td></td>
</tr>
<tr>
<td>7-2</td>
<td>Flash A sample clock slave delay line delay cell number selection .</td>
</tr>
<tr>
<td>ASLVSEL</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Flash A sample clock reference delay line locked.</td>
</tr>
<tr>
<td>AREFLOCK</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Flash A sample clock slave delay line locked.</td>
</tr>
<tr>
<td>ASLVLOCK</td>
<td></td>
</tr>
</tbody>
</table>
27.7.2.27  AHB Suspend Status Register (AHBSPNDDS)

27.7.2.27.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>AHBSPNDDS</td>
<td>ECh</td>
</tr>
</tbody>
</table>

27.7.2.27.2  Function
Indicates the status of Suspended AHB Read Prefetch command sequence. When there is IP/AHB command triggered and arbitrator is processing an AHB Read sequence (prefetching more data not for current AHB burst), the prefetch sequence will be suspended and may be resumed when there is no transaction on FlexSPI any more. FlexSPI saves only one AHB prefetch sequence. When a new prefetch sequence is suspended with an active sequence suspended already, previous suspended sequence will be removed and never resumed. Refer Command Abort and Suspend for more details.

27.7.2.27.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DATLFT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

27.7.2.27.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>DATLFT</td>
</tr>
<tr>
<td>DATLFT</td>
<td>Left Data size for suspended command sequence (in byte).</td>
</tr>
<tr>
<td>15-4</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
**27.7.2.28 IP RX FIFO Status Register (IPRXFSTS)**

### 27.7.2.28.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPRXFSTS</td>
<td>F0h</td>
</tr>
</tbody>
</table>

### 27.7.2.28.2 Function

This status register indicates the status of IP RX FIFO.

### 27.7.2.28.3 Diagram

![Diagram of IPRXFSTS register]

### 27.7.2.28.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Total Read Data Counter: RDCNTR * 64 Bits.</td>
</tr>
<tr>
<td>RDCNTR</td>
<td></td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 27.7.2.29 IP TX FIFO Status Register (IPTXFSTS)

#### 27.7.2.29.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IPTXFSTS</td>
<td>F4h</td>
</tr>
</tbody>
</table>

#### 27.7.2.29.2 Function

This status register indicates the status of IP TX FIFO.

#### 27.7.2.29.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>WRCNTR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FILL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

#### 27.7.2.29.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Total Write Data Counter: WRCNTR * 64 Bits.</td>
</tr>
<tr>
<td>WRCNTR</td>
<td></td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-0</td>
<td>Fill level of IP TX FIFO.</td>
</tr>
<tr>
<td>FILL</td>
<td>Valid Data entries in IP TX FIFO is: FILL * 64 Bits.</td>
</tr>
</tbody>
</table>
27.7.2.30  IP RX FIFO Data Register a (RFDR0 - RFDR31)

27.7.2.30.1  Offset

For a = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RFDRa</td>
<td>100h + (a × 4h)</td>
</tr>
</tbody>
</table>

27.7.2.30.2  Function

These registers provide read access to IP RX FIFO by IPS bus. The read value is unknown for read access to invalid entries in IP RX FIFO.

27.7.2.30.3  Diagram

```
Bits 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
R     RXDATA
W     
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     RXDATA
W     
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

27.7.2.30.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>RX Data</td>
</tr>
</tbody>
</table>

27.7.2.31  IP TX FIFO Data Register a (TFDR0 - TFDR31)
27.7.2.31.1  Offset

For a = 0 to 31:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TFDRa</td>
<td>180h + (a × 4h)</td>
</tr>
</tbody>
</table>

27.7.2.31.2  Function

These registers provide write access to IP TX FIFO by IPS bus.

27.7.2.31.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

27.7.2.31.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>TX Data</td>
</tr>
<tr>
<td>TXDATA</td>
<td></td>
</tr>
</tbody>
</table>

27.7.2.32  LUT a (LUT0 - LUT63)

27.7.2.32.1  Offset

For a = 0 to 63:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LUTa</td>
<td>200h + (a × 4h)</td>
</tr>
</tbody>
</table>
27.7.2.32.2  Function

The LUT is a look-up-table for command sequences. Software should set the sequence index before triggering an IP command or AHB command. FlexSPI will fetch the command sequence from LUT when IP/AHB command triggered. There are 16 command sequences in LUT. Refer Look Up Table for more details.

NOTE
LUT is implemented as memory, so the reset value is unknown.

27.7.2.32.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
<tr>
<td>W</td>
<td>OPCODE1</td>
<td></td>
<td>NUM_PADS1</td>
<td></td>
<td></td>
<td>OPERAND1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
<tr>
<td>W</td>
<td>OPCODE0</td>
<td></td>
<td>NUM_PADS0</td>
<td></td>
<td></td>
<td>OPERAND0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>
```

27.7.2.32.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-26</td>
<td>OPCODE1</td>
</tr>
<tr>
<td>25-24</td>
<td>NUM_PADS1</td>
</tr>
<tr>
<td>23-16</td>
<td>OPERAND1</td>
</tr>
<tr>
<td>15-10</td>
<td>OPCODE0</td>
</tr>
<tr>
<td>9-8</td>
<td>NUM_PADS0</td>
</tr>
<tr>
<td>7-0</td>
<td>OPERAND0</td>
</tr>
</tbody>
</table>
27.8  AHB Memory Map definition

This section describes FlexSPI module AHB memory map in detail.

27.8.1  AHB Memory Map for Serial Flash memory access

AHB read/write access for serial flash memory is mapped to a specific address range. See the Memory Map and register definition for specific address ranges supported.

AHB Bus feature supported for Serial Flash memory reading:
- Cachable and Non-Cachable access
- Prefetch Enable/Disable
- Burst size: 8/16/32/64 bits
- All burst type: SINGLE/INCR/WRAP4/INCR4/WRAP8/INCR8/WRAP16/INCR16

AHB Bus feature for Serial Flash memory writing:
- Bufferable and Non-Bufferable access
- Burst size: 8/16/32/64 bits
- All burst type: SINGLE/INCR/WRAP4/INCR4/WRAP8/INCR8/WRAP16/INCR16

Refer Flash access by AHB Command for more details about AHB access to Serial Flash memory.
Chapter 28
ARM Cortex M7 Platform

28.1 Chip-specific Arm Cortex M7 information

Table 28-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
<tr>
<td>System Debug</td>
<td>-</td>
<td>System Debug</td>
</tr>
</tbody>
</table>

There are 16 regions implemented in the MPU

Below is a summary of the CoreSight components used in RT10XX and their corresponding Arm documents:

Table 28-2. CoreSight Components and Corresponding Arm Documents

<table>
<thead>
<tr>
<th>CoreSight Component</th>
<th>Arm Document</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>TSGEN (Timestamp generator)</td>
<td>Arm CoreSight™ SoC-400</td>
<td>Read-only APB interface of the TSGEN is not applicable.</td>
</tr>
<tr>
<td></td>
<td>Revision: r3p2</td>
<td></td>
</tr>
<tr>
<td>ETM</td>
<td>Arm CoreSight™ ETM-M7</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Revision: r0p1</td>
<td></td>
</tr>
<tr>
<td>DAP</td>
<td>Arm Cortex-M7 Processor</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Revision: r1p2</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
28.2 Arm Cortex M7 Platform

28.2.1 Overview

The Cortex-M7 platform features a single Arm®Cortex®-M7 processor in this chip. The Arm®Cortex®-M7 processor is a highly efficient, high-performance, embedded processor that features low interrupt latency, low-cost debug, and has backwards compatibility with existing Cortex-M profile processors. The processor has an in-order super-scalar pipeline by which many instructions can be dual-issued, including load/load and load/store instruction pairs because of multiple memory interfaces.

Memory interfaces that the processor supports include:

- Tightly-Coupled Memory (TCM)
- Harvard instruction and data caches and AXI master (AXIM) interface
- Dedicated low-latency AHB-Lite peripheral (AHBP) interface

The Arm Cortex-M7 Platform supports the following:

- 32 KB L1 Instruction Cache
- 32 KB L1 Data Cache
- Floating Point Unit (FPU) with support for the FPv5 architecture
- Internal Trace (TRC)

The number ofIRQs supported for this chip is 160. In addition, it supports various components composing the Arm CoreSight debug/Trace system, such as ETM and CTI.

**NOTE**
This chip supports up to 16 interrupt priority levels, i.e. it implements bits [7:4] of each NVIC Interrupt Priority Register.
28.2.2 Block Diagram

A block diagram for the Cortex-M7 is given below:

![Block Diagram of Cortex-M7](image)

**Figure 28-1. Cortex-M7 Platform Block Diagram**

28.2.3 External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ARM_TRACE0</td>
<td>Trace signal</td>
<td>GPIO_B0_04</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td>ARM_TRACE1</td>
<td>Trace signal</td>
<td>GPIO_B0_05</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td>ARM_TRACE2</td>
<td>Trace signal</td>
<td>GPIO_B0_06</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td>ARM_TRACE3</td>
<td>Trace signal</td>
<td>GPIO_B0_07</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td>ARM_TRACE_CLK</td>
<td>Clock Signal</td>
<td>GPIO_B0_12</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td>ARM_EVENT0</td>
<td>Output Event signal</td>
<td>GPIO_B0_14</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td>ARM_EVENTI</td>
<td>Input Event Signal</td>
<td>GPIO_B0_15</td>
<td>ALT2</td>
<td>I</td>
</tr>
</tbody>
</table>
NOTE
See the Arm rows of "Muxing Options" table in the "External Signals and Pin Multiplexing" chapter for details.

28.2.4 Clocks

<table>
<thead>
<tr>
<th>Clock Name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>axi_clk</td>
<td>ipg_clk_root</td>
<td>Bus clock</td>
</tr>
<tr>
<td>main_clk</td>
<td>ahb_clk_root</td>
<td>Arm core clock</td>
</tr>
<tr>
<td>trace_clk_in</td>
<td>trace_clk_root</td>
<td>Clock signal</td>
</tr>
</tbody>
</table>
Chapter 29
Network Interconnect Bus System (NIC-301)

29.1 Chip-specific NIC-301 information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

29.2 Overview

This section provides an overview of the

- NIC-301 (Network Inter-Connect) AXI arbiter IP

The NIC-301 (by Arm Ltd.) is a configurable AXI arbiter between several masters and slaves. The NIC-301 IP is designed so that many configuration options are selected at the hardware design stage, determined by SoC characteristics and needs, while several other configuration options are software-controlled.

This chapter covers in brief the NIC-301 while providing configuration details on the NIC-301 instances used in the chip. For complete details on the NIC-301 design, see the Arm specification, *AMBA® Network Interconnect (NIC-301) Technical Reference Manual, version r2p3*. 
NOTE
The NIC-301 default settings are configured by NXP's board support package (BSP), and in most cases should not be modified by the customer. The default settings have gone through exhaustive testing during the validation of the part, and have proven to work well for the part's intended target applications. Changes to the default settings may result in a degradation in system performance.

29.2.1 NIC-301 Main Features
Key features of the NIC-301 module include the following:

- Address space memory mapping.
- Programmer's view, for software-configured parameters, via internal "GPV" ports.
- Support for cross-clock domain synchronization.

29.2.2 Modes and Operations
The NIC-301 supports a normal functional mode only.

29.3 External Signals
There are no external I/O interfaces for NIC-301.

29.4 Memory Map and Register Definition
The bus system is composed of five instances: SIM_M7, SIM_PER, SIM_M, SIM_MAIN and SIM_EMS. Three of them have GPV registers which are helpful for bus arbitration and performance. For detailed descriptions of these registers, see the Arm document: DDI0397I_corelink_network_interconnect_nic301_r2p3_trm.pdf.

1. SIM_MAIN registers
The SIM_MAIN GPV base address is GPV0_BASE = 0x41000000. The following registers are implemented in this NIC.
<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>read_qos</td>
<td>m_a_2</td>
<td>LCD</td>
<td>GPV0_BASE + 0x44000 + 0x100</td>
<td>1</td>
<td>Set the priority of master’s read. The priority level would be used when the master’s read transaction is being arbitrated by the NIC. Legal programmable values are from 0 to 15. Higher number sets higher priority (0: the lowest arbitration priority; ...; 15: the highest priority).</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_a_3</td>
<td>CSI</td>
<td>GPV0_BASE + 0x45000 + 0x100</td>
<td>4</td>
<td>Same as above</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_a_4</td>
<td>PXP</td>
<td>GPV0_BASE + 0x46000 + 0x100</td>
<td>2</td>
<td>Same as above</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_a_2</td>
<td>LCD</td>
<td>GPV0_BASE + 0x44000 + 0x104</td>
<td>1</td>
<td>Set the priority of master’s write. The priority level would be used when the master’s write transaction is being arbitrated by the NIC. Legal programmable values are from 0 to 15. Higher number sets higher priority (0: the lowest arbitration priority; ...; 15: the highest priority).</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_a_3</td>
<td>CSI</td>
<td>GPV0_BASE + 0x45000 + 0x104</td>
<td>4</td>
<td>Same as above</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_a_4</td>
<td>PXP</td>
<td>GPV0_BASE + 0x46000 + 0x104</td>
<td>2</td>
<td>Same as above</td>
</tr>
<tr>
<td>fn_mod</td>
<td>m_a_2</td>
<td>LCD</td>
<td>GPV0_BASE + 0x44000 + 0x108</td>
<td>0</td>
<td>Issuing functionality modification register. This register sets the block issuing capability to one outstanding transaction. Legal programmable values are 0, 1, 2 and 3.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 2. SIM_M registers

The SIM_M GPV base address is GPV1_BASE = 0x41100000. The following registers are implemented in this NIC.

<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
</table>
| fn_mod2       | m_c_0     | DCP         | GPV1_BASE + 0x42000 + 0x024 | 0           | Legal programmable values are 0 and 1.  
  • 0: Enable the size merge function  
  • 1: Bypass the size merge function |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>fn_mod_ahb</td>
<td>m_c_1</td>
<td>ENET</td>
<td>GPV1_BASE + 0x43000 + 0x028</td>
<td>0</td>
<td>This register has 3 control bits.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>• Bit 0: rd_incr_override. Writing 1 to this bit forces NIC to convert all AHB read transactions to a series of AXI singles.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>• Bit 1: wr_incr_override. Writing 1 to this bit forces NIC to convert all AHB write transactions to a series of AXI singles.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>• Bit 2: lock_override. Writing 1 to this bit forces NIC not to create any AXI lock transactions.</td>
</tr>
<tr>
<td>fn_mod_ahb</td>
<td>m_c_5</td>
<td>TestPort</td>
<td>GPV1_BASE + 0x47000 + 0x028</td>
<td>0</td>
<td>Same as above</td>
</tr>
<tr>
<td>fn_mod_ahb</td>
<td>m_c_6</td>
<td>ENET2</td>
<td>GPV1_BASE + 0x48000 + 0x028</td>
<td>0</td>
<td>Same as above</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_c_0</td>
<td>DCP</td>
<td>GPV1_BASE + 0x42000 + 0x100</td>
<td>0</td>
<td>Set the priority of master's read. The priority level would be used when the master's read transaction is being arbitrated by the NIC.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>read_qos</td>
<td>m_c_1</td>
<td>ENET</td>
<td>GPV1_BASE + 0x43000 + 0x100</td>
<td>3</td>
<td>Same as above</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_c_2</td>
<td>USBO2</td>
<td>GPV1_BASE + 0x44000 + 0x100</td>
<td>1</td>
<td>Same as above</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_c_3</td>
<td>USDHC1</td>
<td>GPV1_BASE + 0x45000 + 0x100</td>
<td>2</td>
<td>Same as above</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_c_4</td>
<td>USDHC2</td>
<td>GPV1_BASE + 0x46000 + 0x100</td>
<td>2</td>
<td>Same as above</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_c_5</td>
<td>TestPort</td>
<td>GPV1_BASE + 0x47000 + 0x100</td>
<td>0</td>
<td>Read-only register.</td>
</tr>
<tr>
<td>read_qos</td>
<td>m_c_6</td>
<td>ENET2</td>
<td>GPV1_BASE + 0x48000 + 0x100</td>
<td>3</td>
<td>Set the priority of master’s read. The priority level would be used when the master’s read transaction is being arbitrated by the NIC. Legal programmable values are from 0 to 15. Higher number sets higher priority (0: the lowest arbitration priority; ...; 15: the highest priority).</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_c_0</td>
<td>DCP</td>
<td>GPV1_BASE + 0x42000 + 0x104</td>
<td>0</td>
<td>Set the priority of master’s write. The priority level would be used when the master’s write transaction is being arbitrated by the NIC. Legal programmable values are from 0 to 15. Higher number sets higher priority (0: the lowest arbitration priority; ...; 15: the highest priority).</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_c_1</td>
<td>ENET</td>
<td>GPV1_BASE + 0x43000 + 0x104</td>
<td>3</td>
<td>Same as above</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>write_qos</td>
<td>m_c_2</td>
<td>USBO2</td>
<td>GPV1_BASE + 0x44000 + 0x104</td>
<td>1</td>
<td>Same as above</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_c_3</td>
<td>USDHC1</td>
<td>GPV1_BASE + 0x45000 + 0x104</td>
<td>2</td>
<td>Same as above</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_c_4</td>
<td>USDHC2</td>
<td>GPV1_BASE + 0x46000 + 0x104</td>
<td>2</td>
<td>Same as above</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_c_5</td>
<td>TestPort</td>
<td>GPV1_BASE + 0x47000 + 0x104</td>
<td>0</td>
<td>Read-only register.</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_c_6</td>
<td>ENET2</td>
<td>GPV1_BASE + 0x48000 + 0x104</td>
<td>3</td>
<td>Set the priority of master's write. The priority level would be used when the master's write transaction is being arbitrated by the NIC. Legal programmable values are from 0 to 15. Higher number sets higher priority (0: the lowest arbitration; ..., 15: the highest priority).</td>
</tr>
</tbody>
</table>
| fn_mod        | m_c_0     | DCP         | GPV1_BASE + 0x42000 + 0x108 | 0           | Issuing functionality modification register. This register sets the block issuing capability to one outstanding transaction. Legal programmable values are 0, 1, 2 and 3. **NOTE:** It is recommended to keep its reset value to obtain the best performance.  
  - 0: Default setting  
  - 1: Set read issuing capability to one outstanding transaction  
  - 2: Set write issuing capability to |

*Table continues on the next page...*
### Memory Map and Register Definition

<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>fn_mod</td>
<td>m_c_1</td>
<td>ENET</td>
<td>GPV1_BASE + 0x43000 + 0x108</td>
<td>0</td>
<td>Same as above</td>
</tr>
<tr>
<td>fn_mod</td>
<td>m_c_2</td>
<td>USBO2</td>
<td>GPV1_BASE + 0x44000 + 0x108</td>
<td>0</td>
<td>Same as above</td>
</tr>
<tr>
<td>fn_mod</td>
<td>m_c_3</td>
<td>USDHC1</td>
<td>GPV1_BASE + 0x45000 + 0x108</td>
<td>0</td>
<td>Same as above</td>
</tr>
<tr>
<td>fn_mod</td>
<td>m_c_4</td>
<td>USDHC2</td>
<td>GPV1_BASE + 0x46000 + 0x108</td>
<td>0</td>
<td>Same as above</td>
</tr>
<tr>
<td>fn_mod</td>
<td>m_c_5</td>
<td>TestPort</td>
<td>GPV1_BASE + 0x47000 + 0x108</td>
<td>0</td>
<td>Same as above</td>
</tr>
<tr>
<td>fn_mod</td>
<td>m_c_6</td>
<td>ENET2</td>
<td>GPV1_BASE + 0x48000 + 0x108</td>
<td>0</td>
<td>Same as above</td>
</tr>
</tbody>
</table>

3. **SIM_M7 registers**

The SIM_M7 GPV base address is GPV4_BASE = 0x41400000. The following registers are implemented in this NIC.

<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>fn_mod_ahb</td>
<td>m_b_1</td>
<td>DMA</td>
<td>GPV4_BASE + 0x43000 + 0x028</td>
<td>0</td>
<td>This register has 3 control bits.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>- Bit 0: rd_incr_override. Writing 1 to this bit forces NIC to convert all AHB read transactions to a series of AXI singles.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>- Bit 1: wr_incr_override. Writing 1 to this bit forces NIC to convert all AHB write transactions to a series of AXI singles.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
</table>
| wr_tidemark   | m_b_0     | Cortex-M7   | GPV4_BASE + 0x42000 + 0x040 | 4           | The write data FIFO depth is 4, so the valid programmable values to this register are 0, 1, 2, 3, and 4. This is a tidemark level that stalls the release of the transaction until:  
  - The NIC receives the WLAST beat.  
  - The write FIFO becomes full.  
  - The number of occupied slots in the write data FIFO exceeds the write tidemark. |
| read_qos      | m_b_0     | Cortex-M7   | GPV4_BASE + 0x42000 + 0x100 | 4           | Set the priority of master's read. The priority level would be used when the master's read transaction is being arbitrated by the NIC. Legal programmable values are from 0 to 15. Higher number sets higher priority (0: the lowest)

*NOTE:* It is recommended to keep its reset value to obtain the best performance.
<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>read_qos</td>
<td>m_b_1</td>
<td>DMA</td>
<td>GPV4_BASE + 0x43000 + 0x100</td>
<td>3</td>
<td>Same as above</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_b_0</td>
<td>Cortex-M7</td>
<td>GPV4_BASE + 0x42000 + 0x104</td>
<td>4</td>
<td>Set the priority of master’s write. The priority level would be used when the master’s write transaction is being arbitrated by the NIC. Legal programmable values are from 0 to 15. Higher number sets higher priority (0: the lowest arbitration priority; ...; 15: the highest priority).</td>
</tr>
<tr>
<td>write_qos</td>
<td>m_b_1</td>
<td>DMA</td>
<td>GPV4_BASE + 0x43000 + 0x104</td>
<td>3</td>
<td>Same as above</td>
</tr>
</tbody>
</table>
| fn_mod        | m_b_0     | Cortex-M7   | GPV4_BASE + 0x42000 + 0x108 | 0           | Issuing functionality modification register. This register sets the block issuing capability to one outstanding transaction. Legal programmable values are 0, 1, 2 and 3. **NOTE:** It is recommended to keep its reset value to obtain the best performance.  
- 0: Default setting  
- 1: Set read issuing capability to one outstanding transaction  
- 2: Set write issuing capability to |

*Table continues on the next page...*
4. **IB registers**

There are no IB registers implemented in this chip.

5. **Address region control registers**

There are not such type of registers implemented in this chip.

6. **Peripheral ID registers**

The peripheral ID registers are implemented in SIM_MAIN, SIM_M, and SIM_M7. For more details, please see the Arm document: *DDI0397I_corelink_network_interconnect_nic301_r2p3_trm.pdf.*

---

<table>
<thead>
<tr>
<th>Register Name</th>
<th>Port Name</th>
<th>Module Name</th>
<th>Absolute Address</th>
<th>Reset Value</th>
<th>Descriptions</th>
</tr>
</thead>
<tbody>
<tr>
<td>fn_mod</td>
<td>m_b_1</td>
<td>DMA</td>
<td>GPV4_BASE + 0x43000 + 0x108</td>
<td>0</td>
<td>Same as above</td>
</tr>
</tbody>
</table>

- One outstanding transaction
- 3: Set both read and write issuing capability to one outstanding transaction
Chapter 30
On-Chip RAM Memory Controller (OCRAM)

30.1 Chip-specific OCRAM information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

30.2 Overview

There is 1 OCRAM controller implemented in the chip. One controller is for up to 512 KB on-chip RAM. The size of OCRAM is configured in the FlexRAM module via IOMUXC. For more details, refer to the FlexRAM chapter.

The on-chip RAM block is implemented as an slave module on the 64-bit system AXI bus. Designed as a simple on-chip memory controller, it supports only one AXI port with memory banks. For the AXI port, the read and write transactions are handled by two independent modules. As it is possible to have simultaneous read and write request from the AXI bus, each memory bank has an arbiter with round-robin scheme. After arbitration, the granted read or write access command can then be issued to the memory cell through a read/write MUX.
The memory banks are organized with the lower 2 bits of the address which is the AXI bus address and is 64 bits aligned interleaved. This allows a read access and a write access to be processed at the same time if they are targeted to different memory banks.

Various options are provided for adding a pipeline or wait-states in a read/write access, in order to ensure flexible timing control at both high and low frequencies.

The internal block diagram is shown in the figure below.

![On-chip RAM Block Diagram](image)

**Figure 30-1. On-chip RAM Block Diagram**

### 30.3 Basic Functions
30.3.1 Read/Write Arbitration

The detailed rules used in arbitration are as follows:

- If there is no granted read or write in the last cycle, and there is only a read request or a write request, the request will be granted.
- If there is no granted read or write in the last cycle, and there are both read or write requests coming in at the same time, the read request will be granted first.
- If a granted read/write transaction has just finished, the write/read request will have the higher priority in the next cycle.
- If the first read/write access request in a transaction is granted, all the data transfer in this burst will be finished before the next arbitration begins, that is, the round-robin arbitration mechanism is based on AXI transaction, not data access.

30.4 Advanced Features

This section describes some advanced features designed to avoid timing issues when the on-chip RAM is working at high frequency.

All of the features can be disabled/enabled by programming the corresponding fields of the General Purpose Register (IOMUXC.GPR3) bits [3:0] in the IOMUX chapter.

30.4.1 Read Data Wait State

When the wait state is enabled, it will take 2 cycles for each read access (each beat of a read burst).

This can avoid the potential timing problem caused by the longer memory access time at higher frequency.

When this feature is disabled, it only takes 1 clock cycle to finish a read transaction. That is, read data is available in the next cycle of read request becomes valid on the bus.

For the normal OCRAM, the read data wait state is configurable via IOMUXC.GPR3[0].

30.4.2 Read Address Pipeline

When this feature is enabled, the read address from the AXI master is delayed 1 cycle before it can be accepted by the on-chip RAM.
Advanced Features

This can avoid setup time issues for the read access on the memory cell at high frequency. Enabling this feature can cost, at most, 1 more clock cycle for each AXI read transaction, that is, at most 1 more clock cycle for each read burst with multiple beats of data.

When this feature is disabled, the read address from the AXI master can be accepted by the on-chip RAM without delay, and data can become ready for master at next clock cycle (if no other access and no read data wait).

For the normal OCRAM, the read address pipeline is configurable via IOMUXC.GPR3[1].

30.4.3 Write Data Pipeline

When this feature is enabled, the write data from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM.

This can avoid setup time issue for the write access on the memory cell at high frequency. Enabling this feature would cost at most 1 more clock cycle for each AXI write transaction, that is, at most 1 more clock cycle for each write burst with multiple beats of data.

When this feature is disabled, the write data from the AXI master can be accepted by the on-chip RAM without delay, and data can be written to memory at this cycle (if no other access and write address is also ready at this cycle).

For the normal OCRAM, the write data pipeline is configurable via IOMUXC.GPR3[2].

30.4.4 Write Address Pipeline

When this feature is enabled, the write address from the AXI master would be delayed 1 cycle before it can be accepted by the on-chip RAM.

This can avoid setup time issue for the write access on the memory cell at high frequency. Enabling this feature would take at most 1 more clock cycle for each AXI write transaction, that is, at most 1 more clock cycle for each write burst with multiple beats of data.

When this feature is disabled, the write address from the AXI master can be accepted by the on-chip RAM without delay, and data can be written to memory at this cycle (if no other access and write data is also ready at this cycle).
For the normal OCRAM, the write address pipeline is configurable via IOMUXC.GPR3[3]

### 30.5 Programmable Registers

There are no programmable registers in this block; however, OCRAM configurable bits can be found in the IOMUX Controller (IOMUXC) general purpose registers found here.

- TrustZone bits: IOMUXC_GPR10
Chapter 31
FlexRAM

31.1 Chip-specific FlexRAM information

Table 31-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

For additional information see application note AN12077: Using the i.MX RT FlexRAM. This document describes the flexible memory array available on the i.MX RT MCUs. It includes the following information:

• Configuration of the bank array
• Memory type size definition
• Available memory controllers
• Power domains and clocks
• Interrupt request generation
• Example of FlexRAM configuration usage on a specific application use case
31.2 Overview

31.2.1 Introduction
This SoC has 512 KB of on-chip RAM which is shared by I-TCM, D-TCM and general purpose On Chip RAM (OCRAM). The FlexRAM is the manager of the big on-chip RAM array.

31.2.2 Features
The FLEXRAM includes the following features:

- Integrated I-TCM and D-TCM RAM controller
  - 64-bit I-TCM interface and 2x 32-bit D-TCM interface.
  - The controller supports up to 512 KB TCM (for both ITCM and DTCM) space.
  - The controller supports two access modes:
    - Fast mode: RAM accesses is expected to be finished in 1-cycle for both read and write.
    - Wait mode: RAM accesses is expected to be finished in 2-cycle. Wait mode for read and write path can be enabled separately.
  - Synchronous interface to the M7 Core, run at the same frequency as the core
  - Automatically clock gating control to reduce power consumption
- Integrated OCRAM controller
  - single SRAM bank controller.
  - support up to 512 KB SRAM size
  - Synchronous to the system bus, runs at the same frequency as bus fabric
- Parameterized RAM Array
  - Support up to 512 KB total memory space
  - Support up to 32 block of 32-bit RAM
- RAM Array portioning
  - RAM size of ITCM, DTCM and OCRAM can be configured from 0 to full RAM Array size separately
  - Step of the RAM size partitioning for ITCM, DTCM and OCRAM is (Total RAM SIZE)/16
  - Flexible RAM bank organization.
- Flexible power mode:
  - Run mode: All RAM banks are powered on
• Retention mode: Only 1 (Bank0) out of the 16 RAM banks is on while the rest banks are powered off
• Partial mode: 8 out of the 16 RAM banks (bank8 to bank15) can be powered off dynamically
• Bank8~15 can be disabled with hardware fuse setting. When the fuse is set, total RAM size will be limit to 256 KB
• Generates interrupt upon TCM, OCRAM access out of configured RAM range

31.2.3 Block diagram

![FLEXRAM block diagram](image)

Figure 31-1. FLEXRAM block diagram

31.3 Functional description

FLEXRAM converts AXI and TCM interface signals to RAM interface signals and implements mux control for OCRAM, DTCM and ITCM access to on-chip RAM.
31.3.1 Interface Conversion

FLEXRAM integrate OCRAM controller which converts AXI master interface signals to RAM interface signals (Please see OCRAM section). OCRAM controller can support to add pipeline or wait-state in read/write access by IOMUX GPR.

FLEXRAM also implement TCM controller module to convert DTCM/ITCM interface to RAM interface. TCM read/write access can be extended to 2 cycles by setting TCM_CTRL register. When DTCM and ITCM access unallocated RAM address, TCM controller can send tcm_err to DTCM/ITCM interface.

31.3.2 RAM Bank Allocation

OCRAM, DTCM and ITCM share 512 KB of on-chip RAM. SW can configure from 0 to 512 KB full RAM array size for OCRAM, DTCM and ITCM by IOMUX GPR16 and GPR17. The RAM size step is 32KB. The allocated RAM bank can be not overlapped for OCRAM, DTCM and ITCM. Table below show an example of a 128KB ITCM, 128KB DTCM and 256KB OCRAM configuration.

<table>
<thead>
<tr>
<th>Bank</th>
<th>ITCM</th>
<th>DTCM</th>
<th>OCRAM</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bank0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank2</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank3</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank4</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bank5</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bank6</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Bank7</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Bank8</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank9</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank10</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank11</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Bank12</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bank13</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bank14</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Bank15</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>
Each RAM bank has 2 bits bank configuration from IOMUX GPR17.

<table>
<thead>
<tr>
<th>RAM Bank Configuration</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
</tr>
<tr>
<td>01</td>
</tr>
<tr>
<td>10</td>
</tr>
<tr>
<td>11</td>
</tr>
</tbody>
</table>

### 31.3.3 Low power modes

FLEXRAM has input fuse control signal to control OCRAM bank8~bank15 interface access. When the fuse bit is programmed, bank8~bank15 can't be accessed again and can be power down.

### 31.3.4 Clocks

The following table describes the clock sources of the FlexRAM module.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock for register accesses</td>
</tr>
</tbody>
</table>

### 31.3.5 Reset

FLAMRAM has 2 reset signals. One is used for OCRAM interface and in always on power domain. The other is used for TCM interface and in core power domain.

### 31.3.6 Interrupts

FLEXRAM can generate interrupt in the following cases:
- OCRAM, DTCM or ITCM access the RAM address which is not allocated.
31.4 Memory Map and register definition

This section includes the FLEXRAM module memory map and detailed descriptions of all registers.

31.4.1 FLEXRAM register descriptions

31.4.1.1 FLEXRAM Memory map

FlexRAM base address: 400B_0000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>TCM CRTL Register (TCM_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>Interrupt Status Register (INT_STATUS)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Interrupt Status Enable Register (INT_STAT_EN)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>18h</td>
<td>Interrupt Enable Register (INT_SIG_EN)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

31.4.1.2 TCM CRTL Register (TCM_CTRL)

31.4.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCM_CTRL</td>
<td>0h</td>
</tr>
</tbody>
</table>

31.4.1.2.2 Function

.
### 31.4.1.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

#### 31.4.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>FORCE_CLK_ON</td>
</tr>
<tr>
<td>1</td>
<td>TCM_RWAIT_EN</td>
</tr>
<tr>
<td>0</td>
<td>TCMclearfix;_WWAIT_EN</td>
</tr>
</tbody>
</table>

- **FORCE_CLK_ON**: Force RAM Clock Always On
- **TCM_RWAIT_EN**: TCM Read Wait Mode Enable
  - 0b - TCM read fast mode: Read RAM accesses are expected to be finished in 1-cycle.
  - 1b - TCM read wait mode: Read RAM accesses are expected to be finished in 2-cycles.
- **TCMclearfix;_WWAIT_EN**: TCM Write Wait Mode Enable
  - 0b - TCM write fast mode: Write RAM accesses are expected to be finished in 1-cycle.
  - 1b - TCM write wait mode: Write RAM accesses are expected to be finished in 2-cycles.

### 31.4.1.3 Interrupt Status Register (INT_STATUS)

#### 31.4.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_STATUS</td>
<td>10h</td>
</tr>
</tbody>
</table>
31.4.1.3.2 Function

31.4.1.3.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

31.4.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>OCRAM Access Error Status</td>
</tr>
<tr>
<td>OCRAM_ERR_STATUS</td>
<td>When OCRAM access unallocated address, this bit will be asserted if corresponding status enable bit in INT_STAT_EN register is set.</td>
</tr>
<tr>
<td></td>
<td>0b - OCRAM access error does not happen</td>
</tr>
<tr>
<td></td>
<td>1b - OCRAM access error happens.</td>
</tr>
<tr>
<td>4</td>
<td>DTMC Access Error Status</td>
</tr>
<tr>
<td>DTMC_ERR_STATUS</td>
<td>When DTMC access unallocated address, this bit will be asserted if corresponding status enable bit in INT_STAT_EN register is set.</td>
</tr>
<tr>
<td></td>
<td>0b - DTMC access error does not happen</td>
</tr>
<tr>
<td></td>
<td>1b - DTMC access error happens.</td>
</tr>
<tr>
<td>3</td>
<td>ITCM Access Error Status</td>
</tr>
<tr>
<td>ITCM_ERR_STATUS</td>
<td>When ITCM access unallocated address, this bit will be asserted if corresponding status enable bit in INT_STAT_EN register is set.</td>
</tr>
<tr>
<td></td>
<td>0b - ITCM access error does not happen</td>
</tr>
<tr>
<td></td>
<td>1b - ITCM access error happens.</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 31.4.1.4 Interrupt Status Enable Register (INT_STAT_EN)

#### 31.4.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_STAT_EN</td>
<td>14h</td>
</tr>
</tbody>
</table>

#### 31.4.1.4.2 Function

Setting the bits in this register to 1 enables the corresponding Interrupt Status to be set by the specified event.

#### 31.4.1.4.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- **OCRAM_ERR_STAT_EN**
- **DTCM_ERR_STAT_EN**
- **ITCM_ERR_STAT_EN**
- **Reserved2**
- **Reserved1**
- **Reserved0**
```
# Memory Map and register definition

## 31.4.1.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>OCRAM Access Error Status Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>4</td>
<td>DTCM Access Error Status Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>3</td>
<td>ITCM Access Error Status Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Masked</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>2</td>
<td>Reserved2</td>
</tr>
<tr>
<td>1</td>
<td>Reserved1</td>
</tr>
<tr>
<td>0</td>
<td>Reserved0</td>
</tr>
</tbody>
</table>

## 31.4.1.5 Interrupt Enable Register (INT_SIG_EN)

### 31.4.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT_SIG_EN</td>
<td>18h</td>
</tr>
</tbody>
</table>

### 31.4.1.5.2 Function

This register is used to select which interrupt status is indicated to the Host System as the interrupt. These status bits all share the same interrupt line. Setting any of these bits to 1 enables interrupt generation. The corresponding Status register bit will generate an interrupt when the corresponding interrupt signal enable bit is set.
31.4.1.5.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

31.4.1.5.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-6 Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>5 OCRA M.ERR.SIG.EN</td>
<td>OCRAM Access Error Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>4 DTCM.ERR.SIG.EN</td>
<td>DTCM Access Error Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>3 ITCM.ERR.SIG.EN</td>
<td>ITCM Access Error Interrupt Enable 0b - Masked 1b - Enabled</td>
</tr>
<tr>
<td>2 Reserved2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1 Reserved1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0 Reserved0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
Chapter 32
AHB to IP Bridge (AIPSTZ)

32.1 Chip-specific AIPSTZ information

Table 32-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
</tbody>
</table>

32.2 Overview

This section provides an overview of the AHB to IP Bridge (AIPSTZ). This particular peripheral is designed as the bridge between AHB bus and peripherals with the lower bandwidth IP Slave (IPS) buses.

32.2.1 Features

The following list summarizes the key features of the bridge:

- The bridge supports the IPS slave bus signals. This interface is only meant for slave peripherals.
- The bridge supports 8-, 16-, and 32-bit IPS peripherals. (Accesses larger than the size of a peripheral are not supported, except to 32-bit memory.)
- The bridge supports a pair of IPS accesses for 64-bit and certain misaligned AHB transfers to 32-bit memory in 64-bit platforms.
- The bridge directly supports up to 32 16-Kbyte external IPS peripherals, and 2 global external IPS peripheral spaces. The bridge occupies 1 MBytes of total address space.
The bridge provides configurable per-block and per-master access protections. Access permissions are based on bus master (e.g. DMA or core) privilege levels and resource domain. More details on the protection features and configuration can be found in the Security Reference Manual.

Peripheral read transactions require a minimum of 2 hclk clocks, and unbuffered write transactions require a minimum of 3 hclk clocks.

The bridge uses one single asynchronous reset and one global clock.

### 32.3 Clocks

The following table describes the clock sources for AIPSTZ. Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>hclk</td>
<td>ahb_clk_root</td>
<td>Module clock</td>
</tr>
</tbody>
</table>

### 32.4 Functional Description

The AIPS bridge serves as a protocol translator between the AHB system bus and the IP bus.

Support is provided for generating a pair of 32-bit IP bus accesses when targeted by a 64-bit system bus access, or a misaligned access which crosses a 32-bit boundary. No other bus-sizing access support is provided.

The AHB to IP bridge is the interface between the AHB and on-chip IPS peripherals, which are sub-blocks containing readable/writable control and status registers.

The AHB master reads and writes these registers through the AIPSTZ. The bridge generates block enables, the block address, transfer attributes, byte enables and write data as inputs to the IPS peripherals. The bridge captures read data from the IPS interface and drives it on the AHB.

Each bridge that connects to the IPS (or peripherals) are referred as AIPS. The chip has several separate AIPS modules, and peripherals are grouped and assigned under each AIPS block. The list of peripherals are indicated as n-1, ... and n-x for AIPS-1, ... and AIPS-x respectively.
AIPS occupies a 1-Mbyte portion of the address space. The register maps of the IPS peripherals are located on 16-Kbyte boundaries. Each IPS peripheral is allocated one 16-Kbyte block of the memory map, and is activated by one of the block enables from the bridge. Up to thirty-two 16-Kbyte external IPS peripherals may be implemented, occupying contiguous blocks of 16-Kbytes. Two global external IPS block enables are available for the remaining address space to allow for customization and expansion of addressed peripheral devices. In addition, a single "non-global" block enable is also asserted whenever any of the thirty-two non-global block enables is asserted.

The bridge is responsible for indicating to IPS peripherals if an access is in supervisor or user mode. It may block user mode accesses to certain IPS peripherals or it may allow the individual IPS peripherals to determine if user mode accesses are allowed. In addition, peripherals may be designated as write-protected.

The bridge supports the notion of "trusted" masters for security purposes. Masters may be individually designated as trusted for reads, trusted for writes, or trusted for both reads and writes, as well as being forced to look as though all accesses from a master are in user-mode privilege level. Refer to AIPSTZ Memory Map/Register Definition for more information.

The AIPSTZ prevents access to a peripheral if the transaction originated from a source from a resource domain that has been explicitly omitted. Resource domains are assigned in the RDC submodule. Please refer to the RDC chapter for programming details.

All peripheral devices are expected to only require aligned accesses equal to or smaller in size than the peripheral size. An exception to this rule is supported for 32-bit peripherals to allow memory to be placed on the IPS.

### 32.5 Access Protections

The AIPSTZ bridge provides programmable access protections for both masters and peripherals. It allows the privilege level of a master to be overridden, forcing it to user-mode privilege, and allows masters to be designated as trusted or untrusted.

Peripherals may require supervisor privilege level for access, may restrict access to a trusted master only, and may be write-protected. IP bus peripherals are subject to access control policies set in both CSU registers and AIPSTZ registers. An access is blocked if it is denied by either policy.

Masters and peripherals are assigned to one or more resource domains in the RDC submodule (see the RDC chapter for details). Depending on RDC programming, masters transactions through the AIPSTZ may or may not be allowed access to peripherals in different resource domains.
32.6 Access Support

Aligned 64-bit accesses, aligned and misaligned word and half word accesses, as well as byte accesses are supported for 32-bit peripherals. Misaligned accesses are supported to allow memory to be placed on the IPS.

Peripheral registers must not be misaligned, although no explicit checking is performed by the AIPS bridge. The bridge will perform two IPS transfers for 64-bit accesses, word accesses with byte offsets of 1, 2, or 3, and for half word accesses with a byte offset of 3. All other accesses will be performed with a single IPS transfer.

Only aligned half word and byte accesses are supported for 16-bit peripherals. All other accesses types are unsupported, and results of such accesses are undefined. They are not terminated with an error response.

Only byte accesses are supported for 8-bit peripherals. All other accesses types are unsupported, and results of such accesses are undefined. They are not terminated with an error response.

32.7 Initialization Information

The AIPS bridge should be programmed before use.

The following registers should be initialized: The Master Privilege Registers (AIPSTZ_MPRs), the Peripheral Access Control registers (AIPSTZ_PACRs), and the Off-platform Peripheral Access Control registers (AIPSTZ_OPACRs) described in AIPSTZ Memory Map/Register Definition.

32.7.1 Security Block

The AIPSTZ contains a security block that is connected to each off-platform peripheral. This block filters accesses based on write/read, non-secure, and supervisor signals.

Each peripheral can be individually configured to allow or deny each of the following transactions as described in the table below:

<table>
<thead>
<tr>
<th>Config Bit</th>
<th>Write</th>
<th>Non-Secure</th>
<th>Supervisor</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Secure User Read</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 32-3. Peripheral Access Configuration options (continued)

<table>
<thead>
<tr>
<th>Config Bit</th>
<th>Write</th>
<th>Non-Secure</th>
<th>Supervisor</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Secure Supervisor Read</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Non-Secure User Read</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Non-Secure Supervisor Read</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Secure User Write</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Secure Supervisor Write</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Non-Secure User Write</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Non-Secure Supervisor Write</td>
</tr>
</tbody>
</table>

Each peripheral has a security configuration (sec_config_X) input for determining whether to allow or deny a given access type. These are 8-bit vectors, with each bit corresponding to one of the transactions above as listed in the Config Bit column of Table 32-3. If the bit is asserted (1'b1), the transaction is allowed. If the bit is negated (1'b0), the transaction is not allowed.

For example, if peripheral 0 is configured as follows:

```
sec_config_0 [7:0] = 8'b0011_0011
```

This peripheral can only be accessed by secure transactions. Bits 0, 1, 4, and 5 are asserted and these bits refer to the four types of secure transactions. If an insecure transaction is attempted to this peripheral, it will result in an error.

Eight bits per peripheral across an entire system can result in a large number of configuration bits that must be assigned and controlled, most likely in a series of registers in another block. To reduce the number of register bits required predefined sets of security profiles can be defined and encapsulated in an external security translation block. The table below describes one set of security profiles that has been proposed for use with the AIPSTZ.

<table>
<thead>
<tr>
<th>CSU_SEC_LEVEL</th>
<th>Non-Secure User</th>
<th>Non-Secure Supervisor</th>
<th>Secure User</th>
<th>Secure Supervisor</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>RD+WR</td>
<td>RD+WR</td>
<td>RD+WR</td>
<td>RD+WR</td>
</tr>
<tr>
<td>1</td>
<td>NOT ALLOWED</td>
<td>RD+WR</td>
<td>RD+WR</td>
<td>RD+WR</td>
</tr>
<tr>
<td>2</td>
<td>Read Only</td>
<td>Read Only</td>
<td>RD+WR</td>
<td>RD+WR</td>
</tr>
<tr>
<td>3</td>
<td>NOT ALLOWED</td>
<td>Read Only</td>
<td>RD+WR</td>
<td>RD+WR</td>
</tr>
<tr>
<td>4</td>
<td>NOT ALLOWED</td>
<td>NOT ALLOWED</td>
<td>RD+WR</td>
<td>RD+WR</td>
</tr>
<tr>
<td>5</td>
<td>NOT ALLOWED</td>
<td>NOT ALLOWED</td>
<td>NOT ALLOWED</td>
<td>RD+WR</td>
</tr>
<tr>
<td>6</td>
<td>NOT ALLOWED</td>
<td>NOT ALLOWED</td>
<td>Read Only</td>
<td>Read Only</td>
</tr>
<tr>
<td>7</td>
<td>NOT ALLOWED</td>
<td>NOT ALLOWED</td>
<td>NOT ALLOWED</td>
<td>NOT ALLOWED</td>
</tr>
</tbody>
</table>
Information regarding CSU is provided in the Security Reference Manual. Contact your NXP representative for information about obtaining this document.

A 3-bit input, 8-bit output translation block can be used such that only three register bits are required to set the security profile and the translation block will drive the correct 8-bit configuration vector. Each peripheral connected to the AIPSTZ would require this translation block. The top level AIPSTZ has this three bit input line `csu_sec_level[2:0]' corresponding to each peripheral X.

### 32.8 AIPSTZ Memory Map/Register Definition

The memory map for the AIPS SW-visible registers is shown in the table below. The MPROT and OPACR fields are 4 bits in width. Some bits may be reserved depending on device.

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>4007_C000</td>
<td>Master Privileged Registers (AIPSTZ1_MPR)</td>
<td>32</td>
<td>R/W</td>
<td>7700_0000h</td>
<td>32.8.1/1779</td>
</tr>
<tr>
<td>4007_C040</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ1_OPACR)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.2/1782</td>
</tr>
<tr>
<td>4007_C044</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ1_OPACR1)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.3/1785</td>
</tr>
<tr>
<td>4007_C048</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ1_OPACR2)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.4/1788</td>
</tr>
<tr>
<td>4007_C04C</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ1_OPACR3)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.5/1791</td>
</tr>
<tr>
<td>4007_C050</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ1_OPACR4)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.6/1794</td>
</tr>
<tr>
<td>4017_C000</td>
<td>Master Privileged Registers (AIPSTZ2_MPR)</td>
<td>32</td>
<td>R/W</td>
<td>7700_0000h</td>
<td>32.8.1/1779</td>
</tr>
<tr>
<td>4017_C040</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ2_OPACR)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.2/1782</td>
</tr>
<tr>
<td>4017_C044</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ2_OPACR1)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.3/1785</td>
</tr>
<tr>
<td>4017_C048</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ2_OPACR2)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.4/1788</td>
</tr>
<tr>
<td>4017_C04C</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ2_OPACR3)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.5/1791</td>
</tr>
<tr>
<td>4017_C050</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ2_OPACR4)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.6/1794</td>
</tr>
<tr>
<td>4027_C000</td>
<td>Master Privileged Registers (AIPSTZ3_MPR)</td>
<td>32</td>
<td>R/W</td>
<td>7700_0000h</td>
<td>32.8.1/1779</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### AIPSTZ memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>4027_C040</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ3_OPACR)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.2/1782</td>
</tr>
<tr>
<td>4027_C044</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ3_OPACR1)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.3/1785</td>
</tr>
<tr>
<td>4027_C048</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ3_OPACR2)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.4/1788</td>
</tr>
<tr>
<td>4027_C04C</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ3_OPACR3)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.5/1791</td>
</tr>
<tr>
<td>4027_C050</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ3_OPACR4)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.6/1794</td>
</tr>
<tr>
<td>4037_C000</td>
<td>Master Privileged Registers (AIPSTZ4_MPR)</td>
<td>32</td>
<td>R/W</td>
<td>7700_0000h</td>
<td>32.8.1/1779</td>
</tr>
<tr>
<td>4037_C040</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ4_OPACR)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.2/1782</td>
</tr>
<tr>
<td>4037_C044</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ4_OPACR1)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.3/1785</td>
</tr>
<tr>
<td>4037_C048</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ4_OPACR2)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.4/1788</td>
</tr>
<tr>
<td>4037_C04C</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ4_OPACR3)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.5/1791</td>
</tr>
<tr>
<td>4037_C050</td>
<td>Off-Platform Peripheral Access Control Registers (AIPSTZ4_OPACR4)</td>
<td>32</td>
<td>R/W</td>
<td>4444_4444h</td>
<td>32.8.6/1794</td>
</tr>
</tbody>
</table>

#### 32.8.1 Master Privileged Registers (AIPSTZx_MPR)

Each AIPSTZ_MPR specifies 16 4-bit fields defining the access privilege level associated with a bus master in the platform, as well as specifying whether write accesses from this master are bufferable shown in Table 32-5

The registers provide one field per bus master, where field 15 corresponds to master 15, field 14 to master 14,... field 0 to master 0 (typically the processor core). The master index allocation is shown in the table below.

**Table 32-5. MPROT Field**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>MBW</td>
<td>Master Buffer Writes - This bit determines whether the AIPSTZ is enabled to buffer writes from this master.</td>
</tr>
<tr>
<td>2</td>
<td>MTR</td>
<td>Master Trusted for Reads - This bit determines whether the master is trusted for read accesses.</td>
</tr>
<tr>
<td>1</td>
<td>MTW</td>
<td>Master Trusted for Writes - This bit determines whether the master is trusted for write accesses.</td>
</tr>
<tr>
<td>0</td>
<td>MPL</td>
<td>Master Privilege Level - This bit determines how the privilege level of the master is determined.</td>
</tr>
</tbody>
</table>
NOTE
The reset value is set to 0000_0000_7700_0000, which makes master 0 and master 1 (Arm CORE) the trusted masters. Trusted software can change the settings after reset.

Table 32-6. Master Index Allocation

<table>
<thead>
<tr>
<th>Master Index</th>
<th>Master Name</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>Master 0</td>
<td>Arm core</td>
<td></td>
</tr>
<tr>
<td>Master 1</td>
<td>eDMA</td>
<td></td>
</tr>
<tr>
<td>Master 2</td>
<td>DCP</td>
<td></td>
</tr>
<tr>
<td>Master 3</td>
<td>Others</td>
<td>Share the same number allocation.</td>
</tr>
<tr>
<td>Master 4-15</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

Address: Base address + 0h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>MPROT0</th>
<th>MPROT1</th>
<th>MPROT2</th>
<th>MPROT3</th>
<th>Reserved</th>
<th>MPROT5</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

AIPSTZx_MPR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Master 0 Privilege, Buffer, Read, Write Control</td>
</tr>
<tr>
<td>MPROT0</td>
<td>xxx0  MPL0 — Accesses from this master are forced to user-mode (ips_supervisor_access is forced to zero) regardless of the hprot[1] access attribute.</td>
</tr>
<tr>
<td></td>
<td>xxx1  MPL1 — Accesses from this master are not forced to user-mode. The hprot[1] access attribute is used directly to determine ips_supervisor_access.</td>
</tr>
<tr>
<td></td>
<td>xx0x  MTW0 — This master is not trusted for write accesses.</td>
</tr>
<tr>
<td></td>
<td>xx1x  MTW1 — This master is trusted for write accesses.</td>
</tr>
<tr>
<td></td>
<td>x0xx  MTR0 — This master is not trusted for read accesses.</td>
</tr>
<tr>
<td></td>
<td>x1xx  MTR1 — This master is trusted for read accesses.</td>
</tr>
<tr>
<td></td>
<td>0xxx  MBW0 — Write accesses from this master are not bufferable</td>
</tr>
<tr>
<td></td>
<td>1xxx  MBW1 — Write accesses from this master are allowed to be buffered</td>
</tr>
<tr>
<td>27–24</td>
<td>Master 1 Privilege, Buffer, Read, Write Control</td>
</tr>
<tr>
<td>MPROT1</td>
<td>xxx0  MPL0 — Accesses from this master are forced to user-mode (ips_supervisor_access is forced to zero) regardless of the hprot[1] access attribute.</td>
</tr>
<tr>
<td></td>
<td>xxx1  MPL1 — Accesses from this master are not forced to user-mode. The hprot[1] access attribute is used directly to determine ips_supervisor_access.</td>
</tr>
<tr>
<td></td>
<td>xx0x  MTW0 — This master is not trusted for write accesses.</td>
</tr>
<tr>
<td></td>
<td>xx1x  MTW1 — This master is trusted for write accesses.</td>
</tr>
<tr>
<td></td>
<td>x0xx  MTR0 — This master is not trusted for read accesses.</td>
</tr>
<tr>
<td></td>
<td>x1xx  MTR1 — This master is trusted for read accesses.</td>
</tr>
<tr>
<td></td>
<td>0xxx  MBW0 — Write accesses from this master are not bufferable</td>
</tr>
<tr>
<td></td>
<td>1xxx  MBW1 — Write accesses from this master are allowed to be buffered</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### AIPSTZx_MPR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>23–20 MPROT2</td>
<td>Master 2 Privilege, Buffer, Read, Write Control</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>MPL0</strong> — Accesses from this master are forced to user-mode (ips_supervisor_access is forced to zero) regardless of the hprot[1] access attribute.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>MPL1</strong> — Accesses from this master are not forced to user-mode. The hprot[1] access attribute is used directly to determine ips_supervisor_access.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>MTW0</strong> — This master is not trusted for write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>MTW1</strong> — This master is trusted for write accesses.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>MTR0</strong> — This master is not trusted for read accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>MTR1</strong> — This master is trusted for read accesses.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>MBW0</strong> — Write accesses from this master are not bufferable</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>MBW1</strong> — Write accesses from this master are allowed to be buffered</td>
</tr>
<tr>
<td>19–16 MPROT3</td>
<td>Master 3 Privilege, Buffer, Read, Write Control.</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>MPL0</strong> — Accesses from this master are forced to user-mode (ips_supervisor_access is forced to zero) regardless of the hprot[1] access attribute.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>MPL1</strong> — Accesses from this master are not forced to user-mode. The hprot[1] access attribute is used directly to determine ips_supervisor_access.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>MTW0</strong> — This master is not trusted for write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>MTW1</strong> — This master is trusted for write accesses.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>MTR0</strong> — This master is not trusted for read accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>MTR1</strong> — This master is trusted for read accesses.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>MBW0</strong> — Write accesses from this master are not bufferable</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>MBW1</strong> — Write accesses from this master are allowed to be buffered</td>
</tr>
<tr>
<td>15–12</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
<tr>
<td>11–8 MPROT5</td>
<td>Master 5 Privilege, Buffer, Read, Write Control.</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>MPL0</strong> — Accesses from this master are forced to user-mode (ips_supervisor_access is forced to zero) regardless of the hprot[1] access attribute.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>MPL1</strong> — Accesses from this master are not forced to user-mode. The hprot[1] access attribute is used directly to determine ips_supervisor_access.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>MTW0</strong> — This master is not trusted for write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>MTW1</strong> — This master is trusted for write accesses.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>MTR0</strong> — This master is not trusted for read accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>MTR1</strong> — This master is trusted for read accesses.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>MBW0</strong> — Write accesses from this master are not bufferable</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>MBW1</strong> — Write accesses from this master are allowed to be buffered</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
32.8.2 Off-Platform Peripheral Access Control Registers (AIPSTZx_OPACR)

Each of the off-platform peripherals have an Off-platform Peripheral Access Control Register (AIPSTZ_OPACR) which defines the access levels supported by the given block.

Each AIPSTZ_OPACR has the following format shown in Table 32-7

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 3   | BW    | **Buffer Writes** - This bit determines whether write accesses to this peripheral are allowed to be buffered.  
1. Buffered writes are not available for AIPSTZ. This bit should be set to '0'. |
| 2   | SP    | **Supervisor Protect** - This bit determines whether the peripheral requires supervisor privilege level for access. |
| 1   | WP    | **Write Protect** - This bit determines whether the peripheral allows write accesses. |
| 0   | TP    | **Trusted Protect** - This bit determines whether the peripheral allows accesses from an untrusted master. |

Address: Base address + 40h offset

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
<th>OPAC0</th>
<th>OPAC1</th>
<th>OPAC2</th>
<th>OPAC3</th>
<th>OPAC4</th>
<th>OPAC5</th>
<th>OPAC6</th>
<th>OPAC7</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**AIPSTZx_OPACR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28 OPAC0</td>
<td>Off-platform Peripheral Access Control 0</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be bufferable by the AIPSTZ.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

**23–20**
**OPAC2**

Off-platform Peripheral Access Control 2

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

**19–16**
**OPAC3**

Off-platform Peripheral Access Control 3

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

**15–12**
**OPAC4**

Off-platform Peripheral Access Control 4

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### AIPSTZx_OPACR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

11–8 OPAC5

**Off-platform Peripheral Access Control 5**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

7–4 OPAC6

**Off-platform Peripheral Access Control 6**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

OPAC7

**Off-platform Peripheral Access Control 7**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
AIPSTZx_OPACR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx1</td>
<td>TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td>WP0 — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td>WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td>SP0 — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td>SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td>BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td>BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

32.8.3 Off-Platform Peripheral Access Control Registers (AIPSTZx_OPACR1)

Each of the off-platform peripherals have an Off-platform Peripheral Access Control Register (AIPSTZ_OPACR) which defines the access levels supported by the given block.

Each AIPSTZ_OPACR has the following format shown in Table 32-7

Address: Base address + 44h offset

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>Bit 30</th>
<th>Bit 29</th>
<th>Bit 28</th>
<th>Bit 27</th>
<th>Bit 26</th>
<th>Bit 25</th>
<th>Bit 24</th>
<th>Bit 23</th>
<th>Bit 22</th>
<th>Bit 21</th>
<th>Bit 20</th>
<th>Bit 19</th>
<th>Bit 18</th>
<th>Bit 17</th>
<th>Bit 16</th>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>OPAC8</td>
<td>OPAC9</td>
<td>OPAC10</td>
<td>OPAC11</td>
<td>OPAC12</td>
<td>OPAC13</td>
<td>OPAC14</td>
<td>OPAC15</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

AIPSTZx_OPACR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Off-platform Peripheral Access Control 8</td>
</tr>
<tr>
<td>xxx0</td>
<td>TP0 — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td>TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td>WP0 — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td>WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td>SP0 — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td>SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### AIPSTZ\textsubscript{x} OPACR1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

#### 27–24

**OPAC9**

| xxx0 | **TP0** — Accesses from an untrusted master are allowed. |
| xxx1 | **TP1** — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| xx0x | **WP0** — This peripheral allows write accesses. |
| xx1x | **WP1** — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| x0xx | **SP0** — This peripheral does not require supervisor privilege level for accesses. |
| x1xx | **SP1** — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |

| 0xxx  | **BW0** — Write accesses to this peripheral are not bufferable by the AIPSTZ. |
| 1xxx  | **BW1** — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |

#### 23–20

**OPAC10**

| xxx0 | **TP0** — Accesses from an untrusted master are allowed. |
| xxx1 | **TP1** — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| xx0x | **WP0** — This peripheral allows write accesses. |
| xx1x | **WP1** — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| x0xx | **SP0** — This peripheral does not require supervisor privilege level for accesses. |
| x1xx | **SP1** — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |

| 0xxx  | **BW0** — Write accesses to this peripheral are not bufferable by the AIPSTZ. |
| 1xxx  | **BW1** — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |

#### 19–16

**OPAC11**

| xxx0 | **TP0** — Accesses from an untrusted master are allowed. |
| xxx1 | **TP1** — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| xx0x | **WP0** — This peripheral allows write accesses. |
| xx1x | **WP1** — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| x0xx | **SP0** — This peripheral does not require supervisor privilege level for accesses. |
| x1xx | **SP1** — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |

| 0xxx  | **BW0** — Write accesses to this peripheral are not bufferable by the AIPSTZ. |
| 1xxx  | **BW1** — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |

Table continues on the next page...
### AIPSTZx OPACR1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15–12 OPAC12 | Off-platform Peripheral Access Control 12  
| xxx0 | TP0 — Accesses from an untrusted master are allowed.  
| xxx1 | TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| xx0x | WP0 — This peripheral allows write accesses.  
| xx1x | WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| x0xx | SP0 — This peripheral does not require supervisor privilege level for accesses.  
| x1xx | SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| 0xxx | BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.  
| 1xxx | BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |
| 11–8 OPAC13 | Off-platform Peripheral Access Control 13  
| xxx0 | TP0 — Accesses from an untrusted master are allowed.  
| xxx1 | TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| xx0x | WP0 — This peripheral allows write accesses.  
| xx1x | WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| x0xx | SP0 — This peripheral does not require supervisor privilege level for accesses.  
| x1xx | SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| 0xxx | BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.  
| 1xxx | BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |
| 7–4 OPAC14 | Off-platform Peripheral Access Control 14  
| xxx0 | TP0 — Accesses from an untrusted master are allowed.  
| xxx1 | TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| xx0x | WP0 — This peripheral allows write accesses.  
| xx1x | WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| x0xx | SP0 — This peripheral does not require supervisor privilege level for accesses.  
| x1xx | SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.  
| 0xxx | BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.  
| 1xxx | BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |

Table continues on the next page...
32.8.4 Off-Platform Peripheral Access Control Registers (AIPSTZx_OPACR2)

Each of the off-platform peripherals have an Off-platform Peripheral Access Control Register (AIPSTZ_OPACR) which defines the access levels supported by the given block.

Each AIPSTZ_OPACR has the following format shown in Table 32-7

Address: Base address + 48h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>OPAC16</th>
<th>OPAC17</th>
<th>OPAC18</th>
<th>OPAC19</th>
<th>OPAC20</th>
<th>OPAC21</th>
<th>OPAC22</th>
<th>OPAC23</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>31</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

AIPSTZx_OPACR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Off-platform Peripheral Access Control 16</td>
</tr>
<tr>
<td>x00</td>
<td>TP0 — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>x01</td>
<td>TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x00</td>
<td>WP0 — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>x01</td>
<td>WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x00</td>
<td>SP0 — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x01</td>
<td>SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0xxx</td>
<td>BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td>BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>27–24</td>
<td>Off-platform Peripheral Access Control 17</td>
</tr>
<tr>
<td>OPAC17</td>
<td></td>
</tr>
<tr>
<td>xxx0</td>
<td>TP0 — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td>TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td>WP0 — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td>WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td>SP0 — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td>SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td>BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td>BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>23–20</td>
<td>Off-platform Peripheral Access Control 18</td>
</tr>
<tr>
<td>OPAC18</td>
<td></td>
</tr>
<tr>
<td>xxx0</td>
<td>TP0 — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td>TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td>WP0 — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td>WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td>SP0 — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td>SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td>BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td>BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>19–16</td>
<td>Off-platform Peripheral Access Control 19</td>
</tr>
<tr>
<td>OPAC19</td>
<td></td>
</tr>
<tr>
<td>xxx0</td>
<td>TP0 — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td>TP1 — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td>WP0 — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td>WP1 — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td>SP0 — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td>SP1 — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td>BW0 — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td>BW1 — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### AIPSTZx_OPACR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–12</td>
<td>Off-platform Peripheral Access Control 20</td>
</tr>
<tr>
<td>OPAC20</td>
<td></td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

| 11–8  | Off-platform Peripheral Access Control 21 |
| OPAC21 | |
| xxx0  | **TP0** — Accesses from an untrusted master are allowed. |
| xxx1  | **TP1** — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| xx0x  | **WP0** — This peripheral allows write accesses. |
| xx1x  | **WP1** — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| x0xx  | **SP0** — This peripheral does not require supervisor privilege level for accesses. |
| x1xx  | **SP1** — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| 0xxx  | **BW0** — Write accesses to this peripheral are not bufferable by the AIPSTZ. |
| 1xxx  | **BW1** — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |

| 7–4   | Off-platform Peripheral Access Control 22 |
| OPAC22 | |
| xxx0  | **TP0** — Accesses from an untrusted master are allowed. |
| xxx1  | **TP1** — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| xx0x  | **WP0** — This peripheral allows write accesses. |
| xx1x  | **WP1** — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| x0xx  | **SP0** — This peripheral does not require supervisor privilege level for accesses. |
| x1xx  | **SP1** — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus. |
| 0xxx  | **BW0** — Write accesses to this peripheral are not bufferable by the AIPSTZ. |
| 1xxx  | **BW1** — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |

| OPAC23 | Off-platform Peripheral Access Control 23 |

Table continues on the next page...
### AIPSTZx_OPACR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

### 32.8.5 Off-Platform Peripheral Access Control Registers (AIPSTZx_OPACR3)

Each of the off-platform peripherals have an Off-platform Peripheral Access Control Register (AIPSTZ_OPACR) which defines the access levels supported by the given block.

Each AIPSTZ_OPACR has the following format shown in Table 32-7

Address: Base address + 4Ch offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R  | W  | OPAC24 | OPAC25 | OPAC26 | OPAC27 | OPAC28 | OPAC29 | OPAC30 | OPAC31|
| Reset | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |

#### AIPSTZx_OPACR3 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Off-platform Peripheral Access Control 24</td>
</tr>
<tr>
<td>OPAC24</td>
<td></td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### AIPSTZx_OPACR3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>27–24</td>
<td><strong>OPAC25</strong> Off-platform Peripheral Access Control 25</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>23–20</td>
<td><strong>OPAC26</strong> Off-platform Peripheral Access Control 26</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>19–16</td>
<td><strong>OPAC27</strong> Off-platform Peripheral Access Control 27</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## AIPSTZx_OPACR3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–12 OPAC28</td>
<td>Off-platform Peripheral Access Control 28</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>11–8 OPAC29</td>
<td>Off-platform Peripheral Access Control 29</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>7–4 OPAC30</td>
<td>Off-platform Peripheral Access Control 30</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>OPAC31</td>
<td>Off-platform Peripheral Access Control 31</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### AIPSTZx_OPACR3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
</tbody>
</table>

0xxx  | **BW0** — Write accesses to this peripheral are not bufferable by the AIPSTZ. |
1xxx  | **BW1** — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ. |

#### 32.8.6 Off-Platform Peripheral Access Control Registers (AIPSTZx_OPACR4)

Each of the off-platform peripherals have an Off-platform Peripheral Access Control Register (AIPSTZ_OPACR) which defines the access levels supported by the given block.

Each AIPSTZ_OPACR has the following format shown in Table 32-7

Address: Base address + 50h offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | OPAC32 | OPAC33 | Reserved |
| W   |        |        |           |

| Reset | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |

### AIPSTZx_OPACR4 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Off-platform Peripheral Access Control 32</td>
</tr>
<tr>
<td>31–29</td>
<td>OPAC32</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>x0xx</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### AIPSTZx_OPACR4 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
<tr>
<td>27–24</td>
<td><strong>OPAC33</strong> — Off-platform Peripheral Access Control 33</td>
</tr>
<tr>
<td>xxx0</td>
<td><strong>TP0</strong> — Accesses from an untrusted master are allowed.</td>
</tr>
<tr>
<td>xxx1</td>
<td><strong>TP1</strong> — Accesses from an untrusted master are not allowed. If an access is attempted by an untrusted master, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>WP0</strong> — This peripheral allows write accesses.</td>
</tr>
<tr>
<td>xx1x</td>
<td><strong>WP1</strong> — This peripheral is write protected. If a write access is attempted, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>xx0x</td>
<td><strong>SP0</strong> — This peripheral does not require supervisor privilege level for accesses.</td>
</tr>
<tr>
<td>x1xx</td>
<td><strong>SP1</strong> — This peripheral requires supervisor privilege level for accesses. The master privilege level must indicate supervisor via the hprot[1] access attribute, and the MPROTx[MPL] control bit for the master must be set. If not, the access is terminated with an error response and no peripheral access is initiated on the IPS bus.</td>
</tr>
<tr>
<td>0xxx</td>
<td><strong>BW0</strong> — Write accesses to this peripheral are not bufferable by the AIPSTZ.</td>
</tr>
<tr>
<td>1xxx</td>
<td><strong>BW1</strong> — Write accesses to this peripheral are allowed to be buffered by the AIPSTZ.</td>
</tr>
</tbody>
</table>

- **This field is reserved.**
  - **Reserved**
Chapter 33
Display and Camera Overview

33.1 Display and Camera Overview

The following modules are a part of the Display and Camera system:

- LCD Interface (LCDIF): 24-bit parallel RGB LCD interface
- PXP pixel pipeline: 2D graphics and pixel/image processing engine
- Camera Sensor Interface (CSI): up to 24-bit parallel interface for image sensor

The following figure shows the high-level integration scheme of the chip display and camera system.

![Block Diagram](image-url)
33.1.1 PiXel Processing Pipeline

The pixel processing pipeline is used to perform image processing on image/video buffers before sending to an LCD display.

The main features of PXP include:

- Multiple input/output format support, including YUV/RGB/Grayscale
- Supports both RGB/YUV scaling
- Supports overlay with Alpha blending
- Supports Rotation of 0, 90, 180, and 270 degrees in conjunction with vertical and horizontal flip options

33.1.2 LCD Interface

The LCDIF is a general purpose display controller that is used to drive a wide range of display devices. These displays can vary in size and capability. Many of these displays have had an asynchronous parallel MPU interface for command and data transfer to an integrated frame buffer. There are other popular displays that support moving pictures and require the RGB interface mode (called DOTCLK interface in this document) or the VSYNC mode for high-speed data transfers.

The block has several major features:

- Bus master interface to source frame buffer data for display refresh and a DMA interface to manage input data transfers from the LCD requiring minimal CPU overhead.
- 8/16/18/24 bit LCD data bus support available depending on I/O mux options.
- Programmable timing and parameters for MPU, VSYNC and DOTCLK LCD interfaces to support a wide variety of displays.

33.1.3 CMOS Sensor Interface

The CSI enables the chip to connect directly to external CMOS image sensors. CMOS image sensors are separated into two classes, dumb and smart. Dumb sensors are those that support only traditional sensor timing (Vertical SYNC and Horizontal SYNC) and
output only Bayer and statistics data, while smart sensors support CCIR656 video decoder formats and perform additional processing of the image (for example, image compression, image pre-filtering, and various data output formats).

The capabilities of the CSI include:

- Configurable interface logic to support most commonly available CMOS sensors.
- Support for CCIR656 video interface as well as traditional sensor interface.
- 8-bit data port for YCC, YUV, or RGB data input.
- 8-bit/10-bit/16-bit data port for Bayer data input.
- Full control of 8-bit/pixel, 10-bit/pixel or 16-bit/pixel data format to 64-bit receive FIFO packing.
- Embedded DMA controllers to transfer data from receive FIFO or statistic FIFO through AHB bus.
- Support for double buffering two frames in the external memory.
- Single interrupt source to interrupt controller from maskable interrupt sources:
  - Start of Frame
  - End of Frame
  - Change of Field
  - FIFO full
  - FIFO overrun
  - DMA transfer done
  - CCIR error
  - AHB bus response error
- Configurable master clock frequency output to sensor.
- Statistic data generation for Auto Exposure (AE) and Auto White Balance (AWB) control of the camera (only for Bayer data and 8-bit/pixel format).
Chapter 34
CMOS Sensor Interface (CSI)

34.1 Chip-specific CSI information

Table 34-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

34.2 Overview

This chapter presents the CMOS Sensor Interface (CSI) architecture, operation principles, and programming model.

The CSI enables the chip to connect directly to external CMOS image sensors. CMOS image sensors are separated into two classes, dumb and smart. Dumb sensors are those that support only traditional sensor timing (Vertical SYNC and Horizontal SYNC) and output only Bayer and statistics data, while smart sensors support CCIR656 video decoder formats and perform additional processing of the image (for example, image compression, image pre-filtering, and various data output formats).

The capabilities of the CSI include:

- Configurable interface logic to support most commonly available CMOS sensors.
- Support for CCIR656 video interface as well as traditional sensor interface.
• 8-bit / 10-bit / 16-bit data port for Bayer data input.
• Full control of 8-bit/pixel, 10-bit/pixel or 16-bit / pixel data format to 64-bit receive FIFO packing.
• Receive FIFO overrun protection mechanism.
• Embedded DMA controllers to transfer data from receive FIFO or statistic FIFO through AHB bus.
• Support 2D DMA transfer from the receive FIFO to the frame buffers in the external memory.
• Support double bufferring two frames in the external memory.
• Single interrupt source to interrupt controller from maskable interrupt sources: Start of Frame, End of Frame, Change of Field, FIFO full, FIFO overrun, DMA transfer done, CCIR error and AHB bus response error.
• Configurable master clock frequency output to sensor.
• Statistic data generation for Auto Exposure (AE) and Auto White Balance (AWB) control of the camera (only for Bayer data and 8-bit/pixel format).

### 34.3 External Signals

The table below describes the external signals for the CSI. The external signals are tied between the CSI module and an external CMOS sensor.

#### Table 34-2. CSI External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>CSI_DATA00</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_10</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA01</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_11</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA02</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_15</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_11</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>CSI_DATA03</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_14</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_10</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>CSI_DATA04</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_13</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_09</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>CSI_DATA05</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_12</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_08</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>CSI_DATA06</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_11</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_07</td>
<td>ALT4</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>CSI_DATA07</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_10</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_06</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA08</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_09</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_05</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA09</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_AD_B1_08</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_04</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA10</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_09</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA11</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_08</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA12</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_07</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA13</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_06</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA14</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_05</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA15</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_B1_04</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA16</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_EMC_37</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA17</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_EMC_36</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA18</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_EMC_35</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA19</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_EMC_34</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA20</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_EMC_33</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA21</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_EMC_32</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>CSI_DATA22</td>
<td>Data Sensor Signal, part of 16-bit Sensor Data Bus (Bayer, YUV, YCrCb, RGB)</td>
<td>GPIO_EMC_31</td>
<td>ALT4</td>
<td>I</td>
</tr>
</tbody>
</table>
### 34.4 Clocks

The following table describes the clock sources for CSI. Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>csi_hclk</td>
<td>ipg_clk_root</td>
<td>Module clock</td>
</tr>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
<tr>
<td>ipg_clk_s_raw</td>
<td>ipg_clk_root</td>
<td>Peripheral raw data clock</td>
</tr>
</tbody>
</table>

### 34.5 Principles of Operation

The information found here describes the modes of operation of the sensor interface.

The CSI is designed to support generic sensor interface timing as well as CCIR656 video interface timing. Traditional CMOS sensors typically use VSYNC (SOF), HSYNC (BLANK), and PIXCLK signals to output Bayer or YUV data. Smart CMOS sensors, that
come with on-chip imaging processing, usually support video mode transfer. They use an embedded timing codec to replace the VSYNC and HSYNC signal. The timing codec is defined by the CCIR656 standard.

The CSI can support connection with the sensor as follows.

- To connect with one 8-bit sensor, the sensor data interface should connect to CSI_DATA[9:2].
- To connect with one 10-bit sensor, the sensor data interface should connect to CSI_DATA[9:0].
- To connect with one 16-bit sensor, the sensor data interface should connect to CSI_DATA[15:0].

Table 34.4. CSI input data format

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>TVdecode YCbCr 1 Cycle</th>
<th>RGB888 1 Cycle</th>
<th>RGB888/ YUV4444 3 Cycle</th>
<th>RGB666 1 Cycle</th>
<th>RGB565 1 Cycle</th>
<th>YCbCr422 1 Cycle</th>
<th>YCbCr422 2 Cycle</th>
<th>Generic 10 bit</th>
<th>CCIR656</th>
</tr>
</thead>
</table>

*Table continues on the next page...*
### Table 34-4. CSI input data format (continued)

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>TVdecode YCbCr 1 Cycle</th>
<th>RGB888 1 Cycle</th>
<th>RGB888/ YUV4444 3 Cycle</th>
<th>RGB666 1 Cycle</th>
<th>RGB565 1 Cycle</th>
<th>YCbCr422 1 Cycle</th>
<th>YCbCr422 2 Cycle</th>
<th>Generic 10 bit</th>
<th>CCIR656</th>
</tr>
</thead>
</table>

#### 34.5.1 Data Transfer with the Embedded DMA Controllers

The CSI has two embedded DMA controllers, one for the receive FIFO and the other for the statistic FIFO. It supports 2D DMA transfer from the receive FIFO to the frame buffers in the external memory and linear DMA transfer from the statistic FIFO.

To transfer data from the RxFIFO to the external memory, the user should set the start address in the frame buffer where the transferred data is stored, the parameters of the frame buffers, and the parameters of the image coming from the sensor. The user can have two frame buffers in the external memory. Each one will store a frame of image coming from the sensor. The embedded DMA controller will first write the frame buffer1 and then frame buffer2. These two frame buffers will be written by turns. The start address should be aligned in double words and set in the CSIDMASA-FB1 and CSIDMASA-FB2 registers. In the CSIFBUF_PARA register, the user should set the stride of the frame buffer to show how many double words to skip before starting to write the next row of the image. In the CSIIMAG_PARA register, the user should set the width and height of the image coming from the sensor. The RxFF_LEVEL and DMA_REQ_EN_RFF bits in CSICR3 registers also need to be set before the data transfer starts. When the number of the data in the RxFIFO reaches the trigger level, a DMA request will be sent to the embedded DMA controller and the data will be read out.
from the RxFIFO and written through AHB bus into the external frame buffers. The burst type of transfer can be INCR4, INCR8 and INCR16 by setting DMA_BURST_TYPE_RFF bits in CSICR2 register. After all data in an image frame are transferred, the DMA_TSF_DONE_FB1 or DMA_TSF_DONE_FB2 bit will be set in CSISR register and the interrupt can be triggered if the corresponding enable bit is set in CSICR1 register. The DMA_REFLASH_RFF bit in CSICR3 can be used to activate or restart the embedded DMA controller.

The RxFIFO has the overrun protection mechanism in case the RxFIFO is overrun during data transfer. If the RxFIFO is full and more data needs to be received during the data transfer, the RxFIFO will be overwritten continuously and all 128 words of data in the RxFIFO before overrun occurred will be discarded; the corresponding 128 words memory space in the frame buffer will keep the previous values.

To transfer data from the statistic FIFO to the external memory, the user should set the start address of the external memory where the transferred data is stored and the total transfer sizes. The start address and the transfer sizes are all aligned in double words and should be set in the CSIDMASA-STATFIFO and CSIDMATS-STATFIFO registers. The STATFF_LEVEL and DMA_REQ_EN_SFF bits in CSICR3 registers should also be set before the data transfer starts. When the number of the data in the STATFIFO reaches the trigger level, a dma request will be sent to the embedded DMA controller and the data will be read out from the STATFIFO and written through AHB bus into the external memory. The burst type of transfer can be INCR4, INCR8 and INCR16 by setting DMA_BURST_TYPE_SFF bits in CSICR2 register. After all expected data (defined by the total transfer sizes) are transferred, the DMA_TSF_DONE_SFF bit will be set in CSISR register and an interrupt can be triggered if the SFF_DMA_DONE_INTEN is enabled in CSICR1 register. The DMA_REFLASH_SFF bit in CSICR3 can be used to activate or re-start the embedded DMA controller.

### 34.5.2 Gated Clock Mode

VSYNC, HSYNC, and PIXCLK signals are used in gated clock mode.

A frame starts with an active edge on VSYNC, then HSYNC asserts and holds for the entire line. The Pixel clock is valid as long as HSYNC is asserted. Data is latched at the active edge of the valid pixel clocks. HSYNC deasserts at the end of line. Pixel clocks then become invalid and CSI stops receiving data from the stream. For the next line the HSYNC timing repeats. For the next frame the VSYNC timing repeats.
34.5.3 Non-Gated Clock Mode

In non-gated clock mode, only the VSYNC and PIXCLK signals are used; the HSYNC signal is ignored.

![Timing Diagram](image)

**Figure 34-1. Non-Gated Clock Mode Timing Diagram**

The overall timing of non-gated mode is the same as the gated-clock mode, except for the HSYNC signal. HSYNC signal is ignored by the CSI. All incoming pixel clocks are valid and cause data to be latched into RxFIFO. The PIXCLK signal is inactive (states low) until valid data is ready to be transmitted over the bus.

Figure 34-1 shows the timing of a typical sensor. Other sensors may have the slightly different timing from that shown. The CSI can be programmed to support rising/falling-edge triggered VSYNC, active-high/low HSYNC, and rising/falling-edge triggered PIXCLK.

34.5.4 CCIR656 Interlace Mode

In CCIR656 interlace mode, only the PIXCLK and CSI_DATA[9:2] signals are used. The start of frame and blank signals are replaced by a timing codec which is embedded in the data stream. Each active line starts with an Start of Active Video (SAV) code and ends with an End of Active Video (EAV) code. In some cases, digital blanking is inserted in between EAV and SAV code. The CSI decodes and filters out the timing-coding from the data stream, recovering VSYNC and HSYNC signals for internal use, such as statistical block control. Data is forwarded to the data receive and packing block in a sequential manner without reordering—that is, field 1 followed by field 2. The fields must be reordered in software to get back the original image.

Change of Field (COF) interrupt is triggered upon every field change. The interrupt service routine reads the status register to check for the current field.
According to the CCIR656 specification, the image must be in 625/50 PAL or 525/60 NTSC format. In addition, the image is interlaced into odd and even fields with vertical and horizontal blank data being filled into certain lines. Data must be in YCbCr422 format, each pixel contains 2 bytes, either Y + Cr or Y + Cb. These requirements are set for TV systems. The CSI module supports PAL and NTSC format only.

The following figure describes the frame structure in PAL system, showing vertical and horizontal blanking.

![Figure 34-2. CCIR656 Interlace Mode (PAL)](image)

The following figure describes the general timing for a single line, showing SAV and EAV.

![Figure 34-3. CCIR656 General Line Timing](image)

The coding tables recommended by the CCIR656 specification are shown below. It is used in the CCIR656 mode to decode the video stream. An interrupt is generated for SOF, which is decoded from the embedded timing codec.
### Table 34-5. Coding for SAV and EAV

<table>
<thead>
<tr>
<th>Data Bit Number</th>
<th>1st Byte</th>
<th>2nd Byte</th>
<th>3rd Byte</th>
<th>4th Byte</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 (MSB)</td>
<td>0xFF</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
<tr>
<td>6</td>
<td>0x1</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
<tr>
<td>5</td>
<td>0x1</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
<tr>
<td>4</td>
<td>0x1</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
<tr>
<td>3</td>
<td>0x1</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
<tr>
<td>2</td>
<td>0x1</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
<tr>
<td>1</td>
<td>0x1</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
<tr>
<td>0</td>
<td>0x1</td>
<td>0x00</td>
<td>0x00</td>
<td>0xXY</td>
</tr>
</tbody>
</table>

### Table 34-6. Codes with Protection bits for Error Detection/Correction

<table>
<thead>
<tr>
<th>F</th>
<th>V</th>
<th>H</th>
<th>P3</th>
<th>P2</th>
<th>P1</th>
<th>P0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

### Table 34-7. Representations by F-Bit

<table>
<thead>
<tr>
<th>F-Bit</th>
<th>Representations</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ODD FIELD (FIELD 1)</td>
</tr>
<tr>
<td>1</td>
<td>EVEN FIELD (FIELD 2)</td>
</tr>
</tbody>
</table>

### 34.5.5 CCIR656 Progressive Mode

For a CMOS camera system of VGA or CIF resolution, strict adherence to the interlace requirements stated in the CIR standard is not required.

The image is considered to have only 1 active field which is scanned in a progressive manner. This active field is regarded as field 1 and the F-bit in the timing codec is ignored by the decoder. Most sensors support CCIR timing in this mode (progressive) by default.

The following figure shows the typical flow of progressive mode.
An interrupt is generated for SOF but not for COF. In the general case, when SOF information is retrieved from the embedded coding, it is known as internal VSYNC mode. In other cases, when the VSYNC signal is provided by the sensor, it is known as external VSYNC mode. The CSI can be operated in internal or external VSYNC mode.

### 34.5.6 Error Correction for CCIR656 Coding

According to the algorithm for CCIR coding, protection bits in the SAV and EAV are encoded in the way that allows a 1-bit error to be corrected, or a 2-bit error to be detected by the decoder. This feature is supported by the interlace mode CCIR decoder in CSI.

For the 1-bit error case, users can select the error to be corrected automatically, or simply shown as a status flag instead. For the 2-bit error case, because the decoder is unable to make a correction, the error would be shown as a status flag only.

An interrupt can be generated upon the detection of an error. This signal can be enabled or disabled without affecting the operation of the status bit.

### 34.6 Interrupt Generation

The information found here describes CSI events that generate interrupts.
34.6.1 Start Of Frame Interrupt (SOF_INT)

The source of an SOF interrupt is dependent on the mode of operation.

In traditional mode, VSYNC signal is taken from sensor and SOF_INT is generated at the rising or falling edge (programmable) of VSYNC.

In CCIR interlace mode, the SOF interrupt information is retrieved from the embedded coding and SOF_INT is generated.

In CCIR progressive mode, there are two sources of an SOF interrupt:

- In **internal** VSYNC mode, SOF is retrieved from the embedded coding.
- In **external** VSYNC mode, VSYNC is taken from the sensor and SOF is generated at the rising edge of VSYNC.

34.6.2 End Of Frame Interrupt (EOF_INT)

An EOF interrupt is generated when the frame ends and the complete frame data in RXFIFO is read.

The EOF event triggering works with the RX count register (CSIRXCNT). Software sets the RX count register to the frame size (in words). The CSI RX logic then counts the number of pixel data being received and compares it with the RX count. If the preset value is reached, an EOF interrupt is generated and the data in the RXFIFO are read. If a SOF event is detected before this happens, the EOF interrupt is not generated.

34.6.3 Change Of Field Interrupt (COF_INT)

The Change of Field interrupt is only valid in CCIR Interlace mode. The COF interrupt is generated when the field toggles, either from field 1 to field 2, or field 2 to field 1.

Software should first check COF_INT bit in the CSI Status Register (CSISTAT) before checking that F1_INT or F2_INT is turned on.

In PAL systems, the field changes at the beginning of the frame and coincides with SOF. For the first field, a COF interrupt is not generated, only an SOF. The COF interrupt is generated for the second field.
34.6.4 CCIR Error Interrupt (ECC_INT)

The CCIR Error Interrupt is only valid for CCIR Interlace mode. An ECC interrupt is generated when an error is found on the SAV or EAV codes in the incoming stream. When this happens, the ECC_INT status bit is set.

34.6.5 RxFIFO Full Interrupt (RxFF_INT)

A RxFIFO full interrupt is generated when the number of data in RXFIFO reaches the water mark defined by RxFF_LEVEL in CSICR3.

34.6.6 Statistic FIFO Full Interrupt (STATFF_INT)

A StatFIFO full interrupt is generated when the number of data in STATFIFO reaches the water mark defined by STATFF_LEVEL in CSICR3.

34.6.7 RxFIFO Overrun Interrupt (RFF_OR_INT)

A RxFIFO Overrun interrupt is generated when the RxFIFO has 128 words data and more data is being written in.

34.6.8 Statistic FIFO Overrun Interrupt (SFF_OR_INT)

A StatFIFO Overrun interrupt is generated when the STATFIFO has 64 words data and more data is being written in.

34.6.9 Frame Buffer1 DMA Transfer Done Interrupt (DMA_TSF_DONE_FB1)

A DMA transfer done interrupt of frame buffer1 is generated when one frame of data are transferred from RxFIFO to the frame buffer1 in the external memory.
34.6.10 Frame Buffer2 DMA Transfer Done Interrupt
(DMA_TSF_DONE_FB2)

A DMA transfer done interrupt of frame buffer2 is generated when one frame of data are
transferred from RxFIFO to the frame buffer2 in the external memory.

34.6.11 Statistic FIFO DMA Transfer Done Interrupt
(DMA_TSF_DONE_SFF)

A StatFIFO DMA transfer done interrupt is generated when all the data are transferred
from StatFIFO to the external memory. The transfer size is defined in the STATFIFO
DMA Transfer Size Register.

34.6.12 AHB Bus Response Error Interrupt (HRESP_ERR_INT)

An AHB Bus response error interrupt is generated when a bus error is detected.

34.7 Data Packing Style

Careful attention to endianess is needed given the different port sizes at different stages
of the image capture path.

To enable flexible packing of image data before storage in the FIFOs, the CSI module
can swap data fields by use of the PACK_DIR and the SWAP16_EN bit in CSI Control
Register 1 (CSICR1).

The CSI module accepts 8-bit, 10-bit or 16-bit data from the sensor by configuring
PIXEL_BIT bit in CSI Control Register 1 (CSICR1) and TWO_8BIT_SENSOR bit in
CSI Control Register3 (CSICR3). The input data is packed according to the setting of
PACK_DIR bit. The packed data is stored in the RX FIFO according to the setting of the
SWAP16_EN bit.

For 10-bit per pixel data format, each pixel is expanded to 16 bits by appending 6 zeros
bits to the most significant bit.
34.7.1 RX FIFO Path

34.7.1.1 Bayer Data

Bayer data is a type of raw data from the image sensor. This byte-wide data must be converted to the RGB space or YUV space by software. The data path for Bayer data is from the CSI to memory. If the system is in little endian, then the PACK_DIR bit should be set to 0. 8-bit data format from a sensor is packed to 64 bits as P7.P6.P5.P4.P3.P2.P1.P0, where P0 is the pixel coming in time slot 0 (first data) and P3 is the pixel coming in time slot 3 (the last data in the 64-bit word). When the data is addressed as bytes by software, P0 is transferred first, P1 is transferred next, and so on. 10-bit data format is packed to 64 bits as 000000.P3.000000.P2.000000.P1.000000.P0, where P0 is the 10-bit data coming in time slot 0 (first pixel) and P3 is the 10-bit data coming in time slot 3 (fourth pixel). 16-bit data is packed to 64 bits as P7.P6.P5.P4.P3.P2.P1.P0.

34.7.1.2 RGB565 Data

RGB565 data is processed data from the image sensor, which can be put directly into the display buffer. The data is 16 bits wide. The data path is from CSI to memory to the display controller. On the sensor side, data must be transmitted as P0 first, followed by P1, and so on. For each pixel, whether the MSB or LSB is sent first depends on the endianness of the sensor. Data is 16 bits wide with the MSB labeled RG, and the LSB labeled GB. P0 is represented as RG0 and GB0.

CSI receives data in one of the following sequence:

- RG0, GB0, RG1, GB1, while RG0 comes out at time slot 0 (first data), and GB1 comes out at time slot 3 (last data)
- GB0, RG0, GB1, RG1

Using the first sequence as an example, and assuming the system is running in little endian, the data is presented as:

- 8-bit data from sensor: RG0, GB0, RG1, GB1, …
- 64-bit data before storage in the CSI RX FIFO (PACK_DIR bit = 1):
  RG0GB0RG1GB1RG2GB2RG3GB3
- 64-bit data in CSI RX FIFO (SWAP16_EN bit enabled):
  RG3GB3RG2GB2RG1GB1RG0GB0
34.7.1.3 RGB888 Data

This is another kind of processed data from image sensor, which can be used for further image processing directly. Each of the data consist of 8-bit Red, 8-bit Green, and 8-bit Blue data. An example of timing scheme is shown in the following figure.

An optional scheme to pack a dummy byte is provided. For every group of 3 bytes data, a dummy zero is packed to form a 32-bit word as shown in the following figure. The dummy zero can be packed at the LSB position or MSB position. Using RGB888A_FORMAT_SEL in CSI_CSICR18[18] to determine to put the dummy bytes packed at LSB or MSB position.
Figure 34-6. Optional Dummy Byte Packing Scheme

Format 1 with Pack direction = '1' (MSB first)
34.7.2 STAT FIFO Path

Statistics only works for Bayer data in 8-bit per pixel format. It generates 16-bit statistical output from the 8-bit Bayer input (CSI_DATA[13:6]). The outputs are Sum of Green (G), Sum of Red (R), Sum of Blue (B), and Auto Focus (F). Each output is 16-bits wide.

The settings of PACK_DIR and SWAP16_EN bits in the CSICR1 register have no effect on the input path. The PACK_DIR only controls how the 16-bit stat output is packed into the 32-bit STAT FIFO.

When the PACK_DIR bit = 1, the stat data is packed as:

First 32-bit: RG
Second 32-bit: BF
...

When the PACK_DIR bit = 0, the stat data is packed as:

First 32-bit GR
Second 32-bit: FB
...

34.8 CSI Memory Map/Register Definition

All the 32-bit registers of the CSI module are summarized in the Memory Map below:

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_C000</td>
<td>CSI Control Register 1 (CSI_CSICR1)</td>
<td>32</td>
<td>R/W</td>
<td>4000_0800h</td>
<td>34.8.1/1820</td>
</tr>
<tr>
<td>402B_C004</td>
<td>CSI Control Register 2 (CSI_CSICR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.2/1824</td>
</tr>
<tr>
<td>402B_C008</td>
<td>CSI Control Register 3 (CSI_CSICR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.3/1826</td>
</tr>
<tr>
<td>402B_C00C</td>
<td>CSI Statistic FIFO Register (CSI_CSISTATFIFO)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>34.8.4/1828</td>
</tr>
<tr>
<td>402B_C010</td>
<td>CSI RX FIFO Register (CSI_CSIRFIFO)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>34.8.5/1828</td>
</tr>
<tr>
<td>402B_C014</td>
<td>CSI RX Count Register (CSI_CSIRXCNT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_9600h</td>
<td>34.8.6/1829</td>
</tr>
<tr>
<td>402B_C018</td>
<td>CSI Status Register (CSI_CSISR)</td>
<td>32</td>
<td>R/W</td>
<td>8000_4000h</td>
<td>34.8.7/1830</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## CSI memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_C020</td>
<td>CSI DMA Start Address Register - for STATFIFO (CSI_CSIDMASA_STATFIFO)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.8/1833</td>
</tr>
<tr>
<td>402B_C024</td>
<td>CSI DMA Transfer Size Register - for STATFIFO (CSI_CSIDMATS_STATFIFO)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.9/1833</td>
</tr>
<tr>
<td>402B_C028</td>
<td>CSI DMA Start Address Register - for Frame Buffer1 (CSI_CSIDMASA_FB1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.10/1834</td>
</tr>
<tr>
<td>402B_C02C</td>
<td>CSI DMA Transfer Size Register - for Frame Buffer2 (CSI_CSIDMASA_FB2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.11/1835</td>
</tr>
<tr>
<td>402B_C030</td>
<td>CSI Frame Buffer Parameter Register (CSI_CSIFBUF_PARA)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.12/1835</td>
</tr>
<tr>
<td>402B_C034</td>
<td>CSI Image Parameter Register (CSI_CSIMAG_PARA)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.13/1836</td>
</tr>
<tr>
<td>402B_C048</td>
<td>CSI Control Register 18 (CSI_CSICR18)</td>
<td>32</td>
<td>R/W</td>
<td>0002_D000h</td>
<td>34.8.14/1837</td>
</tr>
<tr>
<td>402B_C04C</td>
<td>CSI Control Register 19 (CSI_CSICR19)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>34.8.15/1839</td>
</tr>
</tbody>
</table>
34.8.1 CSI Control Register 1 (CSI_CSICR1)

This register controls the sensor interface timing and interrupt generation. The interrupt enable bits in this register control the interrupt signals and the status bits. That means status bits will only function when the corresponding interrupt bits are enabled.

Address: 402B_C000h base + 0h offset = 402B_C000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>SWAP16_EN</td>
<td>SWAP 16-Bit Enable. This bit enables the swapping of 16-bit data. Data is packed from 8-bit or 10-bit to 32-bit first (according to the setting of PACK_DIR) and then swapped as 16-bit words before being put into the RX FIFO. The action of the bit only affects the RX FIFO and has no affect on the STAT FIFO.</td>
</tr>
<tr>
<td></td>
<td></td>
<td><strong>NOTE:</strong> Example of swapping enabled:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Data input to FIFO = 0x11223344</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Data in RX FIFO = 0x33441122</td>
</tr>
<tr>
<td></td>
<td></td>
<td><strong>NOTE:</strong> Example of swapping disabled:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Data input to FIFO = 0x11223344</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Data in RX FIFO = 0x11223344</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Disable swapping</td>
</tr>
<tr>
<td>1</td>
<td>Enable swapping</td>
</tr>
</tbody>
</table>
| 30    | EXT_VSYNC    | External VSYNC Enable. This bit controls the operational VSYNC mode.  
|       |              | **NOTE:** This only works when the CSI is in CCIR progressive mode.  
| 0     | Internal VSYNC mode |
| 1     | External VSYNC mode |
| 29    | EOF_INT_EN   | End-of-Frame Interrupt Enable. This bit enables and disables the EOF interrupt.  
| 0     | EOF interrupt is disabled |
| 1     | EOF interrupt is generated when RX count value is reached |
| 28    | PrP_IF_EN    | CSI-PrP Interface Enable. This bit controls the CSI to PrP bus. When enabled the RxFIFO is detached from the AHB bus and connected to PrP. All CPU reads or DMA accesses to the RxFIFO register are ignored. All CSI interrupts are also masked.  
| 0     | CSI to PrP bus is disabled |
| 1     | CSI to PrP bus is enabled |
| 27    | CCIR_MODE    | CCIR Mode Select. This bit controls the CCIR mode of operation.  
| 0     | Progressive mode is selected |
| 1     | Interface mode is selected |
| 26    | COF_INT_EN   | Change Of Image Field (COF) Interrupt Enable. This bit enables the COF interrupt.  
| 0     | COF interrupt only in CCIR interface mode when CCIR_EN = 1 and CCIR_MODE = 1. |
| 1     | COF interrupt is enabled |
| 25    | SF_OR_INTEN  | STAT FIFO Overrun Interrupt Enable. This bit enables the STATFIFO overrun interrupt.  
| 0     | STATFIFO overrun interrupt is disabled |
| 1     | STATFIFO overrun interrupt is enabled |
| 24    | RF_OR_INTEN  | RxFIFO Overrun Interrupt Enable. This bit enables the RX FIFO overrun interrupt.  
| 0     | RxFIFO overrun interrupt is disabled |
| 1     | RxFIFO overrun interrupt is enabled |
| 23    | -            | This field is reserved.  
|       | Reserved. This bit is reserved and should read 0. |
| 22    | SFF_DMA_DONE_INTEN | STATFIFO DMA Transfer Done Interrupt Enable. This bit enables the interrupt of STATFIFO DMA transfer done.  
| 0     | STATFIFO DMA Transfer Done interrupt disable |
| 1     | STATFIFO DMA Transfer Done interrupt enable |
| 21    | STATFF_INTEN | STATFIFO Full Interrupt Enable. This bit enables the STAT FIFO interrupt.  
| 0     | STATFIFO full interrupt disable |
| 1     | STATFIFO full interrupt enable |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>20 FB2_DMA_DONE_INTEN</td>
<td>Frame Buffer2 DMA Transfer Done Interrupt Enable. This bit enables the interrupt of Frame Buffer2 DMA transfer done.</td>
</tr>
<tr>
<td>0</td>
<td>Frame Buffer2 DMA Transfer Done interrupt disable</td>
</tr>
<tr>
<td>1</td>
<td>Frame Buffer2 DMA Transfer Done interrupt enable</td>
</tr>
<tr>
<td>19 FB1_DMA_DONE_INTEN</td>
<td>Frame Buffer1 DMA Transfer Done Interrupt Enable. This bit enables the interrupt of Frame Buffer1 DMA transfer done.</td>
</tr>
<tr>
<td>0</td>
<td>Frame Buffer1 DMA Transfer Done interrupt disable</td>
</tr>
<tr>
<td>1</td>
<td>Frame Buffer1 DMA Transfer Done interrupt enable</td>
</tr>
<tr>
<td>18 RXFF_INTEN</td>
<td>RxFIFO Full Interrupt Enable. This bit enables the RxFIFO full interrupt.</td>
</tr>
<tr>
<td>0</td>
<td>RxFIFO full interrupt disable</td>
</tr>
<tr>
<td>1</td>
<td>RxFIFO full interrupt enable</td>
</tr>
<tr>
<td>17 SOF_POL</td>
<td>SOF Interrupt Polarity. This bit controls the condition that generates an SOF interrupt.</td>
</tr>
<tr>
<td>0</td>
<td>SOF interrupt is generated on SOF falling edge</td>
</tr>
<tr>
<td>1</td>
<td>SOF interrupt is generated on SOF rising edge</td>
</tr>
<tr>
<td>16 SOF_INTEN</td>
<td>Start Of Frame (SOF) Interrupt Enable. This bit enables the SOF interrupt.</td>
</tr>
<tr>
<td>0</td>
<td>SOF interrupt disable</td>
</tr>
<tr>
<td>1</td>
<td>SOF interrupt enable</td>
</tr>
<tr>
<td>15–12 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>11 HSYNC_POL</td>
<td>HSYNC Polarity Select. This bit controls the polarity of HSYNC.</td>
</tr>
<tr>
<td>0</td>
<td>HSYNC is active low</td>
</tr>
<tr>
<td>1</td>
<td>HSYNC is active high</td>
</tr>
<tr>
<td>10 CCIR_EN</td>
<td>CCIR656 Interface Enable. This bit selects the type of interface used.</td>
</tr>
<tr>
<td>0</td>
<td>Traditional interface is selected. Timing interface logic is used to latch data.</td>
</tr>
<tr>
<td>1</td>
<td>CCIR656 interface is selected</td>
</tr>
<tr>
<td>9 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>8 FCC</td>
<td>FIFO Clear Control. This bit determines how the RXFIFO and STATFIFO are cleared. When Synchronous FIFO clear is selected the RXFIFO and STATFIFO are cleared, and STAT block is reset, on every SOF. FIFOs and STAT block restarts immediately after reset. For information on the operation when Asynchronous FIFO clear is selected, refer to the descriptions for the CLR_RXFIFO and CLR_STATFIFO bits.</td>
</tr>
<tr>
<td>0</td>
<td>Asynchronous FIFO clear is selected.</td>
</tr>
<tr>
<td>1</td>
<td>Synchronous FIFO clear is selected</td>
</tr>
<tr>
<td>7 PACK_DIR</td>
<td>Data Packing Direction. This bit controls how 8-bit/10-bit image data is packed into 32-bit RX FIFO, and how 16-bit statistical data is packed into 32-bit STAT FIFO.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Pack from LSB first. For image data, 0x11, 0x22, 0x33, 0x44, it will appear as 0x44332211 in RX FIFO. For stat data, 0xAAAA, 0xBBB, it will appear as 0xBBBAAAAA in STAT FIFO.</td>
</tr>
<tr>
<td>1</td>
<td>Pack from MSB first. For image data, 0x11, 0x22, 0x33, 0x44, it will appear as 0x11223344 in RX FIFO. For stat data, 0xAAAA, 0xBBB, it will appear as 0xAABBBBAAAA in STAT FIFO.</td>
</tr>
<tr>
<td>6</td>
<td>CLR_STATFIFO Asynchronous STATFIFO Clear. This bit clears the STATFIFO and Reset STAT block. This bit works only in async FIFO clear mode-that is, FCC = 0. Otherwise this bit is ignored. Writing 1 will clear STATFIFO and reset STAT block immediately, STATFIFO and STAT block then wait and restart after the arrival of next SOF. The bit is restored to 0 automatically after finish. Normally reads 0.</td>
</tr>
<tr>
<td>5</td>
<td>CLR_RXFIFO Asynchronous RX FIFO Clear. This bit clears the RX FIFO. This bit works only in async FIFO clear mode—that is, FCC = 0. Otherwise this bit is ignored. Writing 1 clears the RX FIFO immediately, RX FIFO restarts immediately after that. The bit is restored to 0 automatically after finish. Normally reads 0.</td>
</tr>
<tr>
<td>4</td>
<td>GCLK_MODE Gated Clock Mode Enable. Controls if CSI is working in gated or non-gated mode. This bit works only in traditional mode—that is, CCIR_EN = 0. Otherwise this bit is ignored. 0 Non-gated clock mode. All incoming pixel clocks are valid. HSYNC is ignored. 1 Gated clock mode. Pixel clock signal is valid only when HSYNC is active.</td>
</tr>
<tr>
<td>3</td>
<td>INV_DATA Invert Data Input. This bit enables or disables internal inverters on the data lines. 0 CSI_D[7:0] data lines are directly applied to internal circuitry 1 CSI_D[7:0] data lines are inverted before applied to internal circuitry</td>
</tr>
<tr>
<td>2</td>
<td>INV_PIXCLK Invert Pixel Clock Input. This bit determines if the Pixel Clock (CSI_PIXCLK) is inverted before it is applied to the CSI module. 0 CSI_PIXCLK is directly applied to internal circuitry 1 CSI_PIXCLK is inverted before applied to internal circuitry</td>
</tr>
<tr>
<td>1</td>
<td>REDGE Valid Pixel Clock Edge Select. Selects which edge of the CSI_PIXCLK is used to latch the pixel data. 0 Pixel data is latched at the falling edge of CSI_PIXCLK 1 Pixel data is latched at the rising edge of CSI_PIXCLK</td>
</tr>
<tr>
<td>0</td>
<td>PIXEL_BIT Pixel Bit. This bit indicates the bayer data width for each pixel. This bit should be configured before activating or re-starting the embedded DMA controller. 0 8-bit data for each pixel 1 10-bit data for each pixel</td>
</tr>
</tbody>
</table>
34.8.2 CSI Control Register 2 (CSI_CSICR2)

This register provides the statistic block with data about which live view resolution is being used, and the starting sensor pixel of the Bayer pattern. It also contains the horizontal and vertical count used to determine the number of pixels to skip between the 64 x 64 blocks of statistics when generating statistics on live view image that are greater than 512 x 384.

Address: 402B_C000h base + 4h offset = 402B_C004h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>DMA_BURST_TYPE_RFF</td>
<td>Burst Type of DMA Transfer from RxFIFO. Selects the burst type of DMA transfer from RxFIFO.</td>
</tr>
<tr>
<td></td>
<td>X0</td>
<td>INCR8</td>
</tr>
<tr>
<td></td>
<td>01</td>
<td>INCR4</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>INCR16</td>
</tr>
<tr>
<td>29–28</td>
<td>DMA_BURST_TYPE_SFF</td>
<td>Burst Type of DMA Transfer from STATFIFO. Selects the burst type of DMA transfer from STATFIFO.</td>
</tr>
<tr>
<td></td>
<td>X0</td>
<td>INCR8</td>
</tr>
<tr>
<td></td>
<td>01</td>
<td>INCR4</td>
</tr>
<tr>
<td></td>
<td>11</td>
<td>INCR16</td>
</tr>
</tbody>
</table>
### CSI_CSICR2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>27</td>
<td>This field is reserved. Reserved. These bit is reserved and should read 0.</td>
</tr>
</tbody>
</table>
| 26 DRM | Double Resolution Mode. Controls size of statistics grid.  
0 | Stats grid of 8 x 6  
1 | Stats grid of 8 x 12 |
| 25–24 AFS | Auto Focus Spread. Selects which green pixels are used for auto-focus.  
00 | Abs Diff on consecutive green pixels  
01 | Abs Diff on every third green pixels  
1x | Abs Diff on every four green pixels |
| 23 SCE | Skip Count Enable. Enables or disables the skip count feature.  
0 | Skip count disable  
1 | Skip count enable |
| 22–21 | This field is reserved. Reserved. These bits are reserved and should read 0. |
| 20–19 BTS | Bayer Tile Start. Controls the Bayer pattern starting point.  
00 | GR  
01 | RG  
10 | BG  
11 | GB |
| 18–16 LVRM | Live View Resolution Mode. Selects the grid size used for live view resolution.  
0 | 512 x 384  
1 | 448 x 336  
2 | 384 x 288  
3 | 384 x 256  
4 | 320 x 240  
5 | 288 x 216  
6 | 400 x 300 |
| 15–8 VSC | Vertical Skip Count. Contains the number of rows to skip. SCE must be 1, otherwise VSC is ignored.  
0–255 | Number of rows to skip minus 1 |
| HSC | Horizontal Skip Count. Contains the number of pixels to skip. SCE must be 1, otherwise HSC is ignored.  
0–255 | Number of pixels to skip minus 1 |
34.8.3 CSI Control Register 3 (CSI_CSICR3)

This read/write register acts as an extension of the functionality of the CSI Control register 1, adding additional control and features.

Address: 402B_C000h base + 8h offset = 402B_C008h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Frame Counter. This is a 16-bit Frame Counter (Wraps around automatically after reaching the maximum)</td>
</tr>
<tr>
<td>15</td>
<td>Frame Count Reset. Resets the Frame Counter. (Cleared automatically after reset is done)</td>
</tr>
<tr>
<td>14</td>
<td>Reflash DMA Controller for RxFIFO. This bit reflash the embedded DMA controller for RxFIFO. It should be reflash before the embedded DMA controller starts to work. (Cleared automatically after reflash is done)</td>
</tr>
<tr>
<td>13</td>
<td>Reflash DMA Controller for STATFIFO. This bit reflash the embedded DMA controller for STATFIFO. It should be reflash before the embedded DMA controller starts to work. (Cleared automatically after reflash is done)</td>
</tr>
<tr>
<td>Field</td>
<td>Description</td>
</tr>
<tr>
<td>------------------------</td>
<td>--------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>12 DMA_REQ_EN_RFF</td>
<td>DMA Request Enable for RxFIFO. This bit enables the dma request from RxFIFO to the embedded DMA controller.</td>
</tr>
<tr>
<td></td>
<td>0 Disable the dma request</td>
</tr>
<tr>
<td></td>
<td>1 Enable the dma request</td>
</tr>
<tr>
<td>11 DMA_REQ_EN_SFF</td>
<td>DMA Request Enable for STATFIFO. This bit enables the dma request from STATFIFO to the embedded DMA controller.</td>
</tr>
<tr>
<td></td>
<td>0 Disable the dma request</td>
</tr>
<tr>
<td></td>
<td>1 Enable the dma request</td>
</tr>
<tr>
<td>10–8 STATFF_LEVEL</td>
<td>STATFIFO Full Level. When the number of data in STATFIFO reach this level, STATFIFO full interrupt is generated, or STATFIFO DMA request is sent.</td>
</tr>
<tr>
<td></td>
<td>000 4 Double words</td>
</tr>
<tr>
<td></td>
<td>001 8 Double words</td>
</tr>
<tr>
<td></td>
<td>010 16 Double words</td>
</tr>
<tr>
<td></td>
<td>011 24 Double words</td>
</tr>
<tr>
<td></td>
<td>100 32 Double words</td>
</tr>
<tr>
<td></td>
<td>101 48 Double words</td>
</tr>
<tr>
<td></td>
<td>110 64 Double words</td>
</tr>
<tr>
<td></td>
<td>111 96 Double words</td>
</tr>
<tr>
<td>7 HRESP_ERR_EN</td>
<td>Hresponse Error Enable. This bit enables the hresponse error interrupt.</td>
</tr>
<tr>
<td></td>
<td>0 Disable hresponse error interrupt</td>
</tr>
<tr>
<td></td>
<td>1 Enable hresponse error interrupt</td>
</tr>
<tr>
<td>6–4 RXFF_LEVEL</td>
<td>RxFIFO Full Level. When the number of data in RxFIFO reaches this level, a RxFIFO full interrupt is generated, or an RXFIFO DMA request is sent.</td>
</tr>
<tr>
<td></td>
<td>000 4 Double words</td>
</tr>
<tr>
<td></td>
<td>001 8 Double words</td>
</tr>
<tr>
<td></td>
<td>010 16 Double words</td>
</tr>
<tr>
<td></td>
<td>011 24 Double words</td>
</tr>
<tr>
<td></td>
<td>100 32 Double words</td>
</tr>
<tr>
<td></td>
<td>101 48 Double words</td>
</tr>
<tr>
<td></td>
<td>110 64 Double words</td>
</tr>
<tr>
<td></td>
<td>111 96 Double words</td>
</tr>
<tr>
<td>3 TWO_8BIT_SENSOR</td>
<td>16-bit Sensor Mode. This bit indicates one 16-bit sensor connected to the 16-bit data ports. This bit should be set if there is one 16-bit sensor connected. This bit should be configured before activating or restarting the embedded DMA controller.</td>
</tr>
<tr>
<td></td>
<td>0 Only one 8-bit sensor is connected</td>
</tr>
<tr>
<td></td>
<td>1 One 16-bit sensor is connected</td>
</tr>
<tr>
<td>2 ZERO_PACK_EN</td>
<td>Dummy Zero Packing Enable. This bit causes a dummy zero to be packed with every 3 incoming bytes, forming a 32-bit word. The dummy zero is always packed to the LSB position. This packing function is only available in 8-bit/pixel mode.</td>
</tr>
<tr>
<td></td>
<td>0 Zero packing disabled</td>
</tr>
<tr>
<td></td>
<td>1 Zero packing enabled</td>
</tr>
</tbody>
</table>
CSI_CSICR3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ECC_INT_EN</td>
<td>Error Detection Interrupt Enable. This bit enables and disables the error detection interrupt. This feature only works in CCIR interlace mode.</td>
</tr>
<tr>
<td>0</td>
<td>No interrupt is generated when error is detected. Only the status bit ECC_INT is set.</td>
</tr>
<tr>
<td>1</td>
<td>Interrupt is generated when error is detected.</td>
</tr>
<tr>
<td>ECC_AUTO_EN</td>
<td>Automatic Error Correction Enable. This bit enables and disables the automatic error correction. If an error occurs and error correction is disabled only the ECC_INT status bit is set. This feature only works in CCIR interlace mode.</td>
</tr>
<tr>
<td>0</td>
<td>Auto Error correction is disabled.</td>
</tr>
<tr>
<td>1</td>
<td>Auto Error correction is enabled.</td>
</tr>
</tbody>
</table>

34.8.4 CSI Statistic FIFO Register (CSI_CSISTATFIFO)

The StatFIFO is a read-only register containing statistic data from the sensor. Writing to this register has no effect.

Address: 402B_C000h base + Ch offset = 402B_C00Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

**CSI_CSISTATFIFO field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>STAT</td>
<td>Static data from sensor</td>
</tr>
</tbody>
</table>

34.8.5 CSI RX FIFO Register (CSI_CSIRFIFO)

This read-only register contains received image data. Writing to this register has no effect.

Address: 402B_C000h base + 10h offset = 402B_C010h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>
CSI_CSIRFIFO field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMAGE</td>
<td>Received image data</td>
</tr>
</tbody>
</table>

34.8.6 CSI RX Count Register (CSI_CSIRXCNT)

This register works for EOF interrupt generation. It should be set to the number of words to receive that would generate an EOF interrupt.

There is an internal counter that counts the number of words read from the RX FIFO. Whenever the RX FIFO is being read, by either the CPU or the embedded DMA controller, the counter value is updated and compared with this register. If the values match, then an EOF interrupt is triggered.

Address: 402B_C000h base + 14h offset = 402B_C014h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| R   | W   | Reserved |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 0   | 1   | 1   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

CSI_CSIRXCNT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–22</td>
<td>This field is reserved. Reserved. These bits are reserved and should read 0.</td>
</tr>
<tr>
<td>RXCNT</td>
<td>RxFIFO Count. This 22-bit counter for RXFIFO is updated each time the RXFIFO is read by CPU or DMA. This counter should be set to the expected number of words to receive that would generate an EOF interrupt.</td>
</tr>
</tbody>
</table>
34.8.7 CSI Status Register (CSI_CSISR)

This read/write register shows sensor interface status, and which kind of interrupt is being generated. The corresponding interrupt bits must be set for the status bit to function. Status bits should function normally even if the corresponding interrupt enable bits are not enabled.

Address: 402B_C000h base + 18h offset = 402B_C018h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–29</td>
<td>Reserved.</td>
</tr>
<tr>
<td>28</td>
<td>BASEADDR_CHANGE_ERROR</td>
</tr>
<tr>
<td></td>
<td>When using base address switching enable, this bit will be 1 when switching occur before DMA complete. This bit will be clear by writing 1.</td>
</tr>
<tr>
<td></td>
<td>When this interrupt happens, follow the steps listed below.</td>
</tr>
<tr>
<td></td>
<td>1. Unassert the CSI enable, CSIX_CSICR18 bit31,</td>
</tr>
<tr>
<td></td>
<td>2. Reflash the DMA, assert the CSIX_CSICR3 bit 14,</td>
</tr>
<tr>
<td></td>
<td>3. Assert the CSI enable, CSIX_CSICR18 bit31.</td>
</tr>
<tr>
<td>27</td>
<td>DMA_FIELD0_DONE</td>
</tr>
<tr>
<td></td>
<td>When DMA field 0 is complete, this bit will be set to 1(clear by writing 1).</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CSI_CSISR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>26 DMA_FIELD1_DONE</td>
<td>When DMA field 0 is complete, this bit will be set to 1(clear by writing 1).</td>
</tr>
<tr>
<td>25 SF_OR_INT</td>
<td>STATFIFO Overrun Interrupt Status. Indicates the overflow status of the STATFIFO register. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 STATFIFO has not overflowed.</td>
</tr>
<tr>
<td></td>
<td>1 STATFIFO has overflowed.</td>
</tr>
<tr>
<td>24 RF_OR_INT</td>
<td>RxFIFO Overrun Interrupt Status. Indicates the overflow status of the RxFIFO register. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 RxFIFO has not overflowed.</td>
</tr>
<tr>
<td></td>
<td>1 RxFIFO has overflowed.</td>
</tr>
<tr>
<td>23 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved. This bit is reserved and should read 0.</td>
</tr>
<tr>
<td>22 DMA_TSF_DONE_SFF</td>
<td>DMA Transfer Done from StatFIFO. Indicates that the dma transfer from StatFIFO is completed. It can trigger an interrupt if the corresponding enable bit is set in CSICR1. This bit can be cleared by writing 1 or reflashing the StatFIFO dma controller in CSICR3. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 DMA transfer is not completed.</td>
</tr>
<tr>
<td></td>
<td>1 DMA transfer is completed.</td>
</tr>
<tr>
<td>21 STATFF_INT</td>
<td>STATFIFO Full Interrupt Status. Indicates the number of data in the STATFIFO reaches the trigger level. (this bit is cleared automatically by reading the STATFIFO)</td>
</tr>
<tr>
<td></td>
<td>0 STATFIFO is not full.</td>
</tr>
<tr>
<td></td>
<td>1 STATFIFO is full.</td>
</tr>
<tr>
<td>20 DMA_TSF_DONE_FB2</td>
<td>DMA Transfer Done in Frame Buffer2. Indicates that the DMA transfer from RxFIFO to Frame Buffer2 is completed. It can trigger an interrupt if the corresponding enable bit is set in CSICR1. This bit can be cleared by writing 1 or reflashing the RxFIFO dma controller in CSICR3. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 DMA transfer is not completed.</td>
</tr>
<tr>
<td></td>
<td>1 DMA transfer is completed.</td>
</tr>
<tr>
<td>19 DMA_TSF_DONE_FB1</td>
<td>DMA Transfer Done in Frame Buffer1. Indicates that the DMA transfer from RxFIFO to Frame Buffer1 is completed. It can trigger an interrupt if the corresponding enable bit is set in CSICR1. This bit can be cleared by writing 1 or reflashing the RxFIFO dma controller in CSICR3. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 DMA transfer is not completed.</td>
</tr>
<tr>
<td></td>
<td>1 DMA transfer is completed.</td>
</tr>
<tr>
<td>18 RxFF_INT</td>
<td>RxFIFO Full Interrupt Status. Indicates the number of data in the RxFIFO reaches the trigger level. (this bit is cleared automatically by reading the RxFIFO)</td>
</tr>
<tr>
<td></td>
<td>0 RxFIFO is not full.</td>
</tr>
<tr>
<td></td>
<td>1 RxFIFO is full.</td>
</tr>
<tr>
<td>17 EOF_INT</td>
<td>End of Frame (EOF) Interrupt Status. Indicates when EOF is detected. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 EOF is not detected.</td>
</tr>
<tr>
<td></td>
<td>1 EOF is detected.</td>
</tr>
<tr>
<td>16 SOF_INT</td>
<td>Start of Frame Interrupt Status. Indicates when SOF is detected. (Cleared by writing 1)</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SOF is not detected.</td>
</tr>
<tr>
<td>1</td>
<td>SOF is detected.</td>
</tr>
<tr>
<td>15 F2_INT</td>
<td>CCIR Field 2 Interrupt Status. Indicates the presence of field 2 of video in CCIR mode. (Cleared automatically when current field does not match)</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Only works in CCIR Interlace mode.</td>
</tr>
<tr>
<td>0</td>
<td>Field 2 of video is not detected.</td>
</tr>
<tr>
<td>1</td>
<td>Field 2 of video is about to start.</td>
</tr>
<tr>
<td>14 F1_INT</td>
<td>CCIR Field 1 Interrupt Status. Indicates the presence of field 1 of video in CCIR mode. (Cleared automatically when current field does not match)</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Only works in CCIR Interlace mode.</td>
</tr>
<tr>
<td>0</td>
<td>Field 1 of video is not detected.</td>
</tr>
<tr>
<td>1</td>
<td>Field 1 of video is about to start.</td>
</tr>
<tr>
<td>13 COF_INT</td>
<td>Change Of Field Interrupt Status. Indicates that a change of the video field has been detected. Only works in CCIR Interlace mode. Software should read this bit first and then dispatch the new field from F1_INT and F2_INT. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 Video field has no change.</td>
</tr>
<tr>
<td></td>
<td>1 Change of video field is detected.</td>
</tr>
<tr>
<td>12–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved. These bits are reserved and should read 0.</td>
</tr>
<tr>
<td>7 HRESP_ERR_INT</td>
<td>Hresponse Error Interrupt Status. Indicates that a hresponse error has been detected. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 No hresponse error.</td>
</tr>
<tr>
<td></td>
<td>1 Hresponse error is detected.</td>
</tr>
<tr>
<td>6–2</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved. These bits are reserved and should read 0.</td>
</tr>
<tr>
<td>1 ECC_INT</td>
<td>CCIR Error Interrupt. This bit indicates an error has occurred. This only works in CCIR Interlace mode. (Cleared by writing 1)</td>
</tr>
<tr>
<td></td>
<td>0 No error detected</td>
</tr>
<tr>
<td></td>
<td>1 Error is detected in CCIR coding</td>
</tr>
<tr>
<td>0 DRDY</td>
<td>RXFIFO Data Ready. Indicates the presence of data that is ready for transfer in the RxFIFO. (Cleared automatically by reading FIFO)</td>
</tr>
<tr>
<td></td>
<td>0 No data (word) is ready</td>
</tr>
<tr>
<td></td>
<td>1 At least 1 datum (word) is ready in RXFIFO.</td>
</tr>
</tbody>
</table>
### 34.8.8 CSI DMA Start Address Register - for STATFIFO (CSI_CSIDMASA_STATFIFO)

This register provides the start address for the embedded DMA controller of STATFIFO. The embedded DMA controller will read data from STATFIFO and write it to the external memory from the start address. This register should be configured before activating or restarting the embedded DMA controller.

Address: 402B_C000h base + 20h offset = 402B_C020h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DMA_START_ADDR_SFF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DMA_START_ADDR_SFF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**CSI_CSIDMASA_STATFIFO field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2 DMA_START_</td>
<td>DMA Start Address for STATFIFO. Indicates the start address to write data.</td>
</tr>
<tr>
<td>ADDR_SFF</td>
<td>The embedded DMA controller will read data from STATFIFO and write it from</td>
</tr>
<tr>
<td></td>
<td>this address through AHB bus. The address should be double words aligned.</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved. These bits are reserved and should read 0.</td>
</tr>
</tbody>
</table>

### 34.8.9 CSI DMA Transfer Size Register - for STATFIFO (CSI_CSIDMATS_STATFIFO)

This register provides the total transfer size for the embedded DMA controller of STATFIFO. This register should be configured before activating or restarting the embedded DMA controller.

Address: 402B_C000h base + 24h offset = 402B_C024h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DMA_TSF_SIZE_SFF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

NXP Semiconductors
CSI_CSIDMATS_STATFIFO field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMA_TSF_SIZE_SFF</td>
<td>DMA Transfer Size for STATFIFO. Indicates how many words to be transferred by the embedded DMA controller. The size should be double words aligned.</td>
</tr>
</tbody>
</table>

34.8.10 CSI DMA Start Address Register - for Frame Buffer1 (CSI_CSIDMASA_FB1)

This register provides the start address in the frame buffer1 for the embedded DMA controller of RxFIFO. The embedded DMA controller will read data from RxFIFO and write it to the frame buffer1 from the start address. This register should be configured before activating or restarting the embedded DMA controller.

Address: 402B_C000h base + 28h offset = 402B_C028h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

CSI_CSIDMASA_FB1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2 DMA_START_ADDR_FB1</td>
<td>DMA Start Address in Frame Buffer1. Indicates the start address to write data. The embedded DMA controller will read data from RxFIFO and write it from this address through AHB bus. The address should be double words aligned.</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved. These bits are reserved and should read 0.</td>
</tr>
</tbody>
</table>
34.8.11 CSI DMA Transfer Size Register - for Frame Buffer2 (CSI_CSIDMASA_FB2)

This register provides the start address in the frame buffer2 for the embedded DMA controller of RxFIFO. The embedded DMA controller will read data from RxFIFO and write it to the frame buffer2 from the start address. This register should be configured before activating or restarting the embedded DMA controller.

Address: 402B_C000h base + 2Ch offset = 402B_C02Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>31-2</td>
<td>DMA_START_ADDR_FB2</td>
<td>DMA_START_ADDR_FB2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

 CSI_CSIDMASA_FB2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2 DMA_START_ADDR_FB2</td>
<td>DMA Start Address in Frame Buffer2. Indicates the start address to write data. The embedded DMA controller will read data from RxFIFO and write it from this address through AHB bus. The address should be double words aligned.</td>
</tr>
<tr>
<td>- Reserved</td>
<td>This field is reserved. Reserved. These bits are reserved and should read 0.</td>
</tr>
</tbody>
</table>

34.8.12 CSI Frame Buffer Parameter Register (CSI_CSIFBUF_PARA)

This register provides the stride of the frame buffer to show how many words to skip before starting to write the next row of the image. The width of the frame buffer minus the width of the image is the stride. This register should be configured before activating or restarting the embedded DMA controller.

Address: 402B_C000h base + 30h offset = 402B_C030h

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R/W  | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   | R   |
|      | DEINTERLACE_STRIDE | FBUF_STRIDE |
| Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
CSI_MEM_MAP/REGISTER_DEFINITION

### CSI_CSIIFBUF_PARA field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>DEINTERLACE_STRIDE is only used in the deinterlace mode. If line stride feature is supported in deinterlace mode, FBUF_STRIDE and DEINTERLACE_STRIDE need to be configured at the same time. DEINTERLACE_STRIDE is configured the same as line width. In normal line stride feature, only FBUF_STRIDE needs to be configured.</td>
</tr>
<tr>
<td></td>
<td><img src="image.png" alt="Diagram" /></td>
</tr>
<tr>
<td>FBUF_STRIDE</td>
<td>Frame Buffer Parameter. Indicates the stride of the frame buffer. The width of the frame buffer(in double words) minus the width of the image(in double words) is the stride. The stride should be double words aligned. The embedded DMA controller will skip the stride before starting to write the next row of the image.</td>
</tr>
</tbody>
</table>

### 34.8.13 CSI Image Parameter Register (CSI_CSIIMAG_PARA)

This register provides the width and the height of the image from the sensor. The width and height should be aligned in pixel. The width of the image multiplied by the height is the total pixel size that will be transfered in a frame by the embedded DMA controller. This register should be configured before activating or restarting the embedded DMA controller.

Address: 402B_C000h base + 34h offset = 402B_C034h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### CSI_CSIIMAG_PARA field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>IMAGE_WIDTH</td>
</tr>
<tr>
<td>IMAGE_WIDTH</td>
<td>Image Width. Indicates how many pixels in a line of the image from the sensor. If the input data from the sensor is 8-bit/pixel format, the IMAGE_WIDTH should be a multiple of 8 pixels. If the input data from the sensor is 10-bit/pixel or 16-bit/pixel format, the IMAGE_WIDTH should be a multiple of 4 pixels.</td>
</tr>
<tr>
<td>IMAGE_HEIGHT</td>
<td>Image Height. Indicates how many pixels in a column of the image from the sensor.</td>
</tr>
</tbody>
</table>
34.8.14 CSI Control Register 18 (CSI_CSICR18)

This read/write register acts as an extension of the functionality of the CSI Control register 1.

Address: 402B_C000h base + 48h offset = 402B_C048h

### CSI_CSICR18 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 CSI_ENABLE</td>
<td>CSI global enable signal. Only when this bit is 1, CSI can start to receive the data and store to memory.</td>
</tr>
<tr>
<td>30–20 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>19–18 MASK_OPTION</td>
<td>These bits used to choose the method to mask the CSI input.</td>
</tr>
<tr>
<td>00 01 02 03</td>
<td>Writing to memory from first completely frame, when using this option, the CSI_ENABLE should be 1.</td>
</tr>
<tr>
<td>00 01 02 03</td>
<td>Writing to memory when CSI_ENABLE is 1.</td>
</tr>
<tr>
<td>00 01 02 03</td>
<td>Writing to memory from second completely frame, when using this option, the CSI_ENABLE should be 1.</td>
</tr>
<tr>
<td>00 01 02 03</td>
<td>Writing to memory when data comes in, not matter the CSI_ENABLE is 1 or 0.</td>
</tr>
<tr>
<td>17–16 -</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### CSI_CSICR18 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–12 AHB_HPROT</td>
<td>Hprot value in AHB bus protocol.</td>
</tr>
<tr>
<td>11</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>10 RGB888A_FORMAT_SEL</td>
<td>Output is 32-bit format.</td>
</tr>
<tr>
<td></td>
<td>0 {8’h0, data[23:0]}</td>
</tr>
<tr>
<td></td>
<td>1 {data[23:0], 8’h0}</td>
</tr>
<tr>
<td>9 BASEADDR_CHANGE_ERROR_IE</td>
<td>Base address change error interrupt enable signal.</td>
</tr>
<tr>
<td>8 LAST_DMA_REQ_SEL</td>
<td>Choosing the last DMA request condition.</td>
</tr>
<tr>
<td></td>
<td>0 fifo_full_level</td>
</tr>
<tr>
<td></td>
<td>1 hburst_length</td>
</tr>
<tr>
<td>7 DMA_FIELD1_DONE_IE</td>
<td>When in interlace mode, field 1 done interrupt enable.</td>
</tr>
<tr>
<td></td>
<td>0 Interrupt disabled</td>
</tr>
<tr>
<td></td>
<td>1 Interrupt enabled</td>
</tr>
<tr>
<td>6 FIELD0_DONE_IE</td>
<td>In interlace mode, field 0 means interrupt enabled.</td>
</tr>
<tr>
<td></td>
<td>0 Interrupt disabled</td>
</tr>
<tr>
<td></td>
<td>1 Interrupt enabled</td>
</tr>
<tr>
<td>5 BASEADDR_SWITCH_SEL</td>
<td>CSI 2 base addresses switching method. When using this bit, BASEADDR_SWITCH_EN is 1.</td>
</tr>
<tr>
<td></td>
<td>0 Switching base address at the edge of the vsync</td>
</tr>
<tr>
<td></td>
<td>1 Switching base address at the edge of the first data of each frame</td>
</tr>
<tr>
<td>4 BASEADDR_SWITCH_EN</td>
<td>When this bit is enabled, CSI DMA will switch the base address according to BASEADDR_SWITCH_SEL rather than atomically by DMA completed.</td>
</tr>
<tr>
<td>3 PARALLEL24_EN</td>
<td>When input is parallel rgb888/yuv444 24bit, this bit can be enabled.</td>
</tr>
<tr>
<td>2 DEINTERLACE_EN</td>
<td>This bit is used to select the output method When input is standard CCIR656 video.</td>
</tr>
<tr>
<td></td>
<td>0 Deinterlace disabled</td>
</tr>
<tr>
<td></td>
<td>1 Deinterlace enabled</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>
34.8.15 CSI Control Register 19 (CSI_CSICR19)

This read/write register acts as an extension of the functionality of the CSI Control register 1.

Address: 402B_C000h base + 4Ch offset = 402B_C04Ch

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>DMA_RFIFO_HIGHEST_FIFO_LEVEL</td>
<td>This byte stores the highest FIFO level achieved by CSI FIFO timely and will be clear by writing 8'ff to it.</td>
</tr>
</tbody>
</table>
Chapter 35
Enhanced LCD Interface (eLCDIF)

35.1 Chip-specific eLCDIF information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

35.2 Overview

The enhanced Liquid Crystal Display Interface (LCDIF) is a general purpose display controller

The LCDIF block supports the following:

- Displays that support moving pictures and require the RGB interface mode (DOTCLK interface).

The LCDIF provides fully programmable functionality to supported interfaces:

- Bus master interface to source frame buffer data for display refresh. This interface can also be used to drive data for "Smart" displays.
- DMA interface to manage data transfers between "Smart" displays and SoC.
- 8/16/18/24 bit LCD data bus support available depending on I/O mux options.
- Programmable timing and parameters for DOTCLK LCD interfaces.
35.3 External Signals

The following table describes the external signals of LCD:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCD_CLK</td>
<td>Clock signal</td>
<td>GPIO_B0_00</td>
<td>ALT0</td>
<td>I</td>
</tr>
<tr>
<td>LCD_ENABLE</td>
<td>Enable signal</td>
<td>GPIO_B0_01</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_HSYNC</td>
<td>HSYNC signal</td>
<td>GPIO_B0_02</td>
<td>ALT0</td>
<td>I</td>
</tr>
<tr>
<td>LCD_VSYNC</td>
<td>VSYNC signal</td>
<td>GPIO_B0_03</td>
<td>ALT0</td>
<td>I</td>
</tr>
<tr>
<td>LCD_DATA00</td>
<td>Data Signal</td>
<td>GPIO_B0_04</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA01</td>
<td>Data Signal</td>
<td>GPIO_B0_05</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA02</td>
<td>Data Signal</td>
<td>GPIO_B0_06</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA03</td>
<td>Data Signal</td>
<td>GPIO_B0_07</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA04</td>
<td>Data Signal</td>
<td>GPIO_B0_08</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA05</td>
<td>Data Signal</td>
<td>GPIO_B0_09</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA06</td>
<td>Data Signal</td>
<td>GPIO_B0_10</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA07</td>
<td>Data Signal</td>
<td>GPIO_B0_11</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA08</td>
<td>Data Signal</td>
<td>GPIO_B0_12</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA09</td>
<td>Data Signal</td>
<td>GPIO_B0_13</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA10</td>
<td>Data Signal</td>
<td>GPIO_B0_14</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA11</td>
<td>Data Signal</td>
<td>GPIO_B0_15</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA12</td>
<td>Data Signal</td>
<td>GPIO_B1_00</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA13</td>
<td>Data Signal</td>
<td>GPIO_B1_01</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA14</td>
<td>Data Signal</td>
<td>GPIO_B1_02</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA15</td>
<td>Data Signal</td>
<td>GPIO_B1_03</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA16</td>
<td>Data Signal</td>
<td>GPIO_B1_04</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA17</td>
<td>Data Signal</td>
<td>GPIO_B1_05</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA18</td>
<td>Data Signal</td>
<td>GPIO_B1_06</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA19</td>
<td>Data Signal</td>
<td>GPIO_B1_07</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA20</td>
<td>Data Signal</td>
<td>GPIO_B1_08</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA21</td>
<td>Data Signal</td>
<td>GPIO_B1_09</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA22</td>
<td>Data Signal</td>
<td>GPIO_B1_10</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td>LCD_DATA23</td>
<td>Data Signal</td>
<td>GPIO_B1_11</td>
<td>ALT0</td>
<td>IO</td>
</tr>
</tbody>
</table>
35.4 Clocks

The following table describes the clock sources for LCDIF. Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock Name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>apb_clk</td>
<td>ipg_clk_root</td>
<td>AXI Clock</td>
</tr>
<tr>
<td>pix_clk</td>
<td>lcdif_clk_root</td>
<td>Pixel Clock</td>
</tr>
</tbody>
</table>

35.5 Functional Description

Bus Interface Mechanisms through Initializing the LCDIF, describe the internal pipeline for the LCDIF interfaces. Differences for each mode are then described in separate sections, as follows:

- DOTCLK Interface

LCDIF pin usage by interface mode is described in LCDIF Pin Usage by Interface Mode.
 Functional Description

35.5.1 Bus Interface Mechanisms

The LCDIF module has memory-mapped control, data and status registers. It provides several interfaces to transfer data between the display and SoC.
The bus master interface is used to initiate the requests to transfer data from external memory to the display. It is completely autonomous, or no CPU intervention is required, to manage the cyclical nature of refreshing standard display types.

The DMA interface requires the SoC integrated APBDMA engine to manage data transfers on behalf of the LCDIF. APBDMA descriptor chains are created to manage control and data flow between the LCDIF and external display. This interface is typically used for "Smart" display types that integrate their own frame buffer and control interface. The APBDMA engine is used to reduce the CPU compute requirements to complete the display solution.

The host CPU executes display drivers to manage the display solution. The following sections describe the system bus interface mechanisms.

### 35.5.1.1 Bus Master Operation in Write/Display Modes

The LCDIF block has a bus master interface that initiates requests for data to drive the display. The LCDIF_MASTER bit must be set to 1 to enable the bus master interface. Software should program all control registers required to transfer the frame sequence.

The DOTCLK mode is used to refresh the display at the desired refresh rate and resolution, and drive displays that don't integrate a display buffer memory. When the display is refreshed, the LCDIF will automatically update the LCDIF_CUR_BUF_ADDR register with the value in LCDIF_NEXT_BUF_ADDR at the end of current frame and start fetching the next frame from the new address. If the LCDIF_NEXT_BUF_ADDR register was not updated within a frame refresh cycle, LCDIF will keep transmitting the last frame until a new value is programmed into that register.

### 35.5.1.2 System Bus Master Performance

The performance of the LCDIF block can be controlled by changing the burst length and the outstanding cycle issuing capability depending on the memory bandwidth requirements. Two fields in the LCDIF_CTRL2 register will throttle system memory requests. The LCDIF_CTRL2_OUTSTANDING_REQS field will control how many requests the LCDIF can have in flight on any given clock cycle. This should be programmed based on the expected system bus latency for returned read data. Also, the LCDIF_CTRL2_BURST_LEN_8 bit will set the number of 64 bit words requested for each LCDIF system bus request to either 8 or 16 QWORDS. Generally, 4 outstanding requests of length 16 will provide enough performance to drive any standard display.
resolution. These configuration bits are intended to change the access pattern of the LCDIF to optimize system bus throughput when other system masters will contend for system memory resources.

### 35.5.1.3 DMA Operation in MPU Read Mode

Data can be transferred between an external display and the SoC using the APBDMA interface. This mode is enabled by setting the LCDIF_MASTER bit to 0 and is typically used with "Smart" displays. The APBDMA module executes DMA descriptor chains to process the desired data flow sequence. The data can be either frame buffer data or display control data.

### 35.5.2 Write Data Path

LCDIF supports raster based frame buffers and there is no support for tiled buffers.

There are several options to accommodate endianness of display buffers in memory before the data is processed for the external display. The LCDIF_CTRL[INPUT_DATA_SWIZZLE] field provides the following options for data word multiplexing:

- **00 (0): No swizzle (little-endian)**
- **01 (1): Swap bytes 0 and 3, swap bytes 1 and 2 (big-endian)**
- **10 (2): Swap half-words**
- **11 (3): Swap bytes within each half-word**

The LCDIF_CTRL[WORD_LENGTH] field indicates the input data/pixel format. LCDIF_TRANSFER_COUNT register denotes how much data is contained in each frame. The LCDIF_TRANSFER_COUNT[H_COUNT] field indicates the number of pixels per line and LCDIF_TRANSFER_COUNT[V_COUNT] indicates the total number of lines per frame. The LCDIF_CTRL1[BYTE_PACKING_FORMAT] field can be used to specify which bytes within the 32-bit word are going to be valid. For example, if the entire 32-bit word is valid, LCDIF_CTRL1[BYTE_PACKING_FORMAT] should be set to 0xF, if only lower 3 bytes of each word in the frame buffer are valid, then LCDIF_CTRL1[BYTE_PACKING_FORMAT] should be set to 0x7.

The LCDIF_CTRL[LCD_DATABUS_WIDTH] field suggests the width of the bus going to the display controller. There is an option to source all 32 bits of the input word and transfer it to the output I/O display interface. If the LCDIF_CTRL[LCD_DATABUS_WIDTH] is not the same as LCDIF_CTRL[WORD_LENGTH], LCDIF will perform RGB to RGB color space conversion. For example, if the input frame has fewer bits per pixel than the display, as in a 16 bpp input frame going to 24 bpp LCD, LCDIF will pad the MSBs of each color to...
the LSBs of the same color for each pixel. If the input frame has more bits per pixel than the display, for example, 24 bpp input frame going to 16 bpp LCD, LCDIF will drop the LSBs of each color channel to convert to the lower color depth. LCDIF also has the capability to support delta pixel displays by swizzling the R, G and B colors of each pixel in the odd and even lines of the frame separately by programming the LCDIF_CTRL2[ODD_LINE_PATTERN] and the LCDIF_CTRL2[EVEN_LINE_PATTERN] bit fields. This operation occurs after the RGB-to-RGB color space conversion operation.

The following list shows how the different input/output combinations can be obtained:

- **LCDIF_CTRL[WORD_LENGTH]=1** indicates that the input is 8-bit data. Any combination of LCDIF_CTRL1[BYTE_PACKING_FORMAT] is permissible. Limitation: LCDIF_TRANSFER_COUNT[H_COUNT] must be a multiple of the sum of BYTE_PACKING_FORMAT [3], BYTE_PACKING_FORMAT [2], BYTE_PACKING_FORMAT [1] and BYTE_PACKING_FORMAT [0]. LCDIF_CTRL[LCD_DATABUS_WIDTH] must be 1, indicating an 8-bit data bus.

- **LCDIF_CTRL[WORD_LENGTH]=0** implies the input frame buffer is RGB 16 bits per pixel. LCDIF_CTRL[DATA_FORMAT_16_BIT] field determines the pixels are RGB 555 or RGB 565. Limitation: LCDIF_CTRL1[BYTE_PACKING_FORMAT] should be 0x3 or 0xC if there is only one pixel per word. If there are two pixels per word, it should be 0xF and LCDIF_TRANSFER_COUNT[H_COUNT] will be restricted to be a multiple of 2 pixels.

- **LCDIF_CTRL[WORD_LENGTH]=2** indicates that input frame buffer is RGB 18 bits per pixel, that is, RGB 666. The valid RGB values can be left-aligned or right-aligned within a 32-bit word. The alignment of the valid 18 bits within a word is indicated by the LCDIF_CTRL[DATA_FORMAT_18_BIT] bit. Limitation: LCDIF_CTRL1[BYTE_PACKING_FORMAT] can be 0x7, 0xE or 0xF. Packed pixels are not supported in this case. LCDIF_TRANSFER_COUNT[H_COUNT] can be any number.

- **LCDIF_CTRL[WORD_LENGTH]=3** indicates that the input frame-buffer is RGB 24 bits per pixel (RGB 888). If LCDIF_CTRL1[BYTE_PACKING_FORMAT] is 0x7, it indicates that there is only one pixel per 32-bit word and there is no restriction on LCDIF_TRANSFER_COUNT[H_COUNT]. This is also the option that provides 32 bit output depending on the I/O muxing options available. The fourth byte, or bits [31:24], and connected to the I/Os if this muxing is available in the chip package.
Limitation: If LCDIF_CTRL1[BYTE_PACKING_FORMAT] is 0xF, it indicates that the pixels are packed, that is, there are 4 pixels in 3 words or 12 bytes and LCDIF_TRANSFER_COUNT[H_COUNT] must be a multiple of 4 pixels.

After the RGB to RGB color space conversions, there is one more opportunity to swizzle the data before sending it out to the display or the encoder. This can be done with the LCDIF_CTRL[CSC_DATA_SWIZZLE] field, and it provides the same options as the LCDIF_CTRL[INPUT_DATA_SWIZZLE] register.

Finally, there is an option to shift the output data before sending it out to the display. This is done based on the LCDIF_CTRL[SHIFT_DIR] and LCDIF_CTRL[SHIFT_NUM_BITS] fields.

**Figure 35-2. General Operations in Write Data Path**

The examples in the following figures illustrate some different combinations of register programming for write mode. Assume that the data transferred over the system bus within a 32 bit word is organized as {A7-A0, B7-B0, C7-C0, D7-D0} in 8-bit mode and {A15-A0, B15-B0} in 16-bit mode.

In this example, all 32 bits of the input word are transferred out over an 8 bit display bus. Each byte within the 32 bit word is shifted to the right with zeros appended to bits D[7:6]. The input data bits [7:2] are shifted to the right by 2 bits and presented on the D[5:0].
Figure 35-3. Register programming for write mode

In this 8 bit display interface example, one byte of the input word is deleted and not transferred over the external 8 bit display interface. This mode could be used to transfer 24bpp pixels over the 8 bit interface. In this case, the 4th unused byte is not transferred.
Figure 35-4. Register programming for write mode

The following example uses a 16 bit display interface. Each 16 bit half word is shifted to the right by two bits with zeros appended to the most significant two bits.
Figure 35-5. Register programming for write mode

This example indicates how an unpacked frame buffer can sourced for display. Only a single 16 bit half word within the 32 bit word is transferred out via the 16 display bus.
32 Bit Word

35.5.3 LCDIF Interrupts

LCDIF supports a number of interrupts to aid controlling and status reporting of the block.

All the interrupts have individual mask bits for enabling or disabling each of them. They all get funneled through a single interrupt line connected to the interrupt collector (ICOLL).

The following list describes the different interrupts supported by LCDIF:

- Underflow interrupt is asserted when the clock domain crossing FIFO (TXFIFO) becomes empty but the block is in active display portion during that time. Software should take corrective action to make sure that this does not happen.
- In the bus master mode, the overflow interrupt will be asserted if the block has requested more data than it's FIFOs could hold.
- Cur_frame_done interrupt occurs at the end of every frame.
35.5.4 Initializing the LCDIF

This section describes write modes.

35.5.4.1 Write Modes

The following initialization steps are common to all LCDIF write modes of operation before entering any particular mode.

Initialization steps:

1. Configure the external I/Os to correctly interface the external display, when required.
2. Start the DISPLAY CLOCK (pix_clk) clock and set the appropriate frequency by programming the registers in CCM.
3. Start the BUS CLOCK (apb_clk) and set the appropriate frequency by programming the registers in CCM.
4. Bring the LCDIF out of soft reset and disable the clock gate bit.
5. Set the transfer mode of operation to bus master. The LCDIF_CTRL[MASTER] bit determines the transfer mode selected. Bus master (LCDIF_CTRL[MASTER] =1), APBDMA is the transfer mode to select.
6. Set the LCDIF_CTRL[INPUT_DATA_SWIZZLE] according to the endianness of the LCD controller. Also, set the LCDIF_CTRL[DATA_SHIFT_DIR] and LCDIF_CTRL[SHIFT_NUM_BITS] if it is required to shift the data left or right before it is output.
7. Set the LCDIF_CTRL[WORD_LENGTH] field appropriately: 0 = 16-bit input, 1 = 8-bit input, 2 = 18-bit input, 3 = 24/32-bit input. Also, select the correct 16/18/24 bit data format with the corresponding fields in LCDIF_CTRL register.
8. Set the LCDIF_CTRL1[BYTE_PACKING_FORMAT] field according to the input frame.
10. Enable the necessary IRQs.

35.5.5 DOTCLK Interface

The DOTCLK interface is another mode used in moving picture displays.

It includes the VSYNC, HSYNC, DOTCLK and (optional) ENABLE signals. The interface is popularly called the RGB interface if the ENABLE signal is present.
The DOTCLK mode writes data at high speed to the LCD, and the display operation is synchronized with the VSYNC, HSYNC, ENABLE and DOTCLK signals. The polarities, periods and pulse-widths of the sync signals are programmable using the LCDIF_VDCTRL0-4 registers. The units for the VSYNC signal must be number of horizontal lines and can be selected using the VSYNC_PULSE_WIDTH_UNIT and VSYNC_PERIOD_UNIT bit fields. The VERTICAL_WAIT_CNT is by default given the same unit as the VSYNC_PERIOD. The DISPLAY CLOCK (pix_clk) frequency is managed by the CCM.
In DOTCLK mode, LCDIF_CTRL_BYPASS_COUNT bit must be set to 1. To end the current transfer, the software should make the DOTCLK_MODE bit 0, so that all data that is currently in the LCDIF LFIFO and TXFIFO is transmitted. Once that transfer is complete, the block will automatically clear the RUN bit and issue the cur_frame_done interrupt.

### 35.5.5.1 Code Example

The following code shows an example for programming a 320x240 display.

```
NOTE
Setting up the display must be done via SPI.

// Note: Common initialization steps in Initializing the LCDIF must also be
// executed along with the following code
BF_CS1 (LCDIF_CTRL, DOTCLK_MODE, 1);
BF_CS1 (LCDIF_CTRL, BYPASS_COUNT, 1); //Always for DOTCLK mode
BF_CS1 (LCDIF_VDCTRL0, VSYNC_OEB, 0); //Vsync is always an output in the DOTCLK mode
BF_CS1 (LCDIF_VDCTRL0, VSYNC_POL, 0, HSYNC_POL, 0, DOTCLK_POL, 0, ENABLE_POL, 0);
BF_CS1 (LCDIF_VDCTRL0, ENABLE_PRESENT, 1);
BF_CS2 (LCDIF_VDCTRL0, VSYNC_PERIOD_UNIT, 1, VSYNC_PULSE_WIDTH_UNIT, 1);
BF_CS1 (LCDIF_VDCTRL1, VSYNC_PERIOD, 280);
BF_CS2 (LCDIF_VDCTRL2, HSYNC_PULSE_WIDTH, 10, HSYNC_PERIOD, 360); //Assuming
// LCD_DATABUS_WIDTH is 24bit
BF_CS2 (LCDIF_VDCTRL3, VSYNC_ONLY, 0);
BF_CS2 (LCDIF_VDCTRL3, HORIZONTAL_WAIT_CNT, 20, VERTICAL_WAIT_CNT, 20);
BF_CS1 (LCDIF_VDCTRL4, DOTCLK_H_VALID_DATA_CNT, 320); //Note that DOTCLK_V_VALID_DATA_CNT is
//implicitly assumed to be HW_LCDIF_TRANSFER_COUNT_V_COUNT
BF_CS1 (LCDIF_VDCTRL4, SYNC_SIGNALS_ON, 1);
BF_CS1 (LCDIF_CTRL, RUN, 1);
```

To stop the transfer completely, the ideal way is to make DOTCLK_MODE = 0. In that case, the block will transmit the contents in the FIFO and reset the RUN bit.

### 35.5.6 LUT

The Lookup Table (LUT) is used to expand the 8 bits pixel to 24 bits pixel before output to external displayer. This module is used when input data from memory is 8-bits in width under limited bandwidth system and external displayer has a 24 bits requirement.

There are two 256x24 bits LUT memory in LCDIF module in case of changing LUT during active display. When using LUT function, it should be initialized through single PIO register writing first. Writing data to register LCDIF_LUT0_DATA will trigger storing data to lut0 memory and increase the lut0 memory address LCDIF_LUT0_ADDR automatically. Writing data again to register LCDIF_LUT0_DATA will store the data to memory and increase the memory address accordingly. The same operation is performed while writing to LCDIF_LUT1_DATA and LCDIF_LUT1_ADDR.
After initialization, LCDIF_CUR_BUF_ADDR bit 0 determines which LUT is used during active display.

Lastly, when there is active display, it will use the lowest 8 bits LCDIF data as LUT address and output the 24 bits from the lookup table.

### 35.5.7 Panel Interface Generator (Pigeon Mode)

There are several panel interface signal outputs (CLK signal not included), each of them with dedicated timing purpose as default. This is called "Legacy Mode". Pigeon Mode is a timing mode which can be independently enabled on any of the timing signals, with a unified flexible configuration. Signals within pigeon mode can be programmed into any supported signals, and are interchangeable. The following are the legacy timing signals which support pigeon mode:

- PIGEON[00] – LCD_DATA16
- PIGEON[01] – LCD_DATA17
- PIGEON[02] – LCD_DATA18
- PIGEON[03] – LCD_DATA19
- PIGEON[04] – LCD_DATA20
- PIGEON[05] – LCD_DATA21
- PIGEON[06] – LCD_DATA22
- PIGEON[07] – LCD_DATA23
- PIGEON[08] – LCD_ENABLE
- PIGEON[09] – LCD_HSYNC
- PIGEON[10] – LCD_VSYNC

Each pigeon signal has one local counter with a configurable start point and incremental condition. It will be compared to configuration register value for signal assertion/de-assertion control, plus delta offset for data alignment and other options like polarity/logic operation. A detailed running scenario is as follows:

1. Start local counter on the MASK rising edge (reference point/start point)
2. Increment on event selected through INC_SEL
3. Count and match SET_CNT: assert signal, reset counter (SET_CNT==0 means assert immediately on MASK's rising edge)
4. Count and match CLR_CNT: de-assert signal, stop counter (CLR_CNT==0 means de-assert on MASK's falling edge)

**NOTE**

When local counter is running, further changes to MASK are not cared unless CLR_CNT==0
MASK is the start point for local counter created using a combination any of the options (ANDed) from below:

1. **STATE_MASK** = (FS\|FB\|FD\|FE) \& (LS\|LB\|LD\|LE)
   
   In this case you have 8 bits to select in which vertical/horizontal state your counter starts ticking. This is the most common use-case because timing signals generally relate to scan states.

   For example, for a line timing signal start on Line Begin phase during Frame Begin/Frame Data lines, use the configuration below:

   ![Table 35-4. State Mask Combinations](image)

<table>
<thead>
<tr>
<th>STATE_MASK</th>
<th>LS</th>
<th>LB=1</th>
<th>LD</th>
<th>LE</th>
</tr>
</thead>
<tbody>
<tr>
<td>FS</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FB=1</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FD=1</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>FE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

2. **MASK_CNT/MASK_CNT_SEL** (global counter)

   Sometimes a more accurate reference point is required, such as "line 20 in a frame", or "line 12 in Frame Begin state" or "pixel 23 in LD phase". For such use-cases, several Global Counters shared by all pigeons are provided. Global counter type (line counter/frame counter/state counter, etc.) is selected using MASK_CNT_SEL, when global counter matches the MASK_CNT value. The pigeon local counter will start ticking.

3. Use another pigeon signal as mask (SIG_LOGIC=MASK)

   For some tightly coupled signals it is possible to use one as a reference to generate another.

   INC_SEL- select local counter tick event
   a. pclk - pixel clk
   b. line - line start pulse
   c. frame - frame start pulse
   d. another - another pigeon signal

   OFFSET- offset on pclk basis: Some signals need to come out slightly earlier or later than programmed. For example, the CE type signal usually aligns with the Line Data phase, but some panels need it as one cycle pulse before Line Data. The user can set OFFSET to a negative value to achieve this.

Global counters (selectable through MASK_CNT_SEL):
• HCNT / VCNT : normal pclk counter / line counter
• HSTATE_CNT / VSTATE_CNT: similar to above, but reset when state changes
• HSTATE_CYCLE / VSTATE_CYCLE: (see figure below for definition of CYCLE/PERIOD/CNT)

Some panels have multiple Gate Drivers/Source Drivers, so Frame Data / Line Data state may be further split to match each driver, and signals such as CE[n] are only valid during part n of Line Data. For such signals, use LCDIF_PIGEON_CTRL[*_PERIOD] to specify PERIOD where CNT is reset and CYCLE is included. Then the user can select CYCLE as MASK_CNT to generate mask for CE[n].

• FRAME_CNT / FRAME_CYCLE (only for frame-crossing signals): frame cycle counter doesn't have a reset condition; use LCDIF_PIGEON_CTRL1[FRAME_CNT_CYCLES] to reset it.

![Figure 35-8. Definition of CNT, CYCLE, PERIOD](image)

The following are register settings for the figure above:
• LCDIF_PIGEON_CTRL0[LD_PERIOD]=2
• MASK_CNT_SEL = 1 // HSTATE_CYCLE
• MASK_CNT = 1 // CE[1]
• MASK_CNT = 2 // CE[2]
35.5.8 LCDIF Pin Usage by Interface Mode

The following tables detail how the LCDIF level interface pins are used based on the desired mode of operation. The chip level I/Os should also be configured to be consistent with the desired LCDIF operating mode.

**NOTE**

There is an option to internally mux the HSYNC, DOTCLK and ENABLE signals in the DOTCLK mode by setting the MUX_SYNC_SIGNALS bit in the VDCTRL0 register.

Table 35-5. Pin use in DOTCLK Mode

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>8-bit DOTCLK LCD IF</th>
<th>16-bit DOTCLK LCD IF</th>
<th>18-bit DOTCLK LCD IF</th>
<th>24-bit DOTCLK LCD IF</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCD_VSYNC</td>
<td>LCD_VSYNC</td>
<td>LCD_VSYNC</td>
<td>LCD_VSYNC</td>
<td>LCD_VSYNC</td>
</tr>
<tr>
<td>LCD_HSYNC</td>
<td>LCD_HSYNC</td>
<td>LCD_HSYNC</td>
<td>LCD_HSYNC</td>
<td>LCD_HSYNC</td>
</tr>
<tr>
<td>LCD_DOTCLK</td>
<td>LCD_DOTCLK</td>
<td>LCD_DOTCLK</td>
<td>LCD_DOTCLK</td>
<td>LCD_DOTCLK</td>
</tr>
<tr>
<td>LCD_ENABLE</td>
<td>LCD_ENABLE</td>
<td>LCD_ENABLE</td>
<td>LCD_ENABLE</td>
<td>LCD_ENABLE</td>
</tr>
<tr>
<td>LCD_DATA23 (LCD_D23)</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA23</td>
</tr>
<tr>
<td>LCD_DATA22 (LCD_D22)</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA22</td>
</tr>
<tr>
<td>LCD_DATA21 (LCD_D21)</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA21</td>
</tr>
<tr>
<td>LCD_DATA20 (LCD_D20)</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA20</td>
</tr>
<tr>
<td>LCD_DATA19 (LCD_D19)</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA19</td>
</tr>
<tr>
<td>LCD_DATA18 (LCD_D18)</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA18</td>
</tr>
<tr>
<td>LCD_DATA17 (LCD_D17)</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA17</td>
</tr>
<tr>
<td>LCD_DATA16 (LCD_D16)</td>
<td>X</td>
<td>X</td>
<td>LCD_DATA16</td>
<td>LCD_DATA16</td>
</tr>
<tr>
<td>LCD_DATA15 (LCD_D15)</td>
<td>X</td>
<td>LCD_DATA15</td>
<td>LCD_DATA15</td>
<td>LCD_DATA15</td>
</tr>
<tr>
<td>LCD_DATA14 (LCD_D14)</td>
<td>X</td>
<td>LCD_DATA14</td>
<td>LCD_DATA14</td>
<td>LCD_DATA14</td>
</tr>
<tr>
<td>LCD_DATA13 (LCD_D13)</td>
<td>X</td>
<td>LCD_DATA13</td>
<td>LCD_DATA13</td>
<td>LCD_DATA13</td>
</tr>
<tr>
<td>LCD_DATA12 (LCD_D12)</td>
<td>X</td>
<td>LCD_DATA12</td>
<td>LCD_DATA12</td>
<td>LCD_DATA12</td>
</tr>
<tr>
<td>LCD_DATA11 (LCD_D11)</td>
<td>X</td>
<td>LCD_DATA11</td>
<td>LCD_DATA11</td>
<td>LCD_DATA11</td>
</tr>
<tr>
<td>LCD_DATA10 (LCD_D10)</td>
<td>X</td>
<td>LCD_DATA10</td>
<td>LCD_DATA10</td>
<td>LCD_DATA10</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 35-5. Pin use in DOTCLK Mode (continued)

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>8-bit DOTCLK LCD IF</th>
<th>16-bit DOTCLK LCD IF</th>
<th>18-bit DOTCLK LCD IF</th>
<th>24-bit DOTCLK LCD IF</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCD_DATA09 (LCD_D9)</td>
<td>X</td>
<td>LCD_DATA09</td>
<td>LCD_DATA09</td>
<td>LCD_DATA09</td>
</tr>
<tr>
<td>LCD_DATA08 (LCD_D8)</td>
<td>X</td>
<td>LCD_DATA08</td>
<td>LCD_DATA08</td>
<td>LCD_DATA08</td>
</tr>
<tr>
<td>LCD_DATA07 (LCD_D7)</td>
<td>LCD_DATA07</td>
<td>LCD_DATA07</td>
<td>LCD_DATA07</td>
<td>LCD_DATA07</td>
</tr>
<tr>
<td>LCD_DATA06 (LCD_D6)</td>
<td>LCD_DATA06</td>
<td>LCD_DATA06</td>
<td>LCD_DATA06</td>
<td>LCD_DATA06</td>
</tr>
<tr>
<td>LCD_DATA05 (LCD_D5)</td>
<td>LCD_DATA05</td>
<td>LCD_DATA05</td>
<td>LCD_DATA05</td>
<td>LCD_DATA05</td>
</tr>
<tr>
<td>LCD_DATA04 (LCD_D4)</td>
<td>LCD_DATA04</td>
<td>LCD_DATA04</td>
<td>LCD_DATA04</td>
<td>LCD_DATA04</td>
</tr>
<tr>
<td>LCD_DATA03 (LCD_D3)</td>
<td>LCD_DATA03</td>
<td>LCD_DATA03</td>
<td>LCD_DATA03</td>
<td>LCD_DATA03</td>
</tr>
<tr>
<td>LCD_DATA02 (LCD_D2)</td>
<td>LCD_DATA02</td>
<td>LCD_DATA02</td>
<td>LCD_DATA02</td>
<td>LCD_DATA02</td>
</tr>
<tr>
<td>LCD_DATA01 (LCD_D1)</td>
<td>LCD_DATA01</td>
<td>LCD_DATA01</td>
<td>LCD_DATA01</td>
<td>LCD_DATA01</td>
</tr>
<tr>
<td>LCD_DATA00 (LCD_D0)</td>
<td>LCD_DATA00</td>
<td>LCD_DATA00</td>
<td>LCD_DATA00</td>
<td>LCD_DATA00</td>
</tr>
<tr>
<td>LCD_RESET</td>
<td>LCD_RESET</td>
<td>LCD_RESET</td>
<td>LCD_RESET</td>
<td>LCD_RESET</td>
</tr>
</tbody>
</table>

### 35.6 Behavior During Reset

BUS CLOCK (apb_clk) and DISPLAY CLOCK (pix_clk) must be running before making any changes to SFTRST or CLKGATE bits.

A soft reset (SFTRST) can take multiple clock periods to complete, so do not set CLKGATE when setting SFTRST.

The reset process gates the clocks automatically.

### 35.7 LCDIF Memory Map/Register Definition

Some of the LCDIF registers (XXX_SET, XXX_CLR, and XXX_TOG) allow direct bit field masking and access.

- When writing 1 to XXX_SET bit fields, these registers allow setting the masked 1 bit fields, while keeping unchanged all bit fields which remain on 0 logic state.
• When writing 1 to XXX_CLR bit fields, these registers allow clearing the masked 1 bit fields, while keeping unchanged all other bit fields which remained on 0 logic state.

• When writing 1 to XXX_TOG bit fields, these registers allow inverting the logic state of all masked 1 bit fields, while they keep unchanged the remaining bit fields which were kept on 0 logic state.

**LCDIF Hardware Register Format Summary**

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_8000</td>
<td>LCDIF General Control Register (LCDIF_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>35.7.1/1865</td>
</tr>
<tr>
<td>402B_8004</td>
<td>LCDIF General Control Register (LCDIF_CTRL_SET)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>35.7.1/1865</td>
</tr>
<tr>
<td>402B_8008</td>
<td>LCDIF General Control Register (LCDIF_CTRL_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>35.7.1/1865</td>
</tr>
<tr>
<td>402B_800C</td>
<td>LCDIF General Control Register (LCDIF_CTRL_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>35.7.1/1865</td>
</tr>
<tr>
<td>402B_8010</td>
<td>LCDIF General Control1 Register (LCDIF_CTRL1)</td>
<td>32</td>
<td>R/W</td>
<td>000F_0000h</td>
<td>35.7.2/1867</td>
</tr>
<tr>
<td>402B_8014</td>
<td>LCDIF General Control1 Register (LCDIF_CTRL1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>000F_0000h</td>
<td>35.7.2/1867</td>
</tr>
<tr>
<td>402B_8018</td>
<td>LCDIF General Control1 Register (LCDIF_CTRL1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>000F_0000h</td>
<td>35.7.2/1867</td>
</tr>
<tr>
<td>402B_801C</td>
<td>LCDIF General Control1 Register (LCDIF_CTRL1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>000F_0000h</td>
<td>35.7.2/1867</td>
</tr>
<tr>
<td>402B_8020</td>
<td>LCDIF General Control2 Register (LCDIF_CTRL2)</td>
<td>32</td>
<td>R/W</td>
<td>0020_0000h</td>
<td>35.7.3/1870</td>
</tr>
<tr>
<td>402B_8024</td>
<td>LCDIF General Control2 Register (LCDIF_CTRL2_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0020_0000h</td>
<td>35.7.3/1870</td>
</tr>
<tr>
<td>402B_8028</td>
<td>LCDIF General Control2 Register (LCDIF_CTRL2_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0020_0000h</td>
<td>35.7.3/1870</td>
</tr>
<tr>
<td>402B_802C</td>
<td>LCDIF General Control2 Register (LCDIF_CTRL2_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0020_0000h</td>
<td>35.7.3/1870</td>
</tr>
<tr>
<td>402B_8030</td>
<td>LCDIF Horizontal and Vertical Valid Data Count Register (LCDIF_TRANSFER_COUNT)</td>
<td>32</td>
<td>R/W</td>
<td>0001_0000h</td>
<td>35.7.4/1872</td>
</tr>
<tr>
<td>402B_8040</td>
<td>LCD Interface Current Buffer Address Register (LCDIF_CUR_BUF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.5/1872</td>
</tr>
<tr>
<td>402B_8050</td>
<td>LCD Interface Next Buffer Address Register (LCDIF_NEXT_BUF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.6/1873</td>
</tr>
<tr>
<td>402B_8070</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register0 (LCDIF_VDCTRL0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.7/1873</td>
</tr>
<tr>
<td>402B_8074</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register0 (LCDIF_VDCTRL0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.7/1873</td>
</tr>
<tr>
<td>402B_8078</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register0 (LCDIF_VDCTRL0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.7/1873</td>
</tr>
<tr>
<td>402B_807C</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register0 (LCDIF_VDCTRL0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.7/1873</td>
</tr>
<tr>
<td>402B_8080</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register1 (LCDIF_VDCTRL1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.8/1875</td>
</tr>
<tr>
<td>402B_8090</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register2 (LCDIF_VDCTRL2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.9/1875</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_80A0</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register3 (LCDIF_VDCTRL3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.10/1876</td>
</tr>
<tr>
<td>402B_80B0</td>
<td>LCDIF VSYNC Mode and Dotclk Mode Control Register4 (LCDIF_VDCTRL4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.11/1877</td>
</tr>
<tr>
<td>402B_8190</td>
<td>Bus Master Error Status Register (LCDIF_BM_ERROR_STAT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.12/1878</td>
</tr>
<tr>
<td>402B_81A0</td>
<td>CRC Status Register (LCDIF_CRC_STAT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.13/1878</td>
</tr>
<tr>
<td>402B_81B0</td>
<td>LCD Interface Status Register (LCDIF_STAT)</td>
<td>32</td>
<td>R</td>
<td>9500_0000h</td>
<td>35.7.14/1879</td>
</tr>
<tr>
<td>402B_8380</td>
<td>LCDIF Pigeon Mode Control0 Register (LCDIF_PIGEONCTRL0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.15/1881</td>
</tr>
<tr>
<td>402B_8384</td>
<td>LCDIF Pigeon Mode Control0 Register (LCDIF_PIGEONCTRL0_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.15/1881</td>
</tr>
<tr>
<td>402B_8388</td>
<td>LCDIF Pigeon Mode Control0 Register (LCDIF_PIGEONCTRL0_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.15/1881</td>
</tr>
<tr>
<td>402B_838C</td>
<td>LCDIF Pigeon Mode Control0 Register (LCDIF_PIGEONCTRL0_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.15/1881</td>
</tr>
<tr>
<td>402B_8390</td>
<td>LCDIF Pigeon Mode Control1 Register (LCDIF_PIGEONCTRL1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.16/1881</td>
</tr>
<tr>
<td>402B_8394</td>
<td>LCDIF Pigeon Mode Control1 Register (LCDIF_PIGEONCTRL1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.16/1881</td>
</tr>
<tr>
<td>402B_8398</td>
<td>LCDIF Pigeon Mode Control1 Register (LCDIF_PIGEONCTRL1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.16/1881</td>
</tr>
<tr>
<td>402B_839C</td>
<td>LCDIF Pigeon Mode Control1 Register (LCDIF_PIGEONCTRL1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.16/1881</td>
</tr>
<tr>
<td>402B_83A0</td>
<td>LCDIF Pigeon Mode Control2 Register (LCDIF_PIGEONCTRL2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.17/1882</td>
</tr>
<tr>
<td>402B_83A4</td>
<td>LCDIF Pigeon Mode Control2 Register (LCDIF_PIGEONCTRL2_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.17/1882</td>
</tr>
<tr>
<td>402B_83A8</td>
<td>LCDIF Pigeon Mode Control2 Register (LCDIF_PIGEONCTRL2_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.17/1882</td>
</tr>
<tr>
<td>402B_83AC</td>
<td>LCDIF Pigeon Mode Control2 Register (LCDIF_PIGEONCTRL2_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.17/1882</td>
</tr>
<tr>
<td>402B_8800</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_0_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8810</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_0_1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_8820</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_0_2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8840</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_1_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8850</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_1_1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>Absolute address (hex)</td>
<td>Register name</td>
<td>Width (in bits)</td>
<td>Access</td>
<td>Reset value</td>
<td>Section/page</td>
</tr>
<tr>
<td>-----------------------</td>
<td>-----------------------------------------------------</td>
<td>-----------------</td>
<td>--------</td>
<td>-------------------</td>
<td>--------------</td>
</tr>
<tr>
<td>402B_8860</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8880</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8890</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_88A0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_88C0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_88D0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_88E0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8900</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8910</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_8920</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8940</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8950</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_8960</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8980</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8990</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_89A0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_89C0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_89D0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_89E0</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8A00</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8A10</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_8A20</td>
<td>Panel Interface Signal Generator Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## LCDIF Memory Map/Register Definition

### LCDIF memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_8A40</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_9_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8A50</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_9_1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_8A60</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_9_2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8A80</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_10_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8A90</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_10_1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_8AA0</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_10_2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8AC0</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_11_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.18/1883</td>
</tr>
<tr>
<td>402B_8AD0</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_11_1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.19/1884</td>
</tr>
<tr>
<td>402B_8AE0</td>
<td>Panel Interface Signal Generator Register (LCDIF_PIGEON_11_2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.20/1884</td>
</tr>
<tr>
<td>402B_8B00</td>
<td>Lookup Table Data Register. (LCDIF_LUT_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0001h</td>
<td>35.7.21/1885</td>
</tr>
<tr>
<td>402B_8B10</td>
<td>Lookup Table Control Register. (LCDIF_LUT0_ADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.22/1886</td>
</tr>
<tr>
<td>402B_8B20</td>
<td>Lookup Table Data Register. (LCDIF_LUT0_DATA)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.23/1886</td>
</tr>
<tr>
<td>402B_8B30</td>
<td>Lookup Table Control Register. (LCDIF_LUT1_ADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.24/1887</td>
</tr>
<tr>
<td>402B_8B40</td>
<td>Lookup Table Data Register. (LCDIF_LUT1_DATA)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>35.7.25/1887</td>
</tr>
</tbody>
</table>
35.7.1 LCDIF General Control Register (LCDIF_CTRLn)

The LCD Interface Control Register provides overall control of the LCDIF block. The LCDIF Control Register provides a variety of control functions to the programmer. These functions allow the interface to be very flexible to work with a variety of LCD controllers, and to minimize overhead and increase performance of LCD programming. The register has been organized such that switching between the different LCD modes can be done with minimum PIO writes.

Address: 402B_8000h base + 0h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>SFTRST</th>
<th>CLKGATE</th>
<th>Reserved</th>
<th>Reserved</th>
<th>DATA_SHIFT_DIR</th>
<th>SHIFT_NUM_BITS</th>
<th>Reserved</th>
<th>BYPASS_COUNT</th>
<th>Reserved</th>
<th>DOTCLK_MODE</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>INPUT_DATA_SWIZZLE</th>
<th>CSC_DATA_SWIZZLE</th>
<th>LCD_DATABUS_WIDTH</th>
<th>WORD_LENGTH</th>
<th>Reserved</th>
<th>ENABLE_PXP_HANDSHAKE</th>
<th>MASTER</th>
<th>Reserved</th>
<th>DATA_FORMAT_16_BIT</th>
<th>DATA_FORMAT_18_BIT</th>
<th>DATA_FORMAT_24_BIT</th>
<th>RUN</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 SFTRST</td>
<td>This bit must be set to zero to enable normal operation of the LCDIF. When set to one, it forces a block level reset.</td>
</tr>
<tr>
<td>30 CLKGATE</td>
<td>This bit must be set to zero for normal operation. When set to one it gates off the clocks to the block.</td>
</tr>
<tr>
<td>29 -</td>
<td>Reserved</td>
</tr>
<tr>
<td>28 -</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>27-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>26 DATA_SHIFT_DIR</td>
<td>Use this bit to determine the direction of shift of transmit data.</td>
</tr>
<tr>
<td>0x0</td>
<td>TXDATA_SHIFT_LEFT — Data to be transmitted is shifted LEFT by SHIFT_NUM_BITS bits.</td>
</tr>
<tr>
<td>0x1</td>
<td>TXDATA_SHIFT_RIGHT — Data to be transmitted is shifted RIGHT by SHIFT_NUMBITS bits.</td>
</tr>
<tr>
<td>25–21 SHIFT_NUM_BITS</td>
<td>The data to be transmitted is shifted left or right by this number of bits.</td>
</tr>
<tr>
<td>20-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>19 BYPASS_COUNT</td>
<td>When this bit is 0, it means that LCDIF will stop the block operation and turn off the RUN bit after the amount of data indicated by the LCDIF_TRANSFER_COUNT register has been transferred out. When this bit is set to 1, the block will continue normal operation indefinitely until it is told to stop. This bit must be 0 in MPU and VSYNC modes, and must be 1 in DOTCLK and DVI modes of operation.</td>
</tr>
<tr>
<td>18-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>17 DOTCLK_MODE</td>
<td>Set this bit to 1 to make the hardware go into the DOTCLK mode, i.e. VSYNC/HSYNC/DOTCLK/ENABLE interface mode. ENABLE is optional, selected by the ENABLE_PRESENT bit. Toggle this bit from 1 to 0 to make the hardware go out of DOTCLK mode after completing all data transfer and deasserting the RUN bit.</td>
</tr>
<tr>
<td>16-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>15–14 INPUT_DATA_SWIZZLE</td>
<td>This field specifies how to swap the bytes fetched by the bus master interface. The swizzle function is independent of the WORD_LENGTH bit. The supported swizzle configurations are:</td>
</tr>
<tr>
<td>13–12 CSC_DATA_SWIZZLE</td>
<td>This field specifies how to swap the bytes after the data has been converted into an internal representation of 24 bits per pixel and before it is transmitted over the LCD interface bus. The data is always transmitted with the least significant byte/hword (half word) first after the swizzle takes place. So, INPUT_DATA_SWIZZLE takes place first on the incoming data, and then CSC_DATA_SWIZZLE is applied. The swizzle function is independent of the WORD_LENGTH or the LCD_DATABUS_WIDTH fields. If RGB_TO_YCRCB422_CSC bit is set, the swizzle occurs on the Y, Cb, Cr values. The supported swizzle configurations are:</td>
</tr>
<tr>
<td>11–10 LCD_DATABUS_WIDTH</td>
<td>LCD Data bus transfer width.</td>
</tr>
<tr>
<td></td>
<td>0x0 16_BIT — 16-bit data bus mode.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### LCDIF_CTRL Field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x1 8_BIT</td>
<td>8-bit data bus mode.</td>
</tr>
<tr>
<td>0x2 18_BIT</td>
<td>18-bit data bus mode.</td>
</tr>
<tr>
<td>0x3 24_BIT</td>
<td>24-bit data bus mode.</td>
</tr>
<tr>
<td>9–8 WORD_LENGTH</td>
<td>Input data format.</td>
</tr>
<tr>
<td>0x0 16_BIT</td>
<td>Input data is 16 bits per pixel.</td>
</tr>
<tr>
<td>0x1 8_BIT</td>
<td>Input data is 8 bits wide.</td>
</tr>
<tr>
<td>0x2 18_BIT</td>
<td>Input data is 18 bits per pixel.</td>
</tr>
<tr>
<td>0x3 24_BIT</td>
<td>Input data is 24 bits per pixel.</td>
</tr>
<tr>
<td>7</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>6 ENABLE_PXP_HANDSHAKE</td>
<td>If this bit is set and LCDIF_MASTER bit is set, the LCDIF will act as bus master and the handshake mechanism between LCDIF and PXP will be turned on. If LCDIF_MASTER bit is not set, this bit becomes a don't care.</td>
</tr>
<tr>
<td>5 MASTER</td>
<td>Set this bit to make the LCDIF act as a bus master. If this bit is reset, the LCDIF will support APBDMA or PIO mode.</td>
</tr>
<tr>
<td>4 RS R V D 0</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>3 DATA_FORMAT_16_BIT</td>
<td>When this bit is 1 and WORD_LENGTH = 0, it implies that the 16-bit data is in ARGB555 format. When this bit is 0 and WORD_LENGTH = 0, it implies that the 16-bit data is in RGB565 format. When WORD_LENGTH is not 0, this bit does not care.</td>
</tr>
<tr>
<td>2 DATA_FORMAT_18_BIT</td>
<td>Used only when WORD_LENGTH = 2, i.e. 18-bit.</td>
</tr>
<tr>
<td>0x0 LOWER_18_BITS_VALID</td>
<td>Data input to the block is in 18 bpp format, such that lower 18 bits contain RGB 666 and upper 14 bits do not contain any useful data.</td>
</tr>
<tr>
<td>0x1 UPPER_18_BITS_VALID</td>
<td>Data input to the block is in 18 bpp format, such that upper 18 bits contain RGB 666 and lower 14 bits do not contain any useful data.</td>
</tr>
<tr>
<td>1 DATA_FORMAT_24_BIT</td>
<td>Used only when WORD_LENGTH = 3, i.e. 24-bit. Note that this applies to both packed and unpacked 24-bit data.</td>
</tr>
<tr>
<td>0x0 ALL_24_BITS_VALID</td>
<td>Data input to the block is in 24 bpp format, such that all RGB 888 data is contained in 24 bits.</td>
</tr>
<tr>
<td>0x1 DROP_UPPER_2_BITS_PER_BYTE</td>
<td>Data input to the block is actually RGB 18 bpp, but there is 1 color per byte, hence the upper 2 bits in each byte do not contain any useful data, and should be dropped.</td>
</tr>
<tr>
<td>0 RUN</td>
<td>When this bit is set by software, the LCDIF will begin transferring data between the SoC and the display. This bit must remain set until the operation is complete.</td>
</tr>
</tbody>
</table>

### 35.7.2 LCDIF General Control1 Register (LCDIF_CTRL1n)

The LCDIF Control Register provides overall control of the LCDIF block.

The LCDIF Control1 Register provides additional programming to the LCDIF. It implements some bits which are unlikely to change often in a particular application. It also carries interrupt-related bits which are common across more than one mode of operation.
Address: 402B_8000h base + 10h offset + (4d × i), where i=0d to 3d

### LCDIF_CTRL1n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 IMAGE_DATA_SELECT</td>
<td>Command Mode MIPI image data select bit. This bit will control MIPI DSI SYS_ADDR[1]. This bit should only be changed when RUN is 0.</td>
</tr>
<tr>
<td>30 CS_OUT_SELECT</td>
<td>This bit is CS0/CS1 valid select signals. When set 0x0, LCDIF_CSn0 output valid, and LCSIF_CSn1 will always output 1. When set to 0x1, LCDIF_CSn1 output valid, and LCSIF_CSn0 will always output 1.</td>
</tr>
<tr>
<td>29–28</td>
<td>Reserved. Write as 0.</td>
</tr>
<tr>
<td>27</td>
<td>This field is reserved. Reserved bits. Write as 0.</td>
</tr>
<tr>
<td>26 BM_ERROR_IRQ_EN</td>
<td>This bit is set to enable bus master error interrupt in the LCDIF master mode.</td>
</tr>
<tr>
<td>25 BM_ERROR_IRQ</td>
<td>This bit is set to indicate that an interrupt is requested by the LCDIF block. This bit is cleared by software by writing a one to its SCT clear address. This bit will be set when the LCDIF is in master mode and an error response was returned by the slave.</td>
</tr>
<tr>
<td>0x0 NO_REQUEST — No Interrupt Request Pending.</td>
<td></td>
</tr>
<tr>
<td>0x1 REQUEST — Interrupt Request Pending.</td>
<td></td>
</tr>
<tr>
<td>24 RECOVER_ON_UNDERFLOW</td>
<td>Set this bit to enable the LCDIF block to recover in the next field/frame if there was an underflow in the current field/frame.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### LCDIF_CTRL1n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>23 INTERLACE_ FIELDS</td>
<td>Set this bit if it is required that the LCDIF block fetches odd lines in one field and even lines in the other field. It will work only if LCDIF_MASTER is set to 1.</td>
</tr>
<tr>
<td>22 START_ INTERLACE_ FROM_ SECOND_FIELD</td>
<td>The default is to grab the odd lines first and then the even lines. Set this bit if it is required to grab the even lines first and then the odd lines. (Line numbers start from 1, so odd lines are 1,3,5,etc. and even lines are 2,4,6, etc.)</td>
</tr>
<tr>
<td>21 FIFO_CLEAR</td>
<td>Set this bit to clear all the data in the latency FIFO (LFIFO), TXFIFO and the RXFIFO.</td>
</tr>
<tr>
<td>20 IRQ_ON_ ALTERNATE_ FIELDS</td>
<td>If this bit is set, the LCDIF block will assert the cur_frame_done interrupt only on alternate fields, otherwise it will issue the interrupt on both odd and even field. This bit is mostly relevant if INTERLACE_ FIELDS is set.</td>
</tr>
<tr>
<td>19–16 BYTE_ PACKING_ FORMAT</td>
<td>This bitfield is used to show which data bytes in a 32-bit word are valid. Default value 0xf indicates that all bytes are valid. For 8-bit transfers, any combination in this bitfield will mean valid data is present in the corresponding bytes. The 16-bit mode, a 16-bit half-word is valid only if adjacent bits [1:0] or [3:2] or both are 1. A value of 0x0 will mean that none of the bytes are valid and should not be used. For example, set the bit field value to 0x7 if the display data is arranged in the 24-bit unpacked format (A-R-G-B where A value does not have be transmitted).</td>
</tr>
<tr>
<td>15 OVERFLOW_ IRQ_EN</td>
<td>This bit is set to enable an overflow interrupt in the TXFIFO in the write mode.</td>
</tr>
<tr>
<td>14 UNDERFLOW_ IRQ_EN</td>
<td>This bit is set to enable an underflow interrupt in the TXFIFO in the write mode.</td>
</tr>
<tr>
<td>13 CUR_FRAME_ DONE_IRQ_EN</td>
<td>This bit is set to 1 enable an interrupt every time the hardware enters in the vertical blanking state.</td>
</tr>
<tr>
<td>12 VSYNC_EDGE_ IRQ_EN</td>
<td>This bit is set to enable an interrupt every time the hardware encounters the leading VSYNC edge in the VSYNC and DOTCLK modes, or the beginning of every field in DVI mode.</td>
</tr>
<tr>
<td>11 OVERFLOW_ IRQ</td>
<td>This bit is set to indicate that an interrupt is requested by the LCDIF block. This bit is cleared by software by writing a one to its SCT clear address. A latency FIFO (LFIFO) overflow in the write mode (MPU/ VSYNC/DOTCLK/DVI mode) was detected, data samples have been lost.</td>
</tr>
<tr>
<td>10 UNDERFLOW_ IRQ</td>
<td>This bit is set to indicate that an interrupt is requested by the LCDIF block. This bit is cleared by software by writing a one to its SCT clear address. A TXFIFO underflow in the write mode (MPU/VSYNC/ DOTCLK/DVI mode) was detected. Could produce an error in the DOTCLK / DVI modes.</td>
</tr>
<tr>
<td>9 CUR_FRAME_ DONE_IRQ</td>
<td>This bit is set to indicate that an interrupt is requested by the LCDIF block. This bit is cleared by software by writing a one to its SCT clear address. It indicates that the hardware has completed transmitting the current frame and is in the vertical blanking period in the DOTCLK/DVI modes. In the MPU and VSYNC modes, this IRQ is asserted at the end of the data transfer indicated by LCDIF_TRANSFER_COUNT register.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### LCDIF_CTRL1n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0</td>
<td><strong>NO_REQUEST</strong> — No Interrupt Request Pending.</td>
</tr>
<tr>
<td>0x1</td>
<td><strong>REQUEST</strong> — Interrupt Request Pending.</td>
</tr>
<tr>
<td>8</td>
<td>VSYNC_EDGE_IRQ</td>
</tr>
<tr>
<td></td>
<td>This bit is set to indicate that an interrupt is requested by the LCDIF block. This bit is cleared by software by writing a one to its SCT clear address. It is set whenever the leading VSYNC edge is detected in the VSYNC and DOTCLK modes. In the DVI mode, it is asserted every time the block enters a new field.</td>
</tr>
<tr>
<td>0x0</td>
<td><strong>NO_REQUEST</strong> — No Interrupt Request Pending.</td>
</tr>
<tr>
<td>0x1</td>
<td><strong>REQUEST</strong> — Interrupt Request Pending.</td>
</tr>
<tr>
<td>7–3</td>
<td>RSRVD0</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved bits. Write as 0.</td>
</tr>
<tr>
<td>2</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved.</td>
</tr>
<tr>
<td>0</td>
<td>-</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

### 35.7.3 LCDIF General Control2 Register (LCDIF_CTRL2n)

The LCDIF Control Register provides overall control of the LCDIF block.

The LCDIF Control2 Register provides additional programming to the LCDIF. It implements some bits which are unlikely to change often in a particular application.

Address: 402B_8000h base + 20h offset + (4d × i), where i=0d to 3d
### LCDIF_CTRL2n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 RSRVD5</td>
<td>This field is reserved. Reserved bits. Write as 0.</td>
</tr>
<tr>
<td>23–21 OUTSTANDING_REQS</td>
<td>This bitfield indicates the maximum number of outstanding transactions that LCDIF should request when it is acting as a bus master. Default is 2 outstanding transactions.</td>
</tr>
<tr>
<td></td>
<td>0x0 REQ_1 —</td>
</tr>
<tr>
<td></td>
<td>0x1 REQ_2 —</td>
</tr>
<tr>
<td></td>
<td>0x2 REQ_4 —</td>
</tr>
<tr>
<td></td>
<td>0x3 REQ_8 —</td>
</tr>
<tr>
<td></td>
<td>0x4 REQ_16 —</td>
</tr>
<tr>
<td>20 BURST_LEN_8</td>
<td>By default, when the LCDIF is in the bus master mode, it will issue AXI bursts of length 16 (except when in packed 24 bpp mode, it will issue bursts of length 15). When this bit is set to 1, the block will issue bursts of length 8 (except when in packed 24 bpp mode, it will issue bursts of length 9). Note that this bitfield is only applicable when LCDIF_MASTER is set to 1.</td>
</tr>
<tr>
<td>19 RSRVD4</td>
<td>This field is reserved. Reserved bits. Write as 0.</td>
</tr>
<tr>
<td>18–16 ODD_LINE_PATTERN</td>
<td>This field determines the order of the RGB components of each pixel in ODD lines (line numbers 1,3,5,...).</td>
</tr>
<tr>
<td></td>
<td>0x0 RGB —</td>
</tr>
<tr>
<td></td>
<td>0x1 RBG —</td>
</tr>
<tr>
<td></td>
<td>0x2 GBR —</td>
</tr>
<tr>
<td></td>
<td>0x3 GRB —</td>
</tr>
<tr>
<td></td>
<td>0x4 BRG —</td>
</tr>
<tr>
<td></td>
<td>0x5 BGR —</td>
</tr>
<tr>
<td>15 RSRVD3</td>
<td>This field is reserved. Reserved bits. Write as 0.</td>
</tr>
<tr>
<td>14–12 EVEN_LINE_PATTERN</td>
<td>This field determines the order of the RGB components of each pixel in EVEN lines (line numbers 2,4,6,...).</td>
</tr>
<tr>
<td></td>
<td>0x0 RGB —</td>
</tr>
<tr>
<td></td>
<td>0x1 RBG —</td>
</tr>
<tr>
<td></td>
<td>0x2 GBR —</td>
</tr>
<tr>
<td></td>
<td>0x3 GRB —</td>
</tr>
<tr>
<td></td>
<td>0x4 BRG —</td>
</tr>
<tr>
<td></td>
<td>0x5 BGR —</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>RSRVD0</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved bits. Write as 0.</td>
</tr>
</tbody>
</table>

35.7.4 LCDIF Horizontal and Vertical Valid Data Count Register (LCDIF_TRANSFER_COUNT)

This register tells the LCDIF how much data will be sent for this frame, or transaction. The total number of words is a product of the V_COUNT and H_COUNT fields. The word size is specified by the WORD_LENGTH field.

This register gives the dimensions of the input frame. For normal operation, but V_COUNT and H_COUNT should be non-zero.

Address: 402B_8000h base + 30h offset = 402B_8030h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Number of horizontal lines per frame which contain valid data. In DOTCLK mode, V_COUNT should be the same as the number of active horizontal lines in a progressive frame.</td>
</tr>
<tr>
<td>V_COUNT</td>
<td>Number of horizontal lines per frame which contain valid data. In DOTCLK mode, V_COUNT should be the same as the number of active horizontal lines in a progressive frame.</td>
</tr>
<tr>
<td>H_COUNT</td>
<td>Total valid data (pixels) in each horizontal line. The data size is given by the WORD_LENGTH. In 24-bit packed format (WORD_LENGTH=0x3, BYTE_PACKING_FORMAT=0xF), the H_COUNT must be a multiple of 4 pixels. In 16-bit packed format (WORD_LENGTH=0x0, BYTE_PACKING_FORMAT=0xF), the H_COUNT must be a multiple of 2 pixels.</td>
</tr>
</tbody>
</table>

35.7.5 LCD Interface Current Buffer Address Register (LCDIF_CUR_BUF)

This register indicates the address of the current frame being transmitted by LCDIF.

When the LCDIF is behaving as a master, this address points to the address of the current frame of data being sent out via the LCDIF. When the current frame is done, the LCDIF block will assert the cur_frame_done interrupt for software to take action. The block will also copy the LCDIF_NEXT_BUF_ADDR into this bitfield so that the software can program the next frame address into the LCDIF_NEXT_BUF_ADDR bitfield. This address must always be double-word aligned.
Address: 402B_8000h base + 40h offset = 402B_8040h

### LCDIF_CUR_BUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Address of the current frame being transmitted by LCDIF.</td>
</tr>
</tbody>
</table>

#### 35.7.6 LCD Interface Next Buffer Address Register (LCDIF_NEXT_BUF)

This register indicates the address of next frame that will be transmitted by LCDIF.

When the LCDIF is behaving as a master, this address points to the address of the next frame of data that will be sent out via the LCDIF. It is up to the software to make sure that this register is programmed before the end of the current frame, otherwise it might result in old data going out the LCDIF. This address must always be double-word aligned.

Address: 402B_8000h base + 50h offset = 402B_8050h

### LCDIF_NEXT_BUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Address of the next frame that will be transmitted by LCDIF.</td>
</tr>
</tbody>
</table>

#### 35.7.7 LCDIF VSYNC Mode and Dotclk Mode Control Register0 (LCDIF_VDCTRL0n)

This register is used to control the VSYNC and DOTCLK modes of the LCDIF so as to work with different types of LCDs like moving picture displays and delta pixel displays.

This register gives general programmability to the VSYNC signal including polarity, direction, pulse width, etc.
Address: 402B_8000h base + 70h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–29 RSRVD2</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This field is reserved. Reserved bits. Write as 0.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>28 ENABLE_PRESENT</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Setting this bit to 1 will make the hardware generate the ENABLE signal in the DOTCLK mode, thereby making it the true RGB interface along with the remaining three signals VSYNC, HSYNC and DOTCLK.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>27 VSYNC_POL</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Default 0 active low during VSYNC_PULSE_WIDTH time and will be high during the rest of the VSYNC period. Set it to 1 to invert the polarity.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>26 HSYNC_POL</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Default 0 active low during HSYNC_PULSE_WIDTH time and will be high during the rest of the HSYNC period. Set it to 1 to invert the polarity.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>25 DOTCLK_POL</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Default is data launched at negative edge of DOTCLK and captured at positive edge. Set it to 1 to invert the polarity. Set it to 0 in DVI mode.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>24 ENABLE_POL</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Default 0 active low during valid data transfer on each horizontal line.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>23–22 RSRVD1</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This field is reserved. Reserved bits. Write as 0.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>21 VSYNC_PERIOD_UNIT</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Default 0 for counting VSYNC_PERIOD in terms of DISPLAY CLOCK (pix_clk) cycles. Set it to 1 to count in terms of complete horizontal lines. DISPLAY CLOCK (pix_clk) cycles should be used in the VSYNC mode, while horizontal line should be used in the DOTCLK mode.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>20 VSYNC_PULSE_WIDTH_UNIT</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Default 0 for counting VSYNC_PULSE_WIDTH in terms of DISPLAY CLOCK (pix_clk) cycles. Set it to 1 to count in terms of complete horizontal lines.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>19 HALF_LINE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Setting this bit to 1 will make the total VSYNC period equal to the VSYNC_PERIOD field plus half the HORIZONTAL_PERIOD field (i.e. VSYNC_PERIOD field plus half horizontal line), otherwise it is just VSYNC_PERIOD. Should be only used in the DOTCLK mode, not in the VSYNC interface mode.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>18 HALF_LINE_MODE</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>When this bit is 0, the first field (VSYNC period) will end in half a horizontal line and the second field will begin with half a horizontal line. When this bit is 1, all fields will end with half a horizontal line, and none will begin with half a horizontal line.</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
Field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VSYNC_PULSE_WIDTH</td>
<td>Number of units for which VSYNC signal is active. For the DOTCLK mode, the unit is determined by the VSYNC_PULSE_WIDTH_UNIT. If the VSYNC_PULSE_WIDTH_UNIT is 0 for DOTCLK mode, VSYNC_PULSE_WIDTH must be less than HSYNC_PERIOD. For the VSYNC interface mode, it should be in terms of number of DISPLAY CLOCK (pix_clk) cycles only.</td>
</tr>
</tbody>
</table>

35.7.8 LCDIF VSYNC Mode and Dotclk Mode Control Register1 (LCDIF_VDCTRL1)

This register is used to control the VSYNC signal in the VSYNC and DOTCLK modes of the block.

This register determines the period and duty cycle of the VSYNC signal when it is generated in the block.

Address: 402B_8000h base + 80h offset = 402B_8080h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>VSYNC_PERIOD</td>
<td>R/W</td>
</tr>
</tbody>
</table>

**LCDIF_VDCTRL1 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>VSYNC_PERIOD</td>
<td>Total number of units between two positive or two negative edges of the VSYNC signal. If HALF_LINE is set, it is implicitly calculated to be VSYNC_PERIOD plus half HSYNC_PERIOD.</td>
</tr>
</tbody>
</table>

35.7.9 LCDIF VSYNC Mode and Dotclk Mode Control Register2 (LCDIF_VDCTRL2)

This register is used to control the HSYNC signal in the DOTCLK mode of the block.

This register determines the period and duty cycle of the HSYNC signal when it is generated in the block.

Address: 402B_8000h base + 90h offset = 402B_8090h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>HSYNC_PULSE_WIDTH</td>
<td>R/W</td>
</tr>
<tr>
<td>17</td>
<td>HSYNC_PERIOD</td>
<td>R/W</td>
</tr>
</tbody>
</table>
### LCDIF_VDCTRL2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–18</td>
<td>Number of DISPLAY CLOCK (pix_clk) cycles for which HSYNC signal is active.</td>
</tr>
<tr>
<td>HSYNC_PULSE_WIDTH</td>
<td></td>
</tr>
<tr>
<td>HSYNC_PERIOD</td>
<td>Total number of DISPLAY CLOCK (pix_clk) cycles between two positive or two negative edges of the HSYNC signal.</td>
</tr>
</tbody>
</table>

### 35.7.10 LCDIF VSYNC Mode and Dotclk Mode Control Register3 (LCDIF_VDCTRL3)

This register is used to determine the vertical and horizontal wait counts.

This register determines the back porches of HSYNC and VSYNC signals when they are generated by the block.

Address: 402B_8000h base + A0h offset = 402B_80A0h

#### LCDIF_VDCTRL3 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>This field is reserved. Reserved bits, write as 0.</td>
</tr>
<tr>
<td>RSRVD0</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>When this bit is set, the LCDIF block will internally mux HSYNC with LCD_D14, DOTCLK with LCD_D13 and ENABLE with LCD_D12, otherwise these signals will go out on separate pins. This feature can be used to maintain backward compatible with 37xx.</td>
</tr>
<tr>
<td>MUX_SYNC_Signals</td>
<td></td>
</tr>
<tr>
<td>VSYNC_ONLY</td>
<td>This bit must be set to 1 in the VSYNC mode of operation, and 0 in the DOTCLK mode of operation.</td>
</tr>
<tr>
<td>HORIZONTAL_WAIT_CNT</td>
<td></td>
</tr>
<tr>
<td>VERTICAL_WAIT_CNT</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
**35.7.11 LCDIF VSYNC Mode and Dotclk Mode Control Register**

This register is used to control the DOTCLK mode of the block.

This register determines the active data in each horizontal line in the DOTCLK mode. Note that the total number of active horizontal lines in the DOTCLK mode is the same as the V_COUNT bitfield in the LCDIF_TRANSFER_COUNT register.

**Address:** 402B_8000h base + B0h offset = 402B_80B0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>DOTCLK_DLY_SEL</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28–19</td>
<td>sync_signals_on, DOTCLK_H_VALID_DATA_CNT</td>
</tr>
<tr>
<td>18–17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15–14</td>
<td>DOTCLK_H_VALID_DATA_CNT</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4–3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**LCDIF_VDCTRL4 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–29 DOTCLK_DLY_SEL</td>
<td>This bitfield selects the amount of time by which the DOTCLK signal should be delayed before coming out of the LCD_DOTCK pin. 0 = 2ns; 1=4ns;2=6ns;3=8ns. Remaining values are reserved.</td>
</tr>
<tr>
<td>28–19 RSRVD0</td>
<td>This field is reserved. Reserved bits, write as 0.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### LCDIF_VDCTRL4 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>18 SYNC_SIGNALS_ON</td>
<td>Set this field to 1 if the LCD controller requires that the VSYNC or VSYNC/HSYNC/DOTCLK control signals should be active at least one frame before the data transfers actually start and remain active at least one frame after the data transfers end. The hardware does not count the number of frames automatically. Rather, the VSYNC edge interrupt can be monitored by software to count the number of frames that have occurred after this bit is set and then the RUN bit can be set to start the data transactions. This bit must always be set in the DOTCLK mode of operation, and it must be set in the VSYNC mode of operation when VSYNC signal is an output.</td>
</tr>
<tr>
<td>DOTCLK_H_VALID_DATA_CNT</td>
<td>Total number of DISPLAY CLOCK (pix_clk) cycles on each horizontal line that carry valid data in DOTCLK mode.</td>
</tr>
</tbody>
</table>

### 35.7.12 Bus Master Error Status Register (LCDIF_BM_ERROR_STAT)

This register reflects the virtual address at which the AXI master received an error response from the slave.

When the BM_ERROR_IRQ is asserted, the address of the bus error is updated in the register.

Address: 402B_8000h base + 190h offset = 402B_8190h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>ADDR</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

**LCDIF_BM_ERROR_STAT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Virtual address at which bus master error occurred.</td>
</tr>
</tbody>
</table>

### 35.7.13 CRC Status Register (LCDIF_CRC_STAT)

This register reflects the CRC value of each frame sent out by LCDIF. The CRC is done on the final output bus, so the value will be dependent on the LCD_DATABUS_WIDTH bitfield even if the input data is the same.

This register will be updated when the CUR_FRAME_DONE_IRQ is asserted.

Address: 402B_8000h base + 1A0h offset = 402B_81A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>CRC_VALUE</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>
### 35.7.14 LCD Interface Status Register (LCDIF_STAT)

The LCD interface status register can be used to check the current status of the LCDIF block.

The LCD interface status register that contains read only views of some parameters or current state of the block.

**Address:** 402B_8000h base + 1B0h offset = 402B_81B0h

![Diagram of LCDIF_STAT register]

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>PRESENT</td>
<td>DMA_REQ</td>
<td>LFIFO_FULL</td>
<td>LFIFO_EMPTY</td>
<td>TX_FIFO_FULL</td>
<td>TX_FIFO_EMPTY</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

| Reset | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
LCDIF Memory Map/Register Definition

**LCDIF_STAT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31        | **PRESENT**
0: LCDIF not present on this product
1: LCDIF is present. |
| 30        | **DMA_REQ**
Reflects the current state of the DMA Request line for the LCDIF. The DMA Request line toggles for each new request. |
| 29        | **LFIFO_FULL**
Read only view of the signals that indicates LCD LFIFO is full. |
| 28        | **LFIFO_EMPTY**
Read only view of the signals that indicates LCD LFIFO is empty. |
| 27        | **TXFIFO_FULL**
Read only view of the signals that indicates LCD TXFIFO is full. |
| 26        | **TXFIFO_EMPTY**
Read only view of the signals that indicates LCD TXFIFO is empty. |
| 25        | This field is reserved.
Reserved |
| 24–9      | This field is reserved.
Reserved bits. Write as 0. |
| 0         | **LFIFO_COUNT**
Read only view of the current count in Latency buffer (LFIFO). |
35.7.15 LCDIF Pigeon Mode Control0 Register (LCDIF_PIGEONCTRL0n)

This register contains global counter settings for Pigeon Mode also houses general purpose timing adjustment registers

Address: 402B_8000h base + 380h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>31–28 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>30</td>
<td>LD_PERIOD</td>
<td>Period of pclk counter during LD phase</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>LD_PERIOD</td>
<td>Period of line counter during FD phase</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>FRAME_CNT_CYCLES</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>FRAME_CNT_PERIOD</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

LCDIF_PIGEONCTRL0n field descriptions

35.7.16 LCDIF Pigeon Mode Control1 Register (LCDIF_PIGEONCTRL1n)

This register contains global counter settings for Pigeon Mode also houses general purpose timing adjustment registers

Address: 402B_8000h base + 390h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>31–28 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>30</td>
<td>FRAME_CNT_CYCLES</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>FRAME_CNT_PERIOD</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

LCDIF_PIGEONCTRL1n field descriptions

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>27–16 FRAME_CNT_CYCLES</td>
<td>Max cycles of frame counter</td>
</tr>
<tr>
<td>15–12 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>FRAME_CNT_PERIOD</td>
<td>Period of frame counter</td>
</tr>
</tbody>
</table>

**35.7.17 LCDIF Pigeon Mode Control2 Register (LCDIF_PIGEONCTRL2n)**

This register contains global counter settings for Pigeon Mode also houses clock gating and data enable registers.

Address: 402B_8000h base + 3A0h offset + (4d × i), where i=0d to 3d

### LCDIF_PIGEONCTRL2n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>1 PIGEON_CLK_GATE</td>
<td>Pigeon mode dot clock gate enable</td>
</tr>
<tr>
<td>0 PIGEON_DATA_EN</td>
<td>Pigeon mode data enable</td>
</tr>
</tbody>
</table>
### 35.7.18 Panel Interface Signal Generator Register (LCDIF_PIGEONn)

This register contains parameters for timing signal generation.

Address: \(402B_{\text{8000h}} \text{ base} + 800_{\text{h}} \text{ offset} + (64d \times i)\), where \(i=0d\) to \(11d\)

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### LCDIF_PIGEONn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 STATE MASK</td>
<td>state_mask = (FS</td>
</tr>
<tr>
<td>0x1 FS — FRAME SYNC</td>
<td></td>
</tr>
<tr>
<td>0x2 FB — FRAME BEGIN</td>
<td></td>
</tr>
<tr>
<td>0x4 FD — FRAME DATA</td>
<td></td>
</tr>
<tr>
<td>0x8 FE — FRAME END</td>
<td></td>
</tr>
<tr>
<td>0x10 LS — LINE SYNC</td>
<td></td>
</tr>
<tr>
<td>0x20 LB — LINE BEGIN</td>
<td></td>
</tr>
<tr>
<td>0x40 LD — LINE DATA</td>
<td></td>
</tr>
<tr>
<td>0x80 LE — LINE END</td>
<td></td>
</tr>
<tr>
<td>23–12 MASK_CNT</td>
<td>When the global counter selected through MASK_CNT_SEL matches value in this reg, pigeon local counter start ticking. 0=disable</td>
</tr>
<tr>
<td>11–8 MASK_CNT_SEL</td>
<td>select global counters as mask condition, use together with MASK_CNT</td>
</tr>
<tr>
<td>0x0 HSTATE_CNT — pclk counter within one hscan state</td>
<td></td>
</tr>
<tr>
<td>0x1 HSTATE_CYCLE — pclk cycle within one hscan state</td>
<td></td>
</tr>
<tr>
<td>0x2 VSTATE_CNT — line counter within one vscan state</td>
<td></td>
</tr>
<tr>
<td>0x3 VSTATE_CYCLE — line cycle within one vscan state</td>
<td></td>
</tr>
<tr>
<td>0x4 FRAME_CNT — frame counter</td>
<td></td>
</tr>
<tr>
<td>0x5 FRAME_CYCLE — frame cycle</td>
<td></td>
</tr>
<tr>
<td>0x6 HCNT — horizontal counter (pclk counter within one line)</td>
<td></td>
</tr>
<tr>
<td>0x7 VCNT — vertical counter (line counter within one frame)</td>
<td></td>
</tr>
<tr>
<td>7–4 OFFSET</td>
<td>offset on pclk unit. 0=align with data, positive value means delay, minus value mean ahead. Supported range depends on panel mode</td>
</tr>
<tr>
<td>3–2 INC_SEL</td>
<td>Event to increment local counter</td>
</tr>
<tr>
<td>0x0 PCLK — pclk</td>
<td></td>
</tr>
<tr>
<td>0x1 LINE — Line start pulse</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### LCDIF_PIGEONn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x2</td>
<td>FRAME — Frame start pulse</td>
</tr>
<tr>
<td>0x3</td>
<td>SIG_ANOTHER — Use another signal as tick event</td>
</tr>
<tr>
<td>1</td>
<td>POL — Polarity of signal output</td>
</tr>
<tr>
<td>0x0</td>
<td>ACTIVE_HIGH — Normal Signal (Active high)</td>
</tr>
<tr>
<td>0x1</td>
<td>ACTIVE_LOW — Inverted signal (Active low)</td>
</tr>
<tr>
<td>0</td>
<td>EN — Enable pigeon Mode on this signal</td>
</tr>
</tbody>
</table>

### 35.7.19 Panel Interface Signal Generator Register (LCDIF_PIGEONn)

This register contains parameters for timing signal generation.

Address: 402B_8000h base + 810h offset + (64d × i), where i=0d to 11d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 CLR_CNT</td>
<td>Deassert signal output when counter match this value</td>
</tr>
<tr>
<td>0x0</td>
<td>CLEAR_USING_MASK — Keep active until mask off</td>
</tr>
<tr>
<td>SET_CNT</td>
<td>Assert signal output when counter match this value</td>
</tr>
<tr>
<td>0x0</td>
<td>START_ACTIVE — Start as active</td>
</tr>
</tbody>
</table>

### 35.7.20 Panel Interface Signal Generator Register (LCDIF_PIGEONn)

This register contains parameters for timing signal generation.

Address: 402B_8000h base + 820h offset + (64d × i), where i=0d to 11d
### LCDIF_PIGEONn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–9 RSVD</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>8–4 SIG_ANOTHER</td>
<td>Select another signal for logic operation or as mask or counter tick event</td>
</tr>
<tr>
<td>SIG_LOGIC</td>
<td>Logic operation with another signal: DIS/AND/OR/COND</td>
</tr>
<tr>
<td>0 CLEAR USING MASK</td>
<td>— Keep active until mask off</td>
</tr>
<tr>
<td></td>
<td>DIS — No logic operation</td>
</tr>
<tr>
<td></td>
<td>AND — sigout = sig_another AND this_sig</td>
</tr>
<tr>
<td></td>
<td>OR — sigout = sig_another OR this_sig</td>
</tr>
<tr>
<td></td>
<td>MASK — mask = sig_another AND other_masks</td>
</tr>
</tbody>
</table>

### 35.7.21 Lookup Table Data Register. (LCDIF_LUT_CTRL)

Address: 402B_8000h base + B00h offset = 402B_8B00h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1

### LCDIF_LUT_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>0 LUT_BYPASS</td>
<td>Setting this bit will bypass the LUT memory resource completely. No pixel transformations will occur at last stage before output to external displayer.</td>
</tr>
</tbody>
</table>
35.7.22  Lookup Table Control Register. (LCDIF_LUT0_ADDR)

Address: 402B_8000h base + B10h offset = 402B_8B10h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**LCDIF_LUT0_ADDR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>ADDR</td>
<td>LUT indexed address pointer. This address into the LUT memory is always four byte aligned for PIO access. The least two significant bits are not used to drive the LUT memory array. For PIO LUT access, when the LUT data register is written, the contents of the LUT at the address specified by this address field will be loaded with a 32-bit DWORD. This address pointer will be incremented after the LUT data is written. This will provide recursive writes to the LUT data register to initialize the entire LUT array with recursive writes to the LUT data register.</td>
</tr>
</tbody>
</table>

35.7.23  Lookup Table Data Register. (LCDIF_LUT0_DATA)

Address: 402B_8000h base + B20h offset = 402B_8B20h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DATA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**LCDIF_LUT0_DATA field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATA</td>
<td>Writing this field will load 4 bytes, aligned to four byte boundaries, of data indexed by the ADDR field of the REG_LUT_CTRL register.</td>
</tr>
</tbody>
</table>
35.7.24 Lookup Table Control Register. (LCDIF_LUT1_ADDR)

Address: 402B_8000h base + B30h offset = 402B_8B30h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**LCDIF_LUT1_ADDR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>ADDR</td>
<td>LUT indexed address pointer. This address into the LUT memory is always four byte aligned for PIO access. The least two significant bits are not used to drive the LUT memory array. For PIO LUT access, when the LUT data register is written, the contents of the LUT at the address specified by this address field will be loaded with a 32-bit DWORD. This address pointer will be incremented after the LUT data is written. This will provide recursive writes to the LUT data register to initialize the entire LUT array with recursive writes to the LUT data register.</td>
</tr>
</tbody>
</table>

35.7.25 Lookup Table Data Register. (LCDIF_LUT1_DATA)

Address: 402B_8000h base + B40h offset = 402B_8B40h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**LCDIF_LUT1_DATA field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATA</td>
<td>Writing this field will load 4 bytes, aligned to four byte boundaries, of data indexed by the ADDR field of the REG_LUT_CTRL register.</td>
</tr>
</tbody>
</table>
Chapter 36
Pixel Pipeline (PXP)

36.1 Chip-specific PXP information

Table 36-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

36.2 Overview

This document describes the micro-architecture for the Pixel Processing Pipeline used to process graphics buffers or composite video and graphics data before sending to an LCD display or TV encoder.

It is used to minimize the memory footprint required for the display pipeline and provide an area and performance optimized to both SDRAM-less and SRAM-based systems.

The PXP integrates of several independent processing stages into a cohesive strategy to create flexible pixel pipeline.

The PXP combines the following into a single processing engine:

- Scaling
- Color Space Conversion (CSC)
- Rotation
By integrating multiple blocks, intermediate buffer operations to external memory are removed, reducing external memory bandwidth, power, and software control complexity. The PXP block diagram is shown below.

Figure 36-1. PXP Architecture

### 36.3 Clocks

The following table describes the clock sources for PXP. Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>clk</td>
<td>ipg_clk_root</td>
<td>PXP clock</td>
</tr>
</tbody>
</table>

### 36.4 Top-level architecture

The PXP consist of several pipelined blocks that perform the video source frame scaling, color space conversion, alpha-blending/color key algorithm, secondary CSC, pixel correction.
The entire pipeline operate within the requirements of the PXP architecture, and perform operations on either 8x8 or 16x16 pixel blocks in the representative source buffers. The entire pipeline operate within the context of two iteration counters that iterate through the appropriate grid of input blocks to produce the rotated output grid blocks in scan-line order.

Figure 36-1 shows the high-level architecture of the scaling, color space conversion, blending, pixel correction, rotation engines. The Alpha Surface Engine fetches one RGB graphics plane alpha surface (AS). The scaling engine fetches a single processed surface (PS), which can be blended with the AS surface. Although the PXP processes NxN pixel macro blocks, each of the AS or PS surfaces can have any pixel alignment within the output buffer. There are no restrictions and any pixel coordinates within the output buffer are valid. The upper left origin of the output buffer is defined as pixel 0,0. The upper left and lower right coordinates for each of the AS and PS are inclusive within the output buffer.

Figure 36-2 represents a sample output buffer configuration with both an AS and PS included. The alignment of each AS and PS within the output buffer can be at any arbitrary pixel locations. For example, the PS has an upper left coordinate (ULC) of 2,2 and a lower right coordinate (LRC) at pixel 13,13. The maximum value for the ULC and LRC for each of the AS and PS is bounded by the LRC of the output buffer, 15,15 for this example.
The AS engine supports RGB pixel formats, and the PS engine supports RGB, YUV, and YCbCr pixel formats. The CSC1 can be used to convert to RGB pixel formats so that the PS surface can be blended with the AS surfaces in the compositing engine in the RGB color space. There is a single rotation engine in the PXP with a programmable location with two possible rotations, one after PS processing, other just before the transfer to display buffer. Rotation can occur after image composition or at the output of the PS engine. In the first scenario, all the data produced by the AS and PS engines is rotated. When the rotation module is programmed to rotate only PS images, the AS is not rotated, and AS pixels are combined with rotated PS surfaces.

### 36.4.1 Processing Details

The PXP architecture has been driven primarily by the requirement that the output buffer must be processed and rotated without intermediate frame buffer stored in external memory.
This reduces the use of external memory bandwidth requirements thus reducing overall system power consumed.

Since the output of the rotation block must be NxN pixel blocks in scan order, the entire pipeline will operate on NxN pixel blocks. In essence, the pipeline will be able to operate on blocks in a random access fashion, but the entire pipeline will operate within the context of two iteration counters that will iterate through the horizontal and vertical input blocks to generate the required output block.

**Processing Pipeline**

The control block will coordinate the processing of the pixel blocks within the source and destination image buffers. It begins by issuing a command to each stage of the pipeline requesting that operations be done for the block at offset x, y. When the block accepts the command, it asserts its acknowledge signal for a single cycle to indicate the acceptance and allow the control unit to move to the next block.

When the PS and AS fetch engines have received a command, they will fetch the required data and place it into their fetch buffers. If compositing the RGB AS surface with the PS surface, then the output of the PS engine needs to be converted to the RGB color space using CSC1, since all compositing occurs in the RGB color space. For YUV output pixel formats, the CSC1 unit can be enabled to convert pixels into the RGB space for subsequent compositing with AS pixels. If the final output color space is YUV and there is no compositing required (AS not present, for example), then the CSC unit can be bypassed and the pixel data path will pass the YUV pixels to the rotation engine. For YUV output formats, scaling operations, and rotation operations are still valid, but blending RGB AS surfaces with YUV PS surfaces is NOT supported.

The alpha blender/color key module will process a pixel any time that both inputs present valid data.

A handshake will be created between each stage and a pipeline controller to handle the advance of the pipeline and generation of the iteration counters. The pipeline controller will also maintain the interlocks with the LCD interface for the case where the LCD display and pixel processing pipeline use the SRAM to maintain the double buffer block intermediate buffer.

### 36.4.2 Scaling Operation

The scaling engine operates on YUV (or YCbCr) 422 or 420 and any RGB formatted pixels. Each color plane is sourced from color planes indicated by different base address registers.
The scaling source data can be stored as 3 individual planes for each Y, U, and V data, stored as two planes as a single Y and interleaved UV plane, or stored as a single plane with YUV/RGB interleaved on a per byte basis.

The scaled output image is presented to the CSC module as YUV444 or RGB888 pixels with a single byte for each color channel. The scaler can reduce an input image by a maximum factor of 16. In this case, the output image will be 1/16 the dimension of the input image in each of the X and Y axis. There are no limits, essentially, on increasing the source image size. The theoretical maximum increase is 4096 since a 12 bit fractional step function is used when scaling an input image. Scaling in either axis, X or Y is independent, so a source image can appear stretched in either direction.

All source images pass through the scale engine. The PXP alpha blend module and AS pixel streams are in the RGB888 format, so PS pixel buffers must be converted to the RGB888 format for alpha blending. The scaling engine works with the CSC1 module to translate YUV/YCbCr pixel formats to RGB888 for output frame buffer compositing using the alpha blender. The CSC1 unit can be bypassed so compositing can occur in the alpha engine.

The scaling operation is divided into two scaling steps. The first step is a decimation scaler, and the second step is a bilinear filter. The decimation filter provide a maximum down scaling factor of 8, and the subsequent bilinear filter provides a maximum scaling factor of 2. Combined, the maximum scaling factor can be up to 16. The decimation and bilinear scaling engines are independently programmable. There is also an initial offset that is programmable to allow more source data to be considered in the bilinear scaling engine.

### 36.4.3 Decimation Image Scaling

The first of two scaling engines is the decimation filter.

The intent of the decimation filter is to use as much source data as is possible to create the output image frame buffer. The decimation filter simply discards certain pixels from the source PS image depending on the reduction selected.

For RGB pixel formats, each color channel is treated equally since there is the same amount of pixel data within each color plane. For YUV422/420 formats, the chroma samples are already subsampled by 2. In these decimation scenarios, the chroma decimation factor is adjusted to account for the pre-decimation of the chroma samples. For example, since YUV422 is already sub-sampled by 2 horizontally, an X decimation factor of 2 does not apply to the YUV422 pixels in the X direction. All the chroma samples are passed on to the bilinear filter in this case. As another example, an X
decimation factor of 4 will decimate the chroma samples by 2, since this factor combined with the pre-decimation factor of 2 in the pixel source buffers totals an overall decimation factor of 4.

The following example will show which pixels (in green) in a source RGB buffer that are passed to the bilinear filter for an X decimation factor of 2 and a Y decimation factor of 4. All pixels coincident with dashed lines are discarded.

Figure 36-3. RGB decimation X/2, Y/4
Using the same decimation factor as the above scenario for RGB pixels, but using YUV420 source buffers, it can be shown that the decimation factor for the Y and UV components of data are decimated differently. This is due to the pre-decimation of the chroma samples in the source frame buffers. Figure 4: YUV420 decimation X /2, Y /4 indicates that the U/V samples in the X direction are not decimated, but the Y samples in the X direction are decimated by the factor of 2.

Figure 36-4. YUV420 decimation X /2, Y /4
36.4.4 Bilinear Image Scaling Filter

The PXP implements a bilinear scaling filter to resize an input image to a different resolution for display output.

The bilinear filter is a weighted average of the four nearest pixels that can be sourced to approximate the pixel in the output frame buffer.

When scaling YUV data, the UV values are offset by 0x80 (top bit inverted) to shift the signed UV bits into an unsigned equivalent with a range of 0 to 255. YCbCr data does not have to be shifted since it is defined as an unsigned byte. The REG_CSC1_COEF0[YCBCR_MODE] bit controls whether this operation is applied to the input UV bytes.

After scaling, the offset is removed so that the range for UV data is signed from -128 to 127.

The reason for this adjustment is based on the implementation of an unsigned scaling engine, and therefore, is to ensure that the scaled values are handled properly. Consider the following table:

<table>
<thead>
<tr>
<th>Format</th>
<th>pixel0</th>
<th>pixel1</th>
<th>average</th>
<th>Result</th>
</tr>
</thead>
<tbody>
<tr>
<td>decimal</td>
<td>-2</td>
<td>+2</td>
<td>0</td>
<td>Correct</td>
</tr>
<tr>
<td>CbCr</td>
<td>0x7E</td>
<td>0x82</td>
<td>0x80</td>
<td>Correct (0x80 is 0 in CbCr)</td>
</tr>
<tr>
<td>UV</td>
<td>0xFE</td>
<td>0x02</td>
<td>0x80</td>
<td>Incorrect (0x80 is -128 in UV)</td>
</tr>
<tr>
<td>decimal</td>
<td>-32</td>
<td>+16</td>
<td>-8</td>
<td>Correct</td>
</tr>
<tr>
<td>CbCr</td>
<td>0x60</td>
<td>0x90</td>
<td>0x78</td>
<td>Correct (0x78 is -8 in CbCr)</td>
</tr>
<tr>
<td>UV</td>
<td>0xE0</td>
<td>0x10</td>
<td>0x78</td>
<td>Incorrect (0x78 is +120 in UV)</td>
</tr>
</tbody>
</table>

To compute the output pixel value at position as indicated by P, consider the diagram below.
A step function is used to indicate the position of the pixel "P" in the output frame. This position may not coincide with a single pixel position in the input frame buffer. In this case, the four closest pixels in the input frame are used to approximate the value of the pixel in the output frame.

The PXP scaler first computes a linear filter in the X axis to create the two intermediate pixel values Px0 and Px1. The step function's X fractional component is used to provide the weighting factor for blending p00 with p10 to provide Px0. Likewise, Px1 is also derived from a linear filter using p01 and p11.

The equations for Px0 and Px1 are as follows:

\[
Px0 = p00(1-Rx) + p10Rx
\]
\[
Px1 = p01(1-Rx) + p11Rx
\]

The PXP scaler uses the intermediate X pixels Px0 and Px1 and implements a bilinear filter on these two pixel values to produce the final pixel value at position P. The remainder of the step function for the Y axis is used to compute the weighted average pixel result. The equation for final filtered pixel is:

\[
P = Px0(1-Ry) + Px1Ry
\]
36.4.5 YUV 4:2:2 Image Scaling

The following figure illustrates the positioning of YUV samples for the 4:2:2 formats. There are twice as many Y luma samples then U and V chroma samples horizontally.

Consider the scaled output pixel Ps (pixel scaled) which has an accumulated step function of X=1.5 and Y=0.5. The remainder for the step function is Rx = 0.5 and Ry = 0.5. Or, the sub pixel position of output pixel Ps is half way between line 0 and 1 and half way between column 1 and 2.

The Y output component of Ps is simply the bilinear function of the four nearest Y samples from the input image. Specifically, the Y values at [1,0], [2,0], [1,1], and [2,1] are used to compute the Y for Ps.

For the U and V components of Ps, there are no samples present in the column position 1. The bilinear filter uses chroma components located at [0,0], [2,0], [0,1] and [2,1]. Since the chroma components are not sub sampled vertically, the remainder used to combine pixels vertically is Ry=0.5 (the same as for Y). However, horizontally, the scaling engine shifts the remainder by a factor of 2. So an X axis step function value of X=1.5 has a remainder Rx=0.75. Source chroma values are not replicated, they are completely interpolated using the four nearest chroma samples to approximate U and V at Ps.
The following figure illustrates the positioning of YUV samples for the 4:2:0 formats. Chroma is sub sampled both horizontally and vertically. In this format, the chroma frame buffers contain ¼ the data that the luma frame buffers store.

![Diagram of YUV Sample Positioning, 4:2:0](image)

**Figure 36-7. YUV Sample Positioning, 4:2:0**

The Y output component for all scaled pixels in 4:2:0 formats are the same as for the 4:2:2 pixel formats.

The U and V output components have two considerations when computing the output pixel Ps.

1. All chroma samples from the input source image are shifted left and up by ½ a sample position of the input pixel matrix.
2. Odd scan lines are replicated using the previous even chroma scan line values. So, output image chroma values that map between even to odd scan lines are replicated in the vertical axis. In contrast, output image chroma values between odd to even scan lines are interpolated vertically.

The chroma values are interpolated horizontally as in the 4:2:2 pixel format.

As an example, consider the interpolated pixel Ps in the 4:2:0 diagram above. For the Y component, the interpolated output luma is a function of the Y values in the source frame buffer at position [1,0], [2,0], [1,1], [2,1].
For the U and V interpolated samples, the chroma values on scan line position 0.5 are shifted so that they coincide with the even luma sample points. They are also replicated so that a single chroma scan line is used twice. The chroma scan line at 0.5 is replicated to represent the 4:2:2 sample points for scan line 0 and 1. The chroma scan line at 2.5 is replicated to represent the 4:2:2 sample points for scan line 2 and 3. This pattern of chroma replication occurs for the entire source frame buffer during the scaling operation.

![Figure 36-8. Scaled Chroma Computation Examples](image)

The preceding diagram has two examples for the computation of the scaled chroma output pixel. For chroma at output position PsA (vertical position 0.5), interpolation occurs in the X axis using chroma values at column 0 and column 2. However, since line 0 and line 1 have equal chroma values due to chroma line replication, scaling in the Y axis results in replication of chroma values.

For chroma at output position PsB (vertical position 1.5), interpolation occurs in both the X and Y axis. The Y axis is an interpolation since the chroma values copied to scan line 1 and 2 and not the same.

In summary, any output image pixels that map to an odd scan line above and an even scan line below are interpolated vertically. Output image pixels that map to an even scan line above and an odd scan line below are replicated vertically.

### 36.4.7 RGB/YUV444 Image Scaling

For all RGB formats, the RGB pixels are converted up to RGB888 with 8 bits per each color component.
Then each color component is passed to the scaling engine and each component is treated in the same manor. The RGB scaling operation is the same as for the Y scaling operation described in the preceding sections. Also, YUV444 contains a byte for each color plane at each pixel location, so all three color components are scaled in the same manor.

### 36.4.8 Color Space Conversion (CSC)

The CSC unit converts pixels between color spaces. The CSC1 unit is right after the scaling unit and is dedicated to converting from YUV to RGB. All coefficients are programmed as two's compliment numbers and CSC unit can be bypassed if conversion is not desired in the pixel data path.

### 36.4.9 CSC1 Operation

The CSC1 module receives scaled YUV/YCbCr444 pixels from the scale engine and converts the pixels to the RGB888 color space only if CSC1 is enabled.

The CSC1 module will convert only to the RGB color space and it can be bypassed to allow YUV pixels through the data path. These pixels are loaded into the pixel FIFO for processing by subsequent modules in the pixel data path.

The following equations are used to perform YUV/YCbCr -> RGB conversion. The constants will be stored in the PXP control registers as two's compliment values to allow flexibility in the implementation and to allow for differences in the video encode and decode operations. In addition, this provides a software mechanism to manipulate brightness or contrast.

\[
R = C0(Y+Yoffset) + C1(V+UVoffset)
\]

\[
G = C0(Y+Yoffset) + C3(U+UVoffset) + C2(V+UVoffset)
\]

\[
B = C0(Y+Yoffset) + C4(U+UVoffset)
\]

Note: In the equations above, U and V are synonymous with Cb and Cr in regards to the color space format of the source frame buffer.

Saturation of each color channel is checked and corrected for excursions outside the nominal YUV/YCbCr color spaces. Overflow for the three channels are saturated at 0x255 and underflow is saturated at 0x00.

The table below indicates the expected coefficients for YUV and YCbCr modes of operation:
### 36.4.10 YUV versus YCbCr Support

By default, the PXP color space coefficients are set to support the conversion of YUV data to RGB data.

If YCbCr input is present, software must change the coefficient registers appropriately (see the register definitions for values). Software must also set the YCBCR_MODE bit in the COEFF0 register to ensure proper conversion of YUV versus YCBCR data.

### 36.4.11 Alpha Blending/Color Key

Regardless of pixel input format, the PS and AS pixels are normalized to 32-bits, organized as one alpha and three data bytes. Alpha blending occurs in the RGB space, if blending is required, PS pixels should be converted to RGB space. If no alpha blending is required, then YUV pixels can bypass the alpha blending ALU without color space conversion. All pixels are processed by the pixel ALU, but the ALU operations can be disabled to achieve pixel pass through for either PS or AS source pixels.

### 36.4.12 Alpha Blend

The alpha value for an individual pixel represents a mathematical weighting factor applied to the AS pixel. An alpha value of 0x00 corresponds to a transparent pixel and a value of 0xFF corresponds to an opaque pixel.

The effective alpha value for an AS pixel is determined by the AS_CTRL[ALPHA] and AS_CTRL[ALPHA_CTRL] register fields. If AS_CTRL[ALPHA_CTRL] = ALPHA_OVERRIDE, the alpha value for the pixel is taken from the AS_CTRL[ALPHA]. This can be useful for applying a constant alpha to an entire image or for image formats that don't include an alpha value. If AS_CTRL[ALPHA_CTRL] =

---

<table>
<thead>
<tr>
<th>Coefficient</th>
<th>YUV</th>
<th>YCbCr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Yoffset</td>
<td>0x000</td>
<td>0x1F0 (-16)</td>
</tr>
<tr>
<td>UVoffset</td>
<td>0x000</td>
<td>0x180 (-128)</td>
</tr>
<tr>
<td>C0</td>
<td>0x100 (1.00)</td>
<td>0x12A (1.164)</td>
</tr>
<tr>
<td>C1</td>
<td>0x123 (1.140)</td>
<td>0x198 (1.596)</td>
</tr>
<tr>
<td>C2</td>
<td>0x76B (-0.581)</td>
<td>0x730 (-0.813)</td>
</tr>
<tr>
<td>C3</td>
<td>0x79B (-0.394)</td>
<td>0x79C (-0.392)</td>
</tr>
<tr>
<td>C4</td>
<td>0x208 (2.032)</td>
<td>0x204 (2.017)</td>
</tr>
</tbody>
</table>
ALPHA_MULTIPLY, the pixel's alpha value will be multiplied by the pixel's ALPHA value in order to allow scaling of the pixel's alpha or to provide better control for pixel formats such as RGB1555, which only contains a single bit of alpha.

For each color channel, the equation used to blend two source pixels is defined below:

\[ \text{Gá} = \text{PIO programmed global alpha (8-bit value)}. \]
\[ \text{Eá} = \text{Embedded alpha associated with AS pixel}. \]
\[ \text{á} = \text{Gá} \times \text{Eá} + 0x80 \]

The result for the red channel as an example:

\[ R[7:0] = (\text{á} \times \text{PS.r}) + ((1 - \text{á}) \times \text{AS.r}) \]

When \( \text{á} \) is 0xff, the PS pixel will not be blended with the AS pixel, but PS will be passed as the output pixel and will not be blended with AS. In this case, AS will be discarded. Likewise, if \( \text{á} \) is 0x00 for a given pixel, PS will be loaded as the output pixel.

AS_CTRL[ALPHA_INVERT] provides the option to invert the final alpha value. This essentially inverts the effect the alpha value has on the AS and PS blending operation.

### 36.4.12.1 Porter-Duff Alpha Blend

Porter-Duff blend includes 12 blending modes to describe digital image composite. These processes include Clear, Source Only, Destination Only, Source Over, Source In, Source Out, Source Atop, Destination Over, Destination In, Destination Out, Destination Atop and XOR. Through these processes it can achieve any 2D image composite.

To control the blending modes, please see the following picture. All the registers showed below are included in HW_PXP_ALPHA_A_CTRL.
image output = s01_alpha × s1_pixel' + s10_alpha × s0_pixel'
alpha output = s10_alpha × s0_alpha'' + s01_alpha × s1_alpha''

36.4.13 Color Key

The color key function is provided to create transparent effects on the output pixel.

Color keying is applied on the input pixels after they are converted to 8-bits for each red, green, and blue color channels (color keys are not applied directly to 16-bit pixel formats but to their corresponding 24-bit representation). A color key range is programmable for both PS and AS pixels. If the PS 24-bit pixel is within the PS color key range, then AS is passed through the pixel pipeline. In this case, alpha blending does NOT occur. Conversely, if PS is within the AS color key range, then PS is passed via the PXP data pipeline. If both PS and AS color key tests pass, then the back ground color register is passed onto following PXP processing components in the pipeline.

The condition for color keying to be satisfied is:
CK0.r.low <= PS.r <= CK0.r.high
CK0.g.low <= PS.g <= CK0.g.high
CK0.b.low <= PS.b <= CK0.b.high

For example, if the "red" 8-bit value for the PS pixel (or PS.r) is between the color key low and high values (CK0.r.l and CK0.r.h), the condition is true for the red color plane. When ALL three color planes meet this condition, then only the PS pixel is loaded into the output register.

To disable color keying, program the low color key register value to 0xff and the high value to 0x00. This will guarantee that the color key range test will never be true.

### 36.4.14 Rotation

There is a single rotation resource integrated into the PXP. The location of this resource within the PXP data path is programmable. Rotation can occur after compositing the AS and PS buffers in the output stage.

As an alternative configuration, the PS buffer can be rotated and later composited with the AS surface that is not rotated. There is a single configuration bit that provides the configuration of where rotation is implemented within the PXP.

To rotate graphics, the hardware must read pixels in one direction across a frame buffer and write them in an alternate orientation. For the 90 and 270 degree cases, this means that lines of pixels must either be read or written vertically in a frame buffer.

![Figure 36-10. Rotation Read and Write](image-url)
In order to rotate efficiently, multiple columns must be rotated to enable the engine to both fetch and store bursts of pixels, thus improving memory performance. The simplest method of doing this is to operate on square blocks of pixels. To rotate the image, each sub-block of pixels must be rotated by the required rotation angle.

![Source buffer](image)

![Destination buffer](image)

When multiple lines are read from the source buffer, data can be both read and written as bursts to the memory controller. In this example, photos are read in a 4x4 pixel block and rotated, improving memory efficiency.

**Figure 36-11. Rotated Sub-blocks**

To manage the rotation process, the source image can be broken into a grid of sub-blocks that have coordinates as shown in the diagram below. In addition to rotating the sub-block, each block must be translated to a new coordinate location. For each of the rotation angles (0, 90, 180, 270), it is possible to define a simple algorithm for computing the new translated grid address. The hardware must then simply compute the memory address from the base grid address for both load and store operations.
When the image is broken into a grid and sub-blocks, each sub-block can be numbered with a coordinate. In addition to being rotated, each sub-block is translated to a new grid coordinate. The new coordinate can easily be calculated from the source coordinate and the angle of rotation.

**Figure 36-12. Grid of Sub-Blocks with Coordinates**

In order to balance the requirements of reasonable burst sizes to the memory controller as well as keep the hardware storage requirements to a minimum, the blending/rotation engine will operate on either 8x8 or 16x16 pixel blocks. When using the Rotate engine with the input fetch engine, you need to program the input fetch engine to work in 8x8 block mode.

**NOTE**

An important artifact of the PXP is when rotating a source image and the output is NOT divisible by the block size selected. The output engine essentially truncates any output pixels after the desired number of pixels has been written. Since the output buffer is written as a horizontal row of blocks, the incorrect pixels could be truncated and the final output image can look shifted. In the case where the block size is programmed to 8x8, and the output size that is programmed is 12x12, then there is a remainder of 4 pixels that will be truncated in either the X and/or Y axis when the PXP operation is complete. The output will be shifted by 4 pixels in this example. To compensate for this, the source base address needs to be adjusted so the correct pixels get truncated and the image does not look shifted. In this example, with 90 degrees of rotation, the PS base address should be adjusted by 4 times the actual PS base address -(4*pitch).
36.4.15 Output Buffer

The output buffer engine accepts data from the PXP pixel pipeline and issues requests to transfer the output pixels to external DRAM or the internal SRAM double buffer row of blocks.

36.4.16 Address calculator

Each of the blocks will manage its own fetch address using a common address calculator block that computes real addresses from a base address and relative block offset from the base.

Each block will then perform the multiple line fetches (or stores) required to perform the operation. This hides all the address buffer computations from the processing blocks and allows each block to simply track the coordinate of the block it is working on.

36.4.17 Block size selection

The PXP can be configured to process blocks that are either 8x8 pixels or 16x16 pixels with the REG_CTRL[BLOCK_SIZE] control bit.

When selecting a 16x16 pixel block size, the accesses to fetch AS and PS images and write the final frame buffer are more efficient since twice as much data is requested and processed per memory request.

When optimizing the system for memory bandwidth and image processing time, configure the PXP to process 16x16 pixel blocks.

36.4.18 Interlaced Video Support

The PXP has some minimal ability to generate interlaced video content from a progressive source. There two available options, based on the bandwidth requirements and how software is managing video frames.

The PXP can either interlace on the input side (by reading every other line of input data) or on the output side (by writing the individual lines of video into two separate fields). Generally, output interleaving should be used since it is the most flexible mode (it allows scaling and full overlay support) and it only requires a single pass of the PXP to generate two separate output fields.
Input interleaving can be beneficial in cases where the PXP is running at 60fps, since it requires fewer fetches to produce the output data. There is no direct hardware support for input interleaving, in that, there is no configuration bit that can be set to alter how the PXP processes a frame for input interleaving. Input interleaving is achieved by simply setting the source frame buffer pitch value to twice the value it would normally be set to for the equivalent progressive frame. The output parameters also need to be consistent with the desired processing effect. For example, the vertical resolution would be set to account for the reduced resolution to process the interlaced input buffers.

### 36.4.19 LCDIF Handshake

The PXP and LCDIF support a mode where the internal SRAM can be used for the frame buffer to minimize external memory bandwidth required.

This is accomplished by creating two buffers in SRAM, a double buffer row of blocks, where each correspond to 8/16-lines of the frame buffer. The buffers must be consecutive and allocated as a single block of data.

![Buffer in OCRAM](image)

**Figure 36-13. Buffer in OCRAM**

The storage required can be calculated for an 8x8 block size as

- storage = 16 (lines) * rotated_row_length * pixel_size

and for 16x16 block size as

- storage = 32 (lines) * rotated_row_length * pixel_size

where pixel_size = 4 for 32bpp or 2 for 16bpp modes. The following table lists the storage requirements for common image sizes using 8x8 block size:

<table>
<thead>
<tr>
<th>Image Size</th>
<th>Storage (16bpp)</th>
<th>Storage (24bpp)</th>
<th>Storage (32bpp)</th>
</tr>
</thead>
<tbody>
<tr>
<td>320x240 (QVGA) - 0/180 rotation</td>
<td>10KB</td>
<td>15KB</td>
<td>20KB</td>
</tr>
<tr>
<td>320x240 (QVGA) - 90/270 rotation</td>
<td>7.5KB</td>
<td>11.5KB</td>
<td>15KB</td>
</tr>
<tr>
<td>640x480 (VGA) - 0/180 rotation</td>
<td>20KB</td>
<td>30KB</td>
<td>40KB</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
The following diagram shows how the minimal rotation buffer would be organized. As the engine and LCD progress down the image, they continually swap roles of filling and emptying each eight-line buffer.

![Minimal Rotation Buffer Organization](image)

The LCD controller (our output scanner) would read one buffer as the blending rotation angle files the second buffer. In this manner, the entire rotated frame buffer need not be written to memory.

**Figure 36-14. Minimal Rotation Buffer Organization**

When this mode is enabled, the PXP will process one row of pixel blocks and write the results to the first SRAM buffer (buffer 0). The PXP will then alternate between writing subsequent rows to buffer 0 and buffer 1. After the PXP generates the data for one buffer, the LCDIF will begin reading that buffer and send the contents to the display device. After the LCDIF finishes reading a buffer, it will start displaying from the other buffer while the PXP continues filling the previously processed buffer.
To accomplish the buffer sharing, the PXP and LCDIF will maintain buffer status using a pair of handshake signals. When a buffer is filled by the PXP, it will assert the `pxp_lcdif_bx_ready` (where x is 0 or 1) signal to indicate to the LCDIF that the buffer has valid data. The LCDIF will then release the buffer by asserting the `lcdif_pxp_bx_done` signal.

The basic protocol is shown in the diagram below:

![Buffer Sharing Diagram](image)

**Figure 36-15. PXP and LCDIF Buffer Sharing**

**Figure 36-16. Buffer Sharing Protocol**
The PXP will continue to assert the bx_ready signal until the corresponding bx_done signal is sampled high for one clock cycle. It will then deassert the bn_ready until the next time the buffer has been filled. After the PXP samples the bx_done signal asserted, it is free to begin filling the buffer with the next block size lines of display data. If a buffer has not been released when the PXP is ready to process data for that buffer, it will suspend rendering operations until the buffer has been released by the LCDIF.

### 36.4.20 LCDIF Abort

When the memory subsystem is not loaded, the PXP should be able to render the buffers faster than the LCDIF can drain the buffers.

It is possible under some scenarios (high LCDIF output rates with high memory latency) that the PXP may not be able to keep up with the LCDIF, even in the SRAM mode of operation. When this happens, the LCDIF will signal that it has completed one of the buffers before the other has been rendered by the PXP. This condition will be detected by the PXP's control logic as an "LCDIF Abort", which will cause the PXP to abort processing in the current row and proceed to the following row. It will acknowledge the abort to the LCDIF by raising the buffer_ready signal for the current buffer to enable the LCDIF to begin displaying the partially-filled buffer. While an abort will create artifacts in the video display, it does minimize the artifacts by limiting them to the remaining pixels blocks in the current row versus ruining the entire frame buffer.

![Figure 36-17. LCDIF Abort](image)

### 36.4.21 Theory of Operation

The PXP can be used to accelerate graphics operations by offloading graphics processing from the processor. The block can perform alpha blending and color key substitution on two RGB graphics buffers.

The PXP is organized as having a processed surface (PS) and an alpha surface (AS) that can be blended with the processed surface. There are no restrictions on the location of the AS or PS within the output surface (OS). As the PXP processes NxN blocks, operations...
are performed on a pixel by pixel basis. The AS and PS pixels are alpha blended, color
to key, process by CSC resources as individual pixel components. This allows efficient
block processing with supporting arbitrary alignment for both the AS and PS surfaces.
The resulting pixel block is then written to the corresponding block in the output buffer.

36.4.22  Pixel Handling

All pixels are internally represented as 32-bit values regardless of input or output pixel
formats. The pixels get converted in the AS and PS buffer engines to 24-bit pixel values.
There is also an 8-bit alpha value at stages up to the alpha blender within the PXP for
blending within the RGB color space. Compositing of AS and PS images can only occur
in the RGB color space. If compositing is not required, then YUV pixels can be
transferred and processed at all PXP pixel resource components. The color orientation of
pixels within the PXP can be controlled by the CSC1 resource.

For RGB, input pixels are converted into 32-bit pixel values using the following rules for
both AS and PS:

1. 32-bit ARGB8888 pixels are read directly with no conversion.
2. 32-bit RGB888 pixels are assumed to have an alpha value of 0xFF (full opaque).
3. 6-bit RGB565 and RGB555 values are expanded into the corresponding 24-bit color
   space and assigned an alpha value of 0xFF (opaque). The expansion process
   replicates the upper pixel bits into the lower pixel bits (for instance a 16-bit RGB555
   triplet of 0x1F/0x10/0x07 would be expanded to 0xFF/0x84/0x39).
4. 16-bit RGB1555 values are expanded into the corresponding 24-bit color space and
   assigned an alpha value of either 0x00 or 0xFF, based on the 1-bit alpha value in the
   pixel. The ALPHA_MULTIPLY function is useful in this scenario to allow scaling
   of the opaque pixels to a semi-transparent value.

Alpha values can be passed through the entire PXP data path and output in ARGB888
and ARGB555 pixel modes. Also, output pixels can be assigned an alpha value using the
REG_OUT_CTRL[ALPHA] register. 16-bit pixels values are formed from the most
significant bits of the 24-bit pixel values.

When YUV/YCbCr output formats are selected, all pixels are internally represented as
either RGB or YUV pixels values.
### 36.4.23 Output Buffer Composition

The output buffer will be rendered by composing each pixel block from the associated PS and AS buffers.

The AS pixel buffer can be blended or color-keyed with the associated data from the PS buffer (either the PS image pixels or REG_PS_BACKGROUND register based on PS programmed coordinates).

![Output Buffer Composition](image)

**Figure 36-18. Output Buffer Composition**

### 36.4.24 PS Image Processing

As the PXP processes image buffers, it iterates over the output buffer by fetching the corresponding input buffer blocks and processing the pixels embedded in these.
### 36.4.25 Letterboxing

At each pixel coordinate, the control logic determines if the PS pixel (argument also applies to AS pixels) will be used in rendering the output pixel.

This is determined by checking the output pixel's coordinates against the REG_OUT_PS_ULC and REG_OUT_PS_LRC (ULC and LRC in short) register contents. For pixels outside this region, the PS pixel will be loaded with the pixel value from REG_PS_BACKGROUND, which can be used to effectively control the letterboxing color. There are no block size or block boundary restrictions when setting the ULC or LRC for either the AS or PS. The only restriction is that the ULC and LRC are within the OUT LRC extents.

![PS Image](image)

The region outside the PS coordinates will be filled with the value specified in the PSBACKGROUND register.

**Figure 36-19. OUT Buffer**

### 36.4.26 Clipping source images

A subset of the PS buffer can be used in rendering the output buffer. The PXP_PS_BUF register can indicate an offset into the PS buffer that will be used for display within the OUTPUT buffer.

The pixel at the address defined in the PXP_PS_BUF register will be the pixel that is displayed at the pixel coordinate indicated by PXP_OUT_PS_ULC within the output buffer. Essentially, the PXP_PS_BUF register can be used to establish an offset into the PS buffer thus clipping all PS buffer pixels that are at a lower address. The PXP_PS_PITCH will always indicate the number of bytes that are vertically adjacent in
the PS buffer. The settings in the PXP_PS_BUF, PXP_OUT_PS_ULC, and PXP_OUT_PS_LRC will determine the subset of the PS buffer, or clipped PS source buffer, that will be used in the output buffer.

It is important to note that when scaling the PS buffer, the coordinates of the PS buffer within the output buffer need to be consistent with the scaling factors and original PS buffer size.

![Figure 36-20. PS Buffer Scaling](image)

When sourcing a subset of the PS image, it should fall completely within the PS buffer to avoid displaying incorrect data. The following conditions should be met:

\[
x_{\text{base_addr}} + x_{\text{scale}} \times (\text{LRC}_X-\text{ULC}_X) \leq \text{PS}\_\text{pitch}
\]
\[
y_{\text{base_addr}} + y_{\text{scale}} \times (\text{LRC}_Y-\text{ULC}_Y) \leq \text{PS}\_\text{size}
\]

The PXP hardware does not check for these conditions and will render the image as programmed. The following case could indicate invalid programming parameters for the PXP:
36.4.27 Color Key Processing

Pixels may be made transparent to the corresponding AS by using the PS color key registers.

If a PS pixel matches the range specified by the REG_PS_COLORKEYLOW and REG_PS_COLORKEYHIGH registers, the pixel from the associated AS will be displayed. If no AS is present for the pixel, a black pixel will be generated since the default AS pixel is 0x00000000 (transparent black pixel).

The most common use for this is when a bitmap does not support an alpha-field or for applications such as "green screen" where an image is substituted for a solid background color.
Figure 36-22. The PS image (player) and AS image (stadium)

The green portion of the background image can be color keyed to display the contents of the AS buffer for locations that match the color range. For this example, the color range is:

PS Colorkey: 00<R<80 70<G<ff 00<B<80

The resulting image becomes:

Figure 36-23. Resulting Image
36.4.28  In Place Processing (PS buffer is destination buffer)

The PXP also has the ability to process an image and write the resulting buffer back to the original PS buffer. This is referred to as "in place" rendering.

This could be useful for basic blit operations into the PS buffer. IN_PLACE operations are achieved by programming the OUT base address to the pixel location in the PS buffer that marks the upper left pixel of the update region. The actual region that is updated should be indicated by programming the ULC = (0,0) and the LRC = (X,Y). The region bounded by the coordinates will be updated, and the rest of the PS buffer will not be modified.

36.4.29  Alpha Surface (AS) Processing

The AS surface has a complete set of registers that determines how the AS effects the final OUT surface.

Most of the registers that exist for the PS surface also are defined for the AS surface where applicable. This is provided to replicate the SW interface for each PS and AS processes.

36.4.30  Alpha Handling

Alpha values in the AS are embedded in the source image pixels. For AS pixel formats that do not support an alpha value, the pixel is assigned an alpha value of 0xFF (opaque).

This can be modified by the AS control by setting either the ALPHA_MULTIPLY or ALPHA OVERRIDE bit in the associated AS_CTRL register. If ALPHA_MULTIPLY is enabled, the 8-bit ALPHA value from the AS_CTRL register is multiplied by the source alpha before blending with the PS image. If the ALPHA_OVERRIDE bit is set, the 8-bit ALPHA value is simply substituted for the pixel.

36.4.31  Color Key Processing (AS_CTRL)

The AS_CTRL register also contains an ENABLE_COLORKEY bit that can be used to enable or disable color key substitution for the AS.
When enabled, the pixel values are compared to the ASCOLORKEYLOW and ASCOLORKEYHIGH registers to determine if a match has occurred. When an AS pixel matches the color key range, the pixel from the AS image is considered transparent and the corresponding PS pixel is rendered. If both the PS and AS pixels match their corresponding color key ranges, the AS pixel is displayed unmodified.

AS color keys are handled in a manner similar to PS color keys. The same images used in the PS color key example could be used with the images swapped. In this case, matches on the AS image to the ASCOLORKEY register would display the PS pixels.

### 36.5 Output Image Processing

Several PXP options affect the resulting output image.

#### 36.5.1 Output Image Size

The PXP generates an output image in the resolution programmed by the REG_OUT_LRC. As the PXP processes pixels, it iterates over the NxN blocks (in output scan-block order) based on the final image resolution.

#### 36.5.2 Output Format

The result of PXP operations are written to the buffer pointed to by the REG_OUT_BUF/REG_OUT_BUF2 registers. The pixel format is controlled by the REG_OUT_CTRL[FORMAT] bit-field.

32-bit pixels are formed directly from the internal 24-bit representations and 16-bit pixel formats are generated by truncating the internal 24-bit values to the appropriate number of bits. For formats supporting an alpha value, the PXP assigns the alpha using the 8-bit value in the REG_OUT_CTRL[ALPHA] field. For ARGB1555, the most significant alpha bit is appended to the output pixel. Also, for ARGB4444, the most significant nibble is appended to the output pixel. Single and dual buffer YUV output formats are also available. Since each pixel in the data path is represented by a full YUV444 24bpp value, decimation reduces the output in cases of YUV422/420 output formats.
36.5.3 Rotation/Flip operations

The PXP supports four rotation angles in conjunction with vertical and horizontal flip options. The flip operations effectively take place before the rotation.

Rotations of 0, 90, 180, and 270 degrees are supported and any combination of rotation and flip are supported. There is no performance difference between any of these modes of operation.

36.6 Queuing PXP transactions

The PXP supports a primitive ability to queue up one operation while the current operation is running. This is enabled through the use of the REG_NEXT register.

When this register is written, it enables the PXP to reload its current register contents with the data found at the location pointed to by this address when it completes processing of the current frame. This feature may be useful in helping to reduce the interrupt latency in servicing the PXP, especially in cases where the PXP and LCDIF are using the on-chip SRAM buffer handshake (since the PXP must begin generating next frame data immediately).

If the PXP is idle when the REG_NEXT register is written, the PXP treats this as an indication that it should immediately load the values at the pointer and begin processing the frame. This ability should allow software to use the same routines when programming the PXP (so that the first frame doesn't differ from subsequent frames).

When loading values from the NEXT register, all registers in the PXP are reloaded. Some register loads have no effect.

After writing the REG_NEXT register, the PXP will set the REG_NEXT[ENABLED] bit of the REG_NEXT register to indicate that the next command has been queued. Software should first check the status of this bit to ensure that a previous command has not been enabled. Likewise, after programming the first frame in a sequence of frames, software should poll this bit until it is sampled logic 1'b0 before queuing the next operation.

The PXP will issue interrupts from frames as they complete, regardless of whether they were started by writing the control registers directly or using the REG_NEXT register. When software receives an interrupt, it should check/clear the PXP's status register as normal, poll the REG_PXP[ENABLED] bit, and then issue the next operation. A queued operation may be cancelled by issuing a CLEAR operation to the REG_PXP[ENABLED] register bit. The SET and TOGGLE operations should never be used with this register.
36.7 Error Handling

The PXP does minimal checking on the control registers, so it is important that these are correctly specified. The PXP does monitor the bus transactions for errors and will report errors in the status register.

Upon receipt of a bus error, the PXP will set the ERROR interrupt and abort any further operations. Bus errors can be generated from any system access that results in an error response returned from the internal SIM Bus errors in the PXP are signaled as either a read or a write error, but do not indicate the failing address. Software may deduce the failing address from the current block status indicators.

36.7.1 Known PXP Limitations/Issues

The PXP has the following known limitations:

1. When using the NEXT register, the interrupt enable setting should remain the same for all frames. If not, the PXP will change the interrupt enable register value and possible cause the loss of an interrupt.
2. Rotations of 180/270 are not supported when performing LCD handshakes

36.8 PXP Memory Map/Register Definition

PXP Hardware Register Format Summary

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_4000</td>
<td>Control Register 0 (PXP_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>36.8.1/1925</td>
</tr>
<tr>
<td>402B_4004</td>
<td>Control Register 0 (PXP_CTRL_SET)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>36.8.1/1925</td>
</tr>
<tr>
<td>402B_4008</td>
<td>Control Register 0 (PXP_CTRL_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>36.8.1/1925</td>
</tr>
<tr>
<td>402B_400C</td>
<td>Control Register 0 (PXP_CTRL_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>C000_0000h</td>
<td>36.8.1/1925</td>
</tr>
<tr>
<td>402B_4010</td>
<td>Status Register (PXP_STAT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.2/1928</td>
</tr>
<tr>
<td>402B_4014</td>
<td>Status Register (PXP_STAT_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.2/1928</td>
</tr>
<tr>
<td>402B_4018</td>
<td>Status Register (PXP_STAT_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.2/1928</td>
</tr>
<tr>
<td>402B_401C</td>
<td>Status Register (PXP_STAT_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.2/1928</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_4020</td>
<td>Output Buffer Control Register (PXP_OUT_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.3/1929</td>
</tr>
<tr>
<td>402B_4024</td>
<td>Output Buffer Control Register (PXP_OUT_CTRL_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.3/1929</td>
</tr>
<tr>
<td>402B_4028</td>
<td>Output Buffer Control Register (PXP_OUT_CTRL_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.3/1929</td>
</tr>
<tr>
<td>402B_402C</td>
<td>Output Buffer Control Register (PXP_OUT_CTRL_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.3/1929</td>
</tr>
<tr>
<td>402B_4030</td>
<td>Output Frame Buffer Pointer (PXP_OUT_BUF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.4/1931</td>
</tr>
<tr>
<td>402B_4040</td>
<td>Output Frame Buffer Pointer #2 (PXP_OUT_BUF2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.5/1932</td>
</tr>
<tr>
<td>402B_4050</td>
<td>Output Buffer Pitch (PXP_OUT_PITCH)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.6/1933</td>
</tr>
<tr>
<td>402B_4060</td>
<td>Output Surface Lower Right Coordinate (PXP_OUT_LRC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.7/1933</td>
</tr>
<tr>
<td>402B_4070</td>
<td>Processed Surface Upper Left Coordinate (PXP_OUT_PS_ULC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.8/1934</td>
</tr>
<tr>
<td>402B_4080</td>
<td>Processed Surface Lower Right Coordinate (PXP_OUT_PS_LRC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.9/1935</td>
</tr>
<tr>
<td>402B_4090</td>
<td>Alpha Surface Upper Left Coordinate (PXP_OUT_AS_ULC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.10/1936</td>
</tr>
<tr>
<td>402B_40A0</td>
<td>Alpha Surface Lower Right Coordinate (PXP_OUT_AS_LRC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.11/1936</td>
</tr>
<tr>
<td>402B_40B0</td>
<td>Processed Surface (PS) Control Register (PXP_PS_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.12/1938</td>
</tr>
<tr>
<td>402B_40B4</td>
<td>Processed Surface (PS) Control Register (PXP_PS_CTRL_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.12/1938</td>
</tr>
<tr>
<td>402B_40B8</td>
<td>Processed Surface (PS) Control Register (PXP_PS_CTRL_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.12/1938</td>
</tr>
<tr>
<td>402B_40BC</td>
<td>Processed Surface (PS) Control Register (PXP_PS_CTRL_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.12/1938</td>
</tr>
<tr>
<td>402B_40C0</td>
<td>PS Input Buffer Address (PXP_PS_BUF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.13/1940</td>
</tr>
<tr>
<td>402B_40D0</td>
<td>PS U/Cb or 2 Plane UV Input Buffer Address (PXP_PS_UBUF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.14/1940</td>
</tr>
<tr>
<td>402B_40E0</td>
<td>PS V/Cr Input Buffer Address (PXP_PS_VBUF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.15/1941</td>
</tr>
<tr>
<td>402B_40F0</td>
<td>Processed Surface Pitch (PXP_PS_PITCH)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.16/1942</td>
</tr>
<tr>
<td>402B_4100</td>
<td>PS Background Color (PXP_PS_BACKGROUND)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.17/1942</td>
</tr>
<tr>
<td>402B_4110</td>
<td>PS Scale Factor Register (PXP_PS_SCALE)</td>
<td>32</td>
<td>R/W</td>
<td>1000_1000h</td>
<td>36.8.18/1943</td>
</tr>
<tr>
<td>402B_4120</td>
<td>PS Scale Offset Register (PXP_PS_OFFSET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.19/1944</td>
</tr>
<tr>
<td>402B_4130</td>
<td>PS Color Key Low (PXP_PS_CLRKEYLOW)</td>
<td>32</td>
<td>R/W</td>
<td>00FF_FFFFh</td>
<td>36.8.20/1945</td>
</tr>
<tr>
<td>402B_4140</td>
<td>PS Color Key High (PXP_PS_CLRKEYHIGH)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.21/1946</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### PXP memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402B_4150</td>
<td>Alpha Surface Control (PXP_AS_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.22/1947</td>
</tr>
<tr>
<td>402B_4160</td>
<td>Alpha Surface Buffer Pointer (PXP_AS_BUF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.23/1949</td>
</tr>
<tr>
<td>402B_4170</td>
<td>Alpha Surface Pitch (PXP_AS_PITCH)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.24/1950</td>
</tr>
<tr>
<td>402B_4180</td>
<td>Overlay Color Key Low (PXP_AS_CLRKEYLOW)</td>
<td>32</td>
<td>R/W</td>
<td>00FF_FFFFh</td>
<td>36.8.25/1950</td>
</tr>
<tr>
<td>402B_4190</td>
<td>Overlay Color Key High (PXP_AS_CLRKEYHIGH)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.26/1951</td>
</tr>
<tr>
<td>402B_41A0</td>
<td>Color Space Conversion Coefficient Register 0 (PXP_CSC1_COEF0)</td>
<td>32</td>
<td>R/W</td>
<td>0400_0000h</td>
<td>36.8.27/1952</td>
</tr>
<tr>
<td>402B_41B0</td>
<td>Color Space Conversion Coefficient Register 1 (PXP_CSC1_COEF1)</td>
<td>32</td>
<td>R/W</td>
<td>0123_0208h</td>
<td>36.8.28/1953</td>
</tr>
<tr>
<td>402B_41C0</td>
<td>Color Space Conversion Coefficient Register 2 (PXP_CSC1_COEF2)</td>
<td>32</td>
<td>R/W</td>
<td>079B_076Ch</td>
<td>36.8.29/1954</td>
</tr>
<tr>
<td>402B_4320</td>
<td>PXP Power Control Register (PXP_POWER)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.30/1955</td>
</tr>
<tr>
<td>402B_4400</td>
<td>Next Frame Pointer (PXP_NEXT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.31/1955</td>
</tr>
<tr>
<td>402B_4440</td>
<td>PXP Alpha Engine A Control Register. (PXP_PORTER_DUFF_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>36.8.32/1958</td>
</tr>
</tbody>
</table>

### 36.8.1 Control Register 0 (PXP_CTRL0)

The CTRL register contains controls for the PXP module.

PXP_CTRL: 0x000
PXP_CTRL_SET: 0x004
PXP_CTRL_CLR: 0x008
PXP_CTRL_TOG: 0x00C

The Control register contains the primary controls for the PXP block. The present bits indicate which of the sub-features of the block are present in the hardware.

**EXAMPLE**

```c
PXP_CTRL_SET(BM_PXP_CTRL_SFTRST);
PXP_CTRL_CLR(BM_PXP_CTRL_SFTRST | BM_PXP_CTRL_CLKGATE);
```
PXP Memory Map/Register Definition

Address: \(402B_{16}.4000h\) base + 0h offset + \((4d \times i)\), where \(i=0d\) to \(3d\)

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

1926

NXP Semiconductors
### PXP_CTRLn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 SFTRST</td>
<td>Set this bit to zero to enable normal PXP operation. Set this bit to one (default) to disable clocking with the PXP and hold it in its reset (lowest power) state. This bit can be turned on and then off to reset the PXP block to its default state.</td>
</tr>
<tr>
<td>30 CLKGATE</td>
<td>This bit must be set to zero for normal operation. When set to one it gates off the clocks to the block.</td>
</tr>
<tr>
<td>29 RSVD4</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>28 EN_REPEAT</td>
<td>Enable the PXP to run continuously. When this bit is set, the PXP will repeat based on the current configuration register settings. If this bit is not set, the PXP will complete the process and enter the idle state ready to accept the next frame to be processed. This bit should be set when the LCDIF handshake mode is enabled so that the next frame is automatically generated for the next screen refresh cycle. If it is not set and the handshake mode is enabled, the CPU will have to initiate the PXP for the next refresh cycle. When the PXP NEXT feature is used, it has priority over the REPEAT mode, in that the new register settings are fetched first, and then the next PXP operation will continue.</td>
</tr>
<tr>
<td>27–24 RSVD3</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>23 BLOCK_SIZE</td>
<td>Select the block size to process.</td>
</tr>
<tr>
<td>22 ROT_POS</td>
<td>This bit controls where rotation will occur in the PXP datapath. Setting this bit to 1'b0 will place the rotation resources at the output stage of the PXP data path. Image compositing will occur before pixels are processed for rotation. Setting this bit to a 1'b1 will place the rotation resources before image composition. Only the PS can be rotated in this configuration and AS will not be rotated.</td>
</tr>
<tr>
<td>21–12 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>11 VFLIP</td>
<td>Indicates that the output buffer should be flipped vertically (effect applied before rotation).</td>
</tr>
<tr>
<td>10 HFLIP</td>
<td>Indicates that the output buffer should be flipped horizontally (effect applied before rotation).</td>
</tr>
<tr>
<td>9–8 ROTATE</td>
<td>Indicates the clockwise rotation to be applied at the output buffer. The rotation effect is defined as occurring after the FLIP_X and FLIP_Y permutation.</td>
</tr>
<tr>
<td>7–5 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4 ENABLE_LCD_HANDSHAKE</td>
<td>Enable handshake with LCD controller. When this is set, the PXP will not process an entire framebuffer, but will instead process rows of NxN blocks in a double-buffer handshake with the LCDIF. This enables the use of the onboard SRAM for a partial frame buffer.</td>
</tr>
<tr>
<td>3 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>2 NEXT_IRQ_ENABLE</td>
<td>Next command interrupt enable. When set, the PXP will issue an interrupt when a queued command initiated by a write to the PXP_NEXT register has been loaded into the PXP's registers. This interrupt also indicates that a new command may now be queued.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### PXP_CTRL field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IRQ_ENABLE</td>
<td>Interrupt enable. NOTE: When using the PXP_NEXT functionality to reprogram the PXP, the new value of this bit will be used and may therefore enable or disable an interrupt unintentionally.</td>
</tr>
<tr>
<td>ENABLE</td>
<td>Enables PXP operation with specified parameters. The ENABLE bit will remain set while the PXP is active and will be cleared after the current operation completes. Software should use the IRQ bit in the PXP_STAT when polling for PXP completion.</td>
</tr>
</tbody>
</table>

### 36.8.2 Status Register (PXP_STATn)

The PXP Interrupt Status register provides interrupt status information.

- **PXP_STAT**: 0x010
- **PXP_STAT_SET**: 0x014
- **PXP_STAT_CLR**: 0x018
- **PXP_STAT_TOG**: 0x01C

This register provides PXP interrupt status and the current X/Y block coordinate that is being processed.

**EXAMPLE**

```c
PXP_STAT_CLR(BM_PXP_STAT_IRQ);  // clear CSC interrupt
```

Address: 402B_4000h base + 10h offset + (4d × i), where i=0d to 3d

---

```plaintext
Bit 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---
R | BLOCKX | | | | | | | | | | | | | | | | |
W | | | | | | | | | | | | | | | | |
 Reset | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0
```

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
P XP_STATn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 BLOCKX</td>
<td>Indicates the X coordinate of the block currently being rendered.</td>
</tr>
<tr>
<td>23–16 BLOCKY</td>
<td>Indicates the X coordinate of the block currently being rendered.</td>
</tr>
<tr>
<td>15–9 RSVD2</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>8 LUT_DMA_LOAD_DONE_IRQ</td>
<td>Indicates that the LUT DMA transfer has completed.</td>
</tr>
<tr>
<td>7–4 AXI_ERROR_ID</td>
<td>Indicates the AXI ID of the failing bus operation.</td>
</tr>
<tr>
<td>3 NEXT_IRQ</td>
<td>Indicates that a command issued with the &quot;Next Command&quot; functionality has been issued and that a new command may be initiated with a write to the P XP_NEXT register.</td>
</tr>
<tr>
<td>2 AXI_READ_ERROR</td>
<td>Indicates P XP encountered an AXI read error and processing has been terminated.</td>
</tr>
<tr>
<td>1 AXI_WRITE_ERROR</td>
<td>Indicates P XP encountered an AXI write error and processing has been terminated.</td>
</tr>
<tr>
<td>0 IRQ</td>
<td>Indicates current P XP interrupt status. The IRQ is routed through the pxp_irq when the IRQ_ENABLE bit in the control register is set.</td>
</tr>
</tbody>
</table>

36.8.3 Output Buffer Control Register (P XP_OUT_CTRLn)

The OUT_CTRL register contains controls for the Output Buffer.

P XP_OUT_CTRL: 0x020
The Control register contains the primary controls for the PXP block. The present bits indicate which of the sub-features of the block are present in the hardware.

EXAMPLE

```c
PXP_CTRL_SET(BM_PXP_CTRL_SFTRST);
PXP_CTRL_CLR(BM_PXP_CTRL_SFTRST | BM_PXP_CTRL_CLKGATE);
```

Address: 402B_4000h base + 20h offset + (4d × i), where i=0d to 3d

![Memory Map Diagram]
### PXP_OUT_CTRL\_n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 ALPHA</td>
<td>When generating an output buffer with an alpha component, the value in this field will be used when enabled to override the alpha passed through the pixel data pipeline.</td>
</tr>
<tr>
<td>23 ALPHA_OUTPUT</td>
<td>Indicates that alpha component in output buffer pixels should be overwritten by PXP_OUT_CTRL[ALPHA]. If 0, retain their alpha value from the computed alpha for that pixel.</td>
</tr>
<tr>
<td>22–10 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>9–8 INTERLACED_OUTPUT</td>
<td>Determines how the PXP writes it's output data. Output interlacing should not be used in conjunction with input interlacing. Splitting frames into fields is most efficient using output interlacing. 2-plane output formats AND interlaced output is NOT supported.</td>
</tr>
<tr>
<td>7–5 RSVD0</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>FORMAT</td>
<td>Output framebuffer format. The UV byte lanes are synonymous with CbCr byte lanes for YUV output pixel formats. For example, the YUV2P420 format should be selected when the output is YCbCr 2-plane 420 output format.</td>
</tr>
<tr>
<td></td>
<td>0x0 PROGRESSIVE — All data written in progressive format to the OUTBUF Pointer.</td>
</tr>
<tr>
<td></td>
<td>0x1 FIELD0 — Interlaced output: only data for field 0 is written to the OUTBUF Pointer.</td>
</tr>
<tr>
<td></td>
<td>0x2 FIELD1 — Interlaced output: only data for field 1 is written to the OUTBUF2 Pointer.</td>
</tr>
<tr>
<td></td>
<td>0x3 INTERLACED — Interlaced output: data for field 0 is written to OUTBUF and data for field 1 is written to OUTBUF2.</td>
</tr>
<tr>
<td></td>
<td>0x0 ARGB8888 — 32-bit pixels</td>
</tr>
<tr>
<td></td>
<td>0x4 RGB888 — 32-bit pixels (unpacked 24-bit pixel in 32 bit DWORD.)</td>
</tr>
<tr>
<td></td>
<td>0x5 RGB888P — 24-bit pixels (packed 24-bit format)</td>
</tr>
<tr>
<td></td>
<td>0x8 ARGB1555 — 16-bit pixels</td>
</tr>
<tr>
<td></td>
<td>0x9 ARGB4444 — 16-bit pixels</td>
</tr>
<tr>
<td></td>
<td>0xC RGB565 — 16-bit pixels</td>
</tr>
<tr>
<td></td>
<td>0x10 YUV1P444 — 32-bit pixels (1-plane XYUV unpacked)</td>
</tr>
<tr>
<td></td>
<td>0x12 UYY1P422 — 16-bit pixels (1-plane U0,Y0,V0,Y1 interleaved bytes)</td>
</tr>
<tr>
<td></td>
<td>0x13 VYY1P422 — 16-bit pixels (1-plane V0,Y0,U0,Y1 interleaved bytes)</td>
</tr>
<tr>
<td></td>
<td>0x14 Y8 — 8-bit monochrome pixels (1-plane Y luma output)</td>
</tr>
<tr>
<td></td>
<td>0x15 Y4 — 4-bit monochrome pixels (1-plane Y luma, 4 bit truncation)</td>
</tr>
<tr>
<td></td>
<td>0x18 YUV2P422 — 16-bit pixels (2-plane UV interleaved bytes)</td>
</tr>
<tr>
<td></td>
<td>0x19 YUV2P420 — 16-bit pixels (2-plane UV)</td>
</tr>
<tr>
<td></td>
<td>0x1A YVU2P422 — 16-bit pixels (2-plane VU interleaved bytes)</td>
</tr>
<tr>
<td></td>
<td>0x1B YVU2P420 — 16-bit pixels (2-plane VU)</td>
</tr>
</tbody>
</table>

### 36.8.4 Output Frame Buffer Pointer (PXP_OUT_BUF)

Output Framebuffer Pointer. This register points to the beginning of the output frame buffer. This pointer is used for progressive format and field 0 when generating interlaced output.
This register is used by the logic to point to the current output location for the output frame buffer.

**EXAMPLE**

```c
PXP_OUT_BUF_WR( buffer );
```

Address: 402B_4000h base + 30h offset = 402B_4030h

<table>
<thead>
<tr>
<th>Bit</th>
<th>ADDR</th>
<th>W</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**PXP_OUT_BUF field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Current address pointer for the output frame buffer. The address can have any byte alignment. 64B alignment is recommended for optimal performance.</td>
</tr>
</tbody>
</table>

### 36.8.5 Output Frame Buffer Pointer #2 (PXP_OUT_BUF2)

Output Framebuffer Pointer #2. This register points to the beginning of the output frame buffer for either field 1 when generating interlaced output or for the UV buffer when in YUV 2-plane output modes. Both interlaced output AND 2-plane output modes are not supported in a single PXP operation. This register is not used as the pointer to the second buffer when in LCDIF_HANDSHAKE mode.

This register is used by the logic to point to the current output location for the field 1 or UV output frame buffer.

**EXAMPLE**

```c
PXP_OUT_BUF_WR( field0 );  // buffer for interlaced field 0
PXP_OUT_BUF2_WR( field1 ); // buffer for interlaced field 1
```

Address: 402B_4000h base + 40h offset = 402B_4040h

<table>
<thead>
<tr>
<th>Bit</th>
<th>ADDR</th>
<th>W</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**PXP_OUT_BUF2 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Current address pointer for the output frame buffer. The address can have any byte alignment. 64B alignment is recommended for optimal performance.</td>
</tr>
</tbody>
</table>
36.8.6 Output Buffer Pitch (PXP_OUT_PITCH)

This register contains the output buffer pitch in bytes.

Any byte value will indicate the vertical pitch. This value will be used in output pixel address calculations.

**EXAMPLE**

```c
PXP_OUT_PITCH_WR( 68 * 4 );  // The output buffer pitch is 68 pixels times 32 bits per pixel
```

Address: 402B_4000h base + 50h offset = 402B_4050h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>RSVD</th>
<th>PITCH</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>30</td>
<td>29</td>
<td>28</td>
<td>27</td>
</tr>
<tr>
<td>26</td>
<td>25</td>
<td>24</td>
<td>23</td>
<td>22</td>
</tr>
<tr>
<td>21</td>
<td>20</td>
<td>19</td>
<td>18</td>
<td>17</td>
</tr>
<tr>
<td>16</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
</tr>
<tr>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
</tr>
<tr>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**PXP_OUT_PITCH field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>RSVD Reserved, always set to zero.</td>
</tr>
<tr>
<td>PITCH</td>
<td>Indicates the number of bytes in memory between two vertically adjacent pixels.</td>
</tr>
</tbody>
</table>

36.8.7 Output Surface Lower Right Coordinate (PXP_OUT_LRC)

This register contains the size, or lower right coordinate, of the output buffer NOT rotated. It is implied that the upper left coordinate of the output surface is always [0,0]. When rotating the framebuffer, the PXP will automatically swap the X/Y, or WIDTH/HEIGHT, to accomodate the rotated size.

This register sets the size of the output frame buffer in pixels, not blocks. The frame buffer need not be a multiple of NxN pixels. Partial blocks will be written for output frame buffer sizes that are not divisable by N pixels in either dimension.

**EXAMPLE**

```c
PXP_OUT_LRC[X]=319;   // set width of output frame buffer to 320 pixels
PXP_OUT_LRC[Y]=243;  // set height of output frame buffer to 244 pixels which is not divisible by block size N
PXP_OUT_LRC_WR( BF_PXP_OUT_LRC_X(319)  |  BF_PXP_OUT_LRC_Y(243) );
```
PXP Memory Map/Register Definition

Address: 402B_4000h base + 60h offset = 402B_4060h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RSVDD1</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RSVDO</td>
<td>Y</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**PXP_OUT_LRC field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>29–16 X</td>
<td>Indicates number of horizontal PIXELS in the output surface (non-rotated). The output buffer pixel width minus 1 should be programmed. The image size is not required to be a multiple of 8 pixels. The PXP will clip the pixel output at this boundary.</td>
</tr>
<tr>
<td>15–14 RSVDO</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>Y</td>
<td>Indicates the number of vertical PIXELS in the output surface (non-rotated). The output buffer pixel height minus 1 should be programmed. The image size is not required to be a multiple of 8 pixels. The PXP will clip the pixel output at this boundary.</td>
</tr>
</tbody>
</table>

36.8.8 Processed Surface Upper Left Coordinate (PXP_OUT_PS_ULC)

This register contains the upper left pixel coordinate for the Processed Surface in the OUTPUT buffer.

This register contains the upper left coordinate of the Processed Surface in the output frame buffer (in pixels). Values that are within the PXP_OUT_LRC X,Y extents are valid. The lowest valid value for these fields is 0,0. If the value of the PXP_OUT_PS_ULC is greater than the PXP_OUT_LRC, then no PS pixels will be fetched from memory, but only PXP_PSBACKGROUND pixels will be processed by the PS engine. Pixel locations that are greater than or equal to the PS upper left coordinates, less than or equal to the PS lower right coordinates, and within the PXP_OUT_LRC extents will use the PS to render pixels into the output buffer.

**EXAMPLE**

PXP_OUT_PS_ULC_WR(0x0002_0002); // Processed Surface upper left coordinate at (X,Y) = 2,2. The PS surface will not effect pixels in the first and second row and column of the output buffer.
Address: 402B_4000h base + 70h offset = 402B_4070h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RSV0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RSV0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**PXP_OUT_PS_ULC field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 RSV0</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>29–16 X</td>
<td>This field indicates the upper left X-coordinate (in pixels) of the processed surface (PS) in the output buffer.</td>
</tr>
<tr>
<td>15–14 RSV0</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>Y</td>
<td>This field indicates the upper left Y-coordinate (in pixels) of the processed surface in the output buffer.</td>
</tr>
</tbody>
</table>

### 36.8.9 Processed Surface Lower Right Coordinate (PXP_OUT_PS_LRC)

This register contains the lower right extent for the Processed Surface in the OUTPUT buffer.

This register contains the lower right coordinate of the Processed Surface in the output frame buffer (in pixels). Values that are within the PXP_OUT_LRC X,Y extents are valid. The lowest valid value for these fields is 0,0. Pixel locations that are greater than or equal to the PS upper left coordinates, less than or equal to the PS lower right coordinates, and within the PXP_OUT_LRC extents will use the PS to render pixels into the output buffer.

**EXAMPLE**

```c
PXP_OUT_PS_ULC_WR(0, 0x03FF_03FF); // With this UL/LR pair of pixel coordinates, only one pixel at OUT[X,Y]=1023,1023 will use the PS to contribute to its value.
PXP_OUT_PS_LRC_WR(0, 0x03FF_03FF);
```
PXP Memory Map/Register Definition

Address: 402B_4000h base + 80h offset = 402B_4080h

---

**PXP_OUT_PS_LRC field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>29–16 X</td>
<td>This field indicates the lower right X-coordinate (in pixels) of the processed surface (PS) in the output frame buffer.</td>
</tr>
<tr>
<td>15–14 RSVD0</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>15–14 Y</td>
<td>This field indicates the lower right Y-coordinate (in pixels) of the processed surface in the output frame buffer.</td>
</tr>
</tbody>
</table>

---

### 36.8.10 Alpha Surface Upper Left Coordinate (PXP_OUT_AS_ULC)

This register contains the upper left location for the Alpha Surface in the output buffer.

This register contains the upper left coordinate of AS in the output frame buffer (in pixels). Values that are within the PXP_OUT_LRC X,Y extents are valid. The lowest valid value for these fields is 0,0. Pixel locations that are greater than or equal to the upper left coordinates will use the AS to render pixels in the output buffer.

**EXAMPLE**

```
PXP_OUT_AS_ULC_WR(0,0x0001_0001); // Alpha Surface upper left coordinate at (X,Y) = 1,1. The AS surface will not effect pixels in the first row or first column of the output buffer.
```

Address: 402B_4000h base + 90h offset = 402B_4090h

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### 36.8.11 Alpha Surface Lower Right Coordinate (PXP_OUT_AS_LRC)

This register contains the lower right extent for Alpha Surface in the output buffer. This register contains the lower right coordinate of AS in the output frame buffer (in pixels). Values that are within the PXP_OUT_LRC X,Y extents are valid. The lowest valid value for these fields is 0,0. Pixel locations that are less than or equal to the lower right coordinates will use the AS to render pixels in the output buffer.

**EXAMPLE**

```
PXP_AS_LRC_WR(0,0x03FF_03FF); // Alpha Surface lower right coordinate at (X,Y) = 1023,1023.
```

Address: 402B_4000h base + A0h offset = 402B_40A0h

---

**PXP_OUT_AS_ULC field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>RSVD1</td>
<td></td>
</tr>
<tr>
<td>29–16</td>
<td>X</td>
</tr>
<tr>
<td>X</td>
<td>This field indicates the upper left X-coordinate (in pixels) of the alpha surface (AS) in the output frame buffer.</td>
</tr>
<tr>
<td>15–14</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>RSVD0</td>
<td></td>
</tr>
<tr>
<td>Y</td>
<td>This field indicates the upper left Y-coordinate (in pixels) of the alpha surface in the output frame buffer.</td>
</tr>
</tbody>
</table>

---

**Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0**

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

| Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0** |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| R | W | Reset |
|   |   | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |

---

#### Field Descriptions

- **RSVD0**: Reserved, always set to zero.
- **Y**: This field indicates the upper left Y-coordinate (in pixels) of the alpha surface in the output frame buffer.
- **X**: This field indicates the upper left X-coordinate (in pixels) of the alpha surface (AS) in the output frame buffer.
### PXP_OUT_AS_LRC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>29–16 X</td>
<td>This field indicates the lower right X-coordinate (in pixels) of the alpha surface (AS) in the output frame buffer.</td>
</tr>
<tr>
<td>15–14 RSVD0</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>Y</td>
<td>This field indicates the lower right Y-coordinate (in pixels) of the alpha surface in the output frame buffer.</td>
</tr>
</tbody>
</table>

#### 36.8.12 Processed Surface (PS) Control Register (PXP_PS_CTRLn)

The PS_CTRL register contains controls for the Processed Surface Buffer.

- **PXP_PS_CTRL**: 0x0B0
- **PXP_PS_CTRL_SET**: 0xb4
- **PXP_PS_CTRL_CLR**: 0xB8
- **PXP_PS_CTRL_TOG**: 0xBC

The Control register contains the primary controls for the PXP block. The present bits indicate which of the sub-features of the block are present in the hardware.

**EXAMPLE**

```c
PXP_CTRL_SET(BM_PXP_CTRL_SFTRST);  
PXP_CTRL_CLR(BM_PXP_CTRL_SFTRST | BM_PXP_CTRL_CLKGATE);  
```

Address: 402B_4000h base + B0h offset + (4d × i), where i=0d to 3d
### PXP_PS_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>11–10 DECX</td>
<td>Horizontal pre decimation filter control.</td>
</tr>
<tr>
<td>0x0</td>
<td>DISABLE — Disable pre-decimation filter.</td>
</tr>
<tr>
<td>0x1</td>
<td>DECX2 — Decimate PS by 2.</td>
</tr>
<tr>
<td>0x2</td>
<td>DECX4 — Decimate PS by 4.</td>
</tr>
<tr>
<td>0x3</td>
<td>DECX8 — Decimate PS by 8.</td>
</tr>
<tr>
<td>9–8 DECY</td>
<td>Verticle pre decimation filter control.</td>
</tr>
<tr>
<td>0x0</td>
<td>DISABLE — Disable pre-decimation filter.</td>
</tr>
<tr>
<td>0x1</td>
<td>DECY2 — Decimate PS by 2.</td>
</tr>
<tr>
<td>0x2</td>
<td>DECY4 — Decimate PS by 4.</td>
</tr>
<tr>
<td>0x3</td>
<td>DECY8 — Decimate PS by 8.</td>
</tr>
<tr>
<td>7–6 RSVD0</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>5 WB_SWAP</td>
<td>Swap bytes in words. For each 16 bit word, the two bytes will be swapped.</td>
</tr>
<tr>
<td>FORMAT</td>
<td>PS buffer format. To select between YUV and YCbCr formats, see bit 31 of the CSC1_COEF0 register.</td>
</tr>
<tr>
<td>0x4</td>
<td>RGB888 — 32-bit pixels (unpacked 24-bit format)</td>
</tr>
<tr>
<td>0xC</td>
<td>RGB555 — 16-bit pixels</td>
</tr>
<tr>
<td>0xD</td>
<td>RGB444 — 16-bit pixels</td>
</tr>
<tr>
<td>0xE</td>
<td>RGB565 — 16-bit pixels</td>
</tr>
<tr>
<td>0x10</td>
<td>YUV1P444 — 32-bit pixels (1-plane XYUV unpacked)</td>
</tr>
<tr>
<td>0x12</td>
<td>UYVV1P422 — 16-bit pixels (1-plane U0,Y0,V0,Y1 interleaved bytes)</td>
</tr>
<tr>
<td>0x13</td>
<td>VYUY1P422 — 16-bit pixels (1-plane V0,Y0,U0,Y1 interleaved bytes)</td>
</tr>
<tr>
<td>0x14</td>
<td>Y8 — 8-bit monochrome pixels (1-plane Y luma output)</td>
</tr>
<tr>
<td>0x15</td>
<td>Y4 — 4-bit monochrome pixels (1-plane Y luma, 4 bit truncation)</td>
</tr>
<tr>
<td>0x18</td>
<td>YUV2P422 — 16-bit pixels (2-plane UV interleaved bytes)</td>
</tr>
<tr>
<td>0x19</td>
<td>YUV2P420 — 16-bit pixels (2-plane UV)</td>
</tr>
<tr>
<td>0x1A</td>
<td>YUV2P422 — 16-bit pixels (2-plane VU interleaved bytes)</td>
</tr>
<tr>
<td>0x1B</td>
<td>YUV2P420 — 16-bit pixels (2-plane VU)</td>
</tr>
<tr>
<td>0x1E</td>
<td>YUV422 — 16-bit pixels (3-plane format)</td>
</tr>
<tr>
<td>0x1F</td>
<td>YUV420 — 16-bit pixels (3-plane format)</td>
</tr>
</tbody>
</table>
36.8.13 PS Input Buffer Address (PXP_PS_BUF)

PS Input Buffer Address. This should be programmed to the starting address of the RGB data or Y (luma) data for the PS plane.

This register contains the pointer to the Luma/RGB buffer. If the application requires an offset into the PS buffer, then this address can be set so that the desired offset is achieved. Any byte address is valid. For best performance, 64B alignment is recommended.

EXAMPLE

PXP_PS_BUF_WR(image_rgb); // RGB image
PXP_PS_BUF_WR(image_y);   // Y (luma) image data
PXP_PS_UBUF_WR(image_u);  // U (Cb) image data
PXP_PS_VBUF_WR(image_v);  // V (Cr) image data

Address: 402B_4000h base + C0h offset = 402B_40C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>ADDR</td>
</tr>
<tr>
<td>0</td>
<td>Reset</td>
</tr>
</tbody>
</table>

PXP_PS_BUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Address pointer for the PS RGB or Y (luma) input buffer.</td>
</tr>
</tbody>
</table>

36.8.14 PS U/Cb or 2 Plane UV Input Buffer Address (PXP_PS_UBUF)

PS Chroma (U/Cb/UV) Input Buffer Address. This register points to the beginning of the PS U/Cb input buffer. In two plane operation, this register points to the beginning of the PS UV chroma input buffer.

This register contains the pointer to the Chroma U/Cb or 2 plane UV buffer. This register is unused when processing 1-plane buffer formats. If the application requires an offset into the PS buffer, then this address can be set so that the desired offset is achieved. Any byte address is valid. For best performance, 64B alignment is recommended.

EXAMPLE

PXP_PS_BUF_WR(image_y);   // Y (luma) image data
PXP_PS_UBUF_WR(image_u);  // U (Cb) image data
PXP_PS_VBUF_WR(image_v);  // V (Cr) image data
Address: 402B_4000h base + D0h offset = 402B_40D0h

### PXP_PS_VBUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Address pointer for the PS U/Cb or 2 plane UV Chroma input buffer.</td>
</tr>
</tbody>
</table>

#### 36.8.15 PS V/Cr Input Buffer Address (PXP_PS_VBUF)

PS Chroma (V/Cr) Input Buffer Address. This register points to the beginning of the PS V/Cr input buffer. In one or two plane operation, this register is not used. In monochrome modes Y8 and Y4, the low 16 bits are used as the U/V data in the datapath instead of sourcing U/V data from external buffers. In this case, it represents a fixed value for U/V data.

This register contains the pointer to the Chroma V/Cr buffer. For Y8/Y4 modes, the low 16 bits are used as the monochrome U and V values in the data path. Bits [15:8] represent the U data byte, and bits [7:0] represent the V data byte. Other than with Y8/Y4 input buffer formats, this register is unused when processing 1 or 2-plane buffer formats. If the application requires an offset into the PS buffer, then this address can be set so that the desired offset is achieved. Any byte address is valid. For best performance, 64B alignment is recommended.

**EXAMPLE**

```c
PXP_PS_BUF_WR(image_y); // Y (luma) image data
PXP_PS_UBUF_WR(image_u); // U (Cb) image data
PXP_PS_VBUF_WR(image_v); // V (Cr) image data
```

Address: 402B_4000h base + E0h offset = 402B_40E0h

### PXP_PS_VBUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Address pointer for the PS V/Cr Chroma input buffer.</td>
</tr>
</tbody>
</table>
36.8.16 Processed Surface Pitch (PXP_PS_PITCH)

This register contains the processed surface pitch in bytes.

Any byte value will indicate the vertical pitch of the PS source frame buffer. This value will be used in PS pixel address calculations. This value has no relation to the UL and LR registers. It specifies how many bytes are between two vertically adjacent pixels in the input PS surface. For multi-plane formats, the Y buffer pitch should be programmed. For 2-plane YUV422, the UV pitch is the same as the Y pitch. For 3-plane YUV422, the U and V pitch is 1/2 the Y pitch. For 2-plane YUV420, the UV pitch is 1/2 the Y pitch. For 3-plane YUV420, the U and V pitch is 1/4 the Y pitch. All source buffers should comply with these U and V resolution reductions with respect to their Y source buffers.

**EXAMPLE**

```
PXP_PS_PITCH_WR( 64 * 4 );  // The output buffer pitch is 64 pixels times 32 bits per pixel
```

Address: 402B_4000h base + F0h offset = 402B_40F0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**PXP_PS_PITCH field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>RSVDD</td>
<td>PITCH</td>
</tr>
<tr>
<td></td>
<td>Indicates the number of bytes in memory between two vertically adjacent pixels.</td>
</tr>
</tbody>
</table>

36.8.17 PS Background Color (PXP_PSBACKGROUND)

PS Background Pixel Color. This register provides a pixel value used when processing pixels outside of the region specified by the PS Coordinate registers. This value can effectively be used to set the color of the letterboxing region around the PS image.

This register contains a pixel value to be used for any PS pixels that fall outside the PS extents. This is effectively a background or letterbox color. The CSC1 control and datapath pixel format should be considered when selecting the background color.

**EXAMPLE**
PXP_PS_BACKGROUND_WR(0x00000000); // letterbox is black
PXP_PS_BACKGROUND_WR(0x00800000); // letterbox is dark red
PXP_PS_BACKGROUND_WR(0x00008000); // letterbox is dark green
PXP_PS_BACKGROUND_WR(0x00000080); // letterbox is dark blue

Address: 402B_4000h base + 100h offset = 402B_4100h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–24</th>
<th>23–20</th>
<th>19–16</th>
<th>15–12</th>
<th>11–8</th>
<th>7–4</th>
<th>3–0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RSVD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>COLOR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

PXP_PS_BACKGROUND field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>RSVD</td>
<td>Background color (in 24bpp format) for any pixels not within the buffer range specified by the PS ULC/LRC.</td>
</tr>
</tbody>
</table>

36.8.18 PS Scale Factor Register (PXP_PS_SCALE)

PS Scale Factor. This register provides the scale factor for the PS buffer.

The maximum down scaling factor is 1/2 such that the output image in either axis is 1/2 the size of the source. The maximum up scaling factor is 2^12 for either axis. The reciprocal of the scale factor should be loaded into this register. To reduce the PS buffer by a factor of two in the output frame buffer, a value of 0.0000_0000_0000 should be loaded into this register. To scale up by a factor of 4, the value of 0.0100_0000_0000, should be loaded into this register. To scale up by 8/5, the value of 0.1010_0000_0000 should be loaded.

EXAMPLE

PXP_PS_SCALE_WR(0x10001000); // 1:1 scaling (0x1.000)
PXP_PS_SCALE_WR(0x08000800); // 2x scaling (0x0.800)
PXP_PS_SCALE_WR(0x20002000); // 1/2x scaling (0x2.000)
PXP Memory Map/Register Definition

Address: 402B_4000h base + 110h offset = 402B_4110h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td><strong>RSVD2</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td><strong>RSVD1</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**PXP_PS_SCALE field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 RSV2</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>30–16 YSCALE</td>
<td>This is a two bit integer and 12 bit fractional representation (###.#####_#####) of the Y scaling factor for the PS source buffer. The maximum value programmed should be 2 since scaling down by a factor greater than 2 is not supported with the bilinear filter. Decimation and the bilinear filter should be used together to achieve scaling by more than a factor of 2.</td>
</tr>
<tr>
<td>15 RSV1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>XSNALE</td>
<td>This is a two bit integer and 12 bit fractional representation (###.#####_#####) of the X scaling factor for the PS source buffer. The maximum value programmed should be 2 since scaling down by a factor greater than 2 is not supported with the bilinear filter. Decimation and the bilinear filter should be used together to achieve scaling by more than a factor of 2.</td>
</tr>
</tbody>
</table>

**36.8.19 PS Scale Offset Register (PXP_PS_OFFSET)**

PS Scale Offset. This register provides the initial scale offset for the PS buffer.

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

1944

NXP Semiconductors
The X and Y offset provides the ability to access the source image with a per sub-pixel granularity. This provides the capability to use all source pixels to effect the output PS image. The fixed offset values can be used for sub-pixel adjustments in the bilinear scaling filter. For example, when scaling an image down by a factor of 2, an initial offset of 0x0 would result in sub-sampling every other pixel. If a fixed offset of 0x800 (1/2), all pixels are used in scaling the final output pixel value. In this case, the first output pixel would be the sum of (1/2*P0) + (1/2*P1). This fixed offset is applied after the decimation filter stage, and before the bilinear filter stage.

**EXAMPLE**

```
PXP_PS_SCALE_WR(0x2000_2000); // 1/2x scaling (0x2.000)
PXP_PS_OFFSET_WR(0x0800_0800); // half-pixel offset in both X and Y to ensure averaging versus pixel decimation
```

Address: 402B_4000h base + 120h offset = 402B_4120h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | RSV2 |     | YOFFSET | RSV1 |     | XOFFSET |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**PXP_PS_OFFSET field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>RSV2 Reserves, always set to zero.</td>
</tr>
<tr>
<td>27–16</td>
<td>YOFFSET This is a 12 bit fractional representation (0.####<em>####</em>####) of the Y scaling offset. This represents a fixed pixel offset which gets added to the scaled address to determine source data for the scaling engine.</td>
</tr>
<tr>
<td>15–12</td>
<td>RSV1 Reserves, always set to zero.</td>
</tr>
<tr>
<td>11–0</td>
<td>XOFFSET This is a 12 bit fractional representation (0.####<em>####</em>####) of the X scaling offset. This represents a fixed pixel offset which gets added to the scaled address to determine source data for the scaling engine.</td>
</tr>
</tbody>
</table>

**36.8.20 PS Color Key Low (PXP_PS_CLRKEYLOW)**

This register contains the color key low value for the PS buffer.

When processing an image, if the PXP finds a pixel in the PS buffer with a color that falls in the range between PXP_PS_CLRKEYLOW and PXP_PS_CLRKEYHIGH, it will insert the pixel from the AS channel. If the current AS pixel is letterboxed or if the AS also matches its colorkey range, the PXP_PS_BACKGROUND color is passed down the pixel pipeline.

**EXAMPLE**
36.8.21 PS Color Key High (PXP_PS_CLRKEYHIGH)

This register contains the color key high value for the PS buffer.

When processing an image, if the PXP finds a pixel in the PS buffer with a color that falls in the range between PXP_PS_CLRKEYLOW and PXP_PS_CLRKEYHIGH, it will insert the pixel from the AS channel. If the current AS pixel is letterboxed or if the AS also matches its colorkey range, the PXP_PS_BACKGROUND color is passed down the pixel pipeline.

EXAMPLE

```
// colorkey values between
PXP_PS_CLRKEYLOW_WR (0x008000); // medium green and
PXP_PS_CLRKEYHIGH_WR(0x00FF00); // light green
```

Address: 402B_4000h base + 140h offset = 402B_4140h
### PXP_PS_CLRKEYHIGH field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>RSVD1</td>
<td></td>
</tr>
<tr>
<td>PIXEL</td>
<td>High range of color key applied to PS buffer. To disable PS colorkeying, set the low colorkey to 0xFFFFFF and the high colorkey to 0x000000.</td>
</tr>
</tbody>
</table>

### 36.8.22 Alpha Surface Control (PXP_AS_CTRL)

This register contains buffer control for the Alpha Surface 0 input buffer. The Alpha Surface Parameter register provides additional controls for AS.

**EXAMPLE**

```c
u32 asparam;
   asparam = BF_PXP_ASPARAM_ENABLE (1);
   asparam |= BF_PXP_ASPARAM_ALPHA_CTRL (BV_PXP_ASPARAM_ALPHA_CTRL__ROPs);
   asparam |= BF_PXP_ASPARAM_FORMAT (BV_PXP_ASPARAM_FORMAT__ARGB8888);
   asparam |= BF_PXP_ASPARAM_ROP (BV_PXP_ASPARAM_ROP__XORAS);
   PXP_ASPARAM_WR(0, asparam); // enable alpha surface to perform XOR ROP using RGB8888 AS pixel format
```

Address: 402B_4000h base + 150h offset = 402B_4150h

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

RSVD1 | ALPHA_INVERT | ROP
```

Chapter 36 Pixel Pipeline (PXP)

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### PXP_AS_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–21 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>20</td>
<td>ALPHA_INVERT Setting this bit to logic 0 will not alter the alpha value. A logic 1 will invert the alpha value and apply (1-alpha) for image composition.</td>
</tr>
<tr>
<td>19–16 ROP</td>
<td>Indicates a raster operation to perform when enabled. Raster operations are enabled through the ALPHA_CTRL field.</td>
</tr>
<tr>
<td></td>
<td>0x0 MASKAS — AS AND PS</td>
</tr>
<tr>
<td></td>
<td>0x1 MASKNOTAS — nAS AND PS</td>
</tr>
<tr>
<td></td>
<td>0x2 MASKASNOT — AS AND nPS</td>
</tr>
<tr>
<td></td>
<td>0x3 MERGEAS — AS OR PS</td>
</tr>
<tr>
<td></td>
<td>0x4 MERGENOTAS — nAS OR PS</td>
</tr>
<tr>
<td></td>
<td>0x5 MERGEASNOT — AS OR nPS</td>
</tr>
<tr>
<td></td>
<td>0x6 NOTCOPYAS — nAS</td>
</tr>
<tr>
<td></td>
<td>0x7 NOT — nPS</td>
</tr>
<tr>
<td></td>
<td>0x8 NOTMASKAS — AS NAND PS</td>
</tr>
<tr>
<td></td>
<td>0x9 NOTMERGEAS — AS NOR PS</td>
</tr>
<tr>
<td></td>
<td>0xA XORAS — AS XOR PS</td>
</tr>
<tr>
<td></td>
<td>0xB NOTXORAS — AS XNOR PS</td>
</tr>
<tr>
<td>15–8</td>
<td>ALPHA Alpha modifier used when the ALPHA_MULTIPLY or ALPHA_OVERRIDE values are programmed in PXP_AS_CTRL[ALPHA_CTRL]. The output alpha value will either be replaced (ALPHA_OVERRIDE) or scaled (ALPHA_MULTIPLY) when selected.</td>
</tr>
<tr>
<td>7–4</td>
<td>FORMAT Indicates the input buffer format for AS.</td>
</tr>
<tr>
<td></td>
<td>0x0 ARGB8888 — 32-bit pixels with alpha</td>
</tr>
<tr>
<td></td>
<td>0x1 RGBA888 — 2-bit pixel with alpha at low 8 bits</td>
</tr>
<tr>
<td></td>
<td>0x4 RGB888 — 32-bit pixels without alpha (unpacked 24-bit format)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### PXP_AS_CTRL field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x8</td>
<td>ARGB1555 — 16-bit pixels with alpha</td>
</tr>
<tr>
<td>0x9</td>
<td>ARGB4444 — 16-bit pixels with alpha</td>
</tr>
<tr>
<td>0xA</td>
<td>RGBA5551 — 16-bit pixel with alpha at low 1 bit</td>
</tr>
<tr>
<td>0xB</td>
<td>RGBA4444 — 16-bit pixel with alpha at low 4 bits</td>
</tr>
<tr>
<td>0xC</td>
<td>RGB555 — 16-bit pixels without alpha</td>
</tr>
<tr>
<td>0xD</td>
<td>RGB444 — 16-bit pixels without alpha</td>
</tr>
<tr>
<td>0xE</td>
<td>RGB565 — 16-bit pixels without alpha</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>3 ENABLE_COLORKEY</th>
<th>Indicates that colorkey functionality is enabled for this alpha surface. Pixels found in the alpha surface colorkey range will be displayed as transparent (the PS pixel will be used).</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>2–1 ALPHA_CTRL</th>
<th>Determines how the alpha value is constructed for this alpha surface. Indicates that the value in the ALPHA field should be used instead of the alpha values present in the input pixels.</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0 Embedded</td>
<td>Indicates that the AS pixel alpha value will be used to blend the AS with PS. The ALPHA field is ignored.</td>
</tr>
<tr>
<td>0x1 Override</td>
<td>Indicates that the value in the ALPHA field should be used instead of the alpha values present in the input pixels.</td>
</tr>
<tr>
<td>0x2 Multiply</td>
<td>Indicates that the value in the ALPHA field should be used to scale all pixel alpha values. Each pixel alpha is multiplied by the value in the ALPHA field.</td>
</tr>
<tr>
<td>0x3 ROPs</td>
<td>Enable ROPs. The ROP field indicates an operation to be performed on the alpha surface and PS pixels.</td>
</tr>
</tbody>
</table>

| 0 RSVD0 | Reserved, always set to zero. |

### 36.8.23 Alpha Surface Buffer Pointer (PXP_AS_BUF)

Alpha Surface 0 Buffer Address Pointer. This register points to the beginning of the Alpha Surface 0 input buffer.

This register is used to indicate the base address of the AS buffer.

**EXAMPLE**

```c
u32* alpha_ptr;
PXP_ASn_WR(0,alpha_ptr);
```

Address: 402B_4000h base + 160h offset = 402B_4160h

### PXP_AS_BUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR</td>
<td>Address pointer for the alpha surface 0 buffer.</td>
</tr>
</tbody>
</table>
36.8.24 Alpha Surface Pitch (PXP_AS_PITCH)

This register contains the alpha surface pitch in bytes.

Any byte value will indicate the vertical pitch. This value will be used in AS pixel address calculations. This value has no relation to the UL and LR registers. It specifies how many bytes are between two vertically adjacent pixels in the input AS surface.

**EXAMPLE**

```
PXP_AS_PITCH_WR( 1920 * 4 ); // The output buffer pitch is HD resolution at 32 bits per pixel
```

Address: 402B_4000h base + 170h offset = 402B_4170h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| W   | RSVD|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**PXP_AS_PITCH field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>RSVD</td>
<td></td>
</tr>
<tr>
<td>PITCH</td>
<td>Indicates the number of bytes in memory between two vertically adjacent pixels.</td>
</tr>
</tbody>
</table>

36.8.25 Overlay Color Key Low (PXP_AS_CLRKEYLOW)

This register contains the color key low value for the AS buffer.

When processing an image, the if the PXP finds a pixel in the current overlay image with a color that falls in the range from the ASCOLORKEYLOW to ASCOLORKEYHIGH range, it will use the PS pixel value for that location. If no PS image is present or if the PS image also matches its colorkey range, the PS background color is used. Colorkey operations are higher priority than alpha or ROP operations.

**EXAMPLE**

```
PXP_AS_CLRKEYLOW_WR (0x000000); // black and
PXP_AS_CLRKEYHIGH_WR(0x800000); // medium red
```
Address: 402B_4000h base + 180h offset = 402B_4180h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**PXP_AS_CLRKEYLOW field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>R</td>
<td>Reserved1</td>
</tr>
</tbody>
</table>

**36.8.26 Overlay Color Key High (PXP_AS_CLRKEYHIGH)**

This register contains the color key high value for the AS buffer.

When processing an image, the if the PXP finds a pixel in the current overlay image with a color that falls in the range from the ASCOLORKEYLOW to ASCOLORKEYHIGH range, it will use the PS pixel value for that location. If no PS image is present or if the PS image also matches its colorkey range, the PS background color is used. Colorkey operations are higher priority than alpha or ROP operations.

**EXAMPLE**

```c
// colorkey values between
PXP_AS_CLRKEYLOW_WR (0x000000); // black and
PXP_AS_CLRKEYHIGH_WR(0x800000); // medium red
```

Address: 402B_4000h base + 190h offset = 402B_4190h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**PXP_AS_CLRKEYHIGH field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>R</td>
<td>Reserved1</td>
</tr>
</tbody>
</table>

**PIXEL**

High range of RGB color key applied to AS buffer. Each overlay has an independent colorkey enable.
36.8.27  Color Space Conversion Coefficient Register 0
(PXP_CSC1_COEF0)

This register contains color space conversion coefficients in two's compliment notation.

The coefficient 0 register contains coefficients used in the color space conversion algorithm. The Y and UV offsets are added to the source buffer to normalize them before the conversion. C0 is the coefficient that is used to multiply the luma component of the data for all three RGB components.

EXAMPLE

```c
// The equations used for Colorspace conversion are:
//     R = C0*(Y+YOFFSET) + C1(V+UV_OFFSET)
//     G = C0*(Y+YOFFSET) + C3(U+UV_OFFSET) + C2(V+UV_OFFSET)
//     R = C0*(Y+YOFFSET) + C4(U+UV_OFFSET)

PXP_CSCCOEF0_WR(0x04030000); // YUV coefficients: C0, Yoffset, UVoffset
PXP_CSCCOEF1_WR(0x01230208); // YUV coefficients: C1, C4
PXP_CSCCOEF2_WR(0x076B079b); // YUV coefficients: C2, C3
```

Address: 402B_4000h base + 1A0h offset = 402B_41A0h

![Register Diagram](image_url)
### PXP_CSC1_COEF0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31:30 YCBCR_MODE</td>
<td>Set to 1 when performing YCbCr conversion to RGB. Set to 0 when converting RGB to YUV data. This bit changes the behavior of the scaler when performing U/V scaling.</td>
</tr>
<tr>
<td>30 BYPASS</td>
<td>Bypass the CSC unit in the scaling engine. When set to logic 1, bypass is enabled and the output pixels will be in the YUV/YCbCr color space. When set to logic 0, the CSC unit is enabled and the pixels will be converted based on the programmed coefficients.</td>
</tr>
<tr>
<td>29 RSVD1</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>28–18 C0</td>
<td>Two's compliment Y multiplier coefficient. YUV=0x100 (1.000) YCbCr=0x12A (1.164)</td>
</tr>
<tr>
<td>17–9 UV_OFFSET</td>
<td>Two's compliment phase offset implicit for CbCr data. Generally used for YCbCr to RGB conversion. YCbCr=0x180, YUV=0x000 (typically -128 or 0x180 to indicate normalized -0.5 to 0.5 range)</td>
</tr>
<tr>
<td></td>
<td>Y_OFFSET Two's compliment amplitude offset implicit in the Y data. For YUV, this is typically 0 and for YCbCr, this is typically -16 (0x1F0)</td>
</tr>
</tbody>
</table>

### 36.8.28 Color Space Conversion Coefficient Register 1 (PXP_CSC1_COEF1)

This register contains color space conversion coefficients in two's compliment notation.

The Coefficient 1 register contains coefficients used in the color space conversion algorithm. C1 is the coefficient that is used to multiply the chroma (Cr/V) component of the data for the red component. C4 is the coefficient that is used to multiply the chroma (Cb/U) component of the data for the blue component. Both values should be coded as a two's compliment fixed point number with 8 bits right of the decimal.

**EXAMPLE**

```
PXP_CSCCOEF0_WR(0x04030000); // YUV coefficients: C0, Yoffset, UVoffset
PXP_CSCCOEF1_WR(0x01230208); // YUV coefficients: C1, C4
PXP_CSCCOEF2_WR(0x076B079b); // YUV coefficients: C2, C3
```
36.8.29  Color Space Conversion Coefficient Register 2 (PXP_CSC1_COEF2)

This register contains color space conversion coefficients in two's compliment notation.

The Coefficient 2 register contains coefficients used in the color space conversion algorithm. C2 is the coefficient that is used to multiply the chroma (Cr/V) component of the data for the green component. C3 is the coefficient that is used to multiply the chroma (Cb/U) component of the data for the green component. Both values should be coded as a two's compliment fixed point number with 8 bits right of the decimal.

**EXAMPLE**

```c
// NOTE: The default values for the CSCCOEF2 register are incorrect. C2 should be 0x76B and C3 should be 0x79C for proper operation.

PXP_CSCCOEF0_WR(0x04030000); // YUV coefficients: C0, Yoffset, UVoffset
PXP_CSCCOEF1_WR(0x01230208); // YUV coefficients: C1, C4
PXP_CSCCOEF2_WR(0x076B079b); // YUV coefficients: C2, C3
```

Address: 402B_4000h base + 1C0h offset = 402B_41C0h
### PXP_CSC1_COEF2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–27</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>26–16</td>
<td>Two's complement Green V/Cr multiplier coefficient. YUV=0x76B (-0.581) YCbCr=0x730 (-0.813)</td>
</tr>
<tr>
<td>15–11</td>
<td>Reserved, always set to zero.</td>
</tr>
<tr>
<td>14–12</td>
<td>Two's complement Green U/Cb multiplier coefficient. YUV=0x79C (-0.394) YCbCr=0x79C (-0.392)</td>
</tr>
</tbody>
</table>

### 36.8.30 PXP Power Control Register (PXP_POWER)

This register controls power states for PXP memories.

Address: 402B_4000h base + 320h offset = 402B_4320h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
</tr>
<tr>
<td>30</td>
<td>CTRL</td>
</tr>
<tr>
<td>29</td>
<td>W</td>
</tr>
<tr>
<td>31-12</td>
<td>ROT_MEM_LP_STATE</td>
</tr>
<tr>
<td>11-9</td>
<td>CONTROL</td>
</tr>
</tbody>
</table>

#### PXP_POWER field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12 CTRL</td>
<td>Power control for the PXP.</td>
</tr>
<tr>
<td>11–9 ROT_MEM_LP_ STATE</td>
<td>Select the low power state of the ROT memory.</td>
</tr>
<tr>
<td>0x0 NONE</td>
<td>Memory is not in low power state.</td>
</tr>
<tr>
<td>0x1 LS</td>
<td>Light Sleep Mode. Low leakage mode, maintain memory contents.</td>
</tr>
<tr>
<td>0x2 DS</td>
<td>Deep Sleep Mode. Low leakage mode, maintain memory contents.</td>
</tr>
<tr>
<td>0x4 SD</td>
<td>Shut Down Mode. Shut Down periphery and core, no memory retention.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

### 36.8.31 Next Frame Pointer (PXP_NEXT)

This register contains a pointer to a data structure used to reload the PXP registers at the end of the current frame.

To enable this functionality, software must write this register while the PXP is processing the current data frame (if the PXP is currently idle, this will also initiate an immediate load of registers from the pointer). The process of writing this register (WRITE operation) will set a semaphore in hardware to notify the control logic that a register...
reload operation must be performed when the current frame processing is complete. At
the end of a frame, the PXP will fetch the register settings from this location, signal an
interrupt to software, then proceed with rendering the next frame of data. Software may
cancel the reload operation by issuing a CLEAR operation to this register. SET and
TOGGLE operations should not be used when addressing this register. All registers will
be reloaded with the exception of the following: STAT, CSCCOEFn, NEXT. All other
registers will be loaded in the order they appear in the register map. After the pointer's
contents have been loaded into the PXP's registers, the NEXT_IRQ interrupt will be
issued (see the PXP_STATUS register).

EXAMPLE

```c
// create register command structure in memory
u32* pxp_commands0[48], pxp_commands1;
    u32 rc;

    // initialize control structure for frame 0
    pxp_commands0[0] = ...; // CTRL
    pxp_commands0[1] = ...; // OUT Buffer
    ...
    pxp_commands0[47] = ..; // Overlay7 param2
   
    // initialize control structure for frame 1
    pxp_commands1[0] = ...; // CTRL
    pxp_commands1[1] = ...; // OUT Buffer
    ...
    pxp_commands1[47] = ..; // Overlay7 param2

    // poll until a command isn't queued
    while (rc=PXP_NEXT_RD() & BM_PXP_NEXT_ENABLED);
    PXP_NEXT_WR(pxp_commands0); // enable PXP operation 0 via command pointer

    // poll until first command clears
    while (rc=PXP_NEXT_RD() & BM_PXP_NEXT_ENABLED);
    PXP_NEXT_WR(pxp_commands1); // enable PXP operation 1 via command pointer
```

Address: 402B_4000h base + 400h offset = 402B_4400h
### PXP_NEXT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>POINTER</td>
</tr>
<tr>
<td>1</td>
<td>RSVD</td>
</tr>
<tr>
<td>0</td>
<td>ENABLED</td>
</tr>
</tbody>
</table>

- **31–2 POINTER**: A pointer to a data structure containing register values to be used when processing the next frame. The pointer must be 32-bit aligned and should reside in on-chip or off-chip memory.
- **1 RSVD**: Reserved, always set to zero.
- **0 ENABLED**: Indicates that the "next frame" functionality has been enabled. This bit reflects the status of the hardware semaphore indicating that a reload operation is pending at the end of the current frame.
### 36.8.32 PXP Alpha Engine A Control Register. (PXP_PORTER_DUFF_CTRL)

Address: $402B_{16}$.4000h base + 440h offset = $402B_{16}$.4440h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>S1_GLOBAL_ALPHA</td>
</tr>
<tr>
<td>23-16</td>
<td>S0_GLOBAL_ALPHA</td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>S1_COLOR_MODE</td>
</tr>
<tr>
<td>12</td>
<td>S1_ALPHA_MODE</td>
</tr>
<tr>
<td>11-10</td>
<td>S1_GLOBAL_ALPHA_MODE</td>
</tr>
<tr>
<td>9-8</td>
<td>S1_S0_FACTOR_MODE</td>
</tr>
</tbody>
</table>

**Table continues on the next page...**
## PXP_PORTER_DUFF_CTRL field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>Reserved: This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>6</td>
<td>S0_COLOR_MODE: s0 color mode</td>
</tr>
<tr>
<td>5</td>
<td>S0_ALPHA_MODE: s0 alpha mode</td>
</tr>
<tr>
<td>4–3</td>
<td>S0_GLOBAL_ALPHA_MODE: s0 global alpha mode</td>
</tr>
<tr>
<td>2–1</td>
<td>S0_S1_FACTOR_MODE: s0 to s1 factor mode</td>
</tr>
<tr>
<td>0</td>
<td>POTER_DUFF_ENABLE: poter_duff enable</td>
</tr>
</tbody>
</table>
Chapter 37
Audio Overview

37.1 Audio Overview

The audio subsystem consists of the following modules: SAI-1, SAI-2, SAI-3, SPDIF and MQS. In addition, the IOMUX must be appropriately configured to get signals in and out of the chip.

Audio Module Overview provides an overview of each of the audio modules, followed by a module-specific section.

37.1.1 Audio Module Overview

The following figure shows a high level block diagram of the audio subsystem.
SAIn are synchronous serial interfaces used to transfer audio data. They can be accessed by both the eDMA and ARM CPUs. Their input/output are connected to the pads through IOMUX.

MQS (medium quality speaker) is used to convert the I2S audio data from SAI to PWM signals that can drive external speaker directly. Its audio source comes from SAI-3 and its output is connected to pads through IOMUX.

The Sony/Philips digital interface (SPDIF) audio module is a stereo transceiver that allows the processor to receive and transmit digital audio over it. The SPDIF receiver section includes a frequency measurement block that allows the precise measurement of an incoming sampling frequency. A recovered clock is provided by the SPDIF receiver section and may be used to drive both internal and external components in the system.

The audio interfaces are summarized as the table below.

**Table 37-1. Audio Interface Summary**

<table>
<thead>
<tr>
<th>Interface</th>
<th>Function</th>
<th>RX Data Line</th>
<th>TX Data Line</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI-1</td>
<td>External audio</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>SAI-2</td>
<td>External audio</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>SAI-3</td>
<td>External audio</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>MQS</td>
<td>External audio</td>
<td>0</td>
<td>2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 37-1. Audio Interface Summary (continued)

<table>
<thead>
<tr>
<th>Interface</th>
<th>Function</th>
<th>RX Data Line</th>
<th>TX Data Line</th>
</tr>
</thead>
<tbody>
<tr>
<td>SPDIF</td>
<td>External audio</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

SAI-1 is used for multi-channel audio interface, which supports up to 8-channels audio input or 8-channels audio output at 384 kHz/32-bit. SAI-2, SAI-3 can be used for stereo audio input and output up to 384 kHz/32-bit. Also SAI-3 is able to drive MQS directly as a low-cost audio output.

To reduce IO count and keep the flexibilities of supporting multiple RX and TX data lines application, SAI-1 has following options on data pin multiplexing.

Table 37-2. SAI-1 TX/RX Data Multiplexing

<table>
<thead>
<tr>
<th>Options</th>
<th>RX Data Line</th>
<th>TX Data Line</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>1</td>
<td>2</td>
<td>3</td>
</tr>
<tr>
<td>2</td>
<td>3</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>4</td>
<td>1</td>
</tr>
</tbody>
</table>

SAI-1 to IOMUXC connection is implemented as shown in the diagram below.

Figure 37-2. SAI-1 TX/RX Data Multiplexing

Detailed clock multiplexing scheme is shown in the following figure.
### 37.1.2 Medium Quality Sound (MQS)

MQS is used to generate medium quality audio via a standard GPIO in the pinmux. The user can connect stereo speakers or headphones to a power amplifier without an additional DAC chip.

- 2-channel, LSB-valid 16 bit, MSB shift-out first serial data (sdata)
- Frame sync aligned with the left channel data
- 44 kHz or 48 kHz I2S signals from SAI3
• SNR target as no more than 20 dB for the signals below 10 kHz
• Signals over 10 kHz have worse THD+N values

### 37.1.3 Synchronous Audio Interface (SAI)

- Transmitter with independent Bit Clock and Frame Sync supporting 1 data line
- Receiver with independent Bit Clock and Frame Sync supporting 1 data line
- Maximum Frame Size of 32 Words
- Word size programmable from 8-bits to 32-bits
- Word size configured separately for first word and remaining words in frame
- Asynchronous FIFO for each Transmit and Receive data line
- Graceful restart after FIFO Error

### 37.1.4 Sony/Philips Digital Interface (SPDIF)

The Sony/Philips Digital Interface (SPDIF) module is a stereo transceiver that allows the processor to receive and transmit digital audio over it using the IEC60958 standard, consumer format. The chip provides a single SPDIF receiver with one input, and one SPDIF transmitter with one output.

The SPDIF transceiver allows the handling of both SPDIF channel status (CS) and User (U) data and features a frequency measurement block that allows the precise measurement of the incoming sampling frequency.

The clock recovered by the SPDIF receiver is provided to drive both internal and external components in the system such as the SPDIF transmitter, ESAI ports, as well as external A/Ds or D/As, with clocking control provided via related registers.

The SPDIF is composed of two parts: SPDIF Receiver and SPDIF Transmitter. The SPDIF receiver extracts the audio data from each SPDIF frame and places the data in two 16-word-deep FIFOs, one FIFO for the left channel, the other FIFO for the right channel. The FIFOs support programmable watermark levels so that FIFO Full service request can be triggered when the combined number of data words stored in both FIFOs is 2, 8, 16 or 32 words. It is recommended to program the watermark level to trigger a FIFO Full service request when 16 word locations are filled. For optimal performance when servicing the FIFO Full service request, the FIFOs should be read alternately, starting with the left channel FIFO. The Channel Status and User Bits are also extracted from each frame and placed in the corresponding registers. The SPDIF receiver provides a bypass option for direct transfer of the SPDIF input signal to the SPDIF transmitter.
For the SPDIF transmitter, the audio data is provided by the processor via the SPDIFTxLeft and SPDIFTxRight registers, and the data is stored in two 16-word-deep FIFOs, one for the right channel, the other for the left channel. The FIFOs support programmable watermark levels so that FIFO Empty service request can be triggered when the combined number of empty data words locations in both FIFOs is 8, 16, 24 or 32 words. It is recommended to program the watermark level to trigger a FIFO Empty service request when 16 word locations are empty. For optimal performance when servicing the FIFO Empty service request, the FIFOs should be written alternately, starting with the left channel FIFO. The Channel Status bits are also provided via the corresponding registers. The SPDIF transmitter generates an SPDIF output bitstream in the biphase mark format (IEC 60958), which consists of audio data, channel status and user bits.

The data handled by the SPDIF module is 24-bit wide. The 24-bit SPDIF data is aligned in the 24 least significant bits of the 32-bit shared peripheral bus data word. The 8 most significant bits of the 32-bit word are ignored by the SPDIF Transmitter when data is being stored in the Transmit FIFOs from the peripheral bus. The 8 most significant bits of the 32-bit word are zeroed by the SPDIF Receiver module when the data is being read from the Receiver FIFOs to the peripheral bus.

Note that 16-bit data is left-aligned in the 24-bit word format of the SPDIF. This means that when receiving 16-bit data, it will be located in the middle two bytes of the 32-bit peripheral bus data word, while the 8 bits of the MSB and the 8 bits of the LSB will be zero. When 16-bit data is to be transmitted, the 32-bit word to be written to the SPDIF Transmit FIFOs should be created as follows: the 16-bit data should be located in the middle two bytes of the 32-bit data word and the 8 bits of the LSB must be set to zero, while the 8 bits of the MSB will be ignored.

The SPDIF Transmit clock is generated by the SPDIF internal clock generator module and the clock sources are from outside of the SPDIF block. The clock sources should provide a clock that is at least 64 x Fs, where Fs is the sampling frequency. The external clock source should provide at least 128 x Fs. Clocks of higher frequency may be provided as long as the multiplication factor is a power of 2 (for example, 128x, 256x or 512x). Also, clock frequency precision of 100ppm or better should be provided.
Chapter 38
Synchronous Audio Interface (SAI)

38.1 Chip-specific SAI information

Table 38-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module or subsystem</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Audio Subsystem</td>
<td>Audio Subsystem</td>
<td>Audio Subsystem Overview</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

**NOTE**
Number of TX and RX data lines for SAI1 and SAI2/SAI3 are 4, and 1 respectively.

**NOTE**
In this device, it does NOT support synchronous mode between different SAI peripherals.

For more details about the features and clocking of different SAI instances, see the Audio Subsystem Overview section.
38.2 Introduction

The I²S (or I2S) module provides a synchronous audio interface (SAI) that supports full-duplex serial interfaces with frame synchronization such as I²S, AC97, TDM, and codec/DSP interfaces.

38.2.1 Features

Note that some of the features are not supported across all SAI instances; see the chip-specific information in the first section of this chapter.

- Transmitter with independent bit clock and frame sync supporting 4 data lines
- Receiver with independent bit clock and frame sync supporting 4 data lines
- Each data line can support a maximum Frame size of 32 words
- Word size of between 8-bits and 32-bits
- Word size configured separately for first word and remaining words in frame
- Asynchronous 32 x 32-bit FIFO for each transmit and receive data line
- Supports graceful restart after FIFO error
- Supports automatic restart after FIFO error without software intervention
- Supports packing of 8-bit and 16-bit data into each 32-bit FIFO word
- Supports combining multiple data line FIFOs into single data line FIFO

38.2.2 Block diagram

The following block diagram also shows the module clocks.
38.2.3 Modes of operation

Module power modes include Run mode, Stop modes, and Debug mode.

38.2.3.1 Run mode

In Run mode, the SAI transmitter and receiver operate normally.
### 38.2.3.2 Stop modes

In Stop mode, the SAI transmitter and/or receiver can continue operating provided the appropriate Stop Enable bit is set (TCSR[STOPE] and/or RCSR[STOPE], respectively), and provided the transmitter and/or receiver is/are using an externally generated bit clock or an Audio Master Clock that remains operating in Stop mode. The SAI transmitter and/or receiver can generate an asynchronous interrupt to wake the CPU from Stop mode.

In Stop mode, if the Transmitter Stop Enable (TCSR[STOPE]) bit is clear, the transmitter is disabled after completing the current transmit frame, and, if the Receiver Stop Enable (RCSR[STOPE]) bit is clear, the receiver is disabled after completing the current receive frame. Entry into Stop mode is prevented (not acknowledged) while waiting for the transmitter and receiver to be disabled at the end of the current frame.

### 38.2.3.3 Debug mode

In Debug mode, the SAI transmitter and/or receiver can continue operating provided the Debug Enable bit is set. When TCSR[DBGE] or RCSR[DBGE] bit is clear and Debug mode is entered, the SAI is disabled after completing the current transmit or receive frame. The transmitter and receiver bit clocks are not affected by Debug mode.

### 38.3 External signals

<table>
<thead>
<tr>
<th>Name</th>
<th>Function</th>
<th>I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>TX_BCLK</td>
<td>Transmit Bit Clock. The bit clock is an input when externally generated and an output when internally generated.</td>
<td>I/O</td>
</tr>
<tr>
<td>TX_SYNC</td>
<td>Transmit Frame Sync. The frame sync is an input sampled synchronously by the bit clock when externally generated and an output generated synchronously by the bit clock when internally generated.</td>
<td>I/O</td>
</tr>
<tr>
<td>TX_DATA[3:0]</td>
<td>Transmit Data. The transmit data is generated synchronously by the bit clock and is tristated whenever not transmitting a word.</td>
<td>O</td>
</tr>
<tr>
<td>RX_BCLK</td>
<td>Receive Bit Clock. The bit clock is an input when externally generated and an output when internally generated.</td>
<td>I/O</td>
</tr>
<tr>
<td>RX_SYNC</td>
<td>Receive Frame Sync. The frame sync is an input sampled synchronously by the bit clock when externally generated and an output generated synchronously by the bit clock when internally generated.</td>
<td>I/O</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
38.4 Functional description

This section provides a complete functional description of the block.

38.4.1 SAI clocking

The SAI clocks include:

- The audio master clock
- The bit clock
- The bus clock

38.4.1.1 Audio master clock

The audio master clock is used to generate the bit clock when the receiver or transmitter is configured for an internally generated bit clock. The transmitter and receiver can independently select between the bus clock and up to three audio master clocks to generate the bit clock.

The audio master clock generation and selection is chip-specific. Refer to chip-specific clocking information about how the audio master clocks are generated.

38.4.1.2 Bit clock

The SAI transmitter and receiver support asynchronous free-running bit clocks that can be generated internally from an audio master clock or supplied externally. There is also the option for synchronous bit clock and frame sync operation between the receiver and transmitter or between multiple SAI peripherals.

- If both transmitter and receiver are configured for asynchronous operation, then the transmitter and receiver will each use their own bit clock and frame sync.
• If the *transmitter* is configured for asynchronous mode and the receiver is configured for synchronous mode, then both transmitter and receiver will use the *transmitter* bit clock and frame sync.

• If the *receiver* is configured for asynchronous mode and the transmitter is configured for synchronous mode, then both transmitter and receiver will use the *receiver* bit clock and frame sync.

Note that the software configures synchronous or asynchronous mode, and that choice selects the bit clock/frame sync used.

Externally generated bit clocks must be:

• Enabled before the SAI transmitter or receiver is enabled
• Disabled after the SAI transmitter or receiver is disabled and completes its current frames

If the SAI transmitter or receiver is using an externally generated bit clock in asynchronous mode and that bit clock is generated by an SAI that is disabled in stop mode, then the transmitter or receiver should be disabled by software before entering stop mode. This issue does not apply when the transmitter or receiver is in a synchronous mode because all synchronous SAIs are enabled and disabled simultaneously.

### 38.4.1.3 Bus clock

The bus clock is used by the control and configuration registers and to generate synchronous interrupts and DMA requests.

**NOTE**

Although there is no specific minimum bus clock frequency specified, the bus clock frequency must be fast enough (relative to the bit clock frequency) to ensure that the FIFOs can be serviced, without generating either a transmitter FIFO underrun or receiver FIFO overflow condition.

### 38.4.2 SAI resets

The SAI is asynchronously reset on system reset. The SAI has a software reset and a FIFO reset.
38.4.2.1 Software reset

The SAI transmitter includes a software reset that resets all transmitter internal logic, including the bit clock generation, status flags, and FIFO pointers. It does not reset the configuration registers. The software reset remains asserted until cleared by software.

The SAI receiver includes a software reset that resets all receiver internal logic, including the bit clock generation, status flags and FIFO pointers. It does not reset the configuration registers. The software reset remains asserted until cleared by software.

38.4.2.2 FIFO reset

The SAI transmitter includes a FIFO reset that synchronizes the FIFO write pointer to the same value as the FIFO read pointer. This empties the FIFO contents and is to be used after TCSR[FEF] is set, and before the FIFO is re-initialized and TCSR[FEF] is cleared. The FIFO reset is asserted for one cycle only.

The SAI transmitter can also reset the FIFO of individual data channels by setting the appropriate TCR3[CFR] bit. This should only be done when the corresponding TCR3[TCE] bit is clear.

The SAI receiver includes a FIFO reset that synchronizes the FIFO read pointer to the same value as the FIFO write pointer. This empties the FIFO contents and is to be used after the RCSR[FEF] is set and any remaining data has been read from the FIFO, and before the RCSR[FEF] is cleared. The FIFO reset is asserted for one cycle only.

The SAI receiver can also reset the FIFO of individual data channels by setting the appropriate RCR3[CFR] bit. This should only be done when the corresponding RCR3[RCE] bit is clear.

38.4.3 Synchronous modes

The SAI transmitter and receiver can operate synchronously to each other.

38.4.3.1 Synchronous mode

The SAI transmitter and receiver can be configured to operate with synchronous bit clock and frame sync.

If the transmitter bit clock and frame sync are to be used by both the transmitter and receiver:
• The transmitter must be configured for asynchronous operation and the receiver for synchronous operation.
• In synchronous mode, the receiver is enabled only when both the transmitter and receiver are enabled.
• It is recommended that the transmitter is the last enabled and the first disabled.

If the receiver bit clock and frame sync are to be used by both the transmitter and receiver:

• The receiver must be configured for asynchronous operation and the transmitter for synchronous operation.
• In synchronous mode, the transmitter is enabled only when both the receiver and transmitter are both enabled.
• It is recommended that the receiver is the last enabled and the first disabled.

When operating in synchronous mode, only the bit clock, frame sync, and transmitter/receiver enable are shared. The transmitter and receiver otherwise operate independently, although configuration registers must be configured consistently across both the transmitter and receiver.

### 38.4.4 Frame sync configuration

When enabled, the SAI continuously transmits and/or receives frames of data. Each frame consists of a fixed number of words and each word consists of a fixed number of bits. Within each frame, any given word can be masked causing the receiver to ignore that word and the transmitter to tri-state for the duration of that word.

The frame sync signal is used to indicate the start of each frame. A valid frame sync requires a rising edge (if active high) or falling edge (if active low) to be detected and the transmitter or receiver cannot be busy with a previous frame. A valid frame sync is also ignored (slave mode) or not generated (master mode) for the first four bit clock cycles after enabling the transmitter or receiver.

The transmitter and receiver frame sync can be configured independently with any of the following options:

• Externally generated or internally generated
• Active high or active low
• Assert with the first bit in frame or asserts one bit early
• Assert for a duration between 1 bit clock and the first word length
• Frame length from 1 to 32 words per frame
• Word length to support 8 to 32 bits per word
• First word length and remaining word lengths can be configured separately
• Words can be configured to transmit/receive MSB first or LSB first

These configuration options cannot be changed after the SAI transmitter or receiver is enabled.

38.4.5 Data FIFO

Each transmit and receive channel includes a FIFO of size 32 x 32-bit. The FIFO data is accessed using the SAI Transmit/Receive Data Registers.

38.4.5.1 Data alignment

Data in the FIFO can be aligned anywhere within the 32-bit wide register through the use of the First Bit Shifted configuration field, which selects the bit index (between 31 and 0) of the first bit shifted.

Examples of supported data alignment and the required First Bit Shifted configuration are illustrated in Figure 38-2 for LSB First configurations and Figure 38-3 for MSB First configurations.

![Table: How data is written to the FIFO, using First Bit Shifted field (FBT)](image)

**Figure 38-2. SAI first bit shifted, LSB first**
How data is written to the FIFO, using First Bit Shifted field (FBT)

**MSB first**

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>11111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10011</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>01111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>01011</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>00111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**First Bit Shifted (FBT)**

<table>
<thead>
<tr>
<th>RCRL5[FBT]</th>
<th>Or</th>
<th>RCRL5[FBT]</th>
</tr>
</thead>
<tbody>
<tr>
<td>TX Config 5 Register</td>
<td>RX Config 5 Register</td>
<td></td>
</tr>
</tbody>
</table>

Number of bits being transferred shown above:
- 24-bit data
- 20-bit data
- 12-bit data
- 8-bit data

Figure 38-3. SAI first bit shifted, MSB first

### 38.4.5.2 FIFO pointers

When writing to a Transmit Data Register (TDR\(n\)), the Write FIFO Pointer (WFP) of the corresponding Transmit FIFO Register (TFR\(n\)) increments after each valid write. The SAI supports 8-bit, 16-bit and 32-bit writes to the Transmit Data Register and the FIFO pointer will increment after each individual write. Note that 8-bit writes should only be used when transmitting up to 8-bit data; 16-bit writes should only be used when transmitting up to 16-bit data.

- If the Transmit FIFO is full, then writes to a Transmit Data Register are ignored.
- If the Transmit FIFO is empty, then to avoid a FIFO underrun, the Transmit Data Register must be written at least 3 bit clocks before the start of the next unmasked word. Before enabling the transmitter, the Transmit FIFO should be initialized with data (since after the transmitter is enabled, the transmitter will start a new frame, and if no data is in the FIFO, then the transmitter will immediately give an error).

When reading a Receive Data Register (RDR\(n\)), the Read FIFO Pointer (RFP) of the corresponding Receive FIFO Register (RFR\(n\)) increments after each valid read. The SAI supports 8-bit, 16-bit and 32-bit reads from the RDR and the FIFO pointer will increment after each individual read. Note that 8-bit reads should only be used when receiving up to 8-bit data; 16-bit reads should only be used when receiving up to 16-bit data.
• If the Receive FIFO is empty, then reads from a Receive Data Register are ignored.
• If the Receive FIFO is full, then to avoid a FIFO overrun, the Receive Data Register must be read at least 3 bit clocks before the end of an unmasked word.

38.4.5.3 FIFO packing

FIFO packing supports storing multiple 8-bit or 16-bit data words in one 32-bit FIFO word for the transmitter and/or receiver. While this can be emulated by adjusting the number of bits per word and number of words per frame (for example, one 32-bit word per frame versus two 16-bit words per frame), FIFO packing does not require even multiples of words per frame and fully supports word masking. When FIFO packing is enabled, the FIFO pointers only increment when the full 32-bit FIFO word has been written (transmit) or read (receive) by software, supporting scenarios where different words within each frame are loaded/stored in different areas of memory.

When 16-bit FIFO packing is enabled for transmit, the transmit shift register is loaded at the start of each frame and after every second unmasked transmit word. The first word transmitted is taken from 16-bit word at byte offset $0$ (first bit is selected by TCFG5[FBT] must be configured within this 16-bit word) and the second word transmitted is taken from the 16-bit word at byte offset $2$ (first bit is selected by TCSR5[FBT][3:0]). The transmitter will transmit logic zero until the start of the next word once the 16-bit word has been transmitted.

When 16-bit FIFO packing is enabled for receive, the receive shift register is stored after every second unmasked received word, and at the end of each frame if there is an odd number of unmasked received words in each frame. The first word received is stored in the 16-bit word at byte offset $0$ (first bit is selected by RCFG5[FBT] and must be configured within this 16-bit word) and the second word received is stored in the 16-bit word at byte offset $2$ (first bit is selected by RCSR5[FBT][3:0]). The receiver will ignore received data until the start of the next word once the 16-bit word has been received.

The 8-bit FIFO packing is similar to 16-bit packing except four words are loaded or stored into each 32-bit FIFO word. The first word is loaded/stored in byte offset $0$, second word in byte offset $1$, third word in byte offset $2$ and fourth word in byte offset $3$. The TCFG5[FBT] and/or RCFG5[FBT] must be configured within byte offset $0$. 
38.4.5.4 FIFO Combine

FIFO combining mode allows the separate FIFOs for multiple data channels to be used as a single FIFO for either software accesses or a single data channel or both. Note that the enabled data channels must be contiguous and data channel 0 must be enabled when FIFO Combine mode is enabled.

Combining FIFOs for software access (writing transmit FIFO registers, reading receive FIFO registers) allows a DMA controller or software to read or write multiple FIFOs without incrementing the address that is accessed. Once enabled, the first software access to a FIFO register will access the first enabled channel FIFO, while the second access to a FIFO register will access the second enabled channel FIFO. This continues until software accesses the last enabled channel FIFO and the pointer resets back to the first enabled channel FIFO. To reset the pointer manually, software can reset the FIFOs or disable the FIFO combining on software accesses.

Combining FIFOs for transmit data channels allows one data channel to use the FIFOs of all enabled channel FIFOs, with identical data output on each enabled data channel. The transmit shift registers for all enabled data channels are loaded at the start of each frame and every N unmasked words (where N is the number of enabled data channels). The first word transmitted is loaded from the first enabled channel FIFO, while the second word transmitted is loaded from the second enabled channel FIFO, and so on until the end of the frame. Since the first word in each frame is always loaded from the first enabled data channel, it is recommended that the number of unmasked words in each frame is evenly divisible by the number of enabled data channels.

Combining FIFOs for receive data channels allows one data channel to use the FIFOs of all enabled channel FIFOs, with received data from channel 0 stored into each enabled data channel. The receive shift register for all enabled data channels are stored after every N unmasked words (where N is the number of enabled data channels). The first word received is stored to the first enabled channel FIFO, while the second word received is stored to the second enabled channel FIFO, and so on until the end of the frame. Since the first word in each frame is always stored the first enabled data channel, it is recommended that the number of unmasked words in each frame is evenly divisible by the number of enabled data channels.

Note that combining FIFOs for data channels will load or store each channel FIFO at the same time. This means that FIFO error conditions are only checked every N words (where N is the number of enabled data channels) and that the FIFO warning and request flags will assert if any of the enabled data channel meets the warning flag or request flag conditions.
38.4.6  Word mask register

The SAI transmitter and receiver each contain a word mask register, namely TMR and RMR, that can be used to mask any word in the frame. Because the word mask register is double buffered, software can update it before the end of each frame to mask a particular word in the next frame.

The TMR causes the Transmit Data pin to be tri-stated for the length of each selected word and the transmit FIFO is not read for masked words.

The RMR causes the received data for each selected word to be discarded and not written to the receive FIFO.

38.4.7  Interrupts and DMA requests

The SAI transmitter and receiver generate separate interrupts and separate DMA requests, but support the same status flags. Asynchronous versions of the transmitter and receiver interrupts are generated to wake up the CPU from stop mode.

38.4.7.1  FIFO request flag

The FIFO request flag is set based on the number of entries in the FIFO and the FIFO watermark configuration.

The transmit FIFO request flag is set when the number of entries in any of the enabled transmit FIFOs is less than or equal to the transmit FIFO watermark configuration and is cleared when the number of entries in each enabled transmit FIFO is greater than the transmit FIFO watermark configuration.

The receive FIFO request flag is set when the number of entries in any of the enabled receive FIFOs is greater than the receive FIFO watermark configuration and is cleared when the number of entries in each enabled receive FIFO is less than or equal to the receive FIFO watermark configuration.

The FIFO request flag can generate an interrupt or a DMA request.

38.4.7.2  FIFO warning flag

The FIFO warning flag is set based on the number of entries in the FIFO.
The transmit warning flag is set when the number of entries in any of the enabled transmit FIFOs is empty and is cleared when the number of entries in each enabled transmit FIFO is not empty.

The receive warning flag is set when the number of entries in any of the enabled receive FIFOs is full and is cleared when the number of entries in each enabled receive FIFO is not full.

The FIFO warning flag can generate an Interrupt or a DMA request.

### 38.4.7.3 FIFO error flag

The transmit FIFO error flag is set when any of the enabled transmit FIFOs underflow. After it is set, all enabled transmit channels will transmit zero data before TCSR[FEF] is cleared.

When TCR4[FCONT] is set, the FIFO will continue transmitting data following an underflow without software intervention. To ensure that data is transmitted in the correct order, the transmitter will continue from the same word number in the frame that caused the FIFO to underflow, but only after new data has been written to the transmit FIFO. Software should still clear the TCSR[FEF] flag, but without reinitializing the transmit FIFOs.

RCSR[FEF] is set when any of the enabled receive FIFOs overflow. After it is set, all enabled receive channels discard received data until RCSR[FEF] is cleared and the next receive frame starts. All enabled receive FIFOs should be emptied before RCSR[FEF] is cleared.

When RCR4[FCONT] is set, the FIFO will continue receiving data following an overflow without software intervention. To ensure that data is received in the correct order, the receiver will continue from the same word number in the frame that caused the FIFO to overflow, but only after data has been read from the receive FIFO. Software should still clear the RCSR[FEF] flag, but without emptying the receive FIFOs.

The FIFO error flag can generate only an interrupt.

### 38.4.7.4 Sync error flag

The sync error flag, TCSR[SEF] or RCSR[SEF], is set when configured for an externally generated frame sync and the external frame sync asserts when the transmitter or receiver is busy with the previous frame. The external frame sync assertion is ignored and the sync error flag is set. When the sync error flag is set, the transmitter or receiver continues checking for frame sync assertion when idle or at the end of each frame.
The sync error flag can generate an interrupt only.

### 38.4.7.5 Word start flag

The word start flag is set at the start of the second bit clock for the selected word, as configured by the Word Flag register field.

The word start flag can generate an interrupt only.

### 38.5 Memory map and register definition

A read or write access to an address from offset 0x100 and above will result in a bus error.

### 38.5.1 I2S register descriptions

#### 38.5.1.1 I2S memory map

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Version ID Register (VERID)</td>
<td>32</td>
<td>RO</td>
<td>0300_0000h</td>
</tr>
<tr>
<td>4h</td>
<td>Parameter Register (PARAM)</td>
<td>32</td>
<td>RO</td>
<td>Table 38-1</td>
</tr>
<tr>
<td>8h</td>
<td>SAI Transmit Control Register (TCSR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>SAI Transmit Configuration 1 Register (TCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>SAI Transmit Configuration 2 Register (TCR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>SAI Transmit Configuration 3 Register (TCR3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>18h</td>
<td>SAI Transmit Configuration 4 Register (TCR4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>SAI Transmit Configuration 5 Register (TCR5)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>20h - 2Ch</td>
<td>SAI Transmit Data Register (TDR0 - TDR3)</td>
<td>32</td>
<td>WORZ</td>
<td>See description</td>
</tr>
<tr>
<td>40h - 4Ch</td>
<td>SAI Transmit FIFO Register (TFR0 - TFR3)</td>
<td>32</td>
<td>RO</td>
<td>See description</td>
</tr>
</tbody>
</table>
### Memory map and register definition

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>60h</td>
<td>SAI Transmit Mask Register (TMR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>88h</td>
<td>SAI Receive Control Register (RCSR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8Ch</td>
<td>SAI Receive Configuration 1 Register (RCR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>90h</td>
<td>SAI Receive Configuration 2 Register (RCR2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>94h</td>
<td>SAI Receive Configuration 3 Register (RCR3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>98h</td>
<td>SAI Receive Configuration 4 Register (RCR4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>9Ch</td>
<td>SAI Receive Configuration 5 Register (RCR5)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>A0h - ACh</td>
<td>SAI Receive Data Register (RDR0 - RDR3)</td>
<td>32</td>
<td>RO</td>
<td>See description</td>
</tr>
<tr>
<td>C0h - CCh</td>
<td>SAI Receive FIFO Register (RFR0 - RFR3)</td>
<td>32</td>
<td>RO</td>
<td>See description</td>
</tr>
<tr>
<td>E0h</td>
<td>SAI Receive Mask Register (RMR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

### 38.5.1.2 Version ID Register (VERID)

#### 38.5.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VERID</td>
<td>0h</td>
</tr>
</tbody>
</table>

#### 38.5.1.2.2 Function

Contains version numbers for the module design and feature set.

#### 38.5.1.2.3 Diagram

![Diagram of Version ID Register]

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```
### 38.5.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Major Version Number</td>
</tr>
<tr>
<td>MAJOR</td>
<td>This read only field returns the major version number for the specification.</td>
</tr>
<tr>
<td>23-16</td>
<td>Minor Version Number</td>
</tr>
<tr>
<td>MINOR</td>
<td>This read only field returns the minor version number for the specification.</td>
</tr>
<tr>
<td>15-0</td>
<td>Feature Specification Number</td>
</tr>
<tr>
<td>FEATURE</td>
<td>This read only field returns the feature set number.</td>
</tr>
<tr>
<td></td>
<td>0000000000000000b - Standard feature set.</td>
</tr>
</tbody>
</table>

### 38.5.1.3 Parameter Register (PARAM)

#### 38.5.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PARAM</td>
<td>4h</td>
</tr>
</tbody>
</table>

#### 38.5.1.3.2 Function

Contains parameter values that were implemented in the module.

#### 38.5.1.3.3 Diagram

![Diagram](image-url)
38.5.1.3.4 Register reset values

<table>
<thead>
<tr>
<th>Register</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>PARAM</td>
<td>SAI1: 0005_0504h</td>
</tr>
<tr>
<td></td>
<td>SAI2, SAI3: 0005_0501h</td>
</tr>
</tbody>
</table>

38.5.1.3.5 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-20</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>19-16</td>
<td>Frame Size</td>
</tr>
<tr>
<td>FRAME</td>
<td>The maximum number of slots per frame is $2^{\text{FRAME}}$.</td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>11-8</td>
<td>FIFO Size</td>
</tr>
<tr>
<td>FIFO</td>
<td>The number of words in each FIFO is $2^{\text{FIFO}}$.</td>
</tr>
<tr>
<td>7-4</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>3-0</td>
<td>Number of Datalines</td>
</tr>
<tr>
<td>DATALINE</td>
<td>The number of datalines implemented.</td>
</tr>
</tbody>
</table>

38.5.1.4 SAI Transmit Control Register (TCSR)

38.5.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCSR</td>
<td>8h</td>
</tr>
</tbody>
</table>
### 38.5.1.4.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>T</td>
<td>E</td>
<td>STOP</td>
<td>E</td>
<td>DBG</td>
<td>E</td>
<td>BC</td>
<td>E</td>
<td>O</td>
<td>O</td>
<td>S</td>
<td>F</td>
<td>R</td>
<td>S</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>O</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 38.5.1.4.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31    | Transmitter Enable  
Enables/disables the transmitter. When software clears this field, the transmitter remains enabled, and this bit remains set, until the end of the current frame.  
0b - Transmitter is disabled.  
1b - Transmitter is enabled, or transmitter has been disabled and has not yet reached end of frame. |
| 30    | Stop Enable  
Configures transmitter operation in Stop mode.  
0b - Transmitter disabled in Stop mode.  
1b - Transmitter enabled in Stop mode. |
| 29    | Debug Enable  
Enables/disables transmitter operation in Debug mode. The transmit bit clock is not affected by debug mode.  
0b - Transmitter is disabled in Debug mode, after completing the current frame.  
1b - Transmitter is enabled in Debug mode. |
| 28    | Bit Clock Enable  
Enables the transmit bit clock, separately from the TE. This field is automatically set whenever TE is set. When software clears this field, the transmit bit clock remains enabled, and this bit remains set, until the end of the current frame.  
0b - Transmit bit clock is disabled.  
1b - Transmit bit clock is enabled. |
| 27-26 | Reserved |
| 25    | FIFO Reset  
Empties the FIFO, and sets the FIFO read and write pointers to the same value, which may or may not be zero. Reading this field will always return zero. FIFO pointers should only be reset when the transmitter is disabled or the FIFO error flag is set.  
0b - No effect.  
1b - FIFO reset. |
| 24    | Software Reset |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| SR    | When set, resets the internal transmitter logic including the FIFO read and write pointers. Software-visible registers are not affected, except for the status registers.  
  - 0b - No effect.  
  - 1b - Software reset. |
| 23-21 | Reserved |
| 20    | Word Start Flag  
  - Indicates that the start of the configured word has been detected. Write a logic 1 to this field to clear this flag.  
  - 0b - Start of word not detected.  
  - 1b - Start of word detected. |
| 19    | Sync Error Flag  
  - Indicates that an error in the externally-generated frame sync has been detected. Write a logic 1 to this field to clear this flag.  
  - 0b - Sync error not detected.  
  - 1b - Frame sync error detected. |
| 18    | FIFO Error Flag  
  - Indicates that an enabled transmit FIFO has underrun. Write a logic 1 to this field to clear this flag.  
  - 0b - Transmit underrun not detected.  
  - 1b - Transmit underrun detected. |
| 17    | FIFO Warning Flag  
  - Indicates that an enabled transmit FIFO is empty.  
  - 0b - No enabled transmit FIFO is empty.  
  - 1b - Enabled transmit FIFO is empty. |
| 16    | FIFO Request Flag  
  - Indicates that the number of words in an enabled transmit channel FIFO is less than or equal to the transmit FIFO watermark.  
  - 0b - Transmit FIFO watermark has not been reached.  
  - 1b - Transmit FIFO watermark has been reached. |
| 15-13 | Reserved |
| 12    | Word Start Interrupt Enable  
  - Enables/disables word start interrupts.  
  - 0b - Disables interrupt.  
  - 1b - Enables interrupt. |
| 11    | Sync Error Interrupt Enable  
  - Enables/disables sync error interrupts.  
  - 0b - Disables interrupt.  
  - 1b - Enables interrupt. |
| 10    | FIFO Error Interrupt Enable  
  - Enables/disables FIFO error interrupts.  
  - 0b - Disables the interrupt.  
  - 1b - Enables the interrupt. |
| 9     | FIFO Warning Interrupt Enable  
  - Enables/disables FIFO warning interrupts.  
  - 0b - Disables the interrupt.  
  - 1b - Enables the interrupt. |

*Table continues on the next page...*
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>FIFO Request Interrupt Enable</td>
</tr>
<tr>
<td>FRIE</td>
<td>Enables/disables FIFO request interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the interrupt.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the interrupt.</td>
</tr>
<tr>
<td>7-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>FIFO Warning DMA Enable</td>
</tr>
<tr>
<td>FWDE</td>
<td>Enables/disables DMA requests.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the DMA request.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the DMA request.</td>
</tr>
<tr>
<td>0</td>
<td>FIFO Request DMA Enable</td>
</tr>
<tr>
<td>FRDE</td>
<td>Enables/disables DMA requests.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the DMA request.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the DMA request.</td>
</tr>
</tbody>
</table>

### 38.5.1.5 SAI Transmit Configuration 1 Register (TCR1)

#### 38.5.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCR1</td>
<td>Ch</td>
</tr>
</tbody>
</table>

#### 38.5.1.5.2 Diagram

![Diagram of TCR1 Register](image-url)
38.5.1.5.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-0</td>
<td>Transmit FIFO Watermark</td>
</tr>
<tr>
<td>TFW</td>
<td>Configures the watermark level for all enabled transmit channels.</td>
</tr>
</tbody>
</table>

38.5.1.6 SAI Transmit Configuration 2 Register (TCR2)

38.5.1.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCR2</td>
<td>10h</td>
</tr>
</tbody>
</table>

38.5.1.6.2 Function

This register must not be altered when TCSR[TE] is set.

38.5.1.6.3 Diagram

38.5.1.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>Synchronous Mode</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| SYNC  | Configures between asynchronous and synchronous modes of operation. When configured for a synchronous mode of operation, the receiver must be configured for asynchronous operation.  
  0b - Asynchronous mode.  
  1b - Synchronous with receiver. |
| 29    | Bit Clock Swap  
  This field swaps the bit clock used by the transmitter. When the transmitter is configured in asynchronous mode and this bit is set, the transmitter is clocked by the receiver bit clock (RX_BCLK). This allows the transmitter and receiver to share the same bit clock, but the transmitter continues to use the transmit frame sync (TX_SYNC).  
  When the transmitter is configured in synchronous mode, the transmitter BCS field and receiver BCS field must be set to the same value. When both are set, the transmitter and receiver are both clocked by the transmitter bit clock (TX_BCLK) but use the receiver frame sync (RX_SYNC).  
  0b - Use the normal bit clock source.  
  1b - Swap the bit clock source. |
| 28    | Bit Clock Input  
  When this field is set and using an internally generated bit clock in either synchronous or asynchronous mode, the bit clock actually used by the transmitter is delayed by the pad output delay (the transmitter is clocked by the pad input as if the clock was externally generated). This has the effect of decreasing the data input setup time, but increasing the data output valid time.  
  The slave mode timing from the datasheet should be used for the transmitter when this bit is set. In synchronous mode, this bit allows the transmitter to use the slave mode timing from the datasheet, while the receiver uses the master mode timing. This field has no effect when configured for an externally generated bit clock.  
  0b - No effect.  
  1b - Internal logic is clocked as if bit clock was externally generated. |
| 27-26 | MCLK Select  
  Selects the audio Master Clock option used to generate an internally generated bit clock. This field has no effect when configured for an externally generated bit clock.  
  **NOTE:** Depending on the device, some Master Clock options might not be available. See the chip-specific information for the meaning of each option.  
  00b - Bus Clock selected.  
  01b - Master Clock (MCLK) 1 option selected.  
  10b - Master Clock (MCLK) 2 option selected.  
  11b - Master Clock (MCLK) 3 option selected. |
| 25    | Bit Clock Polarity  
  Configures the polarity of the bit clock.  
  0b - Bit clock is active high with drive outputs on rising edge and sample inputs on falling edge.  
  1b - Bit clock is active low with drive outputs on falling edge and sample inputs on rising edge. |
| 24    | Bit Clock Direction  
  Configures the direction of the bit clock.  
  0b - Bit clock is generated externally in Slave mode.  
  1b - Bit clock is generated internally in Master mode. |
| 23-8  | Reserved |
| 7-0   | Bit Clock Divide  
  Divides down the audio master clock to generate the bit clock when configured for an internal bit clock. The division value is \((\text{DIV} + 1) \times 2\). |
38.5.1.7 SAI Transmit Configuration 3 Register (TCR3)

38.5.1.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCR3</td>
<td>14h</td>
</tr>
</tbody>
</table>

38.5.1.7.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CFR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Bits</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

38.5.1.7.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>27-24</td>
<td>Channel FIFO Reset</td>
</tr>
<tr>
<td>CFR</td>
<td></td>
</tr>
</tbody>
</table>

Resets the FIFO pointers for a specific channel. Reading this field will always return zero. FIFO pointers should only be reset when a channel is disabled or the FIFO error flag is set.

The width of CFR field = the number of transmit channels (call it N). For example, if CFR is 2 bits wide, then bit position 24 refers to transmit channel 1 FIFO pointer and bit position 25 refers to transmit channel 2 FIFO pointer. Setting bit 24 resets transmit channel 1 FIFO pointer, and setting bit 25 enables transmit channel 2 FIFO pointer. Setting bit N will reset transmit channel N FIFO pointer.

0b - No effect.
1b - Transmit data channel N FIFO is reset.

NOTE: This field is not supported in every instance. The following table includes only supported registers.

<table>
<thead>
<tr>
<th>Field supported in</th>
<th>Field not supported in</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_TCR3</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-16</td>
<td>Transmit Channel Enable</td>
</tr>
<tr>
<td>TCE</td>
<td>Enables the corresponding data channel for transmit operation. Changing TCE field will take effect immediately for generating the FIFO request and warning flags, but at the end of each frame for transmit operation. The width of TCE field = the number of transmit channels (call it N). For example, if TCE field is 2 bits wide, then bit position 16 refers to transmit channel 1 and bit position 17 refers to transmit channel 2. Setting bit 16 enables transmit channel 1, and setting bit 17 enables transmit channel 2. Setting bit N will enable transmit channel N.</td>
</tr>
<tr>
<td></td>
<td>0b - Transmit data channel N is disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Transmit data channel N is enabled.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This field is not supported in every instance. The following table includes only supported registers.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field supported in</th>
<th>Field not supported in</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_TCR3</td>
<td>—</td>
</tr>
<tr>
<td>SAI2_TCR3[16]</td>
<td>SAI2_TCR3[19–17]</td>
</tr>
<tr>
<td>SAI3_TCR3[16]</td>
<td>SAI3_TCR3[19–17]</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-0</td>
<td>Word Flag Configuration</td>
</tr>
<tr>
<td>WDFL</td>
<td>Configures which word sets the start of word flag. The value written must be less than the word number. For example, writing 0 configures the first word in the frame. When configured to a value greater than TCR4[FRSZ], then the start of word flag is never set.</td>
</tr>
</tbody>
</table>

### 38.5.1.8 SAI Transmit Configuration 4 Register (TCR4)

#### 38.5.1.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCR4</td>
<td>18h</td>
</tr>
</tbody>
</table>
38.5.1.8.2  Function
This register must not be altered when TCSR[TE] is set.

38.5.1.8.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>SYWD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

38.5.1.8.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>FCONT</td>
</tr>
<tr>
<td></td>
<td>FIFO Continue on Error</td>
</tr>
<tr>
<td></td>
<td>Configures when the SAI will continue transmitting after a FIFO error has been detected.</td>
</tr>
<tr>
<td></td>
<td>0b - On FIFO error, the SAI will continue from the start of the next frame after the FIFO error flag has been cleared.</td>
</tr>
<tr>
<td></td>
<td>1b - On FIFO error, the SAI will continue from the same word that caused the FIFO error to set after the FIFO warning flag has been cleared.</td>
</tr>
<tr>
<td>27-26</td>
<td>FCOMB</td>
</tr>
<tr>
<td></td>
<td>FIFO Combine Mode</td>
</tr>
<tr>
<td></td>
<td>When FIFO combine mode is enabled for FIFO writes, software writing to any FIFO data register will alternate the write among the enabled data channel FIFOs. For example, if two data channels are enabled then the first write will be performed to the first enabled data channel FIFO and the second write will be performed to the second enabled data channel FIFO. Resetting the FIFO or disabling FIFO combine mode for FIFO writes will reset the pointer back to the first enabled data channel.</td>
</tr>
<tr>
<td></td>
<td>When FIFO combine mode is enabled for FIFO reads from the transmit shift registers, the transmit data channel output will alternate between the enabled data channel FIFOs. For example, if two data channels are enabled then the first unmasked word will be transmitted from the first enabled data channel FIFO and the second unmasked word will be transmitted from the second enabled data channel FIFO. Since the first word of the frame is always transmitted from the first enabled data channel FIFO, it is recommended that the number of unmasked words per frame is evenly divisible by the number of enabled data channels.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This field is not supported in every instance. The following table includes only supported registers.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Field supported in</td>
</tr>
<tr>
<td></td>
<td>SAI1_TCR4</td>
</tr>
<tr>
<td></td>
<td>—</td>
</tr>
<tr>
<td></td>
<td>—</td>
</tr>
</tbody>
</table>

00b - FIFO combine mode disabled.  
01b - FIFO combine mode enabled on FIFO reads (from transmit shift registers).  
10b - FIFO combine mode enabled on FIFO writes (by software).  
11b - FIFO combine mode enabled on FIFO reads (from transmit shift registers) and writes (by software).

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>25-24</td>
<td>FIFO Packing Mode</td>
</tr>
</tbody>
</table>
| FPACK     | Enables packing of 8-bit data or 16-bit data into each 32-bit FIFO word. If the word size is greater than 8-bit or 16-bit then only the first 8-bit or 16-bits are loaded from the FIFO. The first word in each frame always starts with a new 32-bit FIFO word and the first bit shifted must be configured within the first packed word. When FIFO packing is enabled, the FIFO write pointer will only increment when the full 32-bit FIFO word has been written by software.  
|           | 00b - FIFO packing is disabled        |
|           | 01b - Reserved                       |
|           | 10b - 8-bit FIFO packing is enabled  |
|           | 11b - 16-bit FIFO packing is enabled |

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>23-21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20-16</td>
<td>Frame size</td>
</tr>
<tr>
<td>FRSZ</td>
<td>Configures the number of words in each frame. The value written must be one less than the number of words in the frame. For example, write 0 for one word per frame. The maximum supported frame size is 32 words.</td>
</tr>
<tr>
<td>15-13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-8</td>
<td>Sync Width</td>
</tr>
<tr>
<td>SYWD</td>
<td>Configures the length of the frame sync in number of bit clocks. The value written must be one less than the number of bit clocks. For example, write 0 for the frame sync to assert for one bit clock only. The sync width cannot be configured longer than the first word of the frame.</td>
</tr>
<tr>
<td>7-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Channel Mode</td>
</tr>
</tbody>
</table>
| CHMOD     | Configures if transmit data pins are configured for TDM mode or Output mode.  
|           | 0b - TDM mode, transmit data pins are tri-stated when slots are masked or channels are disabled.  
|           | 1b - Output mode, transmit data pins are never tri-stated and will output zero when slots are masked or channels are disabled. |
| 4         | MSB First                        |
| MF        | Configures whether the LSB or the MSB is transmitted first.  
|           | 0b - LSB is transmitted first.    |
|           | 1b - MSB is transmitted first.    |
| 3         | Frame Sync Early                 |
| FSE       | Frame sync asserts with the first bit of the frame.  
|           | 1b - Frame sync asserts one bit before the first bit of the frame. |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>ONDEM</td>
<td>On Demand Mode</td>
</tr>
<tr>
<td></td>
<td>When set, and the frame sync is generated internally, a frame sync is only generated when the FIFO warning flag is clear.</td>
</tr>
<tr>
<td></td>
<td>0b - Internal frame sync is generated continuously.</td>
</tr>
<tr>
<td></td>
<td>1b - Internal frame sync is generated when the FIFO warning flag is clear.</td>
</tr>
<tr>
<td>FSP</td>
<td>Frame Sync Polarity</td>
</tr>
<tr>
<td></td>
<td>Configures the polarity of the frame sync.</td>
</tr>
<tr>
<td></td>
<td>0b - Frame sync is active high.</td>
</tr>
<tr>
<td></td>
<td>1b - Frame sync is active low.</td>
</tr>
<tr>
<td>FSD</td>
<td>Frame Sync Direction</td>
</tr>
<tr>
<td></td>
<td>Configures the direction of the frame sync.</td>
</tr>
<tr>
<td></td>
<td>0b - Frame sync is generated externally in Slave mode.</td>
</tr>
<tr>
<td></td>
<td>1b - Frame sync is generated internally in Master mode.</td>
</tr>
</tbody>
</table>

### 38.5.1.9 SAI Transmit Configuration 5 Register (TCR5)

#### 38.5.1.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCR5</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

#### 38.5.1.9.2 Function

This register must not be altered when TCSR[TE] is set.

#### 38.5.1.9.3 Diagram

![Diagram of TCR5 register](image-url)
### 38.5.1.9.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29 _</td>
<td>Reserved</td>
</tr>
<tr>
<td>28-24 WNW</td>
<td>Word N Width Configures the number of bits in each word, for each word except the first in the frame. The value written must be one less than the number of bits per word. Word width of less than 8 bits is not supported.</td>
</tr>
<tr>
<td>23-21 _</td>
<td>Reserved</td>
</tr>
<tr>
<td>20-16 W0W</td>
<td>Word 0 Width Configures the number of bits in the first word in each frame. The value written must be one less than the number of bits in the first word. Word width of less than 8 bits is not supported if there is only one word per frame.</td>
</tr>
<tr>
<td>15-13 _</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-8 FBT</td>
<td>First Bit Shifted Configures the bit index for the first bit transmitted for each word in the frame. If configured for MSB First, the index of the next bit transmitted is one less than the current bit transmitted. If configured for LSB First, the index of the next bit transmitted is one more than the current bit transmitted. The value written must be greater than or equal to the word width when configured for MSB First. The value written must be less than or equal to 31-word width when configured for LSB First.</td>
</tr>
<tr>
<td>7-0 _</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 38.5.1.10 SAI Transmit Data Register (TDR0 - TDR3)

#### 38.5.1.10.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDR0</td>
<td>20h</td>
</tr>
<tr>
<td>TDR1</td>
<td>24h</td>
</tr>
<tr>
<td>TDR2</td>
<td>28h</td>
</tr>
<tr>
<td>TDR3</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

**NOTE**

Each module instance supports a different number of registers.
### Memory map and register definition

<table>
<thead>
<tr>
<th>Register supported</th>
<th>Register not supported</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_T DR0--\ TDR3</td>
<td>—</td>
</tr>
<tr>
<td>SAI2_T DR0</td>
<td>SAI2_T DR1--\ TDR3</td>
</tr>
<tr>
<td>SAI3_T DR0</td>
<td>SAI3_T DR1--\ TDR3</td>
</tr>
</tbody>
</table>

#### 38.5.1.10.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TDR</td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     |    |    |    |    |    | 0  |    |    |    |    |    |    |    |    |    |
W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | TDR |

Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

See Register reset values.
```

#### 38.5.1.10.3 Register reset values

<table>
<thead>
<tr>
<th>Register</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDR0</td>
<td>SAI1--\SAI3: 0000_0000h</td>
</tr>
<tr>
<td>TDR1--\TDR3</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

#### 38.5.1.10.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Transmit Data Register</td>
</tr>
<tr>
<td>TDR</td>
<td>Writes to this register when the transmit FIFO is not full will push the data written into the transmit data FIFO. Writes to this register when the transmit FIFO is full are ignored.</td>
</tr>
</tbody>
</table>
38.5.1.11 SAI Transmit FIFO Register (TFR0 - TFR3)

38.5.1.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TFR0</td>
<td>40h</td>
</tr>
<tr>
<td>TFR1</td>
<td>44h</td>
</tr>
<tr>
<td>TFR2</td>
<td>48h</td>
</tr>
<tr>
<td>TFR3</td>
<td>4Ch</td>
</tr>
</tbody>
</table>

38.5.1.11.2 Function

The MSB of the read and write pointers is used to distinguish between FIFO full and empty conditions. If the read and write pointers are identical, then the FIFO is empty. If the read and write pointers are identical except for the MSB, then the FIFO is full.

NOTE

Each module instance supports a different number of registers.
38.5.11.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>WCP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>WFP</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: See Register reset values.

38.5.11.4 Register reset values

<table>
<thead>
<tr>
<th>Register</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>TFR0</td>
<td>SAI1–SAI3: 0000_0000h</td>
</tr>
<tr>
<td>TFR1–TFR3</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

38.5.11.5 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Write Channel Pointer</td>
</tr>
<tr>
<td></td>
<td>When FIFO Combine mode is enabled for writes, indicates that this data channel is the next FIFO to be written.</td>
</tr>
</tbody>
</table>

**NOTE:** This field is not supported in every instance. The following table includes only supported registers.

<table>
<thead>
<tr>
<th>Field supported in</th>
<th>Field not supported in</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_TFR0–TFR3</td>
<td></td>
</tr>
<tr>
<td></td>
<td>SAI2_TFR0</td>
</tr>
<tr>
<td></td>
<td>SAI3_TFR0</td>
</tr>
</tbody>
</table>

0b - No effect.
1b - FIFO combine is enabled for FIFO writes and this FIFO will be written on the next FIFO write.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>30-22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21-16</td>
<td>Write FIFO Pointer</td>
</tr>
<tr>
<td></td>
<td>FIFO write pointer for transmit data channel.</td>
</tr>
<tr>
<td>15-6</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 38.5.1.12 SAI Transmit Mask Register (TMR)

#### 38.5.1.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TMR</td>
<td>60h</td>
</tr>
</tbody>
</table>

#### 38.5.1.12.2 Function

This register is double-buffered and updates:

1. When TCSR[TE] is first set
2. At the end of each frame.

This allows the masked words in each frame to change from frame to frame.

#### 38.5.1.12.3 Diagram

```
R | W
---|---
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
R | W
Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0
```

#### 38.5.1.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Transmit Word Mask</td>
</tr>
<tr>
<td>TWM</td>
<td></td>
</tr>
</tbody>
</table>
### 38.5.1.13 SAI Receive Control Register (RCSR)

#### 38.5.1.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCSR</td>
<td>88h</td>
</tr>
</tbody>
</table>

#### 38.5.1.13.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

#### 38.5.1.13.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Receiver Enable</td>
</tr>
<tr>
<td>RE</td>
<td>Enables/disables the receiver. When software clears this field, the receiver remains enabled, and this bit remains set, until the end of the current frame.</td>
</tr>
<tr>
<td></td>
<td>0b - Receiver is disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Receiver is enabled, or receiver has been disabled and has not yet reached end of frame.</td>
</tr>
</tbody>
</table>

| 30    | Stop Enable |
| STOPE | Configures receiver operation in Stop mode. |
|       | 0b - Receiver disabled in Stop mode. |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>1b</td>
<td>Receiver enabled in Stop mode.</td>
</tr>
<tr>
<td>29</td>
<td>DBGE Debug Enable&lt;br&gt;Enables/disables receiver operation in Debug mode. The receive bit clock is not affected by Debug mode.&lt;br&gt;0b - Receiver is disabled in Debug mode, after completing the current frame.&lt;br&gt;1b - Receiver is enabled in Debug mode.</td>
</tr>
<tr>
<td>28</td>
<td>BCE Bit Clock Enable&lt;br&gt;Enables the receive bit clock, separately from RE. This field is automatically set whenever RE is set. When software clears this field, the receive bit clock remains enabled, and this field remains set, until the end of the current frame.&lt;br&gt;0b - Receive bit clock is disabled.&lt;br&gt;1b - Receive bit clock is enabled.</td>
</tr>
<tr>
<td>27-26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>FR FIFO Reset&lt;br&gt;Empties the FIFO, and sets the FIFO read and write pointers to the same value, which may or may not be zero. Reading this field will always return zero. FIFO pointers should only be reset when the receiver is disabled or the FIFO error flag is set.&lt;br&gt;0b - No effect.&lt;br&gt;1b - FIFO reset.</td>
</tr>
<tr>
<td>24</td>
<td>SR Software Reset&lt;br&gt;Resets the internal receiver logic including the FIFO pointers. Software-visible registers are not affected, except for the status registers.&lt;br&gt;0b - No effect.&lt;br&gt;1b - Software reset.</td>
</tr>
<tr>
<td>23-21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>WSF Word Start Flag&lt;br&gt;Indicates that the start of the configured word has been detected. Write a logic 1 to this field to clear this flag.&lt;br&gt;0b - Start of word not detected.&lt;br&gt;1b - Start of word detected.</td>
</tr>
<tr>
<td>19</td>
<td>SEF Sync Error Flag&lt;br&gt;Indicates that an error in the externally-generated frame sync has been detected. Write a logic 1 to this field to clear this flag.&lt;br&gt;0b - Sync error not detected.&lt;br&gt;1b - Frame sync error detected.</td>
</tr>
<tr>
<td>18</td>
<td>FEF FIFO Error Flag&lt;br&gt;Indicates that an enabled receive FIFO has overflowed. Write a logic 1 to this field to clear this flag.&lt;br&gt;0b - Receive overflow not detected.&lt;br&gt;1b - Receive overflow detected.</td>
</tr>
<tr>
<td>17</td>
<td>FWF FIFO Warning Flag&lt;br&gt;Indicates that an enabled receive FIFO is full.&lt;br&gt;0b - No enabled receive FIFO is full.&lt;br&gt;1b - Enabled receive FIFO is full.</td>
</tr>
<tr>
<td>16</td>
<td>FRF FIFO Request Flag&lt;br&gt;Indicates that the number of words in an enabled receive channel FIFO is greater than the receive FIFO watermark.</td>
</tr>
<tr>
<td>Field</td>
<td>Function</td>
</tr>
<tr>
<td>--------</td>
<td>----------</td>
</tr>
<tr>
<td>15-13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Word Start Interrupt Enable</td>
</tr>
<tr>
<td>WSIE</td>
<td>Enables/disables word start interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables interrupt.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables interrupt.</td>
</tr>
<tr>
<td>11</td>
<td>Sync Error Interrupt Enable</td>
</tr>
<tr>
<td>SEIE</td>
<td>Enables/disables sync error interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables interrupt.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables interrupt.</td>
</tr>
<tr>
<td>10</td>
<td>FIFO Error Interrupt Enable</td>
</tr>
<tr>
<td>FEIE</td>
<td>Enables/disables FIFO error interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the interrupt.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the interrupt.</td>
</tr>
<tr>
<td>9</td>
<td>FIFO Warning Interrupt Enable</td>
</tr>
<tr>
<td>FWIE</td>
<td>Enables/disables FIFO warning interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the interrupt.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the interrupt.</td>
</tr>
<tr>
<td>8</td>
<td>FIFO Request Interrupt Enable</td>
</tr>
<tr>
<td>FRIE</td>
<td>Enables/disables FIFO request interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the interrupt.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the interrupt.</td>
</tr>
<tr>
<td>7-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>FIFO Warning DMA Enable</td>
</tr>
<tr>
<td>FWDE</td>
<td>Enables/disables DMA requests.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the DMA request.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the DMA request.</td>
</tr>
<tr>
<td>0</td>
<td>FIFO Request DMA Enable</td>
</tr>
<tr>
<td>FRDE</td>
<td>Enables/disables DMA requests.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables the DMA request.</td>
</tr>
<tr>
<td></td>
<td>1b - Enables the DMA request.</td>
</tr>
</tbody>
</table>

### 38.5.1.14 SAI Receive Configuration 1 Register (RCR1)
38.5.1.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCR1</td>
<td>8Ch</td>
</tr>
</tbody>
</table>

38.5.1.14.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

38.5.1.14.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-0</td>
<td>Receive FIFO Watermark</td>
</tr>
<tr>
<td>RFW</td>
<td>Configures the watermark level for all enabled receiver channels.</td>
</tr>
</tbody>
</table>

38.5.1.15 SAI Receive Configuration 2 Register (RCR2)

38.5.1.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCR2</td>
<td>90h</td>
</tr>
</tbody>
</table>

38.5.1.15.2 Function

This register must not be altered when RCSR[RE] is set.
### 38.5.1.15.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 38.5.1.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Synchronous Mode</td>
</tr>
<tr>
<td></td>
<td>Configures between asynchronous and synchronous modes of operation. When configured for a synchronous mode of operation, the transmitter must be configured for asynchronous operation.</td>
</tr>
<tr>
<td></td>
<td>0b - Asynchronous mode.</td>
</tr>
<tr>
<td></td>
<td>1b - Synchronous with transmitter.</td>
</tr>
<tr>
<td>29</td>
<td>Bit Clock Swap</td>
</tr>
<tr>
<td></td>
<td>This field swaps the bit clock used by the receiver. When the receiver is configured in asynchronous mode and this bit is set, the receiver is clocked by the transmitter bit clock (TX_BCLK). This allows the transmitter and receiver to share the same bit clock, but the receiver continues to use the receiver frame sync (RX_SYNC).</td>
</tr>
<tr>
<td></td>
<td>When the receiver is configured in synchronous mode, the transmitter BCS field and receiver BCS field must be set to the same value. When both are set, the transmitter and receiver are both clocked by the receiver bit clock (RX_BCLK) but use the transmitter frame sync (TX_SYNC).</td>
</tr>
<tr>
<td></td>
<td>0b - Use the normal bit clock source.</td>
</tr>
<tr>
<td></td>
<td>1b - Swap the bit clock source.</td>
</tr>
<tr>
<td>28</td>
<td>Bit Clock Input</td>
</tr>
<tr>
<td></td>
<td>When this field is set and using an internally generated bit clock in either synchronous or asynchronous mode, the bit clock actually used by the receiver is delayed by the pad output delay (the receiver is clocked by the pad input as if the clock was externally generated). This has the effect of decreasing the data input setup time, but increasing the data output valid time.</td>
</tr>
<tr>
<td></td>
<td>The slave mode timing from the datasheet should be used for the receiver when this bit is set. In synchronous mode, this bit allows the receiver to use the slave mode timing from the datasheet, while the transmitter uses the master mode timing. This field has no effect when configured for an externally generated bit clock .</td>
</tr>
<tr>
<td></td>
<td>0b - No effect.</td>
</tr>
<tr>
<td></td>
<td>1b - Internal logic is clocked as if bit clock was externally generated.</td>
</tr>
<tr>
<td>27-26</td>
<td>MCLK Select</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
Selects the audio Master Clock option used to generate an internally generated bit clock. This field has no effect when configured for an externally generated bit clock.

**NOTE:** Depending on the device, some Master Clock options might not be available. See the chip-specific information for the availability and chip-specific meaning of each option.

00b - Bus Clock selected.
01b - Master Clock (MCLK) 1 option selected.
10b - Master Clock (MCLK) 2 option selected.
11b - Master Clock (MCLK) 3 option selected.

25 | Bit Clock Polarity
--- | ---
Configures the polarity of the bit clock.

0b - Bit Clock is active high with drive outputs on rising edge and sample inputs on falling edge.
1b - Bit Clock is active low with drive outputs on falling edge and sample inputs on rising edge.

24 | Bit Clock Direction
--- | ---
Configures the direction of the bit clock.

0b - Bit clock is generated externally in Slave mode.
1b - Bit clock is generated internally in Master mode.

7-0 | Bit Clock Divide
--- | ---
Divides down the audio master clock to generate the bit clock when configured for an internal bit clock. The division value is \( (DIV + 1) \times 2 \).

### 38.5.1.16 SAI Receive Configuration 3 Register (RCR3)

#### 38.5.1.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCR3</td>
<td>94h</td>
</tr>
</tbody>
</table>

#### 38.5.1.16.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31 30 29 28 27 26 25 24</th>
<th>23 22 21 20 19 18 17 16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>CFR</td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15 14 13 12 11 10 9 8</th>
<th>7 6 5 4 3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>
```
### 38.5.1.16.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-24</td>
<td>Channel FIFO Reset</td>
</tr>
<tr>
<td>CFR</td>
<td>Resets the FIFO pointers for a specific channel. Reading this field will always return zero. FIFO pointers should only be reset when a channel is disabled or the FIFO error flag is set.</td>
</tr>
<tr>
<td></td>
<td>The width of CFR field = the number of receive channels (call it N). For example, if CFR is 2 bits wide, then bit position 24 refers to receive channel 1 FIFO pointer and bit position 25 refers to receive channel 2 FIFO pointer. Setting bit 24 resets receive channel 1 FIFO pointer, and setting bit 25 enables receive channel 2 FIFO pointer. Setting bit N will reset receive channel N FIFO pointer.</td>
</tr>
<tr>
<td></td>
<td>0b - No effect.</td>
</tr>
<tr>
<td></td>
<td>1b - Receive data channel N FIFO is reset.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This field is not supported in every instance. The following table includes only supported registers.</td>
</tr>
<tr>
<td></td>
<td><strong>Field supported in</strong></td>
</tr>
<tr>
<td>SAI1_RCR3</td>
<td>—</td>
</tr>
<tr>
<td>SAI2_RCR3[16]</td>
<td>—</td>
</tr>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-16</td>
<td>Receive Channel Enable</td>
</tr>
<tr>
<td>RCE</td>
<td>Enables the corresponding data channel for receive operation. Changing this field will take effect immediately for generating the FIFO request and warning flags, but at the end of each frame for receive operation.</td>
</tr>
<tr>
<td></td>
<td>The width of RCE field = the number of receive channels (call it N). For example, if RCE field is 2 bits wide, then bit position 16 refers to receive channel 1 and bit position 17 refers to receive channel 2. Setting bit 16 enables receive channel 1, and setting bit 17 enables receive channel 2. Setting bit N will enable receive channel N.</td>
</tr>
<tr>
<td></td>
<td>0b - Receive data channel N is disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Receive data channel N is enabled.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This field is not supported in every instance. The following table includes only supported registers.</td>
</tr>
<tr>
<td></td>
<td><strong>Field supported in</strong></td>
</tr>
<tr>
<td>SAI1_RCR3</td>
<td>—</td>
</tr>
<tr>
<td>SAI3_RCR3[16]</td>
<td>SAI3_RCR3[19–17]</td>
</tr>
<tr>
<td>15-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-5</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 38.5.1.17 SAI Receive Configuration 4 Register (RCR4)

#### 38.5.1.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCR4</td>
<td>98h</td>
</tr>
</tbody>
</table>

#### 38.5.1.17.2 Function

This register must not be altered when RCSR[RE] is set.

#### 38.5.1.17.3 Diagram

*Diagram showing register bits and values.*

#### 38.5.1.17.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>FIFO Continue on Error</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| FCONT  | Configures when the SAI will continue receiving after a FIFO error has been detected.  
|        | 0b - On FIFO error, the SAI will continue from the start of the next frame after the FIFO error flag has been cleared.  
|        | 1b - On FIFO error, the SAI will continue from the same word that caused the FIFO error to set after the FIFO warning flag has been cleared. |
| 27-26  | FIFO Combine Mode                                                         |
|        | When FIFO combine mode is enabled for FIFO reads, software reading any FIFO data register will alternate the read among the enabled data channel FIFOs. For example, if two data channels are enabled then the first read will be performed to the first enabled data channel FIFO and the second read will be performed to the second enabled data channel FIFO. Resetting the FIFO or disabling FIFO combine mode for FIFO reads will reset the pointer back to the first enabled data channel.  
|        | When FIFO combine mode is enabled for FIFO writes from the receive shift registers, the first enabled data channel input will alternate between the enabled data channel FIFOs. For example, if two data channels are enabled then the first unmasked received word will be stored in the first enabled data channel FIFO and the second unmasked received word will be stored in the second enabled data channel FIFO. Since the first word of the frame is always stored in the first enabled data channel FIFO, it is recommended that the number of unmasked words per frame is evenly divisible by the number of enabled data channels. |
| NOTE:  | This field is not supported in every instance. The following table includes only supported registers. |

### Field supported in | Field not supported in
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_RCR4</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>SAI2_RCR4</td>
</tr>
<tr>
<td>—</td>
<td>SAI3_RCR4</td>
</tr>
</tbody>
</table>

00b - FIFO combine mode disabled.  
01b - FIFO combine mode enabled on FIFO writes (from receive shift registers).  
10b - FIFO combine mode enabled on FIFO reads (by software).  
11b - FIFO combine mode enabled on FIFO writes (from receive shift registers) and reads (by software).  

<table>
<thead>
<tr>
<th>25-24</th>
<th>FIFO Packing Mode</th>
</tr>
</thead>
</table>
| FPACK | Enables packing of 8-bit data or 16-bit data into each 32-bit FIFO word. If the word size is greater than 8-bit or 16-bit then only the first 8-bit or 16-bits are stored to the FIFO. The first word in each frame always starts with a new 32-bit FIFO word and the first bit shifted must be configured within the first packed word. When FIFO packing is enabled, the FIFO read pointer will only increment when the full 32-bit FIFO word has been read by software.  
|       | 00b - FIFO packing is disabled  
|       | 01b - Reserved.  
|       | 10b - 8-bit FIFO packing is enabled  
|       | 11b - 16-bit FIFO packing is enabled |
| 23-21 | Reserved |
| 20-16 | Frame Size    |
| FRSZ  | Configures the number of words in each frame. The value written must be one less than the number of words in the frame. For example, write 0 for one word per frame. The maximum supported frame size is 32 words. |
| 15-13 | Reserved |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>12-8</td>
<td>Sync Width</td>
</tr>
<tr>
<td>SYWD</td>
<td>Configures the length of the frame sync in number of bit clocks. The value written must be one less than the number of bit clocks. For example, write 0 for the frame sync to assert for one bit clock only. The sync width cannot be configured longer than the first word of the frame.</td>
</tr>
<tr>
<td>7-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved Software should only write zero to this bit.</td>
</tr>
<tr>
<td>4</td>
<td>MSB First</td>
</tr>
<tr>
<td>MF</td>
<td>Configures whether the LSB or the MSB is received first.</td>
</tr>
<tr>
<td></td>
<td>0b - LSB is received first.</td>
</tr>
<tr>
<td></td>
<td>1b - MSB is received first.</td>
</tr>
<tr>
<td>3</td>
<td>Frame Sync Early</td>
</tr>
<tr>
<td>FSE</td>
<td>Frame sync asserts with the first bit of the frame.</td>
</tr>
<tr>
<td></td>
<td>0b - Frame sync asserts with the first bit of the frame.</td>
</tr>
<tr>
<td></td>
<td>1b - Frame sync asserts one bit before the first bit of the frame.</td>
</tr>
<tr>
<td>2</td>
<td>On Demand Mode</td>
</tr>
<tr>
<td>ONDEM</td>
<td>When set, and the frame sync is generated internally, a frame sync is only generated when the FIFO warning flag is clear.</td>
</tr>
<tr>
<td></td>
<td>0b - Internal frame sync is generated continuously.</td>
</tr>
<tr>
<td></td>
<td>1b - Internal frame sync is generated when the FIFO warning flag is clear.</td>
</tr>
<tr>
<td>1</td>
<td>Frame Sync Polarity</td>
</tr>
<tr>
<td>FSP</td>
<td>Configures the polarity of the frame sync.</td>
</tr>
<tr>
<td></td>
<td>0b - Frame sync is active high.</td>
</tr>
<tr>
<td></td>
<td>1b - Frame sync is active low.</td>
</tr>
<tr>
<td>0</td>
<td>Frame Sync Direction</td>
</tr>
<tr>
<td>FSD</td>
<td>Configures the direction of the frame sync.</td>
</tr>
<tr>
<td></td>
<td>0b - Frame Sync is generated externally in Slave mode.</td>
</tr>
<tr>
<td></td>
<td>1b - Frame Sync is generated internally in Master mode.</td>
</tr>
</tbody>
</table>

### 38.5.1.18 SAI Receive Configuration 5 Register (RCR5)

#### 38.5.1.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RCR5</td>
<td>9Ch</td>
</tr>
</tbody>
</table>

#### 38.5.1.18.2 Function

This register must not be altered when RCSR[RE] is set.
### 38.5.1.18.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 38.5.1.18.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28-24</td>
<td>Word N Width</td>
</tr>
<tr>
<td>WNW</td>
<td>Configures the number of bits in each word, for each word except the first in the frame. The value written must be one less than the number of bits per word. Word width of less than 8 bits is not supported.</td>
</tr>
<tr>
<td>23-21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20-16</td>
<td>Word 0 Width</td>
</tr>
<tr>
<td>WOW</td>
<td>Configures the number of bits in the first word in each frame. The value written must be one less than the number of bits in the first word. Word width of less than 8 bits is not supported if there is only one word per frame.</td>
</tr>
<tr>
<td>15-13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-8</td>
<td>First Bit Shifted</td>
</tr>
<tr>
<td>FBT</td>
<td>Configures the bit index for the first bit received for each word in the frame. If configured for MSB First, the index of the next bit received is one less than the current bit received. If configured for LSB First, the index of the next bit received is one more than the current bit received. The value written must be greater than or equal to the word width when configured for MSB First. The value written must be less than or equal to 31-word width when configured for LSB First.</td>
</tr>
<tr>
<td>7-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 38.5.1.19 SAI Receive Data Register (RDR0 - RDR3)
38.5.1.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RDR0</td>
<td>A0h</td>
</tr>
<tr>
<td>RDR1</td>
<td>A4h</td>
</tr>
<tr>
<td>RDR2</td>
<td>A8h</td>
</tr>
<tr>
<td>RDR3</td>
<td>ACh</td>
</tr>
</tbody>
</table>

**NOTE**

Each module instance supports a different number of registers.

<table>
<thead>
<tr>
<th>Register supported</th>
<th>Register not supported</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_R DR0–RDR3</td>
<td>—</td>
</tr>
<tr>
<td>SAI2_R DR0</td>
<td>SAI2_R DR1–RDR3</td>
</tr>
<tr>
<td>SAI3_R DR0</td>
<td>SAI3_R DR1–RDR3</td>
</tr>
</tbody>
</table>

38.5.1.19.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

See Register reset values.

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

See Register reset values.
38.5.1.19.3 Register reset values

<table>
<thead>
<tr>
<th>Register</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>RDR0</td>
<td>SAI1–SAI3: 0000_0000h</td>
</tr>
<tr>
<td>RDR1–RDR3</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

38.5.1.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Receive Data Register</td>
</tr>
<tr>
<td>RDR</td>
<td>Reads from this register when the receive FIFO is not empty will return the data from the top of the receive FIFO. Reads from this register when the receive FIFO is empty are ignored.</td>
</tr>
</tbody>
</table>

38.5.1.20 SAI Receive FIFO Register (RFR0 - RFR3)

38.5.1.20.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RFR0</td>
<td>C0h</td>
</tr>
<tr>
<td>RFR1</td>
<td>C4h</td>
</tr>
<tr>
<td>RFR2</td>
<td>C8h</td>
</tr>
<tr>
<td>RFR3</td>
<td>CCh</td>
</tr>
</tbody>
</table>

38.5.1.20.2 Function

The MSB of the read and write pointers is used to distinguish between FIFO full and empty conditions. If the read and write pointers are identical, then the FIFO is empty. If the read and write pointers are identical except for the MSB, then the FIFO is full.

NOTE

Each module instance supports a different number of registers.

<table>
<thead>
<tr>
<th>Register supported</th>
<th>Register not supported</th>
</tr>
</thead>
<tbody>
<tr>
<td>SAI1_R</td>
<td>—</td>
</tr>
<tr>
<td>FR0–RFR3</td>
<td>—</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Register supported | Register not supported
---|---
SAI2_R | SAI2_R
FR0 | FR1–RFR3
SAI3_R | SAI3_R
FR0 | FR1–RFR3

### 38.5.1.20.3 Diagram

| Bits | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset

*See Register reset values.*

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    | RCP|    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset

*See Register reset values.*

### 38.5.1.20.4 Register reset values

<table>
<thead>
<tr>
<th>Register</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>RFR0</td>
<td>SAI1–SAI3: 0000_0000h</td>
</tr>
<tr>
<td>RFR1–RFR3</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

### 38.5.1.20.5 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21-16</td>
<td>Write FIFO Pointer</td>
</tr>
<tr>
<td>WFP</td>
<td>FIFO write pointer for receive data channel.</td>
</tr>
<tr>
<td>15</td>
<td>Receive Channel Pointer</td>
</tr>
<tr>
<td>RCP</td>
<td>When FIFO Combine mode is enabled for reads, indicates that this data channel is the next FIFO to be read.</td>
</tr>
</tbody>
</table>

*NOTE:* This field is not supported in every instance. The following table includes only supported registers.

*Table continues on the next page...*
Memory map and register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>Field supported in</td>
<td>Field not supported in</td>
</tr>
<tr>
<td>SAI1_RFR0–RFR3</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>SAI2_RFR0</td>
</tr>
<tr>
<td>—</td>
<td>SAI3_RFR0</td>
</tr>
</tbody>
</table>

0b - No effect.
1b - FIFO combine is enabled for FIFO reads and this FIFO will be read on the next FIFO read.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>14-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-0</td>
<td>Read FIFO Pointer</td>
</tr>
<tr>
<td>RFP</td>
<td>FIFO read pointer for receive data channel.</td>
</tr>
</tbody>
</table>

38.5.1.21 SAI Receive Mask Register (RMR)

38.5.1.21.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RMR</td>
<td>E0h</td>
</tr>
</tbody>
</table>

38.5.1.21.2 Function

This register is double-buffered and updates:

1. When RCSR[RE] is first set
2. At the end of each frame

This allows the masked words in each frame to change from frame to frame.
38.5.1.21.3  Diagram

### Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Receive Word Mask</td>
</tr>
<tr>
<td>RWM</td>
<td>Configures whether the receive word is masked (received data ignored and not written to receive FIFO) for the corresponding word in the frame.</td>
</tr>
<tr>
<td></td>
<td>00000000000000000000000000000000b - Word N is enabled.</td>
</tr>
<tr>
<td></td>
<td>00000000000000000000000000000001b - Word N is masked.</td>
</tr>
</tbody>
</table>
Chapter 39
Medium Quality Sound (MQS)

39.1 Chip-specific MQS information

Table 39-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module or subsystem</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Audio Subsystem</td>
<td>Audio Subsystem</td>
<td>Audio Subsystem Overview</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

39.2 Overview

Medium quality sound (MQS) is used to generate medium quality audio via a standard GPIO in the pinmux, allowing the user to connect stereo speakers or headphones to a power amplifier without an additional DAC chip.

MQS accepts the following inputs:

- 2-channel, LSB-valid 16-bit, MSB shift-out first serial data (sdata)
- Frame sync asserting with the first bit of the frame (fs)
- Bit clock used to shift data out on the positive clock edge (bclk)

The 44 kHz or 48 kHz input signals from SAI3 are in left_justified format. MQS provides the SNR target as no more than 20 dB for the signals below 10 kHz. The signals above 10 kHz will have worse THD+N values.
MQS provides only simple audio reproduction. No internal pop, click or distortion artifact reduction methods are provided.

### 39.2.1 Block Diagram

**Figure 39-1. Block Diagram**

MQS has the following sub-modules:

1. **Channel Split**: Splits the I2S signals into separate left channel and right channel audio data.
2. **Noise Shaping**: Uses the sigma-delta algorithm to generate low-resolution, very high sampling audio, while the audio sampling rate is increased.
3. **PWM generation**: Generates the bit stream to the GPIO, which is then used to drive the amplifier and then to drive the external speakers or headphones.
4. **mclk generation**: Used to generate the master clock (mclk). The frequency of mclk is determined by the final bit duration of PWM generation module.
5. **mclk control**: Used as a metronome to co-ordinate the different functional blocks working synchronously.
6. **Reset and Enable**: Used to generate the reset and enable logic to different clock domains.
39.3 External Signals

The following table describes the external signals of MQS:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>MQS_RIGHT</td>
<td>Right signal output</td>
<td>GPIO_AD_B0_04</td>
<td>ALT1</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_00</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMC_13</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>MQS_LEFT</td>
<td>Left signal output</td>
<td>GPIO_EMC_14</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_01</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_05</td>
<td>ALT1</td>
<td></td>
</tr>
</tbody>
</table>

39.4 Interface Signals

MQS module has the following interface signals.

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>In/Out</th>
<th>BitWidth</th>
<th>Description</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>reset_b</td>
<td>In</td>
<td>1</td>
<td>asynchronous reset</td>
<td></td>
</tr>
<tr>
<td>software_reset</td>
<td>In</td>
<td>1</td>
<td>Software reset</td>
<td>From GPR</td>
</tr>
<tr>
<td>mqs_enable</td>
<td>In</td>
<td>1</td>
<td>module enable</td>
<td>From GPR</td>
</tr>
<tr>
<td>pwm_ovr</td>
<td>In</td>
<td>1</td>
<td>PWM oversampling ratio1—64, 0--32</td>
<td>From GPR</td>
</tr>
<tr>
<td>hmclk</td>
<td>In</td>
<td>1</td>
<td>Maximum bit clock, used to generate the mclk, divider ratio is controlled by mqs_hmclk_divide</td>
<td>Max 66.5MHzTypical 24.576MHz</td>
</tr>
<tr>
<td>hmclk_divide</td>
<td>In</td>
<td>8</td>
<td>Divider ration control for mclk from hmclk</td>
<td>From GPR</td>
</tr>
<tr>
<td>bclk</td>
<td>In</td>
<td>1</td>
<td>bit clock from I2S signal</td>
<td></td>
</tr>
<tr>
<td>fs</td>
<td>In</td>
<td>1</td>
<td>frame sync clock from I2S signal</td>
<td></td>
</tr>
<tr>
<td>sdata</td>
<td>In</td>
<td>1</td>
<td>serial audio data from I2S signal</td>
<td></td>
</tr>
</tbody>
</table>
39.5  Programming Considerations

MQS has no internal programmable registers. But it does have some programmability from IOMUXC_GPR2.

<table>
<thead>
<tr>
<th>Register Bits</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IOMUXC_GPR2[26]</td>
<td>MQS_OVERSAMPLE</td>
<td>Used to control the PWM oversampling rate compared with mclk.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1—64, 0—32.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1—Enable MQS, 0—Disable MQS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1—Enable software reset for MQS, 0—Exit software reset for MQS</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0—mclk frequency = hmclk frequency; 1—mclk frequency = ½<em>hmclk frequency; 2—mclk frequency = 1/3</em>hmclk frequency; ...; n—mclk frequency = 1/(n+1)*hmclk frequency</td>
</tr>
</tbody>
</table>

39.5.1  Usage Model

Due to the different devices connected to MQS, and different high frequency behaviors of the connected analog circuits, the user needs choose the appropriate MQS_CLK_DIV and MQS_OVERSAMPLE values for the best audible effects.
Chapter 40
Sony/Philips Digital Interface (SPDIF)

40.1 Chip-specific SPDIF information

Table 40-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module or subsystem</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Audio Subsystem</td>
<td>Audio Subsystem</td>
<td>Audio Subsystem Overview</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

40.2 Overview

The Sony/Philips Digital Interface (SPDIF) audio block is a stereo transceiver that allows the processor to receive and transmit digital audio.

The SPDIF transceiver allows the handling of both SPDIF channel status (CS) and User (U) data and includes a frequency measurement block that allows the precise measurement of an incoming sampling frequency.

A recovered clock is provided to drive both internal components in the system, such as SAI ports, and external components, such as A/Ds or D/As, with clocking control provided via related registers.
As the SPDIF internal data width is 24-bit, the eight most-significant bits of all registers return zeros.

The figure below shows a block diagram of the SPDIF transceiver data paths (receiver and transmitter) and its interface.
Figure 40-1. SPDIF Transceiver Data Interface Block Diagram
40.3 External Signals

The following table describes the external signals of SPDIF:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>SPDIF_OUT</td>
<td>Output line signal</td>
<td>GPIO_EMC_15</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_05</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_02</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>SPDIF_IN</td>
<td>Input line</td>
<td>GPIO_EMC_16</td>
<td>ALT3</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_03</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>SPDIF_SR_CLK</td>
<td>SR clock signal</td>
<td>GPIO_AD_B1_04</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td>SPDIF_LOCK</td>
<td>Lock signal</td>
<td>GPIO_AD_B1_06</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td>SPDIF_EXT_CLK</td>
<td>External clock signal</td>
<td>GPIO_AD_B1_07</td>
<td>ALT3</td>
<td>I</td>
</tr>
</tbody>
</table>

40.4 Clocks

The table found here describes the clock sources for SPDIF.

Please see clock control block for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>gclkw_t0</td>
<td>ipg_clk_root</td>
<td>Global clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
<tr>
<td>tx_clk</td>
<td>spdif0_clk_root</td>
<td>Module Tx clock</td>
</tr>
</tbody>
</table>

40.5 Functional Description

The SPDIF is composed of two parts: SPDIF Receiver and SPDIF Transmitter.

The SPDIF receiver extracts the audio data from each SPDIF frame and places the data in the SPDIF Rx left and right FIFOs. The Channel Status and User Bits are also extracted from each frame and placed in the corresponding registers. The SPDIF receiver also provides a bypass option for direct transfer of the SPDIF input signal to the SPDIF transmitter.
For the SPDIF transmitter, the audio data is provided by the processor via the SPDIFTxLeft and SPDIFTxRight registers. The Channel Status bits are also provided via the corresponding registers. The SPDIF transmitter generates a SPDIF output bitstream in the biphase mark format (IEC60958), which consists of audio data, channel status and user bits.

In the SPDIF transmitter, the IEC60958 biphase bit stream is generated on both edges of the SPDIF Transmit clock. The SPDIF Transmit clock is generated by the SPDIF internal clock generate block and the sources are from outside of the SPDIF block. For the SPDIF receiver, it can recover the SPDIF Rx clock. Figure 1 shows the clock structure of the SPDIF transceiver.

![Figure 40-2. SPDIF Transceiver Clock Diagram](image)

### 40.5.1 SPDIF Receiver

The SPDIF receiver extracts the audio data from each SPDIF frame and places the data in Rx left and right FIFOs.
The Tx left and right FIFOs are 16-deep and 24-bit-wide (equal to the audio data width). The Channel Status and User Bits are also extracted from each frame and placed in corresponding registers. The SPDIF receiver also provides a bypass option for direct transfer of the SPDIF input signal to the SPDIF transmitter.

The SPDIF receiver handles the main data audio stream and recovers the bit clock from the SPDIF input signal. The sample rate can be determined from the frequency measuring block. Additionally, the receiver supports the SPDIF C and U channels. The SPDIF C and U channel data is interfaced directly to memory-mapped registers.

All the data registers are controlled by the Interrupt Control Block and transferred to the memory-mapped IP bus.

The following functions are performed by the SPDIF receiver:

- Audio Data Reception see Audio Data Reception
- Channel Status bits Reception see Channel Status Reception
- U Channel bits Reception see User Bit Reception
- Validity Flag Reception see Validity Flag Reception
- SPDIF Receiver Exception support see SPDIF Receiver
- SPDIF Lock Detection

40.5.1.1 Audio Data Reception

The SPDIF Receiver block extracts the audio data from the IEC60958 stream, and outputs this via Rx left and right FIFOs to the memory-mapped registers SPDIFRxLeft and SPDIFRxRight.

Data from the SPDIF receiver is buffered in receive FIFO, and can be read by the processor from the memory-mapped registers.

- **SPDIF receiver data registers - Behavior on overrun, underrun**

The SPDIF Data Receive registers (SPDIFRxLeft and SPDIFRxRight) have individual FIFOs for left and right channel. As a result, there is always the possibility that left and right FIFOs may go out of sync due to FIFO underruns and FIFO overruns that affect only one part (left or right) of any FIFOs. To prevent this from happening, hardware has been added to the device. Two mechanisms to prevent mismatch between the FIFOs are available.
If a SPDIF Data Rx FIFO overrun occurs on e.g. the right half of the FIFO, the sample that caused the overrun is not written to the right half (due to overrun). Special hardware will make sure the next sample is not written to the left half of the FIFO. If the overrun occurs on the left half of the FIFO, the next sample is not written to the right half of the FIFO.

- **SPDIF receiver data registers - Automatic resynchronization of FIFOs**

An automatic FIFO resynchronization feature is available. It can be enabled and disabled separately for every FIFO. If it is enabled, the hardware will check to see if the left and right FIFOs are in sync. If that is not the case, it will set the filling pointer of the right FIFO to be equal to the filling pointer of the left FIFO.

![State Diagram](image)

**Figure 40-3. FIFO Auto-resync Controller State Machine**

The operation is explained from the state diagram shown above. Every FIFO auto-resync controller has a state machine with 3 states: Off, StandBy and On. In the On state, the filling of the left FIFO is compared with the filling of right, and if they are not equal, right is made equal to left, and an interrupt is generated.

The controller will stay in Off state when the feature is disabled. When not disabled, the state machine will go to Off state on any processor read or write to the FIFO. It will go from On or Off to Standby on any left sample read from SPDIF Tx FIFOs, or on any left sample write to SPDIF Rx FIFOs. The controller will go from Standby to On on any right.
sample read from SPDIF Tx FIFO, or on any right sample write to SPDIF Rx FIFO. There is a control bit in the SPDIFConfig register to enable/disable the feature for the SPDIF Rx FIFO and SPDIF Tx FIFO.

### 40.5.1.1.1 Application Note

The automatic FIFO resynchronization can be switched on, and will avoid all mismatches between left and right FIFOs, if the software obeys the following rules: 1. When the left data is read or written to the left FIFO, in the same place of the program, data must be read or written to the right FIFO. Maximum time difference between left and right is 1/2 sample clock. (E.g. if sample frequency is 44 Khz, approximately 10 micro-seconds. For 88 Khz, approximately 5 micro-seconds.) 2. Write/read data to FIFO s at least 2 samples at the time. If there is a mismatch Left-Right, the resync logic may go on only 1 sample clock after last data is read/written to the FIFO. Also acceptable is polling the FIFO, if at least part of the time 2 samples will be read/written to it.

- **SPDIF receiver - Additional features**

There are three exceptions associated with the SPDIF Receivers FIFOs

- full
- under/overrun
- resync

When the "full" condition is set for processor data input registers, the processor should read data from the FIFO, before overrun occurs. When "full" is set, and the FIFO contains e.g. 6 samples, it is acceptable for the software to read first 6 samples from the LEFT address, followed by 6 samples from the RIGHT address, or 6 samples from the RIGHT address, followed by 6 samples from the LEFT address, or 1 sample LEFT, followed by 1 sample RIGHT repeated 6 times. There is no order specified.

The implementation for SPDIF Rx is a double FIFO, one for left and one for right. "full" is set when both FIFOs are full. "underrun, overrun" are set when one of the FIFOs do underrun or do overrun. The resync interrupt means hardware took special action to resynchronize left and right FIFOs.

The FIFO level at which the "full" interrupt is generated, is programmable via the Full Select field in the SPDIFConfigReg register.

**Rx FIFO on and Rx FIFO reset.**

Two additional control fields of the SPDIF Rx FIFO are the on/off select and FIFO reset fields.

If on/off select is set to off, all-zero will be read from the FIFO, irrespective of the data received over the SPDIF interface.
If FIFO reset is set, the FIFO is blocked at "1 sample in FIFO". In this, the full interrupt will be on if FullSelect is set to "00". If FullSelect is set to any other value, interrupt will be off. The other interrupts are always off.

40.5.1.2  Channel Status Reception

A total of 48 channel status bits are received in two registers. No interpretation is performed by the SPDIF receiver block.

Channel Status Bits are ordered first bit left. CS-channel MSB bit "0" is located in bit position 23 in the memory-mapped register SPDIFRxCCChannel_h. CS-channel bit "23" is considered the LSB bit 0 in the register. C-channel bit 24 to 47 is seen as [23:0] bits of register SPDIFRxCCChannel_l.

40.5.1.2.1  Channel Status Interrupt

When the value of a new SPDIF "CS" channel status frame is loaded in the register, an interrupt is generated. The interrupt is cleared when the processor writes the corresponding bit in the InterruptStat register.

40.5.1.3  User Bit Reception

There are two modes for U Channel reception, CD and non-CD. As is decided by USyncMode (bit 1 of CDText_Control register).

- **Behavior of U Channel receive interface on incoming CD U Channel Sub-code in SPDIF receiver.**

This mode is selected if UsyncMode, bit 1 in register CD Text control is set "1".

The CD sub-code stream embedded into the SPDIF U channel consists of a sequence of packets. Every packet is made up 98 "symbols". The first two symbols of every packet are "sync symbols", the other 96 symbols are "data symbols".

Any sequence found in the SPDIF U channel stream starting with a leading one, followed by 7 information bits, is recognized as a "data symbol". Subsequent data symbols are separated by "pauses". During the "pause", "zero bits" are seen on the SPDIF U channel.

Data symbols are coming in MSB first. The MSB is the leading one.

When a "long pause" is seen between 2 subsequent "data symbols", the SPDIF receiver will assume the reception of one or more "sync symbols". Table below gives details.
<table>
<thead>
<tr>
<th>Number of U Channel zero bits</th>
<th>Corresponding number of sync symbols</th>
</tr>
</thead>
<tbody>
<tr>
<td>0-1</td>
<td>Unpredictable, not allowed</td>
</tr>
<tr>
<td>2-10</td>
<td>0</td>
</tr>
<tr>
<td>11-22</td>
<td>1</td>
</tr>
<tr>
<td>23-34</td>
<td>2</td>
</tr>
<tr>
<td>35-46</td>
<td>3</td>
</tr>
<tr>
<td>&gt;45</td>
<td>Unpredictable, not allowed</td>
</tr>
</tbody>
</table>

The recognition of the number of sync symbols derives from the fact that the U channel transmitter in the CD channel decoder will transmit one symbol on average every 12 SPDIF channel bits. On this average rate, there is a maximum tolerance of 5%.

The SPDIF receiver is tolerant of symbol errors. Due to the physical nature of the transmission of the data over the CD disc, not more than 1 out of any 5 consecutive user channel symbols may be in error. The error may cause a change in data value, which is not detected by this interface, or it may cause a data symbol to be seen as a sync symbol, or a sync symbol to be seen as a data symbol. However, not more than 1 out of any 5 consecutive user channel symbols should be affected in this way.

The SPDIF U channel circuitry recognizes the 98-symbol packet structure, and sends the 96 symbol payload to the processor application. The 96 symbol payload is transmitted to the processor via 2 registers:

- The SPDIFRxUChannel register. In this register, data is presented 3 symbols at the time to the processor. Every time 3 new valid symbols, received on the SPDIF U Channel are present, the UChannelRxFull interrupt is asserted. For one 98-symbol packet, 96 symbols are carried across SPDIFRxUChannel. To transfer all this data, 32 UChannelRxFull interrupts are generated.
- The QChannelReceive register. In this register, only the Q bit of the packet is accumulated. Operation is similar to UChannelReceive. Because only Q-bit is transferred, only 96 Q-bits are transferred for any 98-symbol packet. To transfer this data, 4 QChannelRxFull interrupts are generated. When QChannelRxFull occurs, it is coincident with UChannelRxFull. There is only one QChannelRxFull for every 8 UChannelRxFull. The convention is that most significant data is transmitted first, and is left-aligned in the registers.
- Timing regarding packet boundary is extracted by hardware. The last UChannelRxFull corresponding to a given packet should be coincident with the last QChannelRxFull. In this last U, Q channel interrupt, symbols 95-98 are received, Q channel bits 67-98. The interrupts are coincident with UQSyncFound, flagging last symbols of the current frame.
• When the start of the new packet is found before the current packet is complete (less than 98 symbols in the packet), the UQFrameError interrupt is set. The application software should read out UChannelReceive and QchannelReceive registers, discard the value, and assume the start of a new packet.

• As already said, packet sync extraction is tolerant for single-symbol errors. Packet sync detection is based on the recognition of the sequence data-sync-sync-data in the symbol stream, because this is the only syncing sequence that is not affected by single errors. If the sync symbols are not found 98 symbols after the previous occurrence, it is assumed to be destroyed by channel error, and a new sync symbols is interpolated.

• Normally, only data bytes are passed to the application software. Every databyte will have its most significant bit set. If sync symbols are passed to the application software, they are seen as all-zero symbols. Sync symbols can only end up in the data stream due to channel error.

• **Behavior of U Channel receive interface on incoming non-CD data.**

This mode is selected if UsyncMode, bit 1 in register CD Text control is set '0'.

In non-CD mode, the SPDIF U channel stream is recognized as a sequence of "data symbols". No packet recognition is done.

Any sequence found in the SPDIF U channel stream starting with a leading one, followed by 7 information bits, is recognized as a "data symbol". Subsequent data symbols are separated by "pauses". During the "pause", "zero bits" are seen on the SPDIF U channel.

3 consecutive data symbols seen in the SPDIF U Channel stream are grouped together into the SPDIFRxUChannel register. First symbol is left, last symbol is right aligned. When SPDIFRxUChannel contains 3 new data symbols, UChannelRxFull is asserted.

In this mode, the operation of QchannelRx and associated interrupt QchannelRxFull is reserved, undefined. And the operation of UQFrameError and UQSyncFound is also reserved, undefined.

The U channel is extracted, and output by the SPDIF Rx on SPDIFRxUChannel-Stream.

When incoming SPDIF data parity error or bit error is detected, and if the next SPDIF word for that channel is error-free, the SPDIF word in error is replaced with the average of the previous word and next word. When incoming SPDIF data parity error or bit error is detected, and the next SPDIF word is in error, the previous SPDIF word is repeated.
40.5.1.4 Validity Flag Reception

An interrupt is associated with the Validity flag. (interrupt 16 - SPDFValNoGood). This interrupt is set every time a frame is seen on the SPDIF interface with the validity bit set to "invalid".

40.5.1.5 SPDIF Receiver Interrupt Exception Definition

Several SPDIF exceptions can trigger an interrupt.

They are:

- Control Status channel change. Set when SPDIFRxChannel_1 register is updated. The register is updated for every new C-Channel received. The exception is reset on write to InterruptClear register.
- SPDIF Illegal Symbol. Set on reception of illegal symbol during SPDIF receive. Reset by writing register InterruptClear.
- SPDIF bit error. Set on reception of bit error. (Parity bit does not match). Reset on write to InterruptClear register.
- Receive data FIFO full. Set when SPDIF receive data FIFO is full.
- Receive data FIFO underrun/overrun. Set when there is a underrun/overrun on the SPDIF receive data FIFO.
- Receive data FIFO resynchronization. Set when a resynchronization event occurs on the SPDIF receive data FIFO.
- Receive U Channel buffer full. Set when next 24 bits of U channel code are available.
- Receive Q Channel buffer overrun. Set when Q channel buffer overrun.
- Receive U Channel buffer overrun. Set on U channel buffer overrun.
- Receive Q Channel buffer full. Set when next 24 bits of Q channel code are available.
- Receive UQ sync found. Set when UQ channel sync found.
- Receive UQ frame error. Set when UQ frame error found.

---

1. The SPDIF input is a bi-phase/mark modulated signal. The time between any two successive transitions of the SPDIF signal is always 1, 2 or 3 SPDIF symbol periods long. The SPDIF receiver will parse the stream, and split it in so-called symbols. It recognizes s1, s2 and s3 symbols, depending on the length of the symbols. Not all sequences of these symbols are allowed. To give an example, a sequence s2-s1-s1-s2 cannot occur in a no-error SPDIF signal. If the receiver finds such an illegal sequence, the illegal symbol interrupt is set. No corrective action is undertaken. When the interrupt occurs, this means that (a) The SPDIF signal is destroyed by noise (b) The SPDIF frequency changed.
40.5.1.6 Standards Compliance

The SPDIF interface is compatible with the Tech 3250-E standard of the European Broadcasting Union, except clause 6.3.3 and the IEC60958-3 Ed2 for relevant topics.

Supported input frequency range is 12 Khz up to 96 Khz. (fully compliant) and 96 Khz up to 176 Khz (Can interface with compliant SPDIF transmitter within same cabinet, making reasonable assumptions on jitter added due to interconnecting wire.)

Tolerated jitter on SPDIF input signals are 0.25 bit peak-peak for high frequencies. There is no jitter limit for low frequencies. The user channel extraction in CD mode is capable of coping with single-symbol errors, and still retrieve U channel frames on correct boundaries. This capability is required for reliable reception of CD-Text from some Philips CD channel decoders. This capability was deemed more important than compliance with the IEC60958 annex A.3 standard, and for this reason user channel reception is not compliant with IEC60958 annex A.3. However, the interface is capable to receive U channel inserted by a typical CD channel decoder. Also, in this case, it is more robust and tolerant for channel error than what is required by IEC60958 annex A.3.

40.5.1.7 SPDIF PLOCK Detection and Rxclk Output

Using the high speed system clock, the internal DPLL can extract the bit clock (advanced pulse) from the input bitstream. When this internal DPLL is locked, the LOCK bit of PhaseConfig Register will be set, and the SPDIF Lock output pin SPDIF_LOCK will be asserted.

After DPLL has locked, the pulses are generated, and the average pulse rate is 128 x the sampling frequency. (For a 44.1 Khz input sampling frequency, the average pulse rate = 128 x 44.1 Khz.) The pulse signal is used in the FreqMeas circuit to generate the frequency measurement result.

40.5.1.8 Measuring Frequency of SPDIF_RxClk

The internal DPLL can extract the bit clock (advanced plus) from the input bitstream. To do that, it is necessary to measure the frequency of the incoming signal in relationship with the system clock (BUS_CLK).

Associated with it are two registers, PhaseConfig and FreqMeas. The circuit will measure the frequency of the incoming clock as a function of the BUS_CLK. The circuit is a second-order filter. The output is a value represented by an unsigned number stored in the 24-bit FreqMeas register, giving the frequency of the source as a function of the BUS_CLK.
FreqMeas[23:0] = FreqMeas_CLK / BUS_CLK * 2^{10} * GAIN.

For example, if the GAIN is selected as 8*(2^{10}) (PhaseConfig[5:3] = 3'b011), the actual result
FreqMeas_CLK / BUS_CLK is equal to FreqMeas[23:0] / 2^{23}.

40.5.2  SPIDIF Transmitter

Audio data for the SPIDIF transmitter is provided by processor via the SPDIFTxLeft and SPDIFTxRight registers.

Clocking for SPIDIF transmitter is selected through a multiplexer from several clock sources (see TxClk_Source for clock source inputs). The SPIDIF transmitter clock source can be divided down as needed using Txclk_DF. The SPIDIF transmitter output can be chosen from either the SPIDIF transmitter block, directly from the SPIDIF receiver (via the output multiplexer), or disabled.

The SPIDIF transmitter generates a SPIDIF output bitstream in IEC60958 biphase mark format, consisting of audio data, channel status.

40.5.2.1  Audio Data Transmission

Audio data for the SPIDIF transmitter is provided by the processor via SPDIFTxLeft and SPDIFTxRight registers. They send audio data to Tx left and right FIFOs. The Tx left and right FIFOs are also 16-deep and 24-width (equal to the audio data width).

- **SPIDIF transmitter data registers - Behavior on overrun, underrun**

The SPIDIF Data Transmit registers (SPDIFTxLeft and SPDIFTxRight) have individual FIFOs for left and right channel. As a result, there is always the possibility that left and right FIFOs may go out of sync due to FIFO underruns and FIFO overruns that affect only one part (left or right) of any FIFO. To prevent this from happening, hardware has been added on the device. Two mechanisms to prevent mismatch between the FIFOs are available.

If SPIDIF Tx FIFO underruns on the right half of the FIFO, no sample leaves that FIFO (because it was already empty). Special hardware will make sure that the next sample read from the left FIFO will not leave the FIFO (no read strobe is generated). If the underrun occurs on the left half of the FIFO, next read strobe to the right FIFO is blocked.

- **SPIDIF transmitter data registers - Automatic resynchronization of FIFOs**
See Audio Data Reception.

- **SPDIFTxLeft, SPDIFTxRight details**

With SPDIF Tx FIFOs three exceptions are associated.

- empty
- under/overrun
- resync

When the empty condition is set for processor data output registers, the processor should write data to the FIFO, before underrun occurs. When empty is set and, for instance, 6 samples need to be written, it is acceptable for the software to write first 6 samples from the LEFT address, followed by 6 samples from the RIGHT address, or 1 sample LEFT, followed by 1 sample RIGHT repeated 6 times. Left should be written before right. The implementation of all data out FIFOs is a double FIFO, one for left and one for right. Empty is set when both FIFOs are empty. Underrun, overrun are set when one of the FIFOs do underrun or do overrun. Resync is set when the hardware resynchronizes left and right FIFOs.

On receiving underrun, overrun interrupt, synchronization between Left and Right words in the FIFOs may be lost. Synchronization will not be lost when the underrun or overrun comes from the IEC60958 side of the FIFO. If the processor reads or writes more data from, for example, left than from right, synchronization will be lost. If automatic resynchronization is enabled, and if the software obeys the rules to let this work, resynchronization will be automatic.

### 40.5.2.2 Channel Status Transmission

A total of 48 Consumer channel status bits are transmitted from two registers. Channel Status Bits are ordered first bit left.

CS-channel MSB bit "0" is located in bit position 23 in the memory-mapped register SPDIFTxCChannelCons_h. CS-channel bit "23" is considered bit 0 in the register. C-channel bits 24-47 are seen as MSB-LSB bits of register SPDIFTxCChannelCons_l.

### 40.5.2.3 Validity Flag Transmission

The validity bit setting is performed via bit 5 of the SPDIF_SCR register.

### 40.6 SPDIF Memory Map/Register Definition
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>4038_0000</td>
<td>SPDIF Configuration Register (SPDIF_SCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0400h</td>
<td>40.6.1/2037</td>
</tr>
<tr>
<td>4038_0004</td>
<td>CDText Control Register (SPDIF_SRCD)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>40.6.2/2039</td>
</tr>
<tr>
<td>4038_0008</td>
<td>PhaseConfig Register (SPDIF_SRPC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>40.6.3/2040</td>
</tr>
<tr>
<td>4038_000C</td>
<td>InterruptEn Register (SPDIF_SIE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>40.6.4/2041</td>
</tr>
<tr>
<td>4038_0010</td>
<td>InterruptStat Register (SPDIF_SIS)</td>
<td>32</td>
<td>R</td>
<td>0000_00002h</td>
<td>40.6.5/2043</td>
</tr>
<tr>
<td>4038_0010</td>
<td>InterruptClear Register (SPDIF_SIC)</td>
<td>32</td>
<td>W</td>
<td>0000_00000h</td>
<td>40.6.6/2045</td>
</tr>
<tr>
<td>4038_0014</td>
<td>SPDIFRxLeft Register (SPDIF_SRL)</td>
<td>32</td>
<td>R</td>
<td>0000_00000h</td>
<td>40.6.7/2046</td>
</tr>
<tr>
<td>4038_0018</td>
<td>SPDIFRxRight Register (SPDIF_SRR)</td>
<td>32</td>
<td>R</td>
<td>0000_00000h</td>
<td>40.6.8/2047</td>
</tr>
<tr>
<td>4038_001C</td>
<td>SPDIFRxCChannel_h Register (SPDIF_SRCSH)</td>
<td>32</td>
<td>R</td>
<td>0000_00000h</td>
<td>40.6.9/2047</td>
</tr>
<tr>
<td>4038_0020</td>
<td>SPDIFRxCChannel_l Register (SPDIF_SRCSL)</td>
<td>32</td>
<td>R</td>
<td>0000_00000h</td>
<td>40.6.10/2048</td>
</tr>
<tr>
<td>4038_0024</td>
<td>UchannelRx Register (SPDIF_SRU)</td>
<td>32</td>
<td>R</td>
<td>0000_00000h</td>
<td>40.6.11/2048</td>
</tr>
<tr>
<td>4038_0028</td>
<td>QchannelRx Register (SPDIF_SRQ)</td>
<td>32</td>
<td>R</td>
<td>0000_00000h</td>
<td>40.6.12/2049</td>
</tr>
<tr>
<td>4038_002C</td>
<td>SPDIFTxLeft Register (SPDIF_STL)</td>
<td>32</td>
<td>W</td>
<td>0000_00000h</td>
<td>40.6.13/2049</td>
</tr>
<tr>
<td>4038_0030</td>
<td>SPDIFTxRight Register (SPDIF_STR)</td>
<td>32</td>
<td>W</td>
<td>0000_00000h</td>
<td>40.6.14/2050</td>
</tr>
<tr>
<td>4038_0034</td>
<td>SPDIFTxCChannelCons_h Register (SPDIF_STCSCH)</td>
<td>32</td>
<td>R/W</td>
<td>0000_00000h</td>
<td>40.6.15/2050</td>
</tr>
<tr>
<td>4038_0038</td>
<td>SPDIFTxCChannelCons_l Register (SPDIF_STCSCL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_00000h</td>
<td>40.6.16/2051</td>
</tr>
<tr>
<td>4038_0044</td>
<td>FreqMeas Register (SPDIF_SRFM)</td>
<td>32</td>
<td>R</td>
<td>0000_00000h</td>
<td>40.6.17/2051</td>
</tr>
<tr>
<td>4038_0050</td>
<td>SPDIFTxClk Register (SPDIF_STC)</td>
<td>32</td>
<td>R/W</td>
<td>0002_0F00h</td>
<td>40.6.18/2052</td>
</tr>
</tbody>
</table>
### 40.6.1 SPDIF Configuration Register (SPDIF_SCR)

Address: 4038_0000h base + 0h offset = 4038_0000h

![SPDIF_SCR Diagram]

#### SPDIF_SCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>23</td>
<td>RxFIFO_Ctrl</td>
</tr>
<tr>
<td>0</td>
<td>Normal operation</td>
</tr>
<tr>
<td>1</td>
<td>Always read zero from Rx data register</td>
</tr>
<tr>
<td>22</td>
<td>RxFIFO_Off_On</td>
</tr>
<tr>
<td>0</td>
<td>SPDIF Rx FIFO is on</td>
</tr>
<tr>
<td>1</td>
<td>SPDIF Rx FIFO is off. Does not accept data from interface</td>
</tr>
<tr>
<td>21</td>
<td>RxFIFO_Rst</td>
</tr>
<tr>
<td>0</td>
<td>Normal operation</td>
</tr>
<tr>
<td>1</td>
<td>Reset register to 1 sample remaining</td>
</tr>
<tr>
<td>20–19</td>
<td>RxFIFOFull_Sel</td>
</tr>
<tr>
<td>00</td>
<td>Full interrupt if at least 1 sample in Rx left and right FIFOs</td>
</tr>
<tr>
<td>01</td>
<td>Full interrupt if at least 4 sample in Rx left and right FIFOs</td>
</tr>
<tr>
<td>10</td>
<td>Full interrupt if at least 8 sample in Rx left and right FIFOs</td>
</tr>
<tr>
<td>11</td>
<td>Full interrupt if at least 16 sample in Rx left and right FIFO</td>
</tr>
<tr>
<td>18</td>
<td>RxAutoSync</td>
</tr>
<tr>
<td>0</td>
<td>Rx FIFO auto sync off</td>
</tr>
<tr>
<td>1</td>
<td>Rx FIFO auto sync on</td>
</tr>
<tr>
<td>17</td>
<td>TxAutoSync</td>
</tr>
<tr>
<td>0</td>
<td>Tx FIFO auto sync off</td>
</tr>
<tr>
<td>1</td>
<td>Tx FIFO auto sync on</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### SPDIF_SCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16–15</td>
<td><strong>TxFIFOEmpty_Sel</strong></td>
</tr>
<tr>
<td>00</td>
<td>Empty interrupt if 0 sample in Tx left and right FIFOs</td>
</tr>
<tr>
<td>01</td>
<td>Empty interrupt if at most 4 sample in Tx left and right FIFOs</td>
</tr>
<tr>
<td>10</td>
<td>Empty interrupt if at most 8 sample in Tx left and right FIFOs</td>
</tr>
<tr>
<td>11</td>
<td>Empty interrupt if at most 12 sample in Tx left and right FIFOs</td>
</tr>
<tr>
<td>13</td>
<td><strong>LOWPOWER</strong></td>
</tr>
<tr>
<td></td>
<td>When write 1 to this bit, it will cause SPDIF enter low-power mode.</td>
</tr>
<tr>
<td></td>
<td>return 1 when SPDIF in Low-Power mode.</td>
</tr>
<tr>
<td>12</td>
<td><strong>soft_reset</strong></td>
</tr>
<tr>
<td></td>
<td>When write 1 to this bit, it will cause SPDIF software reset.</td>
</tr>
<tr>
<td></td>
<td>The software reset will last 8 cycles.</td>
</tr>
<tr>
<td></td>
<td>When in the reset process, return 1 when read.</td>
</tr>
<tr>
<td></td>
<td>else return 0 when read.</td>
</tr>
<tr>
<td>11–10</td>
<td><strong>TxFIFO_Ctrl</strong></td>
</tr>
<tr>
<td>00</td>
<td>Send out digital zero on SPDIF Tx</td>
</tr>
<tr>
<td>01</td>
<td>Tx Normal operation</td>
</tr>
<tr>
<td>10</td>
<td>Reset to 1 sample remaining</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td><strong>DMA_Rx_En</strong></td>
</tr>
<tr>
<td></td>
<td>DMA Receive Request Enable (RX FIFO full)</td>
</tr>
<tr>
<td>8</td>
<td><strong>DMA_TX_En</strong></td>
</tr>
<tr>
<td></td>
<td>DMA Transmit Request Enable (Tx FIFO empty)</td>
</tr>
<tr>
<td>7–6</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td><strong>ValCtrl</strong></td>
</tr>
<tr>
<td>0</td>
<td>Outgoing Validity always set</td>
</tr>
<tr>
<td>1</td>
<td>Outgoing Validity always clear</td>
</tr>
<tr>
<td>4–2</td>
<td><strong>TxSel</strong></td>
</tr>
<tr>
<td>000</td>
<td>Off and output 0</td>
</tr>
<tr>
<td>001</td>
<td>Feed-through SPDFIN</td>
</tr>
<tr>
<td>101</td>
<td>Tx Normal operation</td>
</tr>
<tr>
<td>Others</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>No embedded U channel</td>
</tr>
<tr>
<td>1</td>
<td>U channel from SPDIF receive block (CD mode)</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>U channel from on chip transmitter</td>
</tr>
</tbody>
</table>
### 40.6.2 CDText Control Register (SPDIF_SRCD)

Address: 4038_0000h base + 4h offset = 4038_0004h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented. This field is reserved.</td>
</tr>
<tr>
<td>23–15 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 -</td>
<td>This field is reserved. Reserved. set to zero.</td>
</tr>
<tr>
<td>7–3 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>2 -</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>1 USyncMode</td>
<td>0 Non-CD data 1 CD user channel subcode</td>
</tr>
<tr>
<td>0 -</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>
40.6.3 PhaseConfig Register (SPDIF_SRPC)

Address: 4038_0000h base + 8h offset = 4038_0008h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–24</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>[unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>23–11</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>10–7</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>ClkSrc_Sel</td>
<td>Clock source selection, all other settings not shown are reserved:</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>0000 if (DPLL Locked) SPDIF_RxClk else REF_CLK_32K (XTALOSC)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0001 if (DPLL Locked) SPDIF_RxClk else tx_clk (SPDIF0_CLK_ROOT)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0011 if (DPLL Locked) SPDIF_RxClk else SPDIF_EXT_CLK</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0101 REF_CLK_32K (XTALOSC)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0110 tx_clk (SPDIF0_CLK_ROOT)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1000 SPDIF_EXT_CLK</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>6</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>LOCK</td>
<td>LOCK bit to show that the internal DPLL is locked, read only</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>5–3</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>GainSel</td>
<td>Gain selection:</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>000 24*(2**10)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>001 16*(2**10)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### SPDIF_SRPC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>$12 \times 2^{10}$</td>
</tr>
<tr>
<td>011</td>
<td>$8 \times 2^{10}$</td>
</tr>
<tr>
<td>100</td>
<td>$6 \times 2^{10}$</td>
</tr>
<tr>
<td>101</td>
<td>$4 \times 2^{10}$</td>
</tr>
<tr>
<td>110</td>
<td>$3 \times 2^{10}$</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

#### 40.6.4 InterruptEn Register (SPDIF_SIE)

The InterruptEn register (SPDIF_SIE) provides control over the enabling of interrupts.

Address: 4038_0000h base + Ch offset = 4038_000Ch

![InterruptEn Register Diagram]

### SPDIF_SIE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented. This field is reserved.</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22–21</td>
<td>-</td>
</tr>
<tr>
<td>20</td>
<td>Lock</td>
</tr>
<tr>
<td>19</td>
<td>TxUnOv</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>18</td>
<td>TxResyn</td>
</tr>
<tr>
<td>17</td>
<td>CNew</td>
</tr>
<tr>
<td>16</td>
<td>ValNoGood</td>
</tr>
<tr>
<td>15</td>
<td>SymErr</td>
</tr>
<tr>
<td>14</td>
<td>BitErr</td>
</tr>
<tr>
<td>13–11</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>URxFul</td>
</tr>
<tr>
<td>9</td>
<td>URxOv</td>
</tr>
<tr>
<td>8</td>
<td>QRxFul</td>
</tr>
<tr>
<td>7</td>
<td>QRxOv</td>
</tr>
<tr>
<td>6</td>
<td>UQSync</td>
</tr>
<tr>
<td>5</td>
<td>UQErr</td>
</tr>
<tr>
<td>4</td>
<td>RxFIFOUnOv</td>
</tr>
<tr>
<td>3</td>
<td>RxFIFOResyn</td>
</tr>
<tr>
<td>2</td>
<td>LockLoss</td>
</tr>
<tr>
<td>1</td>
<td>TxEm</td>
</tr>
<tr>
<td>0</td>
<td>RxFIFOFul</td>
</tr>
</tbody>
</table>
40.6.5 InterruptStat Register (SPDIF_SIS)

The InterruptStat (SPDIF_SIS) register is a read only register that provides the status on interrupt operations.

Address: 4038_0000h base + 10h offset = 4038_0010h
### SPDIF_SIS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented. This field is reserved.</td>
</tr>
<tr>
<td>23–21 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>20 Lock</td>
<td>SPDIF receiver's DPLL is locked</td>
</tr>
<tr>
<td>19 TxUnOv</td>
<td>SPDIF Tx FIFO under/overrun</td>
</tr>
<tr>
<td>18 TxResyn</td>
<td>SPDIF Tx FIFO resync</td>
</tr>
<tr>
<td>17 CNew</td>
<td>SPDIF receive change in value of control channel</td>
</tr>
<tr>
<td>16 ValNoGood</td>
<td>SPDIF validity flag no good</td>
</tr>
<tr>
<td>15 SymErr</td>
<td>SPDIF receiver found illegal symbol</td>
</tr>
<tr>
<td>14 BitErr</td>
<td>SPDIF receiver found parity bit error</td>
</tr>
<tr>
<td>13–11 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>10 URxFul</td>
<td>U Channel receive register full, can't be cleared with reg. IntClear. To clear it, read from U Rx reg.</td>
</tr>
<tr>
<td>9 URxOv</td>
<td>U Channel receive register overrun</td>
</tr>
<tr>
<td>8 QRxFul</td>
<td>Q Channel receive register full, can't be cleared with reg. IntClear. To clear it, read from Q Rx reg.</td>
</tr>
<tr>
<td>7 QRxOv</td>
<td>Q Channel receive register overrun</td>
</tr>
<tr>
<td>6 UQSync</td>
<td>U/Q Channel sync found</td>
</tr>
<tr>
<td>5 UQErr</td>
<td>U/Q Channel framing error</td>
</tr>
<tr>
<td>4 RxFIFOUnOv</td>
<td>Rx FIFO underrun/overrun</td>
</tr>
<tr>
<td>3 RxFIFOResyn</td>
<td>Rx FIFO resync</td>
</tr>
<tr>
<td>2 LockLoss</td>
<td>SPDIF receiver loss of lock</td>
</tr>
<tr>
<td>1 TxEm</td>
<td>SPDIF Tx FIFO empty, can't be cleared with reg. IntClear. To clear it, write to Tx FIFO.</td>
</tr>
<tr>
<td>0 RxFIFOFul</td>
<td>SPDIF Rx FIFO full, can't be cleared with reg. IntClear. To clear it, read from Rx FIFO.</td>
</tr>
</tbody>
</table>

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

2044

NXP Semiconductors
40.6.6 InterruptClear Register (SPDIF_SIC)

The InterruptClear (SPDIF_SIC) register is a write only register and is used to clear interrupts.

Address: 4038_0000h base + 10h offset = 4038_0010h

![Diagram of InterruptClear Register (SPDIF_SIC)]

### SPDIF_SIC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–24 [unimplemented] | This is a 24-bit register the upper byte is unimplemented.  
This field is reserved. |
| 23–21 Reserved | This read-only field is reserved and always has the value 0. |
| 20 Lock      | SPDIF receiver’s DPLL is locked                  |
| 19 TxUnOv    | SPDIF Tx FIFO under/overrun                     |

Table continues on the next page...
### SPDIFF_SIC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>18</td>
<td>TxResyn</td>
</tr>
<tr>
<td>17</td>
<td>CNew</td>
</tr>
<tr>
<td>16</td>
<td>ValNoGood</td>
</tr>
<tr>
<td>15</td>
<td>SymErr</td>
</tr>
<tr>
<td>14</td>
<td>BitErr</td>
</tr>
<tr>
<td>13–10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>URxOv</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>QRxOv</td>
</tr>
<tr>
<td>6</td>
<td>UQSync</td>
</tr>
<tr>
<td>5</td>
<td>UQErr</td>
</tr>
<tr>
<td>4</td>
<td>RxFIFOUnOv</td>
</tr>
<tr>
<td>3</td>
<td>RxFIFOResyn</td>
</tr>
<tr>
<td>2</td>
<td>LockLoss</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

#### 40.6.7  SPDIFFRxLeft Register (SPDIFF_SRL)

SPDIFFRxLeft register is an audio data reception register.

Address: 4038_0000h base + 14h offset = 4038_0014h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
## SPDIF_SRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>RxDataLeft</td>
<td>Processor receive SPDIF data left</td>
</tr>
</tbody>
</table>

## 40.6.8 SPDIFRxRight Register (SPDIF_SRR)

SPDIFRxRight register is an audio data reception register.

Address: 4038_0000h base + 18h offset = 4038_0018h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

## SPDIF_SRR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>RxDataRight</td>
<td>Processor receive SPDIF data right</td>
</tr>
</tbody>
</table>

## 40.6.9 SPDIFRxCChannel_h Register (SPDIF_SRCSH)

SPDIFRxCChannel_h register is a channel status reception register.

Address: 4038_0000h base + 1Ch offset = 4038_001Ch

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

## SPDIF_SRCSH field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
SPDIF Memory Map/Register Definition

SPDIF_SRCSH field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>This field is reserved.</td>
<td></td>
</tr>
<tr>
<td>RxCChannel_h</td>
<td>SPDIF receive C channel register, contains first 24 bits of C channel without interpretation</td>
</tr>
</tbody>
</table>

40.6.10 SPDIFRxCChannel_l Register (SPDIF_SRCSL)

SPDIFRxCChannel_l register is a channel status reception register.

Address: 4038_0000h base + 20h offset = 4038_0020h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

SPDIF_SRCSL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td>This field is reserved.</td>
<td></td>
</tr>
<tr>
<td>RxCChannel_l</td>
<td>SPDIF receive C channel register, contains next 24 bits of C channel without interpretation</td>
</tr>
</tbody>
</table>

40.6.11 UChannelRx Register (SPDIF_SRU)

UChannelRx register is a user bits reception register.

Address: 4038_0000h base + 24h offset = 4038_0024h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

SPDIF_SRU field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td>This field is reserved.</td>
<td></td>
</tr>
<tr>
<td>RxUChannel</td>
<td>SPDIF receive U channel register, contains next 3 U channel bytes</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
40.6.12 QchannelRx Register (SPDIF_SRQ)

QChannelRx register is a user bits reception register.

Address: 4038_0000h base + 28h offset = 4038_0028h

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**SPDIF_SRQ field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>RxQChannel</td>
<td>SPDIF receive Q channel register, contains next 3 Q channel bytes</td>
</tr>
</tbody>
</table>

40.6.13 SPDIFTxLeft Register (SPDIF_STL)

SPDIFTxLeft register is an audio data transmission register.

Address: 4038_0000h base + 2Ch offset = 4038_002Ch

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**SPDIF_STL field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24 [unimplemented]</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td>TxDataLeft</td>
<td>SPDIF transmit left channel data. It is write-only, and always returns zeros when read</td>
</tr>
</tbody>
</table>
40.6.14  SPDIFTxRight Register (SPDIF_STR)

SPDIFTxRight register is an audio data transmission register.

Address: 4038_0000h base + 30h offset = 4038_0030h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**SPDIF_STR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>[unimplemented]</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td>TxDataRight</td>
<td>SPDIF transmit right channel data. It is write-only, and always returns zeros when read</td>
</tr>
</tbody>
</table>

40.6.15  SPDIFTxCChannelCons_h Register (SPDIF_STCSCH)

SPDIFTxCChannelCons_h register is a channel status transmission register.

Address: 4038_0000h base + 34h offset = 4038_0034h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

**SPDIF_STCSCH field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td>[unimplemented]</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>TxCChannelCons_h</td>
<td>SPDIF transmit Cons. C channel data, contains first 24 bits without interpretation. When read, it returns the latest data written by the processor</td>
</tr>
</tbody>
</table>
40.6.16 SPDIFTxCChannelCons_l Register (SPDIF_STCSCL)

SPDIFTxCChannelCons_l register is a channel status transmission register.

Address: 4038_0000h base + 38h offset = 4038_0038h

<table>
<thead>
<tr>
<th>Bit 31-24 [unimplemented]</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td>TxCChannelCons_l</td>
<td>SPDIF transmit Cons. C channel data, contains next 24 bits without interpretation. When read, it returns the latest data written by the processor</td>
</tr>
</tbody>
</table>

40.6.17 FreqMeas Register (SPDIF_SRFM)

Address: 4038_0000h base + 44h offset = 4038_0044h

<table>
<thead>
<tr>
<th>Bit 31-24 [unimplemented]</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td>FreqMeas</td>
<td>Frequency measurement data</td>
</tr>
</tbody>
</table>
### 40.6.18 SPDIFTxClk Register (SPDIF_STC)

The SPDIFTxClk Control register includes the means to select the transmit clock and frequency division.

Address: 4038_0000h base + 50h offset = 4038_0050h

#### SPDIF_STC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This is a 24-bit register the upper byte is unimplemented.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>23–20</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>19–11</td>
<td>system clock divider factor, 2–512.</td>
</tr>
<tr>
<td>SYSCLK_DF</td>
<td>0 no clock signal</td>
</tr>
<tr>
<td></td>
<td>1 divider factor is 2</td>
</tr>
<tr>
<td></td>
<td>...</td>
</tr>
<tr>
<td></td>
<td>511 divider factor is 512</td>
</tr>
<tr>
<td>10–8</td>
<td>TxClk_Source</td>
</tr>
<tr>
<td>000</td>
<td>000 XTAŁOSC input (XTALOSC clock)</td>
</tr>
<tr>
<td>001</td>
<td>001 tx_clk input (from SPDIF0_CLK_ROOT. See CCM.)</td>
</tr>
<tr>
<td>010</td>
<td>010 tx_clk1 (from SAI1)</td>
</tr>
<tr>
<td>011</td>
<td>011 tx_clk2 SPDIF_EXT_CLK, from pads</td>
</tr>
<tr>
<td>100</td>
<td>100 tx_clk3 (from SAI2)</td>
</tr>
<tr>
<td>101</td>
<td>101 ipg_clk input (frequency divided)</td>
</tr>
<tr>
<td>110</td>
<td>110 tx_clk4 (from SAI3)</td>
</tr>
<tr>
<td>7</td>
<td>tx_all_clk_en</td>
</tr>
<tr>
<td></td>
<td>Spdif transfer clock enable. When data is going to be transfered, this bit should be set to 1.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### SPDIF_STC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>disable transfer clock.</td>
</tr>
<tr>
<td>1</td>
<td>enable transfer clock.</td>
</tr>
<tr>
<td>TxClk_DF</td>
<td>Divider factor (1-128)</td>
</tr>
<tr>
<td>0</td>
<td>divider factor is 1</td>
</tr>
<tr>
<td>1</td>
<td>divider factor is 2</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>127</td>
<td>divider factor is 128</td>
</tr>
</tbody>
</table>
Chapter 41
10/100 /1000 -Mbps Ethernet MAC (ENET)

41.1 Chip-specific ENET information

Table 41-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

41.2 Introduction

The MAC-NET core, in conjunction with a 10/100-Mbit/s MAC, implements layer 3 network acceleration functions. These functions are designed to accelerate the processing of various common networking protocols, such as IP, TCP, UDP, and ICMP, providing wire speed services to client applications.

41.3 Overview

The core implements a dual-speed 10/100-Mbit/s Ethernet MAC compliant with the IEEE802.3-2002 standard. The MAC layer provides compatibility with half- or full-duplex 10/100-Mbit/s Ethernet LANs.
The MAC operation is fully programmable and can be used in Network Interface Card (NIC), bridging, or switching applications. The core implements the remote network monitoring (RMON) counters according to IETF RFC 2819.

The core also implements a hardware acceleration block to optimize the performance of network controllers providing TCP/IP, UDP, and ICMP protocol services. The acceleration block performs critical functions in hardware, which are typically implemented with large software overhead.

The core implements programmable embedded FIFOs that can provide buffering on the receive path for lossless flow control.

Advanced power management features are available with magic packet detection and programmable power-down modes.

A unified DMA (uDMA), internal to the ENET module, optimizes data transfer between the ENET core and the SoC, and supports an enhanced buffer descriptor programming model to support IEEE 1588 functionality.

The programmable Ethernet MAC with IEEE 1588 integrates a standard IEEE 802.3 Ethernet MAC with a time-stamping module. The IEEE 1588 standard provides accurate clock synchronization for distributed control nodes for industrial automation applications.

### 41.3.1 Features

The MAC-NET core includes the following features.

#### 41.3.1.1 Ethernet MAC features

- Implements the full 802.3 specification with preamble/SFD generation, frame padding generation, CRC generation and checking
- Supports zero-length preamble
- Dynamically configurable to support 10/100-Mbit/s operation
- Supports 10/100 Mbit/s full-duplex and configurable half-duplex operation
- Compliant with the AMD magic packet detection with interrupt for node remote power management
- Seamless interface to commercial ethernet PHY devices via one of the following:
  - a 4-bit Media Independent Interface (MII) operating at 2.5/25 MHz.
  - a 4-bit non-standard MII-Lite (MII without the CRS and COL signals) operating at 2.5/25 MHz.
  - a 2-bit Reduced MII (RMII) operating at 50 MHz.
- Simple 64-Bit FIFO user-application interface
- CRC-32 checking at full speed with optional forwarding of the frame check sequence (FCS) field to the client
- CRC-32 generation and append on transmit or forwarding of user application provided FCS selectable on a per-frame basis
- In full-duplex mode:
  - Implements automated pause frame (802.3 x31A) generation and termination, providing flow control without user application intervention
  - Pause quanta used to form pause frames — dynamically programmable
  - Pause frame generation additionally controllable by user application offering flexible traffic flow control
  - Optional forwarding of received pause frames to the user application
  - Implements standard flow-control mechanism
- In half-duplex mode: provides full collision support, including jamming, backoff, and automatic retransmission
- Supports VLAN-tagged frames according to IEEE 802.1Q
- Programmable MAC address: Insertion on transmit; discards frames with mismatching destination address on receive (except broadcast and pause frames)
- Programmable promiscuous mode support to omit MAC destination address checking on receive
- Multicast and unicast address filtering on receive based on 64-entry hash table, reducing higher layer processing load
- Programmable frame maximum length providing support for any standard or proprietary frame length
- Statistics indicators for frame traffic and errors (alignment, CRC, length) and pause frames providing for IEEE 802.3 basic and mandatory management information database (MIB) package and remote network monitoring (RFC 2819)
- Simple handshake user application FIFO interface with fully programmable depth and threshold levels
- Provides separate status word for each received frame on the user interface providing information such as frame length, frame type, VLAN tag, and error information
- Multiple internal loopback options
- MDIO master interface for PHY device configuration and management supports two programmable MDIO base addresses, and standard (IEEE 802.3 Clause 22) and extended (Clause 45) MDIO frame formats
- Supports legacy FEC buffer descriptors
- Interrupt coalescing reduces the number of interrupts generated by the MAC, reducing CPU loading
41.3.1.2  **IP protocol performance optimization features**

- Operates on TCP/IP and UDP/IP and ICMP/IP protocol data or IP header only
- Enables wire-speed processing
- Supports IPv4 and IPv6
- Transparent passing of frames of other types and protocols
- Supports VLAN tagged frames according to IEEE 802.1q with transparent forwarding of VLAN tag and control field
- Automatic IP-header and payload (protocol specific) checksum calculation and verification on receive
- Automatic IP-header and payload (protocol specific) checksum generation and automatic insertion on transmit configurable on a per-frame basis
- Supports IP and TCP, UDP, ICMP data for checksum generation and checking
- Supports full header options for IPv4 and TCP protocol headers
- Provides IPv6 support to datagrams with base header only — datagrams with extension headers are passed transparently unmodified/unchecked
- Provides statistics information for received IP and protocol errors
- Configurable automatic discard of erroneous frames
- Configurable automatic host-to-network (RX) and network-to-host (TX) byte order conversion for IP and TCP/UDP/ICMP headers within the frame
- Configurable padding remove for short IP datagrams on receive
- Configurable Ethernet payload alignment to allow for 32-bit word-aligned header and payload processing
- Programmable store-and-forward operation with clock and rate decoupling FIFOs

41.3.1.3  **IEEE 1588 features**

- Supports all IEEE 1588 frames.
- Allows reference clock to be chosen independently of network speed.
- Software-programmable precise time-stamping of ingress and egress frames
- Timer monitoring capabilities for system calibration and timing accuracy management
- Precise time-stamping of external events with programmable interrupt generation
- Programmable event and interrupt generation for external system control
- Supports hardware- and software-controllable timer synchronization.
- Provides a 4-channel IEEE 1588 timer. Each channel supports input capture and output compare using the 1588 counter.

### 41.3.2 Block diagram

![Ethernet MAC-NET core block diagram](image)

**Figure 41-1. Ethernet MAC-NET core block diagram**
41.4 External Signals

The table found here describes the external signals of ENET.

Table 41-2. ENET External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_MDC</td>
<td>Output clock provides a timing reference to the PHY for data transfers on the MDIO signal.</td>
<td>MII/RMII</td>
<td>GPIO_B1_14</td>
<td>ALT0</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_AD_B1_04</td>
<td>ALT1</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_EMC_40</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>ENET_MDIO</td>
<td>Transfers control information between the external PHY and the media-access controller. Data is synchronous to MDC. This signal is an input after reset.</td>
<td>MII/RMII</td>
<td>GPIO_B1_15</td>
<td>ALT0</td>
<td>IO</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_AD_B1_05</td>
<td>ALT1</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_EMC_41</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>ENET_TX_DATA0</td>
<td>Serial output Ethernet data. Only valid during TX_EN assertion.</td>
<td>MII/RMII</td>
<td>GPIO_B1_07</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_EMC_22</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>ENET_TX_DATA1</td>
<td>Serial output Ethernet data. Only valid during TX_EN assertion.</td>
<td>MII/RMII</td>
<td>GPIO_EMC_21</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_B1_08</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td>ENET_TX_DATA2</td>
<td>Serial output Ethernet data. Only valid during TX_EN assertion.</td>
<td>MII</td>
<td>GPIO_AD_B0_05</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td>ENET_TX_DATA3</td>
<td>Serial output Ethernet data. Only valid during TX_EN assertion.</td>
<td>MII</td>
<td>GPIO_AD_B0_04</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td>ENET_TX_ER</td>
<td>When asserted for one or more clock cycles while TXEN is also asserted, PHY sends one or more illegal symbols.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B0_07</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td>ENET_TX_EN</td>
<td>Indicates when valid nibbles are present on the MII. This signal is asserted with the first nibble of a preamble and is</td>
<td>MII/RMII</td>
<td>GPIO_B1_09</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_EMC_24</td>
<td>ALT3</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_TX_CLK</td>
<td>deasserted before the first TX_CLK following the final nibble of the frame.</td>
<td>MII</td>
<td>GPIO_B1_10</td>
<td>ALT3</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_EM_25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_RX_DATA0</td>
<td>Contains the Ethernet input data transferred from the PHY to the media-</td>
<td>MII/RMII</td>
<td>GPIO_EM_20</td>
<td>ALT3</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td>access controller when RX_EN is asserted.</td>
<td></td>
<td>GPIO_B1_04</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_RX_DATA1</td>
<td>Contains the Ethernet input data transferred from the PHY to the media-</td>
<td>MII/RMII</td>
<td>GPIO_EM_19</td>
<td>ALT3</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td>access controller when RX_EN is asserted.</td>
<td></td>
<td>GPIO_B1_05</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_RX_DATA2</td>
<td>Contains the Ethernet input data transferred from the PHY to the media-</td>
<td>MII</td>
<td>GPIO_AD_B0_09</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td>access controller when RX_EN is asserted.</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_RX_DATA3</td>
<td>Contains the Ethernet input data transferred from the PHY to the media-</td>
<td>MII</td>
<td>GPIO_AD_B0_08</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td>access controller when RX_EN is asserted.</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_RX_ER</td>
<td>When asserted with RXDV, indicates the PHY detects an error in the current frame.</td>
<td>MII/RMII</td>
<td>GPIO_B1_11</td>
<td>ALT3</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_EM_26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_RX_EN</td>
<td>Asserting this input indicates the PHY has valid nibbles present on the MII. RX_EN must remain asserted from the first recovered nibble of the frame through to the last nibble.</td>
<td>MII/RMII</td>
<td>GPIO_EM_23</td>
<td>ALT3</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_B1_06</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 41-2. ENET External Signals (continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_RX_CLK</td>
<td>Asserting RX_EN must start no later than the SFD and exclude any EOF. In RMII mode, this pin also generates the CRS signal.</td>
<td>MII</td>
<td>GPIO_AD_B0_06</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>ENET_CRC</td>
<td>Carrier sense. When asserted, indicates transmit or receive medium is not idle. In RMII mode, this signal is present on the RMII_CRS_DV pin.</td>
<td>MII</td>
<td>GPIO_AD_B0_10</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>ENET_COL</td>
<td>Asserted upon detection of a collision and remains asserted while the collision persists. This signal is not defined for full duplex mode.</td>
<td>MII</td>
<td>GPIO_AD_B0_11</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td>ENET_REF_CLK</td>
<td>In RMII mode, this signal is the reference clock for receive, transmit, and the control interface.</td>
<td>RMII</td>
<td>GPIO_EMC_25</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_B1_10</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td>ENET_1588_EVEN</td>
<td>Capture/compare block input/output event bus signal. When configured for capture and a rising edge is detected, the current timer value is latched and transferred into the corresponding ENET_TCCRn</td>
<td>MII/RMII</td>
<td>GPIO_AD_B0_14</td>
<td>ALT3</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_AD_B0_10</td>
<td>ALT7</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_B1_13</td>
<td>ALT3</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 41-2. ENET External Signals (continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_1588_EVENT</td>
<td>register for inspection by software. When configured for compare, the corresponding signal 1588_EVENT is asserted for one cycle when the timer reaches the compare value programmed in register ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TD_RE] is set. ENET_1588_EVENT T0_OUT has a programmable output width, see IOMUXC_GPR0[C LK_STRETCH], delayed one clock cycle in relation to all other EVENTx_OUT signals.</td>
<td></td>
<td>GPIO_AD_B0_15 ALT3 I</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_1588_EVEN T0_IN</td>
<td>Capture/compare block input/output event bus signal. When configured for capture and a rising edge is detected, the current timer value is latched and transferred into the corresponding ENET_TCCRn register for inspection by software. When configured for compare, the corresponding signal 1588_EVENT is asserted for one cycle.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B0_15 ALT3 I</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_AD_B0_11 ALT7</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>GPIO_B1_12 ALT3</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>cycle when the timer reaches the compare value programmed in register ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TDR] is set.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B0_12</td>
<td>ALT6</td>
<td>O</td>
<td></td>
</tr>
<tr>
<td>ENET_1588_EVEN T1_OUT</td>
<td>Capture/compare block input/output event bus signal. When configured for capture and a rising edge is detected, the current timer value is latched and transferred into the corresponding ENET_TCCRn register for inspection by software. When configured for compare, the corresponding signal 1588_EVENT is asserted for one cycle when the timer reaches the compare value programmed in register ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TDR] is set.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B0_13</td>
<td>ALT6</td>
<td>I</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_1588_EVT</td>
<td>Capture/compare block input/output event bus signal. When configured for capture and a rising edge is detected, the current timer value is latched and transferred into the corresponding ENET_TCCRn register for inspection by software. When configured for compare, the corresponding signal 1588_EVENT is asserted for one cycle when the timer reaches the compare value programmed in register ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TD RE] is set.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B1_02</td>
<td>ALT4</td>
<td>O</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TD RE] is set.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B1_03</td>
<td>ALT4</td>
<td>I</td>
<td></td>
</tr>
<tr>
<td>ENET_1588_EVEN T2_IN</td>
<td>Capture/compare block input/output event bus signal. When configured for capture and a rising edge is detected, the current timer value is latched and transferred into the corresponding ENET_TCCRn register for inspection by software. When configured for compare, the corresponding signal 1588_EVENT is asserted for one cycle when the timer reaches the compare value programmed in register ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TD RE] is set.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B1_03</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td>ENET_1588_EVEN T3_OUT</td>
<td>Capture/compare block input/output event bus signal. When configured for capture and a rising edge is detected, the current timer value is latched and transferred into the corresponding</td>
<td>MII/RMII</td>
<td>GPIO_AD_B0_07</td>
<td>ALT7</td>
<td>O</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 41-2. ENET External Signals (continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_TCCRn</td>
<td>register for inspection by software. When configured for compare, the corresponding signal 1588_EVENT is asserted for one cycle when the timer reaches the compare value programmed in register ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TD RE] is set.</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ENET_1588 Evan</td>
<td>Capture/compare block input/output event bus signal. When configured for capture and a rising edge is detected, the current timer value is latched and transferred into the corresponding ENET_TCCRn register for inspection by software. When configured for compare, the corresponding signal 1588_EVENT is asserted for one cycle when the timer reaches the compare value programmed in register ENET_TCCRn. An interrupt or DMA request can be triggered if the corresponding bit in ENET_TCSRn[TIE] or ENET_TCSRn[TD RE] is set.</td>
<td>MII/RMII</td>
<td>GPIO_AD_B0_08</td>
<td>ALT7</td>
<td>I</td>
</tr>
</tbody>
</table>
Table 41-2. ENET External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Mode</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET_TCSRn[TIE]</td>
<td>or ENET_TCSRn[TD RE] is set.</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

41.5 Clocks

The table found here describes the clock sources for ENET. Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

Table 41-3. ENET Clocks

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Module clock</td>
</tr>
<tr>
<td>ipg_clk_mac0</td>
<td>ipg_clk_root</td>
<td>MAC peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_mac0_s</td>
<td>ipg_clk_root</td>
<td>MAC peripheral access clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
<tr>
<td>ipg_clk_time</td>
<td>ref_enetpll2_clk</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>mem_mac0_mem_clk</td>
<td>ipg_clk_root</td>
<td>MAC memory clock</td>
</tr>
</tbody>
</table>

41.6 Memory map/register definition

ENET registers must be read or written with 32-bit accesses. Non-32 bit accesses will terminate with an error.

Reserved bits should be written with 0 and ignored on read. Unused registers read zero and a write has no effect.

This table shows Ethernet registers organization.

Table 41-4. Register map summary

<table>
<thead>
<tr>
<th>Offset Address</th>
<th>Section</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0000 – 0x01FF</td>
<td>Configuration</td>
<td>Core control and status registers</td>
</tr>
<tr>
<td>0x0200 – 0x03FF</td>
<td>Statistics counters</td>
<td>MIB and Remote Network Monitoring (RFC 2819) registers</td>
</tr>
<tr>
<td>0x0400 – 0x0430</td>
<td>1588 control</td>
<td>1588 adjustable timer (TSM) and 1588 frame control</td>
</tr>
<tr>
<td>0x0600 – 0x07FC</td>
<td>Capture/Compare block</td>
<td>Registers for the Capture/Compare block</td>
</tr>
<tr>
<td>Absolute address (hex)</td>
<td>Register name</td>
<td>Width (in bits)</td>
</tr>
<tr>
<td>------------------------</td>
<td>----------------------------------------</td>
<td>-----------------</td>
</tr>
<tr>
<td>402D_4004</td>
<td>Interrupt Event Register (ENET2_EIR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4008</td>
<td>Interrupt Mask Register (ENET2_EIMR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4010</td>
<td>Receive Descriptor Active Register (ENET2_RDAR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4014</td>
<td>Transmit Descriptor Active Register (ENET2 TDAR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4024</td>
<td>Ethernet Control Register (ENET2_ECR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4040</td>
<td>MII Management Frame Register (ENET2_MMFR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4044</td>
<td>MII Speed Control Register (ENET2_MSCR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4064</td>
<td>MIB Control Register (ENET2_MIBC)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4084</td>
<td>Receive Control Register (ENET2_RCR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_40C4</td>
<td>Transmit Control Register (ENET2_TCR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_40E4</td>
<td>Physical Address Lower Register (ENET2_PALR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_40E8</td>
<td>Physical Address Upper Register (ENET2_PAUR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_40EC</td>
<td>Opcode/Pause Duration Register (ENET2_OPD)</td>
<td>32</td>
</tr>
<tr>
<td>402D_40F0</td>
<td>Transmit Interrupt Coalescing Register (ENET2_TXIC)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4100</td>
<td>Receive Interrupt Coalescing Register (ENET2_RXIC)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4118</td>
<td>Descriptor Individual Upper Address Register (ENET2_IAUR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_411C</td>
<td>Descriptor Individual Lower Address Register (ENET2_IALR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4120</td>
<td>Descriptor Group Upper Address Register (ENET2_GAUR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4124</td>
<td>Descriptor Group Lower Address Register (ENET2_GALR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4144</td>
<td>Transmit FIFO Watermark Register (ENET2_TFWR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4180</td>
<td>Receive Descriptor Ring Start Register (ENET2_RDSR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4184</td>
<td>Transmit Buffer Descriptor Ring Start Register (ENET2_TDSR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4188</td>
<td>Maximum Receive Buffer Size Register (ENET2_MBR)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4190</td>
<td>Receive FIFO Section Full Threshold (ENET2_RSFL)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4194</td>
<td>Receive FIFO Section Empty Threshold (ENET2_RSEM)</td>
<td>32</td>
</tr>
<tr>
<td>402D_4198</td>
<td>Receive FIFO Almost Empty Threshold (ENET2_RAEM)</td>
<td>32</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## ENET memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_419C</td>
<td>Receive FIFO Almost Full Threshold (ENET2_RAFL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0004h</td>
<td>41.6.27/2106</td>
</tr>
<tr>
<td>402D_41A0</td>
<td>Transmit FIFO Section Empty Threshold (ENET2_TSEM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.28/2107</td>
</tr>
<tr>
<td>402D_41A4</td>
<td>Transmit FIFO Almost Empty Threshold (ENET2_TAEM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0004h</td>
<td>41.6.29/2107</td>
</tr>
<tr>
<td>402D_41A8</td>
<td>Transmit FIFO Almost Full Threshold (ENET2_TAFL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0008h</td>
<td>41.6.30/2108</td>
</tr>
<tr>
<td>402D_41AC</td>
<td>Transmit Inter-Packet Gap (ENET2_TIPG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000Ch</td>
<td>41.6.31/2108</td>
</tr>
<tr>
<td>402D_41B0</td>
<td>Frame Truncation Length (ENET2_FTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_07FFh</td>
<td>41.6.32/2109</td>
</tr>
<tr>
<td>402D_41C0</td>
<td>Transmit Accelerator Function Configuration (ENET2_TACC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.33/2109</td>
</tr>
<tr>
<td>402D_41C4</td>
<td>Receive Accelerator Function Configuration (ENET2_RACC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.34/2110</td>
</tr>
<tr>
<td>402D_4200</td>
<td>Reserved Statistic Register (ENET2_RMON_T_DROP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.35/2111</td>
</tr>
<tr>
<td>402D_4204</td>
<td>Tx Packet Count Statistic Register (ENET2_RMON_T_PACKETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.36/2112</td>
</tr>
<tr>
<td>402D_4208</td>
<td>Tx Broadcast Packets Statistic Register (ENET2_RMON_T_BC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.37/2112</td>
</tr>
<tr>
<td>402D_420C</td>
<td>Tx Multicast Packets Statistic Register (ENET2_RMON_T_MC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.38/2113</td>
</tr>
<tr>
<td>402D_4210</td>
<td>Tx Packets with CRC/Align Error Statistic Register (ENET2_RMON_T_CRC_ALIGN)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.39/2113</td>
</tr>
<tr>
<td>402D_4214</td>
<td>Tx Packets Less Than Bytes and Good CRC Statistic Register (ENET2_RMON_T_UNDERSIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.40/2113</td>
</tr>
<tr>
<td>402D_4218</td>
<td>Tx Packets GT MAX_FL bytes and Good CRC Statistic Register (ENET2_RMON_T_OVERSIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.41/2114</td>
</tr>
<tr>
<td>402D_421C</td>
<td>Tx Packets Less Than 64 Bytes and Bad CRC Statistic Register (ENET2_RMON_T_FRAG)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.42/2114</td>
</tr>
<tr>
<td>402D_4220</td>
<td>Tx Packets Greater Than MAX_FL bytes and Bad CRC Statistic Register (ENET2_RMON_T_JAB)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.43/2115</td>
</tr>
<tr>
<td>402D_4224</td>
<td>Tx Collision Count Statistic Register (ENET2_RMON_T_COL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.44/2115</td>
</tr>
<tr>
<td>402D_4228</td>
<td>Tx 64-Byte Packets Statistic Register (ENET2_RMON_T_P64)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.45/2115</td>
</tr>
<tr>
<td>402D_422C</td>
<td>Tx 65- to 127-byte Packets Statistic Register (ENET2_RMON_T_P65TO127)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.46/2116</td>
</tr>
<tr>
<td>402D_4230</td>
<td>Tx 128- to 255-byte Packets Statistic Register (ENET2_RMON_T_P128TO255)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.47/2116</td>
</tr>
<tr>
<td>402D_4234</td>
<td>Tx 256- to 511-byte Packets Statistic Register (ENET2_RMON_T_P256TO511)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.48/2117</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### ENET memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/ page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_4238</td>
<td>Tx 512- to 1023-byte Packets Statistic Register (ENET2_RMON_T_P512TO1023)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.49/2117</td>
</tr>
<tr>
<td>402D_423C</td>
<td>Tx 1024- to 2047-byte Packets Statistic Register (ENET2_RMON_T_P1024TO2047)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.50/2118</td>
</tr>
<tr>
<td>402D_4240</td>
<td>Tx Packets Greater Than 2048 Bytes Statistic Register (ENET2_RMON_T_P_GTE2048)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.51/2118</td>
</tr>
<tr>
<td>402D_4244</td>
<td>Tx Octets Statistic Register (ENET2_RMON_T_OCTETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.52/2118</td>
</tr>
<tr>
<td>402D_4248</td>
<td>Reserved Statistic Register (ENET2_IEEE_T_DROP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.53/2119</td>
</tr>
<tr>
<td>402D_424C</td>
<td>Frames Transmitted OK Statistic Register (ENET2_IEEE_T_FRAME_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.54/2119</td>
</tr>
<tr>
<td>402D_4250</td>
<td>Frames Transmitted with Single Collision Statistic Register (ENET2_IEEE_T_1COL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.55/2120</td>
</tr>
<tr>
<td>402D_4254</td>
<td>Frames Transmitted with Multiple Collisions Statistic Register (ENET2_IEEE_T_MCOL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.56/2120</td>
</tr>
<tr>
<td>402D_4258</td>
<td>Frames Transmitted after Deferral Delay Statistic Register (ENET2_IEEE_T_DEF)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.57/2120</td>
</tr>
<tr>
<td>402D_425C</td>
<td>Frames Transmitted with Late Collision Statistic Register (ENET2_IEEE_T_LCOL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.58/2121</td>
</tr>
<tr>
<td>402D_4260</td>
<td>Frames Transmitted with Excessive Collisions Statistic Register (ENET2_IEEE_T_EXCOL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.59/2121</td>
</tr>
<tr>
<td>402D_4264</td>
<td>Frames Transmitted with Tx FIFO Underrun Statistic Register (ENET2_IEEE_T_MACERR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.60/2122</td>
</tr>
<tr>
<td>402D_4268</td>
<td>Frames Transmitted with Carrier Sense Error Statistic Register (ENET2_IEEE_T_CSERR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.61/2122</td>
</tr>
<tr>
<td>402D_426C</td>
<td>Reserved Statistic Register (ENET2_IEEE_T_SQE)</td>
<td>32</td>
<td>R (reads 0)</td>
<td>0000_0000h</td>
<td>41.6.62/2122</td>
</tr>
<tr>
<td>402D_4270</td>
<td>Flow Control Pause Frames Transmitted Statistic Register (ENET2_IEEE_T_FDXFC)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.63/2123</td>
</tr>
<tr>
<td>402D_4274</td>
<td>Octet Count for Frames Transmitted w/o Error Statistic Register (ENET2_IEEE_T_OCTETS_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.64/2123</td>
</tr>
<tr>
<td>402D_4284</td>
<td>Rx Packet Count Statistic Register (ENET2_RMON_R_PACKETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.65/2124</td>
</tr>
<tr>
<td>402D_4288</td>
<td>Rx Broadcast Packets Statistic Register (ENET2_RMON_R_BC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.66/2124</td>
</tr>
<tr>
<td>402D_428C</td>
<td>Rx Multicast Packets Statistic Register (ENET2_RMON_R_MC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.67/2124</td>
</tr>
<tr>
<td>402D_4290</td>
<td>Rx Packets with CRC/Align Error Statistic Register (ENET2_RMON_R_CRC_ALIGN)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.68/2125</td>
</tr>
<tr>
<td>402D_4294</td>
<td>Rx Packets with Less Than 64 Bytes and Good CRC Stats Register (ENET2_RMON_RUndERSIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.69/2125</td>
</tr>
<tr>
<td>402D_4298</td>
<td>Rx Packets Greater Than MAX_FL and Good CRC Stats Register (ENET2_RMON_R OversIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.70/2126</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_429C</td>
<td>Rx Packets Less Than 64 Bytes and Bad CRC Statistic Register (ENET2_RMON_R_FRAG)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.71/2126</td>
</tr>
<tr>
<td>402D_42A0</td>
<td>Rx Packets Greater Than MAX_FL Bytes and Bad CRC Statistic Register (ENET2_RMON_R_JAB)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.72/2126</td>
</tr>
<tr>
<td>402D_42A4</td>
<td>Reserved Statistic Register (ENET2_RMON_R_RESVD_0)</td>
<td>32</td>
<td>R (reads 0)</td>
<td>0000_0000h</td>
<td>41.6.73/2127</td>
</tr>
<tr>
<td>402D_42A8</td>
<td>Rx 64-Byte Packets Statistic Register (ENET2_RMON_R_P64)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.74/2127</td>
</tr>
<tr>
<td>402D_42AC</td>
<td>Rx 65- to 127-Byte Packets Statistic Register (ENET2_RMON_R_P6STO127)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.75/2128</td>
</tr>
<tr>
<td>402D_42B0</td>
<td>Rx 128- to 255-Byte Packets Statistic Register (ENET2_RMON_R_P128TO255)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.76/2128</td>
</tr>
<tr>
<td>402D_42B4</td>
<td>Rx 256- to 511-Byte Packets Statistic Register (ENET2_RMON_R_P256TO511)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.77/2128</td>
</tr>
<tr>
<td>402D_42B8</td>
<td>Rx 512- to 1023-Byte Packets Statistic Register (ENET2_RMON_R_P512TO1023)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.78/2129</td>
</tr>
<tr>
<td>402D_42BC</td>
<td>Rx 1024- to 2047-Byte Packets Statistic Register (ENET2_RMON_R_P1024TO2047)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.79/2129</td>
</tr>
<tr>
<td>402D_42C0</td>
<td>Rx Packets Greater than 2048 Bytes Statistic Register (ENET2_RMON_R_P_GTE2048)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.80/2130</td>
</tr>
<tr>
<td>402D_42C4</td>
<td>Rx Octets Statistic Register (ENET2_RMON_R_OCTETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.81/2130</td>
</tr>
<tr>
<td>402D_42C8</td>
<td>Frames not Counted Correctly Statistic Register (ENET2_IEEE_R_DROP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.82/2130</td>
</tr>
<tr>
<td>402D_42CC</td>
<td>Frames Received OK Statistic Register (ENET2_IEEE_R_FRAME_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.83/2131</td>
</tr>
<tr>
<td>402D_42D0</td>
<td>Frames Received with CRC Error Statistic Register (ENET2_IEEE_R_CRC)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.84/2131</td>
</tr>
<tr>
<td>402D_42D4</td>
<td>Frames Received with Alignment Error Statistic Register (ENET2_IEEE_R_ALIGN)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.85/2132</td>
</tr>
<tr>
<td>402D_42D8</td>
<td>Receive FIFO Overflow Count Statistic Register (ENET2_IEEE_R_MACERR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.86/2132</td>
</tr>
<tr>
<td>402D_42DC</td>
<td>Flow Control Pause Frames Received Statistic Register (ENET2_IEEE_R_FDXFC)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.87/2132</td>
</tr>
<tr>
<td>402D_42E0</td>
<td>Octet Count for Frames Received without Error Statistic Register (ENET2_IEEE_R_OCTETS_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.88/2133</td>
</tr>
<tr>
<td>402D_4400</td>
<td>Adjustable Timer Control Register (ENET2_ATCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.89/2133</td>
</tr>
<tr>
<td>402D_4404</td>
<td>Timer Value Register (ENET2_ATVR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.90/2135</td>
</tr>
<tr>
<td>402D_4408</td>
<td>Timer Offset Register (ENET2_ATOFF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.91/2135</td>
</tr>
<tr>
<td>402D_440C</td>
<td>Timer Period Register (ENET2_ATPER)</td>
<td>32</td>
<td>R/W</td>
<td>3B9A_CA00h</td>
<td>41.6.92/2136</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_4410</td>
<td>Timer Correction Register (ENET2_ATCOR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.93/2136</td>
</tr>
<tr>
<td>402D_4414</td>
<td>Time-Stamping Clock Period Register (ENET2_ATINC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.94/2137</td>
</tr>
<tr>
<td>402D_4418</td>
<td>Timestamp of Last Transmitted Frame (ENET2_ATSTMP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.95/2137</td>
</tr>
<tr>
<td>402D_4604</td>
<td>Timer Global Status Register (ENET2_TGSR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.96/2138</td>
</tr>
<tr>
<td>402D_4608</td>
<td>Timer Control Status Register (ENET2_TCSR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.97/2139</td>
</tr>
<tr>
<td>402D_460C</td>
<td>Timer Compare Capture Register (ENET2_TCCR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.98/2140</td>
</tr>
<tr>
<td>402D_4610</td>
<td>Timer Control Status Register (ENET2_TCSR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.97/2139</td>
</tr>
<tr>
<td>402D_4614</td>
<td>Timer Compare Capture Register (ENET2_TCCR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.98/2140</td>
</tr>
<tr>
<td>402D_4618</td>
<td>Timer Control Status Register (ENET2_TCSR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.97/2139</td>
</tr>
<tr>
<td>402D_461C</td>
<td>Timer Compare Capture Register (ENET2_TCCR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.98/2140</td>
</tr>
<tr>
<td>402D_4620</td>
<td>Timer Control Status Register (ENET2_TCSR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.97/2139</td>
</tr>
<tr>
<td>402D_4624</td>
<td>Timer Compare Capture Register (ENET2_TCCR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.98/2140</td>
</tr>
<tr>
<td>402D_8004</td>
<td>Interrupt Event Register (ENET_EIR)</td>
<td>32</td>
<td>w1c</td>
<td>0000_0000h</td>
<td>41.6.1/2078</td>
</tr>
<tr>
<td>402D_8008</td>
<td>Interrupt Mask Register (ENET_EIMR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.2/2081</td>
</tr>
<tr>
<td>402D_8010</td>
<td>Receive Descriptor Active Register (ENET_RDAR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.3/2084</td>
</tr>
<tr>
<td>402D_8014</td>
<td>Transmit Descriptor Active Register (ENET_TDAR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.4/2084</td>
</tr>
<tr>
<td>402D_8024</td>
<td>Ethernet Control Register (ENET_ECR)</td>
<td>32</td>
<td>R/W</td>
<td>See section</td>
<td>41.6.5/2085</td>
</tr>
<tr>
<td>402D_8040</td>
<td>MII Management Frame Register (ENET_MMFR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.6/2087</td>
</tr>
<tr>
<td>402D_8044</td>
<td>MII Speed Control Register (ENET_MSCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.7/2088</td>
</tr>
<tr>
<td>402D_8064</td>
<td>MIB Control Register (ENET_MIBC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.8/2090</td>
</tr>
<tr>
<td>402D_8084</td>
<td>Receive Control Register (ENET_RCR)</td>
<td>32</td>
<td>R/W</td>
<td>05EE_0001h</td>
<td>41.6.9/2091</td>
</tr>
<tr>
<td>402D_80C4</td>
<td>Transmit Control Register (ENET_TCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.10/2094</td>
</tr>
<tr>
<td>402D_80E4</td>
<td>Physical Address Lower Register (ENET_PALR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.11/2096</td>
</tr>
<tr>
<td>402D_80E8</td>
<td>Physical Address Upper Register (ENET_PAUR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_8808h</td>
<td>41.6.12/2096</td>
</tr>
<tr>
<td>402D_80EC</td>
<td>Opcode/Pause Duration Register (ENET_OPD)</td>
<td>32</td>
<td>R/W</td>
<td>0001_0000h</td>
<td>41.6.13/2097</td>
</tr>
<tr>
<td>402D_80F0</td>
<td>Transmit Interrupt Coalescing Register (ENET_TXIC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.14/2097</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_8100</td>
<td>Receive Interrupt Coalescing Register (ENET_RXIC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.15/2098</td>
</tr>
<tr>
<td>402D_8118</td>
<td>Descriptor Individual Upper Address Register (ENET_IAUR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.16/2099</td>
</tr>
<tr>
<td>402D_811C</td>
<td>Descriptor Individual Lower Address Register (ENETIALR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.17/2100</td>
</tr>
<tr>
<td>402D_8120</td>
<td>Descriptor Group Upper Address Register (ENET_GAUR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.18/2100</td>
</tr>
<tr>
<td>402D_8124</td>
<td>Descriptor Group Lower Address Register (ENET_GALR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.19/2101</td>
</tr>
<tr>
<td>402D_8144</td>
<td>Transmit FIFO Watermark Register (ENET_TFWR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.20/2101</td>
</tr>
<tr>
<td>402D_8180</td>
<td>Receive Descriptor Ring Start Register (ENET_RDSR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.21/2102</td>
</tr>
<tr>
<td>402D_8184</td>
<td>Transmit Buffer Descriptor Ring Start Register (ENET_TDSR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.22/2103</td>
</tr>
<tr>
<td>402D_8188</td>
<td>Maximum Receive Buffer Size Register (ENET_MRBR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.23/2104</td>
</tr>
<tr>
<td>402D_8190</td>
<td>Receive FIFO Section Full Threshold (ENET_RSFL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.24/2105</td>
</tr>
<tr>
<td>402D_8194</td>
<td>Receive FIFO Section Empty Threshold (ENET_RSEM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.25/2105</td>
</tr>
<tr>
<td>402D_8198</td>
<td>Receive FIFO Almost Empty Threshold (ENET_RAEM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0004h</td>
<td>41.6.26/2106</td>
</tr>
<tr>
<td>402D_819C</td>
<td>Receive FIFO Almost Full Threshold (ENET_RAFL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0004h</td>
<td>41.6.27/2106</td>
</tr>
<tr>
<td>402D_81A0</td>
<td>Transmit FIFO Section Empty Threshold (ENET_TSEM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.28/2107</td>
</tr>
<tr>
<td>402D_81A4</td>
<td>Transmit FIFO Almost Empty Threshold (ENET_TAEM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0004h</td>
<td>41.6.29/2107</td>
</tr>
<tr>
<td>402D_81A8</td>
<td>Transmit FIFO Almost Full Threshold (ENET_TAFM)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0008h</td>
<td>41.6.30/2108</td>
</tr>
<tr>
<td>402D_81AC</td>
<td>Transmit Inter-Packet Gap (ENET_TIPG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000Ch</td>
<td>41.6.31/2108</td>
</tr>
<tr>
<td>402D_81B0</td>
<td>Frame Truncation Length (ENET_FTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_07FFh</td>
<td>41.6.32/2109</td>
</tr>
<tr>
<td>402D_81C0</td>
<td>Transmit Accelerator Function Configuration (ENET_TACC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.33/2109</td>
</tr>
<tr>
<td>402D_81C4</td>
<td>Receive Accelerator Function Configuration (ENET_RACC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.34/2110</td>
</tr>
<tr>
<td>402D_8200</td>
<td>Reserved Statistic Register (ENET_RMON_T_DROP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.35/2111</td>
</tr>
<tr>
<td>402D_8204</td>
<td>Tx Packet Count Statistic Register (ENET_RMON_T_PACKETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.36/2112</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## ENET memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_8208</td>
<td>Tx Broadcast Packets Statistic Register (ENET_RMON_T_BC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.37/2112</td>
</tr>
<tr>
<td>402D_820C</td>
<td>Tx Multicast Packets Statistic Register (ENET_RMON_T_MC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.38/2113</td>
</tr>
<tr>
<td>402D_8210</td>
<td>Tx Packets with CRC/Align Error Statistic Register (ENET_RMON_T_CRC_ALIGN)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.39/2113</td>
</tr>
<tr>
<td>402D_8214</td>
<td>Tx Packets Less Than Bytes and Good CRC Statistic Register (ENET_RMON_T_UNDERSIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.40/2113</td>
</tr>
<tr>
<td>402D_8218</td>
<td>Tx Packets GT MAX_FL bytes and Good CRC Statistic Register (ENET_RMON_T_OVERSIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.41/2114</td>
</tr>
<tr>
<td>402D_821C</td>
<td>Tx Packets Less Than 64 Bytes and Bad CRC Statistic Register (ENET_RMON_T_FRAG)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.42/2114</td>
</tr>
<tr>
<td>402D_8220</td>
<td>Tx Packets Greater Than MAX_FL bytes and Bad CRC Statistic Register (ENET_RMON_T_JAB)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.43/2115</td>
</tr>
<tr>
<td>402D_8224</td>
<td>Tx Collision Count Statistic Register (ENET_RMON_T_COL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.44/2115</td>
</tr>
<tr>
<td>402D_8228</td>
<td>Tx 64-Byte Packets Statistic Register (ENET_RMON_T_P64)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.45/2115</td>
</tr>
<tr>
<td>402D_822C</td>
<td>Tx 65- to 127-byte Packets Statistic Register (ENET_RMON_T_P65TO127)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.46/2116</td>
</tr>
<tr>
<td>402D_8230</td>
<td>Tx 128- to 255-byte Packets Statistic Register (ENET_RMON_T_P128TO255)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.47/2116</td>
</tr>
<tr>
<td>402D_8234</td>
<td>Tx 256- to 511-byte Packets Statistic Register (ENET_RMON_T_P256TO511)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.48/2117</td>
</tr>
<tr>
<td>402D_8238</td>
<td>Tx 512- to 1023-byte Packets Statistic Register (ENET_RMON_T_P512TO1023)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.49/2117</td>
</tr>
<tr>
<td>402D_823C</td>
<td>Tx 1024- to 2047-byte Packets Statistic Register (ENET_RMON_T_P1024TO2047)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.50/2118</td>
</tr>
<tr>
<td>402D_8240</td>
<td>Tx Packets Greater Than 2048 Bytes Statistic Register (ENET_RMON_T_P_GTE2048)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.51/2118</td>
</tr>
<tr>
<td>402D_8244</td>
<td>Tx Octets Statistic Register (ENET_RMON_T_OCTETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.52/2118</td>
</tr>
<tr>
<td>402D_8248</td>
<td>Reserved Statistic Register (ENET_IEEE_T_DROP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.53/2119</td>
</tr>
<tr>
<td>402D_824C</td>
<td>Frames Transmitted OK Statistic Register (ENET_IEEE_T_FRAME_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.54/2119</td>
</tr>
<tr>
<td>402D_8250</td>
<td>Frames Transmitted with Single Collision Statistic Register (ENET_IEEE_T_1COL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.55/2120</td>
</tr>
<tr>
<td>402D_8254</td>
<td>Frames Transmitted with Multiple Collisions Statistic Register (ENET_IEEE_T_MCOL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.56/2120</td>
</tr>
<tr>
<td>402D_8258</td>
<td>Frames Transmitted after Deferral Delay Statistic Register (ENET_IEEE_T_DEF)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.57/2120</td>
</tr>
<tr>
<td>402D_825C</td>
<td>Frames Transmitted with Late Collision Statistic Register (ENET_IEEE_T_LCOL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.58/2121</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_8260</td>
<td>Frames Transmitted with Excessive Collisions Statistic Register (ENET_IEEE_T_EXCOL)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.59/2121</td>
</tr>
<tr>
<td>402D_8264</td>
<td>Frames Transmitted with Tx FIFO Underrun Statistic Register (ENET_IEEE_T_MACERR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.60/2122</td>
</tr>
<tr>
<td>402D_8268</td>
<td>Frames Transmitted with Carrier Sense Error Statistic Register (ENET_IEEE_T_CSERR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.61/2122</td>
</tr>
<tr>
<td>402D_826C</td>
<td>Reserved Statistic Register (ENET_IEEE_T_SQE)</td>
<td>32</td>
<td>R (reads 0)</td>
<td>0000_0000h</td>
<td>41.6.62/2122</td>
</tr>
<tr>
<td>402D_8270</td>
<td>Flow Control Pause Frames Transmitted Statistic Register (ENET_IEEE_T_FDXFC)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.63/2123</td>
</tr>
<tr>
<td>402D_8274</td>
<td>Octet Count for Frames Transmitted w/o Error Statistic Register (ENET_IEEE_T_OCTETS_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.64/2123</td>
</tr>
<tr>
<td>402D_8284</td>
<td>Rx Packet Count Statistic Register (ENET_RMON_R_PACKETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.65/2124</td>
</tr>
<tr>
<td>402D_8288</td>
<td>Rx Broadcast Packets Statistic Register (ENET_RMON_R_BC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.66/2124</td>
</tr>
<tr>
<td>402D_828C</td>
<td>Rx Multicast Packets Statistic Register (ENET_RMON_R_MC_PKT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.67/2124</td>
</tr>
<tr>
<td>402D_8290</td>
<td>Rx Packets with CRC/Align Error Statistic Register (ENET_RMON_R_CRC_ALIGN)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.68/2125</td>
</tr>
<tr>
<td>402D_8294</td>
<td>Rx Packets with Less Than 64 Bytes and Good CRC Statistic Register (ENET_RMON_R_UNDERSIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.69/2125</td>
</tr>
<tr>
<td>402D_8298</td>
<td>Rx Packets Greater Than MAX_FL and Good CRC Statistic Register (ENET_RMON_R_OVERSIZE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.70/2126</td>
</tr>
<tr>
<td>402D_829C</td>
<td>Rx Packets Less Than 64 Bytes and Bad CRC Statistic Register (ENET_RMON_R_FRAG)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.71/2126</td>
</tr>
<tr>
<td>402D_82A0</td>
<td>Rx Packets Greater Than MAX_FL Bytes and Bad CRC Statistic Register (ENET_RMON_R_JAB)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.72/2126</td>
</tr>
<tr>
<td>402D_82A4</td>
<td>Reserved Statistic Register (ENET_RMON_R_RESVD_0)</td>
<td>32</td>
<td>R (reads 0)</td>
<td>0000_0000h</td>
<td>41.6.73/2127</td>
</tr>
<tr>
<td>402D_82A8</td>
<td>Rx 64-Byte Packets Statistic Register (ENET_RMON_R_P64)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.74/2127</td>
</tr>
<tr>
<td>402D_82AC</td>
<td>Rx 65- to 127-Byte Packets Statistic Register (ENET_RMON_R_P65TO127)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.75/2128</td>
</tr>
<tr>
<td>402D_82B0</td>
<td>Rx 128- to 255-Byte Packets Statistic Register (ENET_RMON_R_P128TO255)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.76/2128</td>
</tr>
<tr>
<td>402D_82B4</td>
<td>Rx 256- to 511-Byte Packets Statistic Register (ENET_RMON_R_P256TO511)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.77/2128</td>
</tr>
<tr>
<td>402D_82B8</td>
<td>Rx 512- to 1023-Byte Packets Statistic Register (ENET_RMON_R_P512TO1023)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.78/2129</td>
</tr>
<tr>
<td>402D_82BC</td>
<td>Rx 1024- to 2047-Byte Packets Statistic Register (ENET_RMON_R_P1024TO2047)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.79/2129</td>
</tr>
<tr>
<td>402D_82C0</td>
<td>Rx Packets Greater than 2048 Bytes Statistic Register (ENET_RMON_R_P_GTE2048)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.80/2130</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402D_82C4</td>
<td>Rx Octets Statistic Register (ENET_RMON_R_OCTETS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.81/2130</td>
</tr>
<tr>
<td>402D_82C8</td>
<td>Frames not Counted Correctly Statistic Register (ENET_IEEE_R_DROP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.82/2130</td>
</tr>
<tr>
<td>402D_82CC</td>
<td>Frames Received OK Statistic Register (ENET_IEEE_R_FRAME_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.83/2131</td>
</tr>
<tr>
<td>402D_82D0</td>
<td>Frames Received with CRC Error Statistic Register (ENET_IEEE_R_CRC)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.84/2131</td>
</tr>
<tr>
<td>402D_82D4</td>
<td>Frames Received with Alignment Error Statistic Register (ENET_IEEE_R_ALIGN)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.85/2132</td>
</tr>
<tr>
<td>402D_82D8</td>
<td>Receive FIFO Overflow Count Statistic Register (ENET_IEEE_R_MACERR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.86/2132</td>
</tr>
<tr>
<td>402D_82DC</td>
<td>Flow Control Pause Frames Received Statistic Register (ENET_IEEE_R_FDXFC)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.87/2132</td>
</tr>
<tr>
<td>402D_82E0</td>
<td>Octet Count for Frames Received without Error Statistic Register (ENET_IEEE_R_OCTETS_OK)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.88/2133</td>
</tr>
<tr>
<td>402D_8400</td>
<td>Adjustable Timer Control Register (ENET_ATCR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.89/2133</td>
</tr>
<tr>
<td>402D_8404</td>
<td>Timer Value Register (ENET_ATVR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.90/2135</td>
</tr>
<tr>
<td>402D_8408</td>
<td>Timer Offset Register (ENET_ATOFF)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.91/2135</td>
</tr>
<tr>
<td>402D_840C</td>
<td>Timer Period Register (ENET_ATPER)</td>
<td>32</td>
<td>R/W</td>
<td>3B9A_CA00h</td>
<td>41.6.92/2136</td>
</tr>
<tr>
<td>402D_8410</td>
<td>Timer Correction Register (ENET_ATCOR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.93/2136</td>
</tr>
<tr>
<td>402D_8414</td>
<td>Time-Stamping Clock Period Register (ENET_ATINC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.94/2137</td>
</tr>
<tr>
<td>402D_8418</td>
<td>Timestamp of Last Transmitted Frame (ENET_ATSTMP)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>41.6.95/2137</td>
</tr>
<tr>
<td>402D_8604</td>
<td>Timer Global Status Register (ENET_TGSR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.96/2138</td>
</tr>
<tr>
<td>402D_8608</td>
<td>Timer Control Status Register (ENET_TCSR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.97/2139</td>
</tr>
<tr>
<td>402D_860C</td>
<td>Timer Compare Capture Register (ENET_TCCR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.98/2140</td>
</tr>
<tr>
<td>402D_8610</td>
<td>Timer Control Status Register (ENET_TCSR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.97/2139</td>
</tr>
<tr>
<td>402D_8614</td>
<td>Timer Compare Capture Register (ENET_TCCR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.98/2140</td>
</tr>
<tr>
<td>402D_8618</td>
<td>Timer Control Status Register (ENET_TCSR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.97/2139</td>
</tr>
<tr>
<td>402D_861C</td>
<td>Timer Compare Capture Register (ENET_TCCR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>41.6.98/2140</td>
</tr>
</tbody>
</table>

Table continues on the next page...
41.6.1 Interrupt Event Register (ENETx_EIR)

When an event occurs that sets a bit in EIR, an interrupt occurs if the corresponding bit in the interrupt mask register (EIMR) is also set. Writing a 1 to an EIR bit clears it; writing 0 has no effect. This register is cleared upon hardware reset.

**NOTE**

TxBD[INT] and RxBD[INT] must be set to 1 to allow setting the corresponding EIR register flags in enhanced mode, ENET_ECR[EN1588] = 1. Legacy mode does not require these flags to be enabled.

Address: 402D_4000h base + 4h offset = 402D_4004h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>Babr</td>
<td>Babt</td>
<td>Gra</td>
<td>TXF</td>
<td>TXB</td>
<td>RXF</td>
<td>RXB</td>
<td>MII</td>
<td>EBERR</td>
<td>LC</td>
<td>RL</td>
<td>UN</td>
<td>PLR</td>
<td>WAKEUP</td>
<td>TS_AVAIL</td>
</tr>
<tr>
<td>W</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td>w1c</td>
<td></td>
</tr>
</tbody>
</table>

Reset
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>TS_TIMER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>w1c</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
## ENETx_EIR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved. This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>30</td>
<td>BABR Babbling Receive Error. Indicates a frame was received with length in excess of RCR[MAX_FL] bytes.</td>
</tr>
<tr>
<td>29</td>
<td>BABT Babbling Transmit Error. Indicates the transmitted frame length exceeds RCR[MAX_FL] bytes. Usually this condition is caused when a frame that is too long is placed into the transmit data buffer(s). Truncation does not occur.</td>
</tr>
<tr>
<td>28</td>
<td>GRA Graceful Stop Complete. This interrupt is asserted after the transmitter is put into a pause state after completion of the frame currently being transmitted. See Graceful Transmit Stop (GTS) for conditions that lead to graceful stop. <strong>NOTE:</strong> The GRA interrupt is asserted only when the TX transitions into the stopped state. If this bit is cleared by writing 1 and the TX is still stopped, the bit is not set again.</td>
</tr>
<tr>
<td>27</td>
<td>TXF Transmit Frame Interrupt. Indicates a frame has been transmitted and the last corresponding buffer descriptor has been updated.</td>
</tr>
<tr>
<td>26</td>
<td>TXB Transmit Buffer Interrupt. Indicates a transmit buffer descriptor has been updated.</td>
</tr>
<tr>
<td>25</td>
<td>RXF Receive Frame Interrupt. Indicates a frame has been received and the last corresponding buffer descriptor has been updated.</td>
</tr>
<tr>
<td>24</td>
<td>RXB Receive Buffer Interrupt. Indicates a receive buffer descriptor is not the last in the frame has been updated.</td>
</tr>
<tr>
<td>23</td>
<td>MII MII Interrupt. Indicates that the MII has completed the data transfer requested.</td>
</tr>
<tr>
<td>22</td>
<td>EBERR Ethernet Bus Error. Indicates a system bus error occurred when a uDMA transaction is underway. When this bit is set, ECR[ETHEREN] is cleared, halting frame processing by the MAC. When this occurs, software must ensure proper actions, possibly resetting the system, to resume normal operation.</td>
</tr>
<tr>
<td>21</td>
<td>LC Late Collision. Indicates a collision occurred beyond the collision window (slot time) in half-duplex mode. The frame truncates with a bad CRC and the remainder of the frame is discarded.</td>
</tr>
<tr>
<td>20</td>
<td>RL Collision Retry Limit. Indicates a collision occurred on each of 16 successive attempts to transmit the frame. The frame is discarded without being transmitted and transmission of the next frame commences. This error can only occur in half-duplex mode.</td>
</tr>
<tr>
<td>19</td>
<td>UN Transmit FIFO Underrun. Indicates the transmit FIFO became empty before the complete frame was transmitted. <strong>NOTE:</strong> In situations where the device has various masters generating high traffic, a FIFO underrun can occur on the transmit FIFO. To avoid transmit FIFO underrun, store and forward can be enabled.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
**ENETx_EIR field descriptions (continued)**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 18 PLR | Payload Receive Error  
Indicates a frame was received with a payload length error. See Frame Length/Type Verification: Payload Length Check for more information. |
| 17 WAKEUP | Node Wakeup Request Indication  
Read-only status bit to indicate that a magic packet has been detected. Will act only if ECR[MAGICEN] is set. |
| 16 TS_AVAIL | Transmit Timestamp Available  
Indicates that the timestamp of the last transmitted timing frame is available in the ATSTMP register. |
| 15 TS_TIMER | Timestamp Timer  
The adjustable timer reached the period event. A period event interrupt can be generated if ATCR[PEREN] is set and the timer wraps according to the periodic setting in the ATPER register. Set the timer period value before setting ATCR[PEREN]. |
| 14–13 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| 12 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| 11–9 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| 8 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
41.6.2 Interrupt Mask Register (ENETx_EIMR)

EIMR controls which interrupt events are allowed to generate actual interrupts. A hardware reset clears this register. If the corresponding bits in the EIR and EIMR registers are set, an interrupt is generated. The interrupt signal remains asserted until a 1 is written to the EIR field (write 1 to clear) or a 0 is written to the EIMR field.

Address: 402D_4000h base + 8h offset = 402D_4008h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>BABR</td>
<td>BABT</td>
<td>GRA</td>
<td>TXF</td>
<td>TXB</td>
<td>RXF</td>
<td>RXB</td>
<td>MII</td>
<td>EBERR</td>
<td>LC</td>
<td>RL</td>
<td>UN</td>
<td>PLR</td>
<td>WAKEUP</td>
<td>TS_AVAIL</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>TS_TIMER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### ENETx_EIMR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 Reserved</td>
<td>This field is reserved. This write-only field is reserved. It must always be written with the value 0.</td>
</tr>
</tbody>
</table>
| 30 BABR | BABR Interrupt Mask  
Corresponds to interrupt source EIR[BABR] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR BABR field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.  
0 The corresponding interrupt source is masked.  
1 The corresponding interrupt source is not masked. |
| 29 BABT | BABT Interrupt Mask  
Corresponds to interrupt source EIR[BABT] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR BABT field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.  
0 The corresponding interrupt source is masked.  
1 The corresponding interrupt source is not masked. |
| 28 GRA | GRA Interrupt Mask  
Corresponds to interrupt source EIR[GRA] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The corresponding interrupt source is masked.</td>
</tr>
<tr>
<td>1</td>
<td>The corresponding interrupt source is not masked.</td>
</tr>
</tbody>
</table>

27 TXF

TXF Interrupt Mask
Corresponds to interrupt source EIR[TXF] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR TXF field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.

0 The corresponding interrupt source is masked.
1 The corresponding interrupt source is not masked.

26 TXB

TXB Interrupt Mask
Corresponds to interrupt source EIR[TXB] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR TXB field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.

0 The corresponding interrupt source is masked.
1 The corresponding interrupt source is not masked.

25 RXF

RXF Interrupt Mask
Corresponds to interrupt source EIR[RXF] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR RXF field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.

24 RXB

RXB Interrupt Mask
Corresponds to interrupt source EIR[RXB] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR RXB field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.

23 MII

MII Interrupt Mask
Corresponds to interrupt source EIR[MII] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR MII field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.

22 EBERR

EBERR Interrupt Mask
Corresponds to interrupt source EIR[EBERR] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR EBERR field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.

21 LC

LC Interrupt Mask
Corresponds to interrupt source EIR[LC] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR LC field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared.

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 20 RL | RL Interrupt Mask  
Corresponds to interrupt source EIR[RL] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR RL field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared. |
| 19 UN | UN Interrupt Mask  
Corresponds to interrupt source EIR[UN] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR UN field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared. |
| 18 PLR | PLR Interrupt Mask  
Corresponds to interrupt source EIR[PLR] and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR PLR field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared. |
| 17 WAKEUP | WAKEUP Interrupt Mask  
Corresponds to interrupt source EIR[WAKEUP] register and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR WAKEUP field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared. |
| 16 TS_AVAIL | TS_AVAIL Interrupt Mask  
Corresponds to interrupt source EIR[TS_AVAIL] register and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR TS_AVAIL field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared. |
| 15 TS_TIMER | TS_TIMER Interrupt Mask  
Corresponds to interrupt source EIR[TS_TIMER] register and determines whether an interrupt condition can generate an interrupt. At every module clock, the EIR samples the signal generated by the interrupting source. The corresponding EIR TS_TIMER field reflects the state of the interrupt signal even if the corresponding EIMR field is cleared. |
| 14–13 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| 12 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| 11–9 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| 8 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
41.6.3 Receive Descriptor Active Register (ENETx_RDAR)

RDAR is a command register, written by the user, to indicate that the receive descriptor ring has been updated, that is, that the driver produced empty receive buffers with the empty bit set.

Address: 402D_4000h base + 10h offset = 402D_4010h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**ENETx_RDAR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–25 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 24 RDAR | Receive Descriptor Active  
Always set to 1 when this register is written, regardless of the value written. This field is cleared by the MAC device when no additional empty descriptors remain in the receive ring. It is also cleared when ECR[ETHEREN] transitions from set to cleared or when ECR[RESET] is set. |
| Reserved | This field is reserved. This read-only field is reserved and always has the value 0. |

41.6.4 Transmit Descriptor Active Register (ENETx_TDAR)

The TDAR is a command register that the user writes to indicate that the transmit descriptor ring has been updated, that is, that transmit buffers have been produced by the driver with the ready bit set in the buffer descriptor.

The TDAR register is cleared at reset, when ECR[ETHEREN] transitions from set to cleared, or when ECR[RESET] is set.
Address: 402D_4000h base + 14h offset = 402D_4014h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

TDAR

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

R

W

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**ENETx_TDAR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–25 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>24 TDAR</td>
<td>Transmit Descriptor Active</td>
</tr>
<tr>
<td></td>
<td>Always set to 1 when this register is written, regardless of the value written. This bit is cleared by the MAC device when no additional ready descriptors remain in the transmit ring. Also cleared when ECR[ETHEREN] transitions from set to cleared or when ECR[RESET] is set.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

### 41.6.5 Ethernet Control Register (ENETx_ECR)

ECR is a read/write user register, though hardware may also alter fields in this register. It controls many of the high level features of the Ethernet MAC, including legacy FEC support through the EN1588 field.

Address: 402D_4000h base + 24h offset = 402D_4024h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>DBSWP</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| R   | Reserved | Reserved | Reserved | Reserved | DBGEN | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved |
| W   | Reserved | Reserved | Reserved | Reserved | EN1588 | SLEEP | MAGICEN | ETHEREN | RESET |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
## ENETx_ECR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–18 Reserved</td>
<td>This field is reserved. Always write 01110000000000b to this field.</td>
</tr>
<tr>
<td>17–12 Reserved</td>
<td>This field is reserved. Always write 0 to this field.</td>
</tr>
<tr>
<td>11 Reserved</td>
<td>This field is reserved. Always write 0 to this field.</td>
</tr>
<tr>
<td>10 Reserved</td>
<td>This field is reserved. Always write 0 to this field.</td>
</tr>
<tr>
<td>9 Reserved</td>
<td>This field is reserved. Always write 0 to this field.</td>
</tr>
</tbody>
</table>
| 8 DBSWP | Descriptor Byte Swapping Enable  
Swaps the byte locations of the buffer descriptors.  
**NOTE:** This field must be written to 1 after reset.  
0 The buffer descriptor bytes are not swapped to support big-endian devices.  
1 The buffer descriptor bytes are swapped to support little-endian devices. |
| 7 Reserved | This field is reserved. Always write 0 to this field. |
| 6 DBGEN | Debug Enable  
Enables the MAC to enter hardware freeze mode when the device enters debug mode.  
0 MAC continues operation in debug mode.  
1 MAC enters hardware freeze mode when the processor is in debug mode. |
| 5 Reserved | This field is reserved. This write-only field is reserved. It must always be written with the value 0. |
| 4 EN1588 | EN1588 Enable  
Enables enhanced functionality of the MAC.  
0 Legacy FEC buffer descriptors and functions enabled.  
1 Enhanced frame time-stamping functions enabled. |
| 3 SLEEP | Sleep Mode Enable  
0 Normal operating mode.  
1 Sleep mode. |
| 2 MAGICEN | Magic Packet Detection Enable  
Enables/disables magic packet detection.  
**NOTE:** MAGICEN is relevant only if the SLEEP field is set. If MAGICEN is set, changing the SLEEP field enables/disables sleep mode and magic packet detection.  
**NOTE:** EIMR[WAKEUP] must be written to one if Magic packet wakeup is programmed to wake up the chip from low power mode.  
0 Magic detection logic disabled.  
1 The MAC core detects magic packets and asserts EIR[WAKEUP] when a frame is detected. |

*Table continues on the next page...*
### ENETx_ECR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 ETHERN</td>
<td>Ethernet Enable</td>
</tr>
<tr>
<td>Enables/disables the Ethernet MAC. When the MAC is disabled, the buffer descriptors for an aborted transmit frame are not updated. The uDMA, buffer descriptor, and FIFO control logic are reset, including the buffer descriptor and FIFO pointers. Hardware clears this field under the following conditions:</td>
<td></td>
</tr>
<tr>
<td>• RESET is set by software</td>
<td></td>
</tr>
<tr>
<td>• An error condition causes the EBERR field to set.</td>
<td></td>
</tr>
</tbody>
</table>

**NOTE:**

- ETHERN must be set at the very last step during ENET configuration/setup-initialization, only after all other ENET-related registers have been configured.
- If ETHERN is cleared to 0 by software then next time ETHERN is set, the EIR interrupts must cleared to 0 due to previous pending interrupts.

| 0 Reception immediately stops and transmission stops after a bad CRC is appended to any currently transmitted frame. |
| 1 MAC is enabled, and reception and transmission are possible. |

| 0 RESET | Ethernet MAC Reset |
| When this field is set, it clears the ETHERN field. |

### 41.6.6 MII Management Frame Register (ENETx_MMFR)

Writing to MMFR triggers a management frame transaction to the PHY device unless MSCR is programmed to zero.

If MSCR is changed from zero to non-zero during a write to MMFR, an MII frame is generated with the data previously written to the MMFR. This allows MMFR and MSCR to be programmed in either order if MSCR is currently zero.

If the MMFR register is written while frame generation is in progress, the frame contents are altered. Software must use the EIR[MII] interrupt indication to avoid writing to the MMFR register while frame generation is in progress.

Address: 402D_4000h base + 40h offset = 402D_4040h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>ST</td>
<td>OP</td>
<td>PA</td>
<td>RA</td>
<td>TA</td>
<td>DATA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### ENETx_MMFR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 ST</td>
<td>Start Of Frame Delimiter</td>
</tr>
<tr>
<td>See Table 41-42 (Clause 22) or Table 41-44 (Clause 45) for correct value.</td>
<td></td>
</tr>
</tbody>
</table>
ENETx_MMFR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>29–28 OP</td>
<td>Operation Code</td>
</tr>
<tr>
<td>27–23 PA</td>
<td>PHY Address</td>
</tr>
<tr>
<td>22–18 RA</td>
<td>Register Address</td>
</tr>
<tr>
<td>17–16 TA</td>
<td>Turn Around</td>
</tr>
<tr>
<td>DATA</td>
<td>Management Frame Data</td>
</tr>
</tbody>
</table>

**41.6.7 MII Speed Control Register (ENETx_MSCR)**

MSCR provides control of the MII clock (MDC pin) frequency and allows a preamble drop on the MII management frame.

The MII_SPEED field must be programmed with a value to provide an MDC frequency of less than or equal to 2.5 MHz to be compliant with the IEEE 802.3 MII specification. The MII_SPEED must be set to a non-zero value to source a read or write management frame. After the management frame is complete, the MSCR register may optionally be cleared to turn off MDC. The MDC signal generated has a 50% duty cycle except when MII_SPEED changes during operation. This change takes effect following a rising or falling edge of MDC.

For example, if the internal module clock (that is, peripheral bus clock) is 25 MHz, programming MII_SPEED to 0x4 results in an MDC as given in the following equation:

\[
\text{MII clock frequency} = \frac{25 \text{ MHz}}{((4 + 1) \times 2)} = 2.5 \text{ MHz}
\]

The following table shows the optimum values for MII_SPEED as a function of IPS bus clock frequency.

**Table 41-5. Programming Examples for MSCR**

<table>
<thead>
<tr>
<th>Internal module clock frequency</th>
<th>MSCR [MII_SPEED]</th>
<th>MDC frequency</th>
</tr>
</thead>
<tbody>
<tr>
<td>25 MHz</td>
<td>0x4</td>
<td>2.50 MHz</td>
</tr>
<tr>
<td>33 MHz</td>
<td>0x6</td>
<td>2.36 MHz</td>
</tr>
<tr>
<td>40 MHz</td>
<td>0x7</td>
<td>2.50 MHz</td>
</tr>
<tr>
<td>50 MHz</td>
<td>0x9</td>
<td>2.50 MHz</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 41-5. Programming Examples for MSCR (continued)

<table>
<thead>
<tr>
<th>Internal module clock frequency</th>
<th>MSCR [MII_SPEED]</th>
<th>MDC frequency</th>
</tr>
</thead>
<tbody>
<tr>
<td>66 MHz</td>
<td>0xD</td>
<td>2.36 MHz</td>
</tr>
</tbody>
</table>

Address: 402D_4000h base + 44h offset = 402D_4044h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

ENETx_MSCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–11</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

10–8 HOLDTIME

Hold time On MDIO Output

IEEE802.3 clause 22 defines a minimum of 10 ns for the hold time on the MDIO output. Depending on the host bus frequency, the setting may need to be increased.

000 1 internal module clock cycle
001 2 internal module clock cycles
010 3 internal module clock cycles
111 8 internal module clock cycles

7 DIS_PRE

Disable Preamble

Enables/disables prepending a preamble to the MII management frame. The MII standard allows the preamble to be dropped if the attached PHY devices do not require it.

0 Preamble enabled.
1 Preamble (32 ones) is not prepended to the MII management frame.

6–1 MII_SPEED

MII Speed

Controls the frequency of the MII management interface clock (MDC) relative to the internal module clock. A value of 0 in this field turns off MDC and leaves it in low voltage state. Any non-zero value results in the MDC frequency of:

1/(MII_SPEED + 1) x 2) of the internal module clock frequency

0 Reserved

This field is reserved. This read-only field is reserved and always has the value 0.
41.6.8 MIB Control Register (ENETx_MIBC)

MIBC is a read/write register controlling and observing the state of the MIB block. Access this register to disable the MIB block operation or clear the MIB counters. The MIB_DIS field resets to 1.

Address: 402D_4000h base + 64h offset = 402D_4064h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MIB_DIS</td>
<td>MIB_IDLE</td>
<td>MIB_CLEAR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

ENETx_MIBC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 MIB_DIS</td>
<td>Disable MIB Logic</td>
</tr>
<tr>
<td></td>
<td>If this control field is set,</td>
</tr>
<tr>
<td></td>
<td>0  MIB logic is enabled.</td>
</tr>
<tr>
<td></td>
<td>1  MIB logic is disabled. The MIB logic halts and does not update any MIB counters.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
ENETx_MIBC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>30</td>
<td>MIB_IDLE</td>
</tr>
<tr>
<td></td>
<td>MIB Idle</td>
</tr>
<tr>
<td>0</td>
<td>The MIB block is updating MIB counters.</td>
</tr>
<tr>
<td>1</td>
<td>The MIB block is not currently updating any MIB counters.</td>
</tr>
<tr>
<td>29</td>
<td>MIB_CLEAR</td>
</tr>
<tr>
<td></td>
<td>MIB Clear</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This field is not self-clearing. To clear the MIB counters set and then clear this field.</td>
</tr>
<tr>
<td>0</td>
<td>See note above.</td>
</tr>
<tr>
<td>1</td>
<td>All statistics counters are reset to 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

41.6.9  Receive Control Register (ENETx_RCR)

Address: 402D_4000h base + 84h offset = 402D_4084h
## ENETx_RCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31 GRS | Graceful Receive Stopped  
Read-only status indicating that the MAC receive datapath is stopped. |
| 30 NLC | Payload Length Check Disable  
Enables/disables a payload length check.  
0 The payload length check is disabled.  
1 The core checks the frame's payload length with the frame length/type field. Errors are indicated in the EIR[PLR] field. |
| 29–16 MAX_FL | Maximum Frame Length  
Resets to decimal 1518. Length is measured starting at DA and includes the CRC at the end of the frame. Transmit frames longer than MAX_FL cause the BABT interrupt to occur. Receive frames longer than MAX_FL cause the BABR interrupt to occur and set the LG field in the end of frame receive buffer descriptor. The recommended default value to be programmed is 1518 or 1522 if VLAN tags are supported. |
| 15 CFEN | MAC Control Frame Enable  
Enables/disables the MAC control frame.  
0 MAC control frames with any opcode other than 0x0001 (pause frame) are accepted and forwarded to the client interface.  
1 MAC control frames with any opcode other than 0x0001 (pause frame) are silently discarded. |
| 14 CRCFWD | Terminate/Forward Received CRC  
Specifies whether the CRC field of received frames is transmitted or stripped.  
**NOTE:** If padding function is enabled (PADEN = 1), CRCFWD is ignored and the CRC field is checked always terminated and removed.  
0 The CRC field of received frames is transmitted to the user application.  
1 The CRC field is stripped from the frame. |
| 13 PAUFWD | Terminate/Forward Pause Frames  
Specifies whether pause frames are terminated or forwarded.  
0 Pause frames are terminated and discarded in the MAC.  
1 Pause frames are forwarded to the user application. |
| 12 PADEN | Enable Frame Padding Remove On Receive  
Specifies whether the MAC removes padding from received frames.  
0 No padding is removed on receive by the MAC.  
1 Padding is removed from received frames. |
| 11–10 Reserved | This field is reserved.  
This write-only field is reserved. It must always be written with the value 0. |
| 9 RMII_10T | Enables 10-Mbit/s mode of the RMII  
0  100-Mbit/s operation.  
1  10-Mbit/s operation. |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>RMII_MODE &lt;br&gt;RMII Mode Enable &lt;br&gt;Specifies whether the MAC is configured for MII mode or RMII operation. &lt;br&gt;0 MAC configured for MII mode. &lt;br&gt;1 MAC configured for RMII operation.</td>
</tr>
<tr>
<td>7</td>
<td>Reserved &lt;br&gt;This field is reserved. &lt;br&gt;This write-only field is reserved. It must always be written with the value 0.</td>
</tr>
<tr>
<td>6</td>
<td>Reserved &lt;br&gt;This field is reserved. &lt;br&gt;This write-only field is reserved. It must always be written with the value 0.</td>
</tr>
<tr>
<td>5</td>
<td>FCE &lt;br&gt;Flow Control Enable &lt;br&gt;If set, the receiver detects PAUSE frames. Upon PAUSE frame detection, the transmitter stops transmitting data frames for a given duration.</td>
</tr>
<tr>
<td>4</td>
<td>BC_REJ &lt;br&gt;Broadcast Frame Reject &lt;br&gt;If set, frames with destination address (DA) equal to 0xFFFF_FFFF_FFFF are rejected unless the PROM field is set. If BC_REJ and PROM are set, frames with broadcast DA are accepted and the MISS (M) is set in the receive buffer descriptor.</td>
</tr>
<tr>
<td>3</td>
<td>PROM &lt;br&gt;Promiscuous Mode &lt;br&gt;All frames are accepted regardless of address matching. &lt;br&gt;0 Disabled. &lt;br&gt;1 Enabled.</td>
</tr>
<tr>
<td>2</td>
<td>MII_MODE &lt;br&gt;Media Independent Interface Mode &lt;br&gt;This field must always be set. &lt;br&gt;0 Reserved. &lt;br&gt;1 MII or RMII mode, as indicated by the RMII_MODE field.</td>
</tr>
<tr>
<td>1</td>
<td>DRT &lt;br&gt;Disable Receive On Transmit &lt;br&gt;0 Receive path operates independently of transmit (i.e., full-duplex mode). Can also be used to monitor transmit activity in half-duplex mode. &lt;br&gt;1 Disable reception of frames while transmitting. (Normally used for half-duplex mode.)</td>
</tr>
<tr>
<td>0</td>
<td>LOOP &lt;br&gt;Internal Loopback &lt;br&gt;This is an MII internal loopback, therefore MII_MODE must be written to 1 and RMII_MODE must be written to 0. &lt;br&gt;0 Loopback disabled. &lt;br&gt;1 Transmitted frames are looped back internal to the device and transmit MII output signals are not asserted. DRT must be cleared.</td>
</tr>
</tbody>
</table>
41.6.10 Transmit Control Register (ENETx_TCR)

TCR is read/write and configures the transmit block. This register is cleared at system reset. FDEN can only be modified when ECR[ETHEREN] is cleared.

Address: 402D_4000h base + C4h offset = 402D_40C4h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–11</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>This field is reserved. This field is read/write and must be set to 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>Forward Frame From Application With CRC</td>
</tr>
<tr>
<td>CRCFWD</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 0     | TxBD[TC] controls whether the frame has a CRC from the application.  
| 1     | The transmitter does not append any CRC to transmitted frames, as it is expecting a frame with CRC from the application. |
| 8     | ADDINS Set MAC Address On Transmit  
|       | 0 The source MAC address is not modified by the MAC.  
|       | 1 The MAC overwrites the source MAC address with the programmed MAC address according to ADDSEL. |
| 7–5   | ADDSEL Source MAC Address Select On Transmit  
|       | If ADDINS is set, indicates the MAC address that overwrites the source MAC address.  
| 000   | Node MAC address programmed on PADDR1/2 registers.  
| 100   | Reserved.  
| 101   | Reserved.  
| 110   | Reserved. |
| 4     | RFC_PAUSE Receive Frame Control Pause  
|       | This status field is set when a full-duplex flow control pause frame is received and the transmitter pauses for the duration defined in this pause frame. This field automatically clears when the pause duration is complete. |
| 3     | TFC_PAUSE Transmit Frame Control Pause  
|       | Pauses frame transmission. When this field is set, EIR[GRA] is set. With transmission of data frames stopped, the MAC transmits a MAC control PAUSE frame. Next, the MAC clears TFC_PAUSE and resumes transmitting data frames. If the transmitter pauses due to user assertion of GTS or reception of a PAUSE frame, the MAC may continue transmitting a MAC control PAUSE frame.  
| 0     | No PAUSE frame transmitted.  
| 1     | The MAC stops transmission of data frames after the current transmission is complete. |
| 2     | FDEN Full-Duplex Enable  
|       | If this field is set, frames transmit independent of carrier sense and collision inputs. Only modify this bit when ECR[ETHEREN] is cleared. |
| 1     | Reserved  
|       | This write-only field is reserved. It must always be written with the value 0. |
| 0     | GTS Graceful Transmit Stop  
|       | When this field is set, MAC stops transmission after any frame currently transmitted is complete and EIR[GRA] is set. If frame transmission is not currently underway, the GRA interrupt is asserted immediately. After transmission finishes, clear GTS to restart. The next frame in the transmit FIFO is then transmitted. If an early collision occurs during transmission when GTS is set, transmission stops after the collision. The frame is transmitted again after GTS is cleared. There may be old frames in the transmit FIFO that transmit when GTS is reasserted. To avoid this, clear ECR[ETHEREN] following the GRA interrupt. |
41.6.11 Physical Address Lower Register (ENETx_PALR)

PALR contains the lower 32 bits (bytes 0, 1, 2, 3) of the 48-bit address used in the address recognition process to compare with the destination address (DA) field of receive frames with an individual DA. In addition, this register is used in bytes 0 through 3 of the six-byte source address field when transmitting PAUSE frames.

Address: 402D_4000h base + E4h offset = 402D_40E4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>PADDR1</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

ENETx_PALR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PADDR1</td>
<td>Pause Address</td>
</tr>
<tr>
<td></td>
<td>Bytes 0 (bits 31:24), 1 (bits 23:16), 2 (bits 15:8), and 3 (bits 7:0) of the 6-byte individual address are used for exact match and the source address field in PAUSE frames.</td>
</tr>
</tbody>
</table>

41.6.12 Physical Address Upper Register (ENETx_PAUR)

PAUR contains the upper 16 bits (bytes 4 and 5) of the 48-bit address used in the address recognition process to compare with the destination address (DA) field of receive frames with an individual DA. In addition, this register is used in bytes 4 and 5 of the six-byte source address field when transmitting PAUSE frames. Bits 15:0 of PAUR contain a constant type field (0x8808) for transmission of PAUSE frames.

Address: 402D_4000h base + E8h offset = 402D_40E8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>PADDR2</th>
<th>TYPE</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

ENETx_PAUR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Bytes 4 (bits 31:24) and 5 (bits 23:16) of the 6-byte individual address used for exact match, and the source address field in PAUSE frames.</td>
</tr>
<tr>
<td>PADDR2</td>
<td>Type Field In PAUSE Frames</td>
</tr>
<tr>
<td></td>
<td>These fields have a constant value of 0x8808.</td>
</tr>
</tbody>
</table>
41.6.13 Opcode/Pause Duration Register (ENETx_OPD)

OPD is read/write accessible. This register contains the 16-bit opcode and 16-bit pause duration fields used in transmission of a PAUSE frame. The opcode field is a constant value, 0x0001. When another node detects a PAUSE frame, that node pauses transmission for the duration specified in the pause duration field. The lower 16 bits of this register are not reset and you must initialize it.

Address: 402D_4000h base + ECh offset = 402D_40ECh

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Opcode Field In PAUSE Frames</td>
</tr>
<tr>
<td>OPD</td>
<td>These fields have a constant value of 0x0001.</td>
</tr>
<tr>
<td>PAUSE_DUR</td>
<td>Pause Duration</td>
</tr>
<tr>
<td></td>
<td>Pause duration field used in PAUSE frames.</td>
</tr>
</tbody>
</table>

41.6.14 Transmit Interrupt Coalescing Register (ENETx_TXIC)

See Interrupt coalescence for more information.

Address: 402D_4000h base + F0h offset = 402D_40F0h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Interrupt Coalescing Enable</td>
</tr>
</tbody>
</table>
ENETx_TXIC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Disable Interrupt coalescing.</td>
</tr>
<tr>
<td>1</td>
<td>Enable Interrupt coalescing.</td>
</tr>
<tr>
<td>30</td>
<td>Interrupt Coalescing Timer Clock Source Select</td>
</tr>
<tr>
<td>0</td>
<td>Use MII/GMII TX clocks.</td>
</tr>
<tr>
<td>1</td>
<td>Use ENET system clock.</td>
</tr>
<tr>
<td>29–28</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field must be set to 0.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>27–20</td>
<td>Interrupt coalescing frame count threshold</td>
</tr>
<tr>
<td></td>
<td>This value determines the number of frames needed to be transmitted for raising an interrupt. Frame counter restarts after reaching this threshold value or after the expiring of the coalescing timer. Must be greater than zero to avoid unpredictable behavior.</td>
</tr>
<tr>
<td>19–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field must be set to 0.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>ICTT</td>
<td>Interrupt coalescing timer threshold</td>
</tr>
<tr>
<td></td>
<td>Interrupt coalescing timer threshold in units of 64 clock periods. This value determines the maximum amount of time after transmitting a frame before raising an interrupt. The threshold timer is disabled after expiring or number of frame transmission defined by ICFT and starts again upon transmission of the next first frame. Must be greater than zero to avoid unpredictable behavior.</td>
</tr>
</tbody>
</table>

41.6.15 Receive Interrupt Coalescing Register (ENETx_RXIC)

See Interrupt coalescence for more information.

Address: 402D_4000h base + 100h offset = 402D_4100h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>ICEN</td>
<td>ICCS</td>
<td>Reserved</td>
<td>ICFT</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

ENETx_RXIC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 ICEN</td>
<td>Interrupt Coalescing Enable</td>
</tr>
<tr>
<td>0</td>
<td>Disable Interrupt coalescing.</td>
</tr>
<tr>
<td>1</td>
<td>Enable Interrupt coalescing.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
ENETx_RXIC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>30</td>
<td>Interrupt Coalescing Timer Clock Source Select</td>
</tr>
<tr>
<td>ICCS</td>
<td>0 Use MII/GMII TX clocks. 1 Use ENET system clock.</td>
</tr>
<tr>
<td>29–28</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field must be set to 0.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>27–20</td>
<td>Interrupt coalescing frame count threshold</td>
</tr>
<tr>
<td>ICFT</td>
<td>This value determines the number of frames needed to be received for raising an interrupt. Frame counter restarts after reaching this threshold value or after the expiring of the coalescing timer. Must be greater than zero to avoid unpredictable behavior.</td>
</tr>
<tr>
<td>19–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field must be set to 0.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>ICTT</td>
<td>Interrupt coalescing timer threshold</td>
</tr>
<tr>
<td></td>
<td>Interrupt coalescing timer threshold in units of 64 clock periods. This value determines the maximum amount of time after receiving a frame before raising an interrupt. The threshold timer is disabled after expiring or number of frame reception defined by ICFT and starts again upon reception of the next first frame. Must be greater than zero to avoid unpredictable behavior.</td>
</tr>
</tbody>
</table>

41.6.16 Descriptor Individual Upper Address Register (ENETx_IAUR)

IAUR contains the upper 32 bits of the 64-bit individual address hash table. The address recognition process uses this table to check for a possible match with the destination address (DA) field of receive frames with an individual DA. This register is not reset and you must initialize it.

Address: 402D_4000h base + 118h offset = 402D_4118h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

ENETx_IAUR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IADDR1</td>
<td>Contains the upper 32 bits of the 64-bit hash table used in the address recognition process for receive frames with a unicast address. Bit 31 of IADDR1 contains hash index bit 63. Bit 0 of IADDR1 contains hash index bit 32.</td>
</tr>
</tbody>
</table>
41.6.17 Descriptor Individual Lower Address Register (ENETx_IALR)

IALR contains the lower 32 bits of the 64-bit individual address hash table. The address recognition process uses this table to check for a possible match with the DA field of receive frames with an individual DA. This register is not reset and you must initialize it.

Address: 402D_4000h base + 11Ch offset = 402D_411Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**ENETx_IALR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IADDR2</td>
<td>Contains the lower 32 bits of the 64-bit hash table used in the address recognition process for receive frames with a unicast address. Bit 31 of IADDR2 contains hash index bit 31. Bit 0 of IADDR2 contains hash index bit 0.</td>
</tr>
</tbody>
</table>

41.6.18 Descriptor Group Upper Address Register (ENETx_GAUR)

GAUR contains the upper 32 bits of the 64-bit hash table used in the address recognition process for receive frames with a multicast address. You must initialize this register.

Address: 402D_4000h base + 120h offset = 402D_4120h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**ENETx_GAUR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GADDR1</td>
<td>Contains the upper 32 bits of the 64-bit hash table used in the address recognition process for receive frames with a multicast address. Bit 31 of GADDR1 contains hash index bit 63. Bit 0 of GADDR1 contains hash index bit 32.</td>
</tr>
</tbody>
</table>
41.6.19 Descriptor Group Lower Address Register (ENETx_GALR)

GALR contains the lower 32 bits of the 64-bit hash table used in the address recognition process for receive frames with a multicast address. You must initialize this register.

Address: 402D_4000h base + 124h offset = 402D_4124h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>GADDR2</td>
</tr>
<tr>
<td>30</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>GADDR2</td>
<td>Contains the lower 32 bits of the 64-bit hash table used in the address recognition process for receive frames with a multicast address. Bit 31 of GADDR2 contains hash index bit 31. Bit 0 of GADDR2 contains hash index bit 0.</td>
</tr>
</tbody>
</table>

41.6.20 Transmit FIFO Watermark Register (ENETx_TFWR)

If TFWR[STRFWD] is cleared, TFWR[TFWR] controls the amount of data required in the transmit FIFO before transmission of a frame can begin. This allows you to minimize transmit latency (TFWR = 00 or 01) or allow for larger bus access latency (TFWR = 11) due to contention for the system bus. Setting the watermark to a high value minimizes the risk of transmit FIFO underrun due to contention for the system bus. The byte counts associated with the TFWR field may need to be modified to match a given system requirement, for example, worst-case bus access latency by the transmit data uDMA channel.

When the FIFO level reaches the value the TFWR field and when the STR_FWD is set to ‘0’, the MAC transmit control logic starts frame transmission even before the end-of-frame is available in the FIFO (cut-through operation).

If a complete frame has a size smaller than the threshold programmed with TFWR, the MAC also transmits the Frame to the line.

To enable store and forward on the Transmit path, set STR_FWD to ‘1’ In this case, the MAC starts to transmit data only when a complete frame is stored in the Transmit FIFO.
41.6.21 Receive Descriptor Ring Start Register (ENETx_RDSR)

RDSR points to the beginning of the circular receive buffer descriptor queue in external memory. This pointer must be 64-bit aligned (bits 2–0 must be zero); however, for optimal performance the pointer should be 512-bit aligned, that is, evenly divisible by 64.

**NOTE**

This register must be initialized prior to operation
Address: 402D_4000h base + 180h offset = 402D_4180h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>R_DES_START</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>R_DES_START</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**ENETx_RDSR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>Pointer to the beginning of the receive buffer descriptor queue.</td>
</tr>
<tr>
<td>R_DES_START</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This write-only field is reserved. It must always be written with the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

### 41.6.22 Transmit Buffer Descriptor Ring Start Register (ENETx_TDSR)

TDSR provides a pointer to the beginning of the circular transmit buffer descriptor queue in external memory. This pointer must be 64-bit aligned (bits 2–0 must be zero); however, for optimal performance the pointer should be 512-bit aligned, that is, evenly divisible by 64.

**NOTE**

This register must be initialized prior to operation.

Address: 402D_4000h base + 184h offset = 402D_4184h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>X_DES_START</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>X_DES_START</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Chapter 41 10/100 /1000 -Mbps Ethernet MAC (ENET)**

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
### ENETx_TDSR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3 X_DES_START</td>
<td>Pointer to the beginning of the transmit buffer descriptor queue.</td>
</tr>
<tr>
<td>2 Reserved</td>
<td>This field is reserved. This write-only field is reserved. It must always be written with the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

### 41.6.23 Maximum Receive Buffer Size Register (ENETx_MRBR)

The MRBR is a user-programmable register that dictates the maximum size of all receive buffers. This value should take into consideration that the receive CRC is always written into the last receive buffer.

- **R_BUF_SIZE** is concatenated with the four least-significant bits of this register and are used as the maximum receive buffer size.
- To allow one maximum size frame per buffer, MRBR must be set to RCR[MAX_FL] or larger.
- To properly align the buffer, MRBR must be evenly divisible by 64. To ensure this, set the lower two bits of **R_BUF_SIZE** to zero. The lower four bits of this register are already set to zero by the device.
- To minimize bus usage (descriptor fetches), set MRBR greater than or equal to 256 bytes.

**NOTE**
This register must be initialized before operation.

Address: 402D_4000h base + 188h offset = 402D_4188h

### ENETx_MRBR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–4 R_BUF_SIZE</td>
<td>Receive buffer size in bytes. This value, concatenated with the four least-significant bits of this register (which are always zero), is the effective maximum receive buffer size.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field, which is always zero, is the four least-significant bits of the maximum receive buffer size. This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
### 41.6.24 Receive FIFO Section Full Threshold (ENETx_RSFL)

Address: 402D_4000h base + 190h offset = 402D_4190h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>RX_SECTION_FULL</td>
<td>Value Of Receive FIFO Section Full Threshold</td>
</tr>
<tr>
<td></td>
<td>Value, in 64-bit words, of the receive FIFO section full threshold. Clear this field to enable store and forward on the RX FIFO. When programming a value greater than 0 (cut-through operation), it must be greater than RAEM[RX_ALMOST_EMPTY].</td>
</tr>
<tr>
<td></td>
<td>When the FIFO level reaches the value in this field, data is available in the Receive FIFO (cut-through operation).</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>RX_SECTION_FULL</td>
<td>Value Of Receive FIFO Section Full Threshold</td>
</tr>
<tr>
<td></td>
<td>Value, in 64-bit words, of the receive FIFO section full threshold. Clear this field to enable store and forward on the RX FIFO. When programming a value greater than 0 (cut-through operation), it must be greater than RAEM[RX_ALMOST_EMPTY].</td>
</tr>
<tr>
<td></td>
<td>When the FIFO level reaches the value in this field, data is available in the Receive FIFO (cut-through operation).</td>
</tr>
</tbody>
</table>

### 41.6.25 Receive FIFO Section Empty Threshold (ENETx_RSEM)

Address: 402D_4000h base + 194h offset = 402D_4194h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–21</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>20–16</td>
<td>RX Status FIFO Section Empty Threshold</td>
</tr>
<tr>
<td></td>
<td>Defines number of frames in the receive FIFO, independent of its size, that can be accepted. If the limit is reached, reception will continue normally, however a pause frame will be triggered to indicate a possible congestion to the remote device to avoid FIFO overflow. A value of 0 disables automatic pause frame generation</td>
</tr>
<tr>
<td>15–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>RX_SECTION_EMPTY</td>
<td>Value Of The Receive FIFO Section Empty Threshold</td>
</tr>
<tr>
<td></td>
<td>Value, in 64-bit words, of the receive FIFO section empty threshold. When the FIFO has reached this level, a pause frame will be issued.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–21 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>20–16 STAT SECTION_EMPTY</td>
<td>RX Status FIFO Section Empty Threshold</td>
</tr>
<tr>
<td></td>
<td>Defines number of frames in the receive FIFO, independent of its size, that can be accepted. If the limit is reached, reception will continue normally, however a pause frame will be triggered to indicate a possible congestion to the remote device to avoid FIFO overflow. A value of 0 disables automatic pause frame generation</td>
</tr>
<tr>
<td>15–8 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>RX_SECTION_EMPTY</td>
<td>Value Of The Receive FIFO Section Empty Threshold</td>
</tr>
<tr>
<td></td>
<td>Value, in 64-bit words, of the receive FIFO section empty threshold. When the FIFO has reached this level, a pause frame will be issued.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 41.6.26 Receive FIFO Almost Empty Threshold (ENETx_RAEM)

Address: 402D_4000h base + 198h offset = 402D_4198h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**ENETx_RAEM field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

**RX_ALMOST_EMPTY** Value Of The Receive FIFO Almost Empty Threshold

Value, in 64-bit words, of the receive FIFO almost empty threshold. When the FIFO level reaches the value programmed in this field and the end-of-frame has not been received for the frame yet, the core receive read control stops FIFO read (and subsequently stops transferring data to the MAC client application). It continues to deliver the frame, if again more data than the threshold or the end-of-frame is available in the FIFO. A minimum value of 4 should be set.

### 41.6.27 Receive FIFO Almost Full Threshold (ENETx_RAFL)

Address: 402D_4000h base + 19Ch offset = 402D_419Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**ENETx_RAFL field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

**RX_ALMOST_FULL** Value Of The Receive FIFO Almost Full Threshold

Table continues on the next page...
**ENETx_RAFL field descriptions (continued)**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value, in 64-bit words, of the receive FIFO almost full threshold. When the FIFO level comes close to the maximum, so that there is no more space for at least RX_ALMOST_FULL number of words, the MAC stops writing data in the FIFO and truncates the received frame to avoid FIFO overflow. The corresponding error status will be set when the frame is delivered to the application. A minimum value of 4 should be set.</td>
<td></td>
</tr>
</tbody>
</table>

**41.6.28 Transmit FIFO Section Empty Threshold (ENETx_TSEM)**

Address: 402D_4000h base + 1A0h offset = 402D_41A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–0</td>
<td>0</td>
</tr>
</tbody>
</table>

**ENETx_TSEM field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
<td></td>
</tr>
<tr>
<td>TX_SECTION_EMPTY</td>
<td>Value Of The Transmit FIFO Section Empty Threshold</td>
</tr>
<tr>
<td>Value, in 64-bit words, of the transmit FIFO section empty threshold. See Transmit FIFO for more information.</td>
<td></td>
</tr>
</tbody>
</table>

**41.6.29 Transmit FIFO Almost Empty Threshold (ENETx_TAEM)**

Address: 402D_4000h base + 1A4h offset = 402D_41A4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–0</td>
<td>0</td>
</tr>
</tbody>
</table>

**ENETx_TAEM field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
<td></td>
</tr>
<tr>
<td>TX_ALMOST_EMPTY</td>
<td>Value of Transmit FIFO Almost Empty Threshold</td>
</tr>
<tr>
<td>Value, in 64-bit words, of the transmit FIFO almost empty threshold.</td>
<td></td>
</tr>
<tr>
<td>When the FIFO level reaches the value programmed in this field, and no end-of-frame is available for the frame, the MAC transmit logic, to avoid FIFO underflow, stops reading the FIFO and transmits a frame with an MII error indication. See Transmit FIFO for more information.</td>
<td></td>
</tr>
<tr>
<td>A minimum value of 4 should be set.</td>
<td></td>
</tr>
</tbody>
</table>
41.6.30  Transmit FIFO Almost Full Threshold (ENETx_TAFL)

Address: 402D_4000h base + 1A8h offset = 402D_41A8h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>TX_ALMOST_FULL</td>
<td>Value Of The Transmit FIFO Almost Full Threshold</td>
</tr>
</tbody>
</table>

Value, in 64-bit words, of the transmit FIFO almost full threshold. A minimum value of six is required. A recommended value of at least 8 should be set allowing a latency of two clock cycles to the application. If more latency is required the value can be increased as necessary (latency = TAFL - 5).

When the FIFO level comes close to the maximum, so that there is no more space for at least TX_ALMOST_FULL number of words, the pin ff_tx_rdy is deasserted. If the application does not react on this signal, the FIFO write control logic, to avoid FIFO overflow, truncates the current frame and sets the error status. As a result, the frame will be transmitted with an GMII/MII error indication. See Transmit FIFO for more information.

NOTE: A FIFO overflow is a fatal error and requires a global reset on the transmit datapath or at least deassertion of ETHEREN.

41.6.31  Transmit Inter-Packet Gap (ENETx_TIPG)

Address: 402D_4000h base + 1ACh offset = 402D_41ACh

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>IPG</td>
<td>Transmit Inter-Packet Gap</td>
</tr>
</tbody>
</table>

Indicates the IPG, in bytes, between transmitted frames. Valid values range from 8 to 26. If the written value is less than 8 or greater than 26, the internal (effective) IPG is 12.

NOTE: The IPG value read will be the value that was written, even if it is out of range.
41.6.32  Frame Truncation Length (ENETx_FTRL)

Address: 402D_4000h base + 1B0h offset = 402D_41B0h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

ENETx_FTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TRUNC_FL</td>
<td>Frame Truncation Length</td>
</tr>
<tr>
<td></td>
<td>Indicates the value a receive frame is truncated, if it is greater than this value. Must be greater than or equal to RCR[MAX_FL].</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Truncation happens at TRUNC_FL. However, when truncation occurs, the application (FIFO) may receive less data, guaranteeing that it never receives more than the set limit.</td>
</tr>
</tbody>
</table>

41.6.33  Transmit Accelerator Function Configuration (ENETx_TACC)

TACC controls accelerator actions when sending frames. The register can be changed before or after each frame, but it must remain unmodified during frame writes into the transmit FIFO.

The TFWR[STRFWD] field must be set to use the checksum feature.

Address: 402D_4000h base + 1C0h offset = 402D_41C0h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     | PROCHK| IPRCHK|     | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors 2109
### ENETx_TACC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–5  | Reserved
|       | This field is reserved. This write-only field is reserved. It must always be written with the value 0. |
| 4     | PROCHK
|       | Enables insertion of protocol checksum.  
|       | 0  Checksum not inserted.  
|       | 1  If an IP frame with a known protocol is transmitted, the checksum is inserted automatically into the frame. The checksum field must be cleared. The other frames are not modified. |
| 3     | IPCHK
|       | Enables insertion of IP header checksum.  
|       | 0  Checksum is not inserted.  
|       | 1  If an IP frame is transmitted, the checksum is inserted automatically. The IP header checksum field must be cleared. If a non-IP frame is transmitted the frame is not modified. |
| 2–1   | Reserved
|       | This field is reserved. This write-only field is reserved. It must always be written with the value 0. |
| 0     | SHIFT16
|       | TX FIFO Shift-16  
|       | 0  Disabled.  
|       | 1  Indicates to the transmit data FIFO that the written frames contain two additional octets before the frame data. This means the actual frame begins at bit 16 of the first word written into the FIFO. This function allows putting the frame payload on a 32-bit boundary in memory, as the 14-byte Ethernet header is extended to a 16-byte header. |

### 41.6.34 Receive Accelerator Function Configuration (ENETx_RACC)

Address: 402D_4000h base + 1C4h offset = 402D_41C4h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SHIFT16</td>
<td></td>
<td>LINEDIS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PADREM</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### ENETx_RACC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–8  | Reserved  
|       | This field is reserved. This write-only field is reserved. It must always be written with the value 0. |

Table continues on the next page...
### ENETx_RACC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>7</strong></td>
<td><strong>SHIFT16</strong></td>
</tr>
<tr>
<td></td>
<td>RX FIFO Shift-16</td>
</tr>
<tr>
<td></td>
<td>When this field is set, the actual frame data starts at bit 16 of the first word read from the RX FIFO aligning the Ethernet payload on a 32-bit boundary.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> This function only affects the FIFO storage and has no influence on the statistics, which use the actual length of the frame received.</td>
</tr>
<tr>
<td></td>
<td>0 Disabled.</td>
</tr>
<tr>
<td></td>
<td>1 Instructs the MAC to write two additional bytes in front of each frame received into the RX FIFO.</td>
</tr>
<tr>
<td><strong>6</strong></td>
<td><strong>LINEDIS</strong></td>
</tr>
<tr>
<td></td>
<td>Enable Discard Of Frames With MAC Layer Errors</td>
</tr>
<tr>
<td></td>
<td>0 Frames with errors are not discarded.</td>
</tr>
<tr>
<td></td>
<td>1 Any frame received with a CRC, length, or PHY error is automatically discarded and not forwarded to the user application interface.</td>
</tr>
<tr>
<td><strong>5–3</strong></td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This write-only field is reserved. It must always be written with the value 0.</td>
</tr>
<tr>
<td><strong>2</strong></td>
<td><strong>PRODIS</strong></td>
</tr>
<tr>
<td></td>
<td>Enable Discard Of Frames With Wrong Protocol Checksum</td>
</tr>
<tr>
<td></td>
<td>0 Frames with wrong checksum are not discarded.</td>
</tr>
<tr>
<td></td>
<td>1 If a TCP/IP, UDP/IP, or ICMP/IP frame is received that has a wrong TCP, UDP, or ICMP checksum, the frame is discarded. Discarding is only available when the RX FIFO operates in store and forward mode (RSFL cleared).</td>
</tr>
<tr>
<td><strong>1</strong></td>
<td><strong>IPDIS</strong></td>
</tr>
<tr>
<td></td>
<td>Enable Discard Of Frames With Wrong IPv4 Header Checksum</td>
</tr>
<tr>
<td></td>
<td>0 Frames with wrong IPv4 header checksum are not discarded.</td>
</tr>
<tr>
<td></td>
<td>1 If an IPv4 frame is received with a matching header checksum, the frame is discarded. IPv6 has no header checksum and is not affected by this setting. Discarding is only available when the RX FIFO operates in store and forward mode (RSFL cleared).</td>
</tr>
<tr>
<td><strong>0</strong></td>
<td><strong>PADREM</strong></td>
</tr>
<tr>
<td></td>
<td>Enable Padding Removal For Short IP Frames</td>
</tr>
<tr>
<td></td>
<td>0 Padding not removed.</td>
</tr>
<tr>
<td></td>
<td>1 Any bytes following the IP payload section of the frame are removed from the frame.</td>
</tr>
</tbody>
</table>

### 41.6.35 Reserved Statistic Register (ENETx_RMON_T_DROP)

Address: 402D_4000h base + 200h offset = 402D_4200h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### ENETx_RMON_T_DROP field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Reserved</strong></td>
<td>This read-only field always has the value 0.</td>
</tr>
<tr>
<td>This field is reserved.</td>
<td></td>
</tr>
</tbody>
</table>
41.6.36 Tx Packet Count Statistic Register
(ENETx_RMON_T_PACKETS)

Address: 402D_4000h base + 204h offset = 402D_4204h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**ENETx_RMON_T_PACKETS field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Packet count</td>
</tr>
<tr>
<td></td>
<td>Transmit packet count</td>
</tr>
</tbody>
</table>

41.6.37 Tx Broadcast Packets Statistic Register
(ENETx_RMON_T_BC_PKT)

RMON Tx Broadcast Packets

Address: 402D_4000h base + 208h offset = 402D_4208h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**ENETx_RMON_T_BC_PKT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Broadcast packets</td>
</tr>
</tbody>
</table>
41.6.38  Tx Multicast Packets Statistic Register
(ENETx_RMON_T_MC_PKT)

Address: 402D_4000h base + 20Ch offset = 402D_420Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td></td>
<td>TXPKTS</td>
<td>Multicast packets</td>
</tr>
</tbody>
</table>

41.6.39  Tx Packets with CRC/Align Error Statistic Register
(ENETx_RMON_T_CRC_ALIGN)

Address: 402D_4000h base + 210h offset = 402D_4210h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td></td>
<td>TXPKTS</td>
<td>Packets with CRC/align error</td>
</tr>
</tbody>
</table>

41.6.40  Tx Packets Less Than Bytes and Good CRC Statistic Register
(ENETx_RMON_T_UNDERSIZE)

Address: 402D_4000h base + 214h offset = 402D_4214h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td></td>
<td>TXPKTS</td>
<td>Packets less than bytes</td>
</tr>
</tbody>
</table>

Chapter 41 10/100 /1000 -Mbps Ethernet MAC (ENET)
ENETx_RMON_T_UNDERSIZE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of transmit packets less than 64 bytes with good CRC</td>
</tr>
</tbody>
</table>

41.6.41 Tx Packets GT MAX_FL bytes and Good CRC Statistic Register (ENETx_RMON_T_OVERSIZE)

Address: 402D_4000h base + 218h offset = 402D_4218h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

ENETx_RMON_T_OVERSIZE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of transmit packets greater than MAX_FL bytes with good CRC</td>
</tr>
</tbody>
</table>

41.6.42 Tx Packets Less Than 64 Bytes and Bad CRC Statistic Register (ENETx_RMON_T_FRAG)

Address: 402D_4000h base + 21Ch offset = 402D_421Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

ENETx_RMON_T_FRAG field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of packets less than 64 bytes with bad CRC</td>
</tr>
</tbody>
</table>
41.6.43  Tx Packets Greater Than MAX_FL bytes and Bad CRC
Statistic Register (ENETx_RMON_T_JAB)

Address: 402D_4000h base + 220h offset = 402D_4220h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**ENETx_RMON_T_JAB field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of transmit packets greater than MAX_FL bytes and bad CRC</td>
</tr>
</tbody>
</table>

41.6.44  Tx Collision Count Statistic Register (ENETx_RMON_T_COL)

Address: 402D_4000h base + 224h offset = 402D_4224h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**ENETx_RMON_T_COL field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of transmit collisions</td>
</tr>
</tbody>
</table>

41.6.45  Tx 64-Byte Packets Statistic Register (ENETx_RMON_T_P64)

Address: 402D_4000h base + 228h offset = 402D_4228h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### ENETx_RMON_T_P64 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of 64-byte transmit packets</td>
</tr>
</tbody>
</table>

### 41.6.46 Tx 65- to 127-byte Packets Statistic Register (ENETx_RMON_T_P65TO127)

Address: 402D_4000h base + 22Ch offset = 402D_422Ch

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### ENETx_RMON_T_P65TO127 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of 65- to 127-byte transmit packets</td>
</tr>
</tbody>
</table>

### 41.6.47 Tx 128- to 255-byte Packets Statistic Register (ENETx_RMON_T_P128TO255)

Address: 402D_4000h base + 230h offset = 402D_4230h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### ENETx_RMON_T_P128TO255 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of 128- to 255-byte transmit packets</td>
</tr>
</tbody>
</table>
### 41.6.48 Tx 256- to 511-byte Packets Statistic Register (ENETx_RMON_T_P256TO511)

Address: 402D_4000h base + 234h offset = 402D_4234h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>TXPKTS</td>
<td>Number of 256- to 511-byte transmit packets</td>
</tr>
</tbody>
</table>

### 41.6.49 Tx 512- to 1023-byte Packets Statistic Register (ENETx_RMON_T_P512TO1023)
### 41.6.50 Tx 1024- to 2047-byte Packets Statistic Register (ENETx_RMON_T_P1024TO2047)

Address: 402D_4000h base + 23Ch offset = 402D_423Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–16</th>
<th>15–8</th>
<th>7–0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### ENETx_RMON_T_P1024TO2047 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of 1024- to 2047-byte transmit packets</td>
</tr>
</tbody>
</table>

### 41.6.51 Tx Packets Greater Than 2048 Bytes Statistic Register (ENETx_RMON_T_P_GTE2048)

Address: 402D_4000h base + 240h offset = 402D_4240h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–16</th>
<th>15–8</th>
<th>7–0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### ENETx_RMON_T_P_GTE2048 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TXPKTS</td>
<td>Number of transmit packets greater than 2048 bytes</td>
</tr>
</tbody>
</table>

### 41.6.52 Tx Octets Statistic Register (ENETx_RMON_T_OCTETS)

Address: 402D_4000h base + 244h offset = 402D_4244h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–16</th>
<th>15–8</th>
<th>7–0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset**

0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
### ENETx_RMON_T_OCTETS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>TXOCTS</td>
<td>Number of transmit octets</td>
</tr>
</tbody>
</table>

### 41.6.53 Reserved Statistic Register (ENETx_IEEE_T_DROP)

Address: 402D_4000h base + 248h offset = 402D_4248h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>W</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### ENETx_IEEE_T_DROP field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td>This read-only field always has the value 0.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

### 41.6.54 Frames Transmitted OK Statistic Register (ENETx_IEEE_T_FRAME_OK)

Address: 402D_4000h base + 24Ch offset = 402D_424Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>W</td>
<td>COUNT</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### ENETx_IEEE_T_FRAME_OK field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td>Number of frames transmitted OK</td>
</tr>
</tbody>
</table>

**NOTE:** Does not increment for the broadcast frames when broadcast reject is enabled and promiscuous mode is disabled within the receive control register (RCR).
41.6.55  Frames Transmitted with Single Collision Statistic Register (ENETx_IEEE_T_1COL)

Address: 402D_4000h base + 250h offset = 402D_4250h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>COUNT</td>
</tr>
</tbody>
</table>

ENETx_IEEE_T_1COL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>COUNT</td>
</tr>
</tbody>
</table>

41.6.56  Frames Transmitted with Multiple Collisions Statistic Register (ENETx_IEEE_T_MCOL)

Address: 402D_4000h base + 254h offset = 402D_4254h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>COUNT</td>
</tr>
</tbody>
</table>

ENETx_IEEE_T_MCOL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>COUNT</td>
</tr>
</tbody>
</table>

41.6.57  Frames Transmitted after Deferral Delay Statistic Register (ENETx_IEEE_T_DEF)

Address: 402D_4000h base + 258h offset = 402D_4258h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>COUNT</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### ENETx_IEEE_T_DEF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of frames transmitted with deferral delay</td>
</tr>
</tbody>
</table>

### Frames Transmitted with Late Collision Statistic Register (ENETx_IEEE_T_LCOL)

Address: 402D_4000h base + 25Ch offset = 402D_425Ch

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### ENETx_IEEE_T_LCOL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of frames transmitted with late collision</td>
</tr>
</tbody>
</table>

### Frames Transmitted with Excessive Collisions Statistic Register (ENETx_IEEE_T_EXCOL)

Address: 402D_4000h base + 260h offset = 402D_4260h

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### ENETx_IEEE_T_EXCOL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of frames transmitted with excessive collisions</td>
</tr>
</tbody>
</table>

---

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

2121
### 41.6.60 Frames Transmitted with Tx FIFO Underrun Statistic Register (ENETx_IEEE_T_MACERR)

Address: 402D_4000h base + 264h offset = 402D_4264h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
<td>This field is reserved. It is read-only and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td></td>
<td>Number of frames transmitted with transmit FIFO underrun</td>
</tr>
</tbody>
</table>

### 41.6.61 Frames Transmitted with Carrier Sense Error Statistic Register (ENETx_IEEE_T_CSERR)

Address: 402D_4000h base + 268h offset = 402D_4268h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
<td>This field is reserved. It is read-only and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td></td>
<td>Number of frames transmitted with carrier sense error</td>
</tr>
</tbody>
</table>

### 41.6.62 Reserved Statistic Register (ENETx_IEEE_T_SQE)

Address: 402D_4000h base + 26Ch offset = 402D_426Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
<td>This field is reserved. It is read-only and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td></td>
<td>Number of frames transmitted with carrier sense error</td>
</tr>
</tbody>
</table>

---

Memory map/register definition
### ENETx_IEEE_T_SQE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Counter not implemented as no SQE information is available.</td>
</tr>
</tbody>
</table>

### 41.6.63 Flow Control Pause Frames Transmitted Statistic Register (ENETx_IEEE_T_FDXFC)

Address: 402D_4000h base + 270h offset = 402D_4270h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
</tr>
<tr>
<td>0</td>
<td>COUNT</td>
</tr>
</tbody>
</table>

### ENETx_IEEE_T_FDXFC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of flow-control pause frames transmitted</td>
</tr>
</tbody>
</table>

### 41.6.64 Octet Count for Frames Transmitted w/o Error Statistic Register (ENETx_IEEE_T_OCTETS_OK)

Address: 402D_4000h base + 274h offset = 402D_4274h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>R</td>
</tr>
<tr>
<td>0</td>
<td>COUNT</td>
</tr>
</tbody>
</table>

### ENETx_IEEE_T_OCTETS_OK field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>COUNT</td>
<td>Octet count for frames transmitted without error</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE</strong> Counts total octets (includes header and FCS fields).</td>
</tr>
</tbody>
</table>
Memory map/register definition

41.6.65  Rx Packet Count Statistic Register
(ENETx_RMON_R_PACKETS)

Address: 402D_4000h base + 284h offset = 402D_4284h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**ENETx_RMON_R_PACKETS field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of packets received</td>
</tr>
</tbody>
</table>

41.6.66  Rx Broadcast Packets Statistic Register
(ENETx_RMON_R_BC_PKT)

Address: 402D_4000h base + 288h offset = 402D_4288h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**ENETx_RMON_R_BC_PKT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of receive broadcast packets</td>
</tr>
</tbody>
</table>

41.6.67  Rx Multicast Packets Statistic Register
(ENETx_RMON_R_MC_PKT)

Address: 402D_4000h base + 28Ch offset = 402D_428Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
ENETx_RMON_R_MC_PKT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of receive multicast packets</td>
</tr>
</tbody>
</table>

41.6.68 Rx Packets with CRC/Align Error Statistic Register (ENETx_RMON_R_CRC_ALIGN)

Address: 402D_4000h base + 290h offset = 402D_4290h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

COUNT

ENETx_RMON_R_CRC_ALIGN field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of receive packets with CRC or align error</td>
</tr>
</tbody>
</table>

41.6.69 Rx Packets with Less Than 64 Bytes and Good CRC Statistic Register (ENETx_RMON_R_UNDERSIZE)

Address: 402D_4000h base + 294h offset = 402D_4294h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

COUNT

ENETx_RMON_R_UNDERSIZE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of receive packets with less than 64 bytes and good CRC</td>
</tr>
</tbody>
</table>
41.6.70  Rx Packets Greater Than MAX_FL and Good CRC Statistic Register (ENETx_RMON_R OVERSIZE)

Address: 402D_4000h base + 298h offset = 402D_4298h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

COUNT

ENETx_RMON_R OVERSIZE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of receive packets greater than MAX_FL and good CRC</td>
</tr>
</tbody>
</table>

41.6.71  Rx Packets Less Than 64 Bytes and Bad CRC Statistic Register (ENETx_RMON_R FRAG)

Address: 402D_4000h base + 29Ch offset = 402D_429Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

COUNT

ENETx_RMON_R FRAG field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of receive packets with less than 64 bytes and bad CRC</td>
</tr>
</tbody>
</table>

41.6.72  Rx Packets Greater Than MAX_FL Bytes and Bad CRC Statistic Register (ENETx_RMON_R JAB)

Address: 402D_4000h base + 2A0h offset = 402D_42A0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

COUNT

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
**ENETx_RMON_R_JAB field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of receive packets greater than MAX_FL and bad CRC</td>
</tr>
</tbody>
</table>

**41.6.73 Reserved Statistic Register (ENETx_RMON_R_RESVD_0)**

Address: 402D_4000h base + 2A4h offset = 402D_42A4h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ENETx_RMON_R_RESVD_0 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

**41.6.74 Rx 64-Byte Packets Statistic Register (ENETx_RMON_R_P64)**

Address: 402D_4000h base + 2A8h offset = 402D_42A8h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    | COUNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ENETx_RMON_R_P64 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of 64-byte receive packets</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
NXF Semiconductors
41.6.75  Rx 65- to 127-Byte Packets Statistic Register
(ENETx_RMON_R_P65TO127)

Address: 402D_4000h base + 2ACh offset = 402D_42ACh

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**ENETx_RMON_R_P65TO127 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of 65- to 127-byte receive packets</td>
</tr>
</tbody>
</table>

41.6.76  Rx 128- to 255-Byte Packets Statistic Register
(ENETx_RMON_R_P128TO255)

Address: 402D_4000h base + 2B0h offset = 402D_42B0h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**ENETx_RMON_R_P128TO255 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of 128- to 255-byte receive packets</td>
</tr>
</tbody>
</table>

41.6.77  Rx 256- to 511-Byte Packets Statistic Register
(ENETx_RMON_R_P256TO511)

Address: 402D_4000h base + 2B4h offset = 402D_42B4h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
**ENETx_RMON_R_P256TO511 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of 256- to 511-byte receive packets</td>
</tr>
</tbody>
</table>

**41.6.78 Rx 512- to 1023-Byte Packets Statistic Register (ENETx_RMON_R_P512TO1023)**

Address: 402D_4000h base + 2B8h offset = 402D_42B8h

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ENETx_RMON_R_P512TO1023 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of 512- to 1023-byte receive packets</td>
</tr>
</tbody>
</table>

**41.6.79 Rx 1024- to 2047-Byte Packets Statistic Register (ENETx_RMON_R_P1024TO2047)**

Address: 402D_4000h base + 2BCh offset = 402D_42BCh

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ENETx_RMON_R_P1024TO2047 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of 1024- to 2047-byte receive packets</td>
</tr>
</tbody>
</table>
41.6.80  Rx Packets Greater than 2048 Bytes Statistic Register  
(ENETx_RMON_R_P_GTE2048)  

Address: 402D_4000h base + 2C0h offset = 402D_42C0h  

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

ENETx_RMON_R_P_GTE2048 field descriptions  

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>31</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>30–16</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of greater-than-2048-byte receive packets</td>
</tr>
</tbody>
</table>

41.6.81  Rx Octets Statistic Register  
(ENETx_RMON_R_OCTETS)  

Address: 402D_4000h base + 2C4h offset = 402D_42C4h  

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

ENETx_RMON_R_OCTETS field descriptions  

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>COUNT</td>
<td>Number of receive octets</td>
</tr>
</tbody>
</table>

41.6.82  Frames not Counted Correctly Statistic Register  
(ENETx_IEEE_R_DROP)  

Counter increments if a frame with invalid or missing SFD character is detected and has been dropped. None of the other counters increments if this counter increments.  

Address: 402D_4000h base + 2C8h offset = 402D_42C8h  

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
**ENETx_IEEE_R_DROP field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Frame count</td>
</tr>
</tbody>
</table>

**41.6.83 Frames Received OK Statistic Register (ENETx_IEEE_RFRAME_OK)**

Address: 402D_4000h base + 2CCh offset = 402D_42CCh

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ENETx_IEEE_RFRAME_OK field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of frames received OK</td>
</tr>
</tbody>
</table>

**41.6.84 Frames Received with CRC Error Statistic Register (ENETx_IEEE_R_CRC)**

Address: 402D_4000h base + 2D0h offset = 402D_42D0h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**ENETx_IEEE_R_CRC field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>31–16</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of frames received with CRC error</td>
</tr>
</tbody>
</table>
41.6.85  Frames Received with Alignment Error Statistic Register
(ENETx_IEEE_R_ALIGN)

Address: 402D_4000h base + 2D4h offset = 402D_42D4h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

ENETx_IEEE_R_ALIGN field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of frames received with alignment error</td>
</tr>
</tbody>
</table>

41.6.86  Receive FIFO Overflow Count Statistic Register
(ENETx_IEEE_R_MACERR)

Address: 402D_4000h base + 2D8h offset = 402D_42D8h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

ENETx_IEEE_R_MACERR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Receive FIFO overflow count</td>
</tr>
</tbody>
</table>

41.6.87  Flow Control Pause Frames Received Statistic Register
(ENETx_IEEE_R_FDXFC)

Address: 402D_4000h base + 2DCh offset = 402D_42DCh

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
ENETx_IEEE_R_FDXFC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>COUNT</td>
<td>Number of flow-control pause frames received</td>
</tr>
</tbody>
</table>

41.6.88  Octet Count for Frames Received without Error Statistic Register (ENETx_IEEE_R_OCTETS_OK)

Address: 402D_4000h base + 2E0h offset = 402D_42E0h

ENETx_IEEE_R_OCTETS_OK field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>COUNT</td>
<td>Number of octets for frames received without error</td>
</tr>
</tbody>
</table>
| NOTE:| Counts total octets (includes header and FCS fields). Does not increment for the broadcast frames when broadcast reject is enabled and promiscuous mode is disabled within the receive control register (RCR).

41.6.89  Adjustable Timer Control Register (ENETx_ATCR)

ATCR command fields can trigger the corresponding events directly. It is not necessary to preserve any of the configuration fields when a command field is set in the register, that is, no read-modify-write is required.

NOTE

The CAPTURE and RESTART fields and bits 12 and 10 must be 0 in order to write to the other fields in this register.

Address: 402D_4000h base + 400h offset = 402D_4400h
## ENETx_ATCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 13 SLAVE | Enable Timer Slave Mode  
0 The timer is active and all configuration fields in this register are relevant.  
1 The internal timer is disabled and the externally provided timer value is used. All other fields, except CAPTURE, in this register have no effect. CAPTURE can still be used to capture the current timer value. |
| 12 Reserved | This field is reserved. Always write 0 to this field. |
| 11 CAPTURE | Capture Timer Value  
When this field is set, all other fields are ignored during a write. This field automatically clears to 0 after the command completes.  
0 No effect.  
1 The current time is captured and can be read from the ATVR register. |
| 10 Reserved | This field is reserved. Always write 0 to this field. |
| 9 RESTART | Reset Timer  
Resets the timer to zero. This has no effect on the counter enable. If the counter is enabled when this field is set, the timer is reset to zero and starts counting from there. When set, all other fields are ignored during a write. This field automatically clears to 0 after the command completes. RESTART should be used when the timer is enabled. |
| 8 Reserved | This field is reserved. |
| 7 PINPER | Enables event signal output assertion on period event.  
**NOTE**: Not all devices contain the event signal output. See the chip configuration details.  
0 Disable.  
1 Enable. |
| 6 Reserved | This field is reserved. |
| 5 Reserved | This field is reserved.  
**NOTE**: This field must be written always with one. |
| 4 PEREN | Enable Periodical Event |
### ENETx_ATCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Disable.</td>
</tr>
<tr>
<td>1</td>
<td>A period event interrupt can be generated (EIR[TS_TIMER]) and the event signal output is asserted when the timer wraps around according to the periodic setting ATPER. The timer period value must be set before setting this bit.</td>
</tr>
</tbody>
</table>

**NOTE:** Not all devices contain the event signal output. See the chip configuration details.

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>Reset Timer On Offset Event</td>
</tr>
<tr>
<td>0</td>
<td>The timer is not affected and no action occurs, besides clearing OFFEN, when the offset is reached.</td>
</tr>
<tr>
<td>1</td>
<td>If OFFEN is set, the timer resets to zero when the offset setting is reached. The offset event does not cause a timer interrupt.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>Enable One-Shot Offset Event</td>
</tr>
<tr>
<td>0</td>
<td>Disable.</td>
</tr>
<tr>
<td>1</td>
<td>The timer can be reset to zero when the given offset time is reached (offset event). The field is cleared when the offset event is reached, so no further event occurs until the field is set again. The timer offset value must be set before setting this field.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Enable Timer</td>
</tr>
<tr>
<td>0</td>
<td>The timer stops at the current value.</td>
</tr>
<tr>
<td>1</td>
<td>The timer starts incrementing.</td>
</tr>
</tbody>
</table>

### 41.6.90 Timer Value Register (ENETx_ATVR)

Address: 402D_4000h base + 404h offset = 402D_4404h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>ATIME</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

**ENETx_ATVR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ATIME</td>
<td>A write sets the timer. A read returns the last captured value. To read the current value, issue a capture command (i.e., set ATCR[CAPTURE]) prior to reading this register.</td>
</tr>
</tbody>
</table>

### 41.6.91 Timer Offset Register (ENETx_ATOFF)

Address: 402D_4000h base + 408h offset = 402D_4408h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>OFFSET</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>
### ENETx_ATOFF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>OFFSET</td>
<td>Offset value for one-shot event generation. When the timer reaches the value, an event can be generated to reset the counter. If the increment value in ATINC is given in true nanoseconds, this value is also given in true nanoseconds.</td>
</tr>
</tbody>
</table>

### 41.6.92 Timer Period Register (ENETx_ATPER)

Address: 402D_4000h base + 40Ch offset = 402D_440Ch

#### ENETx_ATPER field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| PERIOD | Value for generating periodic events. Each instance the timer reaches this value, the period event occurs and the timer restarts. If the increment value in ATINC is given in true nanoseconds, this value is also given in true nanoseconds. The value should be initialized to 1,000,000,000 (1×10⁹) to represent a timer wrap around of one second. The increment value set in ATINC should be set to the true nanoseconds of the period of clock ts_clk, hence implementing a true 1 second counter.  

**NOTE:** The value of PERIOD has the following constraint:  
\[ 2^{32} - \text{ENET_ATINC}[\text{INC\_COR}] - 3 \times \text{ENET_ATINC}[\text{INC}] \geq \text{PERIOD} > 0. \]

### 41.6.93 Timer Correction Register (ENETx_ATCOR)

Address: 402D_4000h base + 410h offset = 402D_4410h

#### ENETx_ATCOR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>COR</td>
<td>Correction Counter Wrap-Around Value</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### ENETx_ATCOR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Defines after how many timer clock cycles (ts_clk) the correction counter should be reset and trigger a correction increment on the timer. The amount of correction is defined in ATINC[INC_CORR]. A value of 0 disables the correction counter and no corrections occur.</td>
</tr>
</tbody>
</table>

**NOTE:** This value is given in clock cycles, not in nanoseconds as all other values.

### 41.6.94 Time-Stamping Clock Period Register (ENETx_ATINC)

Address: 402D_4000h base + 414h offset = 402D_4414h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### ENETx_ATINC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–15</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>14–8</td>
<td>Correction Increment Value</td>
</tr>
<tr>
<td>INC_CORR</td>
<td>This value is added every time the correction timer expires (every clock cycle given in ATCOR). A value less than INC slows down the timer. A value greater than INC speeds up the timer.</td>
</tr>
<tr>
<td>7</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>INC</td>
<td>Clock Period Of The Timestamping Clock (ts_clk) In Nanoseconds</td>
</tr>
<tr>
<td></td>
<td>The timer increments by this amount each clock cycle. For example, set to 10 for 100 MHz, 8 for 125 MHz, 5 for 200 MHz.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> For highest precision, use a value that is an integer fraction of the period set in ATPER.</td>
</tr>
</tbody>
</table>

### 41.6.95 Timestamp of Last Transmitted Frame (ENETx_ATSTMP)

Address: 402D_4000h base + 418h offset = 402D_4418h

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R/W  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMESTAMP</td>
<td>Timestamp of the last frame transmitted by the core that had TxBD[TS] set. This register is only valid when EIR[TS_AVAIL] is set.</td>
</tr>
</tbody>
</table>

### 41.6.96 Timer Global Status Register (ENETx_TGSR)

Address: 402D_4000h base + 604h offset = 402D_4604h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### ENETx_TGSR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>TF3</td>
<td>Copy Of Timer Flag For Channel 3</td>
</tr>
<tr>
<td>0</td>
<td>Timer Flag for Channel 3 is clear</td>
</tr>
<tr>
<td>1</td>
<td>Timer Flag for Channel 3 is set</td>
</tr>
<tr>
<td>TF2</td>
<td>Copy Of Timer Flag For Channel 2</td>
</tr>
<tr>
<td>0</td>
<td>Timer Flag for Channel 2 is clear</td>
</tr>
<tr>
<td>1</td>
<td>Timer Flag for Channel 2 is set</td>
</tr>
<tr>
<td>TF1</td>
<td>Copy Of Timer Flag For Channel 1</td>
</tr>
<tr>
<td>0</td>
<td>Timer Flag for Channel 1 is clear</td>
</tr>
<tr>
<td>1</td>
<td>Timer Flag for Channel 1 is set</td>
</tr>
<tr>
<td>TF0</td>
<td>Copy Of Timer Flag For Channel 0</td>
</tr>
<tr>
<td>0</td>
<td>Timer Flag for Channel 0 is clear</td>
</tr>
<tr>
<td>1</td>
<td>Timer Flag for Channel 0 is set</td>
</tr>
</tbody>
</table>
41.6.97 Timer Control Status Register (ENET\textsubscript{x} TCSR\textsubscript{n})

Address: 402D\_4000h base + 608h offset + (8d \times i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 00000000000000000000000000000000

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TPWC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 00000000000000000000000000000000

### ENET\textsubscript{x} TCSR\textsubscript{n} field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>15–11</td>
<td>Timer PulseWidth Control</td>
</tr>
<tr>
<td>TPWC</td>
<td>Specifies the pulse width associated with TMODE values of 1110 or 11X1. Updating this field takes a few cycles to register because it is synchronized to the 1588 clock. When changing this field:</td>
</tr>
<tr>
<td></td>
<td>1. Always disable the channel and read the TMODE field to verify that the channel is disabled.</td>
</tr>
<tr>
<td></td>
<td>2. Set TPWC to the desired value.</td>
</tr>
<tr>
<td></td>
<td>3. Reenable the channel.</td>
</tr>
<tr>
<td></td>
<td>00000 Pulse width is one 1588-clock cycle.</td>
</tr>
<tr>
<td></td>
<td>00001 Pulse width is two 1588-clock cycles.</td>
</tr>
<tr>
<td></td>
<td>00010 Pulse width is three 1588-clock cycles.</td>
</tr>
<tr>
<td></td>
<td>00011 Pulse width is four 1588-clock cycles.</td>
</tr>
<tr>
<td></td>
<td>...</td>
</tr>
<tr>
<td></td>
<td>11111 Pulse width is 32 1588-clock cycles.</td>
</tr>
<tr>
<td>10–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>7</td>
<td>Timer Flag</td>
</tr>
<tr>
<td>TF</td>
<td>Sets when input capture or output compare occurs. This flag is double buffered between the module clock and 1588 clock domains. When this field is 1, it can be cleared to 0 by writing 1 to it.</td>
</tr>
<tr>
<td></td>
<td>0 Input Capture or Output Compare has not occurred.</td>
</tr>
<tr>
<td></td>
<td>1 Input Capture or Output Compare has occurred.</td>
</tr>
<tr>
<td>6</td>
<td>Timer Interrupt Enable</td>
</tr>
<tr>
<td>TIE</td>
<td>0 Interrupt is disabled</td>
</tr>
<tr>
<td></td>
<td>1 Interrupt is enabled</td>
</tr>
<tr>
<td>5–2</td>
<td>Timer Mode</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### ENETx_TCSRn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Updating the Timer Mode field takes a few cycles to register because it is synchronized to the 1588 clock. The version of Timer Mode returned on a read is from the 1588 clock domain. When changing Timer Mode, always disable the channel and read this register to verify the channel is disabled first.</td>
</tr>
<tr>
<td>0000</td>
<td>Timer Channel is disabled.</td>
</tr>
<tr>
<td>0001</td>
<td>Timer Channel is configured for Input Capture on rising edge.</td>
</tr>
<tr>
<td>0010</td>
<td>Timer Channel is configured for Input Capture on falling edge.</td>
</tr>
<tr>
<td>0011</td>
<td>Timer Channel is configured for Input Capture on both edges.</td>
</tr>
<tr>
<td>0100</td>
<td>Timer Channel is configured for Output Compare - software only.</td>
</tr>
<tr>
<td>0101</td>
<td>Timer Channel is configured for Output Compare - toggle output on compare.</td>
</tr>
<tr>
<td>0110</td>
<td>Timer Channel is configured for Output Compare - clear output on compare.</td>
</tr>
<tr>
<td>0111</td>
<td>Timer Channel is configured for Output Compare - set output on compare.</td>
</tr>
<tr>
<td>1000</td>
<td>Reserved</td>
</tr>
<tr>
<td>1010</td>
<td>Timer Channel is configured for Output Compare - clear output on compare, set output on overflow.</td>
</tr>
<tr>
<td>10X1</td>
<td>Timer Channel is configured for Output Compare - set output on compare, clear output on overflow.</td>
</tr>
<tr>
<td>110X</td>
<td>Reserved</td>
</tr>
<tr>
<td>1110</td>
<td>Timer Channel is configured for Output Compare - pulse output low on compare for 1 to 32 1588-clock cycles as specified by TPWC.</td>
</tr>
<tr>
<td>1111</td>
<td>Timer Channel is configured for Output Compare - pulse output high on compare for 1 to 32 1588-clock cycles as specified by TPWC.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
<tr>
<td>TDRE</td>
<td>Timer DMA Request Enable</td>
</tr>
<tr>
<td>0</td>
<td>DMA request is disabled</td>
</tr>
<tr>
<td>1</td>
<td>DMA request is enabled</td>
</tr>
</tbody>
</table>

### 41.6.98 Timer Compare Capture Register (ENETx_TCCRn)

Address: 402D_4000h base + 60Ch offset + (8d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>Reserved</td>
</tr>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### ENETx_TCCRn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCC</td>
<td>Timer Capture Compare</td>
</tr>
<tr>
<td></td>
<td>This register is double buffered between the module clock and 1588 clock domains.</td>
</tr>
<tr>
<td></td>
<td>When configured for compare, the 1588 clock domain updates with the value in the module clock domain whenever the Timer Channel is first enabled and on each subsequent compare. Write to this register with the first compare value before enabling the Timer Channel. When the Timer Channel is enabled, write the second compare value either immediately, or at least before the first compare occurs. After each compare, write the next compare value before the previous compare occurs and before clearing the Timer Flag.</td>
</tr>
</tbody>
</table>
ENET<sub>x</sub>_TCCR<sub>n</sub> field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>The compare occurs one 1588 clock cycle after the IEEE 1588 Counter increments past the compare value in the 1588 clock domain. If the compare value is less than the value of the 1588 Counter when the Timer Channel is first enabled, then the compare does not occur until following the next overflow of the 1588 Counter. If the compare value is greater than the IEEE 1588 Counter when the 1588 Counter overflows, or the compare value is less than the value of the IEEE 1588 Counter after the overflow, then the compare occurs one 1588 clock cycle following the overflow. When configured for capture, the value of the IEEE 1588 Counter is captured into the 1588 clock domain and then updated into the module clock domain, provided the Timer Flag is clear. Always read the capture value before clearing the Timer Flag.</td>
</tr>
</tbody>
</table>

41.7 Functional description

This section provides a complete functional description of the MAC-NET core.

41.7.1 Ethernet MAC frame formats

The IEEE 802.3 standard defines the Ethernet frame format as follows:

- Minimum length of 64 bytes
- Maximum length of 1518 bytes excluding the preamble and the start frame delimiter (SFD) bytes

An Ethernet frame consists of the following fields:

- Seven bytes preamble
- Start frame delimiter (SFD)
- Two address fields
- Length or type field
- Data field
- Frame check sequence (CRC value)
Optionally, MAC frames can be VLAN-tagged with an additional four-byte field inserted between the MAC source address and the type/length field. VLAN tagging is defined by the IEEE P802.1q specification. VLAN-tagged frames have a maximum length of 1522 bytes, excluding the preamble and the SFD bytes.

**Figure 41-3. VLAN-tagged MAC frame format overview**

**Table 41-6. MAC frame definition**

<table>
<thead>
<tr>
<th>Term</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Frame length</td>
<td>Defines the length, in octets, of the complete frame without preamble and SFD. A frame has a valid length if it contains at least 64 octets and does not exceed the programmed maximum length.</td>
</tr>
<tr>
<td>Payload length</td>
<td>The length/type field indicates the length of the frame's payload section. The most significant byte is sent/received first.</td>
</tr>
<tr>
<td></td>
<td>• If the length/type field is set to a value less than 46, the payload is padded so that the minimum frame length requirement (64 bytes) is met. For VLAN-tagged frames, a value less than 42 indicates a padded frame.</td>
</tr>
<tr>
<td></td>
<td>• If the length/type field is set to a value larger than the programmed frame maximum length (e.g. 1518) it is interpreted as a type field.</td>
</tr>
<tr>
<td>Destination and source address</td>
<td>48-bit MAC addresses. The least significant byte is sent/received first and the first two least significant bits of the MAC address distinguish MAC frames, as detailed in MAC address check.</td>
</tr>
</tbody>
</table>
Note

Although the IEEE specification defines a maximum frame length, the MAC core provides the flexibility to program any value for the frame maximum length.

41.7.1.1 Pause Frames

The receiving device generates a pause frame to indicate a congestion to the emitting device, which should stop sending data.

Pause frames are indicated by the length/type set to 0x8808. The two first bytes of a pause frame following the type, defines a 16-bit opcode field set to 0x0001 always. A 16-bit pause quanta is defined in the frame payload bytes 2 (P1) and 3 (P2) as defined in the following table. The P1 pause quanta byte is the most significant.

Table 41-7. Pause Frame Format (Values in Hex)

<table>
<thead>
<tr>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
</tr>
</thead>
<tbody>
<tr>
<td>55</td>
<td>55</td>
<td>55</td>
<td>55</td>
<td>55</td>
<td>55</td>
<td>55</td>
<td>D5</td>
<td>01</td>
<td>80</td>
<td>C2</td>
<td>00</td>
<td>00</td>
<td>01</td>
</tr>
<tr>
<td>15</td>
<td>16</td>
<td>17</td>
<td>18</td>
<td>19</td>
<td>20</td>
<td>21</td>
<td>22</td>
<td>23</td>
<td>24</td>
<td>25</td>
<td>26</td>
<td>27</td>
<td>68</td>
</tr>
<tr>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>00</td>
<td>88</td>
<td>08</td>
<td>00</td>
<td>01</td>
<td>hi</td>
<td>lo</td>
<td>00</td>
<td></td>
</tr>
<tr>
<td>69</td>
<td>70</td>
<td>71</td>
<td>72</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>6B</td>
<td>AE</td>
<td>0A</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CRC-32</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

There is no payload length field found within a pause frame and a pause frame is always padded with 42 bytes (0x00).

If a pause frame with a pause value greater than zero (XOFF condition) is received, the MAC stops transmitting data as soon the current frame transfer is completed. The MAC stops transmitting data for the value defined in pause quanta. One pause quanta fraction refers to 512 bit times.

If a pause frame with a pause value of zero (XON condition) is received, the transmitter is allowed to send data immediately (see Full-duplex flow control operation for details).

41.7.1.2 Magic packets

A magic packet is a unicast, multicast, or broadcast packet, which carries a defined sequence in the payload section.
Magic packets are received and inspected only under specific conditions as described in Magic packet detection.

The defined sequence to decode a magic packet is formed with a synchronization stream which consists of six consecutive 0xFF bytes, and is followed by sequence of sixteen consecutive unicast MAC addresses of the node to be awakened.

This sequence can be located anywhere in the magic packet payload. The magic packet is formed with a standard Ethernet header, optional padding, and CRC.

### 41.7.2 IP and higher layers frame format

The following sections use the term datagram to describe the protocol specific data unit that is found within the payload section of its container entity.

For example, an IP datagram specifies the payload section of an Ethernet frame. A TCP datagram specifies the payload section within an IP datagram.

#### 41.7.2.1 Ethernet types

IP datagrams are carried in the payload section of an Ethernet frame. The Ethernet frame type/length field discriminates several datagram types.

The following table lists the types of interest:

<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x8100</td>
<td>VLAN-tagged frame. The actual type is found 4 octets later in the frame.</td>
</tr>
<tr>
<td>0x0800</td>
<td>IPv4</td>
</tr>
<tr>
<td>0x0806</td>
<td>ARP</td>
</tr>
<tr>
<td>0x86DD</td>
<td>IPv6</td>
</tr>
</tbody>
</table>

#### 41.7.2.2 IPv4 datagram format

The following figure shows the IP Version 4 (IPv4) header, which is located at the beginning of an IP datagram. It is organized in 32-bit words. The first byte sent/received is the leftmost byte of the first word (in other words, version/IHL field).

The IP header can contain further options, which are always padded if necessary to guarantee the payload following the header is aligned to a 32-bit boundary.
The IP header is immediately followed by the payload, which can contain further protocol headers (for example, TCP or UDP, as indicated by the protocol field value). The complete IP datagram is transported in the payload section of an Ethernet frame.

Table 41-9. IPv4 header format

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Version</td>
<td>4-bit IP version information. 0x4 for IPv4 frames.</td>
</tr>
<tr>
<td>IHL</td>
<td>4-bit Internet header length information. Determines number of 32-bit words found within the IP header. If no options are present, the default value is 0x5.</td>
</tr>
<tr>
<td>TOS</td>
<td>Type of service/DiffServ field.</td>
</tr>
<tr>
<td>Length</td>
<td>Total length of the datagram in bytes, including all octets of header and payload.</td>
</tr>
<tr>
<td>Fragment ID</td>
<td>Fields used for IP fragmentation.</td>
</tr>
<tr>
<td>Flags</td>
<td>Time-to-live. In effect, is decremented at each router arrival. If zero, datagram must be discarded.</td>
</tr>
<tr>
<td>Fragment offset</td>
<td>Identifier of protocol that follows in the datagram.</td>
</tr>
<tr>
<td>Protocol</td>
<td>Source address.</td>
</tr>
<tr>
<td>Header checksum</td>
<td>Destination address.</td>
</tr>
<tr>
<td>Options</td>
<td>Options</td>
</tr>
</tbody>
</table>

Table 41-10. IPv4 header fields

<table>
<thead>
<tr>
<th>Field name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Version</td>
<td>4-bit IP version information. 0x4 for IPv4 frames.</td>
</tr>
<tr>
<td>IHL</td>
<td>4-bit Internet header length information. Determines number of 32-bit words found within the IP header. If no options are present, the default value is 0x5.</td>
</tr>
<tr>
<td>TOS</td>
<td>Type of service/DiffServ field.</td>
</tr>
<tr>
<td>Length</td>
<td>Total length of the datagram in bytes, including all octets of header and payload.</td>
</tr>
<tr>
<td>Fragment ID, flags, fragment offset</td>
<td>Fields used for IP fragmentation.</td>
</tr>
<tr>
<td>TTL</td>
<td>Time-to-live. In effect, is decremented at each router arrival. If zero, datagram must be discarded.</td>
</tr>
<tr>
<td>Protocol</td>
<td>Identifier of protocol that follows in the datagram.</td>
</tr>
<tr>
<td>Header checksum</td>
<td>Checksum of IP header. For computational purposes, this field's value is zero.</td>
</tr>
<tr>
<td>Source address</td>
<td>Source IP address.</td>
</tr>
<tr>
<td>Destination address</td>
<td>Destination IP address.</td>
</tr>
</tbody>
</table>

41.7.2.3 IPv6 datagram format

The following figure shows the IP version 6 (IPv6) header, which is located at the beginning of an IP datagram. It is organized in 32-bit words and has a fixed length of ten words (40 bytes). The next header field identifies the type of the header that follows the IPv6 header. It is defined similar to the protocol identifier within IPv4, with new definitions for identifying extension headers. These headers can be inserted between the IPv6 header and the protocol header, which will shift the protocol header accordingly. The accelerator currently only supports IPv6 without extension headers (in other words, the next header specifies TCP, UDP, or IMCP).
The first byte sent/received is the leftmost byte of the first word (in other words, version/traffic class fields).

![Figure 41-4. IPv6 header format](image)

<table>
<thead>
<tr>
<th>Field name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Version</td>
<td>4-bit IP version information. 0x6 for all IPv6 frames.</td>
</tr>
<tr>
<td>Traffic class</td>
<td>8-bit field defining the traffic class.</td>
</tr>
<tr>
<td>Flow label</td>
<td>20-bit flow label identifying frames of the same flow.</td>
</tr>
<tr>
<td>Payload length</td>
<td>16-bit length of the datagram payload in bytes. It includes all octets following the IPv6 header.</td>
</tr>
<tr>
<td>Next header</td>
<td>Identifies the header that follows the IPv6 header. This can be the protocol header or any IPv6 defined extension header.</td>
</tr>
<tr>
<td>Hop limit</td>
<td>Hop counter, decremented by one by each station that forwards the frame. If hop limit is 0 the frame must be discarded.</td>
</tr>
<tr>
<td>Source address</td>
<td>128-bit IPv6 source address.</td>
</tr>
<tr>
<td>Destination address</td>
<td>128-bit IPv6 destination address.</td>
</tr>
</tbody>
</table>

### 41.7.2.4 Internet Control Message Protocol (ICMP) datagram format

An internet control message protocol (ICMP) is found following the IP header, if the protocol identifier is 1. The ICMP datagram has a four-octet header followed by additional message data.

![Table 41-12. ICMP header format](image)
Table 41-13. IP header fields

<table>
<thead>
<tr>
<th>Field name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Type</td>
<td>8-bit type information</td>
</tr>
<tr>
<td>Code</td>
<td>8-bit code that is related to the message type</td>
</tr>
<tr>
<td>Checksum</td>
<td>16-bit one's complement checksum over the complete ICMP datagram</td>
</tr>
</tbody>
</table>

41.7.2.5 User Datagram Protocol (UDP) datagram format

A user datagram protocol header is found after the IP header, when the protocol identifier is 17.

The payload of the datagram is after the UDP header. The header byte order follows the conventions given for the IP header above.

Table 41-14. UDP header format

<table>
<thead>
<tr>
<th>31 30 29 28</th>
<th>27 26 25 24</th>
<th>23 22 21 20</th>
<th>19 18 17 16</th>
<th>15 14 13 12</th>
<th>11 10 9 8</th>
<th>7 6 5 4</th>
<th>3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Source port</td>
<td>Destination port</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Length</td>
<td>Checksum</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 41-15. UDP header fields

<table>
<thead>
<tr>
<th>Field name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Source port</td>
<td>Source application port</td>
</tr>
<tr>
<td>Destination port</td>
<td>Destination application port</td>
</tr>
<tr>
<td>Length</td>
<td>Length of user data which immediately follows the header, including the UDP header (that is, minimum value is 8)</td>
</tr>
<tr>
<td>Checksum</td>
<td>Checksum over the complete datagram and some IP header information</td>
</tr>
</tbody>
</table>

41.7.2.6 TCP datagram format

A TCP header is found following the IP header, when the protocol identifier has a value of 6.

The TCP payload immediately follows the TCP header.

Table 41-16. TCP header format

<table>
<thead>
<tr>
<th>31 30 29 28</th>
<th>27 26 25 24</th>
<th>23 22 21 20</th>
<th>19 18 17 16</th>
<th>15 14 13 12</th>
<th>11 10 9 8</th>
<th>7 6 5 4</th>
<th>3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Source port</td>
<td>Destination port</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 41-16. TCP header format (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sequence</td>
<td>Source application port</td>
</tr>
<tr>
<td>Ack. number</td>
<td>Transmit sequence number</td>
</tr>
<tr>
<td>Offset</td>
<td>Data offset, which is number of 32-bit words within TCP header — if no options selected, defaults to value of 5</td>
</tr>
<tr>
<td>Flags</td>
<td>URG, ACK, PSH, RST, SYN, FIN flags</td>
</tr>
<tr>
<td>Window</td>
<td>TCP receive window size information</td>
</tr>
<tr>
<td>Checksum</td>
<td>Checksum over the complete datagram (TCP header and data) and IP header information</td>
</tr>
<tr>
<td>Options</td>
<td>Additional 32-bit words for protocol options</td>
</tr>
</tbody>
</table>

### Table 41-17. TCP header fields

<table>
<thead>
<tr>
<th>Field name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Source port</td>
<td>Source application port</td>
</tr>
<tr>
<td>Destination port</td>
<td>Destination application port</td>
</tr>
<tr>
<td>Sequence number</td>
<td>Transmit sequence number</td>
</tr>
<tr>
<td>Ack. number</td>
<td>Receive sequence number</td>
</tr>
<tr>
<td>Offset</td>
<td>Data offset, which is number of 32-bit words within TCP header — if no options selected, defaults to value of 5</td>
</tr>
<tr>
<td>Flags</td>
<td>URG, ACK, PSH, RST, SYN, FIN flags</td>
</tr>
<tr>
<td>Window</td>
<td>TCP receive window size information</td>
</tr>
<tr>
<td>Checksum</td>
<td>Checksum over the complete datagram (TCP header and data) and IP header information</td>
</tr>
<tr>
<td>Options</td>
<td>Additional 32-bit words for protocol options</td>
</tr>
</tbody>
</table>

## 41.7.3 IEEE 1588 message formats

The following sections describe the IEEE 1588 message formats.

### 41.7.3.1 Transport encapsulation

The precision time protocol (PTP) datagrams are encapsulated in Ethernet frames using the UDP/IP transport mechanism, or optionally, with the newer 1588v2 directly in Ethernet frames (layer 2).

Typically, multicast addresses are used to allow efficient distribution of the synchronization messages.

#### 41.7.3.1.1 UDP/IP

The 1588 messages (v1 and v2) can be transported using UDP/IP multicast messages.
Table 41-18 shows IP multicast groups defined for PTP. The table also shows their respective MAC layer multicast address mapping according to RFC 1112 (last three octets of IP follow the fixed value of 01-00-5E).

<table>
<thead>
<tr>
<th>Name</th>
<th>IP Address</th>
<th>MAC Address mapping</th>
</tr>
</thead>
<tbody>
<tr>
<td>DefaultPTPdomain</td>
<td>224.0.1.129</td>
<td>01-00-5E-00-01-81</td>
</tr>
<tr>
<td>AlternatePTPdomain1</td>
<td>224.0.1.130</td>
<td>01-00-5E-00-01-82</td>
</tr>
<tr>
<td>AlternatePTPdomain2</td>
<td>224.0.1.131</td>
<td>01-00-5E-00-01-83</td>
</tr>
<tr>
<td>AlternatePTPdomain3</td>
<td>224.0.1.132</td>
<td>01-00-5E-00-01-84</td>
</tr>
</tbody>
</table>

Table 41-19. UDP port numbers

<table>
<thead>
<tr>
<th>Message type</th>
<th>UDP port</th>
<th>Note</th>
</tr>
</thead>
<tbody>
<tr>
<td>Event</td>
<td>319</td>
<td>Used for SYNC and DELAY_REQUEST messages</td>
</tr>
<tr>
<td>General</td>
<td>320</td>
<td>All other messages (for example, follow-up, delay-response)</td>
</tr>
</tbody>
</table>

41.7.3.1.2 Native Ethernet (PTPv2)

In addition to using UDP/IP frames, IEEE 1588v2 defines a native Ethernet frame format that uses ethertype = 0x88F7. The payload of the Ethernet frame immediately contains the PTP datagram, starting with the PTPv2 header.

Besides others, version 2 adds a peer delay mechanism to allow delay measurements between individual point-to-point links along a path over multiple nodes. The following multicast domains are also defined in PTPv2.

<table>
<thead>
<tr>
<th>Name</th>
<th>MAC address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Normal messages</td>
<td>01-1B-19-00-00-00</td>
</tr>
<tr>
<td>Peer delay messages</td>
<td>01-80-C2-00-00-0E</td>
</tr>
</tbody>
</table>

41.7.3.2 PTP header

All PTP frames contain a common header that determines the protocol version and the type of message, which defines the remaining content of the message.

All multi-octet fields are transmitted in big-endian order (the most significant byte is transmitted/received first).
The last four bits of versionPTP are at the same position (second byte) for PTPv1 and PTPv2 headers. This allows accurate identification by inspecting the first two bytes of the message.

### 41.7.3.2.1 PTPv1 header

Table 41-21. Common PTPv1 message header

<table>
<thead>
<tr>
<th>Offset</th>
<th>Octets</th>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>2</td>
<td>versionPTP = 0x0001</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td>versionNetwork</td>
</tr>
<tr>
<td>4</td>
<td>16</td>
<td>subdomain</td>
</tr>
<tr>
<td>20</td>
<td>1</td>
<td>messageType</td>
</tr>
<tr>
<td>21</td>
<td>1</td>
<td>sourceCommunicationTechnology</td>
</tr>
<tr>
<td>22</td>
<td>6</td>
<td>sourceUuid</td>
</tr>
<tr>
<td>28</td>
<td>2</td>
<td>sourcePortId</td>
</tr>
<tr>
<td>30</td>
<td>2</td>
<td>sequenceId</td>
</tr>
<tr>
<td>32</td>
<td>1</td>
<td>control</td>
</tr>
<tr>
<td>33</td>
<td>1</td>
<td>0x00</td>
</tr>
<tr>
<td>34</td>
<td>2</td>
<td>flags</td>
</tr>
<tr>
<td>36</td>
<td>4</td>
<td>reserved</td>
</tr>
</tbody>
</table>

The type of message is encoded in the messageType and control fields as shown in Table 41-22:

Table 41-22. PTPv1 message type identification

<table>
<thead>
<tr>
<th>messageType</th>
<th>control</th>
<th>Message Name</th>
<th>Message</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x01</td>
<td>0x0</td>
<td>SYNC</td>
<td>Event message</td>
</tr>
<tr>
<td>0x01</td>
<td>0x1</td>
<td>DELAY_REQ</td>
<td>Event message</td>
</tr>
<tr>
<td>0x02</td>
<td>0x2</td>
<td>FOLLOW_UP</td>
<td>General message</td>
</tr>
<tr>
<td>0x02</td>
<td>0x3</td>
<td>DELAY_RESP</td>
<td>General message</td>
</tr>
<tr>
<td>0x02</td>
<td>0x4</td>
<td>MANAGEMENT</td>
<td>General message</td>
</tr>
<tr>
<td>other</td>
<td>other</td>
<td>—</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The field sequenceId is used to non-ambiguously identify a message.
41.7.3.2.2 PTPv2 header

Table 41-23. Common PTPv2 message header

<table>
<thead>
<tr>
<th>Offset</th>
<th>Octets</th>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>7</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>2</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>4</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>10</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>2</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>33</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

The type of message is encoded in the field messageId as follows:

Table 41-24. PTPv2 message type identification

<table>
<thead>
<tr>
<th>messageId</th>
<th>Message name</th>
<th>Message</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0</td>
<td>SYNC</td>
<td>Event message</td>
</tr>
<tr>
<td>0x1</td>
<td>DELAY_REQ</td>
<td>Event message</td>
</tr>
<tr>
<td>0x2</td>
<td>PATH_DELAY_REQ</td>
<td>Event message</td>
</tr>
<tr>
<td>0x3</td>
<td>PATH_DELAY_RESP</td>
<td>Event message</td>
</tr>
<tr>
<td>0x4–0x7</td>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>0x8</td>
<td>FOLLOW_UP</td>
<td>General message</td>
</tr>
<tr>
<td>0x9</td>
<td>DELAY_RESP</td>
<td>General message</td>
</tr>
<tr>
<td>0xa</td>
<td>PATH_DELAY_FOLLOW_UP</td>
<td>General message</td>
</tr>
<tr>
<td>0xb</td>
<td>ANNOUNCE</td>
<td>General message</td>
</tr>
<tr>
<td>0xc</td>
<td>SIGNALING</td>
<td>General message</td>
</tr>
<tr>
<td>0xd</td>
<td>MANAGEMENT</td>
<td>General message</td>
</tr>
</tbody>
</table>

The PTPv2 flags field contains further details on the type of message, especially if one-step or two-step implementations are used. The one- or two-step implementation is controlled by the TWO_STEP bit in the first octet of the flags field as shown below. Reserved bits are cleared.
<table>
<thead>
<tr>
<th>Bit</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>ALTERNATE_MASTER</td>
<td>See IEEE 1588 Clause 17.4</td>
</tr>
<tr>
<td>1</td>
<td>TWO_STEP</td>
<td>1 Two-step clock</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 One-step clock</td>
</tr>
<tr>
<td>2</td>
<td>UNICAST</td>
<td>1 Transport layer address uses a unicast destination address</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 Multicast is used</td>
</tr>
<tr>
<td>3</td>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>—</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Profile specific</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Profile specific</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>—</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 41.7.4 MAC receive

The MAC receive engine performs the following tasks:

- Check frame framing
- Remove frame preamble and frame SFD field
- Discard frame based on frame destination address field
- Terminate pause frames
- Check frame length
- Remove payload padding if it exists
- Calculate and verify CRC-32
- Write received frames in the core receive FIFO

If the MAC is programmed to operate in half-duplex mode, it will also check if the frame is received with a collision.
41.7.4.1 Collision detection in half-duplex mode

If the packet is received with a collision detected during reception of the first 64 bytes, the packet is discarded (if frame size was less than ~14 octets) or transmitted to the user application with an error and RxBD[CE] set.

41.7.4.2 Preamble processing

The IEEE 802.3 standard allows a maximum size of 56 bits (seven bytes) for the preamble, while the MAC core allows any preamble length, including zero length preamble.

The MAC core checks for the start frame delimiter (SFD) byte. If the next byte of the preamble, which is different from 0x55, is not 0xD5, the frame is discarded.

Although the IEEE specification dictates that the inner-packet gap should be at least 96 bits, the MAC core is designed to accept frames separated by only 64 10/100-Mbit/s operation (MII) bits.

The MAC core removes the preamble and SFD bytes.
41.7.4.3 MAC address check

The destination address bit 0 differentiates between multicast and unicast addresses.

- If bit 0 is 0, the MAC address is an individual (unicast) address.
- If bit 0 is 1, the MAC address defines a group (multicast) address.
- If all 48 bits of the MAC address are set, it indicates a broadcast address.

41.7.4.3.1 Unicast address check

If a unicast address is received, the destination MAC address is compared to the node MAC address programmed by the host in the PADDR1/2 registers.

If the destination address matches any of the programmed MAC addresses, the frame is accepted.

If Promiscuous mode is enabled (RCR[PROM] = 1) no address checking is performed and all unicast frames are accepted.

41.7.4.3.2 Multicast and unicast address resolution

The hash table algorithm used in the group and individual hash filtering operates as follows.

- The 48-bit destination address is mapped into one of 64 bits, represented by 64 bits in ENETn_GAUR/GALR (group address hash match) or ENETn_IAUR/IALR (individual address hash match).
- This mapping is performed by passing the 48-bit address through the on-chip 32-bit CRC generator and selecting the six most significant bits of the CRC-encoded result to generate a number between 0 and 63.
- The msb of the CRC result selects ENETn_GAUR (msb = 1) or ENETn_GALR (msb = 0).
- The five lsbs of the hash result select the bit within the selected register.
- If the CRC generator selects a bit set in the hash table, the frame is accepted; else, it is rejected.

For example, if eight group addresses are stored in the hash table and random group addresses are received, the hash table prevents roughly 56/64 (or 87.5%) of the group address frames from reaching memory. Those that do reach memory must be further filtered by the processor to determine if they truly contain one of the eight desired addresses.
The effectiveness of the hash table declines as the number of addresses increases.

The user must initialize the hash table registers. Use this CRC32 polynomial to compute the hash:

- FCS(x) = x^{32} + x^{26} + x^{23} + x^{22} + x^{16} + x^{12} + x^{11} + x^{10} + x^{8} + x^{7} + x^{5} + x^{4} + x^{2} + x^{1} + 1

If Promiscuous mode is enabled (ENETn_RCR[PROM] = 1) all unicast and multicast frames are accepted regardless of ENETn_GAUR/GALR and ENETn_IAUR/IALR settings.

### 41.7.4.3.3 Broadcast address reject

All broadcast frames are accepted if BC_REJ is cleared or ENETn_RCR[PROM] is set. If PROM is cleared when ENETn_RCR[BC_REJ] is set, all broadcast frames are rejected.

**Table 41-26. Broadcast address reject programming**

<table>
<thead>
<tr>
<th>PROM</th>
<th>BC_REJ</th>
<th>Broadcast frames</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Accepted</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Rejected</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Accepted</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Accepted</td>
</tr>
</tbody>
</table>

### 41.7.4.3.4 Miss-bit implementation

For higher layer filtering purposes, RxBD[M] indicates an address miss when the MAC operates in promiscuous mode and accepts a frame that would otherwise be rejected.

If a group/individual hash or exact match does not occur and Promiscuous mode is enabled (RCR[PROM] = 1), the frame is accepted and the M bit is set in the buffer descriptor; otherwise, the frame is rejected.

This means the status bit is set in any of the following conditions during Promiscuous mode:

- A broadcast frame is received when BC_REJ is set
- A unicast is received that does not match either:
• Node address (PALR[PADDR1] and PAUR[PADDR2])
• Hash table for unicast (IAUR[IADDR1] and IALR[IADDR2])
• A multicast is received that does not match the GAUR[GADDR1] and GALR[GADDR2] hash table entries

41.7.4.4 Frame length/type verification: payload length check

If the length/type is less than 0x600 and NLC is set, the MAC checks the payload length and reports any error in the frame status word and interrupt bit PLR.

If the length/type is greater than or equal to 0x600, the MAC interprets the field as a type and no payload length check is performed.

The length check is performed on VLAN and stacked VLAN frames. If a padded frame is received, no length check can be performed due to the extended frame payload because padded frames can never have a payload length error.

41.7.4.5 Frame length/type verification: frame length check

When the receive frame length exceeds MAX_FL bytes, the BABR interrupt is generated and the RxBD[LG] bit is set.

The frame is not truncated unless the frame length exceeds the value programmed in ENETn_FTRL[TRUNC_FL]. If the frame is truncated, RxBD[TR] is set. In addition, a truncated frame always has the CRC error indication set (RxBD[CR]).

41.7.4.6 VLAN frames processing

VLAN frames have a length/type field set to 0x8100 immediately followed by a 16-Bit VLAN control information field.

VLAN-tagged frames are received as normal frames because the VLAN tag is not interpreted by the MAC function, and are pushed complete with the VLAN tag to the user application. If the length/type field of the VLAN-tagged frame, which is found four octets later in the frame, is less than 42, the padding is removed. In addition, the frame status word (RxBD[NO]) indicates that the current frame is VLAN tagged.
41.7.4.7 Pause frame termination

The receive engine terminates pause frames and does not transfer them to the receive FIFO. The quanta is extracted and sent to the MAC transmit path via a small internal clock rate decoupling asynchronous FIFO.

The quanta is written only if a correct CRC and frame length are detected by the control state machine. If not, the quanta is discarded and the MAC transmit path is not paused.

Good pause frames are ignored if ENETn_RCR[FCE] is cleared and are forwarded to the client interface when ENETn_RCR[PAUFWD] is set.

41.7.4.8 CRC check

The CRC-32 field is checked and forwarded to the core FIFO interface if ENETn_RCR[CRCFWD] is cleared and ENETn_RCR[PADEN] is cleared. When CRCFWD is set (regardless of PADEN), the CRC-32 field is checked and terminated (not transmitted to the FIFO).

The CRC polynomial, as specified in the 802.3 standard, is:

- FCS(x) = x^{32} + x^{26} + x^{23} + x^{22} + x^{16} + x^{12} + x^{11} + x^{10} + x^{8} + x^{7} + x^{5} + x^{4} + x^{2} + x^{1} + 1

The 32 bits of the CRC value are placed in the frame check sequence (FCS) field with the $x^{31}$ term as right-most bit of the first octet. The CRC bits are thus received in the following order: $x^{31}$, $x^{30}$, ..., $x^{1}$, $x^{0}$.

If a CRC error is detected, the frame is marked invalid and RxBD[CR] is set.

41.7.4.9 Frame padding removal

When a frame is received with a payload length field set to less than 46 (42 for VLAN-tagged frames and 38 for frames with stacked VLANs), the zero padding can be removed before the frame is written into the data FIFO depending on the setting of ENETn_RCR[PADEN].

Note

If a frame is received with excess padding (in other words, the length field is set as mentioned above, but the frame has more than 64 octets) and padding removal is enabled, then the
padding is removed as normal and no error is reported if the frame is otherwise correct (for example: good CRC, less than maximum length, and no other error).

41.7.5 MAC transmit

Frame transmission starts when the transmit FIFO holds enough data.

After a transfer starts, the MAC transmit function performs the following tasks:

- Generates preamble and SFD field before frame transmission
- Generates XOFF pause frames if the receive FIFO reports a congestion or if ENETn_TCR[TFC_PAUSE] is set with ENETn_OPD[PAUSE_DUR] set to a non-zero value
- Generates XON pause frames if the receive FIFO congestion condition is cleared or if TFC_PAUSE is set with PAUSE_DUR cleared
- Suspends Ethernet frame transfer (XOFF) if a non-zero pause quanta is received from the MAC receive path
- Adds padding to the frame if required
- Calculates and appends CRC-32 to the transmitted frame
- Sends the frame with correct inter-packet gap (IPG) (deferring)

When the MAC is configured to operate in half-duplex mode, the following additional tasks are performed:

- Collision detection
- Frame retransmit after back-off timer expires
41.7.5.1 Frame payload padding

The IEEE specification defines a minimum frame length of 64 bytes.

If the frame sent to the MAC from the user application has a size smaller than 60 bytes, the MAC automatically adds padding bytes (0x00) to comply with the Ethernet minimum frame length specification. Transmit padding is always performed and cannot be disabled.

If the MAC is not allowed to append a CRC (TxBD[TC] = 1), the user application is responsible for providing frames with a minimum length of 64 octets.

41.7.5.2 MAC address insertion

On each frame received from the core transmit FIFO interface, the source MAC address is either:

- Replaced by the address programmed in the PADDR1/2 fields (ENETn_TCR[ADDINS] = 1)
- Transparently forwarded to the Ethernet line (ENETn_TCR[ADDINS] = 0)

41.7.5.3 CRC-32 generation

The CRC-32 field is optionally generated and appended at the end of a frame.
The CRC polynomial, as specified in the 802.3 standard, is:

- \( FCS(x) = x^{32} + x^{26} + x^{23} + x^{16} + x^{12} + x^{11} + x^{10} + x^{8} + x^{7} + x^{5} + x^{4} + x^{2} + x^{1} + 1 \)

The 32 bits of the CRC value are placed in the FCS field so that the \( x^{31} \) term is the rightmost bit of the first octet. The CRC bits are thus transmitted in the following order: \( x^{31}, x^{30}, ..., x^1, x^0 \).

### 41.7.5.4 Inter-packet gap (IPG)

In full-duplex mode, after frame transmission and before transmission of a new frame, an IPG (programmed in ENETn_TIPG) is maintained. The minimum IPG can be programmed between 8 and 26 byte-times (64 and 208 bit-times).

In half-duplex mode, the core constantly monitors the line. Actual transmission of the data onto the network occurs only if it has been idle for a 96-bit time period, and any back-off time requirements have been satisfied. In accordance with the standard, the core begins to measure the IPG from CRS de-assertion.

### 41.7.5.5 Collision detection and handling — half-duplex operation only

A collision occurs on a half-duplex network when concurrent transmissions from two or more nodes take place. During transmission, the core monitors the line condition and detects a collision when the PHY device asserts COL.

When the core detects a collision while transmitting, it stops transmission of the data and transmits a 32-bit jam pattern. If the collision is detected during the preamble or the SFD transmission, the jam pattern is transmitted after completing the SFD, which results in a minimum 96-bit fragment. The jam pattern is a fixed pattern that is not compared to the actual frame CRC, and has a very low probability (0.532) of having a jam pattern identical to the CRC.

If a collision occurs before transmission of 64 bytes (including preamble and SFD), the MAC core waits for the backoff period and retransmits the packet data (stored in a 64-byte re-transmit buffer) that has already been sent on the line. The backoff period is generated from a pseudo-random process (truncated binary exponential backoff).

If a collision occurs after transmission of 64 bytes (including preamble and SFD), the MAC discards the remainder of the frame, optionally sets the LC interrupt bit, and sets TxBD[LCE].
Figure 41-7. Packet re-transmit overview

The backoff time is represented by an integer multiple of slot times. One slot is equal to a 512-bit time period. The number of the delay slot times, before the \(n\)th re-transmission attempt, is chosen as a uniformly-distributed random integer in the range:

- \(0 < r < 2^k\)
- \(k = \min(n, N)\); where \(n\) is the number of retransmissions and \(N = 10\)

For example, after the first collision, the backoff period is 0 or 1 slot time. If a collision occurs on the first retransmission, the backoff period is 0, 1, 2, or 3, and so on.

The maximum backoff time (in 512-bit time slots) is limited by \(N = 10\) as specified in the IEEE 802.3 standard.

If a collision occurs after 16 consecutive retransmissions, the core reports an excessive collision condition (ENET\(n\)_EIR[RL] interrupt field and TxBD[EE]) and discards the current packet from the FIFO.

In networks violating the standard requirements, a collision may occur after transmission of the first 64 bytes. In this case, the core stops the current packet transmission and discards the rest of the packet from the transmit FIFO. The core resumes transmission with the next packet available in the core transmit FIFO.

**warning**

Ethernet PHYs that support the SQE Test, or "heartbeat," feature must disable this feature. When this feature is enabled,
the PHY asserts the collision signal after a frame is transmitted to indicate to the ENET that the PHY's collision logic is working. This may cause data corruption in the next frame from the ENET. This corrupted frame contains up to 21 zero bytes which start somewhere within the MAC destination address field. The ENET, however, will still generate a good FCS (CRC-32) but with corrupted data.

41.7.6 Full-duplex flow control operation

Three conditions are handled by the core's flow control engine:

- Remote device congestion — The remote device connected to the same Ethernet segment as the core reports congestion and requests that the core stop sending data.

- Core FIFO congestion — When the core's receive FIFO reaches a user-programmable threshold (RX section empty), the core sends a pause frame back to the remote device requesting the data transfer to stop.

- Local device congestion — Any device connected to the core can request (typically, via the host processor) the remote device to stop transmitting data.

41.7.6.1 Remote device congestion

When the MAC transmit control gets a valid pause quanta from the receive path and if ENETn_RCR[FCE] is set, the MAC transmit logic:

- Completes the transfer of the current frame.

- Stops sending data for the amount of time specified by the pause quanta in 512 bit time increments.

- Sets ENETn_TCR[RFC_PAUSE].

Frame transfer resumes when the time specified by the quanta expires and if no new quanta value is received, or if a new pause frame with a quanta value set to 0x0000 is received. The MAC also resets RFC_PAUSE to zero.

If ENETn_RCR[FCE] cleared, the MAC ignores received pause frames.

Optionally and independent of ENETn_RCR[FCE], pause frames are forwarded to the client interface if PAUFWD is set.
41.7.6.2 Local device/FIFO congestion

The MAC transmit engine generates pause frames when the local receive FIFO is not able to receive more than a pre-defined number of words (FIFO programmable threshold) or when pause frame generation is requested by the local host processor.

- To generate a pause frame, the host processor sets ENETn_TCR[TFC_PAUSE]. A single pause frame is generated when the current frame transfer is completed and TFC_PAUSE is automatically cleared. Optionally, an interrupt is generated.

- An XOFF pause frame is generated when the receive FIFO asserts its section empty flag (internal). An XOFF pause frame is generated automatically, when the current frame transfer completes.

- An XON pause frame is generated when the receive FIFO deasserts its section empty flag (internal). An XON pause frame is generated automatically, when the current frame transfer completes.

When an XOFF pause frame is generated, the pause quanta (payload byte P1 and P2) is filled with the value programmed in ENETn_OPD[PAUSE_DUR].

![Figure 41-8. Pause frame generation overview](image)

**Note**

Although the flow control mechanism should prevent any FIFO overflow on the MAC core receive path, the core receive FIFO is protected. When an overflow is detected on the receive FIFO, the current frame is truncated with an error indication set in the frame status word. The frame should subsequently be discarded by the user application.
41.7.7  Magic packet detection

Magic packet detection wakes a node that is put in power-down mode by the node management agent. Magic packet detection is supported only if the MAC is configured in sleep mode.

41.7.7.1  Sleep mode

To put the MAC in Sleep mode, set ENETn_ECR[SLEEP]. At the same time ENETn_ECR[MAGICEN] should also be set to enable magic packet detection.

In addition, if ENET is enabled, write 1 to ENETn_ECR[SLEEP] before entering into low power mode.

When the MAC is in Sleep mode:

- The transmit logic is disabled.
- The FIFO receive/transmit functions are disabled.
- The receive logic is kept in Normal mode, but it ignores all traffic from the line except magic packets. They are detected so that a remote agent can wake the node.

41.7.7.2  Magic packet detection

The core is designed to detect magic packets (see Magic packets) with the destination address set to:

- Any multicast address
- The broadcast address
- The unicast address programmed in PADDR1/2

When a magic packet is detected, EIR[WAKEUP] is set and none of the statistic registers are incremented.
41.7.7.3  Wakeup

When a magic packet is detected, indicated by ENETₙ_EIR[WAKEUP], ENETₙ_ECR[SLEEP] should be cleared to resume normal operation of the MAC. Clearing the SLEEP bit automatically masks ENETₙ_ECR[MAGICEN], disabling magic packet detection.

41.7.8  IP accelerator functions

The following sections describe the IP accelerator functions.

41.7.8.1  Checksum calculation

The IP and ICMP, TCP, UDP checksums are calculated with one's complement arithmetic summing up 16-bit values.

- For ICMP, the checksum is calculated over the complete ICMP datagram, in other words without IP header.
- For TCP and UDP, the checksums contain the header and data sections and values from the IP header, which can be seen as a pseudo-header that is not actually present in the data stream.

<table>
<thead>
<tr>
<th>Shift</th>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>Source address</td>
</tr>
<tr>
<td>30</td>
<td>1</td>
<td>Destination address</td>
</tr>
<tr>
<td>29</td>
<td>2</td>
<td>Zero</td>
</tr>
<tr>
<td>28</td>
<td>3</td>
<td>Protocol</td>
</tr>
<tr>
<td>27</td>
<td>4</td>
<td>TCP/UDP length</td>
</tr>
<tr>
<td>26</td>
<td>5</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>6</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>7</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>8</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>9</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>10</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>11</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>12</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>13</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>14</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>15</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>16</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>17</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>18</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>19</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>20</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>21</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>22</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>23</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>24</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>25</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>26</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>27</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>28</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>29</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>30</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>31</td>
<td></td>
</tr>
</tbody>
</table>

Table 41-27. IPv4 pseudo-header for checksum calculation

<table>
<thead>
<tr>
<th>Shift</th>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>Source address</td>
</tr>
<tr>
<td>30</td>
<td>1</td>
<td>Destination address</td>
</tr>
<tr>
<td>29</td>
<td>2</td>
<td>TCP/UDP length</td>
</tr>
<tr>
<td>28</td>
<td>3</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>4</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>5</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>6</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>7</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>8</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>9</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>10</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>11</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>12</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>13</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>14</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>15</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>16</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>17</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>18</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>19</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>20</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>21</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>22</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>23</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>24</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>25</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>26</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>27</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>28</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>29</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>30</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>31</td>
<td></td>
</tr>
</tbody>
</table>

Table 41-28. IPv6 pseudo-header for checksum calculation

<table>
<thead>
<tr>
<th>Shift</th>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>Source address</td>
</tr>
<tr>
<td>30</td>
<td>1</td>
<td>Destination address</td>
</tr>
<tr>
<td>29</td>
<td>2</td>
<td>TCP/UDP length</td>
</tr>
<tr>
<td>28</td>
<td>3</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>4</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>5</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>6</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>7</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>8</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>9</td>
<td></td>
</tr>
<tr>
<td>21</td>
<td>10</td>
<td></td>
</tr>
<tr>
<td>20</td>
<td>11</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>12</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>13</td>
<td></td>
</tr>
<tr>
<td>17</td>
<td>14</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>15</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>16</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>17</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>18</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>19</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>20</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>21</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>22</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>23</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>24</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>25</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>26</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>27</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>28</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>29</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>30</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>31</td>
<td></td>
</tr>
</tbody>
</table>
The TCP/UDP length value is the length of the TCP or UDP datagram, which is equal to the payload of an IP datagram. It is derived by subtracting the IP header length from the complete IP datagram length that is given in the IP header (IPv4), or directly taken from the IP header (IPv6). The protocol field is the corresponding value from the IP header. The Zero fields are all zeroes.

For IPv6, the complete 128-bit addresses are considered. The next header value identifies the upper layer protocol as either TCP or UDP. It may differ from the next header value of the IPv6 header if extension headers are inserted before the protocol header.

The checksum calculation uses 16-bit words in network byte order: The first byte sent/received is the MSB, and the second byte sent/received is the LSB of the 16-bit value to add to the checksum. If the frame ends on an odd number of bytes, a zero byte is appended for checksum calculation only, and is not actually transmitted.

### 41.7.8.2 Additional padding processing

According to IEEE 802.3, any Ethernet frame must have a minimum length of 64 octets.

The MAC usually removes padding on receive when a frame with length information is received. Because IP frames have a type value instead of length, the MAC does not remove padding for short IP frames, as it is not aware of the frame contents.

The IP accelerator function can be configured to remove the Ethernet padding bytes that might follow the IP datagram.

On transmit, the MAC automatically adds padding as necessary to fill any frame to a 64-byte length.

### 41.7.8.3 32-bit Ethernet payload alignment

The data FIFOs allow inserting two additional arbitrary bytes in front of a frame. This extends the 14-byte Ethernet header to a 16-byte header, which leads to alignment of the Ethernet payload, following the Ethernet header, on a 32-bit boundary.

This function can be enabled for transmit and receive independently with the corresponding SHIFT16 bits in the ENETn_TACC and ENETn_RACC registers.

When enabled, the valid frame data is arranged as shown in Table 41-29.

| Table 41-29. 64-bit interface data structure with SHIFT16 enabled |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 63 56          | 55 48          | 47 40          | 39 32          | 31 24          | 23 16          | 15 8           | 7 0            |

*Table continues on the next page...*
### 41.7.8.3.1 Receive processing

When ENET\textsubscript{n} RACC[SHIFT16] is set, each frame is received with two additional bytes in front of the frame.

The user application must ignore these first two bytes and find the first byte of the frame in bits 23–16 of the first word from the RX FIFO.

**Note**

SHIFT16 must be set during initialization and kept set during the complete operation, because it influences the FIFO write behavior.

### 41.7.8.3.2 Transmit processing

When ENET\textsubscript{n} TACC[SHIFT16] is set, the first two bytes of the first word written (bits 15–0) are discarded immediately by the FIFO write logic.

The SHIFT16 bit can be enabled/disabled for each frame individually if required, but can be changed only between frames.

### 41.7.8.4 Received frame discard

Because the receive FIFO must be operated in store and forward mode (ENET\textsubscript{n} RSFL cleared), received frames can be discarded based on the following errors:

- The MAC function receives the frame with an error:
  - The frame has an invalid payload length
  - Frame length is greater than MAX\_FL
  - Frame received with a CRC-32 error
  - Frame truncated due to receive FIFO overflow
  - Frame is corrupted as PHY signaled an error (RX\_ERR asserted during reception)
• An IP frame is detected and the IP header checksum is wrong

• An IP frame with a valid IP header and a valid IP header checksum is detected, the protocol is known but the protocol-specific checksum is wrong

If one of the errors occurs and the IP accelerator function is configured to discard frames (ENETn_RACC), the frame is automatically discarded. Statistics are maintained normally and are not affected by this discard function.

### 41.7.8.5 IPv4 fragments

When an IPv4 IP fragment frame is received, only the IP header is inspected and its checksum verified. 32-bit alignment operates the same way on fragments as it does on normal IP frames, as specified above.

The IP fragment frame payload is not inspected for any protocol headers. As such, a protocol header would only exist in the very first fragment. To assist in protocol-specific checksum verification, the one's-complement sum is calculated on the IP payload (all bytes following the IP header) and provided with the frame status word.

The frame fragment status field (RxBD[FRAG]) is set to indicate a fragment reception, and the one's-complement sum of the IP payload is available in RxBD[Payload checksum].

**Note**

After all fragments have been received and reassembled, the application software can take advantage of the payload checksum delivered with the frame's status word to calculate the protocol-specific checksum of the datagram.

For example, if a TCP payload is delivered by multiple IP fragments, the application software can calculate the pseudo-header checksum value from the first fragment, and add the payload checksums delivered with the status for all fragments to verify the TCP datagram checksum.

### 41.7.8.6 IPv6 support

The following sections describe the IPv6 support.
41.7.8.6.1 Receive processing

An Ethernet frame of type 0x86DD identifies an IP Version 6 frame (IPv6) frame. If an IPv6 frame is received, the first IP header is inspected (first ten words), which is available in every IPv6 frame.

If the receive SHIFT16 function is enabled, the IP header is aligned on a 32-bit boundary allowing more efficient processing (see 32-bit Ethernet payload alignment).

For TCP and UDP datagrams, the pseudo-header checksum calculation is performed and verified.

To assist in protocol-specific checksum verification, the one's-complement sum is always calculated on the IP payload (all bytes following the IP header) and provided with the frame status word. For example, if extension headers were present, their sums can be subtracted in software from the checksum to isolate the TCP/UDP datagram checksum, if required.

41.7.8.6.2 Transmit processing

For IPv6 transmission, the SHIFT16 function is supported to process 32-bit aligned datagrams.

IPv6 has no IP header checksum; therefore, the IP checksum insertion configuration is ignored.

The protocol checksum is inserted only if the next header of the IP header is a known protocol (TCP, UDP, or ICMP). If a known protocol is detected, the checksum over all bytes following the IP header is calculated and inserted in the correct position.

The pseudo-header checksum calculation is performed for TCP and UDP datagrams accordingly.

41.7.9 Resets and stop controls

The following sections describe the resets and stop controls.

41.7.9.1 Hardware reset

To reset the Ethernet module, set ENETn_ECR[RESET].

41.7.9.2 Soft reset

When ENET\(_n\)_ECR[ETHER_EN] is cleared during operation, the following occurs:

- uDMA, buffer descriptor, and FIFO control logic are reset, including the buffer descriptor and FIFO pointers.
- A currently ongoing transmit is terminated by asserting TXER to the PHY.
- A currently ongoing transmit FIFO write from the application is terminated by stopping the write to the FIFO, and all further data from the application is ignored. All subsequent writes are ignored until re-enabled.
- A currently ongoing receive FIFO read is terminated. The RxBD has arbitrary values in this case.

41.7.9.3 Hardware freeze

When the processor enters debug mode and ECR[DBGEN] is set, the MAC enters a freeze state where it stops all transmit and receive activities gracefully.

The following happens when the MAC enters hardware freeze:

- A currently ongoing receive transaction on the receive application interface is completed as normal. No further frames are read from the FIFO.
- A currently ongoing transmit transaction on the transmit application interface is completed as normal (in other words, until writing end-of-packet (EOP)).
- A currently ongoing frame receive is completed normally, after which no further frames are accepted from the MII.
- A currently ongoing frame transmit is completed normally, after which no further frames are transmitted.

41.7.9.4 Graceful stop

During a graceful stop, any currently ongoing transactions are completed normally and no further frames are accepted. The MAC can resume from a graceful stop without the need for a reset (for example, clearing ETHER_EN is not required).

The following conditions lead to a graceful stop of the MAC transmit or receive datapaths.
41.7.9.4.1 Graceful transmit stop (GTS)

When gracefully stopped, the MAC is no longer reading frame data from the transmit FIFO and has completed any ongoing transmission.

In any of the following conditions, the transmit datapath stops after an ongoing frame transmission has been completed normally.

- ENETn_TCR[GTS] is set by software.
- ENETn_TCR[TFC_PAUSE] is set by software requesting a pause frame transmission. The status (and register bit) is cleared after the pause frame has been sent.
- A pause frame was received stopping the transmitter. The stopped situation is terminated when the pause timer expires or a pause frame with zero quanta is received.
- MAC is placed in Sleep mode by software or the processor entering Stop mode (see Sleep mode).
- The MAC is in Hardware Freeze mode.

When the transmitter has reached its stopped state, the following events occur:

- The GRA interrupt is asserted, when transitioned into stopped.
- In Hardware Freeze mode, the GRA interrupt does not wait for the application write completion and asserts when the transmit state machine (in other words, line side of TX FIFO) reaches its stopped state.

41.7.9.4.2 Graceful receive stop (GRS)

When gracefully stopped, the MAC is no longer writing frames into the receive FIFO.

The receive datapath stops after any ongoing frame reception has been completed normally, if any of the following conditions occur:

- MAC is placed in Sleep mode either by the software or the processor is in Stop mode). The MAC continues to receive frames and search for magic packets if enabled (see Magic packet detection). However, no frames are written into the receive FIFO, and therefore are not forwarded to the application.
- The MAC is in Hardware Freeze mode. The MAC does not accept any frames from the MII.
When the receive datapath is stopped, the following events occur:

- If the RX is in the stopped state, RCR[GRS] is set
- The GRA interrupt is asserted when the transmitter and receiver are stopped
- Any ongoing receive transaction to the application (RX FIFO read) continues normally until the frame end of package (EOP) is reached. After this, the following occurs:
  - When Sleep mode is active, all further frames are discarded, flushing the RX FIFO
  - In Hardware Freeze mode, no further frames are delivered to the application and they stay in the receive FIFO.

**Note**

The assertion of GRS does not wait for an ongoing FIFO read transaction on the application side of the FIFO (FIFO read).

### 41.7.9.4.3 Graceful stop interrupt (GRA)

The graceful stopped interrupt (GRA) is asserted for the following conditions:

- In Sleep mode, the interrupt asserts only after both TX and RX datapaths are stopped.
- In Hardware Freeze mode, the interrupt asserts only after both TX and RX datapaths are stopped.
- The MAC transmit datapath is stopped for any other condition (GTS, TFC_PAUSE, pause received).

The GRA interrupt is triggered only once when the stopped state is entered. If the interrupt is cleared while the stop condition persists, no further interrupt is triggered.
41.7.10 IEEE 1588 functions

To allow for IEEE 1588 or similar time synchronization protocol implementations, the MAC is combined with a time-stamping module to support precise time-stamping of incoming and outgoing frames. Set ENET\textsubscript{n}_ECR[EN1588] to enable 1588 support.

![Figure 41-9. IEEE 1588 functions overview](image)

41.7.10.1 Adjustable timer module

The adjustable timer module (TSM) implements the free-running counter (FRC), which generates the timestamps. The FRC operates with the time-stamping clock, which can be set to any value depending on your system requirements.

Through dedicated correction logic, the timer can be adjusted to allow synchronization to a remote master and provide a synchronized timing reference to the local system. The timer can be configured to cause an interrupt after a fixed time period, to allow synchronization of software timers or perform other synchronized system functions.

The timer is typically used to implement a period of one second; hence, its value ranges from 0 to \((1 \times 10^9)-1\). The period event can trigger an interrupt, and software can maintain the seconds and hours time values as necessary.

41.7.10.1.1 Adjustable timer implementation

The adjustable timer consists of a programmable counter/accumulator and a correction counter. The periods of both counters and their increment rates are freely configurable, allowing very fine tuning of the timer.
See Timer Synchronization for Multi-Port Implementations, for external clock input options.

The counter produces the current time. During each time-stamping clock cycle, a constant value is added to the current time as programmed in ENETn_ATINC. The value depends on the chosen time-stamping clock frequency. For example, if it operates at 125 MHz, setting the increment to eight represents 8 ns.

The period, configured in ENETn_ATPER, defines the modulo when the counter wraps. In a typical implementation, the period is set to $1 \times 10^9$ so that the counter wraps every second, and hence all timestamps represent the absolute nanoseconds within the one second period. When the period is reached, the counter wraps to start again respecting the period modulo. This means it does not necessarily start from zero, but instead the counter is loaded with the value $(\text{Current} + \text{Inc} - (1 \times 10^9))$, assuming the period is set to $1 \times 10^9$.

The correction counter operates fully independently, and increments by one with each time-stamping clock cycle. When it reaches the value configured in ENETn_ATCOR, it restarts and instructs the timer once to increment by the correction value, instead of the normal value.

The normal and correction increments are configured in ENETn_ATINC. To speed up the timer, set the correction increment more than the normal increment value. To slow down the timer, set the correction increment less than the normal increment value.

The correction counter only defines the distance of the corrective actions, not the amount. This allows very fine corrections and low jitter (in the range of 1 ns) independent of the chosen clock frequency.
By enabling slave mode (ENET\textsubscript{n} ATCR[SLAVE] = 1), the timer is ignored and the current time is externally provided from one of the external modules. See the Chip Configuration details for which clock source is used. This is useful if multiple modules within the system must operate from a single timer (see Timer Synchronization for Multi-Port Implementations). When slave mode is enabled, you still must set ENET\textsubscript{n} ATINC[INC] to the value of the master, since it is used for internal comparisons.

### 41.7.10.2 Timer Synchronization for Multi-Port Implementations

Additional inputs are available to provide a timer value for all time-stamping functions. This is necessary to synchronize the two MACs to a single reference timer. See the Chip Configuration details for available clock inputs to the time-stamping functions. To operate the MAC in slave mode, ENET\textsubscript{n} ATCR[SLAVE] disables the internal adjustable timer and uses the externally provided timer.

### 41.7.10.3 Transmit timestamping

Only 1588 event frames need to be time-stamped on transmit. The client application (for example, the MAC driver) should detect 1588 event frames and set TxBD[TS] together with the frame.

If TxBD[TS] is set, the MAC records the timestamp for the frame in ENET\textsubscript{n} ATSTMP. ENET\textsubscript{n} EIR[TS_AVAIL] is set to indicate that a new timestamp is available.

Software implements a handshaking procedure by setting TxBD[TS] when it transmits the frame for which a timestamp is needed, and then waits for ENET\textsubscript{n} EIR[TS_AVAIL] to determine when the timestamp is available. The timestamp is then read from ENET\textsubscript{n} ATSTMP. This is done for all event frames. Other frames do not use TxBD[TS] and, therefore, do not interfere with the timestamp capture.

### 41.7.10.4 Receive timestamping

When a frame is received, the MAC latches the value of the timer when the frame's start of frame delimiter (SFD) field is detected, and provides the captured timestamp on RxBD[1588 timestamp]. This is done for all received frames.
41.7.10.5 Time synchronization

The adjustable timer module is available to synchronize the local clock of a node to a remote master. It implements a free running 32-bit counter, and also contains an additional correction counter.

The correction counter increases or decreases the rate of the free running counter, enabling very fine granular changes of the timer for synchronization, yet adding only very low jitter when performing corrections.

The application software implements, in a slave scenario, the required control algorithm, setting the correction to compensate for local oscillator drifts and locking the timer to the remote master clock on the network.

The timer and all timestamp-related information should be configured to show the true nanoseconds value of a second (in other words, the timer is configured to have a period of one second). Hence, the values range from 0 to \((1 \times 10^9)–1\). In this application, the seconds counter is implemented in software using an interrupt function that is executed when the nanoseconds counter wraps at \(1 \times 10^9\).

41.7.10.6 Input Capture and Output Compare

The Input Capture Output Compare block can be used to provide precise hardware timing for input and output events.

41.7.10.6.1 Input capture

The TCCR\textsubscript{n} capture registers latch the time value when the corresponding external event occurs. An event can be a rising-, falling-, or either-edge of one of the 1588_TMR\textsubscript{n} signals. An event will cause the corresponding TCSR\textsubscript{n}[TF] timer flag to be set, indicating that an input capture has occurred. If the corresponding interrupt is enabled with the TCSR\textsubscript{n}[TIE] field, an interrupt can be generated.

41.7.10.6.2 Output compare

The TCCR\textsubscript{n} compare registers are loaded with the time at which the corresponding event should occur. When the ENET free-running counter value matches the output compare reference value in the TCCR\textsubscript{n} register, the corresponding flag, TCSR\textsubscript{n}[TF], is set, indicating that an output compare has occurred. The corresponding interrupt, if enabled by TCSR\textsubscript{n}[TIE], will be generated. The corresponding 1588_TMR\textsubscript{n} output signal will be asserted according to TCSR\textsubscript{n}[TMODE].
NOTE
If TSCR\textsubscript{n}[TMODE] is set to 10X1b or 1010b then the timer output pin toggle-on-overflow will occur only when PINPER, PEREN, and EN bits of the ATCR register are one.

41.7.10.6.3 DMA requests
A DMA request can be enabled by setting TCSR\textsubscript{n}[TDRE]. The corresponding DMA request is generated when the TCSR\textsubscript{n}[TF] timer flag is set. When the DMA has completed, the corresponding TCSR\textsubscript{n}[TF] flag is cleared.

41.7.11 FIFO thresholds
The core FIFO thresholds are fully programmable to dynamically change the FIFO operation.

For example, store and forward transfer can be enabled by a simple change in the FIFO threshold registers.

The thresholds are defined in 64-bit words.

The receive and transmit FIFOs both have a depth of 256 words.

41.7.11.1 Receive FIFO
Four programmable thresholds are available, which can be set to any value to control the core operation as follows.

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ENET\textsubscript{n}_RSFL [RX_SECTION_FULL]</td>
<td>When the FIFO level reaches the ENET\textsubscript{n}_RSFL value, the MAC status signal is asserted to indicate that data is available in the receive FIFO (cut-through operation). Once asserted, if the FIFO empties below the threshold set with ENET\textsubscript{n}_RAEM and if the end-of-frame is not yet stored in the FIFO, the status signal is deasserted again. If a frame has a size smaller than the threshold (in other words, an end-of-frame is available for the frame), the status is also asserted. To enable store and forward on the receive path, clear ENET\textsubscript{n}_RSFL. The MAC status signal is asserted only when a complete frame is stored in the receive FIFO. When programming a non-zero value to ENET\textsubscript{n}_RSFL (cut-through operation) it should be greater than ENET\textsubscript{n}_RAEM.</td>
</tr>
<tr>
<td>ENET\textsubscript{n}_RAEM</td>
<td>When the FIFO level reaches the ENET\textsubscript{n}_RAEM value, and the end-of-frame has not been received, the core receive read control stops the FIFO read (and subsequently stops transferring data to the MAC client application).</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 41-30. Receive FIFO thresholds definition (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>[RX_ALMOSTEMPTY]</td>
<td>It continues to deliver the frame, if again more data than the threshold or the end-of-frame is available in the FIFO.</td>
</tr>
<tr>
<td></td>
<td>Set ENET_RAEM to a minimum of six.</td>
</tr>
<tr>
<td>ENET_RAFL</td>
<td>When the FIFO level approaches the maximum and there is no more space remaining for at least ENET_RAFL number of words, the MAC control logic stops writing data in the FIFO and truncates the receive frame to avoid FIFO overflow.</td>
</tr>
<tr>
<td>[RX_ALMOSTFULL]</td>
<td>The corresponding error status is set when the frame is delivered to the application.</td>
</tr>
<tr>
<td></td>
<td>Set ENET_RAFL to a minimum of 4.</td>
</tr>
<tr>
<td>ENET_RSEM</td>
<td>When the FIFO level reaches the ENET_RSEM value, an indication is sent to the MAC transmit logic, which generates an XOFF pause frame. This indicates FIFO congestion to the remote Ethernet client.</td>
</tr>
<tr>
<td>[RX_SECTIONEMPTY]</td>
<td>When the FIFO level goes below the value programmed in ENET_RSEM, an indication is sent to the MAC transmit logic, which generates an XON pause frame. This indicates the FIFO congestion is cleared to the remote Ethernet client.</td>
</tr>
<tr>
<td></td>
<td>Clearing ENET_RSEM disables any pause frame generation.</td>
</tr>
</tbody>
</table>

**Figure 41-11. Receive FIFO overview**

### 41.7.11.2 Transmit FIFO

Four programmable thresholds are available which control the core operation as described below.
### Table 41-31. Transmit FIFO thresholds definition

<table>
<thead>
<tr>
<th>Register</th>
<th>Description</th>
</tr>
</thead>
</table>
| ENET<sub>n</sub>TAEM [TX_ALMOST_EMPTY] | When the FIFO level reaches the ENET<sub>n</sub>TAEM value and no end-of-frame is available for the frame, the MAC transmit logic avoids a FIFO underflow by stopping FIFO reads and transmitting the Ethernet frame with an MII error indication.  
Set ENET<sub>n</sub>TAEM to a minimum of 4. |
| ENET<sub>n</sub>TAFL [TX_ALMOST_FULL] | When the FIFO level approaches the maximum, so that there is no more space for at least ENET<sub>n</sub>TAFL number of words, the MAC deasserts its control signal to the application.  
If the application does not react on this signal, the FIFO write control logic avoids FIFO overflow by truncating the current frame and setting the error status. As a result, the frame is transmitted with an MII error indication.  
Set ENET<sub>n</sub>TAFL to a minimum of 4. Larger values allow more latency for the application to react on the MAC control signal deassertion, before the frame is truncated. A typical setting is 8, which offers 3–4 clock cycles of latency to the application to react on the MAC control signal deassertion. |
| ENET<sub>n</sub>TSEM [TX_SECTION_EMPTY] | When the FIFO level reaches the ENET<sub>n</sub>TSEM value, a MAC status signal is deasserted to indicate that the transmit FIFO is getting full. This gives the ENET module an indication to slow or stop its write transaction to avoid a buffer overflow. This is a pure indication function to the application. It has no effect within the MAC.  
When ENET<sub>n</sub>TSEM is 0, the signal is never deasserted. |
| ENET<sub>n</sub>TFWR | When the FIFO level reaches the ENET<sub>n</sub>TFWR value and when STRFWD is cleared, the MAC transmit control logic starts frame transmission before the end-of-frame is available in the FIFO (cut-through operation).  
If a complete frame has a size smaller than the ENET<sub>n</sub>TFWR threshold, the MAC also transmits the frame to the line.  
To enable store and forward on the transmit path, set STRFWD. In this case, the MAC starts to transmit data only when a complete frame is stored in the transmit FIFO. |

![Figure 41-12. Transmit FIFO overview](image)

**Figure 41-12. Transmit FIFO overview**
41.7.12 Loopback options

The core implements external and internal loopback options, which are controlled by the ENETn_RCR register fields found here.

The core implements external and internal loopback options, which are controlled by the following ENETn_RCR register fields:

<table>
<thead>
<tr>
<th>Register field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOOP</td>
<td>Internal MII loopback. The MAC transmit is returned to the MAC receive. No data is transmitted to the external interfaces. In MII internal loopback, MII_TXCLK and MII_RXCLK must be provided with a clock signal (2.5 MHz for 10 Mbit/s, and 25 MHz for 100 Mbit/s))</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>NOTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>• The legacy buffer descriptor tables show the byte order for little-endian chips. <strong>DBSWP</strong> must be set to 1 after reset to enable little-endian mode.</td>
</tr>
</tbody>
</table>
41.7.13.1 Legacy receive buffer descriptor

The following table shows the legacy FEC receive buffer descriptor. Table 41-36 contains the descriptions for each field.

Table 41-33. Legacy FEC receive buffer descriptor (RxBD)

<table>
<thead>
<tr>
<th>Offset + 0</th>
<th>Byte 1</th>
<th>Offset + 0</th>
<th>Byte 0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>15 14 13 12 11 10 9 8</td>
<td>7 6 5 4 3 2 1 0</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Data length</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 2</td>
<td>E RO1 W RO2 L</td>
<td>M BC MC LG NO CR OV TR</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Rx data buffer pointer — low halfword</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 4</td>
<td>Rx data buffer pointer — high halfword</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

41.7.13.2 Legacy transmit buffer descriptor

The following table shows the legacy FEC transmit buffer descriptor. Table 41-38 contains the descriptions for each field.

Table 41-34. Legacy FEC transmit buffer descriptor (TxBD)

<table>
<thead>
<tr>
<th>Offset + 0</th>
<th>Byte 1</th>
<th>Offset + 0</th>
<th>Byte 0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>15 14 13 12 11 10 9 8</td>
<td>7 6 5 4 3 2 1 0</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Data Length</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 2</td>
<td>R TO1 W TO2 L TC ABC</td>
<td>— — — — — — — —</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Tx Data Buffer Pointer — low halfword</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 4</td>
<td>Tx Data Buffer Pointer — high halfword</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1. This field is not supported by the uDMA.

41.7.14 Enhanced buffer descriptors

This section provides a description of the enhanced operation of the driver/uDMA via the buffer descriptors.

It is followed by a detailed description of the receive and transmit descriptor fields. To enable the enhanced features, set ENETn_ECR[1588EN].

NOTE

The enhanced buffer descriptor tables show the byte order for little-endian chips. DBSVP must be set to 1 after reset to enable little-endian mode.
### 41.7.14.1 Enhanced receive buffer descriptor

The following table shows the enhanced uDMA receive buffer descriptor. Table 41-36 contains the descriptions for each field.

#### Table 41-35. Enhanced uDMA receive buffer descriptor (RxBD)

<table>
<thead>
<tr>
<th>Offset + 0</th>
<th>Byte 1</th>
<th>Offset + 1</th>
<th>(15)</th>
<th>(14)</th>
<th>(13)</th>
<th>(12)</th>
<th>(11)</th>
<th>(10)</th>
<th>(9)</th>
<th>(8)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Data length</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 2</td>
<td>E RO1</td>
<td>W RO2 L</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 4</td>
<td></td>
<td>Rx data buffer pointer – low halfword</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 6</td>
<td></td>
<td>Rx data buffer pointer – high halfword</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 8</td>
<td>VPCP</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + A</td>
<td>ME</td>
<td>—</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + C</td>
<td></td>
<td>Payload checksum</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + E</td>
<td>Header length</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>Offset + 10</td>
<td>—</td>
<td>—</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 12</td>
<td>BDU</td>
<td>—</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 14</td>
<td></td>
<td>1588 timestamp – low halfword</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 16</td>
<td></td>
<td>1588 timestamp – high halfword</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 18</td>
<td>—</td>
<td>—</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 1A</td>
<td>—</td>
<td>—</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 1C</td>
<td>—</td>
<td>—</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset + 1E</td>
<td>—</td>
<td>—</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### Table 41-36. Receive buffer descriptor field definitions

<table>
<thead>
<tr>
<th>Word</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Offset + 0</td>
<td>15–0</td>
<td>Data Length</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Data length. Written by the MAC. Data length is the number of octets written by the MAC into this BD's data buffer if L is cleared (the value is equal to EMRBR), or the length of the frame including CRC if L is set. It is written by the MAC once as the BD is closed.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>15 E</td>
<td>Empty. Written by the MAC (= 0) and user (= 1).</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 The data buffer associated with this BD is filled with received data, or data reception has aborted due to an error condition. The status and length fields have been updated as required.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 The data buffer associated with this BD is empty, or reception is currently in progress.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>14 RO1</td>
<td>Receive software ownership. This field is reserved for use by software. This read/write field is not modified by hardware, nor does its value affect hardware.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>13 W</td>
<td>Wrap. Written by user.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0 The next buffer descriptor is found in the consecutive location.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 The next buffer descriptor is found at the location defined in ENETn_RDSR.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 41-36. Receive buffer descriptor field definitions (continued)

<table>
<thead>
<tr>
<th>Word</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Offset + 2</td>
<td>12</td>
<td>RO2</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Receive software ownership. This field is reserved for use by software. This read/write field is not modified by hardware, nor does its value affect hardware.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>11</td>
<td>L</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Last in frame. Written by the uDMA.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>10–9</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>8</td>
<td>M</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Miss. Written by the MAC. This field is set by the MAC for frames accepted in promiscuous mode, but flagged as a miss by the internal address recognition. Therefore, while in promiscuous mode, you can use this field to quickly determine whether the frame was destined to this station. This field is valid only if the L and PROM bits are set.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>The information needed for this field comes from the promiscuous_miss(ff_rx_err_stat[26]) sideband signal.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>7</td>
<td>BC</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Set if the DA is broadcast (FFFF_FFFF_FFFF).</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>6</td>
<td>MC</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Set if the DA is multicast and not BC.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>5</td>
<td>LG</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Receive frame length violation. Written by the MAC. A frame length greater than RCR[MAX_FL] was recognized. This field is valid only if the L field is set. The receive data is not altered in any way unless the length exceeds TRUNC_FL bytes.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>4</td>
<td>NO</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Receive non-octet aligned frame. Written by the MAC. A frame that contained a number of bits not divisible by 8 was received, and the CRC check that occurred at the preceding byte boundary generated an error or a PHY error occurred. This field is valid only if the L field is set. If this field is set, the CR field is not set.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>3</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>2</td>
<td>CR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Receive CRC or frame error. Written by the MAC. This frame contains a PHY or CRC error and is an integral number of octets in length. This field is valid only if the L field is set.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>1</td>
<td>OV</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Overrun. Written by the MAC. A receive FIFO overrun occurred during frame reception. If this field is set, the other status fields, M, LG, NO, and CR, lose their normal meaning and are zero. This field is valid only if the L field is set.</td>
</tr>
<tr>
<td>Offset + 2</td>
<td>0</td>
<td>TR</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Set if the receive frame is truncated (frame length &gt;TRUNC_FL). If the TR field is set, the frame must be discarded and the other error fields must be ignored because they may be incorrect.</td>
</tr>
<tr>
<td>Offset + 4</td>
<td>15–0</td>
<td>Data buffer pointer low</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Receive data buffer pointer, low halfword</td>
</tr>
<tr>
<td>Offset + 6</td>
<td>15–0</td>
<td>Data buffer pointer high</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Receive data buffer pointer, high halfword</td>
</tr>
<tr>
<td>Offset + 8</td>
<td>15–13</td>
<td>VPCP</td>
</tr>
<tr>
<td></td>
<td></td>
<td>VLAN priority code point. This field is written by the uDMA to indicate the frame priority level. Valid values are from 0 (best effort) to 7 (highest). This value can be used to prioritize different classes of traffic (e.g., voice, video, data). This field is only valid if the L field is set.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 41-36. Receive buffer descriptor field definitions (continued)

<table>
<thead>
<tr>
<th>Offset + 8</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>ICE</td>
<td>IP header checksum error. This is an accelerator option. This field is written by the uDMA. Set when either a non-IP frame is received or the IP header checksum was invalid. An IP frame with less than 3 bytes of payload is considered to be an invalid IP frame. This field is only valid if the L field is set.</td>
</tr>
<tr>
<td>4</td>
<td>PCR</td>
<td>Protocol checksum error. This is an accelerator option. This field is written by the uDMA. Set when the checksum of the protocol is invalid or an unknown protocol is found and checksumming could not be performed. This field is only valid if the L field is set.</td>
</tr>
<tr>
<td>3</td>
<td>VLAN</td>
<td>VLAN. This is an accelerator option. This field is written by the uDMA. It means that the frame has a VLAN tag. This field is valid only if the L field is set.</td>
</tr>
<tr>
<td>1</td>
<td>IPV6</td>
<td>IPV6 Frame. This field is written by the uDMA. This field indicates that the frame has an IPv6 frame type. If this field is not set it means that an IPv4 or other protocol frame was received. This field is valid only if the L field is set.</td>
</tr>
<tr>
<td>0</td>
<td>FRAG</td>
<td>IPv4 Fragment. This is an accelerator option. This field is written by the uDMA. It indicates that the frame is an IPv4 fragment frame. This field is only valid when the L field is set.</td>
</tr>
<tr>
<td>15–11</td>
<td>ME</td>
<td>MAC error. This field is written by the uDMA. This field means that the frame stored in the system memory was received with an error (typically, a receive FIFO overflow). This field is only valid when the L field is set.</td>
</tr>
<tr>
<td>14–11</td>
<td></td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>10</td>
<td>PE</td>
<td>PHY Error. This field is written by the uDMA. Set to “1” when the frame was received with an Error character on the PHY interface. The frame is invalid. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>9</td>
<td>CE</td>
<td>Collision. This field is written by the uDMA. Set when the frame was received with a collision detected during reception. The frame is invalid and sent to the user application. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>8</td>
<td>UC</td>
<td>Unicast. This field is written by the uDMA, and means that the frame is unicast. This field is valid regardless of whether the L field is set.</td>
</tr>
<tr>
<td>7</td>
<td>INT</td>
<td>Generate RXB/RXF interrupt. This field is set by the user to indicate that the uDMA is to generate an interrupt on the dma_int_rxb / dma_int_rxfevent.</td>
</tr>
<tr>
<td>6–0</td>
<td></td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>15–0</td>
<td>Payload checksum</td>
<td>Internet payload checksum. This is an accelerator option. It is the one’s complement sum of the payload section of the IP frame. The sum is calculated over all data following the IP header until the end of the IP payload. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>15–11</td>
<td>Header length</td>
<td>Header length. This is an accelerator option. This field is written by the uDMA. This field is the sum of 32-bit words found within the IP and its following protocol headers. If an IP datagram with an unknown protocol is found, then the value is the length of the IP header. If no IP frame or an erroneous IP header is found, the value is 0. The following values are minimum values if no header options exist in the respective headers:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• ICMP/IP: 6 (5 IP header, 1 ICMP header)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• UDP/IP: 7 (5 IP header, 2 UDP header)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• TCP/IP: 10 (5 IP header, 5 TCP header)</td>
</tr>
</tbody>
</table>

This field is only valid if the L field is set.

Table continues on the next page...
### Table 41-36. Receive buffer descriptor field definitions (continued)

<table>
<thead>
<tr>
<th>Word</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Offset + E</td>
<td>10–8</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + E</td>
<td>7–0 Protocol type</td>
<td>Protocol type. This is an accelerator option. The 8-bit protocol field found within the IP header of the frame. It is valid only when ICE is cleared. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>Offset + 10</td>
<td>15–0</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + 12</td>
<td>15 BDU</td>
<td>Last buffer descriptor update done. Indicates that the last BD data has been updated by uDMA. This field is written by the user (=0) and uDMA (=1).</td>
</tr>
<tr>
<td>Offset + 14</td>
<td>15–0</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + 16</td>
<td>1588 timestamp</td>
<td>This value is written by the uDMA. It is only valid if the L field is set.</td>
</tr>
<tr>
<td>Offset + 18</td>
<td>15–0</td>
<td>Reserved, must be cleared.</td>
</tr>
</tbody>
</table>

### 41.7.14.2 Enhanced transmit buffer descriptor

#### Table 41-37. Enhanced transmit buffer descriptor (TxBD)

<table>
<thead>
<tr>
<th>Offset + 0</th>
<th>Byte 1</th>
<th>Byte 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</td>
<td>Data length</td>
<td></td>
</tr>
<tr>
<td>Offset + 2</td>
<td>R TO1 W TO2 L TC</td>
<td>Tx Data Buffer Pointer – low halfword</td>
</tr>
<tr>
<td>Offset + 4</td>
<td></td>
<td>Tx Data Buffer Pointer – high halfword</td>
</tr>
<tr>
<td>Offset + 8</td>
<td>TXE UE EE FE LCE OE TSE</td>
<td></td>
</tr>
<tr>
<td>Offset + A</td>
<td>— INT TS PINS IINS</td>
<td></td>
</tr>
<tr>
<td>Offset + C</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>Offset + E</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>Offset + 10</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>Offset + 12</td>
<td>BDU</td>
<td></td>
</tr>
<tr>
<td>Offset + 14</td>
<td>1588 timestamp – low halfword</td>
<td></td>
</tr>
<tr>
<td>Offset + 16</td>
<td>1588 timestamp – high halfword</td>
<td></td>
</tr>
<tr>
<td>Offset + 18</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>Offset + 1A</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>Offset + 1C</td>
<td>—</td>
<td></td>
</tr>
<tr>
<td>Offset + 1E</td>
<td>—</td>
<td></td>
</tr>
</tbody>
</table>
### Table 41-38. Enhanced transmit buffer descriptor field definitions

<table>
<thead>
<tr>
<th>Word</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Offset + 0</td>
<td>15–0 Data Length</td>
<td>Data length, written by user. Data length is the number of octets the MAC should transmit from this BD's data buffer. It is never modified by the MAC.</td>
</tr>
</tbody>
</table>
| Offset + 2 | 15 R Ready     | Ready. Written by the MAC and you.  
0 The data buffer associated with this BD is not ready for transmission. You are free to manipulate this BD or its associated data buffer. The MAC clears this field after the buffer has been transmitted or after an error condition is encountered.  
1 The data buffer, prepared for transmission by you, has not been transmitted or currently transmits. You may write no fields of this BD after this field is set. |
| Offset + 2 | 14 TO1 Transmit software ownership | This field is reserved for software use. This read/write field is not modified by hardware and its value does not affect hardware.                                                                              |
| Offset + 2 | 13 W Wrap      | Wrap. Written by user.  
0 The next buffer descriptor is found in the consecutive location  
1 The next buffer descriptor is found at the location defined in ETDSR.                                                                                                                                   |
| Offset + 2 | 12 TO2 Transmit software ownership | This field is reserved for use by software. This read/write field is not modified by hardware and its value does not affect hardware.                                                                              |
| Offset + 2 | 11 L Last in frame | Last in frame. Written by user.  
0 The buffer is not the last in the transmit frame  
1 The buffer is the last in the transmit frame                                                                                                                                                    |
| Offset + 2 | 10 TC Transmit CRC | Transmit CRC. Written by user, and valid only when L is set.  
0 End transmission immediately after the last data byte  
1 Transmit the CRC sequence after the last data byte  
This field is valid only when the L field is set.                                                                                                                                                    |
| Offset + 2 | 9 ABC Append bad CRC | Note: This field is not supported by the uDMA and is ignored.                                                                                                                                                |
| Offset + 2 | 8–0 Reserved, must be cleared |                                                                                                                                                                                                             |
| Offset + 4 | 15–0 Data buffer pointer low | Tx data buffer pointer, low halfword                                                                                                                                                                         |
| Offset + 6 | 15–0 Data buffer pointer high | Tx data buffer pointer, high halfword. The buffer must reside in memory external to the MAC. This value is never modified by the Ethernet controller.  
**NOTE:** For optimal performance, make the transmit buffer pointer evenly divisible by 64.                                                                                                         |
| Offset + 8 | 15 TXE Transmit error occurred | This field is written by the uDMA. This field indicates that there was a transmit error of some sort reported with the frame. Effectively this field is an OR of the other error fields including UE, EE, FE, LCE, OE, and TSE. This field is valid only when the L field is set. |
| Offset + 8 | 14 UE Underflow error | Underflow error. This field is written by the uDMA. This field indicates that the MAC reported an underflow error on transmit. This field is valid only when the L field is set. |

*Table continues on the next page*...
### Table 41-38. Enhanced transmit buffer descriptor field definitions (continued)

<table>
<thead>
<tr>
<th>Word</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Offset + 8</td>
<td>12 EE</td>
<td>Excess Collision error. This field is written by the uDMA. This field indicates that the MAC reported an excess collision error on transmit. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>Offset + 8</td>
<td>11 FE</td>
<td>Frame with error. This field is written by the uDMA. This field indicates that the MAC reported that the uDMA reported an error when providing the packet. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>Offset + 8</td>
<td>10 LCE</td>
<td>Late collision error. This field is written by the uDMA. This field indicates that the MAC reported that there was a Late Collision on transmit. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>Offset + 8</td>
<td>9 OE</td>
<td>Overflow error. This field is written by the uDMA. This field indicates that the MAC reported that there was a FIFO overflow condition on transmit. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>Offset + 8</td>
<td>8 TSE</td>
<td>Timestamp error. This field is written by the uDMA. This field indicates that the MAC reported a different frame type then a timestamp frame. This field is valid only when the L field is set.</td>
</tr>
<tr>
<td>Offset + 8</td>
<td>7–0</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + A</td>
<td>15 INT</td>
<td>Generate interrupt flags. This field is written by the user. This field is valid regardless of the L field and must be the same for all EBD for a given frame. The uDMA does not update this value.</td>
</tr>
<tr>
<td>Offset + A</td>
<td>13 TS</td>
<td>Timestamp. This field is written by the user. This indicates that the uDMA is to generate a timestamp frame to the MAC. This field is valid regardless of the L field and must be the same for all EBD for the given frame. The uDMA does not update this value.</td>
</tr>
<tr>
<td>Offset + A</td>
<td>12 PINS</td>
<td>Insert protocol specific checksum. This field is written by the user. If set, the MAC's IP accelerator calculates the protocol checksum and overwrites the corresponding checksum field with the calculated value. The checksum field must be cleared by the application generating the frame. The uDMA does not update this value. This field is valid regardless of the L field and must be the same for all EBD for a given frame.</td>
</tr>
<tr>
<td>Offset + A</td>
<td>11 IINS</td>
<td>Insert IP header checksum. This field is written by the user. If set, the MAC's IP accelerator calculates the IP header checksum and overwrites the corresponding header field with the calculated value. The checksum field must be cleared by the application generating the frame. The uDMA does not update this value. This field is valid regardless of the L field and must be the same for all EBD for a given frame.</td>
</tr>
<tr>
<td>Offset + A</td>
<td>10–0</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + C</td>
<td>15–0</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + E</td>
<td>15–0</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + 10</td>
<td>15 BDU</td>
<td>Last buffer descriptor update done. Indicates that the last BD data has been updated by uDMA. This field is written by the user (≠0) and uDMA (≠1).</td>
</tr>
<tr>
<td>Offset + 12</td>
<td>14–0</td>
<td>Reserved, must be cleared.</td>
</tr>
<tr>
<td>Offset + 14</td>
<td>15–0</td>
<td>This value is written by the uDMA. It is valid only when the L field is set.</td>
</tr>
<tr>
<td>Offset + 16</td>
<td>1588 timestamp</td>
<td></td>
</tr>
</tbody>
</table>
41.7.15 Client FIFO application interface

The FIFO interface is completely asynchronous from the Ethernet line, and the transmit and receive interface can operate at a different clock rate.

All transfers to/from the user application are handled independently of the core operation, and the core provides a simple interface to user applications based on a two-signal handshake.

41.7.15.1 Data structure description

The data structure defined in the following tables for the FIFO interface must be respected to ensure proper data transmission on the Ethernet line. Byte 0 is sent to and received from the line first.

<table>
<thead>
<tr>
<th>Word 0</th>
<th>63</th>
<th>56</th>
<th>55</th>
<th>48</th>
<th>47</th>
<th>40</th>
<th>39</th>
<th>32</th>
<th>31</th>
<th>24</th>
<th>23</th>
<th>16</th>
<th>15</th>
<th>8</th>
<th>7</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Byte 7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Word 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 15</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 13</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 11</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Byte 8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

The size of a frame on the FIFO interface may not be a modulo of 64-bit.

The user application may not care about the Ethernet frame formats in full detail. It needs to provide and receive an Ethernet frame with the following structure:

- Ethernet MAC destination address
- Ethernet MAC source address
- Optional 802.1q VLAN tag (VLAN type and info field)
- Ethernet length/type field
- Payload

Frames on the FIFO interface do not contain preamble and SFD fields, which are inserted and discarded by the MAC on transmit and receive, respectively.
• On receive, CRC and frame padding can be stripped or passed through transparently.
• On transmit, padding and CRC can be provided by the user application, or appended automatically by the MAC independently for each frame. No size restrictions apply.

**Note**

On transmit, if ENET\_TCR[ADDINS] is set, bytes 6–11 of each frame can be set to any value, since the MAC overwrites the bytes with the MAC address programmed in the ENET\_PAUR and ENET\_PALR registers.

**Table 41-40. FIFO interface frame format**

<table>
<thead>
<tr>
<th>Byte number</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0–5</td>
<td>Destination MAC address</td>
</tr>
<tr>
<td>6–11</td>
<td>Source MAC address</td>
</tr>
<tr>
<td>12–13</td>
<td>Length/type field</td>
</tr>
<tr>
<td>14–N</td>
<td>Payload data</td>
</tr>
</tbody>
</table>

VLAN-tagged frames are supported on both transmit and receive, and implement additional information (VLAN type and info).

**Table 41-41. FIFO interface VLAN frame format**

<table>
<thead>
<tr>
<th>Byte number</th>
<th>Field</th>
</tr>
</thead>
<tbody>
<tr>
<td>0–5</td>
<td>Destination MAC address</td>
</tr>
<tr>
<td>6–11</td>
<td>Source MAC address</td>
</tr>
<tr>
<td>12–15</td>
<td>VLAN tag and info</td>
</tr>
<tr>
<td>16–17</td>
<td>Length/type field</td>
</tr>
<tr>
<td>18–N</td>
<td>Payload data</td>
</tr>
</tbody>
</table>

**Note**

The standard defines that the LSB of the MAC address is sent/received first, while for all the other header fields — in other words, length/type, VLAN tag, VLAN info, and pause quanta — the MSB is sent/received first.

**41.7.15.2 Data structure examples**
If CRC forwarding is enabled \((\text{CRCFWD} = 0)\), the last four valid octets of the frame contain the FCS field. The non-significant bytes of the last word can have any value.

### 41.7.15.3 Frame status

A MAC layer status word and an accelerator status word is available in the receive buffer descriptor.

See Enhanced buffer descriptors for details.

The status is available with each frame with the last data of the frame.

If the frame status contains a MAC layer error (for example, CRC or length error), \(\text{RxBD}[\text{ME}]\) is also set with the last data of the frame.
41.7.16 FIFO protection

The following sections describe the FIFO protection mechanisms.

41.7.16.1 Transmit FIFO underflow

During a frame transfer, when the transmit FIFO reaches the almost empty threshold with no end-of-frame indication stored in the FIFO, the MAC logic:

- Stops reading data from the FIFO
- Asserts the MII error signal (MII_TXER) (1 in Figure 41-16) to indicate that the fragment already transferred is not valid
- Deasserts the MII transmit enable signal (MII_TXEN) to terminate the frame transfer (2)

After an underflow, when the application completes the frame transfer (3), the MAC transmit logic discards any new data available in the FIFO until the end of packet is reached (4) and sets the enhanced TxBD[UE] field.

The MAC starts to transfer data on the MII interface when the application sends a new frame with a start of frame indication (5).

![Figure 41-16. Transmit FIFO underflow protection](image-url)
## 41.7.16.2 Transmit FIFO overflow

On the transmit path, when the FIFO reaches the programmable almost full threshold, the internal MAC ready signal is deasserted. The application should stop sending new data.

However, if the application keeps sending data, the transmit FIFO overflows, corrupting contents that were previously stored. The core logic sets the enhanced TxBD[OE] field for the next frame transmitted to indicate this overflow occurrence.

**Note**

Overflow is a fatal error and must be addressed by resetting the core or clearing ENETn_ECR[ETHER_EN], to clear the FIFOs and prepare for normal operation again.

## 41.7.16.3 Receive FIFO overflow

During a frame reception, if the client application is not able to receive data (1), the MAC receive control truncates the incoming frame when the FIFO reaches the programmable almost-full threshold to avoid an overflow.

The frame is subsequently received on the FIFO interface with an error indication (enhanced RxBD[ME] field set together with receive end-of-packet) (2) with the truncation error status field set (3).

![Figure 41-17. Receive FIFO overflow protection](image)

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
41.7.17 PHY management interface

The MDIO interface is a two-wire management interface. The MDIO management interface implements a standardized method to access the PHY device management registers.

The core implements a master MDIO interface, which can be connected to up to 32 PHY devices.

41.7.17.1 MDIO clause 22 frame format

The core MDIO master controller communicates with the slave (PHY device) using frames that are defined in the following table.

A complete frame has a length of 64 bits made up of an optional 32-bit preamble, 14-bit command, 2-bit bus direction change, and 16-bit data. Each bit is transferred on the rising edge of the MDIO clock (MDC signal). The MDIO data signal is tri-stated between frames.

The core PHY management interface supports the standard MDIO specification (IEEE 802.3 Clause 22).

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ST</td>
<td>Start indication field, programmed with ENETn_MMFR[ST] and equal to 01 for Standard MDIO (Clause 22).</td>
</tr>
</tbody>
</table>
| OP     | Opcode defines type of operation. Programmed with ENETn_MMFR[OP].
01 Write operation
10 Read operation |
| PHYADR | Five-bit PHY device address, programmed with ENETn_MMFR[PA]. Up to 32 devices can be addressed. |
| REGADR | Five-bit register address, programmed with ENETn_MMFR[RA]. Each PHY can implement up to 32 registers. |
| TA     | Turnaround time, programmed with ENETn_MMFR[T]. Two bit-times are reserved for read operations to switch the data bus from write to read. The PHY device presents its register contents in the data phase and drives the bus from the second bit of the turnaround phase. |
| Data   | Data, set by ENETn_MMFR[DATA]. Written to or read from the PHY |
41.7.17.2 MDIO clause 45 frame format

The extended MDIO frame structure defined in IEEE 802.3 Clause 45 introduces indirect addressing. First, a write transaction to an address register is done, followed by a write or read transaction which will put the 16-bit data in the register or retrieve the register contents respectively. A preamble of 32 bits of logical ones is sent prior to every transaction. The MDIO data signal is tri-stated between frames.

The extended MDIO defines four transactions, which are determined by the two-bit opcode field.

Table 41-44. MDIO clause 45 frame structure

<table>
<thead>
<tr>
<th>ST</th>
<th>OP</th>
<th>PRTAD</th>
<th>DEVAD</th>
<th>TA</th>
<th>ADDR/DATA</th>
</tr>
</thead>
</table>

All bits are transmitted from left to right (Preamble bits first) and all fields have their Most-Significant bit sent first (leftmost in above table). The complete frame has a length of 64 bits (32-bit preamble, 14-bit command, 2-bit bus direction change, 16-bit data). Each bit is transferred with the rising edge of the MDIO clock (MDC).

The fields and transactions are summarized in the following tables.

Table 41-45. MDIO clause 45 frame field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ST</td>
<td>Start indication. Indicates the end of the preamble and start of the frame. This value is 00 for extended MDIO (Clause 45) frames.</td>
</tr>
<tr>
<td>OP</td>
<td>Opcode defines if a read or write operation is performed and is programmed with ENETn.MMFR[OP]. See Table 41-46 for more information. &lt;br&gt; 00 Address write &lt;br&gt; 01 Write operation &lt;br&gt; 10 Read inc. operation &lt;br&gt; 11 Read operation</td>
</tr>
<tr>
<td>PRTAD</td>
<td>The port address specifies a MDIO port. Each Port can have up to 32 devices which each can have a separate set of registers.</td>
</tr>
<tr>
<td>DEVAD</td>
<td>Device address. Up to 32 devices can be addressed (within a port).</td>
</tr>
<tr>
<td>TA</td>
<td>Turnaround time, programmed with ENETn.MMFR[TA]. Two bit-times are reserved for read operations to switch the data bus from write to read. The PHY device presents its register contents in the data phase and drives the bus from the second bit of the turnaround phase.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 41-45. MDIO clause 45 frame field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR/DATA</td>
<td>16-bit address (for address write) or data, set by ENET_MMFR[DATA], written to or read from the PHY.</td>
</tr>
</tbody>
</table>

Table 41-46. MDIO Clause 45 Transactions

<table>
<thead>
<tr>
<th>Transaction Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Address</td>
<td>A write transaction to the internal address register of the device/port. The data section of the frame contains the value to be stored in the device’s internal address &quot;pointer&quot; register for further transactions.</td>
</tr>
<tr>
<td>Write</td>
<td>Data write to a register. The 16 bit data will be written to the register identified by the device-internal address.</td>
</tr>
<tr>
<td>Read</td>
<td>Data is read from the register identified by the device-internal address.</td>
</tr>
<tr>
<td>Read inc.</td>
<td>Read with address postincrement. The register identified by the device-internal address is read. After this, the device-internal address is incremented. If the address register is all '1' (0xFFFF) no increment is done (i.e. increment does not wrap around).</td>
</tr>
</tbody>
</table>

41.7.17.3 MDIO clock generation

The MDC clock is generated from the internal bus clock (i.e., IPS bus clock) divided by the value programmed in ENET\_MSCR[MII\_SPEED].
41.7.17.4 MDIO operation

To perform an MDIO access, set the MDIO command register (ENETn_MMFR) according to the description provided in MII Management Frame Register (ENETn_MMFR).

To check when the programmed access completes, read the ENETn_EIR[MII] field.

![Diagram](image)

**Figure 41-18. MDIO access overview**

41.7.18 Ethernet interfaces

The following Ethernet interfaces are implemented:

- Fast Ethernet MII (Media Independent Interface)
- RMII 10/100 using interface converters/gaskets

The following table shows how to configure ENET registers to select each interface.

<table>
<thead>
<tr>
<th>Mode</th>
<th>RCR[RMII_10T]</th>
<th>RCR[RMII_MODE]</th>
</tr>
</thead>
<tbody>
<tr>
<td>MII - 10 Mbit/s</td>
<td>—</td>
<td>0</td>
</tr>
<tr>
<td>MII - 100 Mbit/s</td>
<td>—</td>
<td>0</td>
</tr>
<tr>
<td>RMII - 10 Mbit/s</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>RMII - 100 Mbit/s</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

41.7.18.1 RMII interface

In RMII receive mode, for normal reception following assertion of CRS_DV, RXD[1:0] is 00 until the receiver determines that the receive event has a proper start-of-stream delimiter (SSD).
The preamble appears (RXD[1:0]=01) and the MACs begin capturing data following detection of SFD.

If a false carrier is detected (bad SSD), then RXD[1:0] is 10 until the end of the receive event. This is a unique pattern since a false carrier can only occur at the beginning of a packet where the preamble is decoded (RXD[1:0] = 01).

In RMII transmit mode, TXD[1:0] provides valid data for each REF_CLK period while TXEN is asserted.
41.7.18.2 MII Interface — transmit

On transmit, all data transfers are synchronous to MII_TXCLK rising edge. The MII data enable signal MII_TXEN is asserted to indicate the start of a new frame, and remains asserted until the last byte of the frame is present on the MII_TXD[3:0] bus.

Between frames, MII_TXEN remains deasserted.

If a frame is received on the FIFO interface with an error (for example, RxBD[ME] set) the frame is subsequently transmitted with the MII_TXER error signal for one clock cycle at any time during the packet transfer.
41.7.18.2.1 Transmit with collision — half-duplex

When a collision is detected during a frame transmission (MII_COL asserted), the MAC stops the current transmission, sends a 32-bit jam pattern, and re-transmits the current frame.

(See Collision detection in half-duplex mode for details)

![Figure 41-24. MII transmit operation — transmission with collision](image)

41.7.18.3 MII interface — receive

On receive, all signals are sampled on the MII_RXCLK rising edge. The MII data enable signal, MII_RXDV, is asserted by the PHY to indicate the start of a new frame and remains asserted until the last byte of the frame is present on MII_RXD[3:0] bus.

Between frames, MII_RXDV remains deasserted.

![Figure 41-25. MII receive operation](image)
If the PHY detects an error on the frame received from the line, the PHY asserts the MII error signal, MII_RXER, for at least one clock cycle at any time during the packet transfer.

![Figure 41-26. MII receive operation — errored frame](image)

A frame received on the MII interface with a PHY error indication is subsequently transferred on the FIFO interface with RxBD[ME] set.

### 41.7.19 Interrupt coalescence

The purpose of the interrupt coalescing is to reduce the number of interrupts generated by the MAC so as to reduce the CPU loading.

To facilitate this interrupt coalescing, these registers are available with the same control and configuration fields.

- Transmit Interrupt Coalescing Register (ENET_TXIC)
- Receive Interrupt Coalescing Register (ENET_RXIC)

When coalescing is enabled by asserting the corresponding ICEN field and such interrupt is also enabled by the corresponding interrupt mask of the EIMR register, the MAC generates an interrupt when the threshold number of frames is reached (defined by ICFT) or when the threshold timer expires (defined by ICTT).

When coalescing is disabled by de-asserting ICEN, but interrupt is enabled by the corresponding interrupt mask of the EIMR register, the MAC generates an interrupt as they are received without using coalescing. Interrupt coalescing is done for each transmit and receive queue/class independently.
41.7.19.1 Interrupt coalescence setup
Interrupt coalescence supports both legacy and enhanced BDs. The following guidelines are recommended when setting up interrupt coalescence.

• When the MAC is configured for enhanced (IEEE 1588) mode, that is, enhanced BDs:
  • Set the INT bit in the enhanced received buffer descriptor to one.
  • Set the INT bit in the enhanced transmit buffer descriptor(s) to one.
  • Clear the TXB and RXB fields in the EIMR register.

41.7.19.2 Updating the frame count threshold on-the-fly
To update the ICFT field in the RXIC and TXIC registers:
1. Disable interrupt coalescence by clearing the appropriate ICEN field. This will allow the internal interrupt coalescence counter to reset to zero.

   **NOTE**
   When disabling interrupt coalescence, if an interrupt event is pending, that is, the interrupt counter is not zero, then an interrupt will occur.

2. Write the new threshold value to the ICFT field.
3. Set ICEN to one.

   **NOTE**
   The ICFT field can be updated on-the-fly without disabling the ICEN field. The hardware interrupt will continue and there is a possibility that an interrupt will occur depending on the state of the hardware counter and the previous ICFT value.

41.7.19.3 Updating the timer threshold on-the-fly
To update the ICTT field in the RXIC and TXIC registers:
1. Disable interrupt coalescence by clearing the appropriate ICEN field. This will allow the internal interrupt coalescence counter to reset to zero.

   **NOTE**
   When disabling interrupt coalescence, if an interrupt event is pending, that is, the interrupt counter is not zero, then an interrupt will occur.

2. Write the new timer value to the ICTT field.
3. Set ICEN to one.
Chapter 42
Universal Serial Bus Controller (USB)

42.1 Chip-specific USB information

Table 42-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

42.2 Overview

The USB controller block provides high performance USB functionality that conforms to the *Universal Serial Bus Specification*, Rev. 2.0 (Compaq, Hewlett-Packard, Intel, Lucent, Microsoft, NEC, Philips; 2000), and the *On-The-Go and Embedded Host Supplement to the USB Revision 2.0 Specification* (Hewlett-Packard Company, Intel Corporation, LSI Corporation, Microsoft Corporation, Renesas Electronics Corporation, ST-Ericsson; 2012).

The USB controller consists of two independent USB controller cores: two On-The-Go (OTG) controller cores. Each controller core supports UTMI interfaces according to its feature. See Features for more details. Both the controller cores are single-port cores. For the OTG cores, there is only one port. The port can be used as either a downstream or an upstream port.
The following figure is a block diagram of USB.

Figure 42-1. USB block diagram
42.2.1 Features

There are two USB 2.0 controller cores in this chip:
- Controller Core 0 is also named 'OTG1 Core'; its connected port is named 'OTG1 port'.
- Controller Core 1 is also named 'OTG2 Core'; its connected port is named 'OTG2 port'.

The following list provides features of each controller core.

- **USB 2.0 Controller Core 0**
  - High-Speed/Full-Speed/Low-Speed OTG core
  - HS/FS/LS UTMI compliant interface
  - High Speed, Full Speed and Low Speed operation in HOST mode (with UTMI transceiver)
  - Hardware support for OTG signaling, session request protocol, and host negotiation protocol
  - Up to 8 bidirectional endpoints
  - Support charger detection

- **USB 2.0 Controller Core 1**
  - High-Speed/Full-Speed/Low-Speed OTG core
  - HS/FS/LS UTMI compliant interface
  - High Speed, Full Speed and Low Speed operation in Host mode (with UTMI transceiver)
  - Hardware support for OTG signaling, session request protocol, and host negotiation protocol
  - Up to 8 bidirectional endpoints
  - Low-power mode with local and remote wake-up capability
  - Serial PHY interfaces configurable for bidirectional/unidirectional and differential/single ended
  - Embedded DMA controller in each core

42.2.2 Modes of Operation

The USB has two main modes of operation: normal mode and low power mode.
Each USB OTG controller core can operate in High Speed operation (480 Mbps), Full Speed operation (12 Mbps) and Low Speed operation (1.5 Mbps).

This chapter explains the operation modes.

42.2.2.1 Normal Mode

The OTG controller core can operate in Host mode and Device (Peripheral) mode.

Each USB controller core has its corresponding port, which can work in one or more interface modes.

**NOTE**

Each controller supports only the interface type listed below. Selecting a different interface type in the PORTSC_PTS field results in unpredictable behavior and may cause the system to hang.

- OTG1 port
  - This port supports on-chip UTMI transceiver only.
- OTG2 port
  - This port supports on-chip UTMI transceiver only.

42.2.2.2 Low-Power Mode

Each USB controller core has a low-power mode (Suspend mode) to save power consumption.

As described in the USB 2.0 specification, the device can go into the Suspend state after it sees a constant Idle state on the upstream facing port. The OTG controller core enters Suspend mode after 3 ms of inactivity on the port when it is in Device Operation mode. Host controllers, including the OTG controller in Host mode, do not suspend automatically but can be placed in Suspend mode by software.

Either the local Arm platform or the remote USB Host/Peripheral can initiate a wake-up sequence to resume USB communication. For details about Suspend/Resume, see USB Power Control.
42.3 External Signals

The table found here describes the external signals of USB.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB_OTG1_PWR</td>
<td>To control PMIC to supply VBUS voltage</td>
<td>GPIO_AD_B0_02, GPIO_AD_B1_01</td>
<td>ALT3, ALT0</td>
<td>O</td>
</tr>
<tr>
<td>USB_OTG1_OC</td>
<td>External Input for VBUS over current detection</td>
<td>GPIO_AD_B0_03, GPIO_AD_B1_03</td>
<td>ALT3, ALT0</td>
<td>I</td>
</tr>
<tr>
<td>USB_OTG1_ID</td>
<td>OTG1 ID Signal</td>
<td>GPIO_AD_B0_01, GPIO_AD_B1_02</td>
<td>ALT3, ALT0</td>
<td>I</td>
</tr>
<tr>
<td>USB_OTG2_PWR</td>
<td>To control PMIC to supply VBUS voltage</td>
<td>GPIO_EMC_41, GPIO_AD_B0_15</td>
<td>ALT3, ALT0</td>
<td>O</td>
</tr>
<tr>
<td>USB_OTG2_OC</td>
<td>External Input for VBUS over current detection</td>
<td>GPIO_EMC_40, GPIO_AD_B0_14</td>
<td>ALT3, ALT0</td>
<td>I</td>
</tr>
<tr>
<td>USB_OTG2_ID</td>
<td>OTG2 ID Signal</td>
<td>GPIO_AD_B0_00, GPIO_AD_B1_00</td>
<td>ALT3, ALT0</td>
<td>I</td>
</tr>
</tbody>
</table>

42.4 Functional Description

These sections describe the functionality of the various building blocks of the USB.

42.4.1 USB 2.0 Controller Core 0

The USB 2.0 Controller 0 is an instantiation of an EHCI-compatible core which supports high-, full-, and low-speed operation.

In Host mode, this controller core supports high-, full-, and low-speed operation. In Device mode, it supports high- and full-speed operation.

42.4.1.1 Host Mode

The controller supports direct connection of a HS/FS/LS device with on-chip UTMI transceiver.
Although there is no separate Transaction Translator block in the system, the transaction translator function normally associated with a USB 2.0 high speed hub has been implemented within the DMA and protocol engine blocks to support connection to full and low speed devices.

42.4.1.2 Peripheral (Device) Mode

- Up to eight bidirectional endpoints
- High/full-speed operation
- Support of HNP, and SRP
- Remote wake-up capability

42.4.2 USB 2.0 Controller Core 1

USB 2.0 Controller Core 1 is an instantiation of EHCI-compatible core which supports High Speed / Full Speed / Low Speed operation.

42.4.3 USB Power Control

The USB controller supports suspend and wake-up functionality.

The power control block allows for placing the transceiver in USB low power mode when USB bus is IDLE, and supports local and remote wake-up to bring the transceiver out of USB low power mode when needed. Additionally, the power control block can wake-up the Arm platform from core sleep mode by generating an interrupt.

42.4.3.1 Entering Low Power Suspend Mode

In Host operation mode, low power suspend mode is entered as follows:

1. Clear the ASE and PSE bits in USB_USBCMD, and wait until the AS and PS bits in USB_USBSTS become "0".
2. Set the "SUSPEND" bit in USB_PORTSC1
3. Set the "PHCD" bit in USB_PORTSC1
4. Set all PWD bits in USBPHYx_PWD
5. Set CLKGATE in USBPHYx_CTRL

NOTE
Step 3,4,5 shall be done in atomic operation. That is, interrupt should be disabled during these three steps.
For device operation mode, low power suspend mode is entered as follows:

1. After Host drive is IDLE for 3ms, an SLI interrupt is issued (the "DCSUSPEND" or "SLI" bit in USB_USBSTS)
2. Set the "PHCD" bit on USB_PORTSC1
3. Set all PWD bits in USBPHYx_PWD
4. Set CLKGATE in USBPHYx_CTRL

**NOTE**

Step 2,3,4 shall be done in atomic operation. That is, interrupt should be disabled during these three steps.

### 42.4.3.2 Wake-Up Events

The power control block monitors the USB bus when the USB core is in the USB suspend state.

Depending on whether the core is on Host or Device mode, a number of wake-up conditions are monitored. Upon detection of a wake-up condition, an interrupt will be generated to Arm platform if the related wake-up interrupt enable bit is set.

USB wake-up interrupt also re-activates the Arm platform clocks if they were stopped during the suspend.

#### 42.4.3.2.1 Host Mode Events

The host controller wakes up on the following events:

- Remote Wake-up Request

A peripheral can request the host to reactivate the bus by driving wake-up signaling on the DM/DP lines. The power control block sends a wake-up request to the USB core when a J-K transition on DM/DP line is detected.

- Wake-Up On Overcurrent

If Wake-Up On Overcurrent is enabled (WKOC bit in the USB core register PORTSC1 is set '1'), the power control block sends a wake-up request to the USB core when an overcurrent event is detected.

- Wake-Up On Disconnect
If Wake-Up On Disconnect is enabled (WKDC bit in the USB core register PORTSC1 is set '1'), the power control block sends a wake-up request to the USB core when a disconnection event is detected (J-SE0/K-SE0 transition on DM/DP line).

- Wake-Up On Connect

If a Wake-Up On Connect is enabled (WKCN bit in the USB core register PORTSC1 is set '1'), the power control sub-block sends a wake-up request to the USB core when the connection event is detected (SE0-J/SE0-K transition on DM/DP line).

For a detailed description of register bits WKOC, WKDC, WKCN, please see Port Status & Control (USB_PORTSC1).

42.4.4 Interrupts

42.4.4.1 USB Core Interrupts

Each USB core uses one dedicated vector in the Interrupt Table. The vector numbers associated with each of the cores can be found in the Interrupt section.

With the exception of the wake-up interrupts, all of the interrupt sources are controlled in the USB Cores. Refer to the Interrupt Enable Register (USB_USBINTR) for details.

42.4.4.2 USB Wake-Up Interrupts

Each USB Core has an associated wake-up interrupt. The wake-up interrupts are generated outside of the USB controller cores, but using the same vector as the corresponding USB controller cores interrupt.

These interrupts are generated by the Power Control blocks which run on the 32 KHz standby clock. The wake-up interrupt is designed to work even when the USB and Arm platform clocks are disabled, such that a wake-up condition on the USB bus can reactivate the Arm platform clocks.

Because the wake-up interrupt is generated and cleared on a 32 KHz clock, this interrupt request responds very slowly to clear actions. For this reason, the software must disable the wake-up interrupt to clear the request flag. Disabling the interrupt masks the request instantaneously as this is clocked by the Arm platform clock. The software should wait for at least three 32 KHz clock cycles before re-enabling this interrupt to allow sufficient
time for the request flag to clear. Because this interrupt is only used during low power modes of the USB, it is sufficient to enable the wake-up interrupt just prior to entering the USB suspend mode.

42.5 USB Operation Model

This section describes the detailed application knowledge for OTG1 and OTG2 ports.

42.5.1 Register Interface

Configuration, control and status registers are divided into three categories, identification, capability and operational registers.

**NOTE**

USB controller registers support only DWORD (32-bit) access.

- Identification registers are used to declare the slave interface presence along with the complete set of the hardware configuration parameters.
- Static, read only capability registers define the software limits, restrictions, and capabilities of the host/device controller.
- Operational registers are dynamic control or status registers that may be read only, read/write, or read/write-to-clear. The following sections define the use of these registers.

EHCI registers are listed alongside device registers to show the complementary nature of host and device control.

The following table describes the Interface register sets.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register Set</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td>000h-07Ch</td>
<td>Identification Registers</td>
<td>Identification registers are used to declare the slave interface presence and include a table of the hardware configuration parameters.</td>
</tr>
<tr>
<td>100h-124h</td>
<td>Capability Registers</td>
<td>Capability registers specify the limits, restrictions, and capabilities of a host/device controller implementation. These values are used as parameters to the host/device controller driver.</td>
</tr>
<tr>
<td>080h-0FCh</td>
<td>Operational Registers</td>
<td>Operational registers are used by the system software to control and monitor the operational state of the host/device controller.</td>
</tr>
</tbody>
</table>
### 42.5.1.1 Configuration, Control and Status Register Set

The following table describes the Device/Host capability registers.

**NOTE**

Depending on implementation, "x" can have the following values: UOG1, UOG2.

#### Table 42-4. Device/Host Capability Registers

<table>
<thead>
<tr>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Mnemonic</th>
<th>Register Name</th>
<th>Device Mode</th>
<th>Host Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>000h</td>
<td>4</td>
<td>USB_x_ID</td>
<td>Identification Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>004h</td>
<td>4</td>
<td>USB_x_HWGENERAL</td>
<td>General Hardware Parameters</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>008h</td>
<td>4</td>
<td>USB_x_HWHOST</td>
<td>Host Hardware Parameters</td>
<td>X</td>
<td>O</td>
</tr>
<tr>
<td>00Ch</td>
<td>4</td>
<td>USB_x_HWDEVICE</td>
<td>Device Hardware Parameters</td>
<td>O</td>
<td>X</td>
</tr>
<tr>
<td>010h</td>
<td>4</td>
<td>USB_x_HWTXBUF</td>
<td>TX Buffer Hardware Parameters</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>014h</td>
<td>4</td>
<td>USB_x_HWRXBUF</td>
<td>RX Buffer Hardware Parameters</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>018-07Fh</td>
<td>4</td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>080h</td>
<td>4</td>
<td>USB_x_GPTIMER0LD</td>
<td>General Purpose Timer #0 Load Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>084h</td>
<td>4</td>
<td>USB_x_GPTIMER0CTR</td>
<td>General Purpose Timer #0 Control Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>088h</td>
<td>4</td>
<td>USB_x_GPTIMER1LD</td>
<td>General Purpose Timer #1 Load Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>08Ch</td>
<td>4</td>
<td>USB_x_GPTIMER1CTR</td>
<td>General Purpose Timer #1 Control Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>090h</td>
<td>4</td>
<td>USB_x_SBUSCFG</td>
<td>System Bus Interface Configuration Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>094-09Fh</td>
<td>4</td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>100h</td>
<td>1</td>
<td>USB_x_CAPLENGTH</td>
<td>Capability Register Length</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>101h</td>
<td>-</td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>102h</td>
<td>2</td>
<td>USB_x_HCIVERSION</td>
<td>Host Controller Interface Version Number</td>
<td>X</td>
<td>O</td>
</tr>
<tr>
<td>104h</td>
<td>4</td>
<td>USB_x_HCSPARAMS</td>
<td>Host Controller Structural Parameters</td>
<td>X</td>
<td>O</td>
</tr>
<tr>
<td>108h</td>
<td>4</td>
<td>USB_x_HCCPARAMS</td>
<td>Host Controller Capability Parameters</td>
<td>X</td>
<td>O</td>
</tr>
<tr>
<td>10C-11Fh</td>
<td>4</td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>120h</td>
<td>2</td>
<td>USB_x_DCIVERSION</td>
<td>Device Controller Interface Version Number</td>
<td>O</td>
<td>X</td>
</tr>
<tr>
<td>122h</td>
<td>2</td>
<td>-</td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>124h</td>
<td>4</td>
<td>USB_x_DCCPARAMS</td>
<td>Device Controller Capability Parameters</td>
<td>O</td>
<td>X</td>
</tr>
<tr>
<td>128-13Fh</td>
<td>4</td>
<td></td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>140h</td>
<td>4</td>
<td>USB_x_USB CMD</td>
<td>USB Command Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>144h</td>
<td>4</td>
<td>USB_x_USBSTS</td>
<td>USB Status Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>148h</td>
<td>4</td>
<td>USB_x_USB INTR</td>
<td>USB Interrupt Enable Register</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>14Ch</td>
<td>4</td>
<td>USB_x_FRINDEX</td>
<td>USB Frame Index</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>150h</td>
<td>4</td>
<td>-</td>
<td>Reserved</td>
<td></td>
<td></td>
</tr>
<tr>
<td>154h</td>
<td>4</td>
<td>USB_x_PERIODICLISTBASE</td>
<td>Frame List Base Address</td>
<td>X</td>
<td>O</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 42-4. Device/Host Capability Registers (continued)

<table>
<thead>
<tr>
<th>Offset</th>
<th>Size (Bytes)</th>
<th>Mnemonic</th>
<th>Register Name</th>
<th>Device Mode</th>
<th>Host Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB_x_DEVICEADDR</td>
<td>4</td>
<td>USB Device Address</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>USB_xASYNCLISTADDR</td>
<td>4</td>
<td>Next Asynchronous List Address</td>
<td>X</td>
<td>O</td>
<td></td>
</tr>
<tr>
<td>USB_x_ENDPOINTLISTADDR</td>
<td>4</td>
<td>Address at Endpoint list in memory</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>USB_xDEVICEADDR</td>
<td>4</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>USB_xBURSTSIZE</td>
<td>4</td>
<td>Programmable Burst Size</td>
<td>O</td>
<td>O</td>
<td></td>
</tr>
<tr>
<td>USB_x_TXFILLTUNING</td>
<td>4</td>
<td>Host Transmit Pre-Buffer Packet Tuning</td>
<td>X</td>
<td>O</td>
<td></td>
</tr>
<tr>
<td>USB_xPORTSC1</td>
<td>4</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>USB_xOTGSC</td>
<td>4</td>
<td>On-The-Go Status/Control Register (OTG only)</td>
<td>O</td>
<td>O</td>
<td></td>
</tr>
<tr>
<td>USB_x_USBMODE</td>
<td>4</td>
<td>USB Controller Operating Mode</td>
<td>O</td>
<td>O</td>
<td></td>
</tr>
<tr>
<td>USB_x_ENDPOINTSETUPSTAT</td>
<td>4</td>
<td>Endpoint Setup Status</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>USB_x_ENDPOINTPRIME</td>
<td>4</td>
<td>Endpoint Initialization</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>USB_x_ENDPOINTFLUSH</td>
<td>4</td>
<td>Endpoint De-Initialization</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>USB_x_ENDPOINTSTATUS</td>
<td>4</td>
<td>Endpoint Status</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>USB_x_ENDPOINTCOMPLETE</td>
<td>4</td>
<td>Endpoint Complete</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>USB_x_ENDPOINTCTRL0</td>
<td>64</td>
<td>Endpoint Control Register 0-7</td>
<td>O</td>
<td>X</td>
<td></td>
</tr>
</tbody>
</table>

**NOTE**

"O" means the register is available in host/device operation mode;

"X" means the register is reserved in host/device operation mode.
42.5.1.2 Identification Registers

Identification registers are used to declare the slave interface presence and include a table of the hardware configuration parameters.

42.5.1.3 OTG Operations

42.5.2 Host Data Structures

This section defines the interface data structures used to communicate control, status, and data between HCD (software) and the Enhanced Host Controller (hardware).

The data structure definitions in this chapter support a 32-bit memory buffer address space. The interface consists of a Periodic Schedule, Periodic Frame List, Asynchronous Schedule, Isochronous Transaction Descriptors, Split-transaction Isochronous Transfer Descriptors, Queue Heads, and Queue Element Transfer Descriptors.

The periodic frame list is the root of all periodic (isochronous and interrupt transfer type) transfers for the host controller. The asynchronous list is the root for all the bulk and control transfers. Isochronous data streams are managed using Isochronous Transaction Descriptors. Isochronous split-transaction data streams are managed with Split-transaction Isochronous Transfer Descriptors. All Interrupt, Control, and Bulk data streams are managed via queue heads and Queue Element Transfer Descriptors. These data structures are optimized to reduce the total memory footprint of the schedule and to reduce (on average) the number of memory accesses needed to execute a USB transaction.

Note that software must ensure that no interface data structure reachable by the EHCI host controller spans a 4 K-page boundary.

The data structures defined in this section are (from the host controller's perspective) a mix of read-only and read/writeable fields. The host controller must preserve the read-only fields on all data structure writes.

42.5.2.1 Periodic Frame List

This schedule is for all periodic transfers (isochronous and interrupt). The periodic schedule is referenced from the operational registers space using the USB_PERIODICLISTBASE address register and the USB_FRINDEX register.

The periodic schedule is based on an array of pointers called the Periodic Frame List.
The USB_PERIODICLISTBASE address register is combined with the USB_FRINDEX register to produce a memory pointer into the frame list. The Periodic Frame List implements a sliding window of work over time.

The following figure shows the organization of periodic schedule.

![Figure 42-2. Periodic Schedule Organization](image)

Split transaction Interrupt, Bulk and Control are also managed using queue heads and queue element transfer descriptors.

The periodic frame list is a 4 K-page aligned array of Frame List Link pointers. The length of the frame list may be programmable. The programmability of the periodic frame list is exported to system software via the USB_HCCPARAMS register. If non-programmable, the length is 1024 elements. If programmable, the length can be selected by system software as one of 256, 512, or 1024 elements. An implementation must support all three sizes. Programming the size (that is, the number of elements) is accomplished by system software writing the appropriate value into Frame List Size field in the USB_USBCMD register.

Frame List Link pointers direct the host controller to the first work item in the frame's periodic schedule for the current micro-frame. The link pointers are aligned on DWord boundaries within the Frame List.
The table below illustrates the format of the Frame list element pointer.

### Table 42-5. Format of Frame List Element Pointer

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Frame List Link Pointer | 0  | Typ | 03-00H |

Frame List Link pointers always reference memory objects that are 32-byte aligned. The referenced object may be an isochronous transfer descriptor for high-speed devices, a split-transaction isochronous transfer descriptor (for full-speed isochronous endpoints), or a queue head (used to support high-, full- and low-speed interrupt). System software should not place non-periodic schedule items into the periodic schedule. The least significant bits in a frame list pointer are used to key the host controller as to the type of object the pointer is referencing.

The least significant bit is the T-Bit (bit 0). When this bit is set to a one, the host controller never uses the value of the frame list pointer as a physical memory pointer. The Typ field is used to indicate the exact type of data structure being referenced by this pointer. The value encodings are.

### Table 42-6. Typ Field Value Definitions

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>00b</td>
<td>Isochronous Transfer Descriptor</td>
</tr>
<tr>
<td>01b</td>
<td>Queue Head</td>
</tr>
<tr>
<td>10b</td>
<td>Split Transaction Isochronous Transfer Descriptor.</td>
</tr>
<tr>
<td>11b</td>
<td>Frame Span Traversal Node.</td>
</tr>
</tbody>
</table>

#### 42.5.2.2 Asynchronous List Queue Head Pointer

The Asynchronous Transfer List (based at the USB_ASYNCLISTADDR register) is where all of the control and bulk transfers are managed.

Host controllers use this list only when it reaches the end of the periodic list, the periodic list is disabled, or the periodic list is empty.
AsynListAddr

Operational
Registers

Bulk/Control Queue Heads

Asynchronous Schedule Organization

Figure 42-3. Asynchronous Schedule Organization

The Asynchronous list is a simple circular list of queue heads. The USB_ASYNCLISTADDR register is simply a pointer to the next queue head. This implements a pure round-robin service for all queue heads linked into the asynchronous list.

42.5.2.3 Isochronous (High-Speed) Transfer Descriptor (iTD)

The format of an isochronous transfer descriptor is shown in the table below. This structure is used only for high-speed isochronous endpoints. All other transfer types should use queue structures. Isochronous TDs must be aligned on a 32-byte boundary.

Table 42-7. Isochronous Transaction Descriptor (iTD)

<table>
<thead>
<tr>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Next Link Pointer</td>
<td>0</td>
<td>Typ</td>
<td>T</td>
<td>03-00</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Status</td>
<td>Transaction 0 Length</td>
<td>IO</td>
<td>PC*</td>
<td>Transaction 0 Offset*</td>
<td>07-04</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Status</td>
<td>Transaction 1 Length</td>
<td>IO</td>
<td>PC*</td>
<td>Transaction 1 Offset*</td>
<td>0B-08</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Status</td>
<td>Transaction 2 Length</td>
<td>IO</td>
<td>PC*</td>
<td>Transaction 2 Offset*</td>
<td>0F-08</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Status</td>
<td>Transaction 3 Length</td>
<td>IO</td>
<td>PC*</td>
<td>Transaction 3 Offset*</td>
<td>13-10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 42-7. Isochronous Transaction Descriptor (iTD) (continued)

<table>
<thead>
<tr>
<th>Status</th>
<th>Transaction 4 Length</th>
<th>IO</th>
<th>PG*</th>
<th>Transaction 4 Offset*</th>
<th>17-14 H</th>
</tr>
</thead>
<tbody>
<tr>
<td>Status</td>
<td>Transaction 5 Length</td>
<td>IO</td>
<td>PG*</td>
<td>Transaction 5 Offset*</td>
<td>1B-1 8H</td>
</tr>
<tr>
<td>Status</td>
<td>Transaction 6 Length</td>
<td>IO</td>
<td>PG*</td>
<td>Transaction 6 Offset*</td>
<td>1F-1 CH</td>
</tr>
<tr>
<td>Status</td>
<td>Transaction 7 Length</td>
<td>IO</td>
<td>PG*</td>
<td>Transaction 7 Offset*</td>
<td>23-20 H</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Buffer Pointer (Page 0)</th>
<th>EndPt</th>
<th>R</th>
<th>Device Address</th>
<th>27-24 H</th>
</tr>
</thead>
<tbody>
<tr>
<td>Buffer Pointer (Page 1)</td>
<td>I/ O</td>
<td></td>
<td>Maximum Packet Size</td>
<td>2B-2 8H</td>
</tr>
<tr>
<td>Buffer Pointer (Page 2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Buffer Pointer (Page 3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Buffer Pointer (Page 4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Buffer Pointer (Page 5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Buffer Pointer (Page 6)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

These fields may be modified by the host controller if the I/O field indicates an OUT.

### 42.5.2.3.1 Next Link Pointer

The first DWord of an iTD is a pointer to the next schedule data structure.

The following table describes the Next Schedule Element pointer field.

#### Table 42-8. Next Schedule Element Pointer

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Link Pointer (LP)</td>
<td>These bits correspond to memory address signals [31:5], respectively. This field points to another Isochronous Transaction Descriptor (iTD/siTD) or Queue Head (QH).</td>
</tr>
<tr>
<td>4-3</td>
<td>These bits are reserved and their value has no effect on operation. Software should initialize this field to zero.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 42-8. Next Schedule Element Pointer (continued)

<table>
<thead>
<tr>
<th>Reserved</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2-1 QH/(s)</td>
<td>This field indicates to the Host Controller whether the item referenced is an iTD, siTD or a QH. This allows the Host Controller to perform the proper type of processing on the item after it is fetched. Value encodings are: Value Meaning 00b iTD (isochronous transfer descriptor) 01b QH (queue head) 10b siTD (split transaction isochronous transfer descriptor) 11b FSTN (frame span traversal node)</td>
</tr>
<tr>
<td>0</td>
<td>1= Link Pointer field is not valid. 0= Link Pointer field is valid.</td>
</tr>
</tbody>
</table>

42.5.2.3.2 iTD Transaction Status and Control List

DWords 1 through 8 are eight slots of transaction control and status.

Each transaction description includes:

- Status results field
- Transaction length (bytes to send for OUT transactions and bytes received for IN transactions).
- Buffer offset. The PG and Transaction X Offset fields are used with the buffer pointer list to construct the starting buffer address for the transaction.

The host controller uses the information in each transaction description plus the endpoint information contained in the first three DWords of the Buffer Page Pointer list, to execute a transaction on the USB.

The following table describes iTD Transaction Status and Control fields.

Table 42-9. iTD Transaction Status and Control

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28 Status</td>
<td>This field records the status of the transaction executed by the host controller for this slot. This field is a bit vector with the following encoding:</td>
</tr>
<tr>
<td>Bit</td>
<td>Definition</td>
</tr>
<tr>
<td>31</td>
<td>Active. Set to one by software to enable the execution of an isochronous transaction by the Host Controller. When the transaction associated with this descriptor is completed, the Host Controller sets this bit to zero indicating that a transaction for this element should not be executed when it is next encountered in the schedule.</td>
</tr>
<tr>
<td>30</td>
<td>Data Buffer Error. Set to a one by the Host Controller during status update to indicate that the Host Controller is unable to keep up with the reception of incoming data (overrun) or is unable to supply data fast enough during transmission (under run). If an overrun condition occurs, no action is necessary.</td>
</tr>
<tr>
<td>29</td>
<td>Babble Detected. Set to one by the Host Controller during status update when &quot;babble&quot; is detected during the transaction generated by this descriptor.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 42-9. iTD Transaction Status and Control (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>28</td>
<td>Transaction Error (XactErr). Set to one by the Host Controller during status update in the case where the host did not receive a valid response from the device (Timeout, CRC, Bad PID, etc.). This bit may only be set for isochronous IN transactions.</td>
</tr>
<tr>
<td>27-16</td>
<td>Transaction X Length For an OUT, this field is the number of data bytes the host controller sends during the transaction. The host controller is not required to update this field to reflect the actual number of bytes transferred during the transfer. For an IN, the initial value of the endpoint to deliver. During the status update, the host controller writes back the field is the number of bytes the host expects the number of bytes successfully received. The value in this register is the actual byte count (0‡zero length data, 1‡one byte, 2‡two bytes, etc.). The maximum value this field may contain is 0xC00 (3072).</td>
</tr>
<tr>
<td>15</td>
<td>Interrupt On Complete (IOC) If this bit is set to one, it specifies that when this transaction completes, the Host Controller should issue an interrupt at the next interrupt threshold.</td>
</tr>
<tr>
<td>14-12</td>
<td>Page Select (PG) These bits are set by software to indicate which of the buffer page pointers the offset field in this slot should be concatenated to produce the starting memory address for this transaction. The valid range of values for this field is 0 to 6.</td>
</tr>
<tr>
<td>11-0</td>
<td>Transaction X Offset This field is a value that is an offset, expressed in bytes, from the beginning of a buffer. This field is concatenated onto the buffer page pointer indicated in the adjacent PG field to produce the starting buffer address for this transaction.</td>
</tr>
</tbody>
</table>

42.5.2.3.3 iTD Buffer Page Pointer List (Plus)

DWords 9-15 of an isochronous transaction descriptor are nominally page pointers (4 K aligned) to the data buffer for this transfer descriptor. This data structure requires the associated data buffer to be contiguous (relative to virtual memory), but allows the physical memory pages to be non-contiguous.

Seven page pointers are provided to support the expression of eight isochronous transfers. The seven pointers allow for 3 (transactions) * 1024 (maximum packet size) * 8 (transaction records) (24576 bytes) to be moved with this data structure, regardless of the alignment offset of the first page.

Because each pointer is a 4 K aligned page pointer, the least significant 12 bits in several of the page pointers are used for other purposes.

The tables below illustrate the field descriptions.

Table 42-10. iTD Buffer Pointer Page 0 (Plus)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Buffer Pointer (Page 0) This is a 4 K aligned pointer to physical memory. Corresponds to memory address bits [31:12].</td>
</tr>
<tr>
<td>11-8</td>
<td>Endpoint Number (Endpt) This 4-bit field selects the particular endpoint number on the device serving as the data source or sink.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 42-10. iTD Buffer Pointer Page 0 (Plus) (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>Bit reserved for future use and should be initialized by software to zero.</td>
</tr>
<tr>
<td>6-0</td>
<td>This field selects the specific device serving as the data source or sink.</td>
</tr>
</tbody>
</table>

### Table 42-11. iTD Buffer Pointer Page 1 (Plus)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Buffer Pointer (Page 1) This is a 4K aligned pointer to physical memory.</td>
</tr>
<tr>
<td>11</td>
<td>Direction (I/O) 0 = OUT; 1 = IN. This field encodes whether the high-speed transaction should use an IN or OUT PID.</td>
</tr>
<tr>
<td>10-0</td>
<td>Maximum Packet Size This directly corresponds to the maximum packet size of the associated endpoint (wMaxPacketSize). This field is used for high-bandwidth endpoints where more than one transaction is issued per transaction description (per micro-frame). This field is used with the Multi field to support high-bandwidth pipes. This field is also used for all IN transfers to detect packet babble. Software should not set a value larger than 1024 (400h). Any value larger yields undefined results.</td>
</tr>
</tbody>
</table>

### Table 42-12. iTD Buffer Pointer Page 2 (Plus)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Buffer Pointer This is a 4K aligned pointer to physical memory.</td>
</tr>
<tr>
<td>11-2</td>
<td>Reserved This bit reserved for future use and should be set to zero.</td>
</tr>
<tr>
<td>1-0</td>
<td>Multi This field is used to indicate to the host controller the number of transactions that should be executed per transaction description (per micro-frame). The valid values are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td></td>
<td>00b Reserved. A zero in this field yields undefined results.</td>
</tr>
<tr>
<td></td>
<td>01b One transaction to be issued for this endpoint per micro-frame.</td>
</tr>
<tr>
<td></td>
<td>10b Two transactions to be issued for this endpoint per micro-frame.</td>
</tr>
<tr>
<td></td>
<td>11b Three transactions to be issued for this endpoint per micro-frame.</td>
</tr>
</tbody>
</table>

### Table 42-13. iTD Buffer Pointer Page 3-6

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Buffer Pointer This is a 4K aligned pointer to physical memory.</td>
</tr>
<tr>
<td>11-0</td>
<td>Reserved These bits reserved for future use and should be set to zero.</td>
</tr>
</tbody>
</table>
42.5.2.4 Split Transaction Isochronous Transfer Descriptor (siTD)

All Full-speed isochronous transfers through the internal transaction translator are managed using the siTD data structure. This data structure satisfies the operational requirements for managing the split transaction protocol.

The following table shows the Split Transaction Isochronous Transfer Descriptor (siTD).

**Table 42-14. Split Transaction Isochronous Transfer Descriptor**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Next Link Pointer (LP). This field contains the address of the next data object to be processed in the periodic list and corresponds to memory address signals [31:5], respectively.</td>
</tr>
</tbody>
</table>

1. 04-0B: Static Endpoint State
2. 0C-13: Transfer results

**42.5.2.4.1 Next Link Pointer**

DWord0 of a siTD is a pointer to the next schedule data structure.

The following table describes the Next Link Pointer fields.

**Table 42-15. Next Link Pointer**
Table 42-15. Next Link Pointer (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4-3</td>
<td>Reserved. These bits must be written as zeros.</td>
</tr>
<tr>
<td>2-1</td>
<td>QH/(s)TD Select (Typ). This field indicates to the Host Controller whether the item referenced is an iTD/siTD or a QH. This allows the Host Controller to perform the proper type of processing on the item after it is fetched. Value encodings are: Value Meaning 00b iTD (isochronous transfer descriptor) 01b QH (queue head) 10b siTD (split transaction isochronous transfer descriptor) 11b FSTN (frame span traversal node)</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1 = Link Pointer field is not valid. 0 = Link Pointer is valid.</td>
</tr>
</tbody>
</table>

42.5.2.4.2 siTD Endpoint Capabilities/Characteristics

DWords 1 and 2 specify static information about the full-speed endpoint, the addressing of the parent Companion Controller, and micro-frame scheduling control.

The tables below describe the Endpoint and transaction translator characteristics and micro-frame schedule control fields.

Table 42-16. Endpoint and Transaction Translator Characteristics

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Direction (I/O). 0 = OUT; 1 = IN. This field encodes whether the full-speed transaction should be an IN or OUT.</td>
</tr>
<tr>
<td>30-24</td>
<td>Port Number. This field is the port number of the recipient Transaction Translator.</td>
</tr>
<tr>
<td>23</td>
<td>Reserved. Bit reserved and should be set to zero.</td>
</tr>
<tr>
<td>22-16</td>
<td>Hub Address. This field holds the device address of the Companion Controllers’ hub.</td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved. Field reserved and should be set to zero.</td>
</tr>
<tr>
<td>11-8</td>
<td>Endpoint Number (Endpt). This 4-bit field selects the particular endpoint number on the device serving as the data source or sink.</td>
</tr>
<tr>
<td>7</td>
<td>Reserved. Bit is reserved for future use. It should be set to zero.</td>
</tr>
<tr>
<td>6-0</td>
<td>Device Address. This field selects the specific device serving as the data source or sink.</td>
</tr>
</tbody>
</table>

Table 42-17. Micro-frame Schedule Control

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved. This field reserved for future use. It should be set to zero.</td>
</tr>
<tr>
<td>15-8</td>
<td>Split Completion Mask (mFrame C-Mask). This field (along with the Active and SplitX- state fields in the Status byte) is used to determine during which micro-frames the host controller should execute complete-split transactions. When the criteria for using this field is met, an all zeros value has undefined behavior. The host</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 42-17. Micro-frame Schedule Control (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>controller uses the value of the three low-order bits of the FRINDEX register to index into this bit field. If the FRINDEX register value indexes to a position where the mFrame C-Mask field is a one, then this siTD is a candidate for transaction execution. There may be more than one bit in this mask set.</td>
<td></td>
</tr>
</tbody>
</table>

7-0 Split Start Mask (mFrame S-mask). This field (along with the Active and SplitX-state fields in the Status byte) is used to determine during which micro-frames the host controller should execute start-split transactions. The host controller uses the value of the three low-order bits of the FRINDEX register to index into this bit field. If the FRINDEX register value indexes to a position where the mFrame S-mask field is a one, then this siTD is a candidate for transaction execution. An all zeros value in this field, in combination with existing periodic frame list has undefined results.

42.5.2.4.3 siTD Transfer State

DWords 3-6 are used to manage the state of the transfer.

The following table describes siTD transfer state fields.

Table 42-18. siTD Transfer Status and Control

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Interrupt On Complete (ioc). 0 = Do not interrupt when transaction is complete. 1 = Do interrupt when transaction is complete. When the host controller determines that the split transaction has completed it asserts a hardware interrupt at the next interrupt threshold.</td>
</tr>
<tr>
<td>30</td>
<td>Page Select (P). Used to indicate which data page pointer should be concatenated with the CurrentOffset field to construct a data buffer pointer (0 selects Page 0 pointer and 1 selects Page 1). The host controller is not required to write this field back when the siTD is retired (Active bit transitioned from a one to a zero).</td>
</tr>
<tr>
<td>29-26</td>
<td>Reserved. This field reserved for future use and should be set to zero.</td>
</tr>
<tr>
<td>25-16</td>
<td>Total Bytes To Transfer. This field is initialized by software to the total number of bytes expected in this transfer. Maximum value is 1023 (3FFh)</td>
</tr>
<tr>
<td>15-8</td>
<td>μFrame Complete-split Progress Mask (C-prog-Mask). This field is used by the host controller to record which split-completes has been executed.</td>
</tr>
<tr>
<td>7-0</td>
<td>Status—This field records the status of the transaction executed by the host controller for this slot. It is a bit vector with the encoding shown in the following rows.</td>
</tr>
<tr>
<td>7</td>
<td>Active. Set to one by software to enable the execution of an isochronous split transaction by the Host Controller.</td>
</tr>
<tr>
<td>6</td>
<td>ERR. Set to a one by the Host Controller when an ERR response is received from the Companion Controller.</td>
</tr>
<tr>
<td>5</td>
<td>Data Buffer Error. Set to a one by the Host Controller during status update to indicate that the Host Controller is unable to keep up with the reception of incoming data (overrun) or is unable to supply data fast enough during transmission (under run). In the case of an under run, the Host Controller transmits an incorrect CRC (thus invalidating the data at the endpoint). If an overrun condition occurs, no action is necessary.</td>
</tr>
<tr>
<td>4</td>
<td>Babble Detected. Set to a one by the Host Controller during status update when “babble” is detected during the transaction generated by this descriptor.</td>
</tr>
<tr>
<td>3</td>
<td>Transaction Error (XactErr). Set to a one by the Host Controller during status update in the case where the host did not receive a valid response from the device (Timeout, CRC, Bad PID, etc.). This bit is set only for IN transactions.</td>
</tr>
<tr>
<td>2</td>
<td>Missed Micro-Frame. The host controller detected that a host-induced hold-off caused the host controller to miss a required complete-split transaction.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 42-18. siTD Transfer Status and Control (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Split Transaction State (SplitXstate). The bit encodings are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td>00b</td>
<td>Do Start Split. This value directs the host controller to issue a Start split transaction to the endpoint when a match is encountered in the S-mask.</td>
</tr>
<tr>
<td>01b</td>
<td>Do Complete Split. This value directs the host controller to issue a Complete split transaction to the endpoint when a match is encountered in the C-mask.</td>
</tr>
<tr>
<td>0</td>
<td>Reserved. Bit reserved for future use and should be set to zero.</td>
</tr>
</tbody>
</table>

42.5.2.4.4 siTD Buffer Pointer List (plus)

DWords 4 and 5 are the data buffer page pointers for the transfer. This structure supports one physical page cross. The most significant 20 bits of each DWord in this section are the 4 K (page) aligned buffer pointers.

The least significant 12 bits of each DWord are used as additional transfer state. The following table describes the siTD buffer pointer fields.

Table 42-19. Buffer Page Pointer List (plus)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Buffer Pointer List. Bits [31:12] of DWords 4 and 5 are 4 K page aligned physical memory addresses. These bits correspond to physical address bits [31:12] respectively. The lower 12 bits in each pointer are defined and used as specified below. The field P (see siTD Transfer State) specifies the current active pointer.</td>
</tr>
<tr>
<td>Bits 11-0 (Page 0)</td>
<td>Current Offset—The 12 least significant bits of the Page 0 pointer are the current byte offset for the current page pointer (as selected with the page indicator bit (P field). The host controller is not required to write this field back when the siTD is retired (Active bit transitioned from a one to a zero).</td>
</tr>
<tr>
<td>Bits 11-0 (Page 1)—The least significant bits of the Page 1 pointer are split into three subfields as shown in the following rows.</td>
<td></td>
</tr>
<tr>
<td>11-5 (Page 1)</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-3 (Page 1)</td>
<td>Transaction position (TP). This field is used with T-count to determine whether to send all, first, middle, or last with each outbound transaction payload. System software must initialize this field with the appropriate starting value. The host controller must correctly manage this state during the lifetime of the transfer. The bit encodings are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td>00b</td>
<td>All. The entire full-speed transaction data payload is in this transaction (that is, less than or equal to 188 bytes).</td>
</tr>
<tr>
<td>01b</td>
<td>Begin. This is the first data payload for a full-speed OUT transaction that is greater than 188 bytes.</td>
</tr>
<tr>
<td>10b</td>
<td>Mid. This is the middle payload for a full-speed OUT transaction that is larger than 188 bytes.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 42-19. Buffer Page Pointer List (plus) (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11b</td>
<td>End. This is the last payload for a full-speed OUT transaction that was larger than 188 bytes.</td>
</tr>
<tr>
<td>2-0</td>
<td>Transaction count (T-Count). Software initializes this field with the number of OUT start-splits this transfer requires. Any value larger than 6 is undefined.</td>
</tr>
</tbody>
</table>

### 42.5.2.4.5 siTD Back Link Pointer

DWord 6 of a siTD is simply another schedule link pointer. This pointer is always zero, or references a siTD, and it cannot reference any other schedule data structure.

The following table describes the siTD back link pointer fields.

#### Table 42-20. siTD Back Link Pointer

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>siTD Back Pointer. This field is a physical memory pointer to a siTD.</td>
</tr>
<tr>
<td>4-1</td>
<td>Reserved. This field is reserved for future use. It should be set to zero.</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1 = siTD Back Pointer field is not valid. 0 = siTD Back Pointer field is valid.</td>
</tr>
</tbody>
</table>

### 42.5.2.5 Queue element transfer descriptor (qTD)

This data structure is only used with a queue head. It describes one or more USB transactions to transfer up to 20480 (5*4096) bytes.

The structure contains two structure pointers used for queue advancement, a DWord of transfer state, and a five-element array of data buffer pointers.

It is 32 bytes and must be physically contiguous.

The buffer associated with this transfer must be virtually contiguous. The buffer may start on any byte boundary; however, for optimal utilization of on-chip busses it is recommended to align the buffers on a 32-byte boundary. A separate buffer pointer list element must be used for each physical page in the buffer, regardless of whether the buffer is physically contiguous.

Host controller updates (host controller writes) to stand-alone qTDs only occur during transfer retirement. References in the following bit field definitions of updates to the qTD are to the qTD portion of a queue head.
The following table shows the queue element transfer descriptor data structure.

**Table 42-21. Queue element transfer descriptor data structure**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Next Transfer Element Pointer. This field contains the physical memory address of the next qTD to be processed. The field corresponds to memory address signals[31:5], respectively.</td>
</tr>
<tr>
<td>4-1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Queue Element Transfer Descriptors must be aligned on 32-byte boundaries.

### 42.5.2.5.1 Next qTD Pointer

The first DWord of an element transfer descriptor is a pointer to another transfer element descriptor.

The following table describes Next qTD pointer fields.

**Table 42-22. qTD Next Element Transfer Pointer (DWord 0)**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Next Transfer Element Pointer. This field contains the physical memory address of the next qTD to be processed. The field corresponds to memory address signals[31:5], respectively.</td>
</tr>
<tr>
<td>4-1</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 42.5.2.5.2 Alternate Next qTD Pointer

The second DWord of a queue element transfer descriptor is used to support hardware-only advance of the data stream to the next transfer descriptor on short packet. To be more explicit, the host controller always uses this pointer when the current qTD is retired due to short packet.

The following table describes the TD Alternate Next Element Transfer Pointer field descriptions.

**Table 42-23. TD Alternate Next Element Transfer Pointer (DWord 1)**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Alternate Next Transfer Element Pointer. This field contains the physical memory address of the next qTD to be processed in the event that the current qTD execution encounters a short packet (for an IN transaction). The field corresponds to memory address signals [31:5], respectively.</td>
</tr>
<tr>
<td>4-1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1= pointer is invalid. 0=Pointer is valid (points to a valid Transfer Element Descriptor). This bit indicates to the Host Controller that there are no more valid entries in the queue.</td>
</tr>
</tbody>
</table>

### 42.5.2.5.3 qTD Token

The third DWord of a queue element transfer descriptor contains most of the information the host controller requires to execute a USB transaction (the remaining endpoint-addressing information is specified in the queue head).

**NOTE**

The field descriptions forward reference fields defined in the queue head. Where necessary, these forward references are preceded with a QH notation.

The following table describes the TD Token fields.

**Table 42-24. TD Token (DWord 2)**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Data Toggle</td>
</tr>
<tr>
<td>Data Toggle</td>
<td>This is the data toggle sequence bit. The use of this bit depends on the setting of the Data Toggle Control bit in the queue head.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 42-24. TD Token (DWord 2) (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>30-16</td>
<td><strong>Total Bytes to Transfer</strong>&lt;br&gt;This field specifies the total number of bytes to be moved with this transfer descriptor. This field is decremented by the number of bytes actually moved during the transaction, only on the successful completion of the transaction. The maximum value software may store in this field is $5 \times 4\text{K} (5000\text{H})$. This is the maximum number of bytes 5 page pointers can access. If the value of this field is zero when the host controller fetches this transfer descriptor (and the active bit is set), the host controller executes a zero-length transaction and retires the transfer descriptor. It is not a requirement for OUT transfers that <em>Total Bytes To Transfer</em> be an even multiple of QHD.Maximum Packet Length. If software builds such a transfer descriptor for an OUT transfer, the last transaction is always less than QHD.Maximum Packet Length.&lt;br&gt;Although it is possible to create a transfer up to 20K this assumes the 1st offset into the first page is 0. When the offset cannot be predetermined, crossing past the 5th page can be guaranteed by limiting the total bytes to 16K**. Therefore, the maximum recommended transfer is 16 K(4000H).</td>
</tr>
<tr>
<td>15</td>
<td><strong>Interrupt On Complete (IOC)</strong>&lt;br&gt;If this bit is set to a one, it specifies that when this qTD is completed, the Host Controller should issue an interrupt at the next interrupt threshold.</td>
</tr>
<tr>
<td>14-12</td>
<td><strong>Current Page (C_Page)</strong>&lt;br&gt;This field is used as an index into the qTD buffer pointer list. Valid values are in the range 0H to 4H. The host controller is not required to write this field back when the qTD is retired.</td>
</tr>
<tr>
<td>11-10</td>
<td><strong>Error Counter (CERR)</strong>&lt;br&gt;This field is a 2-bit down counter that keeps track of the number of consecutive Errors detected while executing this qTD. If this field is programmed with a non-zero value during set-up, the Host Controller decrements the count and writes it back to the qTD if the transaction fails. If the counter counts from one to zero, the Host Controller marks the qTD inactive, sets the <em>Halted</em> bit to a one, and error status bit for the error that caused CERR to decrement to zero. An interrupt is generated if the <em>USB Error Interrupt Enable</em> bit in the USBINTR register is set to a one. If HCD programs this field to zero during set-up, the Host Controller does not count errors for this qTD and there is no limit on the retries of this qTD. Note that write-backs of intermediate execution state are to the queue head overlay area, not the qTD.&lt;br&gt;&lt;br&gt;<strong>Transaction Error - Decrement</strong>&lt;br&gt;<strong>Data Buffer Error - No Decrement</strong>³&lt;br&gt;<strong>Stalled - No Decrement</strong>¹&lt;br&gt;<strong>Babble Detected - No Decrement</strong>¹&lt;br&gt;<strong>No Error - No Decrement</strong>²&lt;br&gt;&lt;br&gt;<strong>Error Decrement Counter</strong>&lt;br&gt;&lt;br&gt;1&lt;sup&gt;1&lt;/sup&gt; Detection of Babble or Stall automatically halts the queue head. Thus, count is not decremented&lt;br&gt;&lt;br&gt;2&lt;sup&gt;2&lt;/sup&gt; If the EPS field indicates a HS device or the queue head is in the Asynchronous Schedule (and <em>PIDCode</em> indicates an IN or OUT) and a bus transaction completes and the host controller does not detect a transaction error, then the host controller should reset <em>CERR</em> to extend the total number of errors for this transaction. For example, <em>CERR</em> should be reset with maximum value (3) on each successful completion of a transaction. The host controller must never reset this field if the value at the start of the transaction is 00b.&lt;br&gt;&lt;br&gt;See Split Transaction Interrupt for CERR adjustment rules when the EPS field indicates a FS or LS device and the queue head is in the Periodic Schedule. See Asynchronous - Do Complete Split for CERR adjustment rules when the EPS field indicates a FS or LS device, the queue head is in the Asynchronous schedule and the <em>PIDCode</em> indicates a SETUP.</td>
</tr>
</tbody>
</table>

---

*Table continues on the next page...*
Table 42-24. TD Token (DWord 2) (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3</td>
<td>Data buffer errors are host problems. They don't count against the device's retries.</td>
</tr>
</tbody>
</table>

**NOTE:** Software must not program CERR to a value of zero when the EPS field is programmed with a value indicating a Full- or Low-speed device. This combination could result in undefined behavior.

<table>
<thead>
<tr>
<th>9-8 PID Code</th>
<th>This field is an encoding of the token, which should be used for transactions associated with this transfer descriptor. Encodings are:</th>
</tr>
</thead>
<tbody>
<tr>
<td>00b</td>
<td>OUT Token generates token (E1H)</td>
</tr>
<tr>
<td>01b</td>
<td>IN Token generates token (69H)</td>
</tr>
<tr>
<td>10b</td>
<td>SETUP Token generates token (2DH) (undefined if endpoint is an interrupt, the queue head is non-zero) transfer type, for example, μFrame S-mask field in.</td>
</tr>
<tr>
<td>11b</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>7-0 Status</th>
<th>This field is used by the Host Controller to communicate individual command execution states back to HCD. This field contains the status of the last transaction performed on this qTD. The bit encodings are:</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit</td>
<td>Status Field Description</td>
</tr>
<tr>
<td>7</td>
<td>Active. Set to one by software to enable the execution of transactions by the Host Controller.</td>
</tr>
<tr>
<td>6</td>
<td>Halted. Set to one by the Host Controller during status updates to indicate that a serious error has occurred at the device/endpoint addressed by this qTD. This can be caused by babble, the error counter counting down to zero, or reception of the STALL handshake from the device during a transaction. Any time that a transaction results in the Halted bit being set to a one, the Active bit is also set to zero.</td>
</tr>
<tr>
<td>5</td>
<td>Data Buffer Error. Set to a one by the Host Controller during status update to indicate that the Host Controller is unable to keep up with the reception of incoming data (overrun) or is unable to supply data fast enough during transmission (under run). If an overrun condition occurs, the Host Controller forces a timeout condition on the USB, invalidating the transaction at the source. If the host controller sets this bit to a one, then it remains a one for the duration of the transfer.</td>
</tr>
<tr>
<td>4</td>
<td>Babble Detected. Set to a one by the Host Controller during status update when &quot;babble&quot; is detected during the transaction. In addition to setting this bit, the Host Controller also sets the Halted bit to a one. Because &quot;babble&quot; is considered a fatal error for the transfer, setting the Halted bit to a one insures that no more transactions occur because of this descriptor.</td>
</tr>
<tr>
<td>3</td>
<td>Transaction Error (XactErr). Set to a one by the Host Controller during status update in the case where the host did not receive a valid response from the device (Timeout, CRC, Bad PID, etc.). If the host controller sets this bit to a one, then it remains a one for the duration of the transfer.</td>
</tr>
<tr>
<td>2</td>
<td>Missed Micro-Frame. This bit is ignored unless the QH.EPS field indicates a full- or low-speed endpoint and the queue head is in the periodic list. This bit is set when the host controller detected that a host-induced hold-off caused the host controller to miss a required complete-split transaction. If the host controller sets this bit to a one, then it remains a one for the duration of the transfer.</td>
</tr>
</tbody>
</table>
| 1           | Split Transaction State (SplitXstate). This bit is ignored by the host controller unless the QH.EPS field indicates a full- or low-speed endpoint. When a Full- or Low-speed device, the host controller uses this bit to track the state of the split-

*Table continues on the next page...*
Table 42-24. TD Token (DWord 2) (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>transaction. The functional requirements of the host controller for managing this state bit and the split transaction protocol depends on whether the endpoint is in the periodic or asynchronous schedule. The bit encodings are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td>0b</td>
<td>Do Start Split. This value directs the host controller to issue a Start split transaction to the endpoint.</td>
</tr>
<tr>
<td>1b</td>
<td>Do Complete Split. This value directs the host controller to issue a Complete split transaction to the endpoint.</td>
</tr>
<tr>
<td>0</td>
<td>Ping State (P)/ERR. If the QH.EPS field indicates a High-speed device and the PID_Code indicates an OUT endpoint, then this is the state bit for the Ping protocol. The bit encodings are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td>0b</td>
<td>Do OUT. This value directs the host controller to issue an OUT PID to the endpoint.</td>
</tr>
<tr>
<td>1b</td>
<td>Do Ping. This value directs the host controller to issue a PING PID to the endpoint.</td>
</tr>
<tr>
<td></td>
<td>If the QH.EPS field does not indicate a High-speed device, then this field is used as an error indicator bit. It is set to a one by the host controller whenever a periodic split-transaction receives an ERR handshake.</td>
</tr>
</tbody>
</table>

42.5.2.5.4 qTD Buffer Page Pointer List

The last five DWords of a queue element transfer descriptor is an array of physical memory address pointers. These pointers reference the individual pages of a data buffer.

System software initializes Current Offset field to the starting offset into the current page, where current page is selected through the value in the C_Page field.

The following table describes the qTD Buffer Pointer(s) (DWords 3-7) fields.

Table 42-25. qTD Buffer Pointer(s) (DWords 3-7)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Buffer Pointer List. Each element in the list is a 4 K page aligned physical memory address. The lower 12 bits in each pointer are reserved (except for the first one), as each memory pointer must reference the start of a 4 K page. The field C_Page specifies the current active pointer. When the transfer element descriptor is fetched, the starting buffer address is selected using C_Page (similar to an array index to select an array element). If a transaction spans a 4K buffer boundary, the host controller must detect the page-span boundary in the data stream, increment C_Page and advance to the next buffer pointer in the list, and conclude the transaction through the new buffer pointer.</td>
</tr>
<tr>
<td>11-0</td>
<td>Current Offset (Reserved). This field is reserved in all pointers except the first one (for example Page 0). The host controller should ignore all reserved bits. For the page 0 current offset interpretation, this field is the byte offset into the current page (as selected by C_Page). The host controller is not required to write this field back when the qTD is retired. Software should ensure the Reserved fields are initialized to zero.</td>
</tr>
</tbody>
</table>
42.5.2.6 Queue Head

The table located in this section shows the Queue Head structure layout.

The following table shows the queue head structure layout.

<table>
<thead>
<tr>
<th>Table 42-26. Queue Head Structure Layout</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
</tr>
<tr>
<td>----</td>
</tr>
<tr>
<td>RL</td>
</tr>
<tr>
<td>Mult</td>
</tr>
<tr>
<td>Current qTD Pointer</td>
</tr>
<tr>
<td>Next qTD Pointer</td>
</tr>
<tr>
<td>Alternate Next qTD pointer</td>
</tr>
<tr>
<td>dt</td>
</tr>
<tr>
<td>Buffer Pointer (Page 0)</td>
</tr>
<tr>
<td>Buffer Pointer (Page 1)</td>
</tr>
<tr>
<td>Buffer Pointer (Page 2)</td>
</tr>
<tr>
<td>Buffer Pointer (Page 3)</td>
</tr>
<tr>
<td>Buffer Pointer (Page 4)</td>
</tr>
</tbody>
</table>

1. 04-0B: Static endpoint state.
2. These fields are used exclusively to support split transactions to USB 2.0 hubs.
3. 10-2F: Transfer overlay.
42.5.2.6.1 Queue Head Horizontal Link Pointer

The first DWord of a Queue Head contains a link pointer to the next data object to be processed after any required processing in this queue has been completed, as well as the control bits defined below.

This pointer may reference a queue head or one of the isochronous transfer descriptors. It must not reference a queue element transfer descriptor.

The following table describes the Queue head DWord 0 fields.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Queue Head Horizontal Link Pointer (QHLP). This field contains the address of the next data object to be processed in the horizontal list and corresponds to memory address signals [31:5], respectively.</td>
</tr>
<tr>
<td>4-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2-1</td>
<td>QH/(s)TD Select (Typ). This field indicates to the hardware whether the item referenced by the link pointer is an iTD, siTD or a QH. This allows the Host Controller to perform the proper type of processing on the item after it is fetched. Value encodings are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td></td>
<td>00b iTD (isochronous transfer descriptor)</td>
</tr>
<tr>
<td></td>
<td>01b QH (queue head)</td>
</tr>
<tr>
<td></td>
<td>10b siTD (split transaction isochronous transfer descriptor)</td>
</tr>
<tr>
<td></td>
<td>11b FSTN (frame span traversal node)</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1=Last QH (pointer is invalid). 0=Pointer is valid. If the queue head is in the context of the periodic list, a one bit in this field indicates to the host controller that this is the end of the periodic list. This bit is ignored by the host controller when the queue head is in the Asynchronous schedule. Software must ensure that queue heads reachable by the host controller always have valid horizontal link pointers.</td>
</tr>
</tbody>
</table>

42.5.2.6.2 Queue Head Endpoint Capabilities/Characteristics

The second and third DWords of a Queue Head specifies static information about the endpoint. This information does not change over the lifetime of the endpoint.

There are three types of information in this region:

- Endpoint Characteristics. These are the USB endpoint characteristics including addressing, maximum packet size, and endpoint speed.
- Endpoint Capabilities. These are adjustable parameters of the endpoint. They effect how the endpoint data stream is managed by the host controller.
- Split Transaction Characteristics. This data structure is used to manage full- and low-speed data streams for bulk, control, and interrupt via split transactions to USB2.0 Hub Transaction Translator. There are additional fields used for addressing the hub and scheduling the protocol transactions (for periodic).
The host controller must not modify the bits in this region.

The following table describes the Endpoint characteristics: Queue head DWord 1 fields.

### Table 42-28. Endpoint Characteristics: Queue Head DWord 1

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Nak Count Reload (RL). This field contains a value, which is used by the host controller to reload the Nak Counter field.</td>
</tr>
<tr>
<td>27</td>
<td>Control Endpoint Flag (C). If the QH.EPS field indicates the endpoint is not a high-speed device, and the endpoint is a control endpoint, then software must set this bit to a one. Otherwise, it should always set this bit to zero.</td>
</tr>
<tr>
<td>26-16</td>
<td>Maximum Packet Length. This directly corresponds to the maximum packet size of the associated endpoint (wMaxPacketSize). The maximum value this field may contain is 0x400 (1024).</td>
</tr>
<tr>
<td>15</td>
<td>Head of Reclamation List Flag (H). This bit is set by System Software to mark a queue head as being the head of the reclamation list.</td>
</tr>
</tbody>
</table>
| 14   | Data Toggle Control (DTC). This bit specifies where the host controller should get the initial data toggle on an overlay transition.  
  0b Ignore DT bit from incoming qTD. Host controller preserves DT bit in the queue head.  
  1b Initial data toggle comes from incoming qTD DT bit. Host controller replaces DT bit in the queue head from the DT bit in the qTD. |
| 13-12| Endpoint Speed (EPS). This is the speed of the associated endpoint. Bit combinations are:  
  Value | Meaning |
  00b  | Full-Speed (12 Mbits/sec) |
  01b  | Low-Speed (1.5 Mbits/sec) |
  10b  | High-Speed (480 Mbits/sec) |
  11b  | Reserved |
  This field must not be modified by the host controller. |
| 11-8 | Endpoint Number (Endpt). This 4-bit field selects the particular endpoint number on the device serving as the data source or sink. |
| 7    | Inactivate on Next Transaction (I). This bit is used by system software to request that the host controller set the Active bit to zero. See Rebalancing the periodic schedule, for full operational details. This field is only valid when the queue head is in the Periodic Schedule and the EPS field indicates a Full or Low-speed endpoint. Setting this bit to one when the queue head is in the Asynchronous Schedule or the EPS field indicates a high-speed device yields undefined results. |
| 6-0  | Device Address. This field selects the specific device serving as the data source or sink. |

The table below describes the Endpoint capabilities: Queue head DWord 2 field descriptions.

### Table 42-29. Endpoint Capabilities: Queue Head DWord 2

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31-30| High-Bandwidth Pipe Multiplier (Mult). This field is a multiplier used to key the host controller as the number of successive packets the host controller may submit to the endpoint in the current execution. The host controller makes the simplifying assumption that software properly initializes this field (regardless of location of queue head in the schedules or other run time parameters). The valid values are:  
  Value | Meaning |
  Table continues on the next page... |
Table 42-29. Endpoint Capabilities: Queue Head DWord 2 (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00b</td>
<td>Reserved. A zero in this field yields undefined results.</td>
</tr>
<tr>
<td>01b</td>
<td>One transaction to be issued for this endpoint per micro-frame.</td>
</tr>
<tr>
<td>10b</td>
<td>Two transactions to be issued for this endpoint per micro-frame.</td>
</tr>
<tr>
<td>11b</td>
<td>Three transactions to be issued for this endpoint per micro-frame.</td>
</tr>
<tr>
<td>29-23</td>
<td>Port Number. This field is ignored by the host controller unless the EPS field indicates a full- or low-speed device. The value is the port number identifier on the USB 2.0 Hub (for hub at device address Hub Addr below), below which the full- or low-speed device associated with this endpoint is attached. This information is used in the split-transaction protocol.</td>
</tr>
<tr>
<td>22-16</td>
<td>Hub Addr. This field is ignored by the host controller unless the EPS field indicates a full- or low-speed device. The value is the USB device address of the USB 2.0 Hub below which the full- or low-speed device associated with this endpoint is attached. This field is used in the split-transaction protocol.</td>
</tr>
<tr>
<td>15-8</td>
<td>Split Completion Mask (μFrame C-Mask). This field is ignored by the host controller unless the EPS field indicates this device is a low- or full-speed device and this queue head is in the periodic list. This field (along with the Active and SplitX-state fields) is used to determine during which micro-frames the host controller should execute a complete-split transaction. When the criteria for using this field are met, a zero value in this field has undefined behavior. This field is used by the host controller to match against the three low-order bits of the FRINDEX register. If the FRINDEX register bits decode to a position where the μFrame C-Mask field is a one, then this queue head is a candidate for transaction execution. There may be more than one bit in this mask set.</td>
</tr>
<tr>
<td>7-0</td>
<td>Interrupt Schedule Mask (μFrame S-mask). This field is used for all endpoint speeds. Software should set this field to a zero when the queue head is on the asynchronous schedule. A non-zero value in this field indicates an interrupt endpoint. The host controller uses the value of the three low-order bits of the FRINDEX register as an index into a bit position in this bit vector. If the μFrame S-mask field has a one at the indexed bit position then this queue head is a candidate for transaction execution. If the EPS field indicates the endpoint is a high-speed endpoint, then the transaction executed is determined by the PID_Code field contained in the execution area. This field is also used to support split transaction types: Interrupt (IN/OUT). This condition is true when this field is non-zero and the EPS field indicates this is either a full- or low-speed device. A zero value in this field, in combination with existing in the periodic frame list has undefined results.</td>
</tr>
</tbody>
</table>

42.5.2.6.3 Transfer Overlay-Queue Head

The nine DWords in this area represent a transaction working space for the host controller. The general operational model is that the host controller can detect whether the overlay area contains a description of an active transfer. If it does not contain an active transfer, then it follows the Queue Head Horizontal Link Pointer to the next queue head. The host controller will never follow the Next Transfer Queue Element or Alternate Queue Element pointers unless it is actively attempting to advance the queue. For the duration of the transfer, the host controller keeps the incremental status of the transfer in the overlay area. When the transfer is complete, the results are written back to the original queue element.

The DWord3 of a Queue Head contains a pointer to the source qTD currently associated with the overlay. The host controller uses this pointer to write back the overlay area into the source qTD after the transfer is complete.

The following table describes the current qTD link pointer field descriptions.
**Table 42-30. Current qTD Link Pointer**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Current Element Transaction Descriptor Link Pointer. This field contains the address of the current transaction being processed in this queue and corresponds to memory address signals [31:5], respectively.</td>
</tr>
<tr>
<td>4-0</td>
<td>Reserved (R). These bits are ignored by the host controller when using the value as an address to write data. The actual value may vary depending on the usage.</td>
</tr>
</tbody>
</table>

The DWords 4-11 of a queue head are the transaction overlay area. This area has the same base structure as a Queue Element Transfer Descriptor. The queue head utilizes the reserved fields of the page pointers to implement tracking the state of split transactions.

This area is characterized as an overlay because when the queue is advanced to the next queue element, the source queue element is merged onto this area. This area serves as execution cache for the transfer.

The table below describes the Host-controller rules for bits in overlay.

**Table 42-31. Host-Controller Rules for Bits in Overlay (DWords 5, 6, 8 and 9)**

<table>
<thead>
<tr>
<th>DWord</th>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>4-1</td>
<td>Nak Counter (NakCnt)μRW. This field is a counter the host controller decrements whenever a transaction for the endpoint associated with this queue head results in a Nak or Nyet response. This counter is reloaded from RL before a transaction is executed during the first pass of the reclamation list (relative to an Asynchronous List Restart condition). It is also loaded from RL during an overlay.</td>
</tr>
<tr>
<td>6</td>
<td>31</td>
<td>Data Toggle. The Data Toggle Control controls whether the host controller preserves this bit when an overlay operation is performed.</td>
</tr>
<tr>
<td>6</td>
<td>15</td>
<td>Interrupt On Complete (IOC). The IOC control bit is always inherited from the source qTD when the overlay operation is performed.</td>
</tr>
<tr>
<td>6</td>
<td>11-10</td>
<td>Error Counter (C_ERR). This two-bit field is copied from the qTD during the overlay and written back during queue advancement.</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>Ping State (P)/ERR. If the EPS field indicates a high-speed endpoint, then this field should be preserved during the overlay operation.</td>
</tr>
<tr>
<td>8</td>
<td>7-0</td>
<td>Split-transaction Complete-split Progress (C-prog-mask). This field is initialized to zero during any overlay. This field is used to track the progress of an interrupt split-transaction.</td>
</tr>
<tr>
<td>9</td>
<td>4-0</td>
<td>Split-transaction Frame Tag (Frame Tag). This field is initialized to zero during any overlay. This field is used to track the progress of an interrupt split-transaction.</td>
</tr>
<tr>
<td>9</td>
<td>11-5</td>
<td>S-bytes. Software must ensure that the S-bytes field in a qTD is zero before activating the qTD. This field is used to keep track of the number of bytes sent or received during an IN or OUT split transaction.</td>
</tr>
</tbody>
</table>

### 42.5.2.7 Periodic Frame Span Traversal Node (FSTN)

This data structure is to be used only for managing Full- and Low-speed transactions that span a Host-frame boundary.
See Host Controller Operational Model for FSTNs for full operational details. Software must not use an FSTN in the Asynchronous Schedule. An FSTN in the Asynchronous schedule results in undefined behavior. Software must not use the FSTN feature with a host controller whose USB_HCIVERSION register indicates a revision implementation below 0096h. FSTNs are not defined for implementations before 0.96 and their use yields undefined results.

### Table 42-32. Frame Span Traversal Node Structure Layout

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Normal Path Link Pointer (NPLP). This field contains the address of the next data object to be processed in the periodic list and corresponds to memory address signals [31:5], respectively.</td>
</tr>
<tr>
<td>4-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2-1</td>
<td>QH/(s)TD/FSTN Select (Typ). This field indicates to the Host Controller whether the item referenced is a iTD/siTD, a QH or an FSTN. This allows the Host Controller to perform the proper type of processing on the item after it is fetched. Value encodings are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td></td>
<td>00b iTD (isochronous transfer descriptor)</td>
</tr>
<tr>
<td></td>
<td>01b QH (queue head)</td>
</tr>
<tr>
<td></td>
<td>10b siTD (split transaction isochronous transfer descriptor)</td>
</tr>
<tr>
<td></td>
<td>11b FSTN (Frame Span Traversal Node)</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1 = Link Pointer field is not valid. 0 = Link Pointer is valid.</td>
</tr>
</tbody>
</table>

1. Must be set to indicate a queue head

#### 42.5.2.7.1 FSTN Normal Path Pointer

The first DWord of an FSTN contains a link pointer to the next schedule object. This object can be of any valid periodic schedule data type.

The following table describes the FSTN normal path pointer fields.

### Table 42-33. FSTN Normal Path Pointer Field Descriptions

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Normal Path Link Pointer (NPLP). This field contains the address of the next data object to be processed in the periodic list and corresponds to memory address signals [31:5], respectively.</td>
</tr>
<tr>
<td>4-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2-1</td>
<td>QH/(s)TD/FSTN Select (Typ). This field indicates to the Host Controller whether the item referenced is a iTD/siTD, a QH or an FSTN. This allows the Host Controller to perform the proper type of processing on the item after it is fetched. Value encodings are:</td>
</tr>
<tr>
<td></td>
<td>Value Meaning</td>
</tr>
<tr>
<td></td>
<td>00b iTD (isochronous transfer descriptor)</td>
</tr>
<tr>
<td></td>
<td>01b QH (queue head)</td>
</tr>
<tr>
<td></td>
<td>10b siTD (split transaction isochronous transfer descriptor)</td>
</tr>
<tr>
<td></td>
<td>11b FSTN (Frame Span Traversal Node)</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1 = Link Pointer field is not valid. 0 = Link Pointer is valid.</td>
</tr>
</tbody>
</table>
**42.5.2.7.2 FSTN Back Path Link Pointer**

The second DWord of an FTSN node contains a link pointer to a queue head.

If the T-bit in this pointer is zero, then this FSTN is a Save-Place indicator. Its Typ field must be set by software to indicate the target data structure is a queue head. If the T-bit in this pointer is set to one, then this FSTN is the Restore indicator. When the T-bit is one, the host controller ignores the Typ field.

The following table describes the FSTN back path link pointer fields.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Back Path Link Pointer (BPLP). This field contains the address of a Queue Head. This field corresponds to memory address signals [31:5], respectively.</td>
</tr>
<tr>
<td>4-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2-1</td>
<td>Typ. Software must ensure this field is set to indicate the target data structure is a Queue Head. Any other value in this field yields undefined results.</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1=Link Pointer field is not valid (that is the host controller must not use bits [31:5] as a valid memory address). This value also indicates that this FSTN is a Restore indicator. 0=Link Pointer is valid (that is the host controller may use bits [31:5] (in combination with the CTRLDSSEGMENT register if applicable) as a valid memory address). This value also indicates that this FSTN is a Save-Place indicator.</td>
</tr>
</tbody>
</table>

**42.5.3 Host Operational Model**

The general operational model is for the enhanced interface host controller hardware and enhanced interface host controller driver (generally referred to as system software).

Each significant operational feature of the EHCI host controller is discussed in a separate section. Each section presents the operational model requirements for the host controller hardware. Where appropriate, recommended system software operational models for features are also presented.

**42.5.3.1 Host Controller Initialization**

After initial power-on or HReset (hardware or through HReset bit in the USB_USBCMD register), all of the operational registers are at their default values. After a hardware reset, only the operational registers not contained in the Auxiliary power well are at their default values.

The following table describes the default values of operational registers.
To initialize the host controller, software should perform the following steps:

- Write the appropriate value to the USB_USBINTR register to enable the appropriate interrupts.
- Write the base address of the Periodic Frame List to the USB_PERIODICLISTBASE register. If no work items are in the periodic schedule, all elements of the Periodic Frame List should have their T-Bits set to one.
- Write the USB_USBCMD register to set the desired interrupt threshold, frame list size (if applicable) and turn the host controller ON through setting the Run/Stop bit.

At this point, the host controller is up and running and the port registers begin reporting device connects, and so on. System software can enumerate a port through the reset process (where the port is in the enabled state). At this point, the port is active with SOFs occurring down the enabled ports, but the schedules have not enabled. To communicate with devices through the asynchronous schedule, system software must write the USB_ASYNCLISTADDR register with the address of a control or bulk queue head. Software must then enable the asynchronous schedule by writing one to the Asynchronous Schedule Enable bit in the USB_USBCMD register. To communicate with devices through the periodic schedule, system software must enable the periodic schedule by writing one to the Periodic Schedule Enable bit in the USB_USBCMD register.

**NOTE**

The schedules can be turned on before the first port is reset (and enabled).

When the USB_USBCMD register is written, system software must ensure the appropriate bits are preserved, depending on the intended operation.

---

**Table 42-35. Default Values of Operational Register Space**

<table>
<thead>
<tr>
<th>Operational Register</th>
<th>Default Value (after Reset)</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB_USBCMD</td>
<td>00080000h (00080B00h, if Asynchronous Schedule Park Capability is one)</td>
</tr>
<tr>
<td>USB_USBSTS</td>
<td>00001000h</td>
</tr>
<tr>
<td>USB_USBINTR</td>
<td>00000000h</td>
</tr>
<tr>
<td>USB_FRINDEX</td>
<td>00000000h</td>
</tr>
<tr>
<td>USB_CTRLDSSEGMENT</td>
<td>00000000h</td>
</tr>
<tr>
<td>USB_PERIODICLISTBASE</td>
<td>Undefined</td>
</tr>
<tr>
<td>USB_ASYNCLISTADDR</td>
<td>Undefined</td>
</tr>
<tr>
<td>USB_CONFIGFLAG</td>
<td>00000000h</td>
</tr>
<tr>
<td>USB_PORTSC1</td>
<td>00002000h (w/PPC set to one); 00003000h (w/PPC set to zero)</td>
</tr>
</tbody>
</table>
42.5.3.2 Port Routing and Control

The EHCI specification defines that a USB 2.0 Host controller is comprised of one high-speed host controller, which implements the EHCI programming interface and 0 to N USB 1.1 companion host controllers.

Companion host controllers (cHCs) may be implementations of either Universal or Open host controller specifications. This configuration is used to deliver the required full USB 2.0-defined port capability; for example, Low-, Full-, and High-speed capability for every port.

**NOTE**

The USB controllers on do not require nor support companion controllers to support Full and Low Speed device. Full and Low Speed devices are supported within the USB controller by emulating the functionality of a high-speed HUB. Therefore, no port routing is present in the controller. Please refer to [Embedded Transaction Translator Function](#) for details.

The following figure illustrates a simple block diagram of the port routing logic and its relationship to the high-speed and companion host controllers within a USB 2.0 host controller.
There exists one transceiver per physical port and each host controller block has its own port status and control registers. The EHCI controller has port status and control registers for every port. Each companion host controller has only the port control and status registers it is required to operate. Either the EHCI host controller or one companion host controller controls each transceiver. Routing logic lies between the transceiver, the port status and control registers.

The port routing logic is controlled from signals originating in the EHCI host controller. The EHCI host controller has a global routing policy control field and per-port ownership control fields. The Configured Flag (CF) bit is the global routing policy control. At power-on or reset, the default routing policy is to the companion controllers (if they exist). If the system does not include a driver for the EHCI host controller and the host controller includes Companion Controllers, then the ports still work in Full- and Low-speed mode (assuming the system includes a driver for the companion controllers). In general, when the EHCI owns the ports, the companion host controllers’ port registers do not see a connect indication from the transceiver. Similarly, when a companion host controller owns a port, the EHCI controller's port registers do not see a connect indication.

---

1. The routing logic should not be implemented in the 480 MHz clock domain of the transceiver.
from the transceiver. The details on the rules for the port routing logic are described in the following sections. The USB 2.0 host controller must be implemented as a multi-function PCI device if the implementation includes companion controllers. The companion host controllers' function numbers must be less than the EHCI host controller function number. The EHCI host controller must be a larger function number with respect to the companion host controllers associated with this EHCI host controller. If a PCI device implementation contains only an EHCI controller (that is no companion controllers or other PCI functions), then the EHCI host controller must be function zero, in accordance with the PCI Specification. The N_CC field in the Structural Parameter register (HCSPARMS) indicates whether the controller implementation includes companion host controllers. When N_CC has a non-zero value there exists companion host controllers. If N_CC has a value of zero, then the host controller implementation does not include companion host controllers. If the host controller root ports are exposed to attachment of full- or low-speed devices, the ports always fails the high-speed chirp during reset and the ports are not enabled. System software can notify the user of the illegal condition. This type of implementation requires a USB 2.0 hub be connected to a root port to provide full and low-speed device connectivity.

System software uses information in the host controller capability registers to determine how the ports are routed to the companion host controllers. See Host Controller Structural Parameters (USB_nHCSPARMS)

42.5.3.2.1 Port Routing Control through EHCI Configured (CF) Bit

Each port in the USB 2.0 host controller are routed either to a single companion host controller or to the EHCI host controller.

The port routing logic is controlled by two mechanisms in the EHCI HC: a host controller global flag and per-port control. The Configured Flag (CF) bit, is used to globally set the policy of the routing logic. Each port register has a Port Owner control bit which allows the EHCI Driver to explicitly control the routing of individual ports. Whenever the CF bit transitions from zero to one (this transition is only available under program control) the port routing unconditionally routes all of the port registers to the EHCI HC (all Port Owner bits go to zero). While the CF-bit is one, the EHCI Driver controls individual ports' routing through the Port Owner control bit. Likewise, whenever the CF bit transitions from one to zero (as a result of Aux power application, HCRESET, or software writing zero to CF-bit), the port routing unconditionally routes all of the port registers to the appropriate companion HC. The default value for the EHCI HC's CF bit (after Aux power application or HCRESET) is zero.
The view of the port depends on the current owner. A Universal or Open companion host controller will see port register bits consistent with the appropriate specification. Port bit definitions that are required for EHCI host controllers are not visible to companion host controllers.

The following table summarizes the default routing for all the ports, based on the value of the EHCI HC’s CF bit.

<table>
<thead>
<tr>
<th>HS CF Bit</th>
<th>Default Port Ownership</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0B</td>
<td>Companion HCs</td>
<td>The companion host controllers own the ports and only Full- and Low-speed devices are supported in the system. The exact port assignments are implementation dependent. The ports behave only as Full- and Low-speed ports in this configuration.</td>
</tr>
<tr>
<td>1B</td>
<td>EHCI HC</td>
<td>The EHCI host controller has default ownership over all of the ports. The routing logic inhibits device connect events from reaching the companion HCs’ port status and control registers when the port owner is the EHCI HC. The EHCI HC has access to the additional port status and control bits defined in this specification (see Port Status &amp; Control (USB_PORTSC1)). The EHCI HC can temporarily release control of the port to a companion HC by setting the PortOwner bit in the PORTSC1 register to one.</td>
</tr>
</tbody>
</table>

**42.5.3.2.2 Port Routing Control through PortOwner and Disconnect Event**

Manipulating the port routing through the CF-bit is an extreme process and not intended to be used during normal operation.

The normal mode of port ownership transferal is on the granularity of individual ports using the Port Owner bit in the EHCI HC's USB_PORTSC1 register (for hand-offs from EHCI to companion host controllers). Individual port ownership is returned to the EHCI controller when the port registers a device disconnect. When the disconnect is detected, the port routing logic immediately returns the port ownership to the EHCI controller. The companion host controller port register detects the device disconnect and operates normally.

Under normal operating conditions (assuming all HC drivers loaded and operational and the EHCI CF-bit is set to one), the typical port enumeration sequence proceeds as illustrated below:

- Initial condition is that EHCI is port owner. A device is connected causing the port to detect a connect, set the port connect change bit and issue a port-change interrupt (if enabled).
- EHCI Driver identifies the port with the new connect change bit asserted and sends a change report to the hub driver. Hub driver issues a GetPortStatus() request and
identifies the connect change. It then issues a request to clear the connect change, followed by a request to reset and enable the port.

- When the EHCI Driver receives the request to reset and enable the port, it first checks the value reported by the LineStatus bits in the USB_PORTSC1 register. If they indicate the attached device is a full-speed device (for example, D+ is asserted), then the EHCI Driver sets the PortReset control bit to one (and sets the PortEnable bit to zero) which begins the reset-process. Software times the duration of the reset, then terminates reset signaling by writing zero to the port reset bit. The reset process is actually complete when software reads zero in the PortReset bit. The EHCI Driver checks the PortOwner bit in the USB_PORTSC1 register. If set to one, the connected device is a high-speed device and EHCI Driver (root hub emulator) issues a change report to the hub driver and the hub driver continues to enumerate the attached device.

- At the time the EHCI Driver receives the port reset and enable request the LineStatus bits might indicate a low-speed device. Additionally, when the port reset process is complete, the PortEnable field may indicate that a full-speed device is attached. In either case the EHCI driver sets the PortOwner bit in the USB_PORTSC1 register to one to release port ownership to a companion host controller.

- When the EHCI Driver sets PortOwner bit to one, the port routing logic makes the connection state of the transceiver available to the companion host controller port register and removes the connection state from the EHCI HC port. The EHCI USB_PORTSC1 register observes and reports a disconnect event through the disconnect change bit. The EHCI Driver detects the connection status change (either by polling or by port change interrupt) and then sends a change report to the hub driver. When the hub driver requests that port-state, the EHCI Driver responds with a reset complete change set to one, a connect change set to one and a connect status set to zero. This information is derived directly from the EHCI port register. This allows the hub driver to assume the device was disconnected during reset. It acknowledges the change bits and wait for the next change event. While the EHCI controller does not own the port, it simply remains in a state where the port reports no device connected. The device-connect evaluation circuitry of the companion HC activates and detects the device, the companion Driver detects the connection and enumerates the port.

When a port is routed to a companion HC, it remains under the control of the companion HC until the device is disconnected from the root port (ignoring for now the scenario where EHCI's CF-bit transitions from 1b to 0b). When a disconnect occurs, the disconnect event is detected by both the companion HC port control and the EHCI port ownership control. On the event, the port ownership is returned immediately to the EHCI controller. The companion HC stack detects the disconnect and acknowledges as it would in an ordinary standalone implementation. Subsequent connects is detected by the EHCI port register and the process repeats.
42.5.3.2.3 Example Port Routing State Machine

The following figure illustrates an example of how the port ownership should be managed. The following sections describe the entry conditions to each state.

![Port Owner Handoff State Machine Diagram]

**Figure 42-5. Port Owner Handoff State Machine**

42.5.3.2.3.1 EHCI HC Owner

Entry to this state occurs when one of the following events occur:

- When the EHCI HC's Configure Flag (CF) bit in the USB_CONFIGFLAG register transitions from zero to one. This signals the fact that the system has a host controller driver for the EHCI HC and that all ports in the USB 2.0 host controller must default route to the EHCI controller.
- When the port is owned by a companion HC and the device is disconnected from the port. The EHCI port routing control logic is notified of the disconnect, and returns port routing to the EHCI controller. The connection state of the companion HC goes immediately to the disconnected state (with appropriate side effect to connect change, enable and enable change). The companion HC driver acknowledges the disconnect by setting the connect status change bit to zero. This allows the companion HC's driver to interact with the port completely through the disconnect process.
- When system software writes zero to the PortOwner bit in the USB_PORTSC1 register. This allows software to take ownership of a port from a companion host controller. When this occurs, the routing logic to the companion HC effectively signals a disconnect to the companion HC's port status and control register.
42.5.3.2.3.2 **Companion HC Owner**

Entry to this state occurs whenever one of the following events occur:

- When the PortOwner field transitions from zero to one.
- When the HS-mode HC's Configure Flag (CF) is equal to zero.

On entry to this state, the routing logic allows the companion HC port register to detect a device connect. Normal port enumeration proceeds.

42.5.3.2.4 **Port Power**

The Port Power Control (PPC) bit in the USB_HCSPARAMS register indicates whether the USB 2.0 host controller has port power control (see [Host Controller Structural Parameters](#)).

When this bit is zero, then the host controller does not support software control of port power switches. When in this configuration, the port power is always available and the companion host controllers must implement functionality consistent with port power always on. When the PPC bit is one, then the host controller implementation includes port power switches. Each available switch has an output enable, which is referred to in this discussion as PortPowerOutputEnable (PPE). PPE is controlled based on the state of the combination bits PPC bit, EHCI Configured (CF)-bit and individual Port Power (PP) bits.

The following table describes the summary behavioral model.

<table>
<thead>
<tr>
<th>CF</th>
<th>CHC&lt;sup&gt;1&lt;/sup&gt; (PP)</th>
<th>EHC&lt;sup&gt;2&lt;/sup&gt; (PP)</th>
<th>Owner</th>
<th>PPE&lt;sup&gt;3&lt;/sup&gt;</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>X</td>
<td>CHC</td>
<td>0</td>
<td>When the EHCI controller is not configured, the port is owned by the companion host controller. When the companion HC's port power select is off, then the port power is off.</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>X</td>
<td>CHC</td>
<td>1</td>
<td>Similar to previous entry. When the companion HC's port power select is on, then the port power is on.</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>CHC</td>
<td>0</td>
<td>Port owner has port power turned off, the power to port is off.</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>EHC</td>
<td>0</td>
<td>Port owner has port power turned off, the power to port is off.</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>EHC</td>
<td>1</td>
<td>Port owner has port power on, so power to port is on.</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>CHC</td>
<td>1</td>
<td>If either HC has port power turned on, the power to the port is on.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 42-37. Port Power Enable Control Rules (continued)

<table>
<thead>
<tr>
<th>1</th>
<th>1</th>
<th>0</th>
<th>EHC</th>
<th>1</th>
<th>If either HC has port power turned on, the power to the port is on.</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>CHC</td>
<td>1</td>
<td>Port owner has port power on, so power to port is on.</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>CHC</td>
<td>1</td>
<td>Port owner has port power on, so power to port is on.</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>EHC</td>
<td>1</td>
<td>Port owner has port power on, so power to port is on.</td>
</tr>
</tbody>
</table>

1. CHC (Companion Host Controller).
2. EHC (EHCI Host Controller).
3. PPE (Port Power Enable). This bit actually turns on the port power switch (if one exists).

#### 42.5.3.2.5 Port Reporting Over-Current

Host controllers are by definition power providers on USB. Whether the ports are considered high- or low-powered is a platform implementation issue. Each EHCI USB_PORTSC1 register has an over-current status and over-current change bit.

The functionality of these bits are specified in the USB Specification Revision 2.0.

The over current detection and limiting logic usually resides outside the host controller logic. This logic may be associated with one or more ports. When this logic detects an over-current condition it is made available to both the companion and EHCI ports. The effect of an over-current status on a companion host controller port is beyond the scope of this document.

The over-current condition effects the following bits in the USB_PORTSC1 register on the EHCI port:

- **Over-current Active bits** are set to one. When the over-current condition goes away, the Over-current Active bit transitions from one to zero.
- **Over-current Change bits** are set to one. On every transition of the Over-current Active bit the host controller sets the Over-current Change bit to one. Software sets the Over-current Change bit to zero by writing one to this bit.
- **Port Enabled/Disabled bit** is set to zero. When this change bit gets set to one, then the Port Change Detect bit in the USB_USBSTS register is set to one.
- **Port Power (PP) bits** may optionally be set to zero. There is no requirement in USB that a power provider shut off power in an over current condition. It is sufficient to limit the current and leave power applied. When the Over-current Change bit transitions from zero to one, the host controller also sets the Port Change Detect bit in the USB_USBSTS register to one. In addition, if the Port Change Interrupt Enable bit in the USB_USBINTR register is one, then the host controller issues an interrupt to the system. Refer to Table 42-38 for summary behavior for over-current detection.
when the host controller is halted (suspended from a device component point of view).

### 42.5.3.3 Suspend/Resume-Host Operational Model

The EHCI host controller provides an equivalent suspend and resume model as that defined for individual ports in a USB 2.0 Hub.

Control mechanisms are provided to allow system software to suspend and resume individual ports. The mechanisms allow the individual ports to be resumed completely through software initiation. Other control mechanisms are provided to parameterize the host controller's response (or sensitivity) to external resume events. In this discussion, host-initiated, or software initiated resumes are called Resume Events/Actions. Bus-initiated resume events are called wake-up events. The classes of wake-up events are:

- Remote-wake-up enabled device asserts resume signaling. In similar kind to USB 2.0 Hubs, EHCI controllers must always respond to explicit device resume signaling and wake-up the system (if necessary).
- Port connect and disconnect and over-current events. Sensitivity to these events can be turned on or off by using the per-port control bits in the USB_PORTSC1 registers.

Selective suspend is a feature supported by every USB_PORTSC1 register. It is used to place specific ports into a suspend mode. This feature is used as a functional component for implementing the appropriate power management policy implemented in a particular operating system. When system software intends to suspend the entire bus, it should selectively suspend all enabled ports, then shut off the host controller by setting the Run/Stop bit in the USB_USBCMD register to zero. The EHCI sub-block can then be placed into a lower device state through the PCI power management interface (see Appendix A, Enhanced Host Controller Interface Specification for Universal Serial Bus, Revision 0.95, November 2000, Intel Corporation. http://www.intel.com).

When a wake event occurs, the system resumes operation and system software eventually set the Run/Stop bit to one and resume the suspended ports. Software must not set the Run/Stop bit to one until it is confirmed that the clock to the host controller is stable. This is usually confirmed in a system implementation in that all of the clocks in the system are stable before the Arm platform is restarted. So, by definition, if software is running, clocks in the system are stable and the Run/Stop bit in the USB_USBCMD register can be set to one. Minimum system software delays are also defined in the PCI Power Management Specification. Refer to PCI Power Management Specification for more information.
42.5.3.3.1 Port Suspend/Resume

System software places individual ports into suspend mode by writing one into the appropriate USB_PORTSC1 Suspend bit. Software must only set the Suspend bit when the port is in the enabled state (Port Enabled bit is one) and the EHCI is the port owner (PortOwner bit is zero).

The host controller may evaluate the Suspend bit immediately or wait until a micro-frame or frame boundary occurs. If evaluated immediately, the port is not suspended until the current transaction (if one is executing) completes. Therefore, there may be several micro-frames of activity on the port until the host controller evaluates the Suspend bit. The host controller must evaluate the Suspend bit at least every frame boundary.

System software can initiate a resume on a selectively suspended port by writing one to the Force Port Resume bit. Software should not attempt to resume a port unless the port reports that it is in the suspended state (see Port Status & Control (USB_nPORTSC1)). If system software sets Force Port Resume bit to one when the port is not in the suspended state, the resulting behavior is undefined. In order to assure proper USB device operation, software must wait for at least 10 ms after a port indicates that it is suspended (Suspend bit is one) before initiating a port resume through the Force Port Resume bit. When Force Port Resume bit is one, the host controller sends resume signaling down the port. System software times the duration of the resume (nominally 20 ms) then sets the Force Port Resume bit to zero. When the host controller receives the write to transition Force Port Resume to zero, it completes the resume sequence as defined in the USB specification, and sets both the Force Port Resume and Suspend bits to zero. Software-initiated port resumes do not affect the Port Change Detect bit in the USB_USBSTS register nor do they cause an interrupt if the Port Change Interrupt Enable bit in the USB_USBINTR register is one. An external USB event may also initiate a resume. The wake events are defined above. When a wake event occurs on a suspended port, the resume signaling is detected by the port and the resume is reflected downstream within 100 μsec. The port's Force Port Resume bit is set to one and the Port Change Detect bit in the USB_USBSTS register is set to one. If the Port Change Interrupt Enable bit in the USB_USBINTR register is one the host controller issues a hardware interrupt.

System software observes the resume event on the port, delays a port resume time (nominally 20 ms), then terminates the resume sequence by writing zero to the Force Port Resume bit in the port. The host controller receives the write of zero to Force Port Resume, terminates the resume sequence and sets Force Port Resume and Suspend port bits to zero. Software can determine that the port is enabled (not suspended) by sampling the USB_PORTSC1 register and observing that the Suspend and Force Port Resume bits are zero. Software must ensure that the host controller is running (that is HCHalted bit in the USB_USBSTS register is zero), before terminating a resume by writing zero to a
port's Force Port Resume bit. If HCHalted is one when Force Port Resume is set to zero, then SOFs do not occur down the enabled port and the device returns to suspend mode in a maximum of 10 msec.

The table below summarizes the wake-up events. Whenever a resume event is detected, the Port Change Detect bit in the USB_USBSTS register is set to one. If the Port Change Interrupt Enable bit is one in the USB_USBINTR register, the host controller generates an interrupt on the resume event. Software acknowledges the resume event interrupt by clearing the Port Change Detect status bit in the USB_USBSTS register.

**Table 42-38. Behavior During Wake-up Events**

<table>
<thead>
<tr>
<th>Port Status and Signaling Type</th>
<th>Signaled Port Response</th>
<th>Device State</th>
</tr>
</thead>
<tbody>
<tr>
<td>Port disabled, resume K-State received</td>
<td>No Effect</td>
<td>D0, Not D0</td>
</tr>
<tr>
<td>Port suspended, resume K-State received</td>
<td>Resume reflected downstream on signaled port. Force Port Resume status bit in USB_PORTSC1 register is set to one. Port Change Detect bit in USB_USBSTS register set to one.</td>
<td>[1], [2], [2]</td>
</tr>
<tr>
<td>Port is enabled, disabled or suspended, and the port's WKDSCNNT_E bit is one. A disconnect is detected.</td>
<td>Depending in the initial port state, the USB_PORTSC1 Connect Enable status bits are set to zero, and the Connect Change status bit is set to one. Port Change Detect bit in the USB_USBSTS register is set to one.</td>
<td>[1], [2], [2]</td>
</tr>
<tr>
<td>Port is enabled, disabled or suspended, and the port's WKDSCNNT_E bit is zero. A disconnect is detected.</td>
<td>Depending on the initial port state, the USB_PORTSC1 Connect and Enable status bits are set to zero, and the Connect Change status bit is set to one. Port Change Detect bit in the USB_USBSTS register is set to one.</td>
<td>[1], [3], [3]</td>
</tr>
<tr>
<td>Port is not connected and the port's WKCNNT_E bit is one. A connect is detected.</td>
<td>USB_PORTSC1 Connect Status and Connect Status Change bits are set to one. Port Change Detect bit in the USB_USBSTS register is set to one.</td>
<td>[1], [2], [2]</td>
</tr>
<tr>
<td>Port is not connected and the port's WKCNNT_E bit is zero. A connect is detected.</td>
<td>USB_PORTSC1 Connect Status and Connect Status Change bits are set to one. Port Change Detect bit in the USB_USBSTS register is set to one.</td>
<td>[1], [3], [3]</td>
</tr>
<tr>
<td>Port is connected and the port's WKOC_E bit is one. An over-current condition occurs.</td>
<td>USB_PORTSC1 Over-current Active, Over-current Change bits are set to one. If Port Enable/Disable bit is one, it is set to zero. Port Change Detect bit in the USB_USBSTS register is set to one.</td>
<td>[1], [2], [2]</td>
</tr>
<tr>
<td>Port is connected and the port's WKOC_E bit is zero. An over-current condition occurs.</td>
<td>USB_PORTSC1 Over-current Active, Over-current Change bits are set to one. If Port Enable/Disable bit is one, it is set to zero. Port Change Detect bit in the USB_USBSTS register is set to one.</td>
<td>[1], [3], [3]</td>
</tr>
</tbody>
</table>

[1] Hardware interrupt issued if Port Change Interrupt Enable bit in the USB_USBINTR register is one.

[2] PME# asserted if enabled (Note: PME Status must always be set to one).

42.5.3.4 Schedule Traversal Rules

The host controller executes transactions for devices using a simple, shared-memory schedule.

The schedule is comprised of a few data structures, organized into two distinct lists. The data structures are designed to provide the maximum flexibility required by USB, minimize memory traffic and hardware / software complexity.

System software maintains two schedules for the host controller: a periodic schedule and an asynchronous schedule. The root of the periodic schedule is the USB_PERIODICLISTBASE register (see Frame List Base Address (USB_nPERIODICLISTBASE))/ Device Address (USB_nDEVICEADDR). The USB_PERIODICLISTBASE register is the physical memory base address of the periodic frame list. The periodic frame list is an array of physical memory pointers. The objects referenced from the frame list must be valid schedule data structures as defined in Host Data Structures. In each micro-frame, if the periodic schedule is enabled (see Periodic scheduling threshold) then the host controller must execute from the periodic schedule before executing from the asynchronous schedule. It only executes from the asynchronous schedule after it encounters the end of the periodic schedule. The host controller traverses the periodic schedule by constructing an array offset reference from the USB_PERIODICLISTBASE and the USB_FRINDEX registers (see the following figure). It fetches the element and begins traversing the graph of linked schedule data structures.

The end of the periodic schedule is identified by a next link pointer of a schedule data structure having its T-bit set to one. When the host controller encounters a T-Bit set to one during a horizontal traversal of the periodic list, it interprets this as an End-Of-Periodic-List mark. This causes the host controller to cease working on the periodic schedule and transitions immediately to traversing the asynchronous schedule. After the transition, the host controller executes from the asynchronous schedule until the end of the micro-frame.

The following figure illustrates the derivation of pointer into frame list array.
When the host controller determines that it is the time to execute from the asynchronous list, it uses the operational register USB_ASYNCLISTADDR to access the asynchronous schedule, see the figure below.

Figure 42-6. Derivation of Pointer into Frame List Array

The USB_ASYNCLISTADDR register contains a physical memory pointer to the next queue head. When the host controller makes a transition to executing the asynchronous schedule, it begins by reading the queue head referenced by the USB_ASYNCLISTADDR register. Software must set queue head horizontal pointer T-bits to zero for queue heads in the asynchronous schedule. See Asynchronous Schedule for complete operational details.

Figure 42-7. General Format of Asynchronous Schedule List
42.5.3.4.1 Example - Preserving Micro-Frame Integrity

One of the requirements of a USB host controller is to maintain Frame Integrity. This means that the HC must preserve the micro-frame boundaries.

For example, SOF packets must be generated on time (within the specified allowable jitter), and High-speed EOF1,2 thresholds must be enforced. The end of micro-frame timing points EOF1 and EOF2 are clearly defined in the USB Specification Revision 2.0. One implication of this responsibility is that the HC must ensure that it does not start transactions that do not complete before the end of the micro-frame. More precisely, no transactions should be started by the host controller, which do not complete in their entirety before the EOF1 point. In order to enforce this rule, the host controller must check each transaction before it starts to ensure that it completes before the end of the micro-frame.

So, what exactly needs to be involved in this check? Fundamentally, the transaction data payload, plus bit stuffing, plus transaction overhead must be taken into consideration. It is possible to be extremely accurate on how much time the next transaction takes. Take OUTs for an example. The host controller must fetch all of the OUT data from memory in order to send it onto the USB bus. A host controller implementation could pre-fetch all of the OUT data, and pre-compute the actual number of bits in the token and data packets. In addition, the system knows the depth of the target endpoint, so it could closely estimate turnaround time for handshake. In addition, the host controller knows the size of a handshake packet. Pre-computing effects of bit stuffing and summing up the other overhead numbers can allow the host controller to know exactly whether there is enough bus time, before EOF1 to complete the OUT transaction. To accomplish this particular approach takes an inordinate amount of time and hardware complexity.

The alternative is to make a reasonable guess whether the next transaction can be started. An example approximation algorithm is described below. This example algorithm relies on the EHCI policy that periodic transactions are scheduled first in the micro-frame. It is a reasonable assumption that software never over-commits the micro-frame to periodic transactions greater than the specification allowable 80%. In the available remaining 20% bandwidth, the host controller has some ability (in this example) to decide whether or not to execute a transaction. The result of this algorithm is that sometimes, under some circumstances a transaction is not executed that could have been executed. However, under all circumstances, a transaction is never started unless there is enough time in the frame to complete the transaction.

42.5.3.4.1.1 Transaction Fit - A Best-Fit Approximation Algorithm

A curve is calculated which represents the latest start time for every packet size, at which software schedules the start of a periodic transaction.
This curve is the 80% bandwidth curve. Another curve is calculated which is the absolute, latest permitted start time for every packet size. This curve represents the absolute latest time, that a transaction of each packet size can be started and completed, in the micro-frame. A plot of these two curves are illustrated in Figure 42-8. The plot Y-axis represents the number of byte-times left in a frame.

The space between the 80% and the Last Start plots is bandwidth reclamation area. In this algorithm the host controller may skip transactions during this time if it is prudent.

The Best-Fit Approximation method plots a function \( f(x) \) between the 80% and Last Start curves. The function \( f(x) \) adds a constant to every transaction's maximum packet size and the result compared with the number of bytes left in the frame. The constant represents an approximation of the effects of bit stuffing and protocol overhead. The host controller starts transactions whose results land above the function curve. The host controller will not start transactions whose results land below the function curve.

The following figure illustrates the Best-Fit Approximation.

![Figure 42-8. Best Fit Approximation](image)

The LastStart line was calculated in this example to assume the absolute worst-case bus overhead per transaction. The particular transaction used is a start-split, zero-length OUT transaction with a handshake. Summaries of the component parts are listed in the table below. The component times were derived from the protocol timings defined in the USB Specification Revision 2.0.

<table>
<thead>
<tr>
<th>Component</th>
<th>Bit time</th>
<th>Byte Time</th>
<th>Explanation</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 42-39. Example Worse-case Transaction Timing Components (continued)

<table>
<thead>
<tr>
<th>Component</th>
<th>Value</th>
<th>Unit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Split Token</td>
<td>76</td>
<td>9.5</td>
<td>Split token as defined in USB core specification. Includes sync, token, eop, and so on.</td>
</tr>
<tr>
<td>Host 2 Host IPG</td>
<td>88</td>
<td>11</td>
<td>Number of bit times required between consecutive host packets.</td>
</tr>
<tr>
<td>Token</td>
<td>67</td>
<td>8.375</td>
<td>Token as defined in USB core specification. Includes sync, token, eop, and so on.</td>
</tr>
<tr>
<td>Host 2 Host IPG</td>
<td>88</td>
<td>11</td>
<td>Token as defined in USB core specification. Includes sync, token, eop, and so on.</td>
</tr>
<tr>
<td>Data Packet (0 data bytes)</td>
<td>66.7</td>
<td>8.34</td>
<td>Zero-length data packet. Includes sync, PID, crc16, eop, and so on.</td>
</tr>
<tr>
<td>Turnaround time</td>
<td>721</td>
<td>90.125</td>
<td>Time for packet initiator (Host) to see the beginning of a response to a transmitted packet.</td>
</tr>
<tr>
<td>Handshake packet</td>
<td>48</td>
<td>6</td>
<td>Handshake packet as defined in USB core specification. Includes sync, PID, eop, and so on.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>144 Total</td>
</tr>
</tbody>
</table>

The exact details of the function \( f(x) \) are up to the particular implementation. However, it should be obvious that the goal is to minimize the area under the curve between the approximation function and the Last Start curve, without dipping below the LastStart line, while at the same time keeping the check as simple as possible for hardware implementation. The \( f(x) \) in Figure 42-8 was constructed using the following pseudo-code test on each transaction size data point. This algorithm assumes that the host controller keeps track of the remaining bits in the frame.

```
Algorithm CheckTransactionWillFit (MaximumPacketSize, HC_BytesLeftInFrame)
Begin
  Local Temp = MaximumPacketSize + 192
  Local rvalue = TRUE
  If MaximumPacketSize >= 128 then
    Temp += 128
  End If
  If Temp > HC_BytesLeftInFrame then
    Rvalue = FALSE
  End If
Return rvalue
End
```

This algorithm takes two inputs, the current maximum packet size of the transaction and the hardware counter of the number of bytes left in the current micro-frame. It unconditionally adds a simple constant of 192 to the maximum packet size to account for a first-order effect of transaction overhead and bit stuffing. If the transaction size is greater than or equal to 128 bytes, then an additional constant of 128 is added to the running sum to account for the additional worst-case bit stuffing of payloads larger than 128. An inflection point was inserted at 128 because the \( f(x) \) plot was getting close to the LastStart line.
42.5.3.5 Periodic Schedule Frame Boundaries vs Bus Frame Boundaries

The USB Specification Revision 2.0 requires that the frame boundaries (SOF frame number changes) of the high-speed bus and the full- and low-speed bus(s) below USB 2.0 Hubs be strictly aligned.

Super-imposed on this requirement is that USB 2.0 Hubs manage full- and low-speed transactions through a micro-frame pipeline (see start- (SS) and complete- (CS) splits illustrated in the following figure). A simple, direct projection of the frame boundary model into the host controller interface schedule architecture creates tension (complexity for both hardware and software) between the frame boundaries and the scheduling mechanisms required to service the full- and low-speed transaction translator periodic pipelines.

![Frame Boundary Relationship between HS bus and FS/LS Bus](image)

The simple projection, as the above figure illustrates, introduces frame-boundary wrap conditions for scheduling on both the beginning and end of a frame. In order to reduce the complexity for hardware and software, the host controller is required to implement one micro-frame phase shift for its view of frame boundaries. The phase shift eliminates the beginning of frame and frame-wrap scheduling boundary conditions.

The implementation of this phase shift requires that the host controller use one register value for accessing the periodic frame list and another value for the frame number value included in the SOF token. These two values are separate, but tightly coupled. The periodic frame list is accessed through the Frame List Index Register (USB_FRINDEX) documented in USB Frame Index (USB_nFRINDEX) and initially illustrated in Schedule Traversal Rules. Bits FRINDEX[2:0], represent the micro-frame number. The SOF value is coupled to the value of FRINDEX[13:3]. Both FRINDEX[13:3] and the SOF value are increment based on FRINDEX[2:0]. It is required that the SOF value be delayed from the FRINDEX value by one micro-frame. The one micro-frame delay yields host controller periodic schedule and bus frame boundary relationship as illustrated in the following figure. This adjustment allows software to trivially schedule the periodic start and
complete-split transactions for full-and low-speed periodic endpoints, using the natural alignment of the periodic schedule interface. The reasons for selecting this phase-shift are beyond the scope of this specification.

The following figure illustrates how periodic schedule data structures relate to schedule frame boundaries and bus frame boundaries. To aid the presentation, two terms are defined: The host controller's view of the 1 msec boundaries is called H-Frames. The high-speed bus's view of the 1 msec boundaries is called B-Frames.

![Figure 42-10. Relationship of Periodic Schedule Frame Boundaries to Bus Frame Boundaries](image)

H-Frame boundaries for the host controller correspond to increments of FRINDEX[13:3]. Micro-frame numbers for the H-Frame are tracked by FRINDEX[2:0]. B-Frame boundaries are visible on the high-speed bus through changes in the SOF token's frame number. Micro-frame numbers on the high-speed bus are only derived from the SOF token's frame number (that is the high-speed bus sees eight SOFs with the same frame number value). H-Frames and B-Frames have the fixed relationship (that is B-Frames lag H-Frames by one micro-frame time) illustrated in the figure above. The host controller's periodic schedule is naturally aligned to H-Frames. Software schedules transactions for full- and low-speed periodic endpoints relative the H-Frames. The result is these transactions execute on the high-speed bus at exactly the right time for the USB 2.0 Hub periodic pipeline. As described in USB Frame Index (USB_nFRINDEX), the SOF Value can be implemented as a shadow register (in this example, called SOFV), which lags the FRINDEX register bits [13:3] by one micro-frame count. This lag behavior can be accomplished by incrementing FRINDEX[13:3] based on carry-out on the 7 to 0 increment of FRINDEX[2:0] and incrementing SOFV based on the transition of 0 to 1 of FRINDEX[2:0].
Software is allowed to write to FRINDEX. **USB Frame Index (USB_nFRINDEX)** provides the requirements that software should adhere when writing a new value in FRINDEX.

The table below illustrates the required relationship between the value of FRINDEX and the value of SOFV.

**Table 42-40. Operation of FRINDEX and SOFV (SOF Value Register)**

<table>
<thead>
<tr>
<th>Current</th>
<th>Next</th>
</tr>
</thead>
<tbody>
<tr>
<td>FRINDEX[F]</td>
<td>SOFV</td>
</tr>
<tr>
<td>N</td>
<td>N</td>
</tr>
<tr>
<td>N+1</td>
<td>N</td>
</tr>
<tr>
<td>N+1</td>
<td>N+1</td>
</tr>
<tr>
<td>N+1</td>
<td>N+1</td>
</tr>
<tr>
<td>N+1</td>
<td>N+1</td>
</tr>
<tr>
<td>N+1</td>
<td>N+1</td>
</tr>
<tr>
<td>N+1</td>
<td>N+1</td>
</tr>
<tr>
<td>N+1</td>
<td>N+1</td>
</tr>
</tbody>
</table>

**NOTE**

Where [F] = [13:3]; [μF] = [2:0]

**42.5.3.6 Periodic Schedule**

The periodic schedule traversal is enabled or disabled through the Periodic Schedule Enable bit in the USB_USBCMD register. If the Periodic Schedule Enable bit is set to zero, then the host controller simply does not try to access the periodic frame list through the USB_PERIODICLISTBASE register. Likewise, when the Periodic Schedule Enable bit is one, then the host controller does use the USB_PERIODICLISTBASE register to traverse the periodic schedule.

The host controller will not react to modifications to the Periodic Schedule Enable immediately. In order to eliminate conflicts with split transactions, the host controller evaluates the Periodic Schedule Enable bit only when FRINDEX[2:0] is zero. System software must not disable the periodic schedule if the schedule contains an active split transaction work item that spans the 000b micro-frame. These work items must be removed from the schedule before the Periodic Schedule Enable bit is written to zero.

The Periodic Schedule Status bit in the USB_USBSTS register indicates status of the periodic schedule. System software enables (or disables) the periodic schedule by writing one (or zero) to the Periodic Schedule Enable bit in the USB_USBCMD register. Software then can poll the Periodic Schedule Status bit to determine when the periodic
schedule has made the desired transition. Software must not modify the Periodic Schedule Enable bit unless the value of the Periodic Schedule Enable bit equals that of the Periodic Schedule Status bit.

The periodic schedule is used to manage all isochronous and interrupt transfer streams. The base of the periodic schedule is the periodic frame list. Software links schedule data structures to the periodic frame list to produce a graph of scheduled data structures. The graph represents an appropriate sequence of transactions.

The following figure illustrates isochronous transfers (using iTDs and siTDs) with a period of one are linked directly to the periodic frame list. Interrupt transfers (are managed with queue heads) and isochronous streams with periods other than one are linked following the period-one iTD/siTDs. Interrupt queue heads are linked into the frame list ordered by poll rate. Longer poll rates are linked first (for example, closest to the periodic frame list), followed by shorter poll rates, with queue heads with a poll rate of one, on the very end.

![Figure 42-11. Example Periodic Schedule](image_url)
42.5.3.7 Managing Isochronous Transfers Using iTDs

The structure of an iTD is presented in Isochronous (High-Speed) Transfer Descriptor (iTD). The four distinct sections to an iTD:

- The first field is the Next Link Pointer. This field is for schedule linkage purposes only.
- Transaction description array. This area is an eight-element array. Each element represents control and status information for one micro-frame's worth of transactions for a single high-speed isochronous endpoint.
- The buffer page pointer array is a 7-element array of physical memory pointers to data buffers. These are 4 K aligned pointers to physical memory.
- Endpoint capabilities. This area utilizes the unused low-order 12 bits of the buffer page pointer array. The fields in this area are used across all transactions executed for this iTD, including endpoint addressing, transfer direction, maximum packet size and high-bandwidth multiplier.

42.5.3.7.1 Host Controller Operational Model for iTDs

The host controller uses FRINDEX register bits [12:3] to index into the periodic frame list. This means that the host controller visits each frame list element eight consecutive times before incrementing to the next periodic frame list element. Each iTD contains eight transaction descriptions, which map directly to FRINDEX register bits [2:0]. Therefore, each transaction descriptor corresponds to one micro-frame. Each iTD can span 8 micro-frames worth of transactions.

When the host controller fetches an iTD, it uses FRINDEX register bits [2:0] to index into the transaction description array.

If the active bit in the Status field of the indexed transaction description is set to zero, the host controller ignores the iTD and follows the Next pointer to the next schedule data structure.

When the indexed active bit is one, the host controller continues to parse the iTD. It stores the indexed transaction description and the general endpoint information (device address, endpoint number, maximum packet size, and so on.). It also uses the Page Select (PG) field to index the buffer pointer array, storing the selected buffer pointer and the next sequential buffer pointer. For example, if PG field is 0, then the host controller stores Page 0 and Page 1.
The host controller constructs a physical data buffer address by concatenating the current buffer pointer (as selected using the current transaction description's PG field) and the transaction description's Transaction Offset field. The host controller uses the endpoint addressing information and I/O-bit to execute a transaction to the appropriate endpoint. When the transaction is complete, the host controller clears the active bit and writes back any additional status information to the Status field in the currently selected transaction description.

The data buffer associated with the iTD must be virtually contiguous memory. Seven page pointers are provided to support eight high-bandwidth transactions regardless of the starting packet's offset alignment into the first page. A starting buffer pointer (physical memory address) is constructed by concatenating the page pointer (for example, page 0 pointer) selected by the active transaction descriptions' PG (for example, value: 00B) field with the transaction offset field. As the transaction moves data, the host controller must detect when an increment of the current buffer pointer crosses a page boundary. When this occurs the host controller simply replaces the current buffer pointer's page portion with the next page pointer (for example, page 1 pointer) and continues to move data. The size of each bus transaction is determined by the value in the Maximum Packet Size field. An iTD supports high-bandwidth pipes through the Mult (multiplier) field. When the Mult field is 1, 2, or 3, the host controller executes the specified number of Maximum Packet sized bus transactions for the endpoint in the current micro-frame. In other words, the Mult field represents a transaction count for the endpoint in the current micro-frame. If the Mult field is zero, the operation of the host controller is undefined. The transfer description is used to service all transactions indicated by the Mult field.

For OUT transfers, the value of the Transaction X Length field represents the total bytes to be sent during the micro-frame. The Mult field must be set by software to be consistent with Transaction X Length and Maximum Packet Size. The host controller sends the bytes in Maximum Packet Size'd portions. After each transaction, the host controller decrements its local copy of Transaction X Length by Maximum Packet Size. The number of bytes the host controller sends is always Maximum Packet Size or Transaction X Length, whichever is less. The host controller advances the transfer state in the transfer description, updates the appropriate record in the iTD and moves to the next schedule data structure. The maximum sized transaction supported is 3 x 1024 bytes.

For IN transfers, the host controller issues Mult transactions. It is assumed that software has properly initialized the iTD to accommodate all of the possible data. During each IN transaction, the host controller must use Maximum Packet Size to detect packet babble errors. The host controller keeps the sum of bytes received in the Transaction X Length field. After all transactions for the endpoint have completed for the micro-frame, Transaction X Length contains the total bytes received. If the final value of Transaction X Length is less than the value of Maximum Packet Size, then less data than was allowed for was received from the associated endpoint. This short packet condition does not set
the USBINT bit in the USB_USBSTS register to one. The host controller will not detect this condition. If the device sends more than Transaction X Length or Maximum Packet Size bytes (whichever is less), then the host controller sets the Babble Detected bit to one and set the Active bit to zero. Note, that the host controller is not required to update the iTD field Transaction X Length in this error scenario. If the Mult field is greater than one, then the host controller automatically executes the value of Mult transactions. The host controller will not execute all Mult transactions if:

- The endpoint is an OUT and Transaction X Length goes to zero before all the Mult transactions have executed (ran out of data), or
- The endpoint is an IN and the endpoint delivers a short packet, or an error occurs on a transaction before Mult transactions have been executed. The end of micro-frame may occur before all of the transaction opportunities have been executed. When this happens, the transfer state of the transfer description is advanced to reflect the progress that was made, the result written back to the iTD and the host controller proceeds to processing the next micro-frame. Refer to Appendix D for a table summary of the host controller required behavior for all the high-bandwidth transaction cases.

### 42.5.3.7.2 Software Operational Model for iTDs

A client buffer request to an isochronous endpoint may span 1 to N micro-frames. When N is larger than one, system software may have to use multiple iTDs to read or write data with the buffer (if N is larger than eight, it must use more than one iTD).

The following figure illustrates the simple model of how a client buffer is mapped by system software to the periodic schedule (that is the periodic frame list and a set of iTDs). On the right is the client description of its request. The description includes a buffer base address plus additional annotations to identify which portions of the buffer should be used with each bus transaction. In the middle is the iTD data structures used by the system software to service the client request. Each iTD can be initialized to service up to 24 transactions, organized into eight groups of up to three transactions each. Each group maps to one micro-frame's worth of transactions. The EHCI controller does not provide per-transaction results within a micro-frame. It treats the per-micro-frame transactions as a single logical transfer. On the left is the host controller's frame list. System software establishes references from the appropriate locations in the frame list to each of the appropriate iTDs. If the buffer is large, then system software can use a small set of iTDs to service the entire buffer. System software can activate the transaction description records (contained in each iTD) in any pattern required for the particular data stream.
As noted above, the client request includes a pointer to the base of the buffer and offsets into the buffer to annotate which buffer sections are to be used on each bus transaction that occurs on this endpoint. System software must initialize each transaction description in an iTD to ensure it uses the correct portion of the client buffer. For example, for each transaction description, the PG field is set to index the correct physical buffer page pointer and the Transaction Offset field is set relative to the correct buffer pointer page (for example, the same one referenced by the PG field). When the host controller executes a transaction it selects a transaction description record based on FRINDEX[2:0]. It then uses the current Page Buffer Pointer (as selected by the PG field) and concatenates to the transaction offset field. The result is a starting buffer address for the transaction. As the host controller moves data for the transaction, it must watch for a page wrap condition and properly advance to the next available Page Buffer Pointer. System software must not use the Page 6 buffer pointer in a transaction description where the length of the transfer wraps a page boundary. Doing so yields undefined behavior. The host controller hardware is not required to ‘alias’ the page selector to Page zero. USB 2.0 isochronous.
endpoints can specify a period greater than one. Software can achieve the appropriate scheduling by linking iTDs into the appropriate frames (relative to the frame list) and by setting appropriate transaction description elements active bits to one.

### 42.5.3.7.2.1 Periodic scheduling threshold

The Isochronous Scheduling Threshold field in the USB_HCCPARAMS capability register is an indicator to system software as to how the host controller pre-fetches and effectively caches schedule data structures.

It is used by system software when adding isochronous work items to the periodic schedule. The value of this field indicates to system software the minimum distance it can update isochronous data (relative to the current location of the host controller execution in the periodic list) and still have the host controller process them.

The iTD and siTD data structures each describe 8 micro-frames worth of transactions. The host controller is allowed to cache one (or more) of these data structures in order to reduce memory traffic. Three basic caching models that account for the fact the isochronous data structures span 8 micro-frames. The three caching models are: no caching, micro-frame caching and frame caching.

When software is adding new isochronous transactions to the schedule, it always performs a read of the USB_FRINDEX register to determine the current frame and micro-frame the host controller is currently executing. Of course, there is no information about where in the micro-frame the host controller is, so a constant uncertainty-factor of one micro-frame has to be assumed. Combining the knowledge of where the host controller is executing with the knowledge of the caching model allows the definition of simple algorithms for how closely software can reliably work to the executing host controller.

No caching is indicated with a value of zero in the Isochronous Scheduling Threshold field. The host controller may pre-fetch data structures during a periodic schedule traversal (per micro-frame) but always dumps any accumulated schedule state at the end of the micro-frame. At the appropriate time relative to the beginning of every micro-frame, the host controller always begins schedule traversal from the frame list. Software can use the value of the USB_FRINDEX register (plus the constant 1 uncertainty-factor) to determine the approximate position of the executing host controller. When no caching is selected, software can add an isochronous transaction as near as 2 micro-frames in front of the current executing position of the host controller.

Frame caching is indicated with a non-zero value in bit [7] of the Isochronous Scheduling Threshold field. In the frame-caching model, system software assumes that the host controller caches one (or more) isochronous data structures for an entire frame (8 micro-frames). Software uses the value of the USB_FRINDEX register (plus the constant 1
uncertainty) to determine the current micro-frame/frame (assume modulo 8 arithmetic in
adding the constant 1 to the micro-frame number). For any current frame N, if the current
micro-frame is 0 to 6, then software can safely add isochronous transactions to Frame N
+ 1. If the current micro-frame is 7, then software can add isochronous transactions to
Frame N + 2.

Micro-frame caching is indicated with a non-zero value in the least-significant 3 bits of
the Isochronous Scheduling Threshold field. System software assumes the host controller
caches one or more periodic data structures for the number of micro-frames indicated in
the Isochronous Scheduling Threshold field. For example, if the count value were 2, then
the host controller keeps a window of 2 micro-frames worth of state (current micro-
frame, plus the next) on-chip. On each micro-frame boundary, the host controller releases
the current micro-frame state and begins accumulating the next micro-frame state.

42.5.3.8 Asynchronous Schedule

The Asynchronous schedule traversal is enabled or disabled through the Asynchronous
Schedule Enable bit in the USB_USBCMD register.

If the Asynchronous Schedule Enable bit is set to zero, then the host controller simply
does not try to access the asynchronous schedule through the USB_ASYNCLISTADDR
register. Likewise, when the Asynchronous Schedule Enable bit is one, then the host
controller does use the USB_ASYNCLISTADDR register to traverse the asynchronous
schedule. Modifications to the Asynchronous Schedule Enable bit are not necessarily
immediate. Rather the new value of the bit is taken into consideration the next time the
host controller needs to use the value of the USB_ASYNCLISTADDR register to get the
next queue head.

The Asynchronous Schedule Status bit in the USB_USBSTS register indicates status of
the asynchronous schedule. System software enables (or disables) the asynchronous
schedule by writing one (or zero) to the Asynchronous Schedule Enable bit in the
USB_USBCMD register. Software then can poll the Asynchronous Schedule Status bit to
determine when the asynchronous schedule has made the desired transition. Software
must not modify the Asynchronous Schedule Enable bit unless the value of the
Asynchronous Schedule Enable bit equals that of the Asynchronous Schedule Status bit.

The asynchronous schedule is used to manage all Control and Bulk transfers. Control and
Bulk transfers are managed using queue head data structures. The asynchronous schedule
is based at the USB_ASYNCLISTADDR register. The default value of the
USB_ASYNCLISTADDR register after reset is undefined and the schedule is disabled
when the Asynchronous Schedule Enable bit is zero.
Software may only write this register with defined results when the schedule is disabled. For example, Asynchronous Schedule Enable bit in the USB_USBCMD and the Asynchronous Schedule Status bit in the USB_USBSTS register are zero. System software enables execution from the asynchronous schedule by writing a valid memory address (of a queue head) into this register. Then software enables the asynchronous schedule by setting the Asynchronous Schedule Enable bit to one. The asynchronous schedule is actually enabled when the Asynchronous Schedule Status bit is one.

When the host controller begins servicing the asynchronous schedule, it begins by using the value of the USB_ASYNCLISTADDR register. It reads the first referenced data structure and begins executing transactions and traversing the linked list as appropriate. When the host controller completes processing the asynchronous schedule, it retains the value of the last accessed queue head's horizontal pointer in the USB_ASYNCLISTADDR register. Next time the asynchronous schedule is accessed, this is the first data structure that is serviced. This provides round-robin fairness for processing the asynchronous schedule.

A host controller completes processing the asynchronous schedule when one of the following events occur:

- The end of a micro-frame occurs.
- The host controller detects an empty list condition (see Empty Asynchronous Schedule Detection)
- The schedule has been disabled through the Asynchronous Schedule Enable bit in the USB_USBCMD register.

The queue heads in the asynchronous list are linked into a simple circular list as shown in Figure 42-7. Queue head data structures are the only valid data structures that may be linked into the asynchronous schedule. An isochronous transfer descriptor (iTD or siTD) in the asynchronous schedule yields undefined results.

The maximum packet size field in a queue head is sized to accommodate the use of this data structure for all non-isochronous transfer types. The USB Specification, Revision 2.0 specifies the maximum packet sizes for all transfer types and transfer speeds. System software should always parameterize the queue head data structures according to the core specification requirements.

### 42.5.3.8.1 Adding Queue Heads to Asynchronous Schedule

This is a software requirement section.

There are two independent events for adding queue heads to the asynchronous schedule. The first is the initial activation of the asynchronous list. The second is inserting a new queue head into an activated asynchronous list.
Activation of the list is simple. System software writes the physical memory address of a queue head into the USB_ASYNCLISTADDR register, then enables the list by setting the Asynchronous Schedule Enable bit in the USB_USBCMD register to one.

When inserting a queue head into an active list, software must ensure that the schedule is always coherent from the host controllers' point of view. This means that the system software must ensure that all queue head pointer fields are valid. For example, qTD pointers have T-Bits set to one or reference valid qTDs and the Horizontal Pointer references a valid queue head data structure. The following algorithm represents the functional requirements:

```c
InsertQueueHead (pQHeadCurrent, pQueueHeadNew)
--
-- Requirement: all inputs must be properly initialized.
--
-- pQHeadCurrent is a pointer to a queue head that is
-- already in the active list
-- pQueueHeadNew is a pointer to the queue head to be added
--
-- This algorithm links a new queue head into a existing
-- list
--
   pQueueHeadNew.HorizontalPointer = pQueueHeadCurrent.HorizontalPointer
   pQueueHeadCurrent.HorizontalPointer = physicalAddressOf(pQueueHeadNew)
End InsertQueueHead
```

### 42.5.3.8.2 Removing Queue Heads from Asynchronous Schedule

This is a software requirement section.

There are two independent events for removing queue heads from the asynchronous schedule. The first is shutting down (deactivating) the asynchronous list. The second is extracting a single queue head from an activated list.

Software deactivates the asynchronous schedule by setting the Asynchronous Schedule Enable bit in the USB_USBCMD register to zero. Software can determine when the list is idle when the Asynchronous Schedule Status bit in the USB_USBSTS register is zero. The normal mode of operation is that software removes queue heads from the asynchronous schedule without shutting it down. Software must not remove an active queue head from the schedule. Software should first deactivate all active qTDs, wait for the queue head to go inactive, then remove the queue head from the asynchronous list. Software removes a queue head from the asynchronous list through the following algorithm. As illustrated, the unlinking is quite easy. Software merely must ensure all of the link pointers reachable by the host controller are kept consistent.

```c
UnlinkQueueHead (pQHeadPrevious, pQueueHeadToUnlink, pQHeadNext)
--
-- Requirement: all inputs must be properly initialized.
--
-- pQHeadPrevious is a pointer to a queue head that
-- references the queue head to remove
-- pQHeadToUnlink is a pointer to the queue head to be
```
If software removes the queue head with the H-bit set to one, it must select another queue head still linked into the schedule and set its H-bit to one. This should be completed before removing the queue head. The requirement is that software keep one queue head in the asynchronous schedule, with its H-bit set to one. At the point software has removed one or more queue heads from the asynchronous schedule, it is unknown whether the host controller has a cached pointer to them. Similarly, it is unknown how long the host controller might retain the cached information, as it is implementation dependent and may be affected by the actual dynamics of the schedule load. Therefore, once software has removed a queue head from the asynchronous list, it must retain the coherency of the queue head (link pointers, and so on). It cannot disturb the removed queue heads until it knows that the host controller does not have a local copy of a pointer to any of the removed data structures.

The method software uses to determine when it is safe to modify a removed queue head is to handshake with the host controller. The handshake mechanism allows software to remove items from the asynchronous schedule, then execute a simple, lightweight handshake that is used by software as a key that it can free (or reuse) the memory associated the data structures it has removed from the asynchronous schedule.

The handshake is implemented with three bits in the host controller. The first bit is a command bit (Interrupt on Async Advance Doorbell bit in the USB_USBCMD register) that allows software to inform the host controller that something has been removed from its asynchronous schedule. The second bit is a status bit (Interrupt on Async Advance bit in the USB_USBSTS register) that the host controller sets after it has released all on-chip state that may potentially reference one of the data structures just removed. When the host controller sets this status bit to one, it also sets the command bit to zero. The third bit is an interrupt enable (Interrupt on Async Advance bit in the USB_USBINTR register) that is matched with the status bit. If the status bit is one and the interrupt enable bit is one, then the host controller asserts a hardware interrupt.

The figure below illustrates a general example. In this example, consecutive queue heads (B and C) are unlinked from the schedule using the algorithm above. Before the unlink operation, the host controller has a copy of queue head A.
The unlink algorithm requires that as software unlinks each queue head, the unlinked queue head is loaded with the address of a queue head that remains in the asynchronous schedule.

When the host controller observes that doorbell bit being set to one, it makes a note of the local reachable schedule information. In this example, the local reachable schedule information includes both queue heads (A and B). It is sufficient that the host controller can set the status bit (and clear the doorbell bit) as soon as it has traversed beyond current reachable schedule information (that is traversed beyond queue head (B) in this example). The following figure illustrates the generic queue head unlink scenario.

![Diagram showing queue head unlink scenario]

*Figure 42-13. Generic Queue Head Unlink Scenario*

Alternatively, a host controller implementation is allowed to traverse the entire asynchronous schedule list (for example, observed the head of the queue (twice)) before setting the Advance on Async status bit to one.

Software may re-use the memory associated with the removed queue heads after it observes the Interrupt on Async Advance status bit is set to one, following assertion of the doorbell. Software should acknowledge the Interrupt on Async Advance status as indicated in the USB_USBSTS register, before using the doorbell handshake again.

### 42.5.3.8.3 Empty Asynchronous Schedule Detection

The Enhanced Host Controller Interface uses two bits to detect when the asynchronous schedule is empty.
The queue head data structure (see Table 42-26) defines an *H-bit* in the queue head, which allows software to mark a queue head as being the *head* of the reclaim list. The Enhanced Host Controller Interface also keeps a 1-bit flag in the USB_USBSTS register (*Reclamation*) that is set to zero when the Enhanced Interface Host Controller observes a queue head with the H-bit set to one. The reclamation flag in the status register is set to one when any USB transaction from the asynchronous schedule is executed (or whenever the asynchronous schedule starts, see Asynchronous schedule traversal: *Start Event*).

If the Enhanced Host Controller Interface ever encounters an *H-bit* of one and a *Reclamation* bit of zero, the EHCI controller simply stops traversal of the asynchronous schedule.

An example illustrating the H-bit in a schedule is shown in the following figure.

**Figure 42-14. Asynchronous Schedule List w/Annotation to Mark Head of List**

Software must ensure there is at most one queue head with the *H-bit* set to one, and that it is always coherent with respect to the schedule.

### 42.5.3.8.4 Restarting Asynchronous Schedule Before EOF

There are many situations where the host controller will detect an empty list *long* before the end of the micro-frame.

It is important to remember that under many circumstances the schedule traversal has stopped due to Nak/Nyet responses from all endpoints.

An example of particular interest is when a start-split for a bulk endpoint occurs early in the micro-frame. Given the EHCI simple traversal rules, the complete-split for that transaction may Nak/Nyet out very quickly. If it is the only item in the schedule, then the host controller ceases traversal of the Asynchronous schedule very early in the micro-frame. In order to provide reasonable service to this endpoint, the host controller should issue the complete-split before the end of the current micro-frame, instead of waiting.
until the next micro-frame. When the reason for host controller idling asynchronous schedule traversal is because of empty list detection, it is mandatory the host controller implement a 'waking' method to resume traversal of the asynchronous schedule. An example method is described below.

42.5.3.8.4.1  Example Method for Restarting Asynchronous Schedule Traversal

The reason for idling the host controller when the list is empty is to keep the host controller from unnecessarily occupying too much memory bandwidth. The question is: how long should the host controller stay idle before restarting?

The answer in this example is based on deriving a manifest constant, which is the amount of time the host controller will stay idle before restarting traversal. In this example, the manifest constant is called AsyncSchedSleepTime, and has a value of 10 μsec. The value is derived based on the analysis in Example Derivation for AsyncSchedSleepTime, The traversal algorithm is simple:

- Traverse the Asynchronous schedule until the either an End-Of-micro-Frame event occurs, or an empty list is detected. If the event is an End-of-micro-Frame, go attempt to traverse the Periodic schedule. If the event is an empty list, then set a sleep timer and go to a schedule sleep state.
- When the sleep timer expires, set working context to the Asynchronous Schedule start condition and go to schedule active state. The start context allows the HC to reload Nakcnt fields, and so on. So the HC has a chance to run for more than one iteration through the schedule.

This process simply repeats itself each micro-frame. The figure below illustrates a sample state machine to manage the active and sleep states of the Asynchronous Schedule traversal policy. There are three states: Actively traversing the Asynchronous schedule, Sleeping, and Not Active. The last two are similar in terms of interaction with the Asynchronous schedule, but the Not Active state means that the host controller is busy with the Periodic schedule or the Asynchronous schedule is not enabled. The Sleeping state is specifically a special state where the host controller is just waiting for a period of time before resuming execution of the Asynchronous schedule.
Figure 42-15. Example State Machine for Managing Asynchronous Schedule Traversal

The actions referred to in the figure above are defined in the following table.

Table 42-41. Asynchronous Schedule SM Transition Actions

<table>
<thead>
<tr>
<th>Action</th>
<th>Action Description Label</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>On detection of the empty list, the host controller sets the AsynchronousTraversalSleepTimer to AsyncSchedSleepTime.</td>
</tr>
<tr>
<td>B</td>
<td>When the AsynchronousTraversalSleepTimer expires, the host controller sets the Reclamation bit in the USBSTS register to one and moves the Nak Counter reload state machine to WaitForListHead (see Nak Count Reload Control).</td>
</tr>
<tr>
<td>C</td>
<td>The host controller cancels the sleep timer (AsynchronousTraversalSleepTimer).</td>
</tr>
</tbody>
</table>

42.5.3.8.4.2 Async Sched Not Active

This is the initial state of the traversal state machine after a host controller reset. The traversal state machine does not leave this state when the Asynchronous Schedule Enable bit in the USB_USBCMD register is zero.

This state is entered from Async Sched Active or Async Sched Sleeping states when the end-of-micro-frame event is detected.

42.5.3.8.4.3 Async Sched Active

This state is entered from the Async Sched Not Active state when the periodic schedule is not active. It is also entered from the Async Sched Sleeping states when the AsyncrhonousTraversalSleepTimer expires. On every transition into this state, the host controller sets the Reclamation bit in the USB_USBSTS register to one.
While in this state, the host controller continually traverses the asynchronous schedule until either the end of micro-frame or an empty list condition is detected.

### 42.5.3.8.4.4 Async Sched Sleeping

The state is entered from the Async Sched Active state when a schedule empty condition is detected. On entry to this state, the host controller sets the `AsynchronousTraversalSleepTimer` to `AsyncSchedSleepTime`.

### 42.5.3.8.4.5 Example Derivation for `AsyncSchedSleepTime`

The derivation is based on analysis of what work the host controller could be doing next. It assumes the host controller does not keep any state about what work is possibly pending in the asynchronous schedule. The schedule could contain any mix of the possible combinations of high- full- or low-speed control and bulk requests.

The table below summarizes some of the typical 'next transactions' that could be in the schedule, and the amount of time (for example `footprint`, or `wall clock`) the transaction takes to complete.

<table>
<thead>
<tr>
<th>Transaction Attributes</th>
<th>Footprint (time)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Speed</td>
<td>Size</td>
<td>Type</td>
</tr>
<tr>
<td>HS</td>
<td>11.9 ms</td>
<td>Bulk</td>
</tr>
<tr>
<td>512</td>
<td>9.45 ms</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FS</td>
<td>~50 ms</td>
<td></td>
</tr>
<tr>
<td>64</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>~12 ms</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

A `AsyncSchedSleepTime` value of 10 μs provides a reasonable relaxation of the system memory load and still provides a good level of service for the various transfer types and payload sizes. For example, say we detect an empty list after issuing a start-split for a 64-byte full-speed bulk request. Assuming this is the only thing in the list, the host controller gets the results of the full-speed transaction from the hub during the fifth complete-split request. If the full-speed transaction was an IN and it nak'd, the 10 μs sleep period would allow the host controller to get the NAK results on the first complete-split.
42.5.3.8.5  Asynchronous schedule traversal: Start Event

Once the HC has idled itself through the empty schedule detection (Section 0), it will naturally activate and begin processing from the Periodic Schedule at the beginning of each micro-frame.

In addition, it may have idled itself early in a micro-frame. When this occurs (idles early in the micro-frame) the HC must occasionally re-activate during the micro-frame and traverse the asynchronous schedule to determine whether any progress can be made. The requirements and method for this restart are described in Restarting Asynchronous Schedule Before EOF. Asynchronous schedule Start Events are defined to be:

- Whenever the host controller transitions from the periodic schedule to the asynchronous schedule. If the periodic schedule is disabled and the asynchronous schedule is enabled, then the beginning of the micro-frame is equivalent to the transition from the periodic schedule, or
- The asynchronous schedule traversal restarts from a sleeping state (see Restarting Asynchronous Schedule Before EOF).

42.5.3.8.6  Reclamation Status Bit (USBSTS Register)

The operation of the empty asynchronous schedule detection feature (see Empty Asynchronous Schedule Detection) depends on the proper management of the Reclamation bit in the USB_USBSTS register. The host controller tests for an empty schedule just after it fetches a new queue head while traversing the asynchronous schedule (see Fetch Queue Head).

The host controller is required to set the Reclamation bit to one whenever an asynchronous schedule traversal Start Event, as documented in Asynchronous schedule traversal: Start Event, occurs. The Reclamation bit is also set to one whenever the host controller executes a transaction while traversing the asynchronous schedule (see Execute Transaction). The host controller sets the Reclamation bit to zero whenever it finds a queue head with its H-bit set to one. Software should only set a queue head's H-bit if the queue head is in the asynchronous schedule. If software sets the H-bit in an interrupt queue head to one, the resulting behavior is undefined. The host controller may set the Reclamation bit to zero when executing from the periodic schedule.

42.5.3.9  Operational Model for Nak Counter

This section describes the operational model for the NakCnt field defined in a queue head.
See Queue Head Initialization for more information. Software should not use this feature for interrupt queue heads. This rule is not required to be enforced by the host controller.

USB protocol has built-in flow control through the Nak response by a device. There are several scenarios, beyond the Ping feature, where an endpoint may naturally Nak or Nyet the majority of the time. An example is the host controller management of the split transaction protocol for control and bulk endpoints. All bulk endpoints (High- or Full-speed) are serviced through the same asynchronous schedule. The time between the Start-split transaction and the first Complete-split transaction could be very short (that is like when the endpoint is the only one in the asynchronous schedule). The hub NYETs (effectively Naks) the Complete-split transaction until the classic transaction is complete. This could result in the host controller thrashing memory, repeatedly fetching the queue head and executing the transaction to the Hub, which does not complete until after the transaction on the classic bus completes.

The two component fields in a queue head to support the throttling feature: a counter field (NakCnt), and a counter reload field (RL). NakCnt is used by the host controller as one of the criteria to determine whether or not to execute a transaction to the endpoint. The two operational modes associated with this counter:

- **Not Used-** This mode is set when the RL field is zero. The host controller ignores the NakCnt field for any execution of transactions through a queue head with an RL field of zero. Software must use this selection for interrupt endpoints.
- **Nak Throttle Mode-** This mode is selected when the RL field is non-zero. In this mode, the value in the NakCnt field represents the maximum number of Nak or Nyet responses the host controller tolerates on each endpoint. In this mode, the HC decrements the NakCnt field based on the token/handshake criteria listed in the table below. The host controller must reload NakCnt when the endpoint successfully moves data (for example, policy to reward device for moving data).

The following table describes the NakCnt field adjustment rules.

<table>
<thead>
<tr>
<th>Token</th>
<th>Handshake</th>
<th>Handshake Nak</th>
<th>NYET</th>
</tr>
</thead>
<tbody>
<tr>
<td>IN/PING</td>
<td>decrement NakCnt</td>
<td>N/A (protocol error)</td>
<td></td>
</tr>
<tr>
<td>OUT</td>
<td>decrement NakCnt</td>
<td>No Action¹ Start</td>
<td></td>
</tr>
<tr>
<td>Split</td>
<td>decrement NakCnt</td>
<td>N/A (protocol error)</td>
<td></td>
</tr>
<tr>
<td>Complete Split</td>
<td>No Action</td>
<td>Decrement NakCnt</td>
<td></td>
</tr>
</tbody>
</table>

¹ Recommended behavior on this response is to reload NakCnt.
In summary, system software enables the counter by setting the reload field (RL) to a non-zero value. The host controller may execute a transaction if \textit{NakCnt} is non-zero. The host controller does not execute a transaction if \textit{NakCnt} is zero. The reload mechanism is described in detail in \textit{Nak Count Reload Control}.

\textbf{NOTE}
When all queue heads in the Asynchronous Schedule either exhausts all transfers or all NakCnt's go to zero, then the host controller detects an empty Asynchronous Schedule and idle schedule traversal (see \textit{Empty Asynchronous Schedule Detection}).

Any time the host controller begins a new traversal of the Asynchronous Schedule, a \textit{Start Event} is assumed, see \textit{Asynchronous schedule traversal: Start Event}. Every time a Start-Event occurs, the Nak Count reload procedure is enabled.

\section*{42.5.3.9.1 Nak Count Reload Control}

When the host controller reaches the \textit{Execute Transaction} state for a queue head (meaning that it has an active operational state), it checks to determine whether the \textit{NakCnt} field should be reloaded from \textit{RL} (see \textit{Execute Transaction}). If the answer is yes, then \textit{RL} is copied into \textit{NakCnt}. After the reload or if the reload is not active, the host controller evaluates whether to execute the transaction.

The host controller must reload nak counters (\textit{NakCnt} see \textit{Table 42-26}) in queue heads during the first pass through the reclamation list after an asynchronous schedule Start Event (see \textit{Asynchronous schedule traversal: Start Event} for the definition of the Start Event). The Asynchronous Schedule should have at most one queue head marked as the head (see \textit{Figure 42-14}).

The following figure illustrates an example state machine that satisfies the operational requirements of the host controller detecting the first pass through the Asynchronous Schedule. This state machine is maintained internal to the host controller and is only used to gate reloading of the nak counter during the queue head traversal state: Execute Transaction (see the figure below). The host controller does not perform the nak counter reload operation if the RL field (see \textit{Table 42-26}) is set to zero.
42.5.3.9.1.1 Wait for List Head

This is the initial state.

The state machine enters this state from Wait for Start Event when a start event as defined in Asynchronous schedule traversal: **Start Event** occurs.

The purpose of this state is to wait for the first observation of the head of the Asynchronous Schedule.

This occurs when the host controller fetches a queue head whose **H-bit** is set to one.

42.5.3.9.1.2 Do Reload

This state is entered from the Wait for List Head state when the host controller fetches a queue head with the **H-bit** set to one. While in this state, the host controller performs nak counter reloads for every queue head visited that has a non-zero nak reload value (**RL**) field.
42.5.3.9.1.3 Wait for Start Event

This state is entered from the Do Reload state when a queue head with the H-bit set to one is fetched. While in this state, the host controller does not perform nak counter reloads.

42.5.3.10 Managing Control/Bulk/Interrupt Transfers through Queue Heads

This section presents an overview of how the host controller interacts with queuing data structures.

Queue heads use the Queue Element Transfer Descriptor (qTD) structure. One queue head is used to manage the data stream for one endpoint. The queue head structure contains static endpoint characteristics and capabilities. It also contains a working area from where individual bus transactions for an endpoint are executed (see Overlay area defined in Table 42-26). Each qTD represents one or more bus transactions, which is defined in the context of this specification as a transfer.

The general processing model for the host controller's use of a queue head is simple:

- read a queue head,
- execute a transaction from the overlay area,
- write back the results of the transaction to the overlay area,
- move to the next queue head.

If the host controller encounters errors during a transaction, the host controller sets one (or more) of the error reporting bits in the queue head's Status field. The Status field accumulates all errors encountered during the execution of a qTD (for example, the error bits in the queue head Status field are 'sticky' until the transfer (qTD) has completed). This state is always written back to the source qTD when the transfer is complete. On transfer (for example, buffer or halt conditions) boundaries, the host controller must auto-advance (without software intervention) to the next qTD. Additionally, the hardware must be able to halt the queue so no additional bus transactions occurs for the endpoint and the host controller does not advance the queue.

An example host controller operational state machine of a queue head traversal is illustrated in the following figure. This state machine is a model for how a host controller should traverse a queue head. The host controller must be able to advance the queue from the Fetch QH state in order to avoid all hardware/software race conditions. This simple mechanism allows software to simply link qTDs to the queue head and activate them, then the host controller always find them if/when they are reachable. The figure below illustrates the Host Controller Queue Head Traversal State Machine.
This traversal state machine applies to all queue heads, regardless of transfer type or whether split transactions are required. The following sections describe each state. Each state description describes the entry criteria. The Execute Transaction state (see Execute
Transaction) describes the basic requirements for all endpoints. Split Transactions for Asynchronous Transfers and Split Transaction Interrupt describe details of the required extensions to the Execute Transaction state for endpoints requiring split transactions.

**NOTE**

Prior to software placing a queue head into either the periodic or asynchronous list, software must ensure the queue head is properly initialized. Minimally, the queue head should be initialized to the following (see Section Queue Head for layout of a queue head):

Valid static endpoint state.

- For the very first use of a queue head, software may zero-out the queue head transfer overlay, then set the Next qTD Pointer field value to reference a valid qTD.

### 42.5.3.10.1 Fetch Queue Head

A queue head can be referenced from the physical address stored in the ASYNCLISTADDR Register (see Next Asynch. Address (USB_nASYNCLISTADDR)/Endpoint List Address (USB_nENDPTLISTADDR) Additionally, it may be referenced from the Next LinkPointer field of an iTD, siTD, FSTN or another Queue Head. If the referencing link pointer has the Typ field set to indicate a queue head, it is assumed to reference a queue head structure as defined in Table 42-26.

While in this state, the host controller performs operations to implement empty schedule detection (see Empty Asynchronous Schedule Detection) and Nak Counter reloads (see Operational Model for Nak Counter). After the queue head has been fetched, the host controller conducts the following queries for empty schedule detection:

- If queue head is not an interrupt queue head (that is S-mask is zero), and
- The H-bit is one, and
- The Reclamation bit in the USBSTS register is zero.

When these criteria are met, the host controller stops traversing the asynchronous list (as described in Empty Asynchronous Schedule Detection). When the criteria are not met, the host controller continues schedule traversal. If the queue head is not an interrupt and the H-bit is one and the Reclamation bit is one, then the host controller sets the Reclamation bit in the USBSTS register to zero before completing this state. The operations for reloading of the Nak Counter are described in detail in Operational Model for Nak Counter.

This state is complete when the queue head has been read on-chip.
42.5.3.10.2  Advance Queue

To advance the queue, the host controller must find the next qTD, adjust pointers, perform the overlay and write back the results to the queue head.

This state is entered from the FetchQHD state if the overlay Active and Halt bits are set to zero. On entry to this state, the host controller determines which next pointer to use to fetch a qTD, fetches a qTD and determines whether or not to perform an overlay.

**NOTE**
If the I-bit is one and the Active bit is zero, the host controller immediately skips processing of this queue head, exits this state and uses the horizontal pointer to the next schedule data structure. If the field Bytes to Transfer is not zero and the T-bit in the Alternate Next qTD Pointer is set to zero, then the host controller uses the Alternate Next qTD Pointer. Otherwise, the host controller uses the NextqTD Pointer. If NextqTD Pointer's T-bit is set to one, then the host controller exits this state and uses the horizontal pointer to the next schedule data structure.

Using the selected pointer the host controller fetches the referenced qTD. If the fetched qTD has its Active bit set to one, the host controller moves the pointer value used to reach the qTD (Next or Alternate Next) to the Current qTD Pointer field, then performs the overlay. If the fetched qTD has its Active bit set to zero, the host controller aborts the queue advance and follows the queue head's horizontal pointer to the next schedule data structure.

The host controller performs the overlay based on the following rules:

- The value of the data toggle (dt) field in the overlay area depends on the value of the data toggle control (dtc) bit (see Table 42-28).
- If the EPS field indicates the endpoint is a high-speed endpoint, the Ping state field is preserved by the host controller. The value of this field is not changed as a result of the overlay.
- C-prog-mask field is set to zero (field from incoming qTD is ignored, as is the current contents of the overlay area).
- Frame Tag field is set to zero (field from incoming qTD is ignored, as is the current contents of the overlay area).
- NakCnt field in the overlay area is loaded from the RL field in the queue head's Static Endpoint State.
- All other areas of the overlay are set by the incoming qTD.

The host controller exits this state when it has committed the write to the queue head.
42.5.3.10.3 Execute Transaction

The host controller enters this state from the Fetch Queue Head state only if the Active bit in Status field of the queue head is set to one.

On entry to this state, the host controller executes a few pre-operations, then checks some pre-condition criteria before committing to executing a transaction for the queue head.

The pre-operations performed and the pre-condition criteria depend on whether the queue head is an interrupt endpoint. The host controller can determine that a queue head is an interrupt queue head when the queue head's S-mask field contains a non-zero value. It is the responsibility of software to ensure the S-mask field is appropriately initialized based on the transfer type. There are other criteria that must be met if the EPS field indicates that the endpoint is a low- or full-speed endpoint, see Split Transactions for Asynchronous Transfers and Split Transaction Interrupt.

42.5.3.10.3.1 Interrupt Transfer Pre-condition Criteria

If the queue head is for an interrupt endpoint (for example, non-zero S-mask field), then the FRINDEX[2:0] field must identify a bit in the S-mask field that has one in it.

For example, an S-mask value of 00100000b would evaluate to true only when FRINDEX[2:0] is equal to 101b. If this condition is met then the host controller considers this queue head for a transaction.

42.5.3.10.3.2 Asynchronous Transfer Pre-operations and Pre-condition Criteria

If the queue head is not for an interrupt endpoint (for example, zero S-mask field), then the host controller performs one pre-operation and then evaluates one pre-condition criteria.

The pre-operation is:

Checks the Nak counter reload state (Operational Model for Nak Counter). It may be necessary for the host controller to reload the Nak Counter field. The reload is performed at this time.

The pre-condition evaluated is:

- Whether or not the NakCnt field has been reloaded, the host controller checks the value of the NakCnt field in the queue head. If NakCnt is non-zero, or if the Reload Nak Counter field is zero, then the host controller considers this queue head for a transaction.
42.5.3.10.3.3 Transfer Type Independent Pre-operations

Regardless of the transfer type, the host controller always performs at least one pre-operation and evaluates one pre-condition. The pre-operation is:

- A host controller internal transaction (down) counter \(qHTransactionCounter\) is loaded from the queue head's \(Mult\) field. A host controller implementation is allowed to ignore this for queue heads on the asynchronous list. It is mandatory for interrupt queue heads. Software should ensure that the \(Mult\) field is set appropriately for the transfer type.

The pre-conditions evaluated are:

- The host controller determines whether there is enough time in the micro-frame to complete this transaction (see Transaction Fit - A Best-Fit Approximation Algorithm for an example evaluation method). If there is not enough time to complete the transaction, the host controller exits this state.
- If the value of \(qHTransactionCounter\) for an interrupt endpoint is zero, then the host controller exits this state.

When the pre-operations are complete and pre-conditions are met, the host controller sets the Reclamation bit in the USBSTS register to one and then begins executing one or more transactions using the endpoint information in the queue head. The host controller iterates \(qHTransactionCounter\) times in this state executing transactions. After each transaction is executed, \(qHTransactionCounter\) is decremented by one. The host controller exits this state when one of the following events occurs:

- The \(qHTransactionCounter\) decrements to zero, or
- The endpoint responds to the transaction with any handshake other than an ACK,\(^4\) or
- The transaction experiences a transaction error, or
- The \(Active\) bit in the queue head goes to zero, or
- There is not enough time in the micro-frame left to execute the next transaction (see Transaction Fit - A Best-Fit Approximation Algorithm for example method for implementing the frame boundary test).

**NOTE**

For a high-bandwidth interrupt OUT endpoint, the host controller may optionally immediately retry the transaction if it fails.

The results of each transaction is recorded in the on-chip overlay area. If data was successfully moved during the transaction, the transfer state in the overlay area is advanced. To advance queue head's transfer state, the Total Bytes to Transfer field is decremented by the number of bytes moved in the transaction, the data toggle bit \((dt)\) is toggled, the current page offset is advanced to the next appropriate value (for example,
advanced by the number of bytes successfully moved), and the $C_{Page}$ field is updated to the appropriate value (if necessary). See Buffer Pointer List Use for Data Streaming with qTDs.

**NOTE**

The *Total Bytes To Transfer* field may be zero when all the other criteria for executing a transaction are met. When this occurs, the host controller executes zero-length transaction to the endpoint. If the $PID_{Code}$ field indicates an IN transaction and the device delivers data, the host controller detects a packet babble condition, set the *babble* and *halted* bits in the *Status* field, set the *Active* bit to zero, write back the results to the source qTD, then exit this state.

In the event an IN token receives a data PID mismatch response, the host controller must ignore the received data (for example not advance the transfer state for the bytes received). Additionally, if the endpoint is an interrupt IN, then the host controller must record that the transaction occurred (for example, decrement $qHTransactionCounter$). It is recommended (but not required) the host controller continue executing transactions for this endpoint if the resultant value of $qHTransactionCounter$ is greater than one.

If the response to the IN bus transaction is a Nak (or Nyet) and $RL$ is non-zero, $NakCnt$ is decremented by one. If $RL$ is zero, then no write-back by the host controller is required (for a transaction receiving a Nak or Nyet response and the value of $CErr$ did not change). Software should set the $RL$ field to zero if the queue head is an interrupt endpoint. Host controller hardware is not required to enforce this rule or operation.

After the transaction has finished and the host controller has completed the post processing of the results (advancing the transfer state and possibly $NakCnt$, the host controller writes back the results of the transaction to the queue head's overlay area in main memory).

The number of bytes moved during an IN transaction depends on how much data the device endpoint delivers. The maximum number of bytes a device can send is *MaximumPacket Size*. The number of bytes moved during an OUT transaction is either *Maximum Packet Length* bytes or *Total Bytes to Transfer*, whichever is less.

If there was a transaction error during the transaction, the transfer state (as defined above) is not advanced by the host controller. The $CErr$ field is decremented by one and the status field is updated to reflect the type of error observed. Transaction errors are summarized in **Transaction Error**.
The following events causes the host controller to clear the *Active* bit in the queue head's overlay status field. When the *Active* bit transitions from one to zero, the transfer in the overlay is considered complete. The reason for the transfer completion (clearing the *Active* bit) determines the next state.

- *CErr* field decrements to zero. When this occurs the *Halted* bit is set to one and *Active* is set to zero. This results in the hardware not advancing the queue and the pipe halts. Software must intercede to recover.
- The device responds to the transaction with a STALL PID. When this occurs, the *Halted* bit is set to one and the *Active* bit is set to zero. This results in the hardware not advancing the queue and the pipe halts. Software must intercede to recover.
- The *Total Bytes to Transfer* field is zero after the transaction completes.
  - For a zero length transaction, it was zero before the transaction was started. When this condition occurs, the *Active* bit is set to zero.
- The PID code is an IN, and the number of bytes moved during the transaction is less than the *Maximum Packet Length*. When this occurs, the *Active* bit is set to zero and a short packet condition exists. The short-packet condition is detected during the Advance Queue state. Refer to Split Transactions for additional rules for managing low- and full-speed transactions.

With the exception of a NAK response (when *RL* field is zero), the host controller always writes the results of the transaction back to the overlay area in main memory. This includes when the transfer completes. For a high-speed endpoint, the queue head information written back includes minimally the following fields: The *PID Code* field indicates an IN and the device sends more than the expected number of bytes (for example *Maximum Packet Length* or *Total Bytes to Transfer* bytes, whichever is less) (for example a packet babble). This results in the host controller setting the *Halted* bit to one.

- NakCnt, dt, Total Bytes to Transfer, C_Page, Status, CERR, and Current Offset

For a low- or full-speed device the queue head information written back also includes the fields:

- C-prog-mask, FrameTag and S-bytes.

The duration of this state depends on the time it takes to complete the transaction(s) and the status write to the overlay is committed.

### 42.5.3.10.3.4 Halting a Queue Head

A halted endpoint is defined only for the transfer types that are managed through queue heads (control, bulk and interrupt).

The following events indicate that the endpoint has reached a condition where no more activity can occur without intervention from the driver:
• An endpoint may return a STALL handshake during a transaction,
• A transaction had three consecutive error conditions, or
• A Packet Babble error occurs on the endpoint.

When any of these events occur (for a queue head) the Host Controller halts the queue head and set the USBERRINT status bit in the USB_n_USBSTS register to one. To halt the queue head, the Active bit is set to zero and the Halted bit is set to one. There may be other error status bits that are set when a queue is halted. The host controller always writes back the overlay area to the source qTD when the transfer is complete, regardless of the reason (normal completion, short packet or halt). The host controller does not advance the transfer state on a transaction that results in a Halt condition (for example no updates necessary for Total Bytes to Transfer, C_Page, Current Offset, and dt). The host controller must update CErr as appropriate. When a queue head is halted, the USB Error Interrupt bit in the USB_n_USBSTS register is set to one. If the USB Error Interrupt Enable bit in the USB_n_USBINTR register is set to one, a hardware interrupt is generated at the next interrupt threshold.

42.5.3.10.3.5  Asynchronous Schedule Park Mode

Asynchronous Schedule Park mode is a special execution mode that can be enabled by system software, where the host controller is permitted to execute more than one bus transaction from a high-speed queue head in the Asynchronous schedule before continuing horizontal traversal of the Asynchronous schedule.

This feature has no effect on queue heads or other data structures in the Periodic schedule. This feature is similar in intent as the Mult feature that is used in the Periodic schedule. Where-as the Mult feature is a characteristic that is tunable for each endpoint; park-mode is a policy that is applied to all high-speed queue heads in the asynchronous schedule. It is essentially the specification of an iterator for consecutive bus transactions to the same endpoint. All of the rules for managing bus transactions and the results of those as defined in Execute Transaction apply. This feature merely specifies how many consecutive times the host controller is permitted to execute from the same queue head before moving to the next queue head in the Asynchronous List. This feature should allow the host controller to attain better bus utilization for those devices that are capable of moving data at maximum rate, while at the same time providing a fair service to all endpoints.

A host controller exports its capability to support this feature to system software by setting the Asynchronous Schedule Park Capability bit in the USB_n_HCCPARAMs register to one. This information keys system software that the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USB_n_USBCMD register are modifiable. System software enables the feature by writing a one to the Asynchronous Schedule Park Mode Enable bit.
When park-mode is not enabled (for example Asynchronous Schedule Park Mode Enable bit in the USB_n_USB_CMD register is zero), the host controller must not execute more than one bus transaction per high-speed queue head, per traversal of the asynchronous schedule. When park-mode is enabled, the host controller must not apply the feature to a queue head whose EPS field indicates a Low/Full-speed device (for example only one bus transaction is allowed from each Low/Full-speed queue head per traversal of the asynchronous schedule). Park-mode may only be applied to queue heads in the Asynchronous schedule whose EPS field indicates that it is a high-speed device.

The host controller must apply park mode to queue heads whose EPS field indicates a high-speed endpoint. The maximum number of consecutive bus transactions a host controller may execute on a high-speed queue head is determined by the value in the Asynchronous Schedule Park Mode Count field in the USB_n_USB_CMD register. Software must not set Asynchronous Schedule Park Mode Enable bit to one and also set Asynchronous Schedule Park Mode Count field to zero. The resulting behavior is not defined. An example behavioral example describes the operational requirements for the host controller implementing park-mode. This feature does not affect how the host controller handles the bus transaction as defined in Execute Transaction. It only affects how many consecutive bus transactions for the current queue head can be executed. All boundary conditions, error detection and reporting applies as usual. This feature is similar in concept to the use of the Mult field for high-bandwidth Interrupt for queue heads in the Periodic Schedule.

The host controller effectively loads an internal down-counter PM-Count from Asynchronous Schedule Park Mode Count when Asynchronous Schedule Park Mode Enable bit is one, and a high-speed queue head is first fetched and meets all the criteria for executing a bus transaction. After the bus transaction, PM-Count is decremented. The host controller may continue to execute bus transactions from the current queue head until PM-Count goes to zero, an error is detected, the buffer for the current transfer is exhausted or the endpoint responds with a flow-control or STALL handshake.

The following table summarizes the responses that effect whether the host controller continues with another bus transaction for the current queue head.

**Table 42-44. Actions for Park Mode, based on Endpoint Response and Residual Transfer State**

<table>
<thead>
<tr>
<th>PID</th>
<th>Endpoint Response</th>
<th>Transfer State after Transaction</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>PM-Count Bytes to Transfer</td>
<td></td>
</tr>
<tr>
<td>IN</td>
<td>DATA[0,1] w/Maximum Packet sized data</td>
<td>Not zero Not Zero</td>
<td>Allowed to perform another bus transaction.²</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Not zero Zero</td>
<td>Retire qTD and move to next QH</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Zero Don't care</td>
<td>Move to next QH.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 42-44. Actions for Park Mode, based on Endpoint Response and Residual Transfer State (continued)

<table>
<thead>
<tr>
<th>DATA[0,1] w/short packet</th>
<th>NAK</th>
<th>STALL, XactErr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Watchdog</td>
<td>Don't care</td>
<td>Don't care</td>
</tr>
<tr>
<td>Retire qTD and move to next QH.</td>
<td>Move to next QH.</td>
<td>Move to next QH.</td>
</tr>
<tr>
<td>NAK</td>
<td>Don't care</td>
<td>Don't care</td>
</tr>
<tr>
<td>Move to next QH.</td>
<td>Move to next QH.</td>
<td></td>
</tr>
<tr>
<td>STALL, XactErr</td>
<td>Don't care</td>
<td>Don't care</td>
</tr>
<tr>
<td>Move to next QH.</td>
<td>Move to next QH.</td>
<td></td>
</tr>
<tr>
<td>OUT</td>
<td>ACK</td>
<td></td>
</tr>
<tr>
<td>Not zero</td>
<td>Not Zero</td>
<td>Allowed to perform another bus transaction.²</td>
</tr>
<tr>
<td>Not zero</td>
<td>Zero</td>
<td>Retire qTD and move to next QH.</td>
</tr>
<tr>
<td>NYET, NAK</td>
<td>Don't care</td>
<td>Don't care</td>
</tr>
<tr>
<td>Move to next QH.</td>
<td>Move to next QH.</td>
<td></td>
</tr>
<tr>
<td>PING</td>
<td>ACK</td>
<td></td>
</tr>
<tr>
<td>Not Zero</td>
<td>Not Zero</td>
<td>Allowed to perform another bus transaction.²</td>
</tr>
<tr>
<td>NYET, NAK</td>
<td>Don't care</td>
<td>Don't care</td>
</tr>
<tr>
<td>Move to next QH.</td>
<td>Move to next QH.</td>
<td></td>
</tr>
<tr>
<td>STALL, XactErr</td>
<td>Don't care</td>
<td>Don't care</td>
</tr>
<tr>
<td>Move to next QH.</td>
<td>Move to next QH.</td>
<td></td>
</tr>
</tbody>
</table>

1. The host controller may continue to execute bus transactions from the current high-speed queue head (if PM-Count is not equal to zero), if a PID mismatch is detected (for example expected DATA1 and received DATA0, or visa-versa).
2. This specification does not require that the host controller execute another bus transaction when PM-Count is non-zero. Implementations are encouraged to make appropriate complexity and performance trade-offs.

42.5.3.10.4 Write Back qTD

This state is entered from the Execute Transaction state when the Active bit is set to zero. The source data for the write-back is the transfer results area of the queue head overlay area (see Table 42-44).

The host controller uses the Current qTD Pointer field as the target address for the qTD. The queue head transfer result area is written back to the transfer result area of the target qTD. This state is also referred to as: qTD retirement. The fields that must be written back to the source qTD include Total Bytes to Transfer, Cerr, and Status.

The duration of this state depends on when the qTD write-back is committed.

42.5.3.10.5 Follow Queue Head Horizontal Pointer

The host controller must use the horizontal pointer in the queue head to the next schedule data structure when any of the following conditions exist:

- If the Active bit is one on exit from the Execute Transaction state, or
- When the host controller exits the Write Back qTD state, or
- If the Advance Queue state fails to advance the queue because the target qTD is not active, or
- If the Halted bit is one on exit from the Fetch QH state.
There is no functional requirement that the host controller wait until the current 
transaction is complete before using the horizontal pointer to read the next linked data 
structure. However, it must wait until the current transaction is complete before executing 
the next data structure.

42.5.3.10.6 Buffer Pointer List Use for Data Streaming with qTDs

A qTD has an array of buffer pointers, which is used to reference the data buffer for a 
transfer. This specification requires that the buffer associated with the transfer be 
virtually contiguous.

This means: if the buffer spans more than one physical page, it must obey the following 
rules (the figure below illustrates an example):

- The first portion of the buffer must begin at some offset in a page and extend through 
  the end of the page.
- The remaining buffer cannot be allocated in small chunks scattered around memory. 
  For each 4 K chunk beyond the first page, each buffer portion matches to a full 4 K 
  page. The final portion, which may only be large enough to occupy a portion of a 
  page, must start at the top of the page and be contiguous within that page.

The buffer pointer list in the qTD is long enough to support a maximum transfer size of 
20 K bytes. This case occurs when all five buffer pointers are used and the first offset is 
zero. A qTD handles a 16 Kbyte buffer with any starting buffer alignment.

The host controller uses the field C_Page field as an index value to determine which 
buffer pointer in the list should be used to start the current transaction. The host controller 
uses a different buffer pointer for each physical page of the buffer. This is always true, 
even if the buffer is physically contiguous.

The host controller must detect when the current transaction spans a page boundary and 
automatically move to the next available buffer pointer in the page pointer list. The next 
available pointer is reached by incrementing C_Page and pulling the next page pointer 
from the list. Software must ensure there are sufficient buffer pointers to move the 
amount of data specified in the Bytes to Transfer field.

The following figure illustrates a nominal example of how System software would 
initialize the buffer pointers list and the C_Page field for a transfer size of 16383 bytes. 
C_Page is set to zero. The upper 20-bits of Page 0 references the start of the physical 
page. Current Offset (the lower 12-bits of queue head Dword 7) holds the offset in the 
page for example 2049 (for example 4096-2047). The remaining page pointers are set to 
reference the beginning of each subsequent 4 K page.
For the first transaction on the qTD (assuming a 512-byte transaction), the host controller uses the first buffer pointer (page 0 because $C\_Page$ is set to zero) and concatenates the Current Offset field. The 512 bytes are moved during the transaction, the Current Offset and Total Bytes to Transfer are adjusted by 512 and written back to the queue head working area.

During the 4th transaction, the host controller needs 511 bytes in page 0 and one byte in page 1. The host controller increments $C\_Page$ (to 1) and use the page 1 pointer to move the final byte of the transaction. After the 4th transaction, the active page pointer is the page 1 pointer and Current Offset has rolled to one, and both are written back to the overlay area. The transactions continue for the rest of the buffer, with the host controller automatically moving to the next page pointer (that is $C\_Page$) when necessary. The three conditions for how the host controller handles $C\_Page$:

- The current transaction does not span a page boundary. The value of $C\_Page$ is not adjusted by the host controller.
• The current transaction does span a page boundary. The host controller must detect the page cross condition and advance to the next buffer while streaming data to/from the USB.
• The current transaction completes on a page boundary (that is the last byte moved for the current transaction is the last byte in the page for the current page pointer). The host controller must increment $C_{Page}$ before writing back status for the transaction.

**NOTE**

The only valid adjustment the host controller may make to $C_{Page}$ is to increment by one.

### 42.5.3.10.7 Adding Interrupt Queue Heads to the Periodic Schedule

The link path(s) from the periodic frame list to a queue head establishes in which frames a transaction can be executed for the queue head. Queue heads are linked into the periodic schedule so they are polled at the appropriate rate.

System software sets a bit in a queue head's $S$-Mask to indicate which micro-frame within 1 msec period a transaction should be executed for the queue head. Software must ensure that all queue heads in the periodic schedule have $S$-Mask set to a non-zero value. An $S$-mask with zero value in the context of the periodic schedule yields undefined results.

If the desired poll rate is greater than one frame, system software can use a combination of queue head linking and $S$-Mask values to spread interrupts of equal poll rates through the schedule so that the periodic bandwidth is allocated and managed in the most efficient manner possible. Some examples are illustrated in the following table.

<table>
<thead>
<tr>
<th>Frame # Reference Sequence</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0, 2, 4, 6, 8, and so on S-Mask = 01h</td>
<td>A queue head for the bInterval of 2 msec (16 micro-frames) is linked into the periodic schedule so that it is reachable from the periodic frame list locations indicated in the previous column. In addition, the S-Mask field in the queue head is set to 01h, indicating that the transaction for the endpoint should be executed on the bus during micro-frame 0 of the frame.</td>
</tr>
<tr>
<td>0, 2, 4, 6, 8, and so on S-Mask = 02h</td>
<td>Another example of a queue head with a bInterval of 2 msec is linked into the periodic frame list at exactly the same interval as the previous example. However, the S-Mask is set to 02h indicating that the transaction for the endpoint should be executed on the bus during micro-frame 1 of the frame.</td>
</tr>
</tbody>
</table>
Managing Transfer Complete Interrupts from Queue Heads

The host controller sets an interrupt to be signaled at the next interrupt threshold when the completed transfer (qTD) has an Interrupt on Complete (IOC) bit set to one, or whenever a transfer (qTD) completes with a short packet.

If system software needs multiple qTDs to complete a client request (that is like a control transfer) the intermediate qTDs do not require interrupts. System software may only need a single interrupt to notify it that the complete buffer has been transferred. System software may set IOC's to occur more frequently. A motivation for this may be that it wants early notification so that interface data structures can be re-used in a timely manner.

Ping Control

USB 2.0 defines an addition to the protocol for high-speed devices called Ping. Ping is required for all USB 2.0 High-speed bulk and control endpoints.

Ping is not allowed for a split-transaction stream. This extension to the protocol eliminates the bad side-effects of Naking OUT endpoints. The Status field has a Ping State bit, which the host controller uses to determine the next actual PID it uses in the next transaction to the endpoint (see the table below).

The Ping State bit is only managed by the host controller for queue heads that meet the following criteria:

- Queue head is not an interrupt and
- EPS field equals High-Speed and
- PIDCode field equals OUT

The following table illustrates the state transition table for the host controller's responsibility for maintaining the PING protocol. Refer to Chapter 8 in the USB Specification Revision 2.0 for detailed description on the Ping protocol.

<table>
<thead>
<tr>
<th>Event</th>
<th>Current</th>
<th>Host</th>
<th>Device</th>
<th>Next</th>
</tr>
</thead>
<tbody>
<tr>
<td>Do Ping</td>
<td>PING</td>
<td>Nak</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Do Ping</td>
<td>PING</td>
<td>Ack</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Do Ping</td>
<td>PING</td>
<td>XactErr</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Do Ping</td>
<td>PING</td>
<td>Stall</td>
<td>N/C 2</td>
<td>Do Ping</td>
</tr>
<tr>
<td>OUT</td>
<td>OUT</td>
<td>Nak</td>
<td>Do Ping</td>
<td></td>
</tr>
<tr>
<td>Do OUT</td>
<td>OUT</td>
<td>Nyet</td>
<td>Do Ping</td>
<td></td>
</tr>
</tbody>
</table>
Table 42-46. Ping Control State Transition Table (continued)

<table>
<thead>
<tr>
<th>State 1</th>
<th>State 2</th>
<th>Transition 1</th>
<th>Transition 2</th>
</tr>
</thead>
<tbody>
<tr>
<td>Do OUT</td>
<td>OUT</td>
<td>Ack</td>
<td>Do OUT</td>
</tr>
<tr>
<td>Do OUT</td>
<td>OUT</td>
<td>XactErr(^1)</td>
<td>Do Ping</td>
</tr>
<tr>
<td>Do OUT</td>
<td>OUT</td>
<td>Stall</td>
<td>N/C(^2)</td>
</tr>
</tbody>
</table>

1. Transaction Error (XactErr) is any time the host misses the handshake.
2. No transition change required for the Ping State bit. The Stall handshake results in the endpoint being halted (for example Active set to zero and Halt set to one). Software intervention is required to restart queue. 3 A Nyet response to an OUT means that the device has accepted the data, but cannot receive any more at this time. Host must advance the transfer state and additionally, transition the Ping State bit to Do Ping. The Ping State bit has the following encoding:

Table 42-47. Ping State bit Encoding

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>0B</td>
<td>Do OUT  The host controller uses an OUT PID during the next bus transaction to this endpoint.</td>
</tr>
<tr>
<td>1B</td>
<td>Do Ping The host controller uses a PING PID during the next bus transaction to this endpoint.</td>
</tr>
</tbody>
</table>

The defined ping protocol (see USB 2.0 Specification, Chapter 8) allows the host to be *imprecise* on the initialization of the ping protocol (that is start in *Do OUT* when we don’t know whether there is space on the device or not). The host controller manages the *Ping State* bit. System software sets the initial value in the queue head when it initializes a queue head. The host controller preserves the *Ping State* bit across all queue advancements. This means that when a new qTD is written into the queue head overlay area, the previous value of the *Ping State* bit is preserved.

**42.5.3.12 Split Transactions**

USB 2.0 defines extensions to the bus protocol for managing USB 1.x data streams through USB 2.0 Hubs.

This section describes how the host controller uses the interface data structures to manage data streams with full- and low-speed devices, connected below USB 2.0 hub, utilizing the split transaction protocol.

Refer to USB 2.0 Specification for the complete definition of the split transaction protocol. Full- and Low-speed devices are enumerated identically as high-speed devices, but the transactions to the Full- and Low-speed endpoints use the split-transaction protocol on the high-speed bus. The split transaction protocol is an encapsulation of (or wrapper around) the Full- or Low-speed transaction. The high-speed wrapper portion of the protocol is addressed to the USB 2.0 Hub and Transaction Translator below which the Full- or Low-speed device is attached.
The EHCI interface uses dedicated data structures for managing full-speed isochronous data streams (see Split Transaction Isochronous Transfer Descriptor (siTD)). Control, Bulk and Interrupt are managed using the queuing data structures (see Queue Head). The interface data structures need to be programmed with the device address and the Transaction Translator number of the USB 2.0 Hub operating as the Low-/Full-speed host controller for this link. The following sections describe the details of how the host controller must process and manage the split transaction protocol.

42.5.3.12.1 Split Transactions for Asynchronous Transfers

A queue head in the asynchronous schedule with an $EPS$ field indicating a full-or low-speed device indicates to the host controller that it must use split transactions to stream data for this queue head.

All full-speed bulk and full-, low-speed control are managed through queue heads in the asynchronous schedule.

Software must initialize the queue head with the appropriate device address and port number for the transaction translator that is serving as the full/low-speed host controller for the links connecting the endpoint. Software must also initialize the split transaction state bit ($SplitXState$) to Do-Start-Split. Finally, if the endpoint is a control endpoint, then system software must set the Control Transfer Type ($C$) bit in the queue head to one. If this is not a control transfer type endpoint, the $C$ bit must be initialized by software to be zero. This information is used by the host controller to properly set the Endpoint Type (ET) field in the split transaction bus token. When the $C$ bit is zero, the split transaction token's ET field is set to indicate a bulk endpoint. When the $C$ bit is one, the split transaction token's ET field is set to indicate a control endpoint. Refer to Chapter 8 of USB Specification Revision 2.0 for details.

![Figure 42-19. Host Controller Asynchronous Schedule Split-Transaction State Machine](image-url)
42.5.3.12.1.1  Asynchronous - Do Start Split

This is the state which software must initialize a full- or low-speed asynchronous queue head. This state is entered from the Do Complete Split state only after a complete-split transaction receives a valid response from the transaction translator that is not a Nyet handshake.

For queue heads in this state, the host controller executes a start-split transaction to the appropriate transaction translator. If the bus transaction completes without an error and PidCode indicates an IN or OUT transaction, then the host controller reloads the error counter (CErr). If it is a successful bus transaction and the PidCode indicates a SETUP, the host controller does not reload the error counter. If the transaction translator responds with a Nak, the queue head is left in this state, and the host controller proceeds to the next queue head in the asynchronous schedule.

If the host controller times out the transaction (no response, or bad response) the host controller decrements Cerr and proceeds to the next queue head in the asynchronous schedule.

42.5.3.12.1.2  Asynchronous - Do Complete Split

This state is entered from the Do Start Split state only after a start-split transaction receives an Ack handshake from the transaction translator.

For queue heads in this state, the host controller executes a complete-split transaction to the appropriate transaction translator. If the transaction translator responds with a Nyet handshake, the queue head is left in this state, the error counter is reset and the host controller proceeds to the next queue head in the asynchronous schedule. When a Nyet handshake is received for a bus transaction where the queue head's PidCode indicates an IN or OUT, the host controller reloads the error counter (CErr). When a Nyet handshake is received for a complete-split bus transaction where the queue head's PidCode indicates a SETUP, the host controller must not adjust the value of CErr.

Independent of PidCode, the following responses have the effects:

- Transaction Error (XactErr). Timeout or data CRC failure, and so on. The error counter (Cerr) is decremented by one and the complete split transaction is immediately retried (if possible). If there is not enough time in the micro-frame to execute the retry, the host controller MUST ensure that the next time the host controller begins executing from the Asynchronous schedule, it must begin executing from this queue head. If another start-split (for some other endpoint) is sent to the transaction translator before the complete-split is really completed, the transaction translator could dump the results (which were never delivered to the host). This is why the core specification states the retries must be immediate. A method to
accomplish this behavior is to not advance the asynchronous schedule. When the host controller returns to the asynchronous schedule in the next micro-frame, the first transaction from the schedule is the retry for this endpoint.

If $Cerr$ went to zero, the host controller must halt the queue.

- **NAK.** The target endpoint Nak'd the full- or low-speed transaction. The state of the transfer is not advanced and the state is exited. If the $PidCode$ is a SETUP, then the Nak response is a protocol error. The $XactErr$ status bit is set to one and the $CErr$ field is decremented.

- **STALL.** The target endpoint responded with a STALL handshake. The host controller sets the $halt$ bit in the status byte, retires the qTD but does not attempt to advance the queue.

If the $PidCode$ indicates an IN, then any of following responses are expected:

- **DATA0/1.** On reception of data, the host controller ensures the PID matches the expected data toggle and checks CRC. If the packet is $good$, the host controller advances the state of the transfer, for example move the data pointer by the number of bytes received, decrement $BytesToTransfer$ field by the number of bytes received, and toggle the $dt$ bit. The host controller then exit this state. The response and advancement of transfer may trigger other processing events, such as retirement of the qTD and advancement of the queue.

If the data sequence PID does not match the expected, the data is ignored, the transfer state is not advanced and this state is exited. If the $PidCode$ indicates an OUT/SETUP, then any of following responses are expected:

- **ACK.** The target endpoint accepted the data, so the host controller must advance the state of the transfer. The $Current Offset$ field is incremented by $Maximum Packet Length$ or $Bytes to Transfer$, whichever is less. The field $Bytes To Transfer$ is decremented by the same amount and the data toggle bit ($dt$) is toggled. The host controller then exit this state.

- Advancing the transfer state may cause other processing events such as retirement of the qTD and advancement of the queue (see Managing Control/Bulk/Interrupt Transfers through Queue Heads).

### 42.5.3.12.2 Split Transaction Interrupt

Split-transaction Interrupt-IN/OUT endpoints are managed through the same data structures used for high-speed interrupt endpoints. They both co-exist in the periodic schedule.
Queue heads/qTDs offer the set of features required for reliable data delivery, which is characteristic to interrupt transfer types. The split-transaction protocol is managed completely within this defined functional transfer framework. For example, for a high-speed endpoint, the host controller visits a queue head, execute a high-speed transaction (if criteria are met) and advance the transfer state (or not) depending on the results of the entire transaction. For low- and full-speed endpoints, the details of the execution phase are different (that is takes more than one bus transaction to complete), but the remainder of the operational framework is intact. This means that the transfer advancement, and so on, occurs as defined in Managing Control/Bulk/Interrupt Transfers through Queue Heads, but only occurs on the completion of a split transaction.

42.5.3.12.2.1 Split Transaction Scheduling Mechanisms for Interrupt

Full- and low-speed Interrupt queue heads have an EPS field indicating full- or low-speed and have a non-zero S-mask field.

The host controller can detect this combination of parameters and assume the endpoint is a periodic endpoint. Low- and full-speed interrupt queue heads require the use of the split transaction protocol. The host controller sets the Endpoint Type (ET) field in the split token to indicate the transaction is an interrupt. These transactions are managed through a transaction translator's periodic pipeline. Software should not set these fields to indicate the queue head is an interrupt unless the queue head is used in the periodic schedule.

System software manages the per/transaction translator periodic pipeline by budgeting and scheduling exactly during which micro-frames the start-splits and complete-splits for each endpoint occurs. The characteristics of the transaction translator are such that the high-speed transaction protocol must execute during explicit micro-frames, or the data or response information in the pipeline is lost.

The following figure illustrates the general scheduling boundary conditions that are supported by the EHCI periodic schedule and queue head data structure. The S and C\text{X} labels indicate micro-frames where software can schedule start-splits and complete splits (respectively).
The scheduling cases are:

- Case 1: The normal scheduling case is where the entire split transaction is completely bounded by a frame (*H-Frame* in this case).
- Case 2a through Case 2c: The USB 2.0 Hub pipeline rules states clearly, when and how many complete-splits must be scheduled to account for earliest to latest execution on the full/low-speed link. The complete-splits may span the *H-Frame* boundary when the start-split is in micro-frame 4 or later. When this occurs, the *H-Frame* to *B-Frame* alignment requires that the queue head be reachable from consecutive periodic frame list locations. System software cannot build an efficient schedule that satisfies this requirement unless it uses FSTNs.

The figure below illustrates the general layout of the periodic schedule.

**Figure 42-20. Split Transaction, Interrupt Scheduling Boundary Conditions**
The periodic frame list is effectively the leaf level a binary tree, which is always traversed leaf to root. Each level in the tree corresponds to a \( 2^N \) poll rate. Software can efficiently manage periodic bandwidth on the USB by *spreading* interrupt queue heads that have the same poll rate requirement across all the available paths from the frame list. For example, system software can schedule eight poll rate 8 queue heads and account for them once in the high-speed bus bandwidth allocation.

When an endpoint is allocated an execution footprint that spans a frame boundary, the queue head for the endpoint must be reachable from consecutive locations in the frame list. An example would be if \( 8_{0b} \), where such an endpoint. Without additional support on the interface, to get \( 8_{0b} \) reachable at the correct time, software would have to link \( 8_1 \) to \( 8_{0b} \). It would then have to move \( 4_1 \) and everything linked after into the same path as \( 4_0 \). This upsets the integrity of the binary tree and disallows the use of the spreading technique.

FSTN data structures are used to preserve the integrity of the binary-tree structure and enable the use of the spreading technique. Host Controller Operational Model for FSTNs defines the hardware and software operational model requirements for using FSTNs.
The following queue head fields are initialized by system software to instruct the host controller when to execute portions of the split-transaction protocol:

- **SplitXState.** This is single bit residing in the Status field of a queue head (see Table 42-24). This bit is used to track the current state of the split transaction.

- **Frame S-mask.** This is a bit-field where system software sets a bit corresponding to the micro-frame (within an H-Frame) that the host controller should execute a start-split transaction. This is always qualified by the value of the SplitXState bit in the Status field of the queue head. For example, referring to Figure 42-20, case one, the S-mask would have a value of 00000001b indicating that if the queue head is traversed by the host controller, and the SplitXState indicates Do_Start, and the current micro-frame as indicated by FRINDEX[2:0] is 0, then execute a start-split transaction.

- **Frame C-mask.** This is a bit-field where system software sets one or more bits corresponding to the micro-frames (within an H-Frame) that the host controller should execute complete-split transactions. The interpretation of this field is always qualified by the value of the SplitXState bit in the Status field of the queue head. For example, referring to Figure 42-20, case one, the C-mask would have a value of 00011100b indicating that if the queue head is traversed by the host controller, and the SplitXState indicates Do_Complete, and the current micro-frame as indicated by FRINDEX[2:0] is 2, 3, or 4, then execute a complete-split transaction. It is software's responsibility to ensure that the translation between H-Frames and B-Frames is correctly performed when setting bits in S-mask and C-mask.

### 42.5.3.12.2.2 Host Controller Operational Model for FSTNs

The FSTN data structure is used to manage Low/Full-speed interrupt queue heads that need to be reached from consecutive frame list locations (that is boundary cases 2a through 2c).

An FSTN is essentially a *back pointer*, similar in intent to the back pointer field in the siTD data structure (see siTD Back Link Pointer).

This feature provides software a simple primitive to save a schedule position, redirect the host controller to traverse the necessary queue heads in the previous frame, then restore the original schedule position and complete normal traversal.

The four components to the use of FSTNs:

- FSTN data structure.
- A *Save Place* indicator. This is always an FSTN with its Back Path Link Pointer.T-bit set to zero.
• A *Restore* indicator. This is always an FSTN with its *Back Path Link Pointer* T-bit set to one.
• Host controller FSTN traversal rules.

When the host controller encounters an FSTN during micro-frames 2 through 7 it simply follows the node's *Normal Path Link Pointer* to access the next schedule data structure.

**NOTE**

The FSTN's *Normal Path Link Pointer* T-bit may set to one, which the host controller must interpret as the end of periodic list mark.

When the host controller encounters a *Save-Place* FSTN in micro-frames 0 or 1, it saves the value of the *Normal Path Link Pointer* and set an internal flag indicating that it is executing in *Recovery Path* mode. *Recovery Path* mode modifies the host controller's rules for how it traverses the schedule and limits which data structures is considered for execution of bus transactions. The host controller continues executing in *Recovery Path* mode until it encounters a *Restore* FSTN or it determines that it has reached the end of the micro-frame (see details in the list below).

The rules for schedule traversal and limited execution while in *Recovery Path* mode are:

• Always follow the *Normal Path Link Pointer* when it encounters an FSTN that is a *Save-Place* indicator. The host controller must not recursively follow *Save-Place* FSTNs. Therefore, while executing in *Recovery Path* mode, it must never follow an FSTN's *Back Path Link Pointer*.
• Do not process an siTD or, iTD data structure. Simply follow its *Next Link Pointer*.
• Do not process a QH (Queue Head) whose *EPS* field indicates a high-speed device. Simply follow its *Horizontal Link Pointer*.
• When a QH's *EPS* field indicates a Full/Low-speed device, the host controller considers only it for execution if its *SplitXState* is DoComplete (note: this applies whether the *PID Code* indicates an IN or an OUT). See *Execute Transaction* and *Tracking Split Transaction Progress for Interrupt Transfers* for a complete list of additional conditions that must be met in general for the host controller to issue a bus transaction.
  • The host controller must not execute a Start-split transaction while executing in *Recovery Path* mode. See *Periodic Isochronous - Do Complete Split* for special handling when in *Recovery Path* mode.
• Stop traversing the *recovery path* when it encounters an FSTN that is a *Restore* indicator. The host controller unconditionally uses the saved value of the *Save-Place* FSTN's *Normal Path Link Pointer* when returning to the normal path traversal. The
host controller must clear the context of executing a Recovery Path when it restores schedule traversal to the Save-Place FSTN's Normal Path Link Pointer.

- If the host controller determines that there is not enough time left in the micro-frame to complete processing of the periodic schedule, it abandons traversal of the recovery path, and clears the context of executing a recovery path. The result is that at the start of the next consecutive micro-frame, the host controller starts traversal at the frame list.

An example traversal of a periodic schedule that includes FSTNs is illustrated in the following figure.

**Figure 42-22. Example Host Controller Traversal of Recovery Path via FSTNs**

In frame N+1 (micro-frames 0 and 1), when the host controller encounters Save-Path FSTN (Save-N), it observes that Save-N.Back Path Link Pointer.T-bit is zero (definition of a Save-Path indicator). The host controller saves the value of Save-N.Normal Path Link Pointer and follows Save-N.Back Path Link Pointer. At the same time, it sets an internal flag indicating that it is now in Recovery Path mode (the recovery path is annotated in the figure above with a large dashed line). The host controller continues traversing data structures on the recovery path and executing only those bus transactions as noted above, on the recovery path until it reaches Restore FSTN (Restore-N). Restore-N.Back Path Link Pointer.T-bit is set to one (definition of a Restore indicator), so the host controller exits Recovery Path mode by clearing the internal Recovery Path mode flag and commences (restores) schedule traversal using the saved value of the Save-Place FSTN's Normal Path Link Pointer (for example Save-N.Normal Path Link Pointer). The nodes traversed during these micro-frames include: \( \{8_{3,0}, 8_{3,1}, 8_{3,2}, \text{Save-A}, 8_{2,2}, 8_{2,3}, 4_{2}, \ldots \} \).
2_0, Restore-N, 4_3, 2_1, Restore-N, 1_0 \ldots \}. The nodes on the recovery-path are in bold. In frame N (micro-frames 0-7), for this example, the host controller traverses all of the schedule data structures utilizing the \textit{Normal Path Link Pointers} in any FSTNs it encounters. This is because the host controller has not yet encountered a \textit{Save-Place} FSTN so it not executing in \textit{Recovery Path} mode. When it encounters the \textit{Restore} FSTN, (Restore-N), during micro-frames 0 and 1, it uses Restore-N.Normal Path Link Pointer to traverse to the next data structure (that is normal schedule traversal). This is because the host controller must use a Restore FSTN's \textit{Normal Path Link Pointer} when not executing in a \textit{Recovery-Path} mode. The nodes traversed during frame N include: \{8_2.0, 8_2.1, 8_2.2, 8_2.3, 4_2, 2_0, Restore-N, 1_0 \ldots \}.

In frame N+1 (micro-frames 2-7), when the host controller encounters Save-Path FSTN Save-N, it unconditionally follows Save-N.Normal Path Link Pointer. The nodes traversed during these micro-frames include: \{8_3.0, 8_3.1, 8_3.2, Save-A, 4_3, 2_1, Restore-N, 1_0 \ldots \}.

### 42.5.3.12.2.3 Software Operational Model for FSTNs

Software must create a consistent, coherent schedule for the host controller to traverse.

When using FSTNs, system software must adhere to the following rules:

- Each \textit{Save-Place} indicator requires a matching \textit{Restore} indicator.
  - The \textit{Save-Place} indicator is an FSTN with a valid \textit{Back Path Link Pointer} and \textit{T-bit} equal to zero.
  - \textit{Back Path Link Pointer.Typ} field must be set to indicate the referenced data structure is a queue head. The \textit{Restore} indicator is an FSTN with its \textit{Back Path Link Pointer.T-bit} set to one.
- A \textit{Restore} FSTN may be matched to one or more \textit{Save-Place} FSTNs. For example, if the schedule includes a poll-rate 1 level, then system software only needs to place a \textit{Restore} FSTN at the beginning of this list in order to match all possible \textit{Save-Place} FSTNs.
- If the schedule does not have elements linked at a poll-rate level of one, and one or more \textit{Save-Place} FSTNs are used, then System Software must ensure the \textit{Restore} FSTN's \textit{Normal Path Link Pointer's T-bit} is set to one, as this is used to mark the end of the periodic list.
- When the schedule does have elements linked at a poll rate level of one, a \textit{Restore} FSTN must be the first data structure on the poll rate one list. All traversal paths from the frame list converge on the poll-rate one list. System software must ensure that \textit{Recovery Path} mode is exited before the host controller is allowed to traverse the poll rate level one list.
- A \textit{Save-Place} FSTN's \textit{Back Path Link Pointer} must reference a queue head data structure. The referenced queue head must be reachable from the previous frame list.
location. In other words, if the Save-Place FSTN is reachable from frame list offset N, then the FSTN's Back Path Link Pointer must reference a queue head that is reachable from frame list offset N-1.

Software should make the schedule as efficient as possible. What this means in this context is that software should have no more than one Save-Place FSTN reachable in any single frame. Note there is times when two (or more, depending on the implementation) could exist as full/low-speed footprints change with bandwidth adjustments. This could occur, for example when a bandwidth re-balance causes system software to move the Save-Place FSTN from one poll rate level to another. During the transition, software must preserve the integrity of the previous schedule until the new schedule is in place.

42.5.3.12.2.4 Tracking Split Transaction Progress for Interrupt Transfers

To correctly maintain the data stream, the host controller must be able to detect and report errors where data is lost.

For interrupt-IN transfers, data is lost when it makes it into the USB 2.0 hub, but the USB 2.0 host system is unable to get it from the USB 2.0 Hub and into the system before it expires from the transaction translator pipeline.

When a lost data condition is detected, the queue must be halted, thus signaling system software to recover from the error. A data-loss condition exists whenever a start-split is issued, accepted and successfully executed by the USB 2.0 Hub, but the complete-splits get unrecoverable errors on the high-speed link, or the complete-splits do not occur at the correct times. One reason complete-splits might not occur at the right time would be due to host-induced system hold-offs that cause the host controller to miss bus transactions because it cannot get timely access to the schedule in system memory.

The same condition can occur for an interrupt-OUT, but the result is not an endpoint halt condition, but rather effects only the progress of the transfer. The queue head has the following fields to track the progress of each split transaction. These fields are used to keep incremental state about which (and when) portions have been executed.

- **C-prog-mask.** This is an eight-bit bit-vector where the host controller keeps track of which complete-splits have been executed. Due to the nature of the Transaction Translator periodic pipeline, the complete-splits need to be executed in-order. The host controller needs to detect when the complete-splits have not been executed in order. This can only occur due to system hold-offs where the host controller cannot get to the memory-based schedule. **C-prog-mask** is a simple bit-vector that the host controller sets one of the C-prog-mask bits for each complete-split executed. The bit position is determined by the micro-frame number in which the complete-split was executed. The host controller always checks **C-prog-mask** before executing a
complete-split transaction. If the previous complete-splits have not been executed then it means one (or more) have been skipped and data has potentially been lost.

- **FrameTag.** This field is used by the host controller during the complete-split portion of the split transaction to tag the queue head with the frame number (*H-Frame number*) when the next complete split must be executed.

- **S-bytes.** This field can be used to store the number of data payload bytes sent during the start-split (if the transaction was an OUT). The *S-bytes* field must be used to accumulate the data payload bytes received during the complete-splits (for an IN).

### 42.5.3.12.2.5 Split Transaction Execution State Machine for Interrupt

In the following presentation, all references to micro-frame are in the context of a micro-frame within an *H-Frame*.

As with asynchronous Full- and Low-speed endpoints, a split-transaction state machine is used to manage the split transaction sequence.

Aside from the fields defined in the queue head for scheduling and tracking the split transaction, the host controller calculates one internal mechanism that is also used to manage the split transaction. The internal calculated mechanism is:

- **cMicroFrameBit** is a single-bit encoding of the current micro-frame number. It is an eight-bit value calculated by the host controller at the beginning of every micro-frame. It is calculated from the three least significant bits of the *FRINDEX* register (that is, \( c_{MicroFrameBit} = 1 \text{ shifted-left}(FRINDEX[2:0]) \)). The *cMicroFrameBit* has at most one bit asserted, which always corresponds to the current micro-frame number. For example, if the current micro-frame is 0, then *cMicroFrameBit* will equal 00000001b. The variable *cMicroFrameBit* is used to compare against the *S-mask* and *C-mask* fields to determine whether the queue head is marked for a start- or complete-split transaction for the current micro-frame.

The following figure illustrates the state machine for managing a complete interrupt split transaction. There are two phases to each split transaction. The first is a single start-split transaction, which occurs when the *SplitXState* is at Do_Start and the single bit in *cMicroFrameBit* has a corresponding bit active in *QH.S-mask*. The transaction translator does not acknowledge the receipt of the periodic start-split, so the host controller unconditionally transitions the state to Do_Complete. Due to the available jitter in the transaction translator pipeline, there will be more than one complete-split transaction scheduled by software for the Do_Complete state. This translates simply to the fact that there are multiple bits set to a one in the *QH.C-mask* field.

The host controller keeps the queue head in the Do_Complete state until the split transaction is complete (see definition below), or an error condition triggers the *three-strikes-rule* (for example, after the host tries the same transaction three times, and each
encounters an error, the host controller will stop retrying the bus transaction and halt the endpoint, thus requiring system software to detect the condition and perform system-dependent recovery).

![Diagram of Split Transaction State Machine for Interrupt]

Figure 42-23. Split Transaction State Machine for Interrupt

See Previous Section for the frame tag management rules.

Periodic Interrupt - Do Start Split

This is the state software must initialize a full- or low-speed interrupt queue head StartXState bit. This state is entered from the Do_Complete Split state only after the split transaction is complete. This occurs when one of the following events occur: The transaction translator responds to a complete-split transaction with one of the following:

- NAK. A NAK response is a propagation of the full- or low-speed endpoint's NAK response.
- ACK. An ACK response is a propagation of the full- or low-speed endpoint's ACK response. Only occurs on an OUT endpoint.
- DATA 0/1. Only occurs for INs. Indicates that this is the last of the data from the endpoint for this split transaction.
- ERR. The transaction on the low-/full-speed link below the transaction translator had a failure (for example, timeout, bad CRC, etc.).
- NYET (and Last). The host controller issued the last complete-split and the transaction translator responded with a NYET handshake. This means that the start-split was not correctly received by the transaction translator, so it never executed a transaction to the full- or low-speed endpoint, see Section Periodic Isochronous - Do Complete Split for the definition of 'Last'.

![Diagram of Start Split State Machine]

USB Operation Model

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
Each time the host controller visits a queue head in this state (once within the Execute Transaction state), it performs the following test to determine whether to execute a start-split.

- **QH.S-mask** is bit-wise anded with **cMicroFrameBit**.

If the result is non-zero, then the host controller will issue a start-split transaction. If the **PIDCode** field indicates an IN transaction, the host controller must zero-out the **QH.S-bytes** field. After the split-transaction has been executed, the host controller sets up state in the queue head to track the progress of the complete-split phase of the split transaction. Specifically, it records the expected frame number into **QH.FrameTag** field (see Section ), set **C-prog-mask** to zero (00h), and exits this state. Note that the host controller must not adjust the value of **CErr** as a result of completion of a start-split transaction.

**Periodic Interrupt - Do Complete Split**

This state is entered unconditionally from the Do Start Split state after a start-split transaction is executed on the bus. Each time the host controller visits a queue head in this state (once within the Execute Transaction state), it checks to determine whether a complete-split transaction should be executed now.

There are four tests to determine whether a complete-split transaction should be executed.

- **Test A.** **cMicroFrameBit** is bit-wise anded with **QH.C-mask** field. A non-zero result indicates that software scheduled a complete-split for this endpoint, during this micro-frame.
- **Test B.** **QH.FrameTag** is compared with the current contents of **FRINDEX[7:3]**. An equal indicates a match.
- **Test C.** The complete-split progress bit vector is checked to determine whether the previous bit is set, indicating that the previous complete-split was appropriately executed. An example algorithm for this test is provided below:

```plaintext
Algorithm Boolean CheckPreviousBit(QH.C-prog-mask, QH.C-mask, cMicroFrameBit)
Begin
    -- Return values:
    -- TRUE - no error
    -- FALSE - error
    --
    Boolean rvalue = TRUE;
    previousBit = cMicroFrameBit logical-rotate-right(1)
    -- Bit-wise anding previousBit with C-mask indicates
    -- whether there was an intent
    -- to send a complete split in the previous micro-frame. So,
    -- if the
    -- 'previous bit' is set in C-mask, check C-prog-mask to
    -- make sure it
    -- happened.
    If (previousBit bitAND QH.C-mask) then
        If not(previousBit bitAND QH.C-prog-mask) then
            rvalue = FALSE;
        End if
    End if
    -- If the C-prog-mask already has a one in this bit position,
```

**Chapter 42 Universal Serial Bus Controller (USB)**

*i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019*

NXP Semiconductors
-- then an aliasing
-- error has occurred. It will probably get caught by the
-- FrameTag Test, but
-- at any rate it is an error condition that as detectable here
-- should not allow
-- a transaction to be executed.
If (cMicroFrameBit bitAND QH.C-prog-mask) then
rvalue = FALSE;
End if
return (rvalue)
End Algorithm

• Test D. Check to see if a start-split should be executed in this micro-frame. Note this
is the same test performed in the Do Start Split state (see Section Periodic
Isochronous - Do Start Split ). Whenever it evaluates to TRUE and the controller is
NOT processing in the context of a Recovery Path mode, it means a start-split should
occur in this micro-frame. Test D and Test A evaluating to TRUE at the same time is
a system software error. Behavior is undefined.

If (A .and. B .and. C .and. not(D)) then the host controller will execute a complete-split
transaction. When the host controller commits to executing the complete-split transaction,
it updates QH.C-prog-mask by bit-ORing with cMicroFrameBit. On completion of the
complete-split transaction, the host controller records the result of the transaction in the
queue head and sets QH.FrameTag to the expected H-Frame number (see Section ). The
effect to the state of the queue head and thus the state of the transfer depends on the
response by the transaction translator to the complete-split transaction. The following
responses have the effects (note that any responses that result in decrementing of the
CErr will result in the queue head being halted by the host controller if the result of the
decrement is zero):

• NYET (and Last). On each NYET response, the host controller checks to determine
whether this is the last complete-split for this split transaction. Last is defined in this
context as the condition where all of the scheduled complete-splits have been
executed. If it is the last complete-split (with a NYET response), then the transfer
state of the queue head is not advanced (never received any data) and this state
exited. The transaction translator must have responded to all the complete-splits with
NYETs, meaning that the start-split issued by the host controller was not received.
The start-split should be retried at the next poll period.
• The test for whether this is the Last complete split can be performed by XOR QH.C-
mask with QH.C-prog-mask. If the result is all zeros then all complete-splits have
been executed. When this condition occurs, the XactErr status bit is set to a one and
the CErr field is decremented.
• NYET (and not Last). See above description for testing for Last. The complete-split
transaction received a NYET response from the transaction translator. Do not update
any transfer state (except for C-prog-mask and FrameTag) and stay in this state. The
host controller must not adjust CErr on this response.
• Transaction Error (XactErr). Timeout, data CRC failure, etc. The CErr field is decremented and the XactErr bit in the Status field is set to a one. The complete split transaction is immediately retried (if Cerr is non-zero). If there is not enough time in the micro-frame to complete the retry and the endpoint is an IN, or CErr is decremented to a zero from a one, the queue is halted. If there is not enough time in the micro-frame to complete the retry and the endpoint is an OUT and CErr is not zero, then this state is exited (that is, return to Do Start Split). This results in a retry of the entire OUT split transaction, at the next poll period. Refer to Chapter 11 Hubs (specifically the section full- and low-speed Interrupts) in the USB Specification Revision 2.0 for detailed requirements on why these errors must be immediately retried.

• ACK. This can only occur if the target endpoint is an OUT. The target endpoint ACK'd the data and this response is a propagation of the endpoint ACK up to the host controller. The host controller must advance the state of the transfer. The Current Offset field is incremented by Maximum Packet Length or Bytes to Transfer, whichever is less. The field Bytes To Transfer is decremented by the same amount. And the data toggle bit (dt) is toggled. The host controller will then exit this state for this queue head. The host controller must reload CErr with maximum value on this response. Advancing the transfer state may cause other process events such as retirement of the qTD and advancement of the queue (see Section Managing Control/Bulk/Interrupt Transfers through Queue Heads).

• MDATA. This response will only occur for an IN endpoint. The transaction translator responded with zero or more bytes of data and an MDATA PID. The incremental number of bytes received is accumulated in QH.S-bytes. The host controller must not adjust CErr on this response.

• DATA0/1. This response may only occur for an IN endpoint. The number of bytes received is added to the accumulated byte count in QH.S-bytes. The state of the transfer is advanced by the result and the host controller will exit this state for this queue head.

• Advancing the transfer state may cause other processing events such as retirement of the qTD and advancement of the queue (see Section Managing Control/Bulk/Interrupt Transfers through Queue Heads).

• If the data sequence PID does not match the expected, the entirety of the data received in this split transaction is ignored, the transfer state is not advanced and this state is exited.

• NAK. The target endpoint Nak'd the full- or low-speed transaction. The state of the transfer is not advanced, and this state is exited. The host controller must reload CErr with maximum value on this response.
• ERR. There was an error during the full- or low-speed transaction. The ERR status bit is set to a one, \( C_{err} \) is decremented, the state of the transfer is not advanced, and this state is exited.

• STALL. The queue is halted (an exit condition of the Execute Transaction state). The status field bits: Active bit is set to zero and the Halted bit is set to a one and the qTD is retired. Responses which are not enumerated in the list or which are received out of sequence are illegal and may result in undefined host controller behavior. The other possible combinations of tests A, B, C, and D may indicate that data or response was lost. The table below lists the possible combinations and the appropriate action.

### Table 42-48. Interrupt IN/OUT Do Complete Split State Execution Criteria

<table>
<thead>
<tr>
<th>Condition</th>
<th>Action</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>not(A) not(D)</td>
<td>Ignore QHD</td>
<td>Neither a start nor complete-split is scheduled for the current micro-frame. Host controller should continue walking the schedule.</td>
</tr>
<tr>
<td>A not(C)</td>
<td>If PIDCode = IN Halt QHD If PIDCode = OUT Retry start-split</td>
<td>Progress bit check failed. These means a complete-split has been missed. There is the possibility of lost data. If PIDCode is an IN, then the Queue head must be halted. If PIDCode is an OUT, then the transfer state is not advanced and the state exited (for example, start-split is retried). This is a host-induced error and does not effect ( C_{ERR} ). In either case, set the Missed Micro-frame bit in the status field to a one.</td>
</tr>
<tr>
<td>A not(B) C</td>
<td>If PIDCode = IN Halt QHD If PIDCode = OUT Retry start-split</td>
<td>( QH.FrameTag ) test failed. This means that exactly one or more H-Frames have been skipped. This means complete-splits and have missed. There is the possibility of lost data. If PIDCode is an IN, then the Queue head must be halted. If PIDCode is an OUT, then the transfer state is not advanced and the state exited (for example, start-split is retried). This is a host-induced error and does not effect ( C_{ERR} ). In either case, set the Missed Micro-frame bit in the status field to a one.</td>
</tr>
<tr>
<td>A B C not(D)</td>
<td>Execute complete-split</td>
<td>This is the non-error case where the host controller executes a complete-split transaction.</td>
</tr>
<tr>
<td>D</td>
<td>If PIDCode = IN Halt QHD If PIDCode = OUT Retry start-split</td>
<td>This is a degenerate case where the start-split was issued, but all of the complete-splits were skipped and all possible intervening opportunities to detect the missed data failed to fire. If PIDCode is an IN, then the Queue head must be halted. If PIDCode is an OUT, then the transfer state is not advanced and the state exited (for example, start-split is retried). This is a host-induced error and does not effect ( C_{ERR} ). In either case, set the Missed Micro-frame bit in the status field to a one. Note: When executing in the context of a Recovery Path mode, the host controller is allowed to process the queue head and take the actions indicated above, or it may wait until the queue head is visited in the</td>
</tr>
</tbody>
</table>
Table 42-48  Interrupt IN/OUT Do Complete Split State Execution Criteria

<table>
<thead>
<tr>
<th>Criteria</th>
</tr>
</thead>
<tbody>
<tr>
<td>normal processing mode. Regardless, the host controller must not execute a start-split in the context of a executing in a Recovery Path mode.</td>
</tr>
</tbody>
</table>

Managing QH.FrameTag Field

The `QH.FrameTag` field in a queue head is completely managed by the host controller. The rules for setting `QH.FrameTag` are simple:

- **Rule 1:** If transitioning from Do Start Split to Do Complete Split and the current value of `FRINDEX[2:0]` is 6, `QH.FrameTag` is set to `FRINDEX[7:3] + 1`. This accommodates split transactions whose start-split and complete-splits are in different H-Frames (case 2a, see Figure 42-20).
- **Rule 2:** If the current value of `FRINDEX[2:0]` is 7, `QH.FrameTag` is set to `FRINDEX[7:3] + 1`. This accommodates staying in Do Complete Split for cases 2a, 2b, and 2c (Figure 42-20).
- **Rule 3:** If transitioning from Do_Start Split to Do Complete Split and the current value of `FRINDEX[2:0]` is not 6, or currently in Do Complete Split and the current value of `(FRINDEX[2:0])` is not 7, `FrameTag` is set to `FRINDEX[7:3]`. This accommodates all other cases (Figure 42-20).

### 42.5.3.12.2.6 Rebalancing the periodic schedule

System software must occasionally adjust a periodic queue head's S-mask and C-mask fields during operation.

This need occurs when adjustments to the periodic schedule create a new bandwidth budget and one or more queue head's are assigned new execution footprints (that is, new S-mask and C-mask values).

It is imperative that System software must not update these masks to new values in the midst of a split transaction. In order to avoid any race conditions with the update, the EHCI host controller provides a simple assist to system software. System software sets the `Inactivate-on-next-Transaction (I)` bit to a one to signal the host controller that it intends to update the S-mask and C-mask on this queue head. System software will then wait for the host controller to observe the `I-bit` is a one and transition the `Active` bit to a zero. The rules for how and when the host controller sets the `Active` bit to zero are enumerated below:

- **If the `Active` bit is a zero, no action is taken.** The host controller does not attempt to advance the queue when the `I-bit` is a one.
- **If the `Active` bit is a one and the `SplitXState` is DoStart (regardless of the value of S-mask),** the host controller will simply set `Active` bit to a zero. The host controller is
not required to write the transfer state back to the current qTD. Note that if the S-mask indicates that a start-split is scheduled for the current micro-frame, the host controller must not issue the start-split bus transaction. It must set the Active bit to zero.

System software must save transfer state before setting the I-bit to a one. This is required so that it can correctly determine what transfer progress (if any) occurred after the I-bit was set to a one and the host controller executed its final bus-transaction and set Active to a zero.

After system software has updated the S-mask and C-mask, it must then reactivate the queue head. Because the Active bit and the I-bit cannot be updated with the same write, system software needs to use the following algorithm to coherently re-activate a queue head that has been stopped via the I-bit.

1. Set the Halted bit to a one, then
2. Set the I-bit to a zero, then
3. Set the Active bit to a one and the Halted bit to a zero in the same write.

Setting the Halted bit to a one inhibits the host controller from attempting to advance the queue between the time the I-bit goes to a zero and the Active bit goes to a one.

### 42.5.3.12.3 Split Transaction Isochronous

Full-speed isochronous transfers are managed using the split-transaction protocol through a USB 2.0 transaction translator in a USB2.0 Hub. The EHCI controller utilizes siTD data structure to support the special requirements of isochronous split-transactions.

This data structure uses the scheduling model of isochronous TDs (iTD, Section Isochronous (High-Speed) Transfer Descriptor (iTD)) (see Section Managing Isochronous Transfers Using iTDs for the operational model of iTDs) with the contiguous data feature provided by queue heads. This simple arrangement allows a single isochronous scheduling model and adds the additional feature that all data received from the endpoint (per split transaction) must land into a contiguous buffer.

#### 42.5.3.12.3.1 Split Transaction Scheduling Mechanisms for Isochronous

Full-speed isochronous transactions are managed through a transaction translator's periodic pipeline. As with full- and low-speed interrupt, system software manages each transaction translator's periodic pipeline by budgeting and scheduling exactly during which micro-frames the start-splits and complete-splits for each full-speed isochronous endpoint occur.
The requirements described in Section Split Transaction Scheduling Mechanisms for Interrupt apply. The following figure illustrates the general scheduling boundary conditions that are supported by the EHCI periodic schedule. The $S_X$ and $C_X$ labels indicate micro-frames where software can schedule start- and complete-splits (respectively). The $H$-Frame boundaries are marked with a large, solid bold vertical line. The $B$-Frame boundaries are marked with a large, bold, dashed line. The bottom of the figure illustrates the relationship of an siTD to the $H$-Frame.

### Figure 42-24. Split Transaction, Isochronous Scheduling Boundary Conditions

When the endpoint is an isochronous OUT, there are only start-splits, and no complete-splits. When the endpoint is an isochronous IN, there is at most one start-split and one to $N$ complete-splits. The scheduling boundary cases are:

- **Case 1**: The entire split transaction is completely bounded by an $H$-Frame. For example: the start-splits and complete-splits are all scheduled to occur in the same $H$-Frame.
Case 2a: This boundary case is where one or more (at most two) complete-splits of a split transaction IN are scheduled across an $H$-Frame boundary. This can only occur when the split transaction has the possibility of moving data in $B$-Frame, micro-frames 6 or 7 ($H$-Frame micro-frame 7 or 0). When an $H$-Frame boundary wrap condition occurs, the scheduling of the split transaction spans more than one location in the periodic list. (For example, it takes two siTDs in adjacent periodic frame list locations to fully describe the scheduling for the split transaction.)

Although the scheduling of the split transaction may take two data structures, all of the complete-splits for each full-speed IN isochronous transaction must use only one data pointer. For this reason, siTDs contain a back pointer, the use of which is described below.

Software must never schedule full-speed isochronous OUTs across an $H$-Frame boundary.

Case 2b: This case can only occur for a very large isochronous IN. It is the only allowed scenario where a start-split and complete-split for the same endpoint can occur in the same micro-frame. Software must enforce this rule by scheduling the large transaction first. Large is defined to be anything larger than 579 byte maximum packet size.

A subset of the same mechanisms employed by full- and low-speed interrupt queue heads are employed in siTDs to schedule and track the portions of isochronous split transactions. The following fields are initialized by system software to instruct the host controller when to execute portions of the split transaction protocol.

- $SplitXState$. This is a single bit residing in the $Status$ field of an siTD (see Figure 42-25). This bit is used to track the current state of the split transaction. The rules for managing this bit are described in Section Split Transaction Execution State Machine for Interrupt.

- $Frame S-mask$. This is a bit-field where system software sets a bit corresponding to the micro-frame (within an $H$-Frame) that the host controller should execute a start-split transaction. This is always qualified by the value of the $SplitXState$ bit. For example, referring to the IN example in Figure 42-24, case one, the $S-mask$ would have a value of 0000001b indicating that if the siTD is traversed by the host controller, and the $SplitXState$ indicates Do Start Split, and the current micro-frame as indicated by USB_n_FRINDEX[2:0] is 0, then execute a start-split transaction.

- $Frame C-mask$. This is a bit-field where system software sets one or more bits corresponding to the micro-frames (within an $H$-Frame) that the host controller should execute complete-split transactions. The interpretation of this field is always qualified by the value of the $SplitXState$ bit. For example, referring to the IN example in Figure 42-24, case one, the $C-mask$ would have a value of 00111100b indicating that if the siTD is traversed by the host controller, and the $SplitXState$ indicates Do
Complete Split, and the current micro-frame as indicated by $USB_n_FRINDEX[2:0]$ is 2, 3, 4, or 5, then execute a complete-split transaction.

- **Back Pointer.** This field in a siTD is used to complete an IN split-transaction using the previous $H-Frame$'s siTD. This is only used when the scheduling of the complete-splits span an $H-Frame$ boundary.

There exists a one-to-one relationship between a high-speed isochronous split transaction (including all start- and complete-splits) and one full-speed isochronous transaction. An siTD contains (amongst other things) buffer state and split transaction scheduling information. An siTD's buffer state always maps to one full-speed isochronous data payload. This means that for any full-speed transaction payload, a single siTD's data buffer must be used. This rule applies to both IN an OUTs. An siTD's scheduling information usually also maps to one high-speed isochronous split transaction. The exception to this rule is the $H-Frame$ boundary wrap cases mentioned above.

The siTD data structure describes at most, one frame's worth of high-speed transactions and that description is strictly bounded within a frame boundary. The figure below illustrates some examples. On the top are examples of the full-speed transaction footprints for the boundary scheduling cases described above. In the middle are time-frame references for both the $B-Frames$ (HS/FS/LS Bus) and the $H-Frames$. On the bottom is illustrated the relationship between the scope of an siTD description and the time references. Each $H-Frame$ corresponds to a single location in the periodic frame list. The implication is that each siTD is reachable from a single periodic frame list location at a time.
Each case is described below:

- **Case 1**: One siTD is sufficient to describe and complete the isochronous split transaction because the whole isochronous split transaction is tightly contained within a single *H-Frame*.

- **Case 2a, 2b**: Although both INs and OUTs can have these footprints, OUTs always take only one siTD to schedule. However, INs (for these boundary cases) require two siTDs to complete the scheduling of the isochronous split transaction $siTD_X$ is used to always issue the start-split and the first $N$ complete-splits. The full-speed transaction (for these cases) can deliver data on the full-speed bus segment during micro-frame 7 of $H-Frame_{Y+1}$, or micro-frame 0 of $H-Frame_{Y+2}$. The complete splits are scheduled using $siTD_{X+2}$ (not shown). The complete-splits to extract this data must use the buffer pointer from $siTD_{X+1}$. The only way for the host controller to reach $siTD_{X+1}$ from $H-Frame_{Y+2}$ is to use $siTD_{X+2}$’s back pointer. The host controller rules for when to use the back pointer are described in Section *Periodic Isochronous - Do Complete Split*.

Software must apply the following rules when calculating the schedule and linking the schedule data structures into the periodic schedule:
• Software must ensure that an isochronous split-transaction is started so that it will complete before the end of the B-Frame.
• Software must ensure that for a single full-speed isochronous endpoint, there is never a start-split and complete-split in H-Frame, micro-frame 1. This is mandated as a rule so that case 2a and case 2b can be discriminated. According to the core USB specification, the long isochronous transaction illustrated in Case 2b, could be scheduled so that the start-split was in micro-frame 1 of H-Frame N and the last complete-split would need to occur in micro-frame 1 of H-Frame N+1. However, it is impossible to discriminate between cases 2a and case 2b, which has significant impact on the complexity of the host controller.

42.5.3.12.3.2 Tracking Split Transaction Progress for Isochronous Transfers

To correctly maintain the data stream, the host controller must be able to detect and report errors where device to host data is lost. Isochronous endpoints do not employ the concept of a halt on error, however the host is required to identify and report per-packet errors observed in the data stream. This includes schedule traversal problems (skipped micro-frames), timeouts and corrupted data received.

In similar kind to interrupt split-transactions, the portions of the split transaction protocol must execute in the micro-frames they are scheduled. The queue head data structure used to manage full- and low-speed interrupt has several mechanisms for tracking when portions of a transaction have occurred. Isochronous transfers use siTDs, for their transfers, and the data structures are only reachable via the schedule in the exact micro-frame in which they are required (so all the mechanism employed for tracking in queue heads is not required for siTDs). Software has the option of reusing siTD several times in the complete periodic schedule. However, it must ensure that the results of split transaction N are consumed and the siTD reinitialized (activated) before the host controller gets back to the siTD (in a future micro-frame).

Split-transaction isochronous OUTs utilize a low-level protocol to indicate which portions of the split transaction data have arrived. Control over the low-level protocol is exposed in an siTD via the fields Transaction Position (TP) and Transaction Count (T-count). If the entire data payload for the OUT split transaction is larger than 188 bytes, there will be more than one start-split transaction, each of which require proper annotation. If host hold-offs occur, then the sequence of annotations received from the host will not be complete, which is detected and handled by the transaction translator. See Section Periodic Isochronous - Do Start Split for a description on how these fields are used during a sequence of start-split transactions.

The fields siTD.T-Count and siTD.TP are used by the host controller to drive and sequence the transaction position annotations. It is the responsibility of system software to properly initialize these fields in each siTD. Once the budget for a split-transaction
isochronous endpoint is established, $S$-mask, $T$-Count, and $TP$ initialization values for all the siTD associated with the endpoint are constant. They remain constant until the budget for the endpoint is recalculated by software and the periodic schedule adjusted.

For IN-endpoints, the transaction translator simply annotates the response data packets with enough information to allow the host controller to identify the last data. As with split transaction Interrupt, it is the host controller's responsibility to detect when it has missed an opportunity to execute a complete-split. The following field in the siTD is used to track and detect errors in the execution of a split transaction for an IN isochronous endpoint.

- **C-prog-mask.** This is an eight-bit bit-vector where the host controller keeps track of which complete-splits have been executed. Due to the nature of the Transaction Translator periodic pipeline, the complete-splits need to be executed in-order. The host controller needs to detect when the complete-splits have not been executed in order. This can only occur due to system hold-offs where the host controller cannot get to the memory-based schedule. **C-prog-mask** is a simple bit-vector that the host controller sets a bit for each complete-split executed. The bit position is determined by the micro-frame (USB_n_FRINDEX[2:0]) number in which the complete-split was executed. The host controller always checks **C-prog-mask** before executing a complete-split transaction. If the previous complete-splits have not been executed, then it means one (or more) have been skipped and data has potentially been lost. System software is required to initialize this field to zero before setting an siTD's **Active** bit to a one.

If a transaction translator returns with the final data before all of the complete-splits have been executed, the state of the transfer is advanced so that the remaining complete-splits are not executed. Refer to Section Asynchronous - Do Complete Split for a description on how the state of the transfer is advanced. It is important to note that an IN siTD is retired based solely on the responses from the Transaction Translator to the complete-split transactions. This means, for example, that it is possible for a transaction translator to respond to a complete-split with an MDATA PID. The number of bytes in the MDATA's data payload could cause the siTD field **Total Bytes to Transfer** to decrement to zero. This response can occur, before all of the scheduled complete-splits have been executed. In other interface, data structures (for example, high-speed data streams through queue heads), the transition of **Total Bytes to Transfer** to zero signals the end of the transfer and results in setting of the **Active** bit to zero. However, in this case, the result has not been delivered by the Transaction Translator and the host must continue with the next complete-split transaction to extract the residual transaction state. This scenario occurs because of the pipeline rules for a Transaction Translator (see Chapter 11 of the Universal Serial Bus Revision 2.0). In summary the periodic pipeline rules require that on a micro-frame boundary, the Transaction Translator will hold the final two bytes received (if it has not seen an End Of Packet (EOP)) in the full-speed bus pipe stage and give the
remaining bytes to the high-speed pipeline stage. At the micro-frame boundary, the Transaction Translator could have received the entire packet (including both CRC bytes) but not received the packet EOP. In the next micro-frame, the Transaction Translator will respond with an MDATA and send all of the data bytes (with the two CRC bytes being held in the full-speed pipeline stage). This could cause the siTD to decrement its Total Bytes to Transfer field to zero, indicating it has received all expected data. The host must still execute one more (scheduled) complete-split transaction in order to extract the results of the full-speed transaction from the Transaction Translator (for example, the Transaction Translator may have detected a CRC failure, and this result must be forwarded to the host).

If the host experiences hold-offs that cause the host controller to skip one or more (but not all) scheduled split transactions for an isochronous OUT, then the protocol to the transaction translator will not be consistent and the transaction translator will detect and react to the problem. Likewise, for host hold-offs that cause the host controller to skip one or more (but not all) scheduled split transactions for an isochronous IN, the C-prog-mask is used by the host controller to detect errors. However, if the host experiences a hold-off that causes it to skip all of an siTD, or an siTD expires during a host hold off (for example, a hold-off occurs and the siTD is no longer reachable by the host controller in order for it to report the hold-off event), then system software must detect that the siTDs have not been processed by the host controller (that is, state not advanced) and report the appropriate error to the client driver.

42.5.3.12.3.3 Split Transaction Execution State Machine for Isochronous

In the following presentation, all references to micro-frame are in the context of a micro-frame within an H-Frame.

If the Active bit in the Status byte is a zero, the host controller will ignore the siTD and continue traversing the periodic schedule. Otherwise the host controller will process the siTD as specified below. A split transaction state machine is used to manage the split-transaction protocol sequence. The host controller uses the fields defined in Section Tracking Split Transaction Progress for Interrupt Transfers, plus the variable cMicroFrameBit defined in Section Split Transaction Execution State Machine for Interrupt to track the progress of an isochronous split transaction. The figure below illustrates the state machine for managing an siTD through an isochronous split transaction. Bold, dotted circles denote the state of the Active bit in the Status field of a siTD. The Bold, dotted arcs denote the transitions between these states. Solid circles denote the states of the split transaction state machine and the solid arcs denote the transitions between these states. Dotted arcs and boxes reference actions that take place either as a result of a transition or from being in a state.
**Figure 42-26. Split Transaction State Machine for Isochronous**

### 42.5.3.12.3.4 Periodic Isochronous - Do Start Split

Isochronous split transaction OUTs use only this state.

An siTD for a split-transaction isochronous IN is either initialized to this state, or the siTD transitions to this state from Do Complete Split when a case 2a (IN) or 2b scheduling boundary isochronous split-transaction completes.

Each time the host controller reaches an active siTD in this state, it checks the *siTD.S-mask* against *cMicroFrameBit*. If there is a one in the appropriate position, the siTD will execute a start-split transaction. By definition, the host controller cannot *reach* an siTD at the wrong time. If the *I/O* field indicates an IN, then the start-split transaction includes only the extended token plus the full-speed token. Software must initialize the *siTD.Total Bytes To Transfer* field to the number of bytes expected. This is usually the maximum packet size for the full-speed endpoint. The host controller exits this state when the start-split transaction is complete.

The remainder of this section is specific to an isochronous OUT endpoint (that is, the *I/O* field indicates an OUT). When the host controller executes a start-split transaction for an isochronous OUT it includes a data payload in the start-split transaction. The memory
buffer address for the data payload is constructed by concatenating $siTD.Current\ Offset$ with the page pointer indicated by the page selector field ($siTD.P$). A zero in this field selects Page 0 and a 1 selects Page 1. During the start-split for an OUT, if the data transfer crosses a page boundary during the transaction, the host controller must detect the page cross, update the $siTD.P$-bit from a zero to a one, and begin using the $siTD.Page$ with $siTD.Current\ Offset$ as the memory address pointer. The field $siTD.TP$ is used to annotate each start-split transaction with the indication of which part of the split-transaction data the current payload represents (ALL, BEGIN, MID, END). In all cases the host controller simply uses the value in $siTD.TP$ to mark the start-split with the correct transaction position code.

$T-Count$ is always initialized to the number of start-splits for the current frame. $TP$ is always initialized to the first required transaction position identifier. The scheduling boundary case (see Figure 42-25) is used to determine the initial value of $TP$. The initial cases are summarized in the following table.

<table>
<thead>
<tr>
<th>Case</th>
<th>T-count</th>
<th>TP</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1, 2a</td>
<td>=1</td>
<td>ALL</td>
<td>When the OUT data payload is less than (or equal to) 188 bytes, only one start-split is required to move the data. The one start-split must be marked with an ALL.</td>
</tr>
<tr>
<td>1, 2a</td>
<td>!=1</td>
<td>BEGIN</td>
<td>When the OUT data payload is greater than 188 bytes more than one start-split must be used to move the data. The initial start-split must be marked with a BEGIN.</td>
</tr>
</tbody>
</table>

After each start-split transaction is complete, the host controller updates $T-Count$ and $TP$ appropriately so that the next start-split is correctly annotated.

The table below illustrates all of the $TP$ and $T-count$ transitions, which must be accomplished by the host controller.

<table>
<thead>
<tr>
<th>TP</th>
<th>T-count next</th>
<th>TP next</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALL</td>
<td>0</td>
<td>N/A</td>
<td>Transition from ALL, to done.</td>
</tr>
<tr>
<td>BEGIN</td>
<td>1</td>
<td>END</td>
<td>Transition from BEGIN to END. Occurs when $T-count$ starts at 2.</td>
</tr>
<tr>
<td>BEGIN</td>
<td>!=1</td>
<td>MID</td>
<td>Transition from BEGIN to MID. Occurs when $T-count$ starts at greater than 2.</td>
</tr>
<tr>
<td>MID</td>
<td>!=1</td>
<td>MID</td>
<td>TP stays at MID while $T-count$ is not equal to 1 (that is, greater than 1). This case can occur for any of the scheduling boundary cases where the $T-count$ starts greater than 3.</td>
</tr>
<tr>
<td>MID</td>
<td>1</td>
<td>END</td>
<td>Transition from MID to END. This case can occur for any of the scheduling boundary cases where the $T-count$ starts greater than 2.</td>
</tr>
</tbody>
</table>
The start-split transactions do not receive a handshake from the transaction translator, so the host controller always advances the transfer state in the siTD after the bus transaction is complete. To advance the transfer state the following operations take place:

- The \textit{siTD.Total Bytes To Transfer} and the \textit{siTD.Current Offset} fields are adjusted to reflect the number of bytes transferred.
- The \textit{siTD.P} (page selector) bit is updated appropriately.
- The \textit{siTD.TP} and \textit{siTD.T-count} fields are updated appropriately as defined in Table 42-50.

These fields are then written back to the memory based siTD. The \textit{S-mask} is fixed for the life of the current budget. As mentioned above, \textit{TP} and \textit{T-count} are set specifically in each siTD to reflect the data to be sent from this siTD. Therefore, regardless of the value of \textit{S-mask}, the actual number of start-split transactions depends on \textit{T-count} (or equivalently, Total Bytes to Transfer). The host controller must set the \textit{Active} bit to a zero when it detects that all of the schedule data has been sent to the bus. The preferred method is to detect when \textit{T-Count} decrements to zero as a result of a start-split bus transaction. Equivalently, the host controller can detect when Total Bytes to Transfer decrements to zero. Either implementation must ensure that if the initial condition is Total Bytes to Transfer equal to zero and \textit{T-count} is equal to a one, then the host controller will issue a single start-split, with a zero-length data payload. Software must ensure that \textit{TP}, \textit{T-count} and Total Bytes to Transfer are set to deliver the appropriate number of bus transactions from each siTD. An inconsistent combination will yield undefined behavior.

If the host experiences hold-offs that cause the host controller to skip start-split transactions for an OUT transfer, the state of the transfer will not progress appropriately. The transaction translator will observe protocol violations in the arrival of the start-splits for the OUT endpoint (that is, the transaction position annotation will be incorrect as received by the transaction translator).

Example scenarios are described in Section \textit{Split Transaction for Isochronous - Processing Examples}.

A host controller implementation can optionally track the progress of an OUT split transaction by setting appropriate bits in the \textit{siTD.C-prog-mask} as it executes each scheduled start-split. The \textit{checkPreviousBit()} algorithm defined in \textit{Periodic Isochronous - Do Complete Split} can be used prior to executing each start-split to determine whether start-splits were skipped. The host controller can use this mechanism to detect missed micro-frames. It can then set the siTD's \textit{Active} bit to zero and stop execution of this siTD. This saves on both memory and high-speed bus bandwidth.
42.5.3.12.3.5 Periodic Isochronous - Do Complete Split

This state is only used by a split-transaction isochronous IN endpoint.

This state is entered unconditionally from the Do Start State after a start-split transaction is executed for an IN endpoint. Each time the host controller visits an siTD in this state, it conducts a number of tests to determine whether it should execute a complete-split transaction. The individual tests are listed below. The sequence they are applied depends on which micro-frame the host controller is currently executing which means that the tests might not be applied until after the siTD referenced from the back pointer has been fetched.

- Test A. `cMicroFrameBit` is bit-wise anded with `siTD.C-mask` field. A non-zero result indicates that software scheduled a complete-split for this endpoint, during this micro-frame. This test is always applied to a newly fetched siTD that is in this state.
- Test B. The `siTD.C-prog-mask` bit vector is checked to determine whether the previous complete splits have been executed. An example algorithm is below (this is slightly different than the algorithm used in Section Periodic Isochronous - Do Complete Split). The sequence in which this test is applied depends on the current value of `USB_n_FRINDEX[2:0]`. If `USB_n_FRINDEX[2:0]` is 0 or 1, it is not applied until the back pointer has been used. Otherwise it is applied immediately.

```
Algorithm Boolean CheckPreviousBit(siTD.C-prog-mask, siTD.C-mask, cMicroFrameBit)
Begin
    Boolean rvalue = TRUE;
    previousBit = cMicroFrameBit rotate-right(1)
    -- Bit-wise anding previousBit with C-mask indicates whether there was an intent
    -- to send a complete split in the previous micro-frame. So, if the
    -- 'previous bit' is set in C-mask, check C-prog-mask to make sure it
    -- happened.
    if previousBit bitAND siTD.C-mask then
        if not (previousBit bitAND siTD.C-prog-mask) then
            rvalue = FALSE
        End if
    End if
    Return rvalue
End Algorithm
```

If Test A is true and `USB_n_FRINDEX[2:0]` is zero or one, then this is a case 2a or 2b scheduling boundary (see Figure 42-24). See Section Periodic Isochronous - Do Complete Split for details in handling this condition.

If Test A and Test B evaluate to true, then the host controller will execute a complete-split transaction using the transfer state of the current siTD. When the host controller commits to executing the complete-split transaction, it updates `QH.C-prog-mask` by bit-ORing with `cMicroFrameBit`. The transfer state is advanced based on the completion status of the complete-split transaction. To advance the transfer state of an IN siTD, the host controller must:

- Decrement the number of bytes received from `siTD>Total Bytes To Transfer`,
- Adjust `siTD.Current Offset` by the number of bytes received,
• Adjust \( siTD.P \) (page selector) field if the transfer caused the host controller to use the next page pointer, and
• Set any appropriate bits in the \( siTD.Status \) field, depending on the results of the transaction.

Note that if the host controller encounters a condition where \( siTD.Total\ Bytes\ To\ Transfer \) is zero, and it receives more data, the host controller must not write the additional data to memory. The \( siTD.Status.Active \) bit must be set to zero and the \( siTD.Status.Babble\ Detected \) bit must be set to a one. The fields \( siTD.Total\ Bytes\ To\ Transfer, siTD.Current\ Offset, \) and \( siTD.P \) (page selector) are not required to be updated as a result of this transaction attempt.

The host controller must accept (assuming good data packet CRC and sufficient room in the buffer as indicated by the value of \( siTD.Total\ Bytes\ To\ Transfer \)) MDATA and DATA0/1 data payloads up to and including 192 bytes. A host controller implementation may optionally set \( siTD.Status\ Active \) to a zero and \( siTD.Status.Babble\ Detected \) to a one when it receives and MDATA or DATA0/1 with a data payload of more than 192 bytes. The following responses have the noted effects:

• ERR. The full-speed transaction completed with a time-out or bad CRC and this is a reflection of that error to the host. The host controller sets the \( ERR \) bit in the \( siTD.Status \) field and sets the \( Active \) bit to a zero.

• Transaction Error (XactErr). The complete-split transaction encounters a Timeout, CRC16 failure, etc. The \( siTD.Status \) field \( XactErr \) field is set to a one and the complete-split transaction must be retried immediately. The host controller must use an internal error counter to count the number of retries as a counter field is not provided in the siTD data structure. The host controller will not retry more than two times. If the host controller exhausts the retries or the end of the micro-frame occurs, the \( Active \) bit is set to zero.

• DATAx (0 or 1). This response signals that the final data for the split transaction has arrived. The transfer state of the siTD is advanced and the \( Active \) bit is set to a zero. If the \( Bytes\ To\ Transfer \) field has not decremented to zero (including the reception of the data payload in the DATAx response), then less data than was expected, or allowed for was actually received. This short packet event does not set the USBINT status bit in the USBSTS register to a one. The host controller will not detect this condition.

• NYET (and Last). On each NYET response, the host controller also checks to determine whether this is the last complete-split for this split transaction. Last was defined in Section Periodic Isochronous - Do Complete Split. If it is the last complete-split (with a NYET response), then the transfer state of the siTD is not advanced (never received any data) and the \( Active \) bit is set to a zero. No bits are set in the \( Status \) field because this is essentially a skipped transaction. The transaction translator must have responded to all the scheduled clompete-splits with NYETs,
meaning that the start-split issued by the host controller was not received. This result should be interpreted by system software as if the transaction was completely skipped. The test for whether this is the last complete split can be performed by XORing C-mask with C-prog-mask. A zero result indicates that all complete-splits have been executed.

- **MDATA (and Last).** See above description for testing for Last. This can only occur when there is an error condition. Either there has been a babble condition on the full-speed link, which delayed the completion of the full-speed transaction, or software set up the $S$-mask and/or $C$-masks incorrectly. The host controller must set $XactErr$ bit to a one and the $Active$ bit is set to a zero.

- **NYET (and not Last).** See above description for testing for Last. The complete-split transaction received a NYET response from the transaction translator. Do not update any transfer state (except for $C$-prog-mask) and stay in this state.

- **MDATA (and not Last).** The transaction translator responds with an MDATA when it has partial data for the split transaction. For example, the full-speed transaction data payload spans from micro-frame X to X+1 and during micro-frame X, the transaction translator will respond with an MDATA and the data accumulated up to the end of micro-frame X. The host controller advances the transfer state to reflect the number of bytes received.

If Test A succeeds, but Test B fails, it means that one or more of the complete-splits have been skipped. The host controller sets the *Missed Micro-Frame* status bit and sets the $Active$ bit to a zero.

### 42.5.3.12.3.6 Complete-Split for Scheduling Boundary Cases 2a, 2b

Boundary cases 2a and 2b (INs only) (see Figure 42-24) require that the host controller use the transaction state context of the previous siTD to finish the split transaction. The table below enumerates the transaction state fields.

<table>
<thead>
<tr>
<th>Buffer State</th>
<th>Status</th>
<th>Execution Progress</th>
</tr>
</thead>
<tbody>
<tr>
<td>Total Bytes To Transfer</td>
<td>All bits in the status field</td>
<td>$C$-prog-mask</td>
</tr>
<tr>
<td>P (page select)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Current Offset</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TP (transaction position)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>T-count (transaction count)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTE**

$TP$ and $T$-count are used only for Host to Device (OUT) endpoints.
If software has budgeted the schedule of this data stream with a frame wrap case, then it must initialize the siTD.Back Pointer field to reference a valid siTD and will have the siTD.Back Pointer.T-bit in the siTD.Back Pointer field set to a zero. Otherwise, software must set the siTD.Back Pointer.T-bit in the siTD.Back Pointer field to a one. The host controller's rules for interpreting when to use the siTD.Back Pointer field are listed below. These rules apply only when the siTD's Active bit is a one and the SplitXState is Do Complete Split.

- When cMicroFrameBit is a 1h and the siTDX.Back Pointer.T-bit is a zero, or
- If cMicroFrameBit is a 2h and siTDX.S-mask[0] is a zero

When either of these conditions apply, then the host controller must use the transaction state from siTDX-1.

In order to access siTDX-1, the host controller reads on-chip the siTD referenced from siTDX.Back Pointer.

The host controller must save the entire state from siTDX while processing siTDX-1. This is to accommodate for case 2b processing. The host controller must not recursively walk the list of siTD.Back Pointers.

If siTDX-1 is active (Active bit is a one and SplitXStat is Do Complete Split), then both Test A and Test B are applied as described above. If these criteria to execute a complete-split are met, the host controller executes the complete split and evaluates the results as described above. The transaction state (see Table 42-51) of siTDX-1 is appropriately advanced based on the results and written back to memory. If the resultant state of siTDX-1's Active bit is a one, then the host controller returns to the context of siTDX, and follows its next pointer to the next schedule item. No updates to siTDX are necessary.

If siTDX-1 is active (Active bit is a one and SplitXStat is Do Start Split), then the host controller must set Active bit to a zero and Missed Micro-Frame status bit to a one and the resultant status written back to memory.

If siTDX-1's Active bit is a zero, (because it was zero when the host controller first visited siTDX-1 via siTDX's back pointer, it transitioned to zero as a result of a detected error, or the results of siTDX-1's complete-split transaction transitioned it to zero), then the host controller returns to the context of siTDX and transitions its SplitXState to Do Start Split. The host controller then determines whether the case 2b start split boundary condition exists (that is, if cMicroframeBit is a 1b and siTDX.S-mask[0] is a 1b). If this criterion is met the host controller immediately executes a start-split transaction and appropriately advances the transaction state of siTDX, then follows siTDX.Next Pointer to the next schedule item. If the criterion is not met, the host controller simply follows siTDX.Next Pointer to the next schedule item. Note that in the case of a 2b boundary case, the split-transaction of siTDX-1 will have its Active bit set to zero when the host controller returns
to the context of $siTD_X$. Also, note that software should not initialize an siTD with $C$-mask bits 0 and 1 set to a one and an $S$-mask with bit zero set to a one. This scheduling combination is not supported and the behavior of the host controller is undefined.

### 42.5.3.12.3.7 Split Transaction for Isochronous - Processing Examples

There is an important difference between how the hardware/software manages the isochronous split transaction state machine and how it manages the asynchronous and interrupt split transaction state machines.

The asynchronous and interrupt split transaction state machines are encapsulated within a single queue head. The progress of the data stream depends on the progress of each split transaction. In some respects, the split-transaction state machine is sequenced via the Execute Transaction queue head traversal state machine (see Figure 42-17).

Isochronous is a pure time-oriented transaction/data stream. The interface data structures are optimized to efficiently describe transactions that need to occur at specific times. The isochronous split-transaction state machine must be managed across these time-oriented data structures. This means that system software must correctly describe the scheduling of split-transactions across more than one data structure.

Then the host controller must make the appropriate state transitions at the appropriate times, in the correct data structures.

For example, the table below illustrates a couple of frames worth of scheduling required to schedule a case 2a full-speed isochronous data stream.

<table>
<thead>
<tr>
<th>siTDX Micro-Frames</th>
<th>Initial SplitXState</th>
</tr>
</thead>
<tbody>
<tr>
<td>#</td>
<td>Masks</td>
</tr>
<tr>
<td>X</td>
<td>S-Mask</td>
</tr>
<tr>
<td></td>
<td>C-Mask</td>
</tr>
<tr>
<td>X+1</td>
<td>S-Mask</td>
</tr>
<tr>
<td></td>
<td>C-Mask</td>
</tr>
<tr>
<td>X+2</td>
<td>S-Mask</td>
</tr>
<tr>
<td></td>
<td>C-Mask</td>
</tr>
<tr>
<td>X+3</td>
<td>S-Mask</td>
</tr>
<tr>
<td></td>
<td>C-Mask</td>
</tr>
</tbody>
</table>

Table 42-52. Example Case 2a - Software Scheduling siTDs for an IN Endpoint
This example shows the first three siTDs for the transaction stream. Because this is the case-2a frame-wrap case, \textit{S-masks} of all siTDs for this endpoint have a value of 10h (a one bit in micro-frame 4) and \textit{C-mask} value of C3h (one-bits in micro-frames 0, 1, 6 and 7). Additionally, sofware ensures that the \textit{Back Pointer} field of each siTD references the appropriate siTD data structure (and the \textit{Back PointerT-bits} are set to zero).

The initial \textit{SplitXState} of the first siTD is Do Start Split. The host controller will visit the first siTD eight times during frame X. The C-mask bits in micro-frames 0 and 1 are ignored because the state is Do Start Split. During micro-frame 4, the host controller determines that it can run a start-split (and does) and changes \textit{SplitXState} to Do Complete Split. During micro-frames 6 and 7, the host controller executes complete-splits. Notice the siTD for frame X+1 has its \textit{SplitXState} initialized to Do Complete Split. As the host controller continues to traverse the schedule during \textit{H-Frame} X+1, it will visit the second siTD eight times. During micro-frames 0 and 1 it will detect that it must execute complete-splits.

During \textit{H-Frame} X+1, micro-frame 0, the host controller detects that siTD\textsubscript{X+1}'s \textit{Back Pointer}.\textit{T-bit} is a zero, saves the state of siTD\textsubscript{X+1} and fetches siTD\textsubscript{X}. It executes the complete split transaction using the transaction state of siTD\textsubscript{X}. If the siTD\textsubscript{X} split transaction is complete, siTD's \textit{Active} bit is set to zero and results written back to siTD\textsubscript{X}. The host controller retains the fact that siTD\textsubscript{X} is retired and transitions the \textit{SplitXState} in the siTD\textsubscript{X+1} to Do Start Split. At this point, the host controller is prepared to execute the start-split for siTD\textsubscript{X+1} when it reaches micro-frame 4. If the split-transaction completes early (transaction-complete is defined in Section \textit{Periodic Isochronous - Do Complete Split}), that is, before all the scheduled complete-splits have been executed, the host controller will transition \textit{siTD\textsubscript{X}.SplitXState} to Do Start Split early and naturally skip the remaining scheduled complete-split transactions. For this example, \textit{siTD\textsubscript{X+1}} does not receive a DATA0 response until \textit{H-Frame} X+2, micro-frame 1.

During \textit{H-Frame} X+2, micro-frame 0, the host controller detects that siTD\textsubscript{X+2}'s \textit{Back Pointer}.\textit{T-bit} is a zero, saves the state of siTD\textsubscript{X+2} and fetches siTD\textsubscript{X+1}. As described above, it executes another split transaction, receives an MDATA response, updates the transfer state, but does not modify the \textit{Active} bit. The host controller returns to the context of siTD\textsubscript{X+2}, and traverses its next pointer without any state change updates to siTD\textsubscript{X+2}. S

During \textit{H-Frame} X+2, micro-frame 1, the host controller detects siTD\textsubscript{X+2}'s \textit{S-mask}[0] is a zero, saves the state of siTD\textsubscript{X+2} and fetches siTD\textsubscript{X+1}. It executes another complete-split transaction, receives a DATA0 response, updates the transfer state and sets the \textit{Active} bit to a zero. It returns to the state of siTD\textsubscript{X+2} and changes its \textit{SplitXState} to Do Start Split. At this point, the host controller is prepared to execute start-splits for siTD\textsubscript{X+2} when it reaches micro-frame 4.
42.5.3.13 Host Controller Pause

When the host controller's *HCHalted* bit in the USBSTS register is a zero, the host controller is sending SOF (Start OF Frame) packets down all enabled ports.

When the schedules are enabled, the EHCI host controller will access the schedules in main memory each micro-frame. This constant pinging of main memory is known to create Arm platform power management problems for mobile systems. Specifically, mobile systems aggressively manage the state of the Arm platform, based on recent history usage. In the more aggressive power saving modes, the Arm platform can disable its caches. Current PC architectures assume that bus-master accesses to main memory must be cache-coherent. So, when bus masters are busy touching memory, the Arm platform power management software can detect this activity over time and inhibit the transition of the Arm platform into its lowest power savings mode. USB controllers are bus-masters and the frequency at which they access their memory-based schedules keeps the Arm platform power management software from placing the Arm platform into its lowest power savings state.

USB Host controllers don't access main memory when they are suspended. However, there are a variety of reasons why placing the USB controllers into suspend won't work, but they are beyond the scope of this document. The base requirement is that the USB controller needs to be kept out of main memory, while at the same time, the USB bus is kept from going into suspend.

EHCI controllers provide a large-grained mechanism that can be manipulated by system software to change the memory access pattern of the host controller. System software can manipulate the schedule enable bits in the USBCMD register to turn on/off the scheduling traversal. A software heuristic can be applied to implement an on/off duty cycle that allows the USB to make reasonable progress and allow the Arm platform power management to get the Arm platform into its lowest power state. This method is not intended to be applied at all times to throttle USB, but should only be applied in very specific configurations and usage loads. For example, when only a keyboard or mouse is attached to the USB, the heuristic could detect times when the USB is attempting to move data only very infrequently and can adjust the duty cycle to allow the Arm platform to reach its low power state for longer periods of time. Similarly, it could detect increases in the USB load and adjust the duty cycle appropriately, even to the point where the schedules are never disabled. The assumption here is that the USB is moving data and the Arm platform will be required to process the data streams.
It is suggested that in order to provide a complete solution for the system, the companion host controllers should also provide a similar method to allow system software to inhibit the companion host controller from accessing its shared memory based data structures (schedule lists or otherwise).

### 42.5.3.14 Port Test Modes -Host Operational Model

EHCI host controllers must implement the port test modes Test J_State, Test K_State, Test_Packet, Test Force_Enable, and Test SE0_NAK as described in the USB Specification Revision 2.0.

The system is only allowed to test ports that are owned by the EHCI controller (for example, CF-bit is a one and PortOwner bit is a zero). System software is allowed to have at most one port in test mode at a time. Placing more than one port in test mode will yield undefined results. The required, per port test sequence is (assuming the CF-bit in the USB_n_CONFIGFLAG register is a one):

- Disable the periodic and asynchronous schedules by setting the Asynchronous Schedule Enable and Periodic Schedule Enable bits in the USBCMD register to a zero.
- Place all enabled root ports into the suspended state by setting the Suspend bit in each appropriate USB_n_PORTSC register to a one.
- Set the Run/Stop bit in the USBCMD register to a zero and wait for the HCHalted bit in the USBSTS register, to transition to a one. Note that an EHCI host controller implementation may optionally allow port testing with the Run/Stop bit set to a one. However, all host controllers must support port testing with Run/Stop set to a zero and HCHalted set to a one.
- Set the Port Test Control field in the port under test PORTSC register to the value corresponding to the desired test mode. If the selected test is Test_Force_Enable, then the Run/Stop bit in the USBCMD register must then be transitioned back to one, in order to enable transmission of SOFs out of the port under test.
- When the test is complete, system software must ensure the host controller is halted (HCHalted bit is a one) then it terminates and exits test mode by setting HCRest to a one.

### 42.5.3.15 Interrupts-Host Operational Model

The EHCI Host Controller hardware provides interrupt capability based on a number of sources.

There are several general groups of interrupt sources:
interrupts as a result of executing transactions from the schedule (success and error conditions),
• Host controller events (Port change events, etc.), and
• Host Controller error events

All transaction-based sources are maskable through the Host Controller's Interrupt Enable register (USBINTR, see Section Interrupt Enable Register (USB_nUSBINTR)). Additionally, individual transfer descriptors can be marked to generate an interrupt on completion. This section describes each interrupt source and the processing that occurs in response to the interrupt.

During normal operation, interrupts may be immediate or deferred until the next interrupt threshold occurs. The interrupt threshold is a tunable parameter via the Interrupt Threshold Control field in the USBCMD register. The value of this register controls when the host controller will generate an interrupt on behalf of normal transaction execution. When a transaction completes during an interrupt interval period, the interrupt signaling the completion of the transfer will not occur until the interrupt threshold occurs. For example, the default value is eight micro-frames. This means that the host controller will not generate interrupts any more frequently than once every eight micro-frames.

Section Host System Error details effects of a host system error.

If an interrupt has been scheduled to be generated for the current interrupt threshold interval, the interrupt is not signaled until after the status for the last complete transaction in the interval has been written back to host memory. This may sometimes result in the interrupt not being signaled until the next interrupt threshold.

Initial interrupt processing is the same, regardless of the reason for the interrupt. When an interrupt is signaled by the hardware, Arm platform control is transferred to host controller's USB interrupt handler. The precise mechanism to accomplish the transfer is OS specific. For this discussion it is just assumed that control is received. When the interrupt handler receives control, its first action is to read the USBSTS (USB Status Register). It then acknowledges the interrupt by clearing all of the interrupt status bits by writing ones to these bit positions. The handler then determines whether the interrupt is due to schedule processing or some other event. After acknowledging the interrupt, the handler (via an OS-specific mechanism), schedules a deferred procedure call (DPC) which will execute later. The DPC routine processes the results of the schedule execution. The precise mechanisms used are beyond the scope of this document.

Note: the host controller is not required to de-assert a currently active interrupt condition when software sets the interrupt enables (in the USBINR register, see Section Interrupt Enable Register (USB_nUSBINTR)) to a zero. The only reliable method software should use for acknowledging an interrupt is by transitioning the appropriate status bits in the USBSTS register (Section USB Status Register (USB_nUSBSTS)) from a one to a zero.
42.5.3.15.1 Transfer/Transaction Based Interrupts

These interrupt sources are associated with transfer and transaction progress. They are all dependent on the next interrupt threshold.

42.5.3.15.1.1 Transaction Error

A transaction error is any error that caused the host controller to think that the transfer did not complete successfully.

The table below lists the events/responses that the host can observe as a result of a transaction. The effects of the error counter and interrupt status are summarized in the following paragraphs. Most of these errors set the XactErr status bit in the appropriate interface data structure.

There is a small set of protocol errors that relate only when executing a queue head and fit under the umbrella of a WRONG PID error that are significant to explicitly identify. When these errors occur, the XactErr status bit in the queue head is set and the CErr field is decremented. When the PIDCode indicates a SETUP, the following responses are protocol errors and result in XactErr bit being set to a one and the CErr field being decremented.

- EPS field indicates a high-speed device and it returns a Nak handshake to a SETUP.
- EPS field indicates a high-speed device and it returns a Nyet handshake to a SETUP.
- EPS field indicates a low- or full-speed device and the complete-split receives a Nak handshake.

<table>
<thead>
<tr>
<th>Event / Result</th>
<th>Queue Head/qTD/iTD/siTD Side-effects</th>
<th>USB Status Register (USBSTS)</th>
</tr>
</thead>
<tbody>
<tr>
<td>CRC</td>
<td>XactErr set to a one.</td>
<td>1.1</td>
</tr>
<tr>
<td>Timeout</td>
<td>XactErr set to a one.</td>
<td>11</td>
</tr>
<tr>
<td>Bad PID ²</td>
<td>XactErr set to a one.</td>
<td>11</td>
</tr>
<tr>
<td>Babble</td>
<td>Section Serial Bus Babble</td>
<td>1</td>
</tr>
<tr>
<td>Buffer Error</td>
<td>Section Data Buffer Error</td>
<td>1</td>
</tr>
</tbody>
</table>

1. If occurs in a queue head, then USBERRINT is asserted only when CErr counts down from a one to a zero. In addition the queue is halted, see Halting a Queue Head.
2. The host controller received a response from the device, but it could not recognize the PID as a valid PID.
42.5.3.15.1.2 Serial Bus Babble

When a device transmits more data on the USB than the host controller is expecting for this transaction, it is defined to be babbling. In general, this is called a *Packet Babble*.

When a device sends more data than the *Maximum Length* number of bytes, the host controller sets the *Babble Detected* bit to a one and halts the endpoint if it is using a queue head (see [Halting a Queue Head](https://example.com)). *Maximum Length* is defined as the minimum of *Total Bytes to Transfer* and *Maximum Packet Size*. The *CErr* field is not decremented for a packet babble condition (only applies to queue heads). A babble condition also exists if IN transaction is in progress at High-speed EOF2 point. This is called a frame babble. A frame babble condition is recorded into the appropriate schedule data structure. In addition, the host controller must disable the port to which the frame babble is detected.

The *USBERRINT* bit in the USB_n_USBSTS register is set to a one and if the *USB Error Interrupt Enable* bit in the USB_n_USBINTR register is a one, then a hardware interrupt is signaled to the system at the next interrupt threshold. The host controller must never start an OUT transaction that will babble across a micro-frame EOF.

**NOTE**

When a host controller detects a data PID mismatch, it must either: disable the packet babble checking for the duration of the bus transaction or do packet babble checking based solely on *Maximum Packet Size*. The USB core specification defines the requirements on a data receiver when it receives a data PID mismatch (for example, expects a DATA0 and gets a DATA1 or visa-versa). In summary, it must ignore the received data and respond with an ACK handshake, in order to advance the transmitter's data sequence.

The EHCI interface allows System software to provide buffers for a Control, Bulk or Interrupt IN endpoint that are not an even multiple of the maximum packet size specified by the device. Whenever a device misses an ACK for an IN endpoint, the host and device are out of synchronization with respect to the progress of the data transfer. The host controller may have advanced the transfer to a buffer that is less than maximum packet size. The device will re-send its maximum packet size data packet, with the original data PID, in response to the next IN token. In order to properly manage the bus protocol, the host controller must disable the packet babble check when it observes the data PID mismatch.
42.5.3.15.1.3  Data Buffer Error

This event indicates that an overrun of incoming data or a underrun of outgoing data has occurred for this transaction.

This would generally be caused by the host controller not being able to access required data buffers in memory within necessary latency requirements. These conditions are not considered transaction errors, and do not effect the error count in the queue head. When these errors do occur, the host controller records the fact the error occurred by setting the Data Buffer Error bit in the queue head, iTD or siTD.

If the data buffer error occurs on a non-isochronous IN, the host controller will not issue a handshake to the endpoint. This will force the endpoint to resend the same data (and data toggle) in response to the next IN to the endpoint.

If the data buffer error occurs on an OUT, the host controller must corrupt the end of the packet so that it cannot be interpreted by the device as a good data packet. Simply truncating the packet is not considered acceptable. An acceptable implementation option is to 1's complement the CRC bytes and send them. There are other options suggested in the Transaction Translator section of the USB Specification Revision 2.0.

42.5.3.15.1.4  USB Interrupt (Interrupt on Completion (IOC))

Transfer Descriptors (iTDs, siTDs, and queue heads (qTDs)) contain a bit that can be set to cause an interrupt on their completion. The completion of the transfer associated with that schedule item causes the USB Interrupt (USBINT) bit in the USB_n_USBSTS register to be set to a one.

In addition, if a short packet is encountered on an IN transaction associated with a queue head, then this event also causes USBINT to be set to a one. If the USB Interrupt Enable bit in the USB_n_USBINTR register is set to a one, a hardware interrupt is signaled to the system at the next interrupt threshold. If the completion is because of errors, the USBERRINT bit in the USB_n_USBSTS register is also set to a one.

42.5.3.15.1.5  Short Packet

Reception of a data packet that is less than the endpoint's Max Packet size during Control, Bulk or Interrupt transfers signals the completion of the transfer. Whenever a short packet completion occurs during a queue head execution, the USBINT bit in the USB_n_USBSTS register is set to a one.

If the USB Interrupt Enable bit is set in the USB_n_USBINTR register, a hardware interrupt is signaled to the system at the next interrupt threshold.
42.5.3.15.2 Host Controller Event Interrupts

These interrupt sources are independent of the interrupt threshold (with the one exception being the Interrupt on Async Advance, see Section Interrupt on Async Advance).

42.5.3.15.2.1 Port Change Events

Port registers contain status and status change bits. When the status change bits are set to a one, the host controller sets the Port Change Detect bit in the USBSTS register to a one.

If the Port Change Interrupt Enable bit in the USB_n_USBINTR register is a one, then the host controller will issue a hardware interrupt. The port status change bits include:

- Connect Status Change
- Port Enable/Disable Change
- Over-current Change
- Force Port Resume

42.5.3.15.2.2 Frame List Rollover

This event indicates that the host controller has wrapped the frame list. The current programmed size of the frame list effects how often this interrupt occurs.

If the frame list size is 1024, then the interrupt will occur every 1024 milliseconds, if it is 512, then it will occur every 512 milliseconds, etc. When a frame list rollover is detected, the host controller sets the Frame List Rollover bit in the USB.USBSTS register to a one. If the Frame List Rollover Enable bit in the USB.USBINTR register is set to a one, the host controller issues a hardware interrupt. This interrupt is not delayed to the next interrupt threshold.

42.5.3.15.2.3 Interrupt on Async Advance

This event is used for deterministic removal of queue heads from the asynchronous schedule. Whenever the host controller advances the on-chip context of the asynchronous schedule, it evaluates the value of the Interrupt on Async Advance Doorbell bit in the USB.USBCMD register.

If it is a one, it sets the Interrupt on Async Advance bit in the USB.USBSTS register to a one. If the Interrupt on Async Advance Enable bit in the USB.USBINTR register is a one, the host controller issues a hardware interrupt at the next interrupt threshold. A detailed explanation of this feature is described in Section Removing Queue Heads from Asynchronous Schedule.
42.5.3.15.2.4 Host System Error

The host controller is a bus master and any interaction between the host controller and the system may experience errors.

The type of host error may be catastrophic to the host controller (such as a Master Abort) making it impossible for the host controller to continue in a coherent fashion. In the presence of non-catastrophic host errors, such as parity errors, the host controller could potentially continue operation. The recommended behavior for these types of errors is to escalate it to a catastrophic error and halt the host controller. Host-based error must result in the following actions:

- The Run/Stop bit in the USB.USBCMD register is set to a zero.
- The following bits in the USB.USBSTS register are set:
  - Host System Error bit is to a one.
  - HCHalted bit is set to a one.
- If the Host System Error Enable bit in the USB.USBINTR register is a one, then the host controller will issue a hardware interrupt. This interrupt is not delayed to the next interrupt threshold. The following table summarizes the required actions taken on the various host errors.

<table>
<thead>
<tr>
<th>Cycle Type</th>
<th>Master Abort</th>
<th>Target Abort</th>
<th>Data Phase Parity</th>
</tr>
</thead>
<tbody>
<tr>
<td>Frame list pointer fetch (read)</td>
<td>Fatal</td>
<td>Fatal</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>siTD fetch (read)</td>
<td>Fatal</td>
<td>Fatal</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>siTD status write-back (write)</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>iTD fetch (read)</td>
<td>Fatal</td>
<td>Fatal</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>iTD status write-back (write)</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>qTD fetch (read)</td>
<td>Fatal</td>
<td>Fatal</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>qHD status write-back (write)</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>Data write</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
<td>Fatal [o]</td>
</tr>
<tr>
<td>Data read</td>
<td>Fatal</td>
<td>Fatal</td>
<td>Fatal [o]</td>
</tr>
</tbody>
</table>

Potentially, a host controller implementation could continue operation without a halt. However, the recommended behavior is to halt the host controller.

**NOTE**

After a Host System Error, Software must reset the host controller through HCReset in the USB.USBCMD register before re-initializing and restarting the host controller.
42.5.4 EHCI Deviation

For the purposes a dual-role Host/Device controller with support for On-The-Go applications, it is necessary to deviate from the EHCI specification. Enhanced Host Controller Interface Specification for Universal Serial Bus, Revision 0.95, November 2000, Intel Corporation. http://www.intel.com. Device operation & On-The-Go operation is not specified in the EHCI and thus the implementation supported in this core is proprietary.

The host mode operation of the core is near EHCI compatible with few minor differences documented in this section.

The particulars of the deviations occur in the areas summarized here:

- Embedded Transaction Translator - Allows direct attachment of FS and LS devices in host mode without the need for a companion controller.
- Device operation - In host mode the device operational registers are generally disabled and thus device mode is mostly transparent when in host mode. However, there are a couple exceptions documented in the following sections.
- Embedded design interface - This core does not have a PCI Interface and therefore the PCI configuration registers described in the EHCI specification are not applicable.
- On-The-Go Operation - This design includes an On-The-Go controller for Port #1.

42.5.4.1 Embedded Transaction Translator Function

The OTG controller supports directly connected full and low speed devices without requiring a companion controller by including the capabilities of a USB 2.0 high speed hub transaction translator.

Although there is no separate Transaction Translator block in the system, the transaction translator function normally associated with a high speed hub has been implemented within the DMA and Protocol engine blocks. The embedded transaction translator function is an extension to EHCI interface, but makes use of the standard data structures and operational models that exist in the EHCI specification to support full and low speed devices.

42.5.4.1.1 Capability Registers

The following additions have been added to the capability registers to support the embedded Transaction Translator Function:
42.5.4.1.2 Operational Registers

The following additions have been added to the operational registers to support the embedded TT:

- Addition of two-bit Port Speed (PSPD) to the Port Status & Control (USB_portSC1) register.

42.5.4.1.3 Discovery-EHCI Deviation

In a standard EHCI controller design, the EHCI host controller driver detects a Full speed (FS) or Low speed (LS) device by noting if the port enable bit is set after the port reset operation.

The port enable will only be set in a standard EHCI controller implementation after the port reset operation and when the host and device negotiate a High-Speed connection (that is, Chirp completes successfully).

Because this controller has an embedded Transaction Translator, the port enable will always be set after the port reset operation regardless of the result of the host device chirp result and the resulting port speed will be indicated by the PSPD field in USB.PORTSCx.

Therefore, the standard EHCI host controller driver requires an alteration to handle directly connected Full and Low speed devices or hubs.

The change is a fundamental one in that is summarized in the following table.

<table>
<thead>
<tr>
<th>Standard EHCI</th>
<th>EHCI with embedded Transaction Translator</th>
</tr>
</thead>
<tbody>
<tr>
<td>After port enable bit is set following a connection and reset sequence, the device/hub is assumed to be HS.</td>
<td>After port enable bit is set following a connection and reset sequence, the device/hub speed is noted from USB.PORTSCx.</td>
</tr>
<tr>
<td>FS and LS devices are assumed to be downstream from a HS hub thus, all port-level control is performed through the Hub Class to the nearest Hub.</td>
<td>FS and LS device can be either downstream from a HS hub or directly attached. When the FS/LS device is downstream from a HS hub, then port-level control is done using the Hub Class through the nearest Hub. When a FS/LS device is directly attached, then port-level control is accomplished using USB.PORTSCx.</td>
</tr>
<tr>
<td>FS and LS devices are assumed to be downstream from a HS hub with HubAddr=X, [where HubAddr &gt; 0 and HubAddr is the address of the Hub where the bus transitions from HS to FS/LS (ie. Split target hub)]</td>
<td>FS and LS device can be either downstream from a HS hub with HubAddr = X [HubAddr &gt; 0] or directly attached [where HubAddr = 0 and HubAddr is the address of the Root Hub where the bus transitions from HS to FS/LS (ie. Split target hub is the root hub)]</td>
</tr>
</tbody>
</table>
42.5.4.1.4 Data Structures

The same data structures used for FS/LS transactions though a HS hub are also used for transactions through the Root Hub with sm embedded Transaction Translator.

Here it is demonstrated how the Hub Address and Endpoint Speed fields should be set for directly attached FS/LS devices and hubs:

1. QH (for direct attach FS/LS) - Async. (Bulk/Control Endpoints) Periodic (Interrupt)
   • Hub Address = 0
   • Transactions to direct attached device/hub.
     • QH.EPS = Port Speed
   • Transactions to a device downstream from direct attached FS hub.
     • QH.EPS = Downstream Device Speed

   **NOTE**
   When QH.EPS = 01 (LS) and PORTSCx.PSPD = 00 (FS), a LS-pre-pid will be sent before the transmitting LS traffic.
   
   Maximum Packet Size must be less than or equal 64 or undefined behaviour may result.

2. siTD (for direct attach FS) - Periodic (ISO Endpoint)
   • All FS ISO transactions:
     • Hub Address = 0
     • siTD.EPS = 00 (full speed)
     • Maximum Packet Size must less than or equal to 1023 or undefined behaviour may result.

42.5.4.1.5 Operational Model

The operational models are well defined for the behavior of the Transaction Translator (see USB 2.0 specification, Universal Serial Bus Specification, Revision 2.0, April 2000, Compaq, Hewlett-Packard, Intel, Lucent, Microsoft, NEC, Philips. http://www.usb.org) and for the EHCI controller moving packets between system memory and a USB-HS hub. Because the embedded Transaction Translator exists within the host controller there is no physical bus between EHCI host controller driver and the USB FS/LS bus. These sections will briefly discuss the operational model for how the EHCI and Transaction Translator operational models are combined without the physical bus between. The following sections assume the reader is familiar with both the EHCI and USB 2.0 Transaction Translator operational models.
42.5.4.1.5.1 Micro-frame Pipeline

The EHCI operational model uses the concept of H-frames and B-frames to describe the pipeline between the Host (H) and the Bus (B). The embedded Transaction Translator shall use the same pipeline algorithms specified in the USB 2.0 specification for a Hub-based Transaction Translator.

All periodic transfers always begin at B-frame 0 (after SOF) and continue until the stored periodic transfers are complete. As an example of the micro-frame pipeline implemented in the embedded Transaction Translator, all periodic transfers that are tagged in EHCI to execute in H-frame 0 will be ready to execute on the bus in B-frame 0.

It is important to note that when programming the S-mask and C-masks in the EHCI data structures to schedule periodic transfers for the embedded Transaction Translator, the EHCI host controller driver must follow the same rules specified in EHCI for programming the S-mask and C-mask for downstream Hub-based Transaction Translators.

Once periodic transfers are exhausted, any stored asynchronous transfer will be moved. Asynchronous transfers are opportunistic in that they shall execute whenever possible and their operation is not tied to H-frame and B-frame boundaries with the exception that an asynchronous transfer can not babble through the SOF (start of B-frame 0.)

42.5.4.1.5.2 Split State Machines

The start and complete split operational model differs from EHCI slightly because there is no bus medium between the EHCI controller and the embedded Transaction Translator.

Where a start or complete-split operation would occur by requesting the split to the HS hub, the start/complete split operation is simple an internal operation to the embedded Transaction Translator. The following table summarizes the conditions where handshakes are emulated from internal state instead of actual handshakes to HS split bus traffic.

<table>
<thead>
<tr>
<th>Condition</th>
<th>Emulate TT Response</th>
</tr>
</thead>
<tbody>
<tr>
<td>Start-Split: All asynchronous buffers full.</td>
<td>NAK</td>
</tr>
<tr>
<td>Start-Split: All periodic buffers full.</td>
<td>ERR</td>
</tr>
<tr>
<td>Start-Split: Success for start of Async. Transaction.</td>
<td>ACK</td>
</tr>
<tr>
<td>Start-Split: Start Periodic Transaction.</td>
<td>No Handshake (Ok)</td>
</tr>
<tr>
<td>Complete-Split: Failed to find transaction in queue.</td>
<td>Bus Time Out</td>
</tr>
<tr>
<td>Complete-Split: Transaction in Queue is Busy.</td>
<td>NYET</td>
</tr>
<tr>
<td>Complete-Split: Transaction in Queue is Complete.</td>
<td>[Actual Handshake from LS/FS device]</td>
</tr>
</tbody>
</table>
1. The un-shaded cells represent Start-Splits and the shaded cells represent Complete-Splits

### 42.5.4.1.5.3 Asynchronous Transaction Scheduling and Buffer Management

The following USB 2.0 specification items are implemented in the embedded Transaction Translator:

- Sequencing is provided & a packet length estimator ensures no full-speed/low-speed packet babbles into SOF time.
- Transaction tracking for 2 data pipes.

#### 42.5.4.1.5.3.1 USB 2.0 - 11.17.3

- Sequencing is provided & a packet length estimator ensures no full-speed/low-speed packet babbles into SOF time.

#### 42.5.4.1.5.3.2 USB 2.0 - 11.17.4

- Transaction tracking for 2 data pipes.

### 42.5.4.1.5.4 Periodic Transaction Scheduling and Buffer Management

The following USB 2.0 specification items are implemented in the embedded Transaction Translator:

- Abort of pending start-splits
  - EOF (and not started in micro-frames 6)
  - Idle for more than 4 micro-frames
- Abort of pending complete-splits
  - EOF
  - Idle for more than 4 micro-frames
- Transaction tracking for up to 16 data pipes.
- Complete-split transaction searching.

**NOTE**

There is no data schedule mechanism for these transactions other than the micro-frame pipeline. The embedded TT assumes the number of packets scheduled in a frame does not exceed the frame duration (1 ms) or else undefined behavior may result.

#### 42.5.4.1.5.4.1 USB 2.0 - 11.18.6.[1-2]

- Abort of pending start-splits
  - EOF (and not started in micro-frames 6)
  - Idle for more than 4 micro-frames
- Abort of pending complete-splits
• EOF
• Idle for more than 4 micro-frames

42.5.4.1.5.4.2 USB 2.0 - 11.18.[7-8]
• Transaction tracking for up to 16 data pipes.
• Complete-split transaction searching.

**NOTE**
There is no data schedule mechanism for these transactions other than the micro-frame pipeline. The embedded TT assumes the number of packets scheduled in a frame does not exceed the frame duration (1 ms) or else undefined behavior may result.

42.5.4.1.5.5 Multiple Transaction Translators

The maximum number of embedded Transaction Translators that is currently supported is one as indicated by the N_TT field in the Host Controller Structural Parameters (USB_nHCSPARAMS) register.

42.5.4.2 Device Operation

The co-existence of a device operational controller within the host controller has little effect on EHCI compatibility for host operation except as noted in this section.

42.5.4.2.1 USB_USBMODE Register

Given that the dual-role controller is initialized in neither host nor device mode, the USB Device Mode (USB_nUSBMODE) register must be programmed for host operation before the EHCI host controller driver can begin EHCI host operations.

42.5.4.2.2 Non-Zero Fields the Register File

Some of the reserved fields and reserved addresses in the capability registers and operational register have use in device mode, the following must be adhered to:

• Write operations to all EHCI reserved fields (some of which are device fields) with the operation registers should always be written to zero. This is an EHCI requirement of the device controller driver that must be adhered to.
• Read operations by the host controller must properly mask EHCI reserved fields (some of which are device fields) because fields that are used exclusive for device are undefined in host mode.
42.5.4.2.3  **SOF Interrupt**

This SOF Interrupt used for device mode is shared as a free running 125us interrupt for host mode.

EHCI does not specify this interrupt but it has been added for convenience and as a potential software time base. See USB Status Register (USB\_nUSBSTS) and Interrupt Enable Register (USB\_nUSBINTR) registers.

42.5.4.3  **Embedded Design Interface**

This is an Embedded USB Host Controller as defined by the EHCI specification and thus does not implement the PCI configuration registers.

42.5.4.3.1  **Frame Adjust Register**

Given that the optional PCI configuration registers are not included in this implementation, there is no corresponding bit level timing adjustments like is provided by the Frame Adjust register in the PCI configuration registers. Starts of micro-frames are timed precisely to 125 us using the transceiver clock as a reference clock. That is, a 60 Mhz transceiver clock for 8-bit physical interfaces & full-speed serial interfaces or 30 Mhz transceiver clock for 16-bit physical interfaces.

42.5.4.4  **Miscellaneous variations from EHCI**

42.5.4.4.1  **Programmable Physical Interface Behaviour**

This design supports multiple Physical interfaces which can operate in differing modes when the core is configured with software programmable Physical Interface Modes. Software programmability allows the selection of the Physical interface part during the board design phase instead of during the chip design phase. The control bits for selecting the Physical Interface operating mode have been added to the Port Status & Control (USB\_nPORTSC1) register providing a capability that is not defined by EHCI.

42.5.4.4.2  **Discovery**
42.5.4.4.2.1 Port Reset

The port connect methods specified by EHCI require setting the port reset bit in the Port Status & Control (USB_nPORTSC1) register for a duration of 10ms. Due to the complexity required to support the attachment of devices that are not high speed there are counter already present in the design that can count the 10ms reset pulse to alleviate the requirement of the software to measure this duration. Therefore, the basic connection is then summarized as the following:

• [Port Change Interrupt] Port connect change occurs to notify the host controller driver that a device has attached.
• Software shall write a '1' to reset the device.
• Software shall write a '0' to reset the device after 10 ms.
  • This step, which is necessary in a standard EHCI design, may be omitted with this implementation. Should the EHCI host controller driver attempt to write a '0' to the reset bit while a reset is in progress, the write will simple be ignored and the reset will continue until completion.
• [Port Change Interrupt] Port enable change occurs to notify the host controller that the device in now operational and at this point the port speed has been determined.

42.5.4.4.2.2 Port Speed Detection

After the port change interrupt indicates that a port is enabled, the EHCI stack should determine the port speed. Unlike the EHCI implementation, which will re-assign the port owner for any device that does not connect at High-Speed, this host controller supports direct attach of non High-Speed devices.

Therefore, the following differences are important regarding port speed detection:

• Port Owner is read-only and always reads 0.
• A 2-bit Port Speed indicator has been added to PORTSC to provide the current operating speed of the port to the host controller driver.
• A 1-bit High Speed indicator has been added to PORTSC to signify that the port is in High-Speed vs. Full/Low Speed - This information is redundant with the 2-bit Port Speed indicator above.

42.5.4.4.3 Port Test Mode

Port Test Control mode behaves fully as described in EHCI. An alternate host controller driver procedure is not necessary or supported.
42.5.5 Device Data Structures

This section defines the interface data structures used to communicate control, status, and data between Device Controller Driver (DCD) Software and the Device Controller.

The data structure definitions in this chapter support a 32-bit memory buffer address space. The interface consists of device Queue Heads and Transfer Descriptors.

**NOTE**
Software must ensure that no interface data structure reachable by the Device Controller spans a 4K-page boundary.

The data structures defined in the chapter are (from the device controller's perspective) a mix of read-only and read/writable fields. The device controller must preserve the read-only fields on all data structure writes.

The figure below shows the organization of the EndPoint Queue Head.

![Figure 42-27. EndPoint Queue Head Organization](image)

Endpoint queue heads are arranged in an array in a continuous area of memory pointed to by the USB.ENDPOINTLISTADDR pointer. The even-numbered device queue heads in the list support receive endpoints (OUT/SETUP) and the odd-numbered queue heads in the list are used for transmit endpoints (IN/INTERRUPT). The device controller will index into this array based upon the endpoint number received from the USB bus. All information necessary to respond to transactions for all primed transfers is contained in this list so the Device Controller can readily respond to incoming requests without having to traverse a linked list.
## NOTE
The Endpoint Queue Head List must be aligned to a 2k boundary.

### 42.5.5.1 Endpoint Queue Head (dQH)

The device Endpoint Queue Head (dQH) is where all transfers for a given endpoint are managed. The dQH is a 48-byte data structure, but must be aligned on 64-byte boundaries.

During priming of an endpoint, the dTD (device transfer descriptor) is copied into the overlay area of the dQH, which starts at the nextTD pointer DWord and continues through the end of the buffer pointers DWords. After a transfer is complete, the dTD status DWord is updated in the dTD pointed to by the currentTD pointer. While a packet is in progress, the overlay area of the dQH is used as a staging area for the dTD so that the Device Controller can access needed information with little minimal latency.

#### Table 42-57. Endpoint Queue Head (dQH)

| Bit 31 | Bit 30 | Bit 29 | Bit 28 | Bit 27 | Bit 26 | Bit 25 | Bit 24 | Bit 23 | Bit 22 | Bit 21 | Bit 20 | Bit 19 | Bit 18 | Bit 17 | Bit 16 | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| Mult   | zlt    | 0      | Maximum Packet Length | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

<table>
<thead>
<tr>
<th>Current dTD Pointer</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Next dTD Pointer</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>Total Bytes</td>
</tr>
<tr>
<td>0</td>
<td>Current Offset</td>
</tr>
<tr>
<td>Buffer Pointer (Page 0)</td>
<td>Reserved</td>
</tr>
<tr>
<td>Buffer Pointer (Page 1)</td>
<td>Reserved</td>
</tr>
<tr>
<td>Buffer Pointer (Page 2)</td>
<td>Reserved</td>
</tr>
<tr>
<td>Buffer Pointer (Page 3)</td>
<td>Reserved</td>
</tr>
<tr>
<td>Buffer Pointer (Page 4)</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>1</td>
</tr>
<tr>
<td>Set-up Buffer Bytes 3…0</td>
<td>0</td>
</tr>
<tr>
<td>Set-up Buffer Bytes 7…4</td>
<td>0</td>
</tr>
</tbody>
</table>

1. Transfer overlay starts at T and continues through Buffer Pointer (Page 4).
42.5.5.1.1 Endpoint Capabilities/Characteristics

This DWord specifies static information about the endpoint, in other words, this information does not change over the lifetime of the endpoint. Device Controller software should not attempt to modify this information while the corresponding endpoint is enabled.

Table 42-58 describes the endpoint capabilities.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Mult. This field is used to indicate the number of packets executed per transaction description as given by the following:</td>
</tr>
<tr>
<td></td>
<td>00 - Execute N Transactions as demonstrated by the USB variable length packet protocol where N is computed using the Maximum Packet Length (dQH) and the Total Bytes field (dTD)</td>
</tr>
<tr>
<td></td>
<td>01 Execute 1 Transaction. 10 Execute 2 Transactions. 11 Execute 3 Transactions.</td>
</tr>
<tr>
<td></td>
<td>NOTE: Non-ISO endpoints must set Mult=&quot;00&quot;. ISO endpoints must set Mult=&quot;01&quot;, &quot;10&quot;, or &quot;11&quot; as needed.</td>
</tr>
<tr>
<td>29</td>
<td>Zero Length Termination Select. This bit is used to indicate when a zero length packet is used to terminate transfers where to total transfer length is a multiple.</td>
</tr>
<tr>
<td></td>
<td>0 - Enable zero length packet to terminate transfers equal to a multiple of the Maximum Packet Length. (default).</td>
</tr>
<tr>
<td></td>
<td>1 - Disable the zero length packet on transfers that are equal in length to a multiple Maximum Packet Length.</td>
</tr>
<tr>
<td>28-27</td>
<td>Reserved. These bit reserved for future use and should be set to zero.</td>
</tr>
<tr>
<td>26-16</td>
<td>Maximum Packet Length. This directly corresponds to the maximum packet size of the associated endpoint (wMaxPacketSize).</td>
</tr>
<tr>
<td></td>
<td>The maximum value this field may contain is 0x400 (1024).</td>
</tr>
<tr>
<td>15</td>
<td>Interrupt On Setup (IOS). This bit is used on control type endpoints to indicate if USBINT is set in response to a setup being received.</td>
</tr>
<tr>
<td>14-0</td>
<td>Reserved. Bits reserved for future use and should be set to zero.</td>
</tr>
</tbody>
</table>

42.5.5.1.2 Transfer Overlay-Endpoint Queue Head

The seven DWords in the overlay area represent a transaction working space for the device controller.

The general operational model is that the device controller can detect whether the overlay area contains a description of an active transfer. If it does not contain an active transfer, then it will not read the associated endpoint.

After an endpoint is readied, the dTD will be copied into this queue head overlay area by the device controller. Until a transfer is expired, software must not write the queue head overlay area or the associated transfer descriptor. When the transfer is complete, the device controller will write the results back to the original transfer descriptor and advance the queue.
See dTD for a description of the overlay fields.

### 42.5.5.1.3 Current dTD Pointer

The current dTD pointer is used by the device controller to locate the transfer in progress. This word is for Device Controller (hardware) use only and should not be modified by DCD software.

The following table describes the dTD Pointer.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Current dTD. This field is a pointer to the dTD that is represented in the transfer overlay area. This field will be modified by the Device Controller to next dTD pointer during endpoint priming or queue advance.</td>
</tr>
<tr>
<td>4-0</td>
<td>Reserved. Bit reserved for future use and should be set to zero.</td>
</tr>
</tbody>
</table>

### 42.5.5.1.4 Set-up Buffer

The set-up buffer is dedicated storage for the 8-byte data that follows a set-up PID.

**NOTE**

Each endpoint has a TX and an RX dQH associated with it, and only the RX queue head is used for receiving setup data packets.

The following table describes the Multiple Mode Control.

<table>
<thead>
<tr>
<th>DWord</th>
<th>Bits</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>31-0</td>
<td>Setup Buffer 0. This buffer contains bytes 3 to 0 of an incoming setup buffer packet and is written by the device controller to be read by software.</td>
</tr>
<tr>
<td>2</td>
<td>31-0</td>
<td>Setup Buffer 1. This buffer contains bytes 7 to 4 of an incoming setup buffer packet and is written by the device controller to be read by software.</td>
</tr>
</tbody>
</table>

### 42.5.5.2 Endpoint Transfer Descriptor (dTD)

The dTD describes to the device controller the location and quantity of data to be sent/received for a given transfer.

The DCD should not attempt to modify any field in an active dTD except the Next Like Pointer, which should only be modified as described in section Managing Transfers with Transfer Descriptors.
Table below shows the Endpoint Transfer Descriptor (dTD).

**Table 42-61. Endpoint Transfer Descriptor (dTD)**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Next Link Pointer</td>
</tr>
<tr>
<td>7-0</td>
<td>Total Bytes</td>
</tr>
<tr>
<td>ioc</td>
<td>Current Offset</td>
</tr>
<tr>
<td>0</td>
<td>Status</td>
</tr>
<tr>
<td></td>
<td>Buffer Pointer (Page 0)</td>
</tr>
<tr>
<td></td>
<td>Buffer Pointer (Page 1)</td>
</tr>
<tr>
<td></td>
<td>Frame Number</td>
</tr>
<tr>
<td></td>
<td>Buffer Pointer (Page 2)</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>Buffer Pointer (Page 3)</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>Buffer Pointer (Page 4)</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The following table describes the dTD Pointer.

**Table 42-62. Next dTD Pointer**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-5</td>
<td>Next Transfer Element Pointer. This field contains the physical memory address of the next dTD to be processed. The field corresponds to memory address signals [31:5], respectively.</td>
</tr>
<tr>
<td>4-1</td>
<td>Reserved. Bits reserved for future use and should be set to zero.</td>
</tr>
<tr>
<td>0</td>
<td>Terminate (T). 1=pointer is invalid. 0=Pointer is valid (points to a valid Transfer Element Descriptor). This bit indicates to the Device Controller that there are no more valid entries in the queue.</td>
</tr>
</tbody>
</table>

The following table describes the dTD Token.

**Table 42-63. dTD Token**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved. Bit reserved for future use and should be set to zero.</td>
</tr>
<tr>
<td>30-16</td>
<td>Total Bytes. This field specifies the total number of bytes to be moved with this transfer descriptor. This field is decremented by the number of bytes actually moved during the transaction and only on the successful completion of the transaction. The maximum value software may store in the field is 5*4K (5000H). This is the maximum number of bytes 5 page pointers can access. Although it is possible to create a transfer up to 20K this assumes the 1st offset into the first page is 0. When the offset cannot be predetermined, crossing past the 5th page can be guaranteed by limiting the total bytes to 16K**. Therefore, the maximum recommended transfer is 16K (4000H). If the value of the field is zero when the host controller fetches this transfer descriptor (and the active bit is set), the device controller executes a zero-length transaction and retires the transfer descriptor.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 42-63. dTD Token (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Interrupt On Complete (IOC). This bit is used to indicate if USBINT is to be set in response to device controller being finished with this dTD.</td>
</tr>
<tr>
<td>14-12</td>
<td>Reserved. Bits reserved for future use and should be set to zero.</td>
</tr>
<tr>
<td>11-10</td>
<td>Multiplier Override (MultO). This field can be used for transmit ISO's (ie. ISO-IN) to override the multiplier in the QH. This field must be zero for all packet types that are not transmit-ISO. Example: if QH.multiplier = 3; Maximum packet size = 8; Total Bytes = 15; MultO = 0 [default] Three packets are sent: {Data2(8); Data1(7); Data0(0)} if QH.multiplier = 3; Maximum packet size = 8; Total Bytes = 15; MultO = 2 Two packets are sent: {Data1(8); Data0(7)} For maximal efficiency, software should compute MultO = greatest integer of (Total Bytes / Max. Packet Size) except for the case when Total Bytes = 0; then MultO should be 1. Note: Non-ISO and Non-TX endpoints must set MultO = &quot;00&quot;.</td>
</tr>
<tr>
<td>9-8</td>
<td>Reserved. Bits reserved for future use and should be set to zero.</td>
</tr>
<tr>
<td>7-0</td>
<td>Status. This field is used by the Device Controller to communicate individual command execution states back to the Device Controller software. This field contains the status of the last transaction performed on this qTD. The bit encodings are: Bit Status Field Description 7 Active. 6 Halted. 5 Data Buffer Error. 3 Transaction Error. 4, 2, 0 Reserved.</td>
</tr>
</tbody>
</table>

The table below describes the dTD Buffer Page Pointer List.

Table 42-64. dTD Buffer Page Pointer List

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-12</td>
<td>Buffer Pointer. Selects the page offset in memory for the packet buffer. Non virtual memory systems will typically set the buffer pointers to a series of incrementing integers.</td>
</tr>
<tr>
<td>0,11-0</td>
<td>Current Offset. Offset into the 4kb buffer where the packet is to begin.</td>
</tr>
<tr>
<td>1,10-0</td>
<td>Frame Number. Written by the device controller to indicate the frame number in which a packet finishes. This is typically be used to correlate relative completion times of packets on an ISO endpoint.</td>
</tr>
</tbody>
</table>

42.5.6 Device Operational Model

The function of the device operation is to transfer a request in the memory image to and from the Universal Serial Bus.
Using a set of linked list transfer descriptors, pointed to by a queue head, the device controller will perform the data transfers. The following sections explain the use of the device controller from the device controller driver (DCD) point-of-view and further describe how specific USB bus events relate to status changes in the device controller programmer's interface.

### 42.5.6.1 Device Controller Initialization

After hardware reset, the device is disabled until the Run/Stop bit is set to a '1'. In the disabled state, the pull-up on the USB D+ is not active which prevents an attach event from occurring. At a minimum, it is necessary to have the queue heads setup for endpoint zero before the device attach occurs.

Shortly after the device is enabled, a USB reset will occur followed by setup packet arriving at endpoint 0. A Queue head must be prepared so that the device controller can store the incoming setup packet.

In order to initialize a device, the software should perform the following steps:

- Set Controller Mode in the USB.USBMODE register to device mode.
  
  **NOTE**
  Transitioning from host mode to device mode requires a device controller reset before modifying USB.USBMODE.

- Allocate and Initialize device queue heads in system memory.
  - Minimum: Initialize device queue heads 0 Tx & 0 Rx.

  **NOTE**
  All device queue heads for control endpoints must be initialized before the endpoint is enabled. Non-Control device queue heads before the endpoint can be used.

  - For information on device queue heads, refer to section Device Data Structures.
  - Configure USB.ENDPOINTLISTADDR Pointer.
    - For additional information on USB.ENDPOINTLISTADDR, refer to the register table.
  - Enable the microprocessor interrupt associated with the USB core.
    - Recommended: enable all device interrupts including: USBINT, USBERRINT, Port Change Detect, USB Reset Received, DCSuspend.
    - For a list of available interrupts refer to the Interrupt Enable Register (USB_nUSBINTR) and the USB Status Register (USB_nUSBSTS) register tables.
  - Set Run/Stop bit to Run Mode.
After the Run bit is set and the device is connected to a host, a Bus Reset will be issued by host downstream port. The DCD must monitor the reset event and adjust the software state as described in the Bus Reset section of the Port State and Control section below.

**NOTE**

Endpoint 0 is designed as a control endpoint only and does not need to be configured using ENDPTCTRL0 register.

It is also not necessary to prime Endpoint 0 initially because the first packet received will always be a setup packet. The contents of the first setup packet will require a response in accordance with USB device framework (Chapter 9) command set.

### 42.5.6.2 Port State and Control

From a chip or system reset, the device controller enters the *powered* state. A transition from the *powered* state to the *attach* state occurs when the Run/Stop bit is set to a '1'.

After receiving a reset on the bus, the port will enter the *defaultFS* or *defaultHS* state in accordance with the reset protocol described in Appendix C.2 of the USB Specification Rev. 2.0.

The following state diagram depicts the state of a USB 2.0 device.
States *powered, attach, defaultFS/HS, suspendFS/HS* are implemented in the device controller and are communicated to the DCD using the following status bits:

The following table describes the Device Controller State Information Bits.

**Table 42-65. Device Controller State Information Bits**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Register</th>
</tr>
</thead>
<tbody>
<tr>
<td>DCSuspend</td>
<td>USB Status Register (USB_nUSBSTS)</td>
</tr>
<tr>
<td>USB Reset Received</td>
<td>USB Status Register (USB_nUSBSTS)</td>
</tr>
<tr>
<td>Port Change Detect</td>
<td>USB Status Register (USB_nUSBSTS)</td>
</tr>
<tr>
<td>High-Speed Port</td>
<td>Port Status &amp; Control (USB_nPORTSC1)</td>
</tr>
</tbody>
</table>

**Figure 42-28. Device State Diagram**

When the host resets the device returns to the default state.
It is the responsibility of the DCD to maintain a state variable to differentiate between the DefaultFS/HS state and the Address/Configured states. Change of state from Default to Address and the Configured states is part of the enumeration process described in the device framework section of the USB 2.0 Specification.

As a result of entering the Address state, the device address register (DEVICEADDR) must be programmed by the DCD.

Entry into the Configured indicates that all endpoints to be used in the operation of the device have been properly initialized by programming the USB_UOG_ENDPTCTRLx registers and initializing the associated queue heads.

### 42.5.6.2.1 Bus Reset

A bus reset is used by the host to initialize downstream devices.

When a bus reset is detected, the device controller will renegotiate its attachment speed, reset the device address to 0, and notify the DCD by interrupt (assuming the USB Reset Interrupt Enable is set). After a reset is received, all endpoints (except endpoint 0) are disabled and any primed transactions will be cancelled by the device controller. The concept of priming will be clarified below, but the DCD must perform the following tasks when a reset is received:

Clear all setup token semaphores by reading the Endpoint Status (USB_{n}ENDPTSTAT) register and writing the same value back to the Endpoint Status (USB_{n}ENDPTSTAT) register.

Clear all the endpoint complete status bits by reading the Endpoint Complete (USB_{n}ENDPTCOMPLETE) register and writing the same value back to the Endpoint Complete (USB_{n}ENDPTCOMPLETE) register.

Cancel all primed status by waiting until all bits in the Endpoint Prime (USB_{n}ENDPTPRIME) are 0 and then writing 0xFFFFFFFF to Endpoint Flush (USB_{n}ENDPTFLUSH).

Read the reset bit in the Port Status & Control (USB_{n}PORTSC1) register and make sure that it is still active. A USB reset will occur for a minimum of 3 ms and the DCD must reach this point in the reset cleanup before end of the reset occurs, otherwise a hardware reset of the device controller is recommended (rare.)

- A hardware reset can be performed by writing a one to the device controller reset bit in the USBCMD reset. Note: a hardware reset will cause the device to detach from the bus by clearing the Run/Stop bit. Thus, the DCD must completely re-initialize the device controller after a hardware reset.
Free all allocated dTDs because they will no longer be executed by the device controller. If this is the first time the DCD is processing a USB reset event, then it is likely that no dTDs have been allocated.

At this time, the DCD may release control back to the OS because no further changes to the device controller are permitted until a Port Change Detect is indicated.

After a Port Change Detect, the device has reached the default state and the DCD can read the Port Status & Control (USB_nPORTSC1) to determine if the device is operating in FS or HS mode. At this time, the device controller has reached normal operating mode and DCD can begin enumeration according to the USB Chapter 9 - Device Framework.

**NOTE**
The device DCD may use the FS/HS mode information to determine the bandwidth mode of the device.

In some applications, it may not be possible to enable one or more pipes while in FS mode. *Beyond the data rate issue, there is no difference in DCD operation between FS and HS modes.*

### 42.5.6.2.2 Suspend/Resume

The details of suspend and resume are explained in these sections.

#### 42.5.6.2.2.1 Suspend

**Suspend Description**

In order to conserve power, USB devices automatically enter the suspended state when the device has observed no bus traffic for a specified period. When suspended, the USB device maintains any internal status, including its address and configuration. Attached devices must be prepared to suspend at any time they are powered, regardless of if they have been assigned a non-default address, are configured, or neither. Bus activity may cease due to the host entering a suspend mode of its own. In addition, a USB device shall also enter the suspended state when the hub port it is attached to is disabled.

A USB device exits suspend mode when there is bus activity. A USB device may also request the host to exit suspend mode or selective suspend by using electrical signaling to indicate remote wakeup. The ability of a device to signal remote wakeup is optional. If the USB device is capable of remote wakeup signaling, the device must support the ability of the host to enable and disable this capability. When the device is reset, remote wakeup signaling must be disabled.

**Suspend Operational Model**
The device controller moves into the suspend state when suspend signaling is detected or activity is missing on the upstream port for more than a specific period. After the device controller enters the suspend state, the DCD is notified by an interrupt (assuming DC Suspend Interrupt is enabled). When the DCSuspend bit in the Port Status & Control (USB_nPORTSC1) is set to a '1', the device controller is suspended.

DCD response when the device controller is suspended is application specific and may involve switching to low power operation.

Information on the bus power limits in suspend state can be found in USB 2.0 specification.

**NOTE**
Review system level clocking issues defined in section (Ref: Signals-Clocking) for the clocking requirements of a suspended device controller.

### 42.5.6.2.2 Resume

If the device controller is suspended, its operation is resumed when any non-idle signaling is received on its upstream facing port. In addition, the device can signal the system to resume operation by forcing resume signaling to the upstream port.

Resume signaling is sent upstream by writing a '1' to the Resume bit in the Port Status & Control (USB_nPORTSC1) while the device is in suspend state. Sending resume signal to an upstream port should cause the host to issue resume signaling and bring the suspended bus segment (one more devices) back to the active condition.

**NOTE**
Before resume signaling can be used, the host must enable it by using the Set Feature command defined in device framework (chapter 9) of the USB 2.0 Specification.

### 42.5.6.3 Managing Endpoints

The USB 2.0 specification defines an endpoint, also called a device endpoint or an address endpoint as a uniquely addressable portion of a USB device that can source or sink data in a communications channel between the host and the device.

The endpoint address is specified by the combination of the endpoint number and the endpoint direction.
The channel between the host and an endpoint at a specific device represents a data pipe. Endpoint 0 for a device is always a control type data channel used for device discovery and enumeration. Other types of endpoints support by USB include bulk, interrupt, and isochronous. Each endpoint type has specific behavior related to packet response and error handling. More detail on endpoint operation can be found in the USB 2.0 specification.

The USB OTG device controller hardware supports up to 8 endpoint numbers. Each endpoint direction is essentially independent and can be configured with differing behavior in each direction. For example, the DCD can configure endpoint 1-IN to be a bulk endpoint and endpoint 1-OUT to be an isochronous endpoint. This helps to conserve the total number of endpoints required for device operation. The only exception is that control endpoints must use both directions on a single endpoint number to function as a control endpoint. Endpoint 0 is, for example, is always a control endpoint and uses the pair of directions.

Each endpoint direction requires a queue head allocated in memory. To support the 8 endpoint numbers, 16 queue heads are required. The operation of an endpoint and use of queue heads are described later in this document.

### 42.5.6.3.1 Endpoint Initialization

After hardware reset, all endpoints except endpoint zero are uninitialized and disabled. The DCD must configure and enable each endpoint by writing to configuration bit in the USB_UOG_ENDPTCTRLx register.

Each 32-bit USB_UOG_ENDPTCTRLx is split into an upper and lower half. The lower half of USB_UOG_ENDPTCTRLx is used to configure the receive or OUT endpoint and the upper half is likewise used to configure the corresponding transmit or IN endpoint. Control endpoints must be configured the same in both the upper and lower half of the USB_UOG_ENDPTCTRLx register otherwise the behavior is undefined. The following table shows how to construct a configuration word for endpoint initialization. The following table shows the fields and values for the Device Controller Endpoint initialization.

<table>
<thead>
<tr>
<th>Field</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Data Toggle Reset</td>
<td>1</td>
</tr>
<tr>
<td>Data Toggle Inhibit</td>
<td>0</td>
</tr>
<tr>
<td>Endpoint Type</td>
<td>00 Control</td>
</tr>
<tr>
<td></td>
<td>01 Isochronous</td>
</tr>
<tr>
<td></td>
<td>10 Bulk</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Stalling

There are two occasions where the device controller may need to return to the host a STALL.

The first occasion is the functional stall, which is a condition set by the DCD as described in the USB 2.0 device framework. A functional stall is only used on non-control endpoints and can be enabled in the device controller by setting the endpoint stall bit in the USB_UOG_ENDPTCTRLx register associated with the given endpoint and the given direction. In a functional stall condition, the device controller will continue to return STALL responses to all transactions occurring on the respective endpoint and direction until the endpoint stall bit is cleared by the DCD.

A protocol stall, unlike a function stall, is used on control endpoints is automatically cleared by the device controller at the start of a new control transaction (setup phase). When enabling a protocol stall, the DCD should enable the stall bits (both directions) as a pair. A single write to the USB_UOG_ENDPTCTRLx register can ensure that both stall bits are set at the same instant.

**NOTE**

Any write to the USB_UOG_ENDPTCTRLx register during operational mode must preserve the endpoint type field (that is, perform a read-modify-write).

The following table shows the response matrix for the Device Controller Stall.

#### Table 42-67. Device Controller Stall Response Matrix

<table>
<thead>
<tr>
<th>USB Packet</th>
<th>Endpoint Stall Bit.</th>
<th>Effect on STALL bit.</th>
<th>USB Response</th>
</tr>
</thead>
<tbody>
<tr>
<td>SETUP packet received by a non-control endpoint.</td>
<td>N/A</td>
<td>None.</td>
<td>STALL</td>
</tr>
<tr>
<td>IN/OUT/PING packet received by a non-control endpoint.</td>
<td>'1'</td>
<td>None.</td>
<td>STALL</td>
</tr>
<tr>
<td>IN/OUT/PING packet received by a non-control endpoint.</td>
<td>'0'</td>
<td>None.</td>
<td>ACK/NAK/NYET</td>
</tr>
<tr>
<td>SETUP packet received by a control endpoint.</td>
<td>N/A</td>
<td>Cleared</td>
<td>ACK</td>
</tr>
<tr>
<td>IN/OUT/PING packet received by a control endpoint</td>
<td>'1'</td>
<td>None</td>
<td>STALL</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 42.5.6.3.3 Data Toggle

Data toggle is a mechanism to maintain data coherency between host and device for any given data pipe.

For more information on data toggle, refer to the USB 2.0 specification.

#### 42.5.6.3.3.1 Data Toggle Reset

The DCD may reset the data toggle state bit and cause the data toggle sequence to reset in the device controller by writing a '1' to the data toggle reset bit in the USB_UOG_ENDPTCTRLx register.

This should only be necessary when configuring/initializing an endpoint or returning from a STALL condition.

#### 42.5.6.3.3.2 Data Toggle Inhibit

**NOTE**

This feature is for test purposes only and should never be used during normal device controller operation.

Setting the *data toggle Inhibit bit* active ('1') causes the device controller to ignore the data toggle pattern that is normally sent and accept all incoming data packets regardless of the data toggle state.

In normal operation, the device controller checks the DATA0/DATA1 bit against the data toggle to determine if the packet is valid. If Data PID does not match the data toggle state bit maintained by the device controller for that endpoint, the Data toggle is considered not valid. If the data toggle is not valid, the device controller assumes the packet was already received and discards the packet (not reporting it to the DCD). To prevent the host controller from re-sending the same packet, the device controller will respond to the error packet by acknowledging it with either an ACK or NYET response.

#### 42.5.6.3.3.3 Priming Transmit Endpoints

Priming a transmit endpoint will cause the device controller to fetch the device transfer descriptor (dTD) for the transaction pointed to by the device queue head (dQH).

---

**Table 42-67. Device Controller Stall Response Matrix (continued)**

<table>
<thead>
<tr>
<th>IN/OUT/PING packet received by a control endpoint.</th>
<th>'0'</th>
<th>None.</th>
<th>ACK/NAK/NYET</th>
</tr>
</thead>
</table>

---

*Chapter 42 Universal Serial Bus Controller (USB)*

NXP Semiconductors

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
After the dTD is fetched, it will be stored in the dQH until the device controller completes the transfer described by the dTD. Storing the dTD in the dQH allows the device controller to fetch the operating context needed to handle a request from the host without the need to follow the linked list, starting at the dQH when the host request is received.

After the device has loaded the dTD, the leading data in the packet is stored in a FIFO in the device controller. This FIFO is split into virtual channels so that the leading data can be stored for any endpoint up to the maximum number of endpoints configured at device synthesis time.

After a priming request is complete, an endpoint state of primed is indicated in the USB_UOG_ENDPTSTATUS register. For a primed transmit endpoint, the device controller can respond to an IN request from the host and meet the stringent bus turnaround time of High Speed USB.

Because only the leading data is stored in the device controller FIFO, it is necessary for the device controller to begin filling in behind leading data after the transaction starts. The FIFO must be sized to account for the maximum latency that can be incurred by the system memory bus. More information about FIFO sizing is presented in section 42.5.6.3.3.4

### 42.5.6.3.3.4 Priming Receive Endpoints

Priming receive endpoints is identical to priming of transmit endpoints from the point of view of the DCD. At the device controller the major difference in the operational model is that there is no data movement of the leading packet data simply because the data is to be received from the host.

Note as part of the architecture, the FIFO for the receive endpoints is not partitioned into multiple channels like the transmit FIFO. Thus, the size of the RX FIFO does not scale with the number of endpoints.

### 42.5.6.4 Operational Model For Packet Transfers

All transactions on the USB bus are initiated by the host and in turn, the device must respond to any request from the host within the turnaround time stated in the USB 2.0 Specification.

At USB 1.1 Full or Low Speed rates, this turnaround time was significant and the USB 1.1 device controllers were architected so that the device controller could access main memory or interrupt a host protocol processor in order to respond to the USB 1.1
transaction. The architecture of the USB 2.0 device controller must be different because same methods will not meet USB 2.0 High-speed turnaround time requirements by simply increasing clock rate.

A USB host will send requests to the device controller in an order that can not be precisely predicted as a single pipeline, so it is not possible to prepare a single packet for the device controller to execute. However, the order of packet requests is predictable when the endpoint number and direction is considered. For example, if endpoint 3 (transmit direction) is configured as a bulk pipe, then we can expect the host will send IN requests to that endpoint. This device controller is architected in such a way that it can prepare packets for each endpoint/direction in anticipation of the host request. The process of preparing the device controller to send or receive data in response to host initiated transaction on the bus is referred to as "priming" the endpoint. This term will be used throughout the following documentation to describe the device controller operation so the DCD can be architected properly use priming. Further, note that the term "flushing" is used to describe the action of clearing a packet that was queued for execution.

42.5.6.4.1 Interrupt/Bulk Endpoint Operational Model

The behaviors of the device controller for interrupt and bulk endpoints are identical. All valid IN and OUT transactions to bulk pipes will handshake with a NAK unless the endpoint had been primed. Once the endpoint has been primed, data delivery will commence.

A dTD will be retired by the device controller when the packets described in the transfer descriptor have been completed. Each dTD describes N packets to be transferred according to the USB Variable Length transfer protocol. The formula and table on the following page describe how the device controller computes the number and length of the packets to be sent/received by the USB vary according to the total number of bytes and maximum packet length.

With Zero Length Termination (ZLT) = 0

\[ N = \text{INT}(\text{Number Of Bytes}/\text{Max. Packet Length}) + 1 \]

With Zero Length Termination (ZLT) = 1

\[ N = \text{MAXINT}(\text{Number Of Bytes}/\text{Max. Packet Length}) \]

Table 42-68. Variable Length Transfer Protocol Example (ZLT = 0)

<table>
<thead>
<tr>
<th>Bytes (dTD)</th>
<th>Max. Packet Length (dQH)</th>
<th>N</th>
<th>P1</th>
<th>P2</th>
<th>P3</th>
</tr>
</thead>
<tbody>
<tr>
<td>511</td>
<td>256</td>
<td>2</td>
<td>256</td>
<td>255</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 42-68. Variable Length Transfer Protocol Example (ZLT = 0) (continued)

<table>
<thead>
<tr>
<th>Bytes (dTD)</th>
<th>Max. Packet Length (dQH)</th>
<th>N</th>
<th>P1</th>
<th>P2</th>
<th>P3</th>
</tr>
</thead>
<tbody>
<tr>
<td>512</td>
<td>256</td>
<td>3</td>
<td>256</td>
<td>256</td>
<td>0</td>
</tr>
<tr>
<td>512</td>
<td>512</td>
<td>2</td>
<td>512</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Table 42-69. Variable Length Transfer Protocol Example (ZLT = 1)

<table>
<thead>
<tr>
<th>Bytes (dTD)</th>
<th>Max. Packet Length (dQH)</th>
<th>N</th>
<th>P1</th>
<th>P2</th>
<th>P3</th>
</tr>
</thead>
<tbody>
<tr>
<td>511</td>
<td>256</td>
<td>2</td>
<td>256</td>
<td>255</td>
<td></td>
</tr>
<tr>
<td>512</td>
<td>256</td>
<td>2</td>
<td>256</td>
<td>256</td>
<td></td>
</tr>
<tr>
<td>512</td>
<td>512</td>
<td>1</td>
<td>512</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTE**

The MULT field in the dQH must be set to "00" for bulk, interrupt, and control endpoints.

TX-dTD is complete when:

- All packets described dTD were successfully transmitted. *** Total bytes in dTD will equal zero when this occurs.

RX-dTD is complete when:

- All packets described in dTD were successfully received. *** Total bytes in dTD will equal zero when this occurs.
- A short packet (number of bytes < maximum packet length) was received. *** This is a successful transfer completion; DCD must check Total Bytes in dTD to determine the number of bytes that are remaining. From the total bytes remaining in the dTD, the DCD can compute the actual bytes received.
- A long packet was received (number of bytes > maximum packet size) OR (total bytes received > total bytes specified). *** This is an error condition. The device controller will discard the remaining packet, and set the Buffer Error bit in the dTD. In addition, the endpoint will be flushed and the USBERR interrupt will become active.

On the successful completion of the packet(s) described by the dTD, the active bit in the dTD will be cleared and the next pointer will be followed when the Terminate bit is clear. When the Terminate bit is set, the device controller will flush the endpoint/direction and cease operations for that endpoint/direction.

On the unsuccessful completion of a packet (see long packet above), the dQH will be left pointing to the dTD that was in error. In order to recover from this error condition, the DCD must properly reinitialize the dQH by clearing the active bit and update the nextTD pointer before attempting to re-prime the endpoint.
NOTE
All packet level errors such as a missing handshake or CRC error will be retried automatically by the device controller.

There is no required interaction with the DCD for handling such errors.

42.5.6.4.1.1 Interrupt/Bulk Endpoint Bus Response Matrix

The table below shows the response matrix for Interrupt/Bulk Endpoint Bus.

<table>
<thead>
<tr>
<th></th>
<th>Stall</th>
<th>Not Primed</th>
<th>Primed</th>
<th>Underflow</th>
<th>Overflow</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>In</td>
<td>STALL</td>
<td>NAK</td>
<td>Transmit</td>
<td>BS Error</td>
<td>N/A</td>
</tr>
<tr>
<td>Out</td>
<td>STALL</td>
<td>NAK</td>
<td>Receive + NYET/ACK</td>
<td>N/A</td>
<td>NAK</td>
</tr>
<tr>
<td>Ping</td>
<td>STALL</td>
<td>NAK</td>
<td>ACK</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>Invalid</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
</tr>
</tbody>
</table>

NOTE
BS Error = Force Bit Stuff Error

NYET/ACK - NYET unless the Transfer Descriptor has packets remaining according to the USB variable length protocol then ACK.

SYSERR - System error should never occur when the latency FIFOs are correctly sized and the DCD is responsive.

42.5.6.4.2 Control Endpoint Operation Model

This section details the setup phase, data phase, status phase, and the control endpoint bus response matrix.

42.5.6.4.2.1 Setup Phase

All requests to a control endpoint begin with a setup phase followed by an optional data phase and a required status phase. The device controller will always accept the setup phase unless the setup lockout is engaged.

The setup lockout will engage so that future setup packets are ignored. Lockout of setup packets ensures that while software is reading the setup packet stored in the queue head, that data is not written as it is being read potentially causing an invalid setup packet.
The setup lockout mechanism can be disabled and a new tripwire type semaphore will ensure that the setup packet payload is extracted from the queue head without being corrupted by an incoming setup packet. This is the preferred behavior because ignoring repeated setup packets due to long software interrupt latency would be a compliance issue.

- Disable Setup Lockout by writing 1 to Setup Lockout Mode (SLOM) in USB Device Mode (USB_nUSBMODE). (once at initialization). Setup lockout is not necessary when using the tripwire as described below.

**NOTE**
Leaving the Setup Lockout Mode As 0 will result in pre-2.3 hardware behavior.

- After receiving an interrupt and inspecting Endpoint Setup Status (USB_nENDPTSETUPSTAT) to determine that a setup packet was received on a particular pipe:
  a. Write 1 to clear corresponding bit Endpoint Setup Status (USB_nENDPTSETUPSTAT).
  b. Write 1 to Setup Tripwire (SUTW) in USB Command Register (USB_nUSBCMD) register.
  c. Duplicate contents of dQH.SetupBuffer into local software byte array.
  d. Read Setup TripWire (SUTW) in USB Command Register (USB_nUSBCMD) register. (if set - continue; if cleared - goto 2)
  e. Write 0 to clear Setup Tripwire (SUTW) in USB Command Register (USB_nUSBCMD) register.
  f. Process setup packet using local software byte array copy and execute status/handshake phases.

**NOTE**
After receiving a new setup packet the status and/or handshake phases may still be pending from a previous control sequence. These should be flushed & deallocated before linking a new status and/or handshake dTD for the most recent setup packet.

### 42.5.6.4.2.2 Data Phase

Following the setup phase, the DCD must create a device transfer descriptor for the data phase and prime the transfer.

After priming the packet, the DCD must verify a new setup packet has not been received by reading the USB.ENDPTSETUPSTAT register immediately verifying that the prime had completed. A prime will complete when the associated bit in the Endpoint Prime (USB_nENDPTPRIME) register is zero and the associated bit in the Endpoint Status
(USB\_n\_ENDPTSTAT) register is a one. If a prime fails, ie. The Endpoint Prime (USB\_n\_ENDPTPRIME) bit goes to zero and the Endpoint Status (USB\_n\_ENDPTSTAT) bit is not set, then the prime has failed. This can only be due to improper setup of the dQH, dTD or a setup arriving during the prime operation. If a new setup packet is indicated after the ENDPTPRIME bit is cleared, then the transfer descriptor can be freed and the DCD must reinterpret the setup packet.

Should a setup arrive after the data stage is primed, the device controller will automatically clear the prime status (Endpoint Status (USB\_n\_ENDPTSTAT)) to enforce data coherency with the setup packet.

NOTE

- The MULT field in the dQH must be set to "00" for bulk, interrupt, and control endpoints.
- Error handling of data phase packets is the same as bulk packets described previously.

42.5.6.4.2.3 Status Phase

Similar to the data phase, the DCD must create a transfer descriptor (with byte length equal zero) and prime the endpoint for the status phase.

The DCD must also perform the same checks of the USB.ENDPTSETUPSTAT as described above in the data phase.

NOTE

- The MULT field in the dQH must be set to 00 for bulk, interrupt, and control endpoints.
- Error handling of data phase packets is the same as bulk packets described previously.

42.5.6.4.2.4 Control Endpoint Bus Response Matrix

Shown in the following table is the device controller response to packets on a control endpoint according to the device controller state.

The table below shows the response matrix for the Control Endpoint Bus.

<table>
<thead>
<tr>
<th>Token Type</th>
<th>Endpoint State</th>
<th>Setup Lockout</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Stall</td>
<td>Not Primed</td>
</tr>
<tr>
<td>Setup</td>
<td>ACK</td>
<td>ACK</td>
</tr>
<tr>
<td>In</td>
<td>STALL</td>
<td>NAK</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 42-71. Control Endpoint Bus Response Matrix (continued)

<table>
<thead>
<tr>
<th>Out</th>
<th>STALL</th>
<th>NAK</th>
<th>Receive + NYET/ACK</th>
<th>N/A</th>
<th>NAK</th>
<th>N/A</th>
</tr>
</thead>
<tbody>
<tr>
<td>Ping</td>
<td>STALL</td>
<td>NAK</td>
<td>ACK</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>Invalid</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
</tr>
</tbody>
</table>

BS Error = Force Bit Stuff Error

NYET/ACK - NYET unless the Transfer Descriptor has packets remaining according to the USB variable length protocol then ACK.

SYSERR - System error should never occur when the latency FIFOs are correctly sized and the DCD is responsive.

42.5.6.4.3 Isochronous Endpoint Operational Model

Isochronous endpoints are used for real-time scheduled delivery of data and their operational model is significantly different than the host throttled Bulk, Interrupt, and Control data pipes.

Real time delivery by the device controller will be accomplished by the following:

- Exactly MULT Packets per (micro) Frame are transmitted/received. Note: MULT is a two-bit field in the device Queue Head. The variable length packet protocol is not used on isochronous endpoints.
- NAK responses are not used. Instead, zero length packets are sent in response to an IN request to an unprimed endpoints. For unprimed RX endpoints, the response to an OUT transaction is to ignore the packet within the device controller.
- Prime requests always schedule the transfer described in the dTD for the next (micro) frame. If the ISO-dTD is still active after that frame, then the ISO-dTD will be held ready until executed or canceled by the DCD.

An EHCI compatible host controller uses the periodic frame list to schedule data exchanges to Isochronous endpoints. The operational model for device mode does not use such a data structure. Instead, the same dTD used for Control/Bulk/Interrupt endpoints is also used for isochronous endpoints. The difference is in the handling of the dTD.

The first difference between bulk and ISO-endpoints is that priming an ISO-endpoint is a delayed operation such that an endpoint will become primed only after a SOF is received. After the DCD writes the prime bit, the prime bit will be cleared as usual to indicate to software that the device controller completed a priming the dTD for transfer. Internal to the design, the device controller hardware masks that prime start until the next frame boundary. This behavior is hidden from the DCD but occurs so that the device controller can match the dTD to a specific (micro)frame.
Another difference with isochronous endpoints is that the transaction must wholly complete in a (micro)frame. Once an ISO transaction is started in a (micro)frame it will retire the corresponding dTD when MULT transactions occur or the device controller finds a fulfillment condition.

The transaction error bit set in the status field indicates a fulfillment error condition. When a fulfillment error occurs, the frame after the transfer failed to complete wholly, the device controller will force retire the ISO-dTD and move to the next ISO-dTD.

It is important to note that fulfillment errors are only caused due to partially completed packets. If no activity occurs to a primed ISO-dTD, the transaction will stay primed indefinitely. This means it is up to software to discard transmit ISO-dTDs that pile up from a failure of the host to move the data.

Finally, the last difference with ISO packets is in the data level error handling. When a CRC error occurs on a received packet, the packet is not retried similar to bulk and control endpoints. Instead, the CRC is noted by setting the Transaction Error bit and the data is stored as usual for the application software to sort out.

- TX Packet Retired
  - MULT counter reaches zero.
  - Fulfillment Error [Transaction Error bit is set]
    - # Packets Occurred > 0 AND # Packets Occurred < MULT

**NOTE**
For TX-ISO, MULT Counter can be loaded with a lesser value in the dTD Multiplier Override field in hardware versions 2.3 and later. If the Multiplier Override is zero, the MULT Counter is initialized to the Multiplier in the QH.

- RX Packet Retired:
  - MULT counter reaches zero.
  - Non-MDATA Data PID is received**
    - ** Exit criteria only valid in hardware version 2.3 or later. Previous to hardware version 2.3, any PID sequence that did not match the MULT field exactly would be flagged as a transaction error due to PID mismatch or fulfillment error.
  - Overflow Error:
    - Packet received is > maximum packet length. [Buffer Error bit is set]
    - Packet received exceeds total bytes allocated in dTD. [Buffer Error bit is set]
  - Fulfillment Error [Transaction Error bit is set]
    - # Packets Occurred > 0 AND # Packets Occurred < MULT
  - CRC Error [Transaction Error bit is set]
NOTE
For ISO, when a dTD is retired, the next dTD is primed for the next frame. For continuous (micro)frame to (micro)frame operation the DCD should ensure that the dTD linked-list is out ahead of the device controller by at least two (micro)frames.

42.5.6.4.3.1 Isochronous Pipe Synchronization

When it is necessary to synchronize an isochronous data pipe to the host, the (micro) frame number (USB_UOG_FRINDEX register) can be used as a marker.

To cause a packet transfer to occur at a specific (micro) frame number [N], the DCD should interrupt on SOF during frame N-1. When the USB_UOG_FRINDEX=N-1, the DCD must write the prime bit. The device controller will prime the isochronous endpoint in (micro) frame N-1 so that the device controller will execute delivery during (micro) frame N.

NOTE
Priming an endpoint towards the end of (micro) frame N-1 will not guarantee delivery in (micro) frame N. The delivery may actually occur in (micro) frame N+1 if device controller does not have enough time to complete the prime before the SOF for packet N is received.

42.5.6.4.3.2 Isochronous Endpoint Bus Response Matrix

The following table shows the response matrix for the Isochronous Endpoint Bus.

<table>
<thead>
<tr>
<th></th>
<th>Stall</th>
<th>Not Primed</th>
<th>Primed</th>
<th>Underflow</th>
<th>Overflow</th>
</tr>
</thead>
<tbody>
<tr>
<td>Setup</td>
<td>STALL</td>
<td>STALL</td>
<td>STALL</td>
<td>N/A</td>
<td>N/A</td>
</tr>
<tr>
<td>In</td>
<td>NULL Packet</td>
<td>NULL Packet</td>
<td>Transmit</td>
<td>BS Error</td>
<td>N/A</td>
</tr>
<tr>
<td>Out</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Receive</td>
<td>N/A</td>
<td>Drop Packet</td>
</tr>
<tr>
<td>Ping</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
</tr>
<tr>
<td>Invalid</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
<td>Ignore</td>
</tr>
</tbody>
</table>

1. BS Error = Force Bit Stuff Error
NULL Packet = Zero Length Packet
42.5.6.5 Managing Queue Heads

The following figure shows the End Point Queue Head.

![End Point Queue Head Diagram](image)

The device queue head (dQH) points to the linked list of transfer tasks, each depicted by the device Transfer Descriptor (dTD). An area of memory pointed to by USB.ENDPOINTLISTADDR contains a group of all dQH's in a sequential list as shown in Figure 42-29. The even elements in the list of dQH's are used for receive endpoints (OUT/SETUP) and the odd elements are used for transmit endpoints (IN/INTERRUPT). Device transfer descriptors are linked head to tail starting at the queue head and ending at a terminate bit. Once the dTD has been retired, it will no longer be part of the linked list from the queue head. Therefore, software is required to track all transfer descriptors because pointers will no longer exist within the queue head once the dTD is retired (see section Software Link Pointers).

In addition to the current and next pointers and the dTD overlay examined in section Operational Model For Packet Transfers, the dQH also contains the following parameters for the associated endpoint: Multipler, Maximum Packet Length, Interrupt On Setup. The complete initialization of the dQH including these fields is demonstrated in the next section.

42.5.6.5.1 Queue Head Initialization

One device queue head must be initialized for each active endpoint.

To initialize a device queue head:
• Write the wMaxPacketSize field as required by the USB Chapter 9 or application specific protocol.
• Write the multiplier field to 0 for control, bulk, and interrupt endpoints. For ISO endpoints, set the multiplier to 1, 2, or 3 as required bandwidth and in conjunction with the USB Chapter 9 protocol.

**NOTE**
In FS mode, the multiplier field can only be 1 for ISO endpoints.

• Write the next dTD Terminate bit field to 1.
• Write the Active bit in the status field to 0.
• Write the Halt bit in the status field to 0.

**NOTE**
The DCD must only modify dQH if the associated endpoint is not primed and there are no outstanding dTD's.

### 42.5.6.5.2 Operational Model For Setup Transfers

As discussed in section Control Endpoint Operation Model, setup transfer requires special treatment by the DCD. A setup transfer does not use a dTD but instead stores the incoming data from a setup packet in an 8-byte buffer within the dQH.

Upon receiving notification of the setup packet, the DCD should handle the setup transfer as demonstrated here:

1. Copy setup buffer contents from dQH - RX to software buffer.
2. Acknowledge setup backup by writing a "1" to the corresponding bit in ENDPTSETUPSTAT.

**NOTE**
• The acknowledge must occur before continuing to process the setup packet.
• After the acknowledge has occurred, the DCD must not attempt to access the setup buffer in the dQH - RX. Only the local software copy should be examined.

3. Check for pending data or status dTD's from previous control transfers and flush if any exist as discussed in section Flushing/De-priming an Endpoint.
4. Decode setup packet and prepare data phase [optional] and status phase transfer as required by the USB Chapter 9 or application specific protocol.
NOTE
It is possible for the device controller to receive setup packets before previous control transfers complete. Existing control packets in progress must be flushed and the new control packet completed.

42.5.6.6 Managing Transfers with Transfer Descriptors

42.5.6.6.1 Software Link Pointers

It is necessary for the DCD software to maintain head and tail pointers to the for the linked list of dTDs for each respective queue head.

This is necessary because the dQH only maintains pointers to the current working dTD and the next dTD to be executed. The operations described in next section for managing dTD will assume the DCD can use reference the head and tail of the dTD linked list. The following figure shows the Software Link Pointers.

![Software Link Pointers Diagram]

**Figure 42-30. Software Link Pointers**

NOTE
To conserve memory, the reserved fields at the end of the dQH can be used to store the Head & Tail pointers, but it still remains the responsibility of the DCD to maintain the pointers.

42.5.6.6.2 Building a Transfer Descriptor

Before a transfer can be executed from the linked list, a dTD must be built to describe the transfer.
Use the following procedure for building dTDs.

Allocate 8-DWord dTD block of memory aligned to 8-DWord boundaries. Example: bit address 4:0 would be equal to "00000"

Write the following fields:

1. Initialize first 7 DWords to 0.
2. Set the terminate bit to 1.
3. Fill in total bytes with transfer size.
4. Set the interrupt on complete if desired.
5. Initialize the status field with the active bit set to 1 and all remaining status bits set to 0.
6. Fill in buffer pointer page 0 and the current offset to point to the start of the data buffer.
7. Initialize buffer pointer page 1 through page 4 to be one greater than each of the previous buffer pointer.

42.5.6.6.3 Executing A Transfer Descriptor

To safely add a dTD, the DCD must be follow this procedure which will handle the event where the device controller reaches the end of the dTD list at the same time a new dTD is being added to the end of the list.

Determine whether the link list is empty: Check DCD driver to see if pipe is empty (internal representation of linked-list should indicate if any packets are outstanding).

- Case 1: Link list is empty
  a. Write dQH next pointer AND dQH terminate bit to 0 as a single DWord operation.
  b. Clear active & halt bit in dQH (in case set from a previous error).
  c. Prime endpoint by writing 1 to correct bit position in Endpoint Prime (USB_endptprime).
- Case 2: Link list is not empty
  a. Add dTD to end of linked list.
  b. Read correct prime bit in Endpoint Prime (USB_endptprime)- if 1 DONE.
  c. Set ATDTW bit in USBCMD register to 1.
  d. Read correct status bit in Endpoint Status (USB_endptstat). (store in tmp. variable for later)
  e. Read ATDTW bit in USBCMD register.
     - If 0 goto 3.
     - If 1 continue to 6.
  f. Write ATDTW bit in USBCMD register to 0.
  g. If status bit read in (3) is 1 DONE.
h. If status bit read in (3) is 0 then Goto Case 1: Step 1.

42.5.6.6.4 Transfer Completion

After a dTD has been initialized and the associated endpoint primed the device controller will execute the transfer upon the host-initiated request. The DCD will be notified with a USB interrupt if the Interrupt On Complete bit was set or alternately, the DCD can poll the endpoint complete register to find when the dTD had been executed. After a dTD has been executed, DCD can check the status bits to determine success or failure.

**NOTE**

Multiple dTD can be completed in a single endpoint complete notification. After clearing the notification, DCD must search the dTD linked list and retire all dTDs that have finished (Active bit cleared).

By reading the status fields of the completed dTDs, the DCD can determine if the transfers completed successfully. Success is determined with the following combination of status bits:

- Active = 0
- Halted = 0
- Transaction Error = 0
- Data Buffer Error = 0

Should any combination other than the one shown above exist, the DCD must take proper action. Transfer failure mechanisms are indicated in the Device Error Matrix.

In addition to checking the status bit the DCD must read the Transfer Bytes field to determine the actual bytes transferred. When a transfer is complete, the Total Bytes transferred is by decremented by the actual bytes transferred. For Transmit packets, a packet is only complete after the actual bytes reaches zero, but for receive packets, the host may send fewer bytes in the transfer according the USB variable length packet protocol.

42.5.6.6.5 Flushing/De-priming an Endpoint

It is necessary for the DCD to flush to de-prime one more endpoints on a USB device reset or during a broken control transfer.

There may also be application specific requirements to stop transfers in progress. The following procedure can be used by the DCD to stop a transfer in progress:

1. Write a '1' to the corresponding bit(s) in Endpoint Flush (USB_nENDPTFLUSH).
2. Wait until all bits in Endpoint Flush (USB_nENDPTFLUSH) are '0'.
Software note: this operation may take a large amount of time depending on the USB bus activity. It is not desirable to have this wait loop within an interrupt service routine.

3. Read **Endpoint Status (USB_nENDPTSTAT)** to ensure that for all endpoints commanded to be flushed, that the corresponding bits are now '0'. If the corresponding bits are '1' after step #2 has finished, then the flush failed as described in the following:

- **Explanation:** In very rare cases, a packet is in progress to the particular endpoint when commanded flush using **Endpoint Flush (USB_nENDPTFLUSH)**. A safeguard is in place to refuse the flush to ensure that the packet in progress completes successfully. The DCD may need to repeatedly flush any endpoints that fail to flush be repeating steps 1-3 until each endpoint is successfully flushed.

### 42.5.6.6.6 Device Error Matrix

The following table summarizes packet errors that are not automatically handled by the Device Controller.

<table>
<thead>
<tr>
<th>Error</th>
<th>Direction</th>
<th>Packet Type</th>
<th>Data Buffer Error Bit</th>
<th>Transaction Error Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Overflow **</td>
<td>RX</td>
<td>Any</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>ISO Packet Error</td>
<td>RX</td>
<td>ISO</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>ISO Fulfillment Error</td>
<td>Both</td>
<td>ISO</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

Notice that the device controller handles all errors on Bulk/Control/Interrupt Endpoints except for a data buffer overflow. However, for ISO endpoints, errors packets are not retried and errors are tagged as indicated. The table below describes the errors.

<table>
<thead>
<tr>
<th>Error</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Overflow</td>
<td>Number of bytes received exceeded max. packet size or total buffer length. <strong>This error will also set the Halt bit in the dQH and if there are dTDs remaining in the linked list for the endpoint, then those will not be executed.</strong></td>
</tr>
<tr>
<td>ISO Packet Error</td>
<td>CRC Error on received ISO packet. Contents not guaranteed to be correct.</td>
</tr>
<tr>
<td>ISO Fulfillment Error</td>
<td>Host failed to complete the number of packets defined in the dQH mult field within the given (micro)frame. For scheduled data delivery the DCD may need to readjust the data queue because a fulfillment error will cause Device Controller to cease data transfers on the pipe for one (micro)frame. During the &quot;dead&quot; (micro)frame, the Device Controller reports error on the pipe and primes for the following frame.</td>
</tr>
</tbody>
</table>
42.5.6.7 Servicing Interrupts

The interrupt service routine must consider that there are high-frequency, low-frequency operations, and error operations and order accordingly.

42.5.6.7.1 High-Frequency Interrupts

High frequency interrupts in particular should be handled in the order below. The most important of these is listed first because the DCD must acknowledge a setup buffer in the timeliest manner possible.

The table below describes the High frequency interrupt events.

Table 42-75. High Frequency Interrupt Events

<table>
<thead>
<tr>
<th>Execution Order</th>
<th>Interrupt</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>1a</td>
<td>USB Interrupt - USB.ENDPTSETUPSTATUS</td>
<td>Copy contents of setup buffer and acknowledge setup packet (as indicated in Figure 42-29 shows the End Point Queue Head). Process setup packet according to USB 2.0 Chapter 9 or application specific protocol.</td>
</tr>
<tr>
<td>1b</td>
<td>USB Interrupt$^1$ - USB.ENDPTCOMPLETE</td>
<td>Handle completion of dTD as indicated in Figure 42-29 shows the End Point Queue Head.</td>
</tr>
<tr>
<td>2</td>
<td>SOF Interrupt</td>
<td>Action as deemed necessary by application. This interrupt may not have a use in all applications.</td>
</tr>
</tbody>
</table>

1. It is likely that multiple interrupts to stack up on any call to the Interrupt Service Routine AND during the Interrupt Service Routine.

42.5.6.7.2 Low-Frequency Interrupts

The low frequency interrupts can be handled in any order because they do not occur often in comparison to the high-frequency interrupts.

The table below shows the Low frequency interrupt events.

Table 42-76. Low Frequency Interrupt Events

<table>
<thead>
<tr>
<th>Interrupt</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>Port Change</td>
<td>Change software state information.</td>
</tr>
<tr>
<td>Sleep Enable (Suspend)</td>
<td>Change software state information. Low power handling as necessary.</td>
</tr>
<tr>
<td>Reset Received</td>
<td>Change software state information. Abort pending transfers.</td>
</tr>
</tbody>
</table>
### 42.5.6.7.3 Error Interrupts

Error interrupts will be least frequent and should be placed last in the interrupt service routine.

The following table shows the error interrupt events.

<table>
<thead>
<tr>
<th>Interrupt</th>
<th>Action</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB Error Interrupt</td>
<td>This error is redundant because it combines USB Interrupt and an error status in the dTD. The DCD will more aptly handle packet-level errors by checking dTD status field upon receipt of USB Interrupt (w/ USB.ENDPTCOMPLETE).</td>
</tr>
<tr>
<td>System Error</td>
<td>Unrecoverable error. Immediate Reset of core; free transfers buffers in progress and restart the DCD.</td>
</tr>
</tbody>
</table>

#### 42.6 USB Non-Core Memory Map/Register Definition

There are two kinds of registers in the USB module: USB core registers and USB non-core registers. USB core registers are used to control USB core functions, and more independent of USB features. Each USB controller core has its own core registers. USB non-core registers are additional to USB core registers, and more dependent on USB features. i.MX series products vary in non-core registers.

This section describes only the USB non-core registers. For detailed descriptions of USB core registers, please refer to Register Interface.

**NOTE**

- For reserved bits, please preserve the value when writing (read its reset value, then write this value back)
- "USB_UOG1_", "USB_UOG2_" prefix in register name indicates it is a core register for OTG1/OTG2 controller core respectively.
- USBNC_USB_" prefix in register name indicates it is a USB non-core register.

**USBNC memory map**

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402E_0800</td>
<td>USB OTG1 Control Register (USBNC_USB_OTG1_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>3000_1000h</td>
<td>42.6.1/2378</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402E_0804</td>
<td>USB OTG2 Control Register (USBNC_USB_OTG2_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>3000_1000h</td>
<td>42.6.2/2381</td>
</tr>
<tr>
<td>402E_0818</td>
<td>OTG1 UTMI PHY Control 0 Register (USBNC_USB_OTG1_PHY_CTRL_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.6.3/2384</td>
</tr>
<tr>
<td>402E_081C</td>
<td>OTG2 UTMI PHY Control 0 Register (USBNC_USB_OTG2_PHY_CTRL_0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0098h</td>
<td>42.6.4/2385</td>
</tr>
</tbody>
</table>
42.6.1 USB OTG1 Control Register (USBNC_USB_OTG1_CTRL)

The USB OTG1 control register controls the integration specific features of the USB OTG1 module. These features are not directly related to the USB functionality, but control special features, interfacing on the USB ports, as well as power control and wake-up functionality.

Address: 402E_0000h base + 800h offset = 402E_0800h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>WKUP_DPDM_EN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>WKUP_ID_EN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0
### USBNC_USB_OTG1_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 WIR</td>
<td>OTG1 Wake-up Interrupt Request</td>
</tr>
<tr>
<td></td>
<td>This bit indicates that a wake-up interrupt request is received on the OTG1 port. This bit is cleared by disabling the wake-up interrupt (clearing bit “OWIE”).</td>
</tr>
<tr>
<td></td>
<td>1 Wake-up Interrupt Request received</td>
</tr>
<tr>
<td></td>
<td>0 No wake-up interrupt request received</td>
</tr>
<tr>
<td>30 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>29 WKUP_DPDM_EN</td>
<td>Wake-up on DPDM change enable</td>
</tr>
<tr>
<td></td>
<td>1 (Default) DPDM changes wake-up to be enabled, it is for device only.</td>
</tr>
<tr>
<td></td>
<td>0 DPDM changes wake-up to be disabled only when VBUS is 0.</td>
</tr>
<tr>
<td>28–18 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>17 WKUP_VBUS_EN</td>
<td>OTG1 wake-up on VBUS change enable</td>
</tr>
<tr>
<td></td>
<td>1 Enable</td>
</tr>
<tr>
<td></td>
<td>0 Disable</td>
</tr>
<tr>
<td>16 WKUP_ID_EN</td>
<td>OTG1 Wake-up on ID change enable</td>
</tr>
<tr>
<td></td>
<td>1 Enable</td>
</tr>
<tr>
<td></td>
<td>0 Disable</td>
</tr>
<tr>
<td>15 WKUP_SW</td>
<td>OTG1 Software Wake-up</td>
</tr>
<tr>
<td></td>
<td>1 Force wake-up</td>
</tr>
<tr>
<td></td>
<td>0 Inactive</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## USBNC_USB_OTG1_CTRL field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14</td>
<td>WKUP_SW_EN</td>
</tr>
<tr>
<td></td>
<td>OTG1 Software Wake-up Enable</td>
</tr>
<tr>
<td></td>
<td>1 Enable</td>
</tr>
<tr>
<td></td>
<td>0 Disable</td>
</tr>
<tr>
<td>13–11</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>WIE</td>
</tr>
<tr>
<td></td>
<td>OTG1 Wake-up Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>This bit enables or disables the OTG1 wake-up interrupt. Disabling the</td>
</tr>
<tr>
<td></td>
<td>interrupt also clears the Interrupt request bit. Wake-up interrupt enable</td>
</tr>
<tr>
<td></td>
<td>should be turned off after receiving a wake-up interrupt and turned on</td>
</tr>
<tr>
<td></td>
<td>again prior to going in suspend mode</td>
</tr>
<tr>
<td></td>
<td>1 Interrupt Enabled</td>
</tr>
<tr>
<td></td>
<td>0 Interrupt Disabled</td>
</tr>
<tr>
<td>9</td>
<td>PWR_POL</td>
</tr>
<tr>
<td></td>
<td>OTG1 Power Polarity</td>
</tr>
<tr>
<td></td>
<td>This bit should be set according to PMIC Power Pin polarity.</td>
</tr>
<tr>
<td></td>
<td>1 PMIC Power Pin is High active.</td>
</tr>
<tr>
<td></td>
<td>0 PMIC Power Pin is Low active.</td>
</tr>
<tr>
<td>8</td>
<td>OVER_CUR_POL</td>
</tr>
<tr>
<td></td>
<td>OTG1 Polarity of Overcurrent</td>
</tr>
<tr>
<td></td>
<td>The polarity of OTG1 port overcurrent event</td>
</tr>
<tr>
<td></td>
<td>1 Low active (low on this signal represents an overcurrent condition)</td>
</tr>
<tr>
<td></td>
<td>0 High active (high on this signal represents an overcurrent condition)</td>
</tr>
<tr>
<td>7</td>
<td>OVER_CUR_DIS</td>
</tr>
<tr>
<td></td>
<td>Disable OTG1 Overcurrent Detection</td>
</tr>
<tr>
<td></td>
<td>1 Disables overcurrent detection</td>
</tr>
<tr>
<td></td>
<td>0 Enables overcurrent detection</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

USB Non-Core Memory Map/Register Definition

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
42.6.2 USB OTG2 Control Register (USBNC_USB_OTG2_CTRL)

The USB OTG2 control register controls the integration specific features of the USB OTG2 module. These features are not directly related to the USB functionality, but control special features, interfacing on the USB ports, as well as power control and wake-up functionality.

Address: 402E_0000h base + 804h offset = 402E_0804h
USBNC_USB_OTG2_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 WIR</td>
<td>OTG2 Wake-up Interrupt Request</td>
</tr>
<tr>
<td></td>
<td>This bit indicates that a wake-up interrupt request is received on the OTG</td>
</tr>
<tr>
<td></td>
<td>port. This bit is cleared by disabling the wake-up interrupt (clearing bit</td>
</tr>
<tr>
<td></td>
<td>“OWIE”).</td>
</tr>
<tr>
<td>1</td>
<td>Wake-up Interrupt Request received</td>
</tr>
<tr>
<td>0</td>
<td>No wake-up interrupt request received</td>
</tr>
<tr>
<td>30 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>29 WKUP_DPDM_EN</td>
<td>Wake-up on DPDM change enable</td>
</tr>
<tr>
<td>1</td>
<td>(Default) DPDM changes wake-up to be enabled, it is for device only.</td>
</tr>
<tr>
<td>0</td>
<td>DPDM changes wake-up to be disabled only when VBUS is 0.</td>
</tr>
<tr>
<td>28–18 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>16 WKUP_ID_EN</td>
<td>OTG2 Wake-up on ID change enable</td>
</tr>
<tr>
<td>1</td>
<td>Enable</td>
</tr>
<tr>
<td>0</td>
<td>Disable</td>
</tr>
<tr>
<td>15 WKUP_SW</td>
<td>OTG2 Software Wake-up</td>
</tr>
<tr>
<td>1</td>
<td>Force wake-up</td>
</tr>
<tr>
<td>0</td>
<td>Inactive</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## USBNC_USB_OTG2_CTRL field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14 WKUP_SW_EN</td>
<td>OTG2 Software Wake-up Enable</td>
</tr>
<tr>
<td></td>
<td>1 Enable</td>
</tr>
<tr>
<td></td>
<td>0 Disable</td>
</tr>
<tr>
<td>13–11 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>10 WIE</td>
<td>OTG2 Wake-up Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>This bit enables or disables the OTG2 wake-up interrupt. Disabling the</td>
</tr>
<tr>
<td></td>
<td>interrupt also clears the Interrupt request bit. Wake-up interrupt enable</td>
</tr>
<tr>
<td></td>
<td>should be turned off after receiving a wake-up interrupt and turned on</td>
</tr>
<tr>
<td></td>
<td>again prior to going in suspend mode</td>
</tr>
<tr>
<td></td>
<td>1 Interrupt Enabled</td>
</tr>
<tr>
<td></td>
<td>0 Interrupt Disabled</td>
</tr>
<tr>
<td>9 PWR_POL</td>
<td>OTG2 Power Polarity</td>
</tr>
<tr>
<td></td>
<td>This bit should be set according to PMIC Power Pin polarity.</td>
</tr>
<tr>
<td></td>
<td>1 PMIC Power Pin is High active.</td>
</tr>
<tr>
<td></td>
<td>0 PMIC Power Pin is Low active.</td>
</tr>
<tr>
<td>8 OVER_CUR_POL</td>
<td>OTG2 Polarity of Overcurrent</td>
</tr>
<tr>
<td></td>
<td>The polarity of OTG2 port overcurrent event</td>
</tr>
<tr>
<td></td>
<td>1 Low active (low on this signal represents an overcurrent condition)</td>
</tr>
<tr>
<td></td>
<td>0 High active (high on this signal represents an overcurrent condition)</td>
</tr>
<tr>
<td>7 OVER_CUR_DIS</td>
<td>Disable OTG2 Overcurrent Detection</td>
</tr>
<tr>
<td></td>
<td>1 Disables overcurrent detection</td>
</tr>
<tr>
<td></td>
<td>0 Enables overcurrent detection</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
**42.6.3 OTG1 UTMI PHY Control 0 Register**  
*(USBNC_USB_OTG1_PHY_CTRL_0)*

USB OTG1 UTMI PHY control register 0 is used to control the on-chip OTG1 UTMI PHY.

Address: 402E_0000h base + 818h offset = 402E_0818h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>UTMCLK_VLD</td>
<td>Indicating whether OTG1 UTMI PHY clock is valid</td>
</tr>
<tr>
<td>30–3</td>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>-</td>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

USB Non-Core Memory Map/Register Definition

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
42.6.4 OTG2 UTMI PHY Control 0 Register
(USBNC_USB_OTG2_PHY_CTRL_0)

USB OTG2 UTMI PHY Control Register 0 are used to control the on-chip OTG2 UTMI PHY.

Address: 402E_0000h base + 81Ch offset = 402E_081Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>UTMI_CLK_VLD</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**USBNC_USB_OTG2_PHY_CTRL_0 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>UTMI_CLK_VLD</td>
</tr>
<tr>
<td>30–31</td>
<td>Indicating whether OTG2 UTMI PHY clock is valid</td>
</tr>
<tr>
<td>-</td>
<td>1 Valid</td>
</tr>
<tr>
<td>30–31</td>
<td>0 Invalid</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

42.7 USB Core Memory Map/Register Definition

**USB memory map**

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402E_0000</td>
<td>Identification register (USB_UOG1_ID)</td>
<td>32</td>
<td>R</td>
<td>E4A1_FA05h</td>
<td>42.7.1/2390</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## USB memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402E_0004</td>
<td>Hardware General (USB_UOG1_HWGENERAL)</td>
<td>32</td>
<td>R</td>
<td>0000_0035h</td>
<td>42.7.2/2390</td>
</tr>
<tr>
<td>402E_0008</td>
<td>Host Hardware Parameters (USB_UOG1_HWHOST)</td>
<td>32</td>
<td>R</td>
<td>1002_0001h</td>
<td>42.7.3/2392</td>
</tr>
<tr>
<td>402E_000C</td>
<td>Device Hardware Parameters (USB_UOG1_HWDEVICE)</td>
<td>32</td>
<td>R</td>
<td>0000_0011h</td>
<td>42.7.4/2392</td>
</tr>
<tr>
<td>402E_0010</td>
<td>TX Buffer Hardware Parameters (USB_UOG1_HWTXBUF)</td>
<td>32</td>
<td>R</td>
<td>8008_0B08h</td>
<td>42.7.5/2393</td>
</tr>
<tr>
<td>402E_0014</td>
<td>RX Buffer Hardware Parameters (USB_UOG1_HWRXBUF)</td>
<td>32</td>
<td>R</td>
<td>0000_0808h</td>
<td>42.7.6/2394</td>
</tr>
<tr>
<td>402E_0080</td>
<td>General Purpose Timer #0 Load (USB_UOG1_GPTIMER0LD)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.7/2394</td>
</tr>
<tr>
<td>402E_0084</td>
<td>General Purpose Timer #0 Controller (USB_UOG1_GPTIMER0CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.8/2395</td>
</tr>
<tr>
<td>402E_0088</td>
<td>General Purpose Timer #1 Load (USB_UOG1_GPTIMER1LD)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.9/2396</td>
</tr>
<tr>
<td>402E_008C</td>
<td>General Purpose Timer #1 Controller (USB_UOG1_GPTIMER1CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.10/2397</td>
</tr>
<tr>
<td>402E_0090</td>
<td>System Bus Config (USB_UOG1_SBUSCFG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0002h</td>
<td>42.7.11/2398</td>
</tr>
<tr>
<td>402E_0100</td>
<td>Capability Registers Length (USB_UOG1_CAPLENGTH)</td>
<td>8</td>
<td>R</td>
<td>40h</td>
<td>42.7.12/2399</td>
</tr>
<tr>
<td>402E_0102</td>
<td>Host Controller Interface Version (USB_UOG1_HCIVERSION)</td>
<td>16</td>
<td>R</td>
<td>0100h</td>
<td>42.7.13/2399</td>
</tr>
<tr>
<td>402E_0104</td>
<td>Host Controller Structural Parameters (USB_UOG1_HCSPARAMS)</td>
<td>32</td>
<td>R</td>
<td>0001_0011h</td>
<td>42.7.14/2400</td>
</tr>
<tr>
<td>402E_0108</td>
<td>Host Controller Capability Parameters (USB_UOG1_HCCPARAMS)</td>
<td>32</td>
<td>R</td>
<td>0000_0006h</td>
<td>42.7.15/2402</td>
</tr>
<tr>
<td>402E_0120</td>
<td>Device Controller Interface Version (USB_UOG1_DCIVERSION)</td>
<td>16</td>
<td>R</td>
<td>0001h</td>
<td>42.7.16/2404</td>
</tr>
<tr>
<td>402E_0124</td>
<td>Device Controller Capability Parameters (USB_UOG1_DCCPARAMS)</td>
<td>32</td>
<td>R</td>
<td>0000_0188h</td>
<td>42.7.17/2405</td>
</tr>
<tr>
<td>402E_0140</td>
<td>USB Command Register (USB_UOG1_USBCMD)</td>
<td>32</td>
<td>R/W</td>
<td>0008_0000h</td>
<td>42.7.18/2406</td>
</tr>
<tr>
<td>402E_0144</td>
<td>USB Status Register (USB_UOG1_USBSTS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.19/2410</td>
</tr>
<tr>
<td>402E_0148</td>
<td>Interrupt Enable Register (USB_UOG1_USBINTR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.20/2414</td>
</tr>
<tr>
<td>402E_014C</td>
<td>USB Frame Index (USB_UOG1_FRINDEX)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.21/2416</td>
</tr>
<tr>
<td>402E_0154</td>
<td>Frame List Base Address (USB_UOG1_PERIODICLISTBASE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.22/2417</td>
</tr>
<tr>
<td>402E_0154</td>
<td>Device Address (USB_UOG1_DEVICEADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.23/2417</td>
</tr>
<tr>
<td>402E_0158</td>
<td>Next Asynch. Address (USB_UOG1ASYNCLISTADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.24/2418</td>
</tr>
<tr>
<td>402E_0158</td>
<td>Endpoint List Address (USB_UOG1_ENDPTLISTADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.25/2419</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table continues on the next page...
### USB memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402E_0208</td>
<td>Host Hardware Parameters (USB_UOG2_HWHOST)</td>
<td>32</td>
<td>R</td>
<td>1002_0001h</td>
<td>42.7.3/2392</td>
</tr>
<tr>
<td>402E_020C</td>
<td>Device Hardware Parameters (USB_UOG2_HWDEVICE)</td>
<td>32</td>
<td>R</td>
<td>0000_0011h</td>
<td>42.7.4/2392</td>
</tr>
<tr>
<td>402E_0210</td>
<td>TX Buffer Hardware Parameters (USB_UOG2_HWTXBUF)</td>
<td>32</td>
<td>R</td>
<td>8008_0B08h</td>
<td>42.7.5/2393</td>
</tr>
<tr>
<td>402E_0214</td>
<td>RX Buffer Hardware Parameters (USB_UOG2_HWRXBUF)</td>
<td>32</td>
<td>R</td>
<td>0000_0808h</td>
<td>42.7.6/2394</td>
</tr>
<tr>
<td>402E_0280</td>
<td>General Purpose Timer #0 Load (USB_UOG2_GPTIMER0LD)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.7/2394</td>
</tr>
<tr>
<td>402E_0284</td>
<td>General Purpose Timer #0 Controller (USB_UOG2_GPTIMER0CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.8/2395</td>
</tr>
<tr>
<td>402E_0288</td>
<td>General Purpose Timer #1 Load (USB_UOG2_GPTIMER1LD)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.9/2396</td>
</tr>
<tr>
<td>402E_028C</td>
<td>General Purpose Timer #1 Controller (USB_UOG2_GPTIMER1CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.10/2397</td>
</tr>
<tr>
<td>402E_0290</td>
<td>System Bus Config (USB_UOG2_SBUSCFG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0002h</td>
<td>42.7.11/2398</td>
</tr>
<tr>
<td>402E_0300</td>
<td>Capability Registers Length (USB_UOG2_CAPLENGTH)</td>
<td>8</td>
<td>R</td>
<td>40h</td>
<td>42.7.12/2399</td>
</tr>
<tr>
<td>402E_0302</td>
<td>Host Controller Interface Version (USB_UOG2_HCVERSION)</td>
<td>16</td>
<td>R</td>
<td>0100h</td>
<td>42.7.13/2399</td>
</tr>
<tr>
<td>402E_0304</td>
<td>Host Controller Structural Parameters (USB_UOG2_HCSPARAMS)</td>
<td>32</td>
<td>R</td>
<td>0001_0011h</td>
<td>42.7.14/2400</td>
</tr>
<tr>
<td>402E_0308</td>
<td>Host Controller Capability Parameters (USB_UOG2_HCCPARAMS)</td>
<td>32</td>
<td>R</td>
<td>0000_0006h</td>
<td>42.7.15/2402</td>
</tr>
<tr>
<td>402E_0320</td>
<td>Device Controller Interface Version (USB_UOG2_DCVERSION)</td>
<td>16</td>
<td>R</td>
<td>0001h</td>
<td>42.7.16/2404</td>
</tr>
<tr>
<td>402E_0324</td>
<td>Device Controller Capability Parameters (USB_UOG2_DCCPARAMS)</td>
<td>32</td>
<td>R</td>
<td>0000_0188h</td>
<td>42.7.17/2405</td>
</tr>
<tr>
<td>402E_0340</td>
<td>USB Command Register (USB_UOG2_USBCMD)</td>
<td>32</td>
<td>R/W</td>
<td>0008_0000h</td>
<td>42.7.18/2406</td>
</tr>
<tr>
<td>402E_0344</td>
<td>USB Status Register (USB_UOG2_USBSTS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.19/2410</td>
</tr>
<tr>
<td>402E_0348</td>
<td>Interrupt Enable Register (USB_UOG2_USBINTR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.20/2414</td>
</tr>
<tr>
<td>402E_034C</td>
<td>USB Frame Index (USB_UOG2_FRINDEX)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.21/2416</td>
</tr>
<tr>
<td>402E_0354</td>
<td>Frame List Base Address (USB_UOG2_PERIODICLISTBASE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.22/2417</td>
</tr>
<tr>
<td>402E_0354</td>
<td>Device Address (USB_UOG2DEVICEADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.23/2417</td>
</tr>
<tr>
<td>402E_0358</td>
<td>Next Asynch. Address (USB_UOG2ASYNCLISTADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.24/2418</td>
</tr>
<tr>
<td>402E_0358</td>
<td>Endpoint List Address (USB_UOG2_ENDPTLISTADDR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.25/2419</td>
</tr>
<tr>
<td>402E_0360</td>
<td>Programmable Burst Size (USB_UOG2_BURSTSIZE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0808h</td>
<td>42.7.26/2419</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## USB memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>402E_0364</td>
<td>TX FIFO Fill Tuning (USB_UOG2_TXFILLTUNING)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.27/2420</td>
</tr>
<tr>
<td>402E_0378</td>
<td>Endpoint NAK (USB_UOG2_ENDPTNAK)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.28/2422</td>
</tr>
<tr>
<td>402E_037C</td>
<td>Endpoint NAK Enable (USB_UOG2_ENDPTNAKEN)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.29/2422</td>
</tr>
<tr>
<td>402E_0380</td>
<td>Configure Flag Register (USB_UOG2_CONFIGFLAG)</td>
<td>32</td>
<td>R</td>
<td>0000_0001h</td>
<td>42.7.30/2423</td>
</tr>
<tr>
<td>402E_0384</td>
<td>Port Status &amp; Control (USB_UOG2_PORTSC1)</td>
<td>32</td>
<td>R/W</td>
<td>1000_0000h</td>
<td>42.7.31/2423</td>
</tr>
<tr>
<td>402E_03A4</td>
<td>On-The-Go Status &amp; control (USB_UOG2_OTGSC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1120h</td>
<td>42.7.32/2430</td>
</tr>
<tr>
<td>402E_03A8</td>
<td>USB Device Mode (USB_UOG2_USBMODE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_5000h</td>
<td>42.7.33/2434</td>
</tr>
<tr>
<td>402E_03AC</td>
<td>Endpoint Setup Status (USB_UOG2_ENDPTSETUPSTAT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.34/2435</td>
</tr>
<tr>
<td>402E_03B0</td>
<td>Endpoint Prime (USB_UOG2_ENDPTPRIME)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.35/2436</td>
</tr>
<tr>
<td>402E_03B4</td>
<td>Endpoint Flush (USB_UOG2_ENDPTFLUSH)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.36/2437</td>
</tr>
<tr>
<td>402E_03B8</td>
<td>Endpoint Status (USB_UOG2_ENDPTSTAT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>42.7.37/2437</td>
</tr>
<tr>
<td>402E_03BC</td>
<td>Endpoint Complete (USB_UOG2_ENDPTCOMPLETE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.38/2438</td>
</tr>
<tr>
<td>402E_03C0</td>
<td>Endpoint Control0 (USB_UOG2_ENDPTCTRL0)</td>
<td>32</td>
<td>R/W</td>
<td>0080_0080h</td>
<td>42.7.39/2439</td>
</tr>
<tr>
<td>402E_03C4</td>
<td>Endpoint Control 1 (USB_UOG2_ENDPTCTRL1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.40/2441</td>
</tr>
<tr>
<td>402E_03C8</td>
<td>Endpoint Control 2 (USB_UOG2_ENDPTCTRL2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.41/2444</td>
</tr>
<tr>
<td>402E_03CC</td>
<td>Endpoint Control 3 (USB_UOG2_ENDPTCTRL3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.42/2446</td>
</tr>
<tr>
<td>402E_03D0</td>
<td>Endpoint Control 4 (USB_UOG2_ENDPTCTRL4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.43/2449</td>
</tr>
<tr>
<td>402E_03D4</td>
<td>Endpoint Control 5 (USB_UOG2_ENDPTCTRL5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.44/2452</td>
</tr>
<tr>
<td>402E_03D8</td>
<td>Endpoint Control 6 (USB_UOG2_ENDPTCTRL6)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.45/2455</td>
</tr>
<tr>
<td>402E_03DC</td>
<td>Endpoint Control 7 (USB_UOG2_ENDPTCTRL7)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>42.7.46/2458</td>
</tr>
</tbody>
</table>
42.7.1 Identification register (USB_nID)

The ID register identifies the USB 2.0 High-Speed core and its revision.

Address: 402E_0000h base + 0h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>23–16</td>
<td>REVISION</td>
<td>Revision number of the controller core.</td>
</tr>
<tr>
<td>15–14</td>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>13–8</td>
<td>NID</td>
<td>Complement version of ID</td>
</tr>
<tr>
<td>7–6</td>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>0–0</td>
<td>ID</td>
<td>Configuration number.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>This number is set to 0x05 and indicates that the peripheral is USB 2.0 High-Speed core.</td>
</tr>
</tbody>
</table>

42.7.2 Hardware General (USB_nHWGENERAL)

General hardware parameters as defined in System Level Issues and Core Configuration.

NOTE

The reset value could vary from instance to instance. Please see the detail in bit field description and ignore reset value in summary table in this case!
Address: 402E_0000h base + 4h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R W | Reserved | SM | PHYM | PHYW | Reserved |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 |

### USB_nHWGENERAL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–11 | This field is reserved.  
          Reserved |
| 10–9  | Serial interface mode capability |
| SM    | 00 No Serial Engine, always use parallel signalling.  
          01 Serial Engine present, always use serial signalling for FS/LS.  
          10 Software programmable - Reset to use parallel signalling for FS/LS  
          11 Software programmable - Reset to use serial signalling for FS/LS |
| 8–6   | Transciever type |
| PHYM  | 000 UTMI/UMTI+  
          001 ULPI DDR  
          010 ULPI  
          011 Serial Only  
          100 Software programmable - reset to UTMI/UTMI+  
          101 Software programmable - reset to ULPI DDR  
          110 Software programmable - reset to ULPI  
          111 Software programmable - reset to Serial  
          1000 IC-USB  
          1001 Software programmable - reset to IC-USB |
| 5–4   | Data width of the transciever connected to the controller core.  
          PHYW bit reset value is  
          00 8 bit wide data bus  
          01 16 bit wide data bus  
          10 Reset to 8 bit wide data bus  
          11 Reset to 16 bit wide data bus |
| -     | This field is reserved.  
          Reserved |
42.7.3 Host Hardware Parameters (USB_nHWHOST)

Address: 402E_0000h base + 8h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

USB_nHWHOST field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>3–1</td>
<td>The Number of downstream ports supported by the host controller is (NPORT+1).</td>
</tr>
<tr>
<td>NPORT</td>
<td>NOTE: When these bits value is '000', it indicates a single-port host controller.</td>
</tr>
<tr>
<td>0</td>
<td>Host Capable. Indicating whether host operation mode is supported or not.</td>
</tr>
<tr>
<td>1</td>
<td>Supported</td>
</tr>
<tr>
<td>0</td>
<td>Not supported</td>
</tr>
<tr>
<td>16</td>
<td>HC</td>
</tr>
</tbody>
</table>

42.7.4 Device Hardware Parameters (USB_nHWDEVICE)

Address: 402E_0000h base + Ch offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

USB_nHWDEVICE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3–1</td>
<td>DEVEP</td>
</tr>
<tr>
<td>NPORT</td>
<td>DC</td>
</tr>
<tr>
<td>0</td>
<td>HC</td>
</tr>
</tbody>
</table>

NOTE: When these bits value is '000', it indicates a single-port host controller.
### USB\_nHWDEVICE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–6</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>5–1</td>
<td>Device Endpoint Number</td>
</tr>
</tbody>
</table>
| 0 DC | Device Capable. Indicating whether device operation mode is supported or not.  
1 Supported  
0 Not supported |

### 42.7.5 TX Buffer Hardware Parameters (USB\_nHWTXBUF)

Address: 402E\_0000h base + 10h offset + (512d × i), where i=0d to 1d

#### USB\_nHWTXBUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved.</td>
</tr>
</tbody>
</table>
| 23–16 | TX FIFO Buffer size is: \(2^{\text{TXCHANADD}}\) * 4 Bytes.  
These bits are set to '08h', so buffer size is 256*4 Bytes.  
For the OTG controller operating in device mode, this is the FIFO buffer size per endpoint. As the OTG controller has 8 TX endpoint, there are 8 of these buffers.  
For the OTG controller operating in host mode, or for Host-only controller, the entire buffer memory is used as a single TX buffer. Therefore, there is only 1 of this buffer |
| 15–8  | This field is reserved. |
| TXBURST | Default burst size for memory to TX buffer transfer.  
This is reset value of TXPBURST bits in USB core regisiter USB\_\_n\_BURSTSIZE.  
Please see Programmable Burst Size (USB\_\_nBURSTSIZE).

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors 2393
42.7.6 RX Buffer Hardware Parameters (USB\_nHWRXBUF)

Address: 402E_0000h base + 14h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>15–8</td>
<td>RXADD</td>
</tr>
<tr>
<td>7–0</td>
<td>RXBURST</td>
</tr>
</tbody>
</table>

USB\_nHWRXBUF field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>15–8</td>
<td>Buffer total size for all receive endpoints is (2(^{RXADD})). RX Buffer size is: (2(^{RXADD}) * 4 Bytes. These bits are set to '08h', so buffer size is 256*4 Bytes. There is a single Receive FIFO buffer in the USB controller. The buffer is shared for all endpoints for the OTG controller in device mode.</td>
</tr>
<tr>
<td>RXBURST</td>
<td>Default burst size for memory to RX buffer transfer. This is reset value of RXPBURST bits in USB core register USB_n_BURSTSIZE. Please see Programmable Burst Size (USB_nBURSTSIZE).</td>
</tr>
</tbody>
</table>

42.7.7 General Purpose Timer #0 Load (USB\_nGPTIMER0LD)

This register controls load value of the count timer in register n\_GPTIMER0CTRL. Please see General Purpose Timer #0 Controller (USB\_nGPTIMER0CTRL).

Address: 402E_0000h base + 80h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>GPTLD</td>
</tr>
</tbody>
</table>

USB\_nGPTIMER0LD field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>GPTLD</td>
<td>General Purpose Timer Load Value These bit fields are loaded to GPTCNT bits when GPTRST bit is set '1b'. This value represents the time in microseconds minus 1 for the timer duration.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
USB\_nGPTIMER0LD field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Example: for a one millisecond timer, load 1000-1=999 or 0x0003E7.</td>
</tr>
<tr>
<td></td>
<td>NOTE: Max value is 0xFFFFFFFF or 16.777215 seconds.</td>
</tr>
</tbody>
</table>

42.7.8 General Purpose Timer #0 Controller (USB\_nGPTIMEROCTRL)

This register contains the control for this countdown timer and a data field can be queried to determine the running count value. This timer has granularity on 1 us and can be programmed to a little over 16 seconds. There are two counter modes which are described in the register table below. When the timer counter value transitions to zero, an interrupt could be generated if enabled.

Interrupt status bit is TI0 bit in n_USBSTS register (See USB Status Register (USB\_nUSBSTS) ), interrupt enable bit is TIE0 bit in n_USBINTR register. (See Interrupt Enable Register (USB\_nUSBINTR) .)

Address: 402E\_0000h base + 84h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>GPTRUN</td>
<td>GPTFRST</td>
<td>Reserved</td>
<td>GPTMODE</td>
<td>GPTCNT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>GPTCNT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

USB\_nGPTIMEROCTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>General Purpose Timer Run</td>
</tr>
<tr>
<td>GPTRUN</td>
<td>GPTCNT bits are not effected when setting or clearing this bit.</td>
</tr>
<tr>
<td>0</td>
<td>Stop counting</td>
</tr>
<tr>
<td>1</td>
<td>Run</td>
</tr>
<tr>
<td>30</td>
<td>General Purpose Timer Reset</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB\_nGPTIMER0CTRL field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No action</td>
</tr>
<tr>
<td>1</td>
<td>Load counter value from GPTLD bits in n_GPTIMER0LD</td>
</tr>
<tr>
<td>29–25</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>24</td>
<td>General Purpose Timer Mode</td>
</tr>
<tr>
<td></td>
<td>In one shot mode, the timer will count down to zero, generate an interrupt, and stop until the counter is reset by software;</td>
</tr>
<tr>
<td></td>
<td>In repeat mode, the timer will count down to zero, generate an interrupt and automatically reload the counter value from GPTLD bits to start again.</td>
</tr>
<tr>
<td>0</td>
<td>One Shot Mode</td>
</tr>
<tr>
<td>1</td>
<td>Repeat Mode</td>
</tr>
<tr>
<td>GPTCNT</td>
<td>General Purpose Timer Counter.</td>
</tr>
<tr>
<td></td>
<td>This field is the count value of the countdown timer.</td>
</tr>
</tbody>
</table>

### 42.7.9 General Purpose Timer #1 Load (USB\_nGPTIMER1LD)

This register controls load value of the count timer in register n\_GPTIMER1CTRL. Please see General Purpose Timer #1 Controller (USB\_nGPTIMER1CTRL).

Address: 402E\_0000h base + 88h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>GPTLD</td>
<td>General Purpose Timer Load Value</td>
</tr>
<tr>
<td></td>
<td>These bit fields are loaded to GPTCNT bits when GPTRST bit is set ‘1b’.</td>
</tr>
<tr>
<td></td>
<td>This value represents the time in microseconds minus 1 for the timer duration.</td>
</tr>
<tr>
<td></td>
<td>Example: for a one millisecond timer, load 1000-1=999 or 0x0003E7.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Max value is 0xFFFFFF or 16.777215 seconds.</td>
</tr>
</tbody>
</table>
42.7.10 General Purpose Timer #1 Controller  
(USB_nGPTIMER1CTRL)

This register contains the control for this countdown timer and a data field can be queried to determine the running count value. This timer has granularity on 1 us and can be programmed to a little over 16 seconds. There are two counter modes which are described in the register table below. When the timer counter value transitions to zero, an interrupt could be generated if enable.

Interrupt status bit is TI1 bit in USB_n_USBSTS register (See USB Status Register (USB_nUSBSTS) ), interrupt enable bit is TIE1 bit in n_USBINTR register (See Interrupt Enable Register (USB_nUSBINTR) )

Address: $402E_{0000h} \text{ base} + 8Ch \text{ offset} + (512d \times i)$, where $i=0d$ to $1d$

### USB_nGPTIMER1CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>GPTRUN General Purpose Timer Run</td>
</tr>
<tr>
<td></td>
<td>GPTCNT bits are not effected when setting or clearing this bit.</td>
</tr>
<tr>
<td>30</td>
<td>GPTRST General Purpose Timer Reset</td>
</tr>
<tr>
<td></td>
<td>0 No action</td>
</tr>
<tr>
<td></td>
<td>1 Load counter value from GPTLD bits in USB_n_GPTIMER0LD</td>
</tr>
<tr>
<td>29–25</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>24</td>
<td>GPTMODE General Purpose Timer Mode</td>
</tr>
<tr>
<td></td>
<td>In one shot mode, the timer will count down to zero, generate an interrupt,</td>
</tr>
<tr>
<td></td>
<td>and stop until the counter is reset by software. In repeat mode, the timer</td>
</tr>
<tr>
<td></td>
<td>will count down to zero, generate an interrupt and automatically reload</td>
</tr>
<tr>
<td></td>
<td>the counter value from GPTLD bits to start again.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB_nGPTIMER1CTRL field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>One Shot Mode</td>
</tr>
<tr>
<td>1</td>
<td>Repeat Mode</td>
</tr>
<tr>
<td>GPTCNT</td>
<td>General Purpose Timer Counter.</td>
</tr>
<tr>
<td></td>
<td>This field is the count value of the countdown timer.</td>
</tr>
</tbody>
</table>

### 42.7.11 System Bus Config (USB_nSBUSCFG)

**Address:** 402E_0000h base + 90h offset + (512d x i), where i=0d to 1d

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| W    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   |

**USB_nSBUSCFG field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>29–0</td>
<td>Reserved</td>
</tr>
<tr>
<td>AHBBRST</td>
<td>AHB master interface Burst configuration</td>
</tr>
<tr>
<td></td>
<td>These bits control AHB master transfer type sequence (or priority).</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> This register overrides n_BURSTSIZE register when its value is not zero.</td>
</tr>
<tr>
<td>000</td>
<td>Incremental burst of unspecified length only</td>
</tr>
<tr>
<td>001</td>
<td>INCR4 burst, then single transfer</td>
</tr>
<tr>
<td>010</td>
<td>INCR8 burst, INCR4 burst, then single transfer</td>
</tr>
<tr>
<td>011</td>
<td>INCR16 burst, INCR8 burst, INCR4 burst, then single transfer</td>
</tr>
<tr>
<td>100</td>
<td>Reserved, don't use</td>
</tr>
<tr>
<td>101</td>
<td>INCR4 burst, then incremental burst of unspecified length</td>
</tr>
<tr>
<td>110</td>
<td>INCR8 burst, INCR4 burst, then incremental burst of unspecified length</td>
</tr>
<tr>
<td>111</td>
<td>INCR16 burst, INCR8 burst, INCR4 burst, then incremental burst of unspecified length</td>
</tr>
</tbody>
</table>
42.7.12 Capability Registers Length (USB\_nCAPLENGTH)

The Capability Registers Length register contains the address offset to the Operational registers relative to the CAPLENGTH register.

Address: 402E\_0000h base + 100h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>CAPLENGTH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

USB\_nCAPLENGTH field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CAPLENGTH</td>
<td>These bits are used as an offset to add to register base to find the beginning of the Operational Register. Default value is ‘40h’.</td>
</tr>
</tbody>
</table>

42.7.13 Host Controller Interface Version (USB\_nHCIVERSION)

This is a 2-byte register containing a BCD encoding of the EHCI revision number supported by this host controller. The most significant byte of this register represents a major revision and the least significant byte is the minor revision.

Address: 402E\_0000h base + 102h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>HCIVERSION</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

USB\_nHCIVERSION field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>HCIVERSION</td>
<td>Host Controller Interface Version Number</td>
</tr>
<tr>
<td></td>
<td>Default value is ‘10h’, which means EHCI rev1.0.</td>
</tr>
</tbody>
</table>
42.7.14 Host Controller Structural Parameters (USB_nHCSPARAMS)

The following figure shows the port steering logic capabilities of Host Control Structural Parameters (n_HCSPARAMS).

Address: 402E_0000h base + 104h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Reserved</th>
<th>N_TT</th>
<th>N_PTT</th>
<th>Reserved</th>
<th>PI</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>N_CC</th>
<th>N_PCC</th>
<th>Reserved</th>
<th>PPC</th>
<th>N_PORTS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**USB_nHCSPARAMS field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>27–24</td>
<td>Number of Transaction Translators (N_TT). Default value '0000b' This field indicates the number of embedded transaction translators associated with the USB2.0 host controller. These bits would be set to '0001b' for Multi-Port Host, and '0000b' for Single-Port Host.</td>
</tr>
<tr>
<td>23–20</td>
<td>Number of Ports per Transaction Translator (N_PTT). Default value '0000b' This field indicates the number of ports assigned to each transaction translator within the USB2.0 host controller. These bits would be set to equal N_PORTS for Multi-Port Host, and '0000b' for Single-Port Host.</td>
</tr>
<tr>
<td>19–17</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16</td>
<td>Port Indicators (P INDICATOR) This bit indicates whether the ports support port indicator control. When set to one, the port status and control registers include a read/writeable field for controlling the state of the port indicator This bit is '1b' in all controller core.</td>
</tr>
<tr>
<td>15–12</td>
<td>Number of Companion Controller (N_CC). This field indicates the number of companion controllers associated with this USB2.0 host controller. These bits are '0000b' in all controller core. 0 There is no internal Companion Controller and port-ownership hand-off is not supported. 1 There are internal companion controller(s) and port-ownership hand-offs is supported.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### USB_nHCSPARAMS field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11–8 N_PCC</td>
<td>Number of Ports per Companion Controller</td>
</tr>
<tr>
<td></td>
<td>This field indicates the number of ports supported per internal Companion Controller. It is used to indicate the port routing configuration to the system software. For example, if N_PORTS has a value of 6 and N_CC has a value of 2 then N_PCC could have a value of 3. The convention is that the first N_PCC ports are assumed to be routed to companion controller 1, the next N_PCC ports to companion controller 2, etc. In the previous example, the N_PCC could have been 4, where the first 4 are routed to companion controller 1 and the last two are routed to companion controller 2. The number in this field must be consistent with N_PORTS and N_CC. These bits are '0000b' in all controller core.</td>
</tr>
<tr>
<td>7–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4 PPC</td>
<td>Port Power Control</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether the host controller implementation includes port power control. A one indicates the ports have port power switches. A zero indicates the ports do not have port power switches. The value of this field affects the functionality of the Port Power field in each port status and control register.</td>
</tr>
<tr>
<td>N_PORTS</td>
<td>Number of downstream ports. This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register. Valid values are in the range of 1h to Fh. A zero in this field is undefined. These bits are always set to '0001b' because all controller cores are Single-Port Host.</td>
</tr>
</tbody>
</table>
42.7.15 Host Controller Capability Parameters
(USB_nHCCPARAMS)

This register identifies multiple mode control (time-base bit functionality), addressing capability.

Address: 402E_0000h base + 108h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
**USB_nHCCPARAMS field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–16 - | This field is reserved.  
Reserved |
| 15–8 EECP | EHCI Extended Capabilities Pointer.  
This field indicates the existence of a capabilities list. A value of 00h indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space of the first EHCI extended capability. The pointer value must be 40h or greater if implemented to maintain the consistency of the PCI header defined for this class of device.  
**NOTE:** These bits are set '00h' in all controller core. |
| 7–4 IST | Isochronous Scheduling Threshold.  
This field indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule. When bit [7] is zero, the value of the least significant 3 bits indicates the number of micro-frames a host controller can hold a set of isochronous data structures (one or more) before flushing the state. When bit [7] is a one, then host software assumes the host controller may cache an isochronous data structure for an entire frame.  
These bits are set '00h' in all controller core. |
| 3 - | This field is reserved.  
Reserved |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 2 ASP | Asynchronous Schedule Park Capability  
If this bit is set to a one, then the host controller supports the park feature for high-speed queue heads in the Asynchronous Schedule. The feature can be disabled or enabled and set to a specific level by using the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USBCMD register.  
**NOTE:** ASP bit reset value: '00b' for OTG controller core, '11b' for Host-only controller core. |
| 1 PFL | Programmable Frame List Flag  
If this bit is set to zero, then the system software must use a frame list length of 1024 elements with this host controller. The USBCMD register Frame List Size field is a read-only register and must be set to zero.  
If set to a one, then the system software can specify and use a smaller frame list and configure the host controller via the USBCMD register Frame List Size field. The frame list must always be aligned on a 4K-page boundary. This requirement ensures that the frame list is always physically contiguous.  
This bit is set '1b' in all controller core. |
| 0 ADC | 64-bit Addressing Capability  
This bit is set '0b' in all controller core, no 64-bit addressing capability is supported. |

### 42.7.16 Device Controller Interface Version (USB\_nDCIVERSION)

This register indicates the two-byte BCD encoding of the device controller interface version number.

Address: 402E\_0000h base + 120h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>(\text{DCIVERSION})</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| DCIVERSION | Device Controller Interface Version Number  
Default value is '01h', which means rev0.1. |
42.7.17 Device Controller Capability Parameters (USB_nDCCPARAMS)

These fields describe the overall device capability of the controller.

Address: 402E_0000h base + 124h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### USB_nDCCPARAMS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–9</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>8 HC</td>
<td>Host Capable</td>
</tr>
<tr>
<td></td>
<td>When this bit is 1, this controller is capable of operating as an EHCI compatible USB 2.0 host controller.</td>
</tr>
<tr>
<td>7 DC</td>
<td>Device Capable</td>
</tr>
<tr>
<td></td>
<td>When this bit is 1, this controller is capable of operating as a USB 2.0 device.</td>
</tr>
<tr>
<td>6–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>DEN</td>
<td>Device Endpoint Number</td>
</tr>
<tr>
<td></td>
<td>This field indicates the number of endpoints built into the device controller. If this controller is not device capable, then this field will be zero. Valid values are 0 - 15.</td>
</tr>
</tbody>
</table>
42.7.18 USB Command Register (USB_nUSBCMD)

The Command Register indicates the command to be executed by the serial bus host/device controller. Writing to the register causes a command to be executed.

Address: $402E_0000h + 140h + (512d \times i)$, where $i=0d$ to $1d$

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

USB_nUSBCMD field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>Interrupt Threshold Control -Read/Write.</td>
</tr>
<tr>
<td>ITC</td>
<td>The system software uses this field to set the maximum rate at which the host/device controller will issue interrupts. ITC contains the maximum interrupt interval measured in micro-frames. Valid values are shown below.</td>
</tr>
<tr>
<td></td>
<td>Value Maximum Interrupt Interval</td>
</tr>
<tr>
<td>0x00</td>
<td>Immediate (no threshold)</td>
</tr>
<tr>
<td>0x01</td>
<td>1 micro-frame</td>
</tr>
<tr>
<td>0x02</td>
<td>2 micro-frames</td>
</tr>
<tr>
<td>0x04</td>
<td>4 micro-frames</td>
</tr>
<tr>
<td>0x08</td>
<td>8 micro-frames</td>
</tr>
<tr>
<td>0x10</td>
<td>16 micro-frames</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB\_nUSBCMD field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x20</td>
<td>32 micro-frames</td>
</tr>
<tr>
<td>0x40</td>
<td>64 micro-frames</td>
</tr>
</tbody>
</table>

**15**

**FS\_2**  
Frame List Size - (Read/Write or Read Only). [host mode only]  
This field is Read/Write only if Programmable Frame List Flag in the HCCPARAMS registers is set to one.  
This field specifies the size of the frame list that controls which bits in the Frame Index Register should be used for the Frame List Current index.  

**NOTE:** This field is made up from USBCMD bits 15, 3 and 2.  

<table>
<thead>
<tr>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>1024 elements (4096 bytes) Default value</td>
</tr>
<tr>
<td>001</td>
<td>512 elements (2048 bytes)</td>
</tr>
<tr>
<td>010</td>
<td>256 elements (1024 bytes)</td>
</tr>
<tr>
<td>011</td>
<td>128 elements (512 bytes)</td>
</tr>
<tr>
<td>100</td>
<td>64 elements (256 bytes)</td>
</tr>
<tr>
<td>101</td>
<td>32 elements (128 bytes)</td>
</tr>
<tr>
<td>110</td>
<td>16 elements (64 bytes)</td>
</tr>
<tr>
<td>111</td>
<td>8 elements (32 bytes)</td>
</tr>
</tbody>
</table>

**14**

**ATDTW**  
Add dTD TripWire - Read/Write. [device mode only]  
This bit is used as a semaphore to ensure proper addition of a new dTD to an active (primed) endpoint's linked list. This bit is set and cleared by software.  
This bit would also be cleared by hardware when state machine is hazard region for which adding a dTD to a primed endpoint may go unrecognized.

**13**

**SUTW**  
Setup TripWire - Read/Write. [device mode only]  
This bit is used as a semaphore to ensure that the setup data payload of 8 bytes is extracted from a QH by the DCD without being corrupted. If the setup lockout mode is off (SLOM bit in USB core register n_USBMODE, see **USB Device Mode** (USB\_nUSBMODE) ) then there is a hazard when new setup data arrives while the DCD is copying the setup data payload from the QH for a previous setup packet. This bit is set and cleared by software.  
This bit would also be cleared by hardware when a hazard detected.

**12**

This field is reserved.  
Reserved

**11**

**ASPE**  
Asynchronous Schedule Park Mode Enable - Read/Write.  
If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit defaults to a 1h and is R/W. Otherwise the bit must be a zero and is RO. Software uses this bit to enable or disable Park mode. When this bit is one, Park mode is enabled. When this bit is a zero, Park mode is disabled.  

**NOTE:** ASPE bit reset value: ‘0b’ for OTG controller.

**10**

This field is reserved.  
Reserved

**9–8**

**ASP**  
Asynchronous Schedule Park Mode Count - Read/Write.  
If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this field defaults to 3h and is R/W. Otherwise it defaults to zero and is Read-Only. It contains a count of the number of successive transactions the host controller is allowed to execute from a high-speed queue head on the

*Table continues on the next page...*
### USB_nUSBCMD field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Asynchronous schedule before continuing traversal of the Asynchronous schedule. Valid values are 1h to 3h. Software must not write a zero to this bit when Park Mode Enable is a one as this will result in undefined behavior. This field is set to 3h in all controller core.</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Interrupt on Async Advance Doorbell - Read/Write. This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell. When the host controller has evicted all appropriate cached schedule states, it sets the Interrupt on Async Advance status bit in the USBSTS register. If the Interrupt on Sync Advance Enable bit in the USBINTR register is one, then the host controller will assert an interrupt at the next interrupt threshold. The host controller sets this bit to zero after it has set the Interrupt on Sync Advance status bit in the USBSTS register to one. Software should not write a one to this bit when the asynchronous schedule is inactive. Doing so will yield undefined results. This bit is only used in host mode. Writing a one to this bit when device mode is selected will have undefined results.</td>
</tr>
<tr>
<td>5</td>
<td>Asynchronous Schedule Enable - Read/Write. Default 0b. This bit controls whether the host controller skips processing the Asynchronous Schedule. Only the host controller uses this bit. Values Meaning 0 Do not process the Asynchronous Schedule. 1 Use the ASYNCLISTADDR register to access the Asynchronous Schedule.</td>
</tr>
<tr>
<td>4</td>
<td>Periodic Schedule Enable - Read/Write. Default 0b. This bit controls whether the host controller skips processing the Periodic Schedule. Only the host controller uses this bit. Values Meaning 0 Do not process the Periodic Schedule 1 Use the PERIODICLISTBASE register to access the Periodic Schedule.</td>
</tr>
<tr>
<td>3–2</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Controller Reset (RESET) - Read/Write. Software uses this bit to reset the controller. This bit is set to zero by the Host/Device Controller when the reset process is complete. Software cannot terminate the reset process early by writing a zero to this register. Host operation mode: When software writes a one to this bit, the Controller resets its internal pipelines, timers, counters, state machines etc. to their initial value. Any transaction currently in progress on USB is immediately terminated. A USB reset is not driven on downstream ports. Software should not set this bit to a one when the HCHalted bit in the USBSTS register is a zero. Attempting to reset an actively running host controller will result in undefined behavior. Device operation mode:</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### USB_nUSBCMD field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>When software writes a one to this bit, the Controller resets its internal pipelines, timers, counters, state machines etc. to their initial value. Writing a one to this bit when the device is in the attached state is not recommended, because the effect on an attached host is undefined. In order to ensure that the device is not in an attached state before initiating a device controller reset, all primed endpoints should be flushed and the USBCMD Run/Stop bit should be set to 0.</td>
<td></td>
</tr>
<tr>
<td>0 RS</td>
<td>Run/Stop (RS) - Read/Write. Default 0b. 1=Run. 0=Stop.</td>
</tr>
<tr>
<td>Host operation mode: When set to ‘1b’, the Controller proceeds with the execution of the schedule. The Controller continues execution as long as this bit is set to a one. When this bit is set to 0, the Host Controller completes the current transaction on the USB and then halts. The HC Halted bit in the status register indicates when the Controller has finished the transaction and has entered the stopped state. Software should not write a one to this field unless the controller is in the Halted state (that is, HCHalted in the USBSTS register is a one).</td>
<td></td>
</tr>
<tr>
<td>Device operation mode: Writing a one to this bit will cause the controller to enable a pull-up on D+ and initiate an attach event. This control bit is not directly connected to the pull-up enable, as the pull-up will become disabled upon transitioning into high-speed mode. Software should use this bit to prevent an attach event before the controller has been properly initialized. Writing a 0 to this will cause a detach event.</td>
<td></td>
</tr>
</tbody>
</table>

---

*Chapter 42 Universal Serial Bus Controller (USB)*

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
42.7.19  USB Status Register (USB_nUSBSTS)

This register indicates various states of the Host/Device Controller and any pending interrupts. This register does not indicate status resulting from a transaction on the serial bus.

Address: 402E_0000h base + 144h offset + (512d × i), where i=0d to 1d
### USB_{n}USBSTS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–26 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>25 TI1</td>
<td>General Purpose Timer Interrupt 1 (GPTINT1) -- R/W/C. This bit is set when the counter in the GPTIMER1CTRL register transitions to zero, writing a one to this bit will clear it.</td>
</tr>
<tr>
<td>24 TI0</td>
<td>General Purpose Timer Interrupt 0 (GPTINT0) -- R/W/C. This bit is set when the counter in the GPTIMER0CTRL register transitions to zero, writing a one to this bit clears it.</td>
</tr>
<tr>
<td>23–17 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>16 NAKI</td>
<td>NAK Interrupt Bit -- RO. This bit is set by hardware when for a particular endpoint both the TX/RX Endpoint NAK bit and corresponding TX/RX Endpoint NAK Enable bit are set. This bit is automatically cleared by hardware when all Enabled TX/RX Endpoint NAK bits are cleared.</td>
</tr>
<tr>
<td>15 AS</td>
<td>Asynchronous Schedule Status - Read Only. This bit reports the current real status of the Asynchronous Schedule. When set to zero the asynchronous schedule status is disabled and if set to one the status is enabled. The Host Controller is not required to immediately disable or enable the Asynchronous Schedule when software transitions the Asynchronous Schedule Enable bit in the USBCMD register. When this bit and the Asynchronous Schedule Enable bit are the same value, the Asynchronous Schedule is either enabled (1) or disabled (0). Only used in the host operation mode.</td>
</tr>
<tr>
<td>14 PS</td>
<td>Periodic Schedule Status - Read Only.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>This bit reports the current real status of the Periodic Schedule. When set to zero the periodic schedule is disabled, and if set to one the status is enabled. The Host Controller is not required to immediately disable or enable the Periodic Schedule when software transitions the Periodic Schedule Enable bit in the USBCMD register. When this bit and the Periodic Schedule Enable bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0). Only used in the host operation mode.</td>
<td></td>
</tr>
<tr>
<td>13 RCL</td>
<td>Reclamation - Read Only. This is a read-only status bit used to detect an empty asynchronous schedule. Only used in the host operation mode.</td>
</tr>
<tr>
<td>12 HCH</td>
<td>HCHalted - Read Only. This bit is a zero whenever the Run/Stop bit is a one. The Controller sets this bit to one after it has stopped executing because of the Run/Stop bit being set to 0, either by software or by the Controller hardware (for example, an internal error). Only used in the host operation mode. Default value is '0b' for OTG core. This is because OTG core is not operating as host in default. Please see CM bit in USB_n_USBMODE register.</td>
</tr>
<tr>
<td>11 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>10 ULPI</td>
<td>ULPI Interrupt - R/WC. This bit will be set ‘1b’ by hardware when there is an event completion in ULPI viewport. This bit is usable only if the controller support UPLI interface mode.</td>
</tr>
<tr>
<td>9 -</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>8 SLI</td>
<td>DCSuspend - R/WC. When a controller enters a suspend state from an active state, this bit will be set to a one. The device controller clears the bit upon exiting from a suspend state. Only used in device operation mode.</td>
</tr>
<tr>
<td>7 SRI</td>
<td>SOF Received - R/WC. When the device controller detects a Start Of (micro) Frame, this bit will be set to a one. When a SOF is extremely late, the device controller will automatically set this bit to indicate that an SOF was expected. Therefore, this bit will be set roughly every 1ms in device FS mode and every 125ms in HS mode and will be synchronized to the actual SOF that is received. Because the device controller is initialized to FS before connect, this bit will be set at an interval of 1ms during the prelude to connect and chirp. In host mode, this bit will be set every 125us and can be used by host controller driver as a time base. Software writes a 1 to this bit to clear it.</td>
</tr>
<tr>
<td>6 URI</td>
<td>USB Reset Received - R/WC. When the device controller detects a USB Reset and enters the default state, this bit will be set to a one. Software can write a 1 to this bit to clear the USB Reset Received status bit. Only used in device operation mode.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB_nUSBSTS field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 5 AAI | Interrupt on Async Advance - R/WC.  
System software can force the host controller to issue an interrupt the next time the host controller advances the asynchronous schedule by writing a one to the Interrupt on Async Advance Doorbell bit in the n_USBCMD register. This status bit indicates the assertion of that interrupt source.  
Only used in host operation mode. |
| 4 SEI | System Error- R/WC.  
This bit is will be set to '1b' when an Error response is seen to a read on the system interface. |
| 3 FRI | Frame List Rollover - R/WC.  
The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size (as programmed in the Frame List Size field of the USB_n_USBCMD register) is 1024, the Frame Index Register rolls over every time FRINDEX [13] toggles. Similarly, if the size is 512, the Host Controller sets this bit to a one every time FHINDEX [12] toggles.  
Only used in host operation mode. |
| 2 PCI | Port Change Detect - R/WC.  
The Host Controller sets this bit to a one when on any port a Connect Status occurs, a Port Enable/Disable Change occurs, or the Force Port Resume bit is set as the result of a J-K transition on the suspended port.  
The Device Controller sets this bit to a one when the port controller enters the full or high-speed operational state. When the port controller exits the full or high-speed operation states due to Reset or Suspend events, the notification mechanisms are the USB Reset Received bit and the DCSuspend bits respectively. |
| 1 UEI | USB Error Interrupt (USBERRINT) - R/WC.  
When completion of a USB transaction results in an error condition, this bit is set by the Host/Device Controller. This bit is set along with the USBINT bit, if the TD on which the error interrupt occurred also had its interrupt on complete (IOC) bit set.  
The device controller detects resume signaling only. |
| 0 UI | USB Interrupt (USBINT) - R/WC.  
This bit is set by the Host/Device Controller when the cause of an interrupt is a completion of a USB transaction where the Transfer Descriptor (TD) has an interrupt on complete (IOC) bit set.  
This bit is also set by the Host/Device Controller when a short packet is detected. A short packet is when the actual number of bytes received was less than the expected number of bytes. |
42.7.20 Interrupt Enable Register (USB_nUSBINTR)

The interrupts to software are enabled with this register. An interrupt is generated when a bit is set and the corresponding interrupt source is active. The USB Status register (n_USBSTS) still shows interrupt sources even if they are disabled by the n_USBINTR register, allowing polling of interrupt events by the software.

Address: 402E_0000h base + 148h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**USB_nUSBINTR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–26</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>25</td>
<td>General Purpose Timer #1 Interrupt Enable</td>
</tr>
<tr>
<td>TIE1</td>
<td>When this bit is one and the TI1 bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td>24</td>
<td>General Purpose Timer #0 Interrupt Enable</td>
</tr>
<tr>
<td>TIE0</td>
<td>When this bit is one and the TI0 bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td>23–20</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>19</td>
<td>USB Host Periodic Interrupt Enable</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB_nUSBINTR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>18 UAIE</td>
<td>USB Host Asynchronous Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one, and the UAI bit in the n_USBSTS register is one, host controller will issue an interrupt at the next interrupt threshold.</td>
</tr>
<tr>
<td>17</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>16 NAKE</td>
<td>NAK Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the NAKI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td>15–11</td>
<td>These bits are reserved and should be set to zero.</td>
</tr>
<tr>
<td>10 ULPIE</td>
<td>ULPI Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the UPLII bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td></td>
<td>This bit is usable only if the controller support UPLI interface mode.</td>
</tr>
<tr>
<td>9</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
<tr>
<td>8 SLE</td>
<td>Sleep Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the SLI bit in n_n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td></td>
<td>Only used in device operation mode.</td>
</tr>
<tr>
<td>7 SRE</td>
<td>SOF Received Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the SRI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td>6 URE</td>
<td>USB Reset Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the URI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td></td>
<td>Only used in device operation mode.</td>
</tr>
<tr>
<td>5 AAE</td>
<td>Async Advance Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the AAI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td></td>
<td>Only used in device operation mode.</td>
</tr>
<tr>
<td>4 SEE</td>
<td>System Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the SEI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td></td>
<td>Only used in host operation mode.</td>
</tr>
<tr>
<td>3 FRE</td>
<td>Frame List Rollover Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the FRI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td></td>
<td>Only used in host operation mode.</td>
</tr>
<tr>
<td>2 PCE</td>
<td>Port Change Detect Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the PCI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td>1 UEE</td>
<td>USB Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the UEI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
<tr>
<td>0 UE</td>
<td>USB Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When this bit is one and the UI bit in n_USBSTS register is a one the controller will issue an interrupt.</td>
</tr>
</tbody>
</table>
42.7.21  USB Frame Index (USB_nFRINDEX)

This register is used by the host controller to index the periodic frame list. The register updates every 125 microseconds (once each micro-frame). Bits [N: 3] are used to select a particular entry in the Periodic Frame List during periodic schedule execution. The number of bits used for the index depends on the size of the frame list as set by system software in the Frame List Size field in the n_USBCMD register.

This register must be written as a DWord. Byte writes produce undefined results. This register cannot be written unless the Host Controller is in the 'Halted' state as indicated by the HCHalted bit. A write to this register while the Run/Stop hit is set to a one produces undefined results. Writes to this register also affect the SOF value.

In device mode this register is read only and, the device controller updates the FRINDEX [13:3] register from the frame number indicated by the SOF marker. Whenever a SOF is received by the USB bus, FRINDEX [13:3] will be checked against the SOF marker. If FRINDEX [13:3] is different from the SOF marker, FRINDEX [13:3] will be set to the SOF value and FRINDEX [2:0] will be set to zero (that is, SOF for 1 ms frame). If FRINDEX [13:3] is equal to the SOF value, FRINDEX [2:0] will be increment (that is, SOF for 125 us micro-frame.).

Address: 402E_0000h base + 14Ch offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–14</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>FRINDEX</td>
<td>Frame Index.</td>
</tr>
</tbody>
</table>

The value, in this register, increments at the end of each time frame (micro-frame). Bits [N: 3] are used for the Frame List current index. This means that each location of the frame list is accessed 8 times (frames or micro-frames) before moving to the next index.

The following illustrates values of N based on the value of the Frame List Size field in the USBCMD register, when used in host mode.

<table>
<thead>
<tr>
<th>USBCMD [Frame List Size] Number Elements N</th>
</tr>
</thead>
<tbody>
<tr>
<td>In device mode the value is the current frame number of the last frame transmitted. It is not used as an index.</td>
</tr>
<tr>
<td>In either mode bits 2:0 indicate the current microframe.</td>
</tr>
<tr>
<td>000 (1024) 12</td>
</tr>
<tr>
<td>001 (512) 11</td>
</tr>
</tbody>
</table>

Table continues on the next page...
USB_nFRINDEX field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>(256) 10</td>
</tr>
<tr>
<td>011</td>
<td>(128) 9</td>
</tr>
<tr>
<td>100</td>
<td>(64) 8</td>
</tr>
<tr>
<td>101</td>
<td>(32) 7</td>
</tr>
<tr>
<td>110</td>
<td>(16) 6</td>
</tr>
<tr>
<td>111</td>
<td>(8) 5</td>
</tr>
</tbody>
</table>

42.7.22 Frame List Base Address (USB_nPERIODICLISTBASE)

Host Controller only

This 32-bit register contains the beginning address of the Periodic Frame List in the system memory. HCD loads this register prior to starting the schedule execution by the Host Controller. The memory structure referenced by this physical memory pointer is assumed to be 4-Kbyte aligned. The contents of this register are combined with the Frame Index Register (USB_n_FRINDEX) to enable the Host Controller to step through the Periodic Frame List in sequence.

Address: 402E_0000h base + 154h offset + (512d × i), where i=0d to 1d

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   | BASEADR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reserved |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

USB_nPERIODICLISTBASE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12</td>
<td>Base Address (Low).</td>
</tr>
<tr>
<td>BASEADR</td>
<td>These bits correspond to memory address signals [31:12], respectively.</td>
</tr>
<tr>
<td></td>
<td>Only used by the host controller.</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
</tr>
</tbody>
</table>

42.7.23 Device Address (USB_nDEVICEADDR)

Device Controller only

The upper seven bits of this register represent the device address. After any controller reset or a USB reset, the device address is set to the default address (0). The default address will match all incoming addresses. Software shall reprogram the address after receiving a SET_ADDRESS descriptor.
Address: 402E_0000h base + 154h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>USBADR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>USBADRA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**USB_nDEVICEADDR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–25 USBADR</td>
<td>Device Address. These bits correspond to the USB device address</td>
</tr>
<tr>
<td>24 USBADRA</td>
<td>Device Address Advance. Default=0. When this bit is '0', any writes to USBADR are instantaneous. When this bit is written to a '1' at the same time or before USBADR is written, the write to the USBADR field is staged and held in a hidden register. After an IN occurs on endpoint 0 and is ACKed, USBADR will be loaded from the holding register. Hardware will automatically clear this bit on the following conditions: 1) IN is ACKed to endpoint 0. (USBADR is updated from staging register). 2) OUT/SETUP occur to endpoint 0. (USBADR is not updated). 3) Device Reset occurs (USBADR is reset to 0). <strong>NOTE:</strong> After the status phase of the SET_ADDRESS descriptor, the DCD has 2 ms to program the USBADR field. This mechanism will ensure this specification is met when the DCD can not write of the device address within 2ms from the SET_ADDRESS status phase. If the DCD writes the USBADR with USBADRA=1 after the SET_ADDRESS data phase (before the prime of the status phase), the USBADR will be programmed instantly at the correct time and meet the 2ms USB requirement.</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

### 42.7.24 Next Asynch. Address (USB_nASYNCLISTADDR)

Host Controller only

This 32-bit register contains the address of the next asynchronous queue head to be executed by the host. Bits [4:0] of this register cannot be modified by the system software and will always return a zero when read.
Address: 402E_0000h base + 158h offset + (512d × i), where i=0d to 1d

### USB_nASYNCLISTADDR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–5 ASYBASE</td>
<td>Link Pointer Low (LPL). These bits correspond to memory address signals [31:5], respectively. This field may only reference a Queue Head (QH). Only used by the host controller.</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

#### 42.7.25 Endpoint List Address (USB_nENDPTLISTADDR)

Device Controller only

In device mode, this register contains the address of the top of the endpoint list in system memory. Bits [10:0] of this register cannot be modified by the system software and will always return a zero when read.

The memory structure referenced by this physical memory pointer is assumed 64-byte.

Address: 402E_0000h base + 158h offset + (512d × i), where i=0d to 1d

### USB_nENDPTLISTADDR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–11 EPBASE</td>
<td>Endpoint List Pointer(Low). These bits correspond to memory address signals [31:11], respectively. This field will reference a list of up to 32 Queue Head (QH) (that is, one queue head per endpoint &amp; direction).</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

#### 42.7.26 Programmable Burst Size (USB_nBURSTSIZE)

This register is used to control the burst size used during data movement on the AHB master interface. This register is ignored if AHBBRST bits in SBUSCFG register is non-zero value.
Address: 402E_0000h base + 160h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reserved**

**TXPBURST**

**RXPBurst**

**Reset** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0

---

### 42.7.27 TX FIFO Fill Tuning (USB_nTXFILLTUNING)

The fields in this register control performance tuning associated with how the host controller posts data to the TX latency FIFO before moving the data onto the USB bus. The specific areas of performance include the how much data to post into the FIFO and an estimate for how long that operation should take in the target system.

**Definitions:**

- \( T_0 \) = Standard packet overhead
- \( T_1 \) = Time to send data payload
- \( T_{ff} \) = Time to fetch packet into TX FIFO up to specified level.
- \( T_s \) = Total Packet Flight Time (send-only) packet \( T_s = T_0 + T_1 \)
- \( T_p \) = Total Packet Time (fetch and send) packet \( T_p = T_{ff} + T_0 + T_1 \)

Upon discovery of a transmit (OUT/SETUP) packet in the data structures, host controller checks to ensure \( T_p \) remains before the end of the [micro)frame. If so it proceeds to pre-fill the TX FIFO. If at anytime during the pre-fill operation the time remaining the [micro)frame is < \( T_s \) then the packet attempt ceases and the packet is tried at a later time. Although this is not an error condition and the host controller will eventually recover, a
mark will be made the scheduler health counter to note the occurrence of a "back-off" event. When a back-off event is detected, the partial packet fetched may need to be discarded from the latency buffer to make room for periodic traffic that will begin after the next SOF. Too many back-off events can waste bandwidth and power on the system bus and thus should be minimized (not necessarily eliminated). Back-offs can be minimized with use of the n_TSCHHEALTH (Tff) described below.

**NOTE**
The reset value could vary from instance to instance. Please see the detail in bit field description and ignore reset value in summary table in this case!

Address: 402E_0000h base + 164h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>TXFIFOTHRES</td>
<td>FIFO Burst Threshold. (Read/Write)</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
<td></td>
<td>This register controls the number of data bursts that are posted to the TX latency FIFO in host mode before the packet begins on to the bus. The minimum value is 2 and this value should be as low as possible to maximize USB performance. A higher value can be used in systems with unpredictable latency and/or insufficient bandwidth where the FIFO may underrun because the data transferred from the latency FIFO to USB occurs before it can be replenished from system memory. This value is ignored if the Stream Disable bit in USB_n_USBMODE register is set. Default value is '0Ah for OTG controller core.</td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
<td>15–13 TXSCHHEALTH</td>
<td>Scheduler Health Counter. (Read/Write To Clear)</td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td></td>
<td>This register increments when the host controller fails to fill the TX latency FIFO to the level programmed by TXFIFOTHRES before running out of time to send the packet before the next Start-Of-Frame. This health counter measures the number of times this occurs to provide feedback to selecting a proper TXSCHOH. Writing to this register will clear the counter and this counter will max. at 31. Default value is '00h' for OTG controller core.</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
<td>12–8 TXSCHOH</td>
<td>Scheduler Overhead. (Read/Write) [Default = 0]</td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
<td></td>
<td>This register adds an additional fixed offset to the schedule time estimator described above as Tff. As an approximation, the value chosen for this register should limit the number of back-off events captured in the TXSCHHEALTH to less than 10 per second in a highly utilized bus. Choosing a value that is too high for this register is not desired as it can needlessly reduce USB utilization. The time unit represented in this register is 1.267us when a device is connected in High-Speed Mode. The time unit represented in this register is 6.333us when a device is connected in Low/Full Speed Mode. Default value is '08h' for OTG controller core.</td>
</tr>
</tbody>
</table>

USB_nTXFILLTUNING field descriptions

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### 42.7.28 Endpoint NAK (USB\_nENDPTNAK)

Address: 402E\_0000h base + 178h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>TX Endpoint NAK - R/WC. Each TX endpoint has 1 bit in this field. The bit is set when the device sends a NAK handshake on a received IN token for the corresponding endpoint. Bit [N] - Endpoint #[N], N is 0-7</td>
</tr>
<tr>
<td>15–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>15–8</td>
<td>RX Endpoint NAK - R/WC. Each RX endpoint has 1 bit in this field. The bit is set when the device sends a NAK handshake on a received OUT or PING token for the corresponding endpoint. Bit [N] - Endpoint #[N], N is 0-7</td>
</tr>
</tbody>
</table>

### 42.7.29 Endpoint NAK Enable (USB\_nENDPTNAKEN)

Address: 402E\_0000h base + 17Ch offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>TX Endpoint NAK Enable - R/W. Each bit is an enable bit for the corresponding TX Endpoint NAK bit. If this bit is set and the corresponding TX Endpoint NAK bit is set, the NAK Interrupt bit is set. Bit [N] - Endpoint #[N], N is 0-7</td>
</tr>
<tr>
<td>15–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>15–8</td>
<td>RX Endpoint NAK Enable - R/W.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
42.7.30 Configure Flag Register (USB_nCONFIGFLAG)

Address: 402E_0000h base + 180h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Bit</td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

**USB_nCONFIGFLAG field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>0 CF</td>
<td>Configure Flag</td>
</tr>
<tr>
<td>Host software sets this bit as the last action in its process of configuring the Host Controller. This bit controls the default port-routing control logic.</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Port routing control logic default-routes each port to an implementation dependent classic host controller.</td>
</tr>
<tr>
<td>1</td>
<td>Port routing control logic default-routes all ports to this host controller.</td>
</tr>
</tbody>
</table>

42.7.31 Port Status & Control (USB_nPORTSC1)

Host Controller

A host controller could implement one to eight port status and control registers. The number is determined by N_PORTs bits in HWSPARAMs register (please see Host Controller Structural Parameters (USB_nHCSPARAMS) ). Software could read this parameter register to determine how many ports need service.

All controller cores on this product are Single-Port, so there is only one port status and control register for each controller core.
This register is only reset by power on reset or controller core reset. The initial conditions of a port are:

- No device connected
- Port disabled

If the port supports power control, this state remains until port power is supplied (by software).

Device Controller

A controller operating in device mode has only port register one (PORTSC1) and it does not support power control in that mode. Port control in device mode is only used for status port reset, suspend, and current connect status. It is also used to initiate test mode or force signaling and allows software to put the PHY into low power suspend mode and disable the PHY clock.

Address: \(402E\_0000h\ base + 184h\ offset + (512d \times i)\), where \(i=0d\ to 1d\)

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>PTS_1</td>
<td>STS</td>
<td>PTW</td>
<td>PSPD</td>
<td>PTS_2</td>
<td>PFSC</td>
<td>PHCD</td>
<td>WKDC</td>
<td>WKDC</td>
<td>WKCN</td>
<td>PTC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>PIC</td>
<td>PO</td>
<td>PP</td>
<td>LS</td>
<td>HSP</td>
<td>PR</td>
<td>SUSP</td>
<td>FPR</td>
<td>OCC</td>
<td>OCA</td>
<td>PEC</td>
<td>PE</td>
<td>CSC</td>
<td>CCS</td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### USB_nPORTSC1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–30 PTS_1</td>
<td><strong>NOTE:</strong> All USB port interface modes are listed in this field description, but not all are supported. For detail feature of each controller core, please see <a href="#">Features</a>. The behaviour is unknown when unsupported interface mode is selected.</td>
</tr>
</tbody>
</table>
| 29 STS | Serial Transceiver Select  
1 Serial Interface Engine is selected  
0 Parallel Interface signals is selected  
Serial Interface Engine can be used in combination with UTMI+/ULPI physical interface to provide FS/LS signaling instead of the parallel interface signals.  
When this bit is set ‘1b’, serial interface engine will be used instead of parallel interface signals.  
This bit has no effect unless PTS bits is set to select UTMI+/ULPI interface.  
The Serial/USB1.1 PHY/IC-USB will use the serial interface engine for FS/LS signaling regardless of this bit value. |
| 28 PTW | Parallel Transceiver Width  
This bit has no effect if serial interface engine is used.  
For OTG1/OTG2 core, it is Read-Only. Reset value is ‘1b’.  
0 Select the 8-bit UTMI interface [60MHz]  
1 Select the 16-bit UTMI interface [30MHz] |
| 27–26 PSPD | Port Speed - Read Only.  
This register field indicates the speed at which the port is operating.  
00 Full Speed  
01 Low Speed  
10 High Speed  
11 Undefined |
| 25 PTS_2 | See description at bits 31-30 |
| 24 PFSC | Port Force Full Speed Connect - Read/Write. Default = 0b.  
When this bit is set to ‘1b’, the port will be forced to only connect at Full Speed, It disables the chirp sequence that allows the port to identify itself as High Speed.  
1 Forced to full speed  
0 Normal operation |
| 23 PHCD | PHY Low Power Suspend - Clock Disable (PLPSCD) - Read/Write. Default = 0b.  
When this bit is set to ‘1b’, the PHY clock is disabled. Reading this bit will indicate the status of the PHY clock.  
**NOTE:** The PHY clock cannot be disabled if it is being used as the system clock.  
In device mode, The PHY can be put into Low Power Suspend when the device is not running (USBCMD Run/Stop=0b) or the host has signalled suspend (PORTSC1 SUSPEND=1b). PHY Low power suspend will be cleared automatically when the host initials resume. Before forcing a resume from the device, the device controller driver must clear this bit.  
In host mode, the PHY can be put into Low Power Suspend when the downstream device has been put into suspend mode or when no downstream device is connected. Low power suspend is completely under the control of software. |

*Table continues on the next page...*
### USB_nPORTSC1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 1     | Disable PHY clock  
|       | Enable PHY clock  |
| 22    | Wake on Over-current Enable (WKOC_E) - Read/Write. Default = 0b. Writing this bit to a one enables the port to be sensitive to over-current conditions as wake-up events. This field is zero if Port Power(Port Status & Control (USB_nPORTSC1)) is zero. |
| 21    | Wake on Disconnect Enable (WKDSCNNT_E) - Read/Write. Default = 0b. Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events. This field is zero if Port Power(Port Status & Control (USB_nPORTSC1)) is zero or in device mode. |
| 20    | Wake on Connect Enable (WKCNNT_E) - Read/Write. Default = 0b. Writing this bit to a one enables the port to be sensitive to device connects as wake-up events. This field is zero if Port Power(Port Status & Control (USB_nPORTSC1)) is zero or in device mode. |
| 19–16 | Port Test Control - Read/Write. Default = 0000b. Refer to Port Test Mode for the operational model for using these test modes and the USB Specification Revision 2.0, Chapter 7 for details on each test mode. The FORCE_ENABLE_FS and FORCE ENABLE LS are extensions to the test mode support specified in the EHCI specification. Writing the PTC field to any of the FORCE_ENABLE_{HS/FS/LS} values will force the port into the connected and enabled state at the selected speed. Writing the PTC field back to TEST_MODE_DISABLE will allow the port state machines to progress normally from that point. **NOTE:** Low speed operations are not supported as a peripheral device. Any other value than zero indicates that the port is operating in test mode. Value Specific Test  
|       | TEST_MODE_DISABLE  
|       | J_STATE  
|       | K_STATE  
|       | SE0 (host) / NAK (device)  
|       | Packet  
|       | FORCE_ENABLE_HS  
|       | FORCE_ENABLE_FS  
|       | FORCE_ENABLE_LS  
|       | Reserved  |
| 15–14 | Port Indicator Control - Read/Write. Default = 0b. Writing to this field has no effect if the P_INDICATOR bit in the HCSPARAMS register is a zero. Refer to the USB Specification Revision 2.0 for a description on how these bits are to be used. This field is zero if Port Power is zero. Bit Value Meaning  
|       | Port indicators are off  
|       | Amber  
|       | Green  
|       | Undefined  |
| 13    | Port Owner-Read/Write. Default = 0. |

*Table continues on the next page...*
**USB_nPORTSC1 field descriptions (continued)**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>This bit unconditionally goes to a 0 when the configured bit in the CONFIGFLAG register makes a 0 to 1 transition. This bit unconditionally goes to 1 whenever the Configured bit is zero System software uses this field to release ownership of the port to a selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that an internal companion controller owns and controls the port. Port owner handoff is not supported in all controller cores, therefore this bit will always be 0.</td>
<td></td>
</tr>
<tr>
<td><strong>12</strong> PP</td>
<td>Port Power (PP)-Read/Write or Read Only. The function of this bit depends on the value of the Port Power Switching (PPC) field in the HCSPARAMS register. The behavior is as follows: PPC Operation 0 1b Read Only - Host controller does not have port power control switches. Each port is hard-wired to power. 1 1b/0b - Read/Write. OTG controller requires port power control switches. This bit represents the current setting of the switch (0=off, 1=on). When power is not available on a port (that is, PP equals a 0), the port is non-functional and will not report attaches, detaches, etc. When an over-current condition is detected on a powered port and PPC is a one, the PP bit in each affected port may be transitional by the host controller driver from a one to a zero (removing power from the port). This feature is implemented in all controller cores (PPC = 1).</td>
</tr>
<tr>
<td><strong>11–10</strong> LS</td>
<td>Line Status-Read Only. These bits reflect the current logical levels of the D+ (bit 11) and D- (bit 10) signal lines. In host mode, the use of linestate by the host controller driver is not necessary (unlike EHCI), because the port controller state machine and the port routing manage the connection of LS and FS. In device mode, the use of linestate by the device controller driver is not necessary. The encoding of the bits are: Bits [11:10] Meaning 00 SE0 10 J-state 01 K-state 11 Undefined</td>
</tr>
<tr>
<td><strong>9</strong> HSP</td>
<td>High-Speed Port - Read Only. Default = 0b. When the bit is one, the host/device connected to the port is in high-speed mode and if set to zero, the host/device connected to the port is not in a high-speed mode. <strong>NOTE:</strong> HSP is redundant with PSPD(bit 27, 26) but remained for compatibility.</td>
</tr>
<tr>
<td><strong>8</strong> PR</td>
<td>Port Reset - Read/Write or Read Only. Default = 0b. In Host Mode: Read/Write. 1=Port is in Reset. 0=Port is not in Reset. Default 0. When software writes a one to this bit the bus-reset sequence as defined in the USB Specification Revision 2.0 is started. This bit will automatically change to zero after the reset sequence is complete. This behavior is different from EHCI where the host controller driver is required to set this bit to a zero after the reset duration is timed in the driver.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>7</strong> SUSP</td>
<td></td>
</tr>
</tbody>
</table>
Suspend - Read/Write or Read Only. Default = 0b.  
1=Port in suspend state. 0=Port not in suspend state.  
In Host Mode: Read/Write.  
Port Enabled Bit and Suspend bit of this register define the port states as follows:  
Bits [Port Enabled, Suspend] Port State  
0x Disable  
10 Enable  
11 Suspend  
When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspended and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.  
The host controller will unconditionally set this bit to zero when software sets the Force Port Resume bit to zero. The host controller ignores a write of zero to this bit.  
If host software sets this bit to a one when the port is not enabled (that is, Port enabled bit is a zero) the results are undefined.  
This field is zero if Port Power(Port Status & Control (USB_nPORTSC1)) is zero in host mode.  
In Device Mode: Read Only.  
In device mode this bit is a read only status bit.  

| 6 FPR |  
Force Port Resume - Read/Write. 1= Resume detected/driven on port. 0=No resume (K-state) detected/driven on port. Default = 0.  
In Host Mode:  
Software sets this bit to one to drive resume signaling. The Host Controller sets this bit to one if a J-to-K transition is detected while the port is in the Suspend state. When this bit transitions to a one because a J-to-K transition is detected, the Port Change Detect bit in the USBSTS register is also set to one. This bit will automatically change to zero after the resume sequence is complete. This behavior is different from EHCI where the host controller driver is required to set this bit to a zero after the resume duration is timed in the driver.  
Note that when the Host controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driven on the port as long as this bit remains a one. This bit will remain a one until the port has switched to the high-speed idle. Writing a zero has no effect because the port controller will time the resume operation, clear the bit the port control state switches to HS or FS idle.  
This field is zero if Port Power(Port Status & Control (USB_nPORTSC1)) is zero in host mode.  
This bit is not-EHCI compatible.  
In Device mode:  

Table continues on the next page...
### USB\_nPORTSC1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>After the device has been in Suspend State for 5ms or more, software must set this bit to one to drive resume signaling before clearing. The Device Controller will set this bit to one if a J-to-K transition is detected while the port is in the Suspend state. The bit will be cleared when the device returns to normal operation. Also, when this bit will be cleared because a K-to-J transition detected, the Port Change Detect bit in the USBSSTS register is also set to one.</td>
<td></td>
</tr>
<tr>
<td>OCC</td>
<td>Over-current Change-R/WC. Default=0. This bit is set ‘1b’ by hardware when there is a change to Over-current Active. Software can clear this bit by writing a one to this bit position.</td>
</tr>
<tr>
<td>OCA</td>
<td>Over-current Active-Read Only. Default 0. This bit will automatically transition from one to zero when the over current condition is removed. 1 This port currently has an over-current condition 0 This port does not have an over-current condition.</td>
</tr>
<tr>
<td>PEC</td>
<td>Port Enable/Disable Change-R/WC. 1=Port enabled/disabled status has changed. 0=No change. Default = 0. In Host Mode: For the root hub, this bit is set to a one only when a port is disabled due to disconnect on the port or due to the appropriate conditions existing at the EOF2 point (See Chapter 11 of the USB Specification). Software clears this by writing a one to it. This field is zero if Port Power(Port Status &amp; Control (USB_nPORTSC1)) is zero. In Device mode: The device port is always enabled, so this bit is always ‘0b’.</td>
</tr>
<tr>
<td>PE</td>
<td>Port Enabled/Disable-Read/Write. 1=Enable. 0=Disable. Default 0. In Host Mode: Ports can only be enabled by the host controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. Ports can be disabled by either a fault condition (disconnect event or other fault condition) or by the host software. Note that the bit status does not change until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller and bus events. When the port is disabled, (0b) downstream propagation of data is blocked except for reset. This field is zero if Port Power(Port Status &amp; Control (USB_nPORTSC1)) is zero in host mode. In Device Mode: The device port is always enabled, so this bit is always ‘1b’.</td>
</tr>
<tr>
<td>CSC</td>
<td>Connect Status Change-R/WC. 1=Change in Current Connect Status. 0=No change. Default 0. In Host Mode: Indicates a change has occurred in the port’s Current Connect Status. The host/device controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware will be ‘setting’ an already-set bit (that is, the bit will remain set). Software clears this bit by writing a one to it. This field is zero if Port Power(Port Status &amp; Control (USB_nPORTSC1)) is zero in host mode. In Device Mode: This bit is undefined in device controller mode.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## USB\_nPORTSC1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 0 CCS | Current Connect Status-Read Only.  
In Host Mode:  
1=Device is present on port. 0=No device is present. Default = 0. This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change bit (Bit 1) to be set.  
This field is zero if Port Power(Port Status & Control (USB\_nPORTSC1)) is zero in host mode.  
In Device Mode:  
1=Attached. 0=Not Attached. Default=0. A one indicates that the device successfully attached and is operating in either high speed or full speed as indicated by the High Speed Port bit in this register. A zero indicates that the device did not attach successfully or was forcibly disconnected by the software writing a zero to the Run bit in the USBCMD register. It does not state the device being disconnected or suspended. |

### 42.7.32 On-The-Go Status & control (USB\_nOTGSC)

This register is available only in OTG controller core. It has four sections:

- OTG Interrupt enables (Read/Write)
- OTG Interrupt status (Read/Write to Clear)
- OTG Status inputs (Read Only)
- OTG Controls (Read/Write)

The status inputs are debounced using a 1 ms time constant. Values on the status inputs that do not persist for more than 1 ms does not cause an update of the status input register, or cause an OTG interrupt.

See also **USB Device Mode (USB\_nUSBMODE)** register.
Address: 402E_0000h base + 1A4h offset + (512d × i), where i=0d to 1d
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>30</td>
<td>Data Pulse Interrupt Enable</td>
</tr>
<tr>
<td>29</td>
<td>1 millisecond timer Interrupt Enable - Read/Write</td>
</tr>
<tr>
<td>28</td>
<td>B Session End Interrupt Enable - Read/Write. Setting this bit enables the B session end interrupt.</td>
</tr>
<tr>
<td>27</td>
<td>B Session Valid Interrupt Enable - Read/Write. Setting this bit enables the B session valid interrupt.</td>
</tr>
<tr>
<td>26</td>
<td>A Session Valid Interrupt Enable - Read/Write. Setting this bit enables the A session valid interrupt.</td>
</tr>
<tr>
<td>25</td>
<td>A VBus Valid Interrupt Enable - Read/Write. Setting this bit enables the A VBus valid interrupt.</td>
</tr>
<tr>
<td>24</td>
<td>USB ID Interrupt Enable - Read/Write. Setting this bit enables the USB ID interrupt.</td>
</tr>
<tr>
<td>23</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>22</td>
<td>Data Pulse Interrupt Status - Read/Write to Clear. This bit is set when data bus pulsing occurs on DP or DM. Data bus pulsing is only detected when USBMODE.CM = Host (11) and PORTSC1(0)[PP] = 0. Software must write a one to clear this bit.</td>
</tr>
<tr>
<td>21</td>
<td>1 millisecond timer Interrupt Status - Read/Write to Clear. This bit is set once every millisecond. Software must write a one to clear this bit.</td>
</tr>
<tr>
<td>20</td>
<td>B Session End Interrupt Status - Read/Write to Clear. This bit is set when VBus has fallen below the B session end threshold. Software must write a one to clear this bit.</td>
</tr>
<tr>
<td>19</td>
<td>B Session Valid Interrupt Status - Read/Write to Clear. This bit is set when VBus has either risen above or fallen below the B session valid threshold. Software must write a one to clear this bit.</td>
</tr>
<tr>
<td>18</td>
<td>A Session Valid Interrupt Status - Read/Write to Clear. This bit is set when VBus has either risen above or fallen below the A session valid threshold. Software must write a one to clear this bit.</td>
</tr>
<tr>
<td>17</td>
<td>A VBus Valid Interrupt Status - Read/Write to Clear. This bit is set when VBus has either risen above or fallen below the VBus valid threshold on an A device. Software must write a one to clear this bit.</td>
</tr>
<tr>
<td>16</td>
<td>USB ID Interrupt Status - Read/Write. This bit is set when a change on the ID input has been detected. Software must write a one to clear this bit.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## USB _nOTGSC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Data Bus Pulsing Status - Read Only. A '1' indicates data bus pulsing is being detected on the port.</td>
</tr>
<tr>
<td>13</td>
<td>1 millisecond timer toggle - Read Only. This bit toggles once per millisecond.</td>
</tr>
<tr>
<td>12</td>
<td>B Session End - Read Only. Indicates VBus is below the B session end threshold.</td>
</tr>
<tr>
<td>11</td>
<td>B Session Valid - Read Only. Indicates VBus is above the B session valid threshold.</td>
</tr>
<tr>
<td>10</td>
<td>A Session Valid - Read Only. Indicates VBus is above the A session valid threshold.</td>
</tr>
<tr>
<td>9</td>
<td>A VBus Valid - Read Only. Indicates VBus is above the A VBus valid threshold.</td>
</tr>
<tr>
<td>8</td>
<td>USB ID - Read Only. 0 = A device, 1 = B device</td>
</tr>
<tr>
<td>7–6</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>5</td>
<td>ID Pullup - Read/Write. This bit provide control over the ID pull-up resistor; 0 = off, 1 = on [default]. When this bit is 0, the ID input will not be sampled.</td>
</tr>
<tr>
<td>4</td>
<td>Data Pulsing - Read/Write. Setting this bit causes the pullup on DP to be asserted for data pulsing during SRP.</td>
</tr>
<tr>
<td>3</td>
<td>OTG Termination - Read/Write. This bit must be set when the OTG device is in device mode, this controls the pulldown on DM.</td>
</tr>
<tr>
<td>2</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>1</td>
<td>VBUS Charge - Read/Write. Setting this bit causes the VBus line to be charged. This is used for VBus pulsing during SRP.</td>
</tr>
<tr>
<td>0</td>
<td>VBUS_Discharge - Read/Write. Setting this bit causes VBus to discharge through a resistor.</td>
</tr>
</tbody>
</table>
42.7.33 USB Device Mode (USB_nUSBMODE)

Address: 402E_0000h base + 1A8h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>15</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>14–5</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Stream Disable Mode. (0 - Inactive [default]; 1 - Active)</td>
</tr>
</tbody>
</table>

Device Mode: Setting to a ‘1’ disables double priming on both RX and TX for low bandwidth systems. This mode ensures that when the RX and TX buffers are sufficient to contain an entire packet that the standard double buffering scheme is disabled to prevent overruns/underruns in bandwidth limited systems. Note: In High Speed Mode, all packets received are responded to with a NYET handshake when stream disable is active.

Host Mode: Setting to a ‘1’ ensures that overruns/underruns of the latency FIFO are eliminated for low bandwidth systems where the RX and TX buffers are sufficient to contain the entire packet. Enabling stream disable also has the effect of ensuring the TX latency is filled to capacity before the packet is launched onto the USB.

**NOTE:** Time duration to pre-fill the FIFO becomes significant when stream disable is active. See TX FIFO Fill Tuning (USB_nTXFILLTUNING) and TXTFILLTUNING [MPH Only] to characterize the adjustments needed for the scheduler when using this feature.

*Table continues on the next page...*
### USB\_nUSBMODE field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>NOTE:</strong></td>
<td>The use of this feature substantially limits of the overall USB performance that can be achieved.</td>
</tr>
<tr>
<td>3 SLOM</td>
<td>Setup Lockout Mode. In device mode, this bit controls behavior of the setup lock mechanism. See Control Endpoint Operation Model.</td>
</tr>
<tr>
<td>0</td>
<td>Setup Lockouts On (default);</td>
</tr>
<tr>
<td>1</td>
<td>Setup Lockouts Off (DCD requires use of Setup Data Buffer Tripwire in USB Command Register (USB_nUSBCMD)).</td>
</tr>
<tr>
<td>2 ES</td>
<td>Endian Select - Read/Write. This bit can change the byte alignment of the transfer buffers to match the host microprocessor. The bit fields in the microprocessor interface and the data structures are unaffected by the value of this bit because they are based upon the 32-bit word.</td>
</tr>
<tr>
<td>Bit Meaning</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Little Endian [Default]</td>
</tr>
<tr>
<td>1</td>
<td>Big Endian</td>
</tr>
<tr>
<td>CM</td>
<td>Controller Mode - R/WO. Controller mode is defaulted to the proper mode for host only and device only implementations. For those designs that contain both host &amp; device capability, the controller defaults to an idle state and needs to be initialized to the desired operating mode after reset. For combination host/device controllers, this register can only be written once after reset. If it is necessary to switch modes, software must reset the controller by writing to the RESET bit in the USBCMD register before reprogramming this register.</td>
</tr>
<tr>
<td>For OTG controller core, reset value is '00b'.</td>
<td></td>
</tr>
<tr>
<td>00</td>
<td>Idle [Default for combination host/device]</td>
</tr>
<tr>
<td>01</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Device Controller [Default for device only controller]</td>
</tr>
<tr>
<td>11</td>
<td>Host Controller [Default for host only controller]</td>
</tr>
</tbody>
</table>

### 42.7.34 Endpoint Setup Status (USB\_nENDPTSETUPSTAT)

Address: 402E\_0000h base + 1ACh offset + (512d × i), where i=0d to 1d

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R/W | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

#### USB\_nENDPTSETUPSTAT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>ENDPTSETUPSTAT</td>
<td>Setup Endpoint Status. For every setup transaction that is received, a corresponding bit in this register is set to one. Software must clear or acknowledge the setup transfer by writing a one to a respective bit after it has read the setup data from Queue head. The response to a setup packet as in the order of operations and total response time is crucial to limit bus time outs while the setup lock our mechanism is engaged. See Managing Endpoints in the Device Operational Model.</td>
</tr>
<tr>
<td>This register is only used in device mode.</td>
<td></td>
</tr>
</tbody>
</table>
42.7.35 Endpoint Prime (USB_nENDPTPRIME)

This register is only used in device mode.

When software sets the prime bit for a given endpoint, the device controller loads the transfer descriptor, pointed to by the queue head, such that the endpoint is ready to transmit or receive when the host sends a request (IN/OUT token). The endpoint will NAK all requests from the host until the endpoint is primed. The controller will automatically re-prime the endpoint with a new transfer descriptor when one is found via the next_dtd pointer of the current transfer descriptor. Hence, the prime bit must only be set by software when a descriptor is added to the queue head.

Address: 402E_0000h base + 1B0h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>Prime Endpoint Transmit Buffer - R/WS. For each endpoint a corresponding bit is used to request that a buffer is prepared for a transmit operation in order to respond to a USB IN/INTERRUPT transaction. Software should write a one to the corresponding bit when posting a new transfer descriptor to an endpoint queue head. Hardware automatically uses this bit to begin parsing for a new transfer descriptor from the queue head and prepare a transmit buffer. Hardware clears this bit when the associated endpoint(s) is (are) successfully primed.</td>
</tr>
<tr>
<td>15–8</td>
<td>Prime Endpoint Receive Buffer - R/WS. For each endpoint, a corresponding bit is used to request a buffer prepare for a receive operation for when a USB host initiates a USB OUT transaction. Software should write a one to the corresponding bit whenever posting a new transfer descriptor to an endpoint queue head. Hardware automatically uses this bit to begin parsing for a new transfer descriptor from the queue head and prepare a receive buffer. Hardware clears this bit when the associated endpoint(s) is (are) successfully primed.</td>
</tr>
</tbody>
</table>

NOTE: These bits are momentarily set by hardware during hardware re-priming operations when a dTD is retired, and the dQH is updated.

PETB[N] - Endpoint #N, N is in 0..7

PERB[N] - Endpoint #N, N is in 0..7
42.7.36 Endpoint Flush (USB_nENDPTFLUSH)

This register is only used in device mode.

Address: 402E_0000h base + 1B4h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–24</th>
<th>23–16</th>
<th>15–8</th>
<th>7–0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>FETB</td>
<td>Reserved</td>
<td>FERB</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
</tr>
</tbody>
</table>

**USB_nENDPTFLUSH field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>FETB Flush Endpoint Transmit Buffer - R/WS. Writing one to a bit(s) in this register causes the associated endpoint(s) to clear any primed buffers. If a packet is in progress for one of the associated endpoints, then that transfer continues until completion. Hardware clears this register after the endpoint flush operation is successful. FETB[N] - Endpoint #N, N is in 0..7</td>
</tr>
<tr>
<td>15–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>7–0</td>
<td>FERB Flush Endpoint Receive Buffer - R/WS. Writing one to a bit(s) causes the associated endpoint(s) to clear any primed buffers. If a packet is in progress for one of the associated endpoints, then that transfer continues until completion. Hardware clears this register after the endpoint flush operation is successful. FERB[N] - Endpoint #N, N is in 0..7</td>
</tr>
</tbody>
</table>

42.7.37 Endpoint Status (USB_nENDPTSTAT)

This register is only used in device mode.

Address: 402E_0000h base + 1B8h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31–24</th>
<th>23–16</th>
<th>15–8</th>
<th>7–0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>Reserved</td>
<td>ETBR</td>
<td>Reserved</td>
<td>ERBR</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
<td>0 0 0 0</td>
</tr>
</tbody>
</table>
USB Core Memory Map/Register Definition

USB_nENDPTSTAT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>ETBR</td>
</tr>
<tr>
<td>15–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>ERBR</td>
<td>Endpoint Receive Buffer Ready -- Read Only. One bit for each endpoint indicates status of the respective endpoint buffer. This bit is set to a one by the hardware as a response to receiving a command from a corresponding bit in the ENDPRIME register. There is always a delay between setting a bit in the ENDPRIME register and endpoint indicating ready. This delay time varies based upon the current USB traffic and the number of bits set in the ENDPRIME register. Buffer ready is cleared by USB reset, by the USB DMA system, or through the ENDPTFLUSH register.</td>
</tr>
</tbody>
</table>

NOTE: These bits are momentarily cleared by hardware during hardware endpoint re-priming operations when a dTD is retired, and the dQH is updated.

ETBR[N] - Endpoint #N, N is in 0..7

ERBR[N] - Endpoint #N, N is in 0..7

42.7.38 Endpoint Complete (USB_nENDPTCOMPLETE)

This register is only used in device mode.

Address: 402E_0000h base + 1BCh offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

USB_nENDPTCOMPLETE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23–16</td>
<td>ETCE</td>
</tr>
</tbody>
</table>

ETCE[N] - Endpoint #N, N is in 0..7

Table continues on the next page...
USB\_nENDPTCOMPLETE field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–8</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>ERCE</td>
<td>Endpoint Receive Complete Event - RW/C. Each bit indicates a received event (OUT/SETUP) occurred and software should read the corresponding endpoint queue to determine the transfer status. If the corresponding IOC bit is set in the Transfer Descriptor, then this bit is set simultaneously with the USBINT. Writing one clears the corresponding bit in this register. ERCE[N] - Endpoint #N, N is in 0..7</td>
</tr>
</tbody>
</table>

42.7.39 Endpoint Control0 (USB\_nENDPTCTRL0)

Every Device implements Endpoint 0 as a control endpoint.

Address: 402E\_0000h base + 1C0h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TXE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TXS</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td>TXT</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RXE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RXS</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
<td>RXT</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

USB\_nENDPTCTRL0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23</td>
<td>TX Endpoint Enable</td>
</tr>
<tr>
<td>TXE</td>
<td>1 Enabled</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB_nENDPTCTRL0 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Endpoint0 is always enabled.</td>
<td></td>
</tr>
</tbody>
</table>
| **22–20** - | This field is reserved.  
Reserved |
| **19–18** TXT | TX Endpoint Type - Read/Write  
00 - Control  
Endpoint0 is fixed as a Control End Point. |
| **17** - | This field is reserved.  
Reserved |
| **16** TXS | TX Endpoint Stall - Read/Write  
0 End Point OK [Default]  
1 End Point Stalled  
Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. It continues returning STALL until the bit is cleared by software or it is automatically cleared upon receipt of a new SETUP request.  
After receiving a SETUP request, this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared.  
**NOTE:** There is a slight delay (50 clocks max.) between the endptsetupstat being cleared and hardware continuing to clear this bit. In most systems it is unlikely the DCD software will observe this delay. However, should the dcd observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a newsetup has been received by checking the associated endptsetupstat bit. |
| **15–8** - | This field is reserved.  
Reserved |
| **7** RXE | RX Endpoint Enable  
1 Enabled  
Endpoint0 is always enabled. |
| **6–4** - | This field is reserved.  
Reserved |
| **3–2** RXT | RX Endpoint Type - Read/Write  
00 Control  
Endpoint0 is fixed as a Control End Point. |
| **1** - | This field is reserved.  
Reserved |
| **0** RXS | RX Endpoint Stall - Read/Write  
0 End Point OK. [Default]  
1 End Point Stalled  
Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. It continues returning STALL until the bit is cleared by software or it is automatically cleared upon receipt of a new SETUP request.  
After receiving a SETUP request, this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared. |

*Table continues on the next page...*
USB\_nENDPTCTRL0 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>NOTE:</strong></td>
<td>There is a slight delay (50 clocks max.) between the endptsetupstat being cleared and hardware continuing to clear this bit. In most systems it is unlikely the dcd software will observe this delay. However, should the dcd observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a newsetup has been received by checking the associated endptsetupstat bit.</td>
</tr>
</tbody>
</table>

### 42.7.40 Endpoint Control 1 (USB\_nENDPTCTRL1)

This is endpoint control register for endpoint 1 in device operation mode.

**NOTE**

If one endpoint direction is enabled and the paired endpoint of opposite direction is disabled then the unused direction type must be changed from the default control-type to any other type (that is Bulk-type). leaving an unconfigured endpoint control causes undefined behavior for the data pid tracking on the active endpoint/direction.

Address: 402E_0000h base + 1C4h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TXE</td>
<td>TXR</td>
<td>TXI</td>
<td>TXE</td>
<td>TXR</td>
<td>TXI</td>
<td>TXT</td>
<td>TXD</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RXE</td>
<td>RXR</td>
<td>RXI</td>
<td>RXE</td>
<td>RXR</td>
<td>RXI</td>
<td>RXT</td>
<td>RXD</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
## USB\textsubscript{\texttt{n}}ENDPTCTRL1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 23 TXE | TX Endpoint Enable  
0 Disabled [Default]  
1 Enabled  
An Endpoint should be enabled only after it has been configured. |
| 22 TXR | TX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence  
Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID’s between the Host and device. |
| 21 TXI | TX Data Toggle Inhibit  
0 PID Sequencing Enabled. [Default]  
1 PID Sequencing Disabled.  
This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet. |
| 20 - | This field is reserved. Reserved |
| 19–18 TXT | TX Endpoint Type - Read/Write  
00 Control  
01 Isochronous  
10 Bulk  
11 Interrupt |
| 17 TXD | TX Endpoint Data Source - Read/Write  
0 Dual Port Memory Buffer/DMA Engine [DEFAULT]  
Should always be written as 0. |
| 16 T XS | TX Endpoint Stall - Read/Write  
0 End Point OK  
1 End Point Stalled  
This bit will be cleared automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDP TSETUPSTAT bit is cleared.  
Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.  
**NOTE:** [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDP TSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit. |
| 15–8 - | This field is reserved. Reserved |

*Table continues on the next page...*
## USB_nENDPTCTRL1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 7 RXE | RX Endpoint Enable  
0 Disabled [Default]  
1 Enabled  
An Endpoint should be enabled only after it has been configured. |
| 6 RXR | RX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence  
Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the host and device. |
| 5 RXI | RX Data Toggle Inhibit  
0 Disabled [Default]  
1 Enabled  
This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always accept data packet regardless of their data PID. |
| 4 - | This field is reserved.  
Reserved. |
| 3–2 RXT | RX Endpoint Type - Read/Write  
00 Control  
01 Isochronous  
10 Bulk  
11 Interrupt |
| 1 RXD | RX Endpoint Data Sink - Read/Write  
0 Dual Port Memory Buffer/DMA Engine [Default]  
Should always be written as zero. |
| 0 RXS | RX Endpoint Stall - Read/Write  
0 End Point OK. [Default]  
1 End Point Stalled  
This bit is set automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared.  
Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.  
**NOTE:** [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit. |
42.7.41 Endpoint Control 2 (USB_nENDPTCTRL2)

This is endpoint control register for endpoint 2 in device operation mode.

**NOTE**

If one endpoint direction is enabled and the paired endpoint of opposite direction is disabled then the unused direction type must be changed from the default control-type to any other type (that is Bulk-type). Leaving an unconfigured endpoint control causes undefined behavior for the data pid tracking on the active endpoint/direction.

Address: 402E_0000h base + 1C8h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TXE</td>
<td>TXR</td>
<td>TXI</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RXE</td>
<td>RXR</td>
<td>RXI</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

USB_nENDPTCTRL2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23 TXE</td>
<td>TX Endpoint Enable</td>
</tr>
<tr>
<td></td>
<td>0 Disabled [Default]</td>
</tr>
<tr>
<td></td>
<td>1 Enabled</td>
</tr>
<tr>
<td></td>
<td>An Endpoint should be enabled only after it has been configured.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### USB_nENDPTCTRL2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 22 TXR | TX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence  
Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the Host and device. |
| 21 TXI | TX Data Toggle Inhibit  
0 PID Sequencing Enabled. [Default]  
1 PID Sequencing Disabled.  
This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet. |
| 20 - | This field is reserved.  
Reserved |
| 19–18 TXT | TX Endpoint Type - Read/Write  
00 Control  
01 Isochronous  
10 Bulk  
11 Interrupt |
| 17 TXD | TX Endpoint Data Source - Read/Write  
0 Dual Port Memory Buffer/DMA Engine [DEFAULT]  
Should always be written as 0. |
| 16 TXS | TX Endpoint Stall - Read/Write  
0 End Point OK  
1 End Point Stalled  
This bit will be cleared automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDP SETUPSTAT bit is cleared.  
Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.  
**NOTE:** [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDP SETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit. |
| 15–8 - | This field is reserved.  
Reserved |
| 7 RXE | RX Endpoint Enable  
0 Disabled [Default]  
1 Enabled  
An Endpoint should be enabled only after it has been configured. |
| 6 RXR | RX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence |

*Table continues on the next page...*
**USB_nENDPTCTRL2 field descriptions (continued)**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the host and device.</td>
<td></td>
</tr>
<tr>
<td>5 RXI</td>
<td>RX Data Toggle Inhibit</td>
</tr>
<tr>
<td>0 Disabled [Default]</td>
<td></td>
</tr>
<tr>
<td>1 Enabled</td>
<td></td>
</tr>
<tr>
<td>This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always accept data packet regardless of their data PID.</td>
<td></td>
</tr>
<tr>
<td>4 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>Reserved.</td>
<td></td>
</tr>
<tr>
<td>3–2 RXT</td>
<td>RX Endpoint Type - Read/Write</td>
</tr>
<tr>
<td>00 Control</td>
<td></td>
</tr>
<tr>
<td>01 Isochronous</td>
<td></td>
</tr>
<tr>
<td>10 Bulk</td>
<td></td>
</tr>
<tr>
<td>11 Interrupt</td>
<td></td>
</tr>
<tr>
<td>1 RXD</td>
<td>RX Endpoint Data Sink - Read/Write</td>
</tr>
<tr>
<td>0 Dual Port Memory Buffer/DMA Engine [Default]</td>
<td></td>
</tr>
<tr>
<td>Should always be written as zero.</td>
<td></td>
</tr>
<tr>
<td>0 RXS</td>
<td>RX Endpoint Stall - Read/Write</td>
</tr>
<tr>
<td>0 End Point OK. [Default]</td>
<td></td>
</tr>
<tr>
<td>1 End Point Stalled</td>
<td></td>
</tr>
<tr>
<td>This bit is set automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared.</td>
<td></td>
</tr>
<tr>
<td>Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.</td>
<td></td>
</tr>
<tr>
<td><strong>NOTE:</strong> CONTROL ENDPOINT TYPES ONLY: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit.</td>
<td></td>
</tr>
</tbody>
</table>

### 42.7.42 Endpoint Control 3 (USB_nENDPTCTRL3)

This is endpoint control register for endpoint 3 in device operation mode.

**NOTE**

If one endpoint direction is enabled and the paired endpoint of opposite direction is disabled then the unused direction type must be changed from the default control-type to any other type (that is Bulk-type). leaving an unconfigured endpoint control.
causes undefined behavior for the data pid tracking on the active endpoint/direction.

Address: 402E_0000h base + 1CCh offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23</td>
<td>TX Endpoint Enable 0 Disabled [Default] 1 Enabled An Endpoint should be enabled only after it has been configured.</td>
</tr>
<tr>
<td>22</td>
<td>TX Data Toggle Reset (WS) Write 1 - Reset PID Sequence Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID’s between the Host and device.</td>
</tr>
<tr>
<td>21</td>
<td>TX Data Toggle Inhibit 0 PID Sequencing Enabled. [Default] 1 PID Sequencing Disabled. This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet.</td>
</tr>
<tr>
<td>20</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## USB_nENDPTCTRL3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>19–18 TXT</td>
<td>TX Endpoint Type - Read/Write</td>
</tr>
<tr>
<td>00</td>
<td>Control</td>
</tr>
<tr>
<td>01</td>
<td>Isochronous</td>
</tr>
<tr>
<td>10</td>
<td>Bulk</td>
</tr>
<tr>
<td>11</td>
<td>Interrupt</td>
</tr>
<tr>
<td>17</td>
<td>TXD</td>
</tr>
<tr>
<td>0</td>
<td>Dual Port Memory Buffer/DMA Engine [DEFAULT]</td>
</tr>
<tr>
<td></td>
<td>Should always be written as 0.</td>
</tr>
<tr>
<td>16</td>
<td>TXS</td>
</tr>
<tr>
<td>0</td>
<td>End Point OK</td>
</tr>
<tr>
<td>1</td>
<td>End Point Stalled</td>
</tr>
<tr>
<td></td>
<td>This bit will be cleared automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared.</td>
</tr>
<tr>
<td></td>
<td>Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.</td>
</tr>
<tr>
<td></td>
<td>NOTE: [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit.</td>
</tr>
<tr>
<td>15–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>RXE</td>
</tr>
<tr>
<td>0</td>
<td>Disabled [Default]</td>
</tr>
<tr>
<td>1</td>
<td>Enabled</td>
</tr>
<tr>
<td></td>
<td>An Endpoint should be enabled only after it has been configured.</td>
</tr>
<tr>
<td>6</td>
<td>RXR</td>
</tr>
<tr>
<td>Write 1</td>
<td>Reset PID Sequence</td>
</tr>
<tr>
<td></td>
<td>Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the host and device.</td>
</tr>
<tr>
<td>5</td>
<td>RXI</td>
</tr>
<tr>
<td>0</td>
<td>Disabled [Default]</td>
</tr>
<tr>
<td>1</td>
<td>Enabled</td>
</tr>
<tr>
<td></td>
<td>This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always accept data packet regardless of their data PID.</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3–2</td>
<td>RXT</td>
</tr>
<tr>
<td>00</td>
<td>Control</td>
</tr>
</tbody>
</table>

Table continues on the next page...
USB\_nENDPTCTRL3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>01</td>
<td>Isochronous</td>
</tr>
<tr>
<td>10</td>
<td>Bulk</td>
</tr>
<tr>
<td>11</td>
<td>Interrupt</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>1 RXD</th>
<th>RX Endpoint Data Sink - Read/Write</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 Dual Port Memory Buffer/DMA Engine [Default]</td>
</tr>
</tbody>
</table>

Should always be written as zero.

<table>
<thead>
<tr>
<th>0 RXS</th>
<th>RX Endpoint Stall - Read/Write</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 End Point OK. [Default]</td>
</tr>
<tr>
<td></td>
<td>1 End Point Stalled</td>
</tr>
</tbody>
</table>

This bit is set automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared.

Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.

**NOTE:** [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit.

---

### 42.7.43 Endpoint Control 4 (USB\_nENDPTCTRL4)

This is endpoint control register for endpoint 4 in device operation mode.

**NOTE**

If one endpoint direction is enabled and the paired endpoint of opposite direction is disabled then the unused direction type must be changed from the default control-type to any other type (that is Bulk-type). leaving an unconfigured endpoint control causes undefined behavior for the data pid tracking on the active endpoint/direction.
USB Core Memory Map/Register Definition

Address: 402E_0000h base + 1D0h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>23–22</td>
<td>21–20</td>
</tr>
<tr>
<td>31–24</td>
<td>TXE</td>
<td>TXR</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–8</td>
<td>7–6</td>
<td>5–4</td>
</tr>
<tr>
<td>15–8</td>
<td>RXE</td>
<td>RXR</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**USB_nENDPTCTRL4 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23 TXE</td>
<td>TX Endpoint Enable&lt;br&gt;0 Disabled [Default]&lt;br&gt;1 Enabled&lt;br&gt;An Endpoint should be enabled only after it has been configured.</td>
</tr>
<tr>
<td>22 TXR</td>
<td>TX Data Toggle Reset (WS)&lt;br&gt;Write 1 - Reset PID Sequence&lt;br&gt;Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the Host and device.</td>
</tr>
<tr>
<td>21 TXI</td>
<td>TX Data Toggle Inhibit&lt;br&gt;0 PID Sequencing Enabled. [Default]&lt;br&gt;1 PID Sequencing Disabled.&lt;br&gt;This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet.</td>
</tr>
<tr>
<td>20</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>19–18 TXT</td>
<td>TX Endpoint Type - Read/Write&lt;br&gt;00 Control&lt;br&gt;01 Isochronous</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### USB_nENDPTCTRL4 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10 Bulk</td>
<td>11 Interrupt</td>
</tr>
</tbody>
</table>
| 17 TXD | TX Endpoint Data Source - Read/Write  
0 Dual Port Memory Buffer/DMA Engine [DEFAULT]  
Should always be written as 0. |
| 16 TXS | TX Endpoint Stall - Read/Write  
0 End Point OK  
1 End Point Stalled  
This bit will be cleared automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared.  
Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.  
**NOTE:** [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit. |
| 15–8 | This field is reserved.  
Reserved |
| 7 RXE | RX Endpoint Enable  
0 Disabled [Default]  
1 Enabled  
An Endpoint should be enabled only after it has been configured. |
| 6 RXR | RX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence  
Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the host and device. |
| 5 RXI | RX Data Toggle Inhibit  
0 Disabled [Default]  
1 Enabled  
This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always accept data packet regardless of their data PID. |
| 4 | This field is reserved.  
Reserved. |
| 3–2 RXT | RX Endpoint Type - Read/Write  
00 Control  
01 Isochronous  
10 Bulk  
11 Interrupt |

*Table continues on the next page...*
### USB_nENDPTCTRL4 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| RXD   | RX Endpoint Data Sink - Read/Write  
|       | 0 Dual Port Memory Buffer/DMA Engine [Default]  
|       | Should always be written as zero. |
| RXS   | RX Endpoint Stall - Read/Write  
|       | 0 End Point OK. [Default]  
|       | 1 End Point Stalled  
|       | This bit is set automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared.  
|       | Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.  
|       | **NOTE:** [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit. |

### 42.7.44 Endpoint Control 5 (USB_nENDPTCTRL5)

This is endpoint control register for endpoint 5 in device operation mode.

**NOTE**

If one endpoint direction is enabled and the paired endpoint of opposite direction is disabled then the unused direction type must be changed from the default control-type to any other type (that is Bulk-type). leaving an unconfigured endpoint control causes undefined behavior for the data pid tracking on the active endpoint/direction.

Address: 402E_0000h base + 1D4h offset + (512d × i), where i=0d to 1d

### Diagram

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>TXE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TXR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TXI</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TXT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TXD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TXS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**
## USB_nENDPTCTRL5 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23 TXE</td>
<td>TX Endpoint Enable 0 Disabled [Default] 1 Enabled An Endpoint should be enabled only after it has been configured.</td>
</tr>
<tr>
<td>22 TXR</td>
<td>TX Data Toggle Reset (WS) Write 1 - Reset PID Sequence Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the Host and device.</td>
</tr>
<tr>
<td>21 TXI</td>
<td>TX Data Toggle Inhibit 0 PID Sequencing Enabled. [Default] 1 PID Sequencing Disabled. This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet.</td>
</tr>
<tr>
<td>19–18 TXT</td>
<td>TX Endpoint Type - Read/Write 00 Control 01 Isochronous 10 Bulk 11 Interrupt</td>
</tr>
<tr>
<td>17 TXD</td>
<td>TX Endpoint Data Source - Read/Write 0 Dual Port Memory Buffer/DMA Engine [DEFAULT] Should always be written as 0.</td>
</tr>
<tr>
<td>16 TXS</td>
<td>TX Endpoint Stall - Read/Write 0 End Point OK 1 End Point Stalled</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Field</td>
<td>Description</td>
</tr>
<tr>
<td>15–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7 RXE</td>
<td>RX Endpoint Enable</td>
</tr>
<tr>
<td>0</td>
<td>Disabled [Default]</td>
</tr>
<tr>
<td>1</td>
<td>Enabled</td>
</tr>
<tr>
<td>An Endpoint should be enabled only after it has been configured.</td>
<td></td>
</tr>
<tr>
<td>6 RXR</td>
<td>RX Data Toggle Reset (WS)</td>
</tr>
<tr>
<td></td>
<td>Write 1 - Reset PID Sequence</td>
</tr>
<tr>
<td></td>
<td>Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID’s between the host and device.</td>
</tr>
<tr>
<td>5 RXI</td>
<td>RX Data Toggle Inhibit</td>
</tr>
<tr>
<td>0</td>
<td>Disabled [Default]</td>
</tr>
<tr>
<td>1</td>
<td>Enabled</td>
</tr>
<tr>
<td>This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always accept data packet regardless of their data PID.</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>3–2 RXT</td>
<td>RX Endpoint Type - Read/Write</td>
</tr>
<tr>
<td>00</td>
<td>Control</td>
</tr>
<tr>
<td>01</td>
<td>Isochronous</td>
</tr>
<tr>
<td>10</td>
<td>Bulk</td>
</tr>
<tr>
<td>11</td>
<td>Interrupt</td>
</tr>
<tr>
<td>1 RXD</td>
<td>RX Endpoint Data Sink - Read/Write</td>
</tr>
<tr>
<td>0</td>
<td>Dual Port Memory Buffer/DMA Engine [Default]</td>
</tr>
<tr>
<td>Should always be written as zero.</td>
<td></td>
</tr>
<tr>
<td>0 RXS</td>
<td>RX Endpoint Stall - Read/Write</td>
</tr>
<tr>
<td>0</td>
<td>End Point OK. [Default]</td>
</tr>
<tr>
<td>1</td>
<td>End Point Stalled</td>
</tr>
</tbody>
</table>

Table continues on the next page...
USB\_nENDPTCTRL5 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This bit is set automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared. Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints. <strong>NOTE:</strong> [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit.</td>
</tr>
</tbody>
</table>

42.7.45 Endpoint Control 6 (USB\_nENDPTCTRL6)

This is endpoint control register for endpoint 6 in device operation mode.

**NOTE**

If one endpoint direction is enabled and the paired endpoint of opposite direction is disabled then the unused direction type must be changed from the default control-type to any other type (that is Bulk-type). leaving an unconfigured endpoint control causes undefined behavior for the data pid tracking on the active endpoint/direction.

Address: 402E\_0000h base + 1D8h offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

TXE TXR TXI Reserved TXT TXD TXS
### USB\_nENDPTCTRL6 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 23 TXE | TX Endpoint Enable  
0 Disabled [Default]  
1 Enabled  
An Endpoint should be enabled only after it has been configured. |
| 22 TXR | TX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence  
Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID’s between the Host and device. |
| 21 TXI | TX Data Toggle Inhibit  
0 PID Sequencing Enabled. [Default]  
1 PID Sequencing Disabled.  
This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet. |
| 20 | This field is reserved. Reserved |
| 19–18 TXT | TX Endpoint Type - Read/Write  
00 Control  
01 Isochronous  
10 Bulk  
11 Interrupt |
| 17 TXD | TX Endpoint Data Source - Read/Write  
0 Dual Port Memory Buffer/DMA Engine [DEFAULT]  
Should always be written as 0. |
| 16 TXS | TX Endpoint Stall - Read/Write  
0 End Point OK  
1 End Point Stalled |

Table continues on the next page...
### USB_nENDPTCTRL6 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–8</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 7 | RX Endpoint Enable  
0 Disabled [Default]  
1 Enabled  
An Endpoint should be enabled only after it has been configured. |
| 6 | RX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence  
Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID’s between the host and device. |
| 5 | RX Data Toggle Inhibit  
0 Disabled [Default]  
1 Enabled  
This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always accept data packet regardless of their data PID. |
| 4 | This field is reserved. Reserved. |
| 3–2 | RX Endpoint Type - Read/Write  
00 Control  
01 Isochronous  
10 Bulk  
11 Interrupt |
| 1 | RX Endpoint Data Sink - Read/Write  
0 Dual Port Memory Buffer/DMA Engine [Default]  
Should always be written as zero. |
| 0 | RX Endpoint Stall - Read/Write  
0 End Point OK. [Default]  
1 End Point Stalled |

*Table continues on the next page...*
USB_nENDPTCTRL6 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This bit is set automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared. Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.</td>
</tr>
</tbody>
</table>

**NOTE:** [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit.

### 42.7.46 Endpoint Control 7 (USB_nENDPTCTRL7)

This is endpoint control register for endpoint 7 in device operation mode.

**NOTE**

If one endpoint direction is enabled and the paired endpoint of opposite direction is disabled then the unused direction type must be changed from the default control-type to any other type (that is Bulk-type). leaving an unconfigured endpoint control causes undefined behavior for the data pid tracking on the active endpoint/direction.

Address: 402E_0000h base + 1DCh offset + (512d × i), where i=0d to 1d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Reset* 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

*TXE* *TXR* *TXI* *TXT* *TXD* *TXS*
### USB_nENDPTCTRL7 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>23</td>
<td>TX Endpoint Enable</td>
</tr>
<tr>
<td></td>
<td>0 Disabled [Default]</td>
</tr>
<tr>
<td></td>
<td>1 Enabled</td>
</tr>
<tr>
<td></td>
<td>An Endpoint should be enabled only after it has been configured.</td>
</tr>
<tr>
<td>22</td>
<td>TX Data Toggle Reset (WS)</td>
</tr>
<tr>
<td></td>
<td>Write 1 - Reset PID Sequence</td>
</tr>
<tr>
<td></td>
<td>Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the Host and device.</td>
</tr>
<tr>
<td>21</td>
<td>TX Data Toggle Inhibit</td>
</tr>
<tr>
<td></td>
<td>0 PID Sequencing Enabled. [Default]</td>
</tr>
<tr>
<td></td>
<td>1 PID Sequencing Disabled.</td>
</tr>
<tr>
<td></td>
<td>This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always transmit DATA0 for a data packet.</td>
</tr>
<tr>
<td>20</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>19–18</td>
<td>TX Endpoint Type - Read/Write</td>
</tr>
<tr>
<td></td>
<td>00 Control</td>
</tr>
<tr>
<td></td>
<td>01 Isochronous</td>
</tr>
<tr>
<td></td>
<td>10 Bulk</td>
</tr>
<tr>
<td></td>
<td>11 Interrupt</td>
</tr>
<tr>
<td>17</td>
<td>TX Endpoint Data Source - Read/Write</td>
</tr>
<tr>
<td></td>
<td>0 Dual Port Memory Buffer/DMA Engine [DEFAULT]</td>
</tr>
<tr>
<td></td>
<td>Should always be written as 0.</td>
</tr>
<tr>
<td>16</td>
<td>TX Endpoint Stall - Read/Write</td>
</tr>
<tr>
<td></td>
<td>0 End Point OK</td>
</tr>
<tr>
<td></td>
<td>1 End Point Stalled</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### USB_nENDPTCTRL7 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>This bit will be cleared automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared. Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints. <strong>NOTE:</strong> [CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit.</td>
<td></td>
</tr>
</tbody>
</table>

| 15–8 | This field is reserved. Reserved |
| 7 RXE | RX Endpoint Enable  
0 Disabled [Default]  
1 Enabled  
An Endpoint should be enabled only after it has been configured. |
| 6 RXR | RX Data Toggle Reset (WS)  
Write 1 - Reset PID Sequence  
Whenever a configuration event is received for this Endpoint, software must write a one to this bit in order to synchronize the data PID's between the host and device. |
| 5 RXI | RX Data Toggle Inhibit  
0 Disabled [Default]  
1 Enabled  
This bit is only used for test and should always be written as zero. Writing a one to this bit causes this endpoint to ignore the data toggle sequence and always accept data packet regardless of their data PID. |
| 4 | This field is reserved. Reserved. |
| 3–2 RXT | RX Endpoint Type - Read/Write  
00 Control  
01 Isochronous  
10 Bulk  
11 Interrupt |
| 1 RXD | RX Endpoint Data Sink - Read/Write  
0 Dual Port Memory Buffer/DMA Engine [Default]  
Should always be written as zero. |
| 0 RXS | RX Endpoint Stall - Read/Write  
0 End Point OK. [Default]  
1 End Point Stalled |

*Table continues on the next page...*
## USB_nENDPTCTRL7 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Description</td>
<td>This bit is set automatically upon receipt of a SETUP request if this Endpoint is configured as a Control Endpoint and this bit will continue to be cleared by hardware until the associated ENDPTSETUPSTAT bit is cleared. Software can write a one to this bit to force the endpoint to return a STALL handshake to the Host. This control will continue to STALL until this bit is either cleared by software or automatically cleared as above for control endpoints.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>[CONTROL ENDPOINT TYPES ONLY]: there is a slight delay (50 clocks max) between the ENDPTSETUPSTAT begin cleared and hardware continuing to clear this bit. In most systems, it is unlikely the DCD software will observe this delay. However, should the DCD observe that the stall bit is not set after writing a one to it then follow this procedure: continually write this stall bit until it is set or until a new setup has been received by checking the associated endptsetupstat bit.</td>
</tr>
</tbody>
</table>
Chapter 43
Universal Serial Bus 2.0 Integrated PHY (USB-PHY)

43.1 Chip-specific USB-PHY information

Table 43-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

43.2 USB PHY Overview

The chip contains 2 integrated USB 2.0 PHY macrocells capable of connecting to USB host/device systems at the USB low-speed (LS) rate of 1.5 Mbits/s, full-speed (FS) rate of 12 Mbits/s or at the USB 2.0 high-speed (HS) rate of 480 Mbits/s.

The integrated PHY provides a standard UTM interface. The USB_{n}_{DN} and USB_{n}_{DP} pins connect directly to a USB connector.

The following subsections describe the external interfaces, internal interfaces, major blocks, and programmable registers that comprise the integrated USB 2.0 PHY.
43.3 Operation

The UTM provides a 16-bit interface to the USB controller. This interface is clocked at 30 MHz.

- The digital portions of the USBPHY block include the UTMI, digital transmitter, digital receiver, and the programmable registers.
- The analog transceiver section comprises an analog receiver and an analog transmitter, as shown in Figure 43-1.

43.3.1 UTMI

The UTMI block handles the line_state bits, reset buffering, suspend distribution, transceiver speed selection, and transceiver termination selection.

The PLL supplies a 120 MHz signal to all of the digital logic. The UTMI block does a final divide-by-four to develop the 30 MHz clock used in the interface.

43.3.2 Digital Transmitter

The digital transmitter receives the 16-bit transmit data from the USB controller and handles the tx_valid, tx_validh and tx_ready handshake.

In addition, it contains the transmit serializer that converts the 16-bit parallel words at 30 MHz to a single bitstream at 480 Mbit for high-speed or 12 Mbit for full-speed or 1.5 Mbit for low-speed. It does this while implementing the bit-stuffing algorithm and the NRZI encoder that are used to remove the DC component from the serial bitstream. The output of this encoder is sent to the low-speed (LS), full-speed (FS) or high-speed (HS) drivers in the analog transceiver section’s transmitter block.

43.3.3 Digital Receiver

The digital receiver receives the raw serial bitstream from the low speed (LS) differential transceiver, full speed (FS) differential transceiver, and a 9X, 480 MHz sampled data from the high speed (HS) differential transceiver.

As the phase of the USB host transmitter shifts relative to the local PLL, the receiver section’s HS DLL tracks these changes to give a reliable sample of the incoming 480 Mbit/s bitstream. Since this sample point shifts relative to the PLL phase used by the digital logic, a rate-matching elastic buffer is provided to cross this clock domain.
boundary. Once the bitstream is in the local clock domain, an NRZI decoder and bit unstuffer restore the original payload data bitstream and pass it to a deserializer and holding register. The receive state machine handles the rx_valid, rx_validh, and handshake with the USB controller. The handshake is not interlocked, in that there is no rx_ready signal coming from the controller. The controller must take each 16-bit value as presented by the PHY. The receive state machine provides an rx_active signal to the controller that indicates when it is inside a valid packet (SYNC detected, and so on).
43.3.4  Analog Receiver

The analog receiver comprises five differential receivers, two single-ended receivers, and a 9X, 480 MHz HS data sampling module, as shown in the figure below and described further in this section.

![Figure 43-1. USB 2.0 PHY Analog Transceiver Block Diagram](image)

43.3.4.1  HS Differential Receiver

The high-speed differential receiver is both a differential analog receiver and threshold comparator. Its output is a one if the differential signal is greater than a 0-V threshold.
Otherwise, its output is 0. Its purpose is to discriminate the ± 400-mV differential voltage resulting from the high-speed drivers current flow into the dual 45Ω terminations found on each pin of the differential pair. The envelope or squelch detector, described below, ensures that the differential signal has sufficient magnitude to be valid. The HS differential receiver tolerates up to 500 mV of common mode offset.

### 43.3.4.2 Squelch Detector

The squelch detector is a differential analog receiver and threshold comparator.

Its output is 1, if the differential magnitude is less than a nominal 100 mV threshold. Otherwise, its output is 0.

Its purpose is to invalidate the HS differential receiver when the incoming signal is simply too low to receive reliably.

### 43.3.4.3 LS/FS Differential Receiver

The low-speed/full-speed differential receiver is both a differential analog receiver and threshold comparator.

The crossover voltage falls between 1.3 V and 2.0 V. Its output is 1, when the USB\_n\_DP line is above the crossover point and the USB\_n\_DN line is below the crossover point. The digital receiver section decodes the receiver data into J or K state according to the speed.

### 43.3.4.4 HS Disconnect Detector

It is a differential analog receiver and threshold comparator. It outputs high when differential magnitude is greater than a nominal 575-mV threshold. Otherwise, it outputs low.

### 43.3.4.5 USB Plugged-In Detector

The USB plugged-in detector looks for both USB\_n\_DP and USB\_n\_DN to be high. There is a pair of large on-chip pullup resistors (200 KΩ) that hold both USB\_n\_DP and USB\_n\_DN high when the USB cable is not attached. The USB plugged-in detector signals a 0 in this case.
When operating in device mode, the upstream port in host/hub interface contains a 15 KΩ pulldown resistor which could easily override the 200 KΩ pullup resistor. When plugged in, at least one signal in the pair will be low, which will force the plugged-in detector's output high.

43.3.4.6 Single-Ended USB_DP Receiver

The single-ended USB_n_DP receiver output is high whenever the USB_n_DP input is above its nominal 1.8 V threshold.

43.3.4.7 Single-Ended USB_DN Receiver

The single-ended USB_n_DN receiver output is high whenever the USB_n_DN input is above its nominal 1.8 V threshold.

43.3.4.8 9X Oversample Module

The 9X oversample module uses nine identically spaced phases of the 480 MHz clock to sample a high speed bit data. The squelch signal is sampled only 1X.

43.3.5 Analog Transmitter

The analog transmitter comprises two differential drivers: one for high-speed signaling and one for full-speed signaling. It also contains the switchable 1.5 KΩ pullup resistor.

See Figure 43-1.

43.3.5.1 Switchable High-Speed 45Ω Termination Resistors

High-speed current mode differential signaling requires good 90 Ω differential termination at each end of the USB cable. This results from switching in 45 Ω terminating resistors from each signal line to ground at each end of the cable.

Because each signal is parallel terminated with 45 Ω at each end, each driver sees a 22.5 Ω load. This load impedance is much too low for full-speed signaling levels—hence the need for switchable high-speed terminating resistors. Switchable trimming resistors are provided to tune the actual termination resistance of each device, as shown in Figure
The HW_USBPHY_TX_TXCAL45DP bit field, for example, allows one of 16 trimming resistor values to be placed in parallel with the 45Ω terminator on the USB_n_DP signal.

43.3.5.2 Low-Speed/Full-Speed Differential Driver

The low-speed/full-speed differential drivers are essentially low-impedance pulldown devices that are switched in a differential mode for low-speed or full-speed signaling, that is, either one or the other device is turned on to signal the "J" state or the "K" state.

43.3.5.3 High-Speed Differential Driver

The high-speed differential driver receives a 17.78 mA current from the constant current source (Iref) and essentially steers it down either the USB_DP signal or the USB_DN signal or alternatively to ground.

This current will produce approximately a 400 mV drop across the 22.5 Ω termination seen by the driver when it is steered onto one of the signal lines. The approximately 17.78 mA current source is referenced back to the integrated voltage-band-gap (Vbg) circuit. The Iref, Ibias, and V to I circuits are shared with the integrated battery charger.

43.3.5.4 Switchable 1.5KΩ USB_DP Pullup Resistor

This product contains a switchable 1.5 KΩ pullup resistor on the USB_n_DP signal.

This resistor is switched on to indicate to the host/hub controller that a full-speed-capable device is on the USB cable, powered on, and ready. This resistor is switched off at power-on reset so the host does not recognize a USB device until the processor software enables the announcement of a full-speed device.
43.3.5.5 Switchable 15KΩ USB_DP Pulldown Resistor

This product contains a switchable 15 KΩ pulldown resistor on both USB_n_DP and USB_n_DN signals. This is used in host mode to indicate to the device controller that a host is present.

![USB 2.0 PHY Transmitter Block Diagram](image)

**Figure 43-2. USB 2.0 PHY Transmitter Block Diagram**
43.3.6 Recommended Register Configuration for USB Certification

The register settings in this section are recommended for passing USB certification.

The following settings lower the J/K levels to certifiable limits:

\[
\begin{align*}
    \text{HW}_\text{USBPHY}_\text{TX}_\text{TXCAL45DP} &= 0x0 \\
    \text{HW}_\text{USBPHY}_\text{TX}_\text{TXCAL45DN} &= 0x0 \\
    \text{HW}_\text{USBPHY}_\text{TX}_\text{D_CAL} &= 0x7
\end{align*}
\]

43.3.7 Charger detection

The USB charger detector is a block that detects whether the upstream-facing device is connected to a down-stream facing charger, either a dedicated USB charger or a host charger.

The USB charger detector is comprised of two sub-blocks, namely the USB data-pin contact detector and the charger detector.

This section details those two sub-blocks and gives the software flow of USB charger detection. Finally, this chapter discusses the detection of a USB charger in case of a dead battery.

43.3.7.1 Charger detect control table

Before we dive into the details of the detectors, we show the logic table of the control signals to give the user an overall picture of the charger detector.

<table>
<thead>
<tr>
<th>EN_B</th>
<th>CHK_CHRG_B</th>
<th>CHK_CONTACT</th>
<th>Data pin contact detector</th>
<th>Charger detector</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Enabled</td>
<td>Disabled</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>x(don't care)</td>
<td>Disabled</td>
<td>Enabled</td>
</tr>
<tr>
<td>1</td>
<td>x</td>
<td>x(don't care)</td>
<td>Disabled</td>
<td>Disabled</td>
</tr>
</tbody>
</table>
43.3.7.2 Data pin contact detector

According to Battery Charging Specification (rev 1.2), USB plugs and receptacles are designed such that when the plug is inserted into the receptacle, the power pins make contact before the data pins make contact. Therefore, there is inevitably a time interval during which $USB_n_{\text{VBUS}}$ has been observed by the device while the $USB_n_{\text{DP}}$ and $USB_n_{\text{DN}}$ pins are not still pending for contact. The USB data pin contact detector is designed to give the software an indication of the contact of the data pins.

To enable the USB data pin contact detector, the user should set the CHK_CONTACT bit of the USB1_CHRG_DETECT register to 1 and monitor the PLUG_CONTACT bit status of the USB1_CHRG_DETECT_STAT register. If PLUG_CONTACT is 1, then it indicates that the data pins have make good contacts, otherwise the user should continue to wait until this bit is set.

According to Table 1, it should be noted that the data pin contact detector only works when EN_B=0 and CHK_CHRG_B=1, both bit being of the USB1_CHRG_DETECT register.

43.3.7.3 Charger detector

Once the data pins make contact, the user should enable the charger detector by clearing the CHK_CHRG_B bit that is low-active. Then the user should wait for 40ms and then check the status bit of CHRG_DETECTED in register hw_anadig_usb1_chrg_det_stat. CHRG_DETECTED=1 means that the device is connected to a charger, either a dedicated charger or a charging downstream port (or equivalently called a host charger, or charging host). To further differentiate between a host charger and a dedicated charger, the user is suggested to pull up $USB_n_{\text{DP}}$ signaling a connect event to the host. Then the user should monitor the $USB_n_{\text{DN}}$ line status. If $USB_n_{\text{DN}}=1$, then the charger is a dedicated charger; if $USB_n_{\text{DN}}=0$, then it is a host charger.

43.3.7.4 Charger detection software flow

Upon seeing VBUS, the software should follow the software flow for the charger detection process. The flow chart mentions the "enable the vdd3p0 current limiter". Please refer to the power chapter for details.
USBPHY Charger Detection Software Flow

**Start**

- **Enable the vbbud currer limiter**
  - Set PMU_REG_3P0.ENABLE_ILIMIT = 1'b1
  - and PMU_REG_3P0.ENABLE_LINREG = 1'b1

- **USBn_VBUS_DETECT_STAT**
  - VBUSVALID = 1'b1?

  - **N**
    - **Turn off the charger detector**
      - (set EN_B and CHK_CHRG_B to 1)
      - In register USBn_VBUS_DETECT

  - **Y**
    - **Set CHK_CHRG_B = 1'b1**
    - **And CHK_CONTACT = 1'b1**
    - **Continue normal boot up**

- **USB plug contacted?**
  - **N**
    - **Set CHK_CONTACT = 1'b0**
    - **And CHK_CHRG_B = 1'b0**
    - **Is it a charger?**
      - **N**
        - **Continue boot up**
      - **Y**
        - **Turn off the charger detector**
          - (set EN_B and CHK_CHRG_B to 1)
          - (monitor the PLUG_CONTACT bit)

  - **Y**
    - **Wait for > 40ms**
    - **(monitor the CHRG_DETECTED bit)**

    - **N**
      - **Turn off the charger detector**
        - (set EN_B and CHK_CHRG_B to 1)

    - **Y**
      - **Is it a charger?**
        - **N**
          - **Continue boot up**
        - **Y**
          - **Turn off the charger detector**
            - (set EN_B and CHK_CHRG_B to 1)
          - **Wait for > 40ms**
          - **Initilaize system and USB**
            - (can only draw 100mA current)
          - **Pull DP high to enumerate**
          - **Continue boot up**

  - **Timeout**
    - **VBUS is coming from a dedicated power supply. No USB actions required.**

  - **Continue boot up**

**Figure 43-3. USBPHY Charger Detection Software Flow**
43.3.7.5 Dead Battery Protect

All the descriptions above are based on the assumption that all the power supplies have been on when the device is plugged into a remote host (or charger). However, there are cases when the local battery of the portable device has been so depleted that the system could not be turned on. In such scenarios the user may prefer a method of signaling the external power management unit (PMIC) the existence of the USB charger to draw a current larger than 100mA from the remote host to speed up system boot up or battery charging. The charger detector indeed supports this function.

When we have a fully depleted battery, all the power supplies might be off. Upon insertion of the 5V, the supplies are brought up by the external PMIC and the internal regulators. Due to the 100mA inrush current limit of the USB spec, we cannot draw larger than 100mA current which might be a limit for system boot-up. Since by default, EN_B=0, CHK_CHRG_B=0 and CHK_CONTACT=1, the usb charger detector is automatically enabled without any software operation needed and it can signal the external PMIC the existence of a USB charger through the open-drain output pin USB_OTG_CHD_B. This pin should be pulled up to an external voltage that is acceptable to the PMIC. If this signal is low, then the PMIC can get that the device is connected to a charger. In this case, the PMIC can draw more than 100mA current from the USB.

It should be noted that this function requires cooperation between the chip and the external PMIC. It is suggested that the user consult NXP for such use cases.

### 43.4 USB PHY Memory Map/Register Definition

USBPHY Hardware Register Format Summary

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_9000</td>
<td>USB PHY Power-Down Register (USBPHY1_PWD)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_9004</td>
<td>USB PHY Power-Down Register (USBPHY1_PWD_SET)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_9008</td>
<td>USB PHY Power-Down Register (USBPHY1_PWD_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_900C</td>
<td>USB PHY Power-Down Register (USBPHY1_PWD_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_9010</td>
<td>USB PHY Transmitter Control Register (USBPHY1_TX)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
</tbody>
</table>

Table continues on the next page...

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### USBPHY memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_9014</td>
<td>USB PHY Transmitter Control Register (USBPHY1_TX_SET)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
<tr>
<td>400D_9018</td>
<td>USB PHY Transmitter Control Register (USBPHY1_TX_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
<tr>
<td>400D_901C</td>
<td>USB PHY Transmitter Control Register (USBPHY1_TX_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
<tr>
<td>400D_9020</td>
<td>USB PHY Receiver Control Register (USBPHY1_RX)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
<tr>
<td>400D_9024</td>
<td>USB PHY Receiver Control Register (USBPHY1_RX_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
<tr>
<td>400D_9028</td>
<td>USB PHY Receiver Control Register (USBPHY1_RX_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
<tr>
<td>400D_902C</td>
<td>USB PHY Receiver Control Register (USBPHY1_RX_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
<tr>
<td>400D_9030</td>
<td>USB PHY General Control Register (USBPHY1_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_9034</td>
<td>USB PHY General Control Register (USBPHY1_CTRL_SET)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_9038</td>
<td>USB PHY General Control Register (USBPHY1_CTRL_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_903C</td>
<td>USB PHY General Control Register (USBPHY1_CTRL_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_9040</td>
<td>USB PHY Status Register (USBPHY1_STATUS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.5/2485</td>
</tr>
<tr>
<td>400D_9050</td>
<td>USB PHY Debug Register (USBPHY1_DEBUG)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_9054</td>
<td>USB PHY Debug Register (USBPHY1_DEBUG_SET)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_9058</td>
<td>USB PHY Debug Register (USBPHY1_DEBUG_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_905C</td>
<td>USB PHY Debug Register (USBPHY1_DEBUG_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_9060</td>
<td>UTMI Debug Status Register 0 (USBPHY1_DEBUG0_STATUS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>43.4.7/2489</td>
</tr>
<tr>
<td>400D_9070</td>
<td>UTMI Debug Status Register 1 (USBPHY1_DEBUG1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_9074</td>
<td>UTMI Debug Status Register 1 (USBPHY1_DEBUG1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_9078</td>
<td>UTMI Debug Status Register 1 (USBPHY1_DEBUG1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_907C</td>
<td>UTMI Debug Status Register 1 (USBPHY1_DEBUG1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_9080</td>
<td>UTMI RTL Version (USBPHY1_VERSION)</td>
<td>32</td>
<td>R</td>
<td>0403_0000h</td>
<td>43.4.9/2491</td>
</tr>
<tr>
<td>400D_A000</td>
<td>USB PHY Power-Down Register (USBPHY2_PWD)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_A004</td>
<td>USB PHY Power-Down Register (USBPHY2_PWD_SET)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_A008</td>
<td>USB PHY Power-Down Register (USBPHY2_PWD_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_A00C</td>
<td>USB PHY Power-Down Register (USBPHY2_PWD_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>001E_1C00h</td>
<td>43.4.1/2477</td>
</tr>
<tr>
<td>400D_A010</td>
<td>USB PHY Transmitter Control Register (USBPHY2_TX)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
<tr>
<td>400D_A014</td>
<td>USB PHY Transmitter Control Register (USBPHY2_TX_SET)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
<tr>
<td>400D_A018</td>
<td>USB PHY Transmitter Control Register (USBPHY2_TX_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
<tr>
<td>400D_A01C</td>
<td>USB PHY Transmitter Control Register (USBPHY2_TX_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>1006_0607h</td>
<td>43.4.2/2479</td>
</tr>
<tr>
<td>400D_A020</td>
<td>USB PHY Receiver Control Register (USBPHY2_RX)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_A024</td>
<td>USB PHY Receiver Control Register (USBPHY2_RX_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
<tr>
<td>400D_A028</td>
<td>USB PHY Receiver Control Register (USBPHY2_RX_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
<tr>
<td>400D_A02C</td>
<td>USB PHY Receiver Control Register (USBPHY2_RX_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.3/2480</td>
</tr>
<tr>
<td>400D_A030</td>
<td>USB PHY General Control Register (USBPHY2_CTRL)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_A034</td>
<td>USB PHY General Control Register (USBPHY2_CTRL_SET)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_A038</td>
<td>USB PHY General Control Register (USBPHY2_CTRL_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_A03C</td>
<td>USB PHY General Control Register (USBPHY2_CTRL_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>C020_0000h</td>
<td>43.4.4/2482</td>
</tr>
<tr>
<td>400D_A040</td>
<td>USB PHY Status Register (USBPHY2_STATUS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.4.5/2485</td>
</tr>
<tr>
<td>400D_A050</td>
<td>USB PHY Debug Register (USBPHY2_DEBUG)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_A054</td>
<td>USB PHY Debug Register (USBPHY2_DEBUG_SET)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_A058</td>
<td>USB PHY Debug Register (USBPHY2_DEBUG_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_A05C</td>
<td>USB PHY Debug Register (USBPHY2_DEBUG_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>7F18_0000h</td>
<td>43.4.6/2487</td>
</tr>
<tr>
<td>400D_A060</td>
<td>UTMI Debug Status Register 0 (USBPHY2_DEBUG0_STATUS)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>43.4.7/2489</td>
</tr>
<tr>
<td>400D_A070</td>
<td>UTMI Debug Status Register 1 (USBPHY2_DEBUG1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_A074</td>
<td>UTMI Debug Status Register 1 (USBPHY2_DEBUG1_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_A078</td>
<td>UTMI Debug Status Register 1 (USBPHY2_DEBUG1_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_A07C</td>
<td>UTMI Debug Status Register 1 (USBPHY2_DEBUG1_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_1000h</td>
<td>43.4.8/2490</td>
</tr>
<tr>
<td>400D_A080</td>
<td>UTMI RTL Version (USBPHY2_VERSION)</td>
<td>32</td>
<td>R</td>
<td>0403_0000h</td>
<td>43.4.9/2491</td>
</tr>
</tbody>
</table>
43.4.1 USB PHY Power-Down Register (USBPHYx_PWDn)

The USB PHY Power-Down Register provides overall control of the PHY power state. Before programming this register, the PHY clocks must be enabled in registers USBPHYx_CTRLn and CCM_ANALOG_USBPHYx_PLL_480_CTRLn.

Address: Base address + 0h offset + (4d × i), where i=0d to 3d

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |

Reset: 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**USBPHYx_PWDn field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–21 RSVD2</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>
| 20 RXPWDRX | 0 = Normal operation.  
1 = Power-down the entire USB PHY receiver block except for the full-speed differential receiver.  
Note that this bit will be auto cleared if there is USB wakeup event while ENAUTOCLR_PHY_PWD bit of USBPHYx_CTRL is enabled. |
| 19 RXPWDDIFF | 0 = Normal operation.  
1 = Power-down the USB high-speed differential receiver. |

*Table continues on the next page...*
### USBPHYx_PWDn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 18 RXPWD1PT1 | 0 = Normal operation.  
1 = Power-down the USB full-speed differential receiver.  
Note that this bit will be auto cleared if there is USB wakeup event while ENAUTOCLR_PHY_PWD bit of USBPHYx_CTRL is enabled. |
| 17 RXPWDENV | 0 = Normal operation.  
1 = Power-down the USB high-speed receiver envelope detector (squelch signal).  
Note that this bit will be auto cleared if there is USB wakeup event while ENAUTOCLR_PHY_PWD bit of USBPHYx_CTRL is enabled. |
| 16–13 RSVD1 | Reserved. |
| 12 TXPWDV2I | 0 = Normal operation.  
1 = Power-down the USB PHY transmit V-to-I converter and the current mirror.  
Note that this bit will be auto cleared if there is USB wakeup event while ENAUTOCLR_PHY_PWD bit of USBPHYx_CTRL is enabled.  
Note that these circuits are shared with the battery charge circuit. Setting this to 1 does not power-down these circuits, unless the corresponding bit in the battery charger is also set for power-down. |
| 11 TXPWDIBIAS | 0 = Normal operation.  
1 = Power-down the USB PHY current bias block for the transmitter. This bit should be set only when the USB is in suspend mode. This effectively powers down the entire USB transmit path.  
Note that this bit will be auto cleared if there is USB wakeup event while ENAUTOCLR_PHY_PWD bit of USBPHYx_CTRL is enabled.  
Note that these circuits are shared with the battery charge circuit. Setting this bit to 1 does not power-down these circuits, unless the corresponding bit in the battery charger is also set for power-down. |
| 10 TXPWDFS | 0 = Normal operation.  
1 = Power-down the USB full-speed drivers. This turns off the current starvation sources and puts the drivers into high-impedance output.  
Note that this bit will be auto cleared if there is USB wakeup event while ENAUTOCLR_PHY_PWD bit of USBPHYx_CTRL is enabled. |
| RSVD0 | Reserved. |
### 43.4.2 USB PHY Transmitter Control Register (USBPHYx_TXn)

The USB PHY Transmitter Control Register handles the transmit controls.

**Address:** Base address + 10h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**USBPHYx_TXn field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–29 RSVD5</td>
<td>Reserved.</td>
</tr>
<tr>
<td>28–26 USBPHY_TX_EDGECTRL</td>
<td>Controls the edge-rate of the current sensing transistors used in HS transmit. NOT FOR CUSTOMER USE.</td>
</tr>
<tr>
<td>25–20 RSVD2</td>
<td>Reserved.</td>
</tr>
<tr>
<td>19–16 TXCAL45DP</td>
<td>Decode to select a 45-Ohm resistance to the USB_DP output pin. Maximum resistance = 0000. Resistance is centered by design at 0110.</td>
</tr>
<tr>
<td>15–12 RSVD1</td>
<td>Reserved.</td>
</tr>
<tr>
<td>Note: This bit should remain clear.</td>
<td></td>
</tr>
<tr>
<td>11–8 TXCAL45DN</td>
<td>Decode to select a 45-Ohm resistance to the USB_DN output pin. Maximum resistance = 0000. Resistance is centered by design at 0110.</td>
</tr>
<tr>
<td>7–4 RSVD0</td>
<td>Reserved.</td>
</tr>
<tr>
<td>Note: This bit should remain clear.</td>
<td></td>
</tr>
<tr>
<td>D_CAL</td>
<td>Resistor Trimming Code:</td>
</tr>
<tr>
<td>0000 = 0.16%</td>
<td></td>
</tr>
<tr>
<td>0111 = Nominal</td>
<td></td>
</tr>
<tr>
<td>1111 = +25%</td>
<td></td>
</tr>
</tbody>
</table>
43.4.3 USB PHY Receiver Control Register (USBPHYx_RXn)

The USB PHY Receiver Control Register handles receive path controls.

Address: Base address + 20h offset + (4d × i), where 0d to 3d

USBPHYx_RXn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–23</td>
<td>RSVD2</td>
</tr>
<tr>
<td>22</td>
<td>RXDBYPASS</td>
</tr>
<tr>
<td>21–7</td>
<td>RSVD1</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USBPHYx_RXn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 6–4 DISCONADJ | The DISCONADJ field adjusts the trip point for the disconnect detector:  
  
  000 = Trip-Level Voltage is 0.57500 V  
  001 = Trip-Level Voltage is 0.56875 V  
  010 = Trip-Level Voltage is 0.58125 V  
  011 = Trip-Level Voltage is 0.58750 V  
  1XX = Reserved |
| 3 RSVD0 | Reserved. |
| ENVADJ | The ENVADJ field adjusts the trip point for the envelope detector:  
  
  000 = Trip-Level Voltage is 0.12500 V  
  001 = Trip-Level Voltage is 0.10000 V  
  010 = Trip-Level Voltage is 0.13750 V  
  011 = Trip-Level Voltage is 0.15000 V  
  1XX = Reserved |
43.4.4 USB PHY General Control Register (USBPHYx_CTRLn)

The USB PHY General Control Register handles OTG and Host controls. This register also includes interrupt enables and connectivity detect enables and results.

Address: Base address + 30h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>SFIRST</td>
<td>CLKGATE</td>
<td>UTMI_SUSPENDM</td>
<td>HOST_FORCE_LS_SE0</td>
<td>OTG_ID_VALUE</td>
<td>RSVD1</td>
<td>FSDLL_RST_EN</td>
<td>ENVBUSCHG_WKUP</td>
<td>ENIDCHG_WKUP</td>
<td>ENDPDMCHG_WKUP</td>
<td>ENAUTOCLR_PHY_PWD</td>
<td>ENAUTOCLR_CLKGATE</td>
<td>ENAUTO_PWRON_PLL</td>
<td>WAKEUP_IRQ</td>
<td>ENIRQWAKEUP</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>ENUTMILEVEL3</td>
<td>ENUTMILEVEL2</td>
<td>DATA_ON_LRADC</td>
<td>DEVPLUGIN_IRQ</td>
<td>ENIRQDEVPLUGIN</td>
<td>RESUME_IRQ</td>
<td>ENIRQRESUMEDECT</td>
<td>RESUMERQSTICKY</td>
<td>ENOTGIDDETECT</td>
<td>OTG_ID_CHG_IRQ</td>
<td>DEVPOLARITY</td>
<td>DEVPIDMDETECT</td>
<td>HOSTIDMDETECT</td>
<td>ENIDMDETECT</td>
<td>ENOTG_ID_CHG_IRQ</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
## USBPHYx_CTRL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 SFTRST</td>
<td>Writing a 1 to this bit will soft-reset the USBPHYx_PWD, USBPHYx_TX, USBPHYx_RX, and USBPHYx_CTRL registers. Set to 0 to release the PHY from reset.</td>
</tr>
<tr>
<td>30 CLKGATE</td>
<td>Gate UTMI Clocks. Clear to 0 to run clocks. Set to 1 to gate clocks. Set this to save power while the USB is not actively being used. Configuration state is kept while the clock is gated. Note this bit can be auto-cleared if there is any wakeup event when USB is suspended while ENAUTOCLR_CLKGATE bit of USBPHYx_CTRL is enabled.</td>
</tr>
<tr>
<td>29 UTMI_SUSPENDM</td>
<td>Used by the PHY to indicate a powered-down state. If all the power-down bits in the USBPHYx_PWD are enabled, UTMI_SUSPENDM will be 0, otherwise 1. UTMI_SUSPENDM is negative logic, as required by the UTMI specification.</td>
</tr>
<tr>
<td>28 HOST_FORCE_LS_SE0</td>
<td>Forces the next FS packet that is transmitted to have an EOP with LS timing. This bit is used in host mode for the resume sequence. After the packet is transferred, this bit is cleared. The design can use this function to force the LS SE0 or use the USBPHYx_CTRL_UTMI_SUSPENDM to trigger this event when leaving suspend. This bit is used in conjunction with USBPHYx_DEBUG_HOST_RESUME_DEBUG.</td>
</tr>
<tr>
<td>27 OTG_ID_VALUE</td>
<td>Almost same as OTGID_STATUS in USBPHYx_STATUS Register. The only difference is that OTG_ID_VALUE has debounce logic to filter the glitches on ID Pad.</td>
</tr>
<tr>
<td>26–25 RSVD1</td>
<td>Reserved.</td>
</tr>
<tr>
<td>24 FSDL RST EN</td>
<td>Enables the feature to reset the FSDLL lock detection logic at the end of each TX packet.</td>
</tr>
<tr>
<td>23 ENVBUSCHG_WKUP</td>
<td>Enables the feature to wakeup USB if VBUS is toggled when USB is suspended.</td>
</tr>
<tr>
<td>22 ENIDCHG_WKUP</td>
<td>Enables the feature to wakeup USB if ID is toggled when USB is suspended.</td>
</tr>
<tr>
<td>21 ENDPDMCHG_WKUP</td>
<td>Enables the feature to wakeup USB if DP/DM is toggled when USB is suspended. This bit is enabled by default.</td>
</tr>
<tr>
<td>20 ENAUTOCLR_PHY_PWD</td>
<td>Enables the feature to auto-clear the PWD register bits in USBPHYx_PWD if there is wakeup event while USB is suspended. This should be enabled if needs to support auto wakeup without S/W's interaction.</td>
</tr>
<tr>
<td>19 ENAUTOCLR_CLKGATE</td>
<td>Enables the feature to auto-clear the CLKGATE bit if there is wakeup event while USB is suspended. This should be enabled if needs to support auto wakeup without S/W's interaction.</td>
</tr>
<tr>
<td>18 ENAUTO_PWRON_PLL</td>
<td>Enables the feature to auto-enable the POWER bit of HW_CLKCTRL_PLLxCTRL0 if there is wakeup event if USB is suspended. This should be enabled if needs to support auto wakeup without S/W's interaction.</td>
</tr>
<tr>
<td>17 WAKEUP_IRQ</td>
<td>Indicates that there is a wakeup event. Reset this bit by writing a 1 to the clear address space and not by a general write.</td>
</tr>
<tr>
<td>16 ENIRQWAKEUP</td>
<td>Enables interrupt for the wakeup events.</td>
</tr>
<tr>
<td>15 ENUTMILEVEL3</td>
<td>Enables UTMI+ Level3. This should be enabled if needs to support external FS Hub with LS device connected</td>
</tr>
<tr>
<td>14 ENUTMILEVEL2</td>
<td>Enables UTMI+ Level2. This should be enabled if needs to support LS device</td>
</tr>
<tr>
<td>13 DATA_ON_LRADC</td>
<td>Enables the LRADC to monitor USB_DP and USB_DM. This is for use in non-USB modes only.</td>
</tr>
<tr>
<td>12 DEVPLUGIN_IRQ</td>
<td>Indicates that the device is connected. Reset this bit by writing a 1 to the clear address space and not by a general write.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USBPHYx_CTRLn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11 ENIRQDEVPLUGIN</td>
<td>Enables interrupt for the detection of connectivity to the USB line.</td>
</tr>
<tr>
<td>10 RESUME_IRQ</td>
<td>Indicates that the host is sending a wake-up after suspend. This bit is also set on a reset during suspend. Use this bit to wake up from suspend for either the resume or the reset case. Reset this bit by writing a 1 to the clear address space and not by a general write.</td>
</tr>
<tr>
<td>9 ENIRQRESUMEDETECT</td>
<td>Enables interrupt for detection of a non-J state on the USB line. This should only be enabled after the device has entered suspend mode.</td>
</tr>
<tr>
<td>8 RESUMEIRQSTICKY</td>
<td>Set to 1 will make RESUME_IRQ bit a sticky bit until software clear it. Set to 0, RESUME_IRQ only set during the wake-up period.</td>
</tr>
<tr>
<td>7 ENOTGIDDETECT</td>
<td>Enables circuit to detect resistance of MiniAB ID pin.</td>
</tr>
<tr>
<td>6 OTG_ID_CHG_IRQ</td>
<td>OTG ID change interrupt. Indicates the value of ID pin changed.</td>
</tr>
<tr>
<td>5 DEVPLUGIN_POLARITY</td>
<td>For device mode, if this bit is cleared to 0, then it trips the interrupt if the device is plugged in. If set to 1, then it trips the interrupt if the device is unplugged.</td>
</tr>
<tr>
<td>4 ENDEVPLUGINDETECT</td>
<td>For device mode, enables 200-KOhm pullups for detecting connectivity to the host.</td>
</tr>
<tr>
<td>3 HOSTDISCONDETECT_IRQ</td>
<td>Indicates that the device has disconnected in high-speed mode. Reset this bit by writing a 1 to the clear address space and not by a general write.</td>
</tr>
<tr>
<td>2 ENIRQHOSTDISCON</td>
<td>Enables interrupt for detection of disconnection to Device when in high-speed host mode. This should be enabled after ENDEVPLUGINDETECT is enabled.</td>
</tr>
<tr>
<td>1 ENHOSTDISCONDETECT</td>
<td>For host mode, enables high-speed disconnect detector. This signal allows the override of enabling the detection that is normally done in the UTMI controller. The UTMI controller enables this circuit whenever the host sends a start-of-frame packet. SW shall set this bit when it found the high-speed device is connected, suggested during bus reset, after found high-speed device in USB_PORTSC1.PSPD). SW shall make sure this bit is not set at the end of resume, otherwise a wrong disconnect status may be detected. Suggest clear it after set USB_PORTSC1.SUSP, set it again after resume is ended(USB_PORTSC1.FPR==0).</td>
</tr>
<tr>
<td>0 ENOTG_ID_CHG_IRQ</td>
<td>Enable OTG_ID_CHG_IRQ.</td>
</tr>
</tbody>
</table>
43.4.5  USB PHY Status Register (USBPHYx_STATUS)

The USB PHY Status Register holds results of IRQ and other detects.

Address: Base address + 40h offset

```
+-----------------+-----------------+-----------------+-----------------+-----------------+-----------------+
| Bit 31 30 29 28 27 26 25 24 | Bit 23 22 21 20 19 18 17 16 |
+-----------------+-----------------+-----------------+-----------------+-----------------+-----------------+
|         R       |       RSVD4     |                   |                   |                   |                   |
+-----------------+-----------------+-----------------+-----------------+-----------------+-----------------+
| W               | W               | W               | W               | W               | W               |
+-----------------+-----------------+-----------------+-----------------+-----------------+-----------------+
| Reset 0 0 0 0 0 0 0 0 | Reset 0 0 0 0 0 0 0 0 |
+-----------------+-----------------+-----------------+-----------------+-----------------+-----------------+
```
### USBPHYx_STATUS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–11 RSVD4</td>
<td>Reserved.</td>
</tr>
<tr>
<td>10 RESUME_STATUS</td>
<td>Indicates that the host is sending a wake-up after suspend and has triggered an interrupt.</td>
</tr>
<tr>
<td>9 RSVD3</td>
<td>Reserved.</td>
</tr>
<tr>
<td>8 OTGID_STATUS</td>
<td>Indicates the results of ID pin on MiniAB plug.</td>
</tr>
<tr>
<td></td>
<td>False (0) is when ID resistance is less than Ra_Plug_ID, indicating host (A) side.</td>
</tr>
<tr>
<td></td>
<td>True (1) is when ID resistance is greater than Rb_Plug_ID, indicating device (B) side.</td>
</tr>
<tr>
<td>7 RSVD2</td>
<td>Reserved.</td>
</tr>
<tr>
<td>6 DEVLPLUGIN_STATUS</td>
<td>Indicates that the device has been connected on the USB_DP and USB_DM lines.</td>
</tr>
<tr>
<td>5–4 RSVD1</td>
<td>Reserved.</td>
</tr>
<tr>
<td>3 HOSTDISCONDETTECT_STATUS</td>
<td>Indicates that the device has disconnected while in high-speed host mode.</td>
</tr>
<tr>
<td>RSVD0</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>
43.4.6 USB PHY Debug Register (USBPHYx_DEBUGn)

This register is used to debug the USB PHY.

Address: Base address + 50h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit 31</th>
<th>Bit 30</th>
<th>Bit 29</th>
<th>Bit 28</th>
<th>Bit 27</th>
<th>Bit 26</th>
<th>Bit 25</th>
<th>Bit 24</th>
<th>Bit 23</th>
<th>Bit 22</th>
<th>Bit 21</th>
<th>Bit 20</th>
<th>Bit 19</th>
<th>Bit 18</th>
<th>Bit 17</th>
<th>Bit 16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RSVD3</td>
<td>CLKGATE</td>
<td>HOST_RESUME_DEBUG</td>
<td>SQUELCHRESETLENGTH</td>
<td>ENSQUELCHRESET</td>
<td>SQUELCHRESETCOUNT</td>
<td>R</td>
<td>RSVD2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RSVD1</td>
<td>ENTX2RXCOUNT</td>
<td>TX2RXCOUNT</td>
<td>RSVDO</td>
<td>ENHSTPULLDOWN</td>
<td>HSTPULLDOWN</td>
<td>DEBUG_INTERFACE_HOLD</td>
<td>OTGIDPLOCK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
## USBPHYx_DEBUGn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 RSVD3</td>
<td>Reserved.</td>
</tr>
<tr>
<td>30 CLKGATE</td>
<td>Gate Test Clocks. Clear to 0 for running clocks. Set to 1 to gate clocks. Set this to save power while the USB is not actively being used. Configuration state is kept while the clock is gated.</td>
</tr>
<tr>
<td>29 HOST_RESUME_DEBUG</td>
<td>Choose to trigger the host resume SE0 with HOST_FORCE_LS_SE0 = 0 or UTMI_SUSPEND = 1.</td>
</tr>
<tr>
<td>28–25 SQUELCHRESETLENGTH</td>
<td>Duration of RESET in terms of the number of 480-MHz cycles.</td>
</tr>
<tr>
<td>24 ENSQUELCHRESET</td>
<td>Set bit to allow squelch to reset high-speed receive.</td>
</tr>
<tr>
<td>23–21 RSVD2</td>
<td>Reserved.</td>
</tr>
<tr>
<td>20–16 SQUELCHRESETCOUNT</td>
<td>Delay in between the detection of squelch to the reset of high-speed RX.</td>
</tr>
<tr>
<td>15–13 RSVD1</td>
<td>Reserved.</td>
</tr>
<tr>
<td>12 ENTX2RXCOUNT</td>
<td>Set this bit to allow a countdown to transition in between TX and RX.</td>
</tr>
<tr>
<td>11–8 TX2RXCOUNT</td>
<td>Delay in between the end of transmit to the beginning of receive. This is a Johnson count value and thus will count to 8.</td>
</tr>
<tr>
<td>7–6 RSVD0</td>
<td>Reserved.</td>
</tr>
<tr>
<td>5–4 ENHSTPULLDOWN</td>
<td>Set bit 5 to 1 to override the control of the USB_DP 15-KOhm pulldown. Set bit 4 to 1 to override the control of the USB_DM 15-KOhm pulldown. Clear to 0 to disable.</td>
</tr>
<tr>
<td>3–2 HSTPULLDOWN</td>
<td>Set bit 3 to 1 to pull down 15-KOhm on USB_DP line. Set bit 2 to 1 to pull down 15-KOhm on USB_DM line. Clear to 0 to disable.</td>
</tr>
<tr>
<td>1 DEBUG_INTERFACE_HOLD</td>
<td>Use holding registers to assist in timing for external UTMI interface.</td>
</tr>
<tr>
<td>0 OTGIDPIOLOCK</td>
<td>Once OTG ID from USBPHYx_STATUS_OTGID_STATUS, use this to hold the value. This is to save power for the comparators that are used to determine the ID status.</td>
</tr>
</tbody>
</table>
43.4.7 UTMI Debug Status Register 0 (USBPHYx_DEBUG0_STATUS)

The UTMI Debug Status Register 0 holds multiple views for counters and status of state machines. This is used in conjunction with the USBPHYx_DEBUG1_DBG_ADDRESS field to choose which function to view. The default is described in the bit fields below and is used to count errors.

Address: Base address + 60h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>SQUELCH_COUNT</th>
<th>UTMI_RXERROR_FAIL_COUNT</th>
<th>LOOP_BACK_FAIL_COUNT</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**USBPHYx_DEBUG0_STATUS field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–26 SQUELCH_COUNT</td>
<td>Running count of the squelch reset instead of normal end for HS RX.</td>
</tr>
<tr>
<td>25–16 UTMI_RXERROR_FAIL_COUNT</td>
<td>Running count of the UTMI_RXERROR.</td>
</tr>
<tr>
<td>LOOP_BACK_FAIL_COUNT</td>
<td>Running count of the failed pseudo-random generator loopback. Each time entering testmode, counter goes to 900D and will count up for every detected packet failure in digital/analog loopback tests.</td>
</tr>
</tbody>
</table>
43.4.8 UTMI Debug Status Register 1 (USBPHYx_DEBUG1n)

Chooses the muxing of the debug register to be shown in USBPHYx_DEBUG0_STATUS.

Address: Base address + 70h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Reserved.</td>
<td>Delay increment of the rise of squelch:</td>
<td>00 = Delay is nominal</td>
<td>01 = Delay is +20%</td>
<td>10 = Delay is -20%</td>
<td>11 = Delay is -40%</td>
</tr>
</tbody>
</table>

**USBPHYx_DEBUG1n field descriptions**

**Note:** This bit should remain clear.
43.4.9 UTMI RTL Version (USBPHYx_VERSION)

Fields for RTL Version.

Address: Base address + 80h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>MAJOR</td>
</tr>
<tr>
<td>23-16</td>
<td>MINOR</td>
</tr>
<tr>
<td>15-8</td>
<td>STEP</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>1</td>
</tr>
<tr>
<td>17</td>
<td>1</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
</tr>
<tr>
<td>31</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset value: 0010_0004h

USBPHYx_VERSION field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>MAJOR</td>
</tr>
<tr>
<td>23–16</td>
<td>MINOR</td>
</tr>
<tr>
<td>15–8</td>
<td>STEP</td>
</tr>
</tbody>
</table>

USB Analog Memory Map/Register Definition

USB_ANALOG memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_81A0</td>
<td>USB VBUS Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0010_0004h</td>
<td>43.5.1/2493</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_VBUS_DETECT)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>400D_81A4</td>
<td>USB VBUS Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0010_0004h</td>
<td>43.5.1/2493</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_VBUS_DETECT_SET)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>400D_81A8</td>
<td>USB VBUS Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0010_0004h</td>
<td>43.5.1/2493</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_VBUS_DETECT_CLR)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>400D_81AC</td>
<td>USB VBUS Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0010_0004h</td>
<td>43.5.1/2493</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_VBUS_DETECT_TOG)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>400D_81B0</td>
<td>USB Charger Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.2/2495</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_CHRG_DETECT)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>400D_81B4</td>
<td>USB Charger Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.2/2495</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_CHRG_DETECT_SET)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>400D_81B8</td>
<td>USB Charger Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.2/2495</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_CHRG_DETECT_CLR)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>400D_81BC</td>
<td>USB Charger Detect Register</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.2/2495</td>
</tr>
<tr>
<td>(USB_ANALOG_USB1_CHRG_DETECT_TOG)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
## USB_ANALOG memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_81C0</td>
<td>USB VBUS Detect Status Register (USB_ANALOG_USB1_VBUS_DETECT_STAT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>43.5.3/2497</td>
</tr>
<tr>
<td>400D_81D0</td>
<td>USB Charger Detect Status Register (USB_ANALOG_USB1_CHRG_DETECT_STAT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>43.5.4/2499</td>
</tr>
<tr>
<td>400D_81E0</td>
<td>USB Loopback Test Register (USB_ANALOG_USB1_LOOPBACK)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.5/2500</td>
</tr>
<tr>
<td>400D_81E4</td>
<td>USB Loopback Test Register (USB_ANALOG_USB1_LOOPBACK_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.5/2500</td>
</tr>
<tr>
<td>400D_81E8</td>
<td>USB Loopback Test Register (USB_ANALOG_USB1_LOOPBACK_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.5/2500</td>
</tr>
<tr>
<td>400D_81EC</td>
<td>USB Loopback Test Register (USB_ANALOG_USB1_LOOPBACK_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.5/2500</td>
</tr>
<tr>
<td>400D_81F0</td>
<td>USB Misc Register (USB_ANALOG_USB1_MISC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.6/2501</td>
</tr>
<tr>
<td>400D_81F4</td>
<td>USB Misc Register (USB_ANALOG_USB1_MISC_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.6/2501</td>
</tr>
<tr>
<td>400D_81F8</td>
<td>USB Misc Register (USB_ANALOG_USB1_MISC_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.6/2501</td>
</tr>
<tr>
<td>400D_81FC</td>
<td>USB Misc Register (USB_ANALOG_USB1_MISC_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.6/2501</td>
</tr>
<tr>
<td>400D_8200</td>
<td>USB VBUS Detect Register (USB_ANALOG_USB2_VBUS_DETECT)</td>
<td>32</td>
<td>R/W</td>
<td>0010_0000h</td>
<td>43.5.7/2502</td>
</tr>
<tr>
<td>400D_8204</td>
<td>USB VBUS Detect Register (USB_ANALOG_USB2_VBUS_DETECT_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0010_0000h</td>
<td>43.5.7/2502</td>
</tr>
<tr>
<td>400D_8208</td>
<td>USB VBUS Detect Register (USB_ANALOG_USB2_VBUS_DETECT_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0010_0000h</td>
<td>43.5.7/2502</td>
</tr>
<tr>
<td>400D_820C</td>
<td>USB VBUS Detect Register (USB_ANALOG_USB2_VBUS_DETECT_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0010_0000h</td>
<td>43.5.7/2502</td>
</tr>
<tr>
<td>400D_8210</td>
<td>USB Charger Detect Register (USB_ANALOG_USB2_CHRG_DETECT)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.8/2504</td>
</tr>
<tr>
<td>400D_8214</td>
<td>USB Charger Detect Register (USB_ANALOG_USB2_CHRG_DETECT_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.8/2504</td>
</tr>
<tr>
<td>400D_8218</td>
<td>USB Charger Detect Register (USB_ANALOG_USB2_CHRG_DETECT_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.8/2504</td>
</tr>
<tr>
<td>400D_821C</td>
<td>USB Charger Detect Register (USB_ANALOG_USB2_CHRG_DETECT_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.8/2504</td>
</tr>
<tr>
<td>400D_8220</td>
<td>USB VBUS Detect Status Register (USB_ANALOG_USB2_VBUS_DETECT_STAT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>43.5.9/2506</td>
</tr>
<tr>
<td>400D_8230</td>
<td>USB Charger Detect Status Register (USB_ANALOG_USB2_CHRG_DETECT_STAT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>43.5.10/2508</td>
</tr>
<tr>
<td>400D_8240</td>
<td>USB Loopback Test Register (USB_ANALOG_USB2_LOOPBACK)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.11/2509</td>
</tr>
<tr>
<td>400D_8244</td>
<td>USB Loopback Test Register (USB_ANALOG_USB2_LOOPBACK_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.11/2509</td>
</tr>
<tr>
<td>400D_8248</td>
<td>USB Loopback Test Register (USB_ANALOG_USB2_LOOPBACK_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.11/2509</td>
</tr>
<tr>
<td>400D_824C</td>
<td>USB Loopback Test Register (USB_ANALOG_USB2_LOOPBACK_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>43.5.11/2509</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## USB_ANALOG memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400D_8250</td>
<td>USB Misc Register (USB_ANALOG_USB2_MISC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0002h</td>
<td>43.5.12/2510</td>
</tr>
<tr>
<td>400D_8254</td>
<td>USB Misc Register (USB_ANALOG_USB2_MISC_SET)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0002h</td>
<td>43.5.12/2510</td>
</tr>
<tr>
<td>400D_8258</td>
<td>USB Misc Register (USB_ANALOG_USB2_MISC_CLR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0002h</td>
<td>43.5.12/2510</td>
</tr>
<tr>
<td>400D_825C</td>
<td>USB Misc Register (USB_ANALOG_USB2_MISC_TOG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0002h</td>
<td>43.5.12/2510</td>
</tr>
<tr>
<td>400D_8260</td>
<td>Chip Silicon Version (USB_ANALOG_DIGPROG)</td>
<td>32</td>
<td>R</td>
<td>006C_0000h</td>
<td>43.5.13/2511</td>
</tr>
</tbody>
</table>

### 43.5.1 USB VBUS Detect Register (USB_ANALOG_USB1_VBUS_DETECTn)

This register defines controls for USB VBUS detect.

Address: 400D_8000h base + 1A0h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
</tr>
<tr>
<td>30</td>
</tr>
<tr>
<td>29</td>
</tr>
<tr>
<td>28</td>
</tr>
<tr>
<td>27</td>
</tr>
<tr>
<td>26</td>
</tr>
<tr>
<td>25</td>
</tr>
<tr>
<td>24</td>
</tr>
<tr>
<td>23</td>
</tr>
<tr>
<td>22</td>
</tr>
<tr>
<td>21</td>
</tr>
<tr>
<td>20</td>
</tr>
<tr>
<td>19</td>
</tr>
<tr>
<td>18</td>
</tr>
<tr>
<td>17</td>
</tr>
<tr>
<td>16</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
</tr>
<tr>
<td>14</td>
</tr>
<tr>
<td>13</td>
</tr>
<tr>
<td>12</td>
</tr>
<tr>
<td>11</td>
</tr>
<tr>
<td>10</td>
</tr>
<tr>
<td>9</td>
</tr>
<tr>
<td>8</td>
</tr>
<tr>
<td>7</td>
</tr>
<tr>
<td>6</td>
</tr>
<tr>
<td>5</td>
</tr>
<tr>
<td>4</td>
</tr>
<tr>
<td>3</td>
</tr>
<tr>
<td>2</td>
</tr>
<tr>
<td>1</td>
</tr>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

#### USB_ANALOG_USB1_VBUS_DETECTn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>
### USB_ANALOG_USB1_VBUS_DETECTn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>27 CHARGE_VBUS</td>
<td>USB OTG charge VBUS.</td>
</tr>
<tr>
<td>26 DISCHARGE_VBUS</td>
<td>USB OTG discharge VBUS.</td>
</tr>
<tr>
<td>25–21</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>20 VBUSVALID_PWRUP_CMPS</td>
<td>Powers up comparators for vbus_valid detector.</td>
</tr>
<tr>
<td>19–3</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>VBUSVALID_THRESH</td>
<td>Set the threshold for the VBUSVALID comparator. This comparator is the most accurate method to</td>
</tr>
<tr>
<td></td>
<td>determine the presence of 5V, and includes hysteresis to minimize the need for software debounce</td>
</tr>
<tr>
<td></td>
<td>of the detection. This comparator has ~50mV of hysteresis to prevent chattering at the comparator</td>
</tr>
<tr>
<td></td>
<td>trip point.</td>
</tr>
<tr>
<td>000</td>
<td><strong>4V0</strong> — 4.0V</td>
</tr>
<tr>
<td>001</td>
<td><strong>4V1</strong> — 4.1V</td>
</tr>
<tr>
<td>010</td>
<td><strong>4V2</strong> — 4.2V</td>
</tr>
<tr>
<td>011</td>
<td><strong>4V3</strong> — 4.3V</td>
</tr>
<tr>
<td>100</td>
<td><strong>4V4</strong> — 4.4V (default)</td>
</tr>
<tr>
<td>101</td>
<td><strong>4V5</strong> — 4.5V</td>
</tr>
<tr>
<td>110</td>
<td><strong>4V6</strong> — 4.6V</td>
</tr>
<tr>
<td>111</td>
<td><strong>4V7</strong> — 4.7V</td>
</tr>
</tbody>
</table>
43.5.2 USB Charger Detect Register
(USB_ANALOG_USB1_CHRG_DETECTn)

This register defines controls for USB charger detect.

Address: 400D_8000h base + 1B0h offset + (4d x i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>23</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>22-21</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>20</td>
<td>Control the charger detector.</td>
</tr>
<tr>
<td></td>
<td>0 ENABLE — Enable the charger detector.</td>
</tr>
<tr>
<td></td>
<td>1 DISABLE — Disable the charger detector.</td>
</tr>
<tr>
<td>19</td>
<td>Check the charger connection</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## USB_ANALOG_USB1_CHRG_DETECTn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>CHECK</strong> — Check whether a charger (either a dedicated charger or a host charger) is connected to USB port.</td>
</tr>
<tr>
<td>1</td>
<td><strong>NO_CHECK</strong> — Do not check whether a charger is connected to the USB port.</td>
</tr>
<tr>
<td>18</td>
<td><strong>CHK_CONTACT</strong> Check the contact of USB plug</td>
</tr>
<tr>
<td>0</td>
<td><strong>NO_CHECK</strong> — Do not check the contact of USB plug.</td>
</tr>
<tr>
<td>1</td>
<td><strong>CHECK</strong> — Check whether the USB plug has been in contact with each other</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>
43.5.3 USB VBUS Detect Status Register  
(USB_ANALOG_USB1_VBUS_DETECT_STAT)

This register defines fields for USB VBUS Detect status.

Address: 400D_8000h base + 1C0h offset = 400D_81C0h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**USB_ANALOG_USB1_VBUS_DETECT_STAT field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## USB_ANALOG_USB1_VBUS_DETECT_STAT field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3 VBUS_VALID</td>
<td>VBus valid for USB OTG. This bit is a read only version of the state of the analog signal. It can not be overwritten by software.</td>
</tr>
<tr>
<td>2 AVALID</td>
<td>Indicates VBus is valid for a A-peripheral. This bit is a read only version of the state of the analog signal. It can not be overritten by software.</td>
</tr>
<tr>
<td>1 BVALID</td>
<td>Indicates VBus is valid for a B-peripheral. This bit is a read only version of the state of the analog signal. It can not be overritten by software.</td>
</tr>
</tbody>
</table>
| 0 SESSEND | Session End for USB OTG. This bit is a read only version of the state of the analog signal. It can not be overritten by software like the SESSEND bit below.  
NOTE: This bit's default value depends on whether VDD5V is present, 0 if VDD5V is present, 1 if VDD5V is not present. |
43.5.4 USB Charger Detect Status Register
(USB_ANALOG_USB1_CHRG_DETECT_STAT)

This register defines fields for USB charger detect status.

Address: 400D_8000h base + 1D0h offset = 400D_81D0h
### USB_ANALOG_USB1_CHRG_DETECT_STAT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>3 DP_STATE</td>
<td>DP line state output of the charger detector.</td>
</tr>
<tr>
<td>2 DM_STATE</td>
<td>DM line state output of the charger detector.</td>
</tr>
<tr>
<td>1 CHRG_DETECTED</td>
<td>State of charger detection. This bit is a read only version of the state of the analog signal.</td>
</tr>
<tr>
<td>0</td>
<td><strong>CHARGER_NOT_PRESENT</strong> — The USB port is not connected to a charger.</td>
</tr>
<tr>
<td>1</td>
<td><strong>CHARGER_PRESENT</strong> — A charger (either a dedicated charger or a host charger) is connected to the USB port.</td>
</tr>
<tr>
<td>0 PLUG_CONTACT</td>
<td>State of the USB plug contact detector.</td>
</tr>
<tr>
<td>0</td>
<td><strong>NO_CONTACT</strong> — The USB plug has not made contact.</td>
</tr>
<tr>
<td>1</td>
<td><strong>GOOD_CONTACT</strong> — The USB plug has made good contact.</td>
</tr>
</tbody>
</table>

### 43.5.5 USB Loopback Test Register

**USB_ANALOG_USB1_LOOPBACK\(n\)**

This register defines controls for the USB1 loopback test function.

Address: 400D_8000h base + 1E0h offset + (4d \times i), where i=0d to 3d

---

**Reserved**

**Reserved**

---

NXP Semiconductors
### USB_ANALOG_USB1_LOOPBACKn Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>UTMI_TESTSTART</td>
<td>Setting this bit can enable 1.5 kΩ pull-up resister on DP.</td>
</tr>
</tbody>
</table>

**NOTE:** This bit can only be used as DCD detection, while it must be cleared in normal function.

### 43.5.6 USB Misc Register (USB_ANALOG_USB1_MISCn)

This register defines controls for USB.

**Address:** 400D_8000h base + 1F0h offset + (4d × i), where i=0d to 3d

#### Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>UTMI_TESTSTART</td>
<td>Enables the clk to the UTMI block.</td>
</tr>
</tbody>
</table>

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### USB_ANALOG_USB1_MISCn Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB_ANALOG_USB1_MISCn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 EN_DEGLITCH</td>
<td>Enable the deglitching circuit of the USB PLL output.</td>
</tr>
<tr>
<td>0 HS_USE_EXTERNAL_R</td>
<td>Use external resistor to generate the current bias for the high speed transmitter. This bit should not be changed unless recommended by NXP.</td>
</tr>
</tbody>
</table>

### 43.5.7 USB VBUS Detect Register

**(USB_ANALOG_USB2_VBUS_DETECTn)**

This register defines controls for USB VBUS detect.

Address: 400D_8000h base + 200h offset + (4d × i), where i=0d to 3d

#### USB ANALOG_USB2_VBUS_DETECT field descriptions

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>27 CHARGE_VBUS</td>
<td>USB OTG charge VBUS.</td>
</tr>
<tr>
<td>26 DISCHARGE_VBUS</td>
<td>USB OTG discharge VBUS.</td>
</tr>
<tr>
<td>25–21</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### USB_ANALOG_USB2_VBUS_DETECT\(n\) field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>20 VBUSVALID_PWRUP_CMPS</td>
<td>Powers up comparators for vbus_valid detector.</td>
</tr>
<tr>
<td>19–3</td>
<td>Reserved.</td>
</tr>
<tr>
<td>VBUSVALID_THRESH</td>
<td>Set the threshold for the VBUSVALID comparator. This comparator is the most accurate method to determine the presence of 5V, and includes hysteresis to minimize the need for software debounce of the detection. This comparator has ~50mV of hysteresis to prevent chattering at the comparator trip point.</td>
</tr>
<tr>
<td>000</td>
<td>4V0 — 4.0V</td>
</tr>
<tr>
<td>001</td>
<td>4V1 — 4.1V</td>
</tr>
<tr>
<td>010</td>
<td>4V2 — 4.2V</td>
</tr>
<tr>
<td>011</td>
<td>4V3 — 4.3V</td>
</tr>
<tr>
<td>100</td>
<td>4V4 — 4.4V (default)</td>
</tr>
<tr>
<td>101</td>
<td>4V5 — 4.5V</td>
</tr>
<tr>
<td>110</td>
<td>4V6 — 4.6V</td>
</tr>
<tr>
<td>111</td>
<td>4V7 — 4.7V</td>
</tr>
</tbody>
</table>
43.5.8 USB Charger Detect Register
(USB_ANALOG_USB2_CHRG_DETECTn)

This register defines controls for USB charger detect.

Address: 400D_8000h base + 210h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

USB_ANALOG_USB2_CHRG_DETECTn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–24</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>23</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>22–21</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>20</td>
<td>Control the charger detector.</td>
</tr>
<tr>
<td>EN_B</td>
<td>0 ENABLE — Enable the charger detector.</td>
</tr>
<tr>
<td></td>
<td>1 DISABLE — Disable the charger detector.</td>
</tr>
<tr>
<td>19</td>
<td>Check the charger connection</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### USB_ANALOG_USB2_CHRG_DETECTn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td><strong>CHECK</strong> — Check whether a charger (either a dedicated charger or a host charger) is connected to USB port.</td>
</tr>
<tr>
<td>1</td>
<td><strong>NO_CHECK</strong> — Do not check whether a charger is connected to the USB port.</td>
</tr>
<tr>
<td>18</td>
<td><strong>CHK_CONTACT</strong> Check the contact of USB plug</td>
</tr>
<tr>
<td>0</td>
<td><strong>NO_CHECK</strong> — Do not check the contact of USB plug.</td>
</tr>
<tr>
<td>1</td>
<td><strong>CHECK</strong> — Check whether the USB plug has been in contact with each other</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>Reserved.</td>
</tr>
</tbody>
</table>
This register defines fields for USB VBUS Detect status.

Address: 400D_8000h base + 220h offset = 400D_8220h

USB_ANALOG_USB2_VBUS_DETECT_STAT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>-</td>
<td>Reserved.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## USB_ANALOG_USB2_VBUS_DETECT_STAT field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3 VBUS_VALID</td>
<td>VBus valid for USB OTG. This bit is a read only version of the state of the analog signal. It can not be overwritten by software.</td>
</tr>
<tr>
<td>2 AVALID</td>
<td>Indicates VBus is valid for a A-peripheral. This bit is a read only version of the state of the analog signal. It can not be overritten by software.</td>
</tr>
<tr>
<td>1 BVALID</td>
<td>Indicates VBus is valid for a B-peripheral. This bit is a read only version of the state of the analog signal. It can not be overritten by software.</td>
</tr>
</tbody>
</table>
| 0 SESSEND | Session End for USB OTG. This bit is a read only version of the state of the analog signal. It can not be overwritten by software like the SESSEND bit below.  
NOTE: This bit's default value depends on whether VDD5V is present, 0 if VDD5V is present, 1 if VDD5V is not present. |
This register defines fields for USB charger detect status.

Address: 400D_8000h base + 230h offset = 400D_8230h
### USB_ANALOG_USB2_CHRG_DETECT_STAT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>3 DP_STATE</td>
<td>DP line state output of the charger detector.</td>
</tr>
<tr>
<td>2 DM_STATE</td>
<td>DM line state output of the charger detector.</td>
</tr>
<tr>
<td>1 CHRG_DETECTED</td>
<td>State of charger detection. This bit is a read only version of the state of the analog signal.</td>
</tr>
<tr>
<td>0</td>
<td></td>
</tr>
<tr>
<td>0 NO_CONTACT</td>
<td>The USB plug has not made contact.</td>
</tr>
<tr>
<td>1 GOOD_CONTACT</td>
<td>The USB plug has made good contact.</td>
</tr>
</tbody>
</table>

### 43.5.11 USB Loopback Test Register ([USB_ANALOG_USB2_LOOPBACKn])

This register defines controls for the USB2 loopback test function.

Address: 400D_8000h base + 240h offset + (4d x i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
USB Analog Memory Map/Register Definition

**USB_ANALOG_USB2_LOOPBACKn field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–1</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>0</td>
<td>UTMI_TESTSTART</td>
</tr>
<tr>
<td></td>
<td>Setting this bit can enable 1.5 kΩ pull-up resister on DP.</td>
</tr>
<tr>
<td><strong>NOTE:</strong></td>
<td>This bit can only be used as DCD detection, while it must be cleared in normal function.</td>
</tr>
</tbody>
</table>

### 43.5.12 USB Misc Register (USB_ANALOG_USB2_MISCn)

This register defines controls for USB.

Address: 400D_8000h base + 250h offset + (4d × i), where i=0d to 3d

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

**USB_ANALOG_USB2_MISCn field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>This field is reserved. Reserved.</td>
</tr>
<tr>
<td>30 EN_CLK_UTMI</td>
<td>Enables the clk to the UTMI block.</td>
</tr>
<tr>
<td>29–2</td>
<td>This field is reserved. Reserved.</td>
</tr>
</tbody>
</table>

Table continues on the next page...

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
USB_ANALOG_USB2_MISCn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 EN_DEGLITCH</td>
<td>Enable the deglitching circuit of the USB PLL output.</td>
</tr>
<tr>
<td>0 HS_USE_EXTERNAL_R</td>
<td>Use external resistor to generate the current bias for the high speed transmitter. This bit should not be changed unless recommended by NXP.</td>
</tr>
</tbody>
</table>

43.5.13 Chip Silicon Version (USB_ANALOG_DIGPROG)

The DIGPROG register returns the digital program ID for the silicon.

Address: 400D_8000h base + 260h offset = 400D_8260h

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|     | R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|     | W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 1   | 0   | 1   | 1   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

USB_ANALOG_DIGPROG field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SILICON_REVISION</td>
<td>Chip silicon revision</td>
</tr>
<tr>
<td>0x006C0000</td>
<td>Silicon revision 1.0</td>
</tr>
</tbody>
</table>
Chapter 44
Flexible Controller Area Network (FLEXCAN)

44.1 Chip-specific FLEXCAN information

Table 44-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

44.2 Overview

The Flexible Controller Area Network (FLEXCAN) module is a communication controller implementing the CAN protocol according to the CAN 2.0B protocol specification.

The CAN protocol was primarily designed to be used as a vehicle serial data bus meeting the specific requirements of this field: real-time processing, reliable operation in the EMI environment of a vehicle, cost-effectiveness and required bandwidth. The FLEXCAN module is a full implementation of the CAN protocol specification, which supports both standard and extended message frames. 64 Message Buffers are supported by the Flexcan module.
44.2.1 Block Diagram

A general block diagram is shown in the figure below, which describes the main sub-blocks implemented in the FLEXCAN module, including the associated memory for storing Mailboxes, Rx Global Mask Registers, Rx Individual Mask Registers, Rx FIFO and Rx FIFO ID Filters.

Support for 64 Mailboxes and 6-deep Rx FIFO is provided. The functions of the sub-modules are described in subsequent sections.
Figure 44-1. FLEXCAN Block Diagram
44.2.2 FLEXCAN Module Features

The FLEXCAN module includes these distinctive legacy features:

- Version 2.0B
  - Standard data and remote frames
  - Extended data and remote frames
  - Zero to eight bytes data length
  - Programmable bit rate up to 1 Mb/sec
  - Content-related addressing
- Flexible Mailboxes of eight bytes data length
- Each Mailbox is configurable as Rx or Tx, all supporting standard and extended messages
- Individual Rx Mask Registers per Mailbox
- Full featured Rx FIFO with storage capacity for 6 frames and internal pointer handling
- Transmission abort capability
- Powerful Rx FIFO ID filtering, capable of matching incoming IDs against either 128 extended, 256 standard or 512 partial (8 bits) IDs, with up to 32 individual masking capability
- 100% backwards compatibility with previous FLEXCAN version
- Unused structures space can be used as general purpose RAM space
- Listen only mode capability
- Programmable loop-back mode supporting self-test operation
- Programmable transmission priority scheme: lowest ID, lowest buffer number or highest priority
- Time Stamp based on 16-bit free-running timer
- Global network time, synchronized by a specific message
- Maskable interrupts independent of the transmission medium (an external transceiver is assumed)
- Short latency time due to an arbitration scheme for high-priority messages
- Low power modes, with programmable wake up on bus activity
- Configurable Glitch filter width to filter the noise on CAN bus when waking up
- Remote request frames may be handled automatically or by software.
- ID filter configuration in Normal Mode
- CAN bit time settings and configuration bits can only be written in Freeze Mode
- Tx mailbox status (Lowest priority buffer or empty buffer)
- SYNC bit status to inform that the module is synchronous with CAN bus
- CRC status for transmitted message
- Selectable priority between Mailboxes and Rx FIFO during matching process
44.2.3 Modes of Operation

The FLEXCAN module has four functional modes: Normal Mode (User and Supervisor), Freeze Mode, Listen-Only Mode and Loop-Back Mode. There are also two low power modes: Disable Mode and Stop Mode.

• Normal Mode (User or Supervisor):

In Normal Mode, the module operates receiving and/or transmitting message frames, errors are handled normally and all the CAN Protocol functions are enabled. User and Supervisor Modes differ in the access to some restricted control registers.

• Freeze Mode:

It is enabled when the FRZ bit in the MCR Register is asserted. If enabled, Freeze Mode is entered when the HALT bit in MCR is set or when Debug Mode is requested at MCU level and the FRZ_ACK bit in the MCR Register is asserted by the FlexCAN. In this mode, no transmission or reception of frames is done and synchronicity to the CAN bus is lost. See Freeze Mode for more information.

• Listen-Only Mode:

The module enters this mode when the LOM bit in the Control Register is asserted. In this mode, transmission is disabled, all error counters are frozen and the module operates in a CAN Error Passive mode. Only messages acknowledged by another CAN station will be received. If FLEXCAN detects a message that has not been acknowledged, it will flag a BIT0 error (without changing the REC), as if it was trying to acknowledge the message.

• Loop-Back Mode:

The module enters this mode when the LPB bit in the Control Register is asserted. In this mode, FLEXCAN performs an internal loop back that can be used for self test operation. The bit stream output of the transmitter is internally fed back to the receiver input. The FLEXCAN_RX input pin is ignored and the FLEXCAN_TX output goes to the recessive state (logic '1'). FLEXCAN behaves as it normally does when transmitting and treats its own transmitted message as a message received from a remote node. In this mode, FLEXCAN ignores the bit sent during the ACK slot in the CAN frame acknowledge field to ensure proper reception of its own message. Both transmit and receive interrupts are generated.

• Module Disable Mode:
This low power mode is entered when the MDIS bit in the MCR Register is asserted and
the LPM_ACK is asserted by the FlexCAN. When disabled, the module requests to
disable the clocks to the CAN Protocol Engine and Controller Host Interface sub-
modules. Exit from this mode is done by negating the MDIS bit in the MCR Register. See
Module Disable Mode for more information.

- Stop Mode:

This low power mode is entered when Stop Mode is requested at Arm level and the
LPM_ACK bit in the MCR Register is asserted by the FlexCAN. When in Stop Mode,
the module puts itself in an inactive state and then informs the Arm that the clocks can be
shut down globally. Exit from this mode happens when the Stop Mode request is
removed or when activity is detected on the CAN bus and the Self Wake Up mechanism
is enabled. See Stop Mode for more information.

44.3 External Signals

The FLEXCAN module has two I/O signals.

Table 44-2. FLEXCAN External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXCAN1_RX</td>
<td>FLEXCAN receive pin. This pin is the receive pin from the CAN bus transceiver. Dominant state is represented by logic level '0'. Recessive state is represented by logic level '1'.</td>
<td>GPIO_AD_B1_09</td>
<td>ALT2</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_03</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMC_18</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_SD_B1_03</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>FLEXCAN1_TX</td>
<td>FLEXCAN transmit pin. This pin is the transmit pin to the CAN bus transceiver. Dominant state is represented by logic level '0'. Recessive state is represented by logic level '1'.</td>
<td>GPIO_AD_B1_08</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B0_02</td>
<td>ALT2</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMC_17</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_SD_B1_02</td>
<td>ALT4</td>
<td></td>
</tr>
<tr>
<td>FLEXCAN2_RX</td>
<td>FLEXCAN transmit pin. This pin is the transmit pin to the CAN bus transceiver. Dominant state is represented by logic level '0'. Recessive state is represented by logic level '1'.</td>
<td>GPIO_AD_B0_03</td>
<td>ALT0</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_EMC_10</td>
<td>ALT3</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_15</td>
<td>ALT6</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_09</td>
<td>ALT6</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 44-2. FLEXCAN External Signals
(continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>GPIO</th>
<th>ALT</th>
</tr>
</thead>
<tbody>
<tr>
<td>FLEXCAN2_TX</td>
<td>FLEXCAN receive pin. This pin is the receive pin from the CAN bus transceiver. Dominant state is represented by logic level '0'. Recessive state is represented by logic level '1'.</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXCAN3_RX</td>
<td>FLEXCAN transmit pin. This pin is the transmit pin to the CAN bus transceiver. Dominant state is represented by logic level '0'. Recessive state is represented by logic level '1'.</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>FLEXCAN3_TX</td>
<td>FLEXCAN receive pin. This pin is the receive pin from the CAN bus transceiver. Dominant state is represented by logic level '0'. Recessive state is represented by logic level '1'.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

44.4 Clocks

The table found here describes the clock sources for FLEXCAN.

Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

Table 44-3. FLEXCAN Clocks

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_chi</td>
<td>ipg_clk_root</td>
<td>CHI clock</td>
</tr>
<tr>
<td>ipg_clk_pe</td>
<td>can_clk_root</td>
<td>Protocol Engine clock</td>
</tr>
<tr>
<td>ipg_clk_pe_nogate</td>
<td>can_clk_root</td>
<td>Protocol Engine clock (no gating)</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
<tr>
<td>mem_ram_CLK</td>
<td>ipg_clk_root</td>
<td>RAM clock</td>
</tr>
</tbody>
</table>
44.5 Message Buffer Structure

Message Buffer Address: Base + 0x0080-0x047C.

The Message Buffer structure used by the FLEXCAN module is represented in the following table.

Both Extended and Standard Frames (29-bit Identifier and 11-bit Identifier, respectively) used in the CAN specification are represented.

Each individual Message buffer is formed by 16 bytes.

<table>
<thead>
<tr>
<th>Table 44-4. Message Buffer Structure</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
</tr>
<tr>
<td>0x0</td>
</tr>
<tr>
<td>0x4</td>
</tr>
<tr>
<td>0x8</td>
</tr>
<tr>
<td>0xC</td>
</tr>
</tbody>
</table>

CODE - Message Buffer Code

This 4-bit field can be accessed (read or write) by the CPU and by the FLEXCAN module itself, as part of the message buffer matching and arbitration process. The encoding is shown in the following tables. See Functional Description for additional information.

<table>
<thead>
<tr>
<th>Table 44-5. Message Buffer Code for Rx buffers</th>
</tr>
</thead>
<tbody>
<tr>
<td>CODE Description</td>
</tr>
<tr>
<td>-------------------</td>
</tr>
<tr>
<td>0b0000: INACTIVE-MB is not active.</td>
</tr>
<tr>
<td>0b0100: EMPTY-MB is active and empty.</td>
</tr>
<tr>
<td>0b0010: FULL-MB is full.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 44-5. Message Buffer Code for Rx buffers (continued)

<table>
<thead>
<tr>
<th>CODE Description</th>
<th>Rx Code BEFORE receive New Frame</th>
<th>SRV¹</th>
<th>Rx Code AFTER successful reception²</th>
<th>RRS³</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>new frame is moved to the MB after the MB was serviced, the code still remains FULL. Refer to Matching Process for matching details related to FULL code.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>No</td>
<td>OVERRUN</td>
<td>-</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>If the MB is FULL and a new frame is moved to this MB before the CPU services it, the CODE field is automatically updated to OVERRUN. Refer to Matching Process for details about overrun behavior.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0b0110: OVERRUN - MB is being overwritten into a full buffer.</td>
<td>OVERRUN</td>
<td>Yes</td>
<td>FULL</td>
<td>-</td>
<td>If the CODE field indicates OVERRUN and CPU has serviced the MB, when a new frame is moved to the MB, the code returns to FULL.</td>
</tr>
<tr>
<td></td>
<td>No</td>
<td>OVERRUN</td>
<td>-</td>
<td>If the CODE field already indicates OVERRUN, and another new frame must be moved, the MB will be overwritten again, and the code will remain OVERRUN. Refer to Matching Process for details about overrun behavior.</td>
<td></td>
</tr>
<tr>
<td>0b1010: RANSWER⁴ - A frame was configured to recognize a Remote Request Frame and transmit a Response Frame in return.</td>
<td>RANSWER</td>
<td>-</td>
<td>TANSWER(0b1110)</td>
<td>0</td>
<td>A Remote Answer was configured to recognize a remote request frame received, after that a MB is set to transmit a response frame. The code is automatically changed to TANSWER(0b1110). Refer to Matching Process for details.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CODE[0]=1b1: BUSY - FlexCAN is updating the contents of the MB. The CPU must not access the MB.</td>
<td>BUSY⁵</td>
<td>-</td>
<td>FULL</td>
<td>-</td>
<td>Indicates that the MB is being updated, it will be negated automatically and does not interfere on the next CODE.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1. SRV: Serviced MB. MB was read and unlocked by reading TIMER or other MB.
2. A frame is considered successful reception after the frame to be moved to MB (move-in process). Refer to Move-in for details
3. Remote Request Stored bit from CTRL2 register. Refer to CTRL2 for details.
4. Code 4'b1010 is not considered as a Tx and a MB with this code should not to be aborted.
5. Note that for Tx MBs, the BUSY bit should be ignored upon read, except when AEN bit is set in the MCR register. If this bit is asserted, the corresponding MB does not participate in the matching process.

---

<table>
<thead>
<tr>
<th>CODE Description</th>
<th>Rx Code BEFORE receive New Frame</th>
<th>SRV¹</th>
<th>Rx Code AFTER successful reception²</th>
<th>RRS³</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

NXP Semiconductors 2521
<table>
<thead>
<tr>
<th>CODE Description</th>
<th>Tx Code BEFORE tx frame</th>
<th>MB RT R</th>
<th>Tx Code AFTER successful transmission</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b1000: INACTIVE - MB is not active</td>
<td>INACTIVE</td>
<td>-</td>
<td>-</td>
<td>MB does not participate in the arbitration process.</td>
</tr>
<tr>
<td>0b1001: ABORT - MB is aborted</td>
<td>ABORT</td>
<td>-</td>
<td>-</td>
<td>MB does not participate in the arbitration process.</td>
</tr>
<tr>
<td>0b1100: DATA - MB is a Tx Data Frame (MB RTR must be 0)</td>
<td>DATA</td>
<td>0</td>
<td>INACTIVE</td>
<td>Transmit data frame unconditionally once. After transmission, the MB automatically returns to the INACTIVE state.</td>
</tr>
<tr>
<td>0b1100: REMOTE - MB is a Tx Remote Request Frame (MB RTR must be 1)</td>
<td>REMOTE</td>
<td>1</td>
<td>EMPTY</td>
<td>Transmit remote request frame unconditionally once. After transmission, the MB automatically becomes an Rx Empty MB with the same ID.</td>
</tr>
<tr>
<td>0b1110: TANSWER - MB is a Tx Response Frame from an incoming Remote Request Frame</td>
<td>TANSWER</td>
<td>-</td>
<td>RANSWER</td>
<td>This is an intermediate code that is automatically written to the MB by the CHI as a result of match to a remote request frame. The remote response frame will be transmitted unconditionally once and then the code will automatically return to RANSWER (0b1010). The CPU can also write this code with the same effect. The remote response frame can be either a data frame or another remote request frame depending on the RTR bit value. Refer to Matching Process and Arbitration process for details.</td>
</tr>
</tbody>
</table>

SRR - Substitute Remote Request

Fixed recessive bit, used only in extended format. It must be set to '1' by the user for transmission (Tx Buffers) and will be stored with the value received on the CAN bus for Rx receiving buffers. It can be received as either recessive or dominant. If FLEXCAN receives this bit as dominant, then it is interpreted as arbitration loss.

1= Recessive value is compulsory for transmission in Extended Format frames
0= Dominant is not a valid value for transmission in Extended Format frames

IDE - ID Extended Bit

This bit identifies whether the frame format is standard or extended. It is also used as part of the reception filter.

1= Frame format is extended
0= Frame format is standard

RTR - Remote Transmission Request
This bit affects the behavior of Remote Frames and is part of the reception filter. Refer to the tables above and RRS bit in **Control 2 Register (FLEXCAN_CTRL2)** for additional details.

If FLEXCAN transmits this bit as '1' (recessive) and receives it as '0' (dominant), it is interpreted as arbitration loss. If this bit is transmitted as '0' (dominant), then if it is received as '1' (recessive), the FLEXCAN module treats it as bit error. If the value received matches the value transmitted, it is considered as a successful bit transmission.

1= Indicates the current MB has a Remote Frame to be transmitted if MB is Tx. If the MB is Rx then incoming Remote Request Frames may be stored.

0= Indicates the current MB has a Data Frame to be transmitted. In Rx MB it may be considered in matching processes.

**DLC - Length of Data in Bytes**

This 4-bit field is the length (in bytes) of the Rx or Tx data, which is located in offset 0x08 through 0x0F of the MB space (see the first table above). In reception, this field is written by the FLEXCAN module, copied from the DLC (Data Length Code) field of the received frame. In transmission, this field is written by the Arm and corresponds to the DLC field value of the frame to be transmitted. When RTR=1, the Frame to be transmitted is a Remote Frame and does not include the data field, regardless of the Length field. The DLC field indicates which DATA BYTES are valid as shown in the table below.

**TIME STAMP - Free-Running Counter Time Stamp**

This 16-bit field is a copy of the Free-Running Timer, captured for Tx and Rx frames at the time when the beginning of the Identifier field appears on the CAN bus.

**PRIO - Local priority**

This 3-bit field is only used when MCR[LPRIO_EN] bit is asserted and it only makes sense for Tx mailboxes. These bits are not transmitted. They are appended to the regular ID to define the transmission priority. See ** Arbitration process**.

**ID - Frame Identifier**

In Standard Frame format, only the 11 most significant bits (28 to 18) are used for frame identification in both receive and transmit cases. The 18 least significant bits are ignored. In Extended Frame format, all bits are used for frame identification in both receive and transmit cases.

**DATA BYTE 0-7 - Data Field**

Up to eight bytes can be used for a data frame.
For Rx frames, the data is stored as it is received from the CAN bus. DATA BYTE (n) is valid only if \( n \) is less than DLC as shown in the table below.

For Tx frames, the CPU prepares the data field to be transmitted within the frame.

### Table 44-7. DATA BYTEs validity

<table>
<thead>
<tr>
<th>DLC</th>
<th>Valid DATA BYTEs</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>none</td>
</tr>
<tr>
<td>1</td>
<td>DATA BYTE 0</td>
</tr>
<tr>
<td>2</td>
<td>DATA BYTE 0-1</td>
</tr>
<tr>
<td>3</td>
<td>DATA BYTE 0-2</td>
</tr>
<tr>
<td>4</td>
<td>DATA BYTE 0-3</td>
</tr>
<tr>
<td>5</td>
<td>DATA BYTE 0-4</td>
</tr>
<tr>
<td>6</td>
<td>DATA BYTE 0-5</td>
</tr>
<tr>
<td>7</td>
<td>DATA BYTE 0-6</td>
</tr>
<tr>
<td>8</td>
<td>DATA BYTE 0-7</td>
</tr>
</tbody>
</table>

### 44.6 Rx FIFO Structure

When the MCR[RFEN] bit is set, the memory area from 0x80 to 0xDC (which is normally occupied by MBs 0 to 5) is used by the reception FIFO engine.

The region 0x80-0x8C contains the output of the FIFO which must be read by the CPU as a Message Buffer. This output contains the oldest message received and not read yet. The region 0x90-0xDC is reserved for internal use of the FIFO engine.

An additional memory area, that starts at 0xE0 and may extend up to 0x2DC (normally occupied by MBs 6 up to 37) depending on the CTRL2[RFFN] field setting, contains the ID Filter Table (configurable from 8 to 128 memory positions) that specifies filtering criteria for accepting frames into the FIFO. Table 44-8 shows the Rx FIFO data structure.

Each ID Filter Table Element occupies an entire 32-bit word and can be compounded by one, two or four Identifier Acceptance Filters (IDAF) depending on the MCR[IDAM] field setting. Table 44-9, Table 44-10 and Table 44-11 show the IDAF indexation. Table 44-12 show the three different formats that the IDAF can assume, depending on the MCR[IDAM] field setting. Note that all elements of the table must have the same format. See Rx FIFO for more information.

Out of reset, the ID Filter Table flexible memory area defaults to 0xE0 and only extends to 0xFC, which corresponds to MBs 6 to 7 for RFFN=0.
Table 44-8. Rx FIFO Structure

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0x80 |     |     |     |     |     | S | I | R | D | T | R | DLC | TIME STAMP |
| 0x84 |     |     |     |     |     |   |   |   |   |   |   | ID Standard | ID Extended |
| 0x88 | Data Byte 0 | Data Byte 1 | Data Byte 2 | Data Byte 3 |
| 0x8C | Data Byte 4 | Data Byte 5 | Data Byte 6 | Data Byte 7 |
| 0x90 to 0xDC | Reserved |
| 0xE0 | ID Filter Table Element 0 |
| 0xE4 | ID Filter Table Element 1 |
| 0xE8 to 0x2D4 | ID Filter Table Elements 2 through 125 |
| 0x2D8 | ID Filter Table Element 126 |
| 0x2DC | ID Filter Table Element 127 |

Table 44-9. Position of ID Filter Table Elements in format A

| Element | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 16 | 15 | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0       | IDAF0 |
| 1       | IDAF1 |
| 2 through 125 | Identifier Acceptance Filter 2 through 125 |
| 126     | IDAF126 |
| 127     | IDAF127 |

Table 44-10. Position of ID Filter Table Elements in format B

| Element | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 16 | 15 | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0       | IDAF0 | IDAF1 |
| 1       | IDAF2 | IDAF3 |
| 2 through 125 | Identifier Acceptance Filter 4 through 251 |
| 126     | IDAF252 | IDAF253 |

Table continues on the next page...
Table 44-10. Position of ID Filter Table Elements in format B (continued)

<table>
<thead>
<tr>
<th>Element</th>
<th>IDAF254</th>
<th>IDAF255</th>
</tr>
</thead>
<tbody>
<tr>
<td>127</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 44-11. Position of ID Filter Table Elements in format C

<table>
<thead>
<tr>
<th>Element</th>
<th>31</th>
<th>24</th>
<th>23</th>
<th>16</th>
<th>15</th>
<th>8</th>
<th>7</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>IDAF0</td>
<td>IDAF1</td>
<td>IDAF2</td>
<td>IDAF3</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>IDAF4</td>
<td>IDAF5</td>
<td>IDAF6</td>
<td>IDAF7</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2 through 125</td>
<td>Identifier Acceptance Filter 8 through 503</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>126</td>
<td>IDAF504</td>
<td>IDAF505</td>
<td>IDAF506</td>
<td>IDAF507</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>127</td>
<td>IDAF508</td>
<td>IDAF509</td>
<td>IDAF510</td>
<td>IDAF511</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 44-12. Identifier Acceptance Filter Format A, B and C

| Format | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| A      | R | T | R | E | RXIDA | (Standard = 29-19, Extended = 29-1) |
| B      | R | T | R | E | RXIDB_0 | (Standard = 29-19, Extended = 29-16) | R | T | R | E | RXIDB_1 | (Standard = 13-3, Extended = 13-0) |
| C      | RXIDC_0 | RXIDC_1 | RXIDC_2 | RXIDC_3 | RXIDC_0 | RXIDC_1 | RXIDC_2 | RXIDC_3 | RXIDC_0 | RXIDC_1 | RXIDC_2 | RXIDC_3 | (Std/Ext = 31-24) | (Std/Ext = 23-16) | (Std/Ext = 15-8) | (Std/Ext = 7-0) |

RTR - Remote Frame

This bit specifies whether Remote Request Frames are accepted into the FIFO if they match the target ID in Formats A and B. If Format C is chosen the acceptance does not depend on whether the frame is a Remote Request Frame or not.

1= Remote Frames can be accepted and data frames are rejected
0= Remote Frames are rejected and data frames can be accepted

IDE - Extended Frame

Specifies if either Extended or Standard Format frames are accepted into the FIFO if they match the target ID in Formats A and B. If Format C is chosen the acceptance does not depend on whether the frame is of the Extended or Standard Format.

1= Extended frames can be accepted and standard frames are rejected
0= Extended frames are rejected and standard frames can be accepted
RXIDA - Rx Frame Identifier (Format A)

Specifies an ID to be used as acceptance criteria for the FIFO. In the Standard Format (IDAF's or incoming frame's IDE bit is negated), only the 11 most significant bits (29 to 19) are used for frame identification. In the Extended Format (both IDAF's and incoming frame's IDE are asserted), all bits are used.

RXIDB_0, RXIDB_1 - Rx Frame Identifier (Format B)

Specifies an ID to be used as acceptance criteria for the FIFO. In the Standard Format (IDAF's or incoming frame's IDE bit is negated), the 11 most significant bits (29 to 19 and 13 to 3) are used for frame identification. In the Extended Format (both IDAF's and incoming frame's IDE are asserted), all 14 bits of the field are compared with the 14 most significant bits of the Identifier of the incoming frame. The 15 least significant bits of the Identifier of an incoming Extended Format frame do not affect the acceptance.

RXIDC_0, RXIDC_1, RXIDC_2, RXIDC_3 - Rx Frame Identifier (Format C)

Specifies an ID to be used as acceptance criteria for the FIFO. In both Standard Format and Extended Format, all 8 bits of the field are compared to the 8 most significant bits of the Identifier of the incoming frame. The 3 least significant bits of the Identifier of an incoming Standard Format frame and the 21 least significant bits of the Identifier of an incoming Extended Format frame do not affect the acceptance.

### 44.7 Functional Description

This section provides a complete functional description of the block.

#### 44.7.1 Functional Overview

The FLEXCAN module is a CAN protocol engine with a very flexible mailbox system for transmitting and receiving CAN frames. The mailbox system consists of a set of 64 Message Buffers (MB) that store configuration and control data, time stamp, message ID and data (see Message Buffer Structure). The memory corresponding to the first 38 MBs can be configured to support a FIFO reception scheme with a powerful ID filtering mechanism, capable of checking incoming frames against a table of IDs (up to 128 extended IDs or 256 standard IDs or 512 8-bit ID slices), with individual mask register for up to 32 ID Filter Table elements. Simultaneous reception through FIFO and mailbox is supported. For mailbox reception, a matching algorithm makes it possible to store received frames only into MBs that have the same ID. A masking scheme makes it possible to match the ID programmed on the MB with a range of Identifiers on received frames.
CAN frames. For transmission, an *arbitration* algorithm decides the prioritization of MBs to be transmitted based on the message ID (optionally augmented by 3 local priority bits) or the MB ordering.

Before proceeding with the functional description, an important concept must be explained. A Message Buffer is said to be "active" at a given time if it can participate in both the Matching and Arbitration processes. An Rx MB with a 0b0000 code is inactive (refer to Table 44-5). Similarly, a Tx MB with a 0b1000 or 0b1001 code is also inactive (refer to Table 44-6).

### 44.7.2 Transmit Process

In order to transmit a CAN frame, the CPU must prepare a Message Buffer for transmission by executing the procedure found here.

1. Check if the respective interruption bit is set and clear it.
2. If the MB is active (transmission pending), write the ABORT code (0b1001) to the CODE field of the Control and Status word to request an abortion of the transmission. Wait for the corresponding IFLAG to be asserted by polling the IFLAG register or by the interrupt request if enabled by the respective IMASK. Then read back the CODE field to check if the transmission was aborted or transmitted (see Transmission Abort Mechanism). If backwards compatibility is desired (MCR[AEN] bit negated), just write the INACTIVE code (0b1000) to the CODE field to inactivate the MB but then the pending frame may be transmitted without notification (see Message Buffer Inactivation).
3. Write the ID word.
4. Write the data bytes.
5. Write the DLC, Control and Code fields of the Control and Status word to activate the MB.

Once the MB is activated, it will participate into the arbitration process and eventually be transmitted according to its priority.

At the end of the successful transmission, the value of the Free Running Timer at the time of the second bit of frame's Identifier field is written into the MB's Time Stamp field, the CODE field in the Control and Status word is updated, the CRC Register is updated, a status flag is set in the Interrupt Flag Register and an interrupt is generated if allowed by the corresponding Interrupt Mask Register bit. The new CODE field after transmission depends on the code that was used to activate the MB in step four (see Table 44-5 and Table 44-6 in Message Buffer Structure).
When the Abort feature is enabled (MCR[AEN] bit is asserted), after the Interrupt Flag is asserted for a Mailbox configured as transmit buffer, the Mailbox is blocked, therefore the CPU is not able to update it until it negates the Interrupt Flag. It means that the CPU must clear the corresponding IFLAG before starting to prepare this MB for a new transmission or reception.

### 44.7.3 Arbitration process

The arbitration process scans the Mailboxes searching the Tx one that holds the message to be sent in the next opportunity. This Mailbox is called the *arbitration winner*.

The scan starts from the lowest Mailbox number and runs toward the higher ones.

The arbitration process is triggered in the following events:

- From the CRC field of the CAN frame. The start point depends on the CTRL2[TASD] field value. See Control 2 Register (FLEXCAN_CTRL2) for details.
- During the error delimiter field of the CAN frame
- During the Overload Delimiter field of a CAN frame.
- When the winner is inactivated and the CAN bus has still not reached the first bit of the Intermission field.
- When Arm write to the C/S word of a winner MB and the CAN bus has still not reached the first bit of the Intermission field.
- When CHI is in Idle state and Arm writes to the C/S word of any MB.
- When FlexCAN exits Bus Off state
- Upon leaving Freeze Mode or Low Power Mode

If the arbitration process does not manage to evaluate all Mailboxes before the CAN bus has reached the first bit of the Intermission field the temporary arbitration winner is invalidated and the FlexCAN will not compete for the CAN bus in the next opportunity.

The arbitration process selects the winner among the active Tx Mailboxes at the end of the scan according to both CTRL1[LBUF] and MCR[LPRIO_EN] bits settings.

#### 44.7.3.1 Lowest Mailbox number first

If CTRL1[LBUF] bit is asserted the first (lowest number) active Tx Mailbox found is the arbitration winner. MCR[LPRIO_EN] bit has no effect when CTRL1[LBUF] is asserted.
44.7.3.2 Highest Mailbox priority first

If CTRL1[LBUF] bit is negated then the arbitration process searches the active Tx Mailbox with the highest priority, and this Mailbox would have a higher probability to win the arbitration on CAN bus.

The sequence of bits considered for this arbitration is called the *arbitration value* of the Mailbox. The highest priority Tx Mailbox is the one that has the least arbitration value among all Tx Mailboxes.

If two or more Mailboxes have equivalent arbitration values the lowest Mailbox number is the arbitration winner.

The composition of the arbitration value depends on MCR[LPRIO_EN] bit setting.

44.7.3.2.1 Local Priority disabled

If MCR[LPRIO_EN] bit is negated the arbitration value is built in the exact sequence of bits as they would be transmitted in a CAN frame (see Table 44-13) in such a way that the Local Priority is disabled.

<table>
<thead>
<tr>
<th>Format</th>
<th>Mailbox Arbitration Value (32 bits)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard (IDE = 0)</td>
<td>Standard ID (11 bits) RTR (1 bit) IDE (1 bit) - (18 bits)</td>
</tr>
<tr>
<td>Extended (IDE = 1)</td>
<td>Extended ID[28:18] (11 bits) SRR (1 bit) IDE (1 bit) Extended ID[17:0] (18 bits)</td>
</tr>
</tbody>
</table>

44.7.3.2.2 Local Priority enabled

If Local Priority is desired MCR[LPRIO_EN] must be asserted.

In this case the Mailbox PRIO field is included at the very left of the arbitration value (see the table below).

<table>
<thead>
<tr>
<th>Format</th>
<th>Mailbox Arbitration Value (35 bits)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard (IDE = 0)</td>
<td>PRIO (3 bits) Standard ID (11 bits) RTR (1 bit) IDE (1 bit) - (18 bits)</td>
</tr>
<tr>
<td>Extended (IDE = 1)</td>
<td>PRIO (3 bits) Extended ID[28:18] (11 bits) SRR (1 bit) IDE (1 bit) Extended ID[17:0] (18 bits)</td>
</tr>
</tbody>
</table>

Table 44-13. Composition of the arbitration value when Local Priority is disabled

Table 44-14. Composition of the arbitration value when Local Priority is enabled
As the PRIO field is the most significant part of the arbitration value Mailboxes with low PRIO values have higher priority than Mailboxes with high PRIO values regardless the rest of their arbitration values.

Note that the PRIO field is not part of the frame on the CAN bus. Its purpose is only to affect the internal arbitration process.

Once the arbitration winner is found, its content is copied to a hidden auxiliary MB called Tx Serial Message Buffer (Tx SMB), which has the same structure as a normal MB but is not user accessible. This operation is called "move-out" and after it is done, write access to the corresponding MB is blocked (if the AEN bit in MCR is asserted). The write access is released in the following events:

- After the MB is transmitted
- FlexCAN enters in Freeze Mode or Bus Off
- FlexCAN loses the bus arbitration or there is an error during the transmission

At the first opportunity window on the CAN bus, the message on the Tx SMB is transmitted according to the CAN protocol rules. FlexCAN transmits up to eight data bytes, even if the DLC (Data Length Code) field value is greater than that.

Arbitration process can be triggered in the following situations:

- During Rx and Tx frames from CAN CRC field to end of frame. Arbitration start point depends on instantiation parameters NUMBER_OF_MB and TASD. Additionally, TASD value may be changed (see Control 2 Register (FLEXCAN_CTRL2)) to optimize the arbitration start point.
- During CAN Bus Off state from TX_ERR_CNT=124 to 128. Arbitration start point depends on instantiation parameters NUMBER_OF_MB and TASD. Additionally, TASD value may be changed (see Control 2 Register (FLEXCAN_CTRL2)) to optimize the arbitration start point.
- During C/S write by CPU in Bus Idle. First C/S write starts arbitration process and a second C/S write during this same arbitration restarts the process. If other C/S writes are performed, Tx arbitration process is pending. If there is no arbitration winner after arbitration process has finished, then TX arbitration machine begins a new arbitration process.
- Arbitration winner deactivation during a valid arbitration window.
- Upon Leave Freeze Mode. If there is a re-synchronization during WaitForBusIdle arbitration process is restarted.

Arbitration process stops in the following situation:

- All Mailboxes were scanned.
- A Tx active Mailbox is found in case of Lowest Buffer feature enabled.
- Arbitration winner inactivation or abort during any arbitration process.
• There was not enough time to finish Tx arbitration process. For instance, a deactivation was performed near the end of frame). In this case arbitration process is pending.
• Error or Overload flag in the bus.
• Low Power or Freeze Mode request in Idle state

Arbitration is considered pending as described below:

• It was not possible to finish arbitration process in time.
• C/S write during arbitration if write is performed in a MB which number is lower than the Tx arbitration pointer.
• Any C/S write if there is no Tx Arbitration process in progress.
• Rx Match has just updated a Rx Code to Tx Code.
• Entering Bus off state.

C/S write during arbitration has the following effect:

• If C/S write is performed in the arbitration winner, a new process is restarted immediately.
• C/S write during arbitration if write is performed in a MB which number is higher than the Tx arbitration pointer.

44.7.4 Receive Process

To be able to receive CAN frames into a Mailbox, the CPU must prepare it for reception by executing the steps listed here.

1. If the Mailbox is active (either Tx or Rx) inactivate the Mailbox (see Message Buffer Inactivation), preferably with a safe inactivation (see Transmission Abort Mechanism);
2. Write the ID word;
3. Write the EMPTY code (0b0100) to the CODE field of the Control and Status word to activate the Mailbox.

Once the Mailbox is activated in the third step, it will be able to receive frames that match the programmed filter. At the end of a successful reception, the Mailbox is updated by the move-in process (see Move-in) as follows:

1. The received Data field (8 bytes at most) is stored;
2. The received Identifier field is stored;
3. The value of the Free Running Timer at the time of the second bit of frame's Identifier field is written into the Mailbox Time Stamp field;
4. The received SRR, IDE, RTR and DLC fields are stored;
5. The CODE field in the Control and Status word is updated. (see Table 44-5 and Table 44-6 in Section Message Buffer Structure)

6. A status flag is set in the Interrupt Flag Register and an interrupt is generated if allowed by the corresponding Interrupt Mask Register bit.

The recommended way for the CPU servicing (read) the frame received in a Mailbox is using the following procedure:

1. Read the Control and Status word of that Mailbox;
2. Check if the BUSY bit is deasserted, indicating that the Mailbox is locked. Repeat step 1) while it is asserted. See Message Buffer Lock Mechanism;
3. Read the contents of the Mailbox. Once Mailbox is locked now, its contents won't be modified by FlexCAN Move-in processes. See Move-in;
4. Acknowledge the proper flag at IFLAG registers;
5. Read the Free Running Timer. It is optional but recommended to unlock Mailbox as soon as possible and make it available for reception.

The CPU should synchronize to frame reception by the status flag bit for the specific Mailbox in one of the IFLAG Registers and not by the CODE field of that Mailbox. Polling the CODE field does not work because once a frame was received and the CPU services the Mailbox (by reading the C/S word followed by unlocking the Mailbox), the CODE field will not return to EMPTY. It will remain FULL. If the CPU tries to workaround this behavior by writing to the C/S word to force an EMPTY code after reading the Mailbox without a prior safe inactivation, a newly received message matching the filter of that Mailbox may be lost.

In summary: never do polling by reading directly the C/S word of the Mailboxes. Instead, read the IFLAG registers.

Note that the received frame's Identifier field is always stored in the matching Mailbox, thus the contents of the ID field in a Mailbox may change if the match was due to masking. Note also that FlexCAN does receive frames transmitted by itself if there exists a matching Rx Mailbox, provided the MCR[SRX_DIS] bit is not asserted. If MCR[SRX_DIS] bit is asserted, FlexCAN will not store messages transmitted by itself in any MB, even if it contains a matching MB, and no interrupt flag or interrupt signal will be generated due to the frame reception.

To be able to receive CAN messages through the Rx FIFO, the CPU must enable and configure the Rx FIFO during Freeze Mode(see Rx FIFO). Upon receiving the Frames Available in Rx FIFO interrupt(see Interrupt Masks 1 Register (FLEXCAN.IMASK1), bit IFLAG[BUF5I] - Frames available in Rx FIFO), the CPU should service the received frame using the following procedure:
1. Read the Control and Status word (optional - needed only if a mask was used for IDE and RTR bits);
2. Read the ID field (optional - needed only if a mask was used);
3. Read the Data field;
4. Read the RXFIR register (optional);
5. Clear the Frames Available in Rx FIFO interrupt by writing 1 to IFLAG[BUF5I] bit (mandatory - releases the MB and allows the CPU to read the next Rx FIFO entry)

### 44.7.5 Matching Process

The matching process scans the MB memory looking for Rx MBs programmed with the same ID as the one received from the CAN bus. If the FIFO is enabled, the priority of scanning can be selected between Mailboxes and FIFO filters. In any case, the matching starts from the lowest number Message Buffer toward the higher ones. If no match is found within the first structure then the other is scanned subsequently. In the event that the FIFO is full, the matching algorithm will always look for a matching MB outside the FIFO region.

As the frame is being received, it is stored in a hidden auxiliary MB called Rx Serial Message Buffer (Rx SMB).

The matching process start point depends on the following conditions:

- if the received frame is a remote frame, the start point is the CRC field of the frame;
- if the received frame is a data frame with DLC field equal to zero, the start point is the CRC field of the frame;
- if the received frame is a data frame with DLC field different than zero, the start point is the DATA field of the frame;

If a matching ID is found in the FIFO table or in one of the Mailboxes, the contents of the SMB will be transferred to the FIFO or to the matched Mailbox by the move-in process. If any CAN protocol error is detected then no match results will be transferred to the FIFO or to the matched Mailbox at the end of reception.

The matching process scans all matching elements of both Rx FIFO (if enabled) and active Rx Mailboxes (CODE is EMPTY, FULL, OVERRUN or RANSWER) in search of a successful comparison with the matching elements of the Rx SMB that is receiving the frame on the CAN bus. The SMB has the same structure of a Mailbox. The reception structures (Rx FIFO or Mailboxes) associated with the matching elements that had a successful comparison are the matched structures. The matching winner is selected at the end of the scan among those matched structures and depends on conditions described ahead. Refer to the following table for details.
Table 44-15. Matching architecture

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Mailbox</td>
<td>0</td>
<td>-</td>
<td>0</td>
<td>cmp²</td>
<td>no_cmp³</td>
<td>cmp_msk⁴</td>
<td>EMPT or FULL or OVERR</td>
</tr>
<tr>
<td>Mailbox</td>
<td>0</td>
<td>-</td>
<td>1</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>EMPT or FULL or OVERR</td>
</tr>
<tr>
<td>Mailbox</td>
<td>1</td>
<td>0</td>
<td>-</td>
<td>cmp</td>
<td>no_cmp</td>
<td>cmp</td>
<td>RANSWER</td>
</tr>
<tr>
<td>Mailbox</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>cmp</td>
<td>no_cmp</td>
<td>cmp_msk</td>
<td>EMPT or FULL or OVERR</td>
</tr>
<tr>
<td>Mailbox</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>EMPT or FULL or OVERR</td>
</tr>
<tr>
<td>FIFO⁵</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>-</td>
</tr>
</tbody>
</table>

1. For Mailbox structure, If SMB[IDE] is asserted, the ID is 29 bits (ID Standard + ID Extended). In case of SMB[IDE] to be negated, the ID is only 11 bits (ID Standard). Please, refer to Message Buffer Structure for ID details. For FIFO structure, the ID depends on IDAM. Please, refer to Rx FIFO Structure for IDAM details.
2. cmp: Compares the SMB contents with the MB contents regardless the masks.
3. no_cmp: The SMB contents are not compared with the MB contents.
4. cmp_msk: Compares the SMB contents with MB contents taking into account the masks.
5. SMB[IDE] and SMB[RTR] are not taken into account when IDAM is type C.

A reception structure is free-to-receive when any of the following conditions is satisfied:

- the CODE field of the Mailbox is EMPTY;
- the CODE field of the Mailbox is either FULL or OVERR and it has already been serviced (the C/S word was read by the Arm and unlocked as described in Message Buffer Lock Mechanism);
- the CODE field of the Mailbox is either FULL or OVERR and an inactivation is performed. (see Message Buffer Inactivation)
- the Rx FIFO is not full.

The scan order for Mailboxes and Rx FIFO is from the matching element with lowest number to the higher ones.

The matching winner search for Mailboxes is affected by the MCR[IRMQ] bit. If it is negated the matching winner is the first matched Mailbox regardless if it is free-to-receive or not. If it is asserted, the matching winner is selected according to the priority below:

1. the first free-to-receive matched Mailbox;
2. the last non free-to-receive matched Mailbox.
It is possible to select the priority of scan between Mailboxes and Rx FIFO by the CTRL2[MRP] bit.

If the selected priority is Rx FIFO first:

- if the Rx FIFO is a matched structure and is free-to-receive then the Rx FIFO is the matching winner regardless of the scan for Mailboxes;
- otherwise (the Rx FIFO is not a matched structure or is not free-to-receive), then the matching winner is searched among Mailboxes as described above.

If the selected priority is Mailboxes first:

- if a free-to-receive matched Mailbox is found, it is the matching winner regardless the scan for Rx FIFO;
- if no matched Mailbox is found, then the matching winner is searched in the scan for the Rx FIFO;
- if both conditions above are not satisfied and a non free-to-receive matched Mailbox is found then the matching winner determination is conditioned by the MCR[IRMQ] bit:
  - if MCR[IRMQ] bit is negated the matching winner is the first matched Mailbox;
  - if MCR[IRMQ] bit is asserted the matching winner is the Rx FIFO if it is a free-to-receive matched structure, otherwise the matching winner is the last non free-to-receive matched Mailbox.

Please, refer to the table below for a summary of matching possibilities.

If a non-safe Mailbox inactivation (see Message Buffer Inactivation) occurs during matching process and the Mailbox inactivated is the temporary matching winner then the temporary matching winner is invalidated. The matching elements scan is not stopped nor restarted, it continues normally. The consequence is that the current matching process works as if the matching elements compared before the inactivation did not exist, therefore a message may be lost.

Suppose, for example, that the FIFO is disabled, IRMQ is enabled and there are two MBs with the same ID, and FlexCAN starts receiving messages with that ID. Let us say that these MBs are the second and the fifth in the array. When the first message arrives, the matching algorithm will find the first match in MB number 2. The code of this MB is EMPTY, so the message is stored there. When the second message arrives, the matching algorithm will find MB number 2 again, but it is not "free-to-receive", so it will keep looking and find MB number 5 and store the message there. If yet another message with the same ID arrives, the matching algorithm finds out that there are no matching MBs that are "free-to-receive", so it decides to overwrite the last matched MB, which is number 5. In doing so, it sets the CODE field of the MB to indicate OVERRUN.
### Table 44-16. Matching Possibilities and Resulting Reception Structures

<table>
<thead>
<tr>
<th>RFEN</th>
<th>IRMQ</th>
<th>MRP</th>
<th>Matched in MB</th>
<th>Matched in FIFO</th>
<th>Reception Structure</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>None</td>
<td>None</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>X³</td>
<td>None</td>
<td>None</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>X³</td>
<td>Free¹</td>
<td>None</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>X³</td>
<td>None</td>
<td>None</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>X³</td>
<td>Free¹</td>
<td>None</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>X³</td>
<td>NotFree</td>
<td>None</td>
<td>LastMB</td>
<td>Overrun</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>None</td>
<td>None</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X³</td>
<td>None</td>
<td>None</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X³</td>
<td>Free¹</td>
<td>None</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X³</td>
<td>None</td>
<td>None</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X³</td>
<td>Free¹</td>
<td>None</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X³</td>
<td>NotFree</td>
<td>None</td>
<td>LastMB</td>
<td>Overrun</td>
</tr>
</tbody>
</table>

FIFO enabled, Queue disabled

<table>
<thead>
<tr>
<th>RFEN</th>
<th>IRMQ</th>
<th>MRP</th>
<th>Matched in MB</th>
<th>Matched in FIFO</th>
<th>Reception Structure</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>X³</td>
<td>NotFull⁶</td>
<td>FIFO</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>None</td>
<td>Full⁷</td>
<td>None</td>
<td>Frame lost by FIFO full (FIFO Overflow)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Free¹</td>
<td>Full</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>NotFree</td>
<td>Full</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>None</td>
<td>NotFull</td>
<td>FIFO</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>None</td>
<td>Full</td>
<td>None</td>
<td>Frame lost by FIFO full (FIFO Overflow)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Free¹</td>
<td>X</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>NotFree</td>
<td>X</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X³</td>
<td>NotFull</td>
<td>FIFO</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>None</td>
<td>Full</td>
<td>None</td>
<td>Frame lost by FIFO full (FIFO Overflow)</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Free¹</td>
<td>Full</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>None</td>
<td>NotFull</td>
<td>FIFO</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Free¹</td>
<td>X</td>
<td>FirstMB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>NotFree</td>
<td>NotFull</td>
<td>FIFO</td>
<td></td>
</tr>
</tbody>
</table>

1. It is a don't care condition.
2. Matched in MB "None" means that the frame has not matched any MB (free-to-receive or non-free-to-receive).
3. It is a forbidden condition.
4. Matched in MB "Free" means that the frame matched at least one MB free-to-receive regardless it has matched MBs non-free-to-receive.
5. Matched in FIFO "None" means that the frame has not matched any filter in FIFO. It is as the FIFO didn't exist (CTRL2[RFEN]=0).
6. Matched in FIFO "NotFull" means that the frame has matched a FIFO filter and has empty slots to receive it.
7. Matched in FIFO "Full" means that the frame has matched a FIFO filter but couldn't store it because it has no empty slots to receive it.
The ability to match the same ID in more than one MB can be exploited to implement a reception queue (in addition to the full featured FIFO) to allow more time for Arm to service the MBs. By programming more than one MB with the same ID, received messages will be queued into the MBs. Arm can examine the Time Stamp field of the MBs to determine the order in which the messages arrived.

Matching to a range of IDs is possible by using ID Acceptance Masks. FlexCAN supports individual masking per MB. Please refer to Rx Mailboxes Global Mask Register (FLEXCAN_RXMGMASK). During the matching algorithm, if a mask bit is asserted, then the corresponding ID bit is compared. If the mask bit is negated, the corresponding ID bit is "don't care". Please note that the Individual Mask Registers are implemented in RAM, so they are not initialized out of reset. Also, they can only be programmed while the module is in Freeze Mode, otherwise they are blocked by hardware.

FlexCAN also supports an alternate masking scheme with only four mask registers (RGXMASK, RX14MASK, RX15MASK and RXFGMASK) for backward compatibility. This alternate masking scheme is enabled when the IRMQ bit in the MCR Register is negated.

### 44.7.6 Move Process

There are two types of move process, namely move-in and move-out.

#### 44.7.6.1 Move-in

The move-in process is the copy of a message received by an Rx SMB to a Rx Mailbox or FIFO that has matched it. If the move destination is the Rx FIFO, attributes of the message are also copied to the RXFIR FIFO. Each Rx SMB has its own move-in process, but only one is performed at a given time as described ahead. The move-in starts only when the message held by the Rx SMB has a corresponding matching winner (see Matching Process) and all of the following conditions are true:

- the CAN bus has reached or let past either:
  - the second bit of Intermission field next to the frame that carried the message that is in the Rx SMB;
  - the first bit of an overload frame next to the frame that carried the message that is in the Rx SMB;
- there is no ongoing matching process;
• the destination Mailbox is not locked by Arm;
• there is no ongoing move-in process from another Rx SMB. If more than one move-in processes are to be started at the same time both are performed and the newest substitutes the oldest.

The term *pending move-in* is used throughout the document and stands for a move-to-be that still does not satisfy all of the aforementioned conditions.

The move-in is cancelled and the Rx SMB is able to receive another message if any of the following conditions is satisfied:

• the destination Mailbox is inactivated after the CAN bus has reached the first bit of Intermission field next to the frame that carried the message and its matching process has finished;
• there is a previous pending move-in to the same destination Mailbox.
• the Rx SMB is receiving a frame transmitted by the FlexCAN itself and the self-reception is disabled;
• any CAN protocol error is detected.

Note that the pending move-in is not cancelled if the module enters in Freeze or Low Power Mode. It only stays on hold waiting for exiting Low Power Mode and to be unlocked. If an MB is unlocked during Freeze Mode, the move-in happens immediately.

The move-in process consists of the following steps:

1. if the message is destined to the Rx FIFO, push IDHIT into the RXFIR FIFO;
2. reads the words DATA0-3 and DATA4-7 from the Rx SMB;
3. writes it in the words DATA0-3 and DATA4-7 of the Rx Mailbox;
4. reads the words Control/Status and ID from the Rx SMB;
5. writes it in the words Control/Status and ID of the Rx Mailbox, updating the CODE field according to Table 44-5.

The move-in process is not atomic, in such a way that it is immediately cancelled by the inactivation of the destination Mailbox (see Message Buffer Inactivation) and in this case the Mailbox may be left partially updated, thus incoherent. The exception is if the move-in destination is an Rx FIFO Message Buffer, then the process cannot be cancelled.

The BUSY Bit (least significant bit of the CODE field) of the destination Message Buffer is asserted while the move-in is being performed in such a way that Arm beware that the Message Buffer content is temporarily incoherent.
44.7.6.2 Move-out

The move-out process is the copy of the content from a Tx Mailbox to the Tx SMB when a message for transmission is available (see Arbitration process). The move-out occurs in the following conditions:

- the first bit of Intermission field;
- during Bus off field when TX Error Counter is in the 124 to 128 range;
- during BusIdle field;
- during Wait For Bus Idle field.

The move-out process is not atomic. Only Arm has priority to access the memory concurrently out of BusIdle state. In BusIdle, the move-out has the lowest priority to the concurrent memory accesses.

44.7.7 Data Coherence

In order to maintain data coherency and FlexCAN proper operation, the Arm must obey the rules described in the Transmit Process and Receive Process.

Any form of Arm accessing an MB structure within FlexCAN other than those specified may cause FlexCAN to behave in an unpredictable way.

44.7.7.1 Transmission Abort Mechanism

The abort mechanism provides a safe way to request the abortion of a pending transmission. A feedback mechanism is provided to inform Arm if the transmission was aborted or if the frame could not be aborted and was transmitted instead.

In order to abort a transmission, Arm must write a specific abort code (0b1001) to the CODE field of the Control and Status word. The active MBs configured as transmission must be aborted first and then they may be updated. If the abort code is written to a Mailbox that is currently being transmitted, or to a Mailbox that was already loaded into the SMB for transmission, the write operation is blocked and the MB is kept active, but the abort request is captured and kept pending until one of the following conditions are satisfied:

- The module loses the bus arbitration
- There is an error during the transmission
- The module is put into Freeze Mode
- The module enters in BusOff state
- There is an overload frame
If none of conditions above are reached, the MB is transmitted correctly, the interrupt flag is set in the IFLAG register and an interrupt to the Arm is generated (if enabled). The abort request is automatically cleared when the interrupt flag is set. In the other hand, if one of the above conditions is reached, the frame is not transmitted, therefore the abort code is written into the CODE field, the interrupt flag is set in the IFLAG and an interrupt is (optionally) generated to Arm.

If Arm writes the ABORT code before the transmission begins internally, then the write operation is not blocked, therefore the MB is updated and the interrupt flag is set. In this way Arm just needs to read the abort code to make sure the active MB was safely inactivated. Although the AEN bit is asserted and Arm wrote the abort code, in this case the MB is inactivated and not aborted, because the transmission did not start yet. One Mailbox is only aborted when the abort request is captured and kept pending until one of the previous conditions are satisfied.

The abort procedure can be summarized as follows:

1. Arm checks the corresponding IFLAG and clears it, if asserted.
2. Arm writes 0b1001 into the CODE field of the C/S word.
3. Arm waits for the corresponding IFLAG indicating that the frame was either transmitted or aborted.
4. Arm reads the CODE field to check if the frame was either transmitted (CODE=0b1000) or aborted (CODE=0b1001).
5. It is necessary to clear the corresponding IFLAG in order to allow the MB to be reconfigured.

44.7.7.2 Message Buffer Inactivation

Inactivation is a mechanism provided to protect the Mailbox against updates by the FlexCAN internal processes, thus allowing Arm to rely on Mailbox data coherence after having updated it, even in Normal Mode.

If a Mailbox is inactivated it does not participate neither in the arbitration nor in the matching process until it is reactivated. See Transmit Process and Receive Process for more detailed instruction on how to inactivate and reactivate a Mailbox.

In order to inactivate a Mailbox Arm must update its CODE field to INACTIVE (either 0b0000 or 0b1000).

As the user is not able to synchronize the CODE field update with the FlexCAN internal processes an inactivation can lead to undesirable results:
• a frame in the bus that matches the filtering of the inactivated Rx Mailbox may be lost without notice, even if there are other Mailboxes with the same filter;
• a frame containing the message within the inactivated Tx Mailbox may be transmitted without notice.

In order to eliminate such risk and perform a safe inactivation Arm must use the following mechanism along with the inactivation itself:

• for Tx Mailboxes, the Transmission Abort (see Transmission Abort Mechanism);

The inactivation automatically unlocks the Mailbox (see Message Buffer Lock Mechanism).

Message Buffers that are part of the Rx FIFO cannot be inactivated. There is no write protection on FIFO region by FlexCAN. Arm must keep the data coherence into FIFO region when RFEN is asserted.

### 44.7.7.3 Message Buffer Lock Mechanism

Besides MB inactivation, FlexCAN has another data coherence mechanism for the receive process. When Arm reads the Control and Status word of an Rx MB with codes FULL or OVERRUN, FlexCAN assumes that Arm wants to read the whole MB in an atomic operation, and thus it sets an internal lock flag for that MB. The lock is released when Arm reads the Free Running Timer (global unlock operation), or when it reads the Control and Status word of another MB regardless of its code or when Arm writes into C/S word from locked MB. The MB locking is done to prevent a new frame to be written into the MB while Arm is reading it.

The locking mechanism only applies to Rx MBs that are not part of FIFO and have a code different than INACTIVE (0b0000) or EMPTY\(^1\) (0b0100). Also, Tx MBs can not be locked.

Suppose, for example, that the FIFO is disabled and the second and the fifth MBs of the array are programmed with the same ID, and FlexCAN has already received and stored messages into these two MBs. Suppose now that the Arm decides to read MB number 5 and at the same time another message with the same ID is arriving. When Arm reads the Control and Status word of MB number 5, this MB is locked. The new message arrives and the matching algorithm finds out that there are no "free-to-receive" MBs, so it decides to override MB number 5. However, this MB is locked, so the new message can not be written there. It will remain in the SMB waiting for the MB to be unlocked, and only then will be written to the MB. If the MB is not unlocked in time and yet another

---

\(^1\) In previous FlexCAN versions, reading the C/S word locks the MB even if it is EMPTY. This behavior is maintained when the IRMQ bit is negated.
new message with the same ID arrives, then the new message overwrites the one on the SMB and there will be no indication of lost messages either in the CODE field of the MB or in the Error and Status Register.

While the message is being moved-in from the SMB to the MB, the BUSY bit on the CODE field is asserted. If Arm reads the Control and Status word and finds out that the BUSY bit is set, it should defer accessing the MB until the BUSY bit is negated.

If the BUSY bit is asserted or if the MB is empty, then reading the Control and Status word does not lock the MB.

Inactivation takes precedence over locking. If Arm inactivates a locked Rx Mailbox, then its lock status is negated and the Mailbox is marked as invalid for the current matching round. Any pending message on the SMB will not be transferred anymore to the Mailbox. An MB is unlocked when Arm reads the Free Running Timer Register (see Free Running Timer Register (FLEXCAN_TIMER)), or the C/S word of another MB.

Lock and unlock mechanisms have the same functionality in both Normal and Freeze modes.

An unlock during Normal or Freeze mode results in the move-in of the pending message. However, the move-in is postponed if an unlock occurs during any of the low power modes (see in Modes of Operation specific information on Module Disable or Stop modes) and it will take place only when the module resumes to Normal or Freeze modes.

### 44.7.8 Rx FIFO

The receive-only FIFO is enabled by asserting the RFEN bit in the MCR.

The reset value of this bit is zero to maintain software backward compatibility with previous versions of the module that did not have the FIFO feature. The FIFO is 6-message deep, therefore when the FIFO is enabled, the memory region occupied by the first 6 Message Buffers is reserved for use of the FIFO engine (see Rx FIFO Structure). Arm can read the received messages sequentially, in the order they were received, by repeatedly reading a Message Buffer structure at the output of the FIFO.

The IFLAG[BUF5I] (Frames available in Rx FIFO) is asserted when there is at least one frame available to be read from the FIFO. An interrupt is generated if it is enabled by the corresponding mask bit. Upon receiving the interrupt, Arm can read the message (accessing the output of the FIFO as a Message Buffer) and the RXFIR register and then clear the interrupt. If there are more messages in the FIFO the act of clearing the interrupt updates the output of the FIFO with the next message and update the RXFIR with the attributes of that message, reissuing the interrupt to Arm. Otherwise, the flag remains negated. The output of the FIFO is only valid when the IFLAG[BUF5I] is asserted.
The IFLAG[BUF6I] (Rx FIFO Warning) is asserted when the number of unread messages within the Rx FIFO is increased to 5 from 4 due to the reception of a new one, meaning that the Rx FIFO is almost full. The flag remains asserted until Arm clears it.

The IFLAG[BUF7I] (Rx FIFO Overflow) is asserted when an incoming message was lost because the Rx FIFO is full. Note that the flag will not be asserted when the Rx FIFO is full and the message was captured by a Mailbox. The flag remains asserted until the Arm clears it.

Clearing one of those three flags does not affect the state of the other two.

An interrupt is generated if an IFLAG bit is asserted and the corresponding mask bit is asserted too.

A powerful filtering scheme is provided to accept only frames intended for the target application, thus reducing the interrupt servicing work load. The filtering criteria is specified by programming a table of up to 128 32-bit registers, according to CTRL2[RFFN] setting, that can be configured to one of the following formats (see also Rx FIFO Structure):

- Format A: 128 IDAFs (extended or standard IDs including IDE and RTR)
- Format B: 256 IDAFs (standard IDs or extended 14-bit ID slices including IDE and RTR)
- Format C: 512 IDAFs (standard or extended 8-bit ID slices)

Every frame available in the FIFO has a corresponding IDHIT (Identifier Acceptance Filter Hit Indicator) that can be read by accessing the RXFIR register. The RXFIR[IDHIT] field refers to the message at the output of the FIFO and is valid whilst the IFLAG[BUF5I] flag is asserted. The RXFIR register must be read only before clearing the flag, which guarantees that the information refers to the correct frame within the FIFO.

Up to thirty two elements of the ID Filter Table are individually affected by the Individual Mask Registers (RXIMR0 - RXIMR31), according to CTRL2[RFFN] setting (refer to Control 2 Register (FLEXCAN_CTRL2)), allowing very powerful filtering criteria to be defined. If the MCR[IRMQ] bit is negated (or if the RXIMR are not available for the particular MCU), then the FIFO ID Filter Table is affected by RXFGMASK.

44.7.9 CAN Protocol Related Features
44.7.9.1 Remote Frames

Remote frame is a special kind of frame. The user can program a mailbox to be a Remote Request Frame by writing the mailbox as Transmit with the RTR bit set to '1'. After the remote request frame is transmitted successfully, the mailbox becomes a Receive Message Buffer, with the same ID as before.

When a remote request frame is received by FlexCAN, it can be treated in three ways, depending on Remote Request Storing (CTRL2[RRS]) and Rx FIFO Enable (MCR[RFEN]) bits:

- If RRS is negated the frame's ID is compared to the IDs of the Transmit Message Buffers with the CODE field 0b1010. If there is a matching ID, then this mailbox frame will be transmitted. Note that if the matching mailbox has the RTR bit set, then FlexCAN will transmit a remote frame as a response. The received remote request frame is not stored in a receive buffer. It is only used to trigger a transmission of a frame in response. The mask registers are not used in remote frame matching, and all ID bits (except RTR) of the incoming received frame should match. In the case that a remote request frame was received and matched a mailbox, this message buffer immediately enters the internal arbitration process, but is considered as normal Tx mailbox, with no higher priority. The data length of this frame is independent of the DLC field in the remote frame that initiated its transmission.

- If RRS is asserted the frame's ID is compared to the IDs of the receive mailboxes with the CODE field 0b0100, 0b0010 or 0b0110. If there is a matching ID, then this mailbox will store the remote frame in the same fashion of a data frame. No automatic remote response frame will be generated. The mask registers are used in the matching process.

- If RFEN is asserted FlexCAN will not generate an automatic response for remote request frames that match the FIFO filtering criteria. If the remote frame matches one of the target IDs, it will be stored in the FIFO and presented to the Arm. Note that for filtering formats A and B, it is possible to select whether remote frames are accepted or not. For format C, remote frames are always accepted (if they match the ID). Remote Request Frames are considered as normal frames, and generate a FIFO overflow when a successful reception occurs and the FIFO is already full.

44.7.9.2 Overload Frames

FLEXCAN does transmit overload frames due to detection of following conditions on CAN bus:

- Detection of a dominant bit in the first/second bit of Intermission
Detection of a dominant bit at the 7th bit (last) of End of Frame field (Rx frames)
Detection of a dominant bit at the 8th bit (last) of Error Frame Delimiter or Overload Frame Delimiter

44.7.9.3 Time Stamp

The value of the Free Running Timer is sampled at the beginning of the Identifier field on the CAN bus, and is stored at the end of "move-in" in the TIME STAMP field, providing network behavior with respect to time.

Note that the Free Running Timer can be reset upon a specific frame reception, enabling network time synchronization. Refer to TSYN description in Control 1 Register (FLEXCAN_CTRL1).

44.7.9.4 Protocol Timing

The FLEXCAN module supports a variety of means to setup bit timing parameters that are required by the CAN protocol. The Control Register has various fields used to control bit timing parameters: PRESDIV, PROPSEG, PSEG1, PSEG2 and RJW. See Control 1 Register (FLEXCAN_CTRL1).

The PRESDIV field controls a prescaler that generates the Serial Clock (Sclock), whose period defines the 'time quantum' used to compose the CAN waveform. A time quantum is the atomic unit of time handled by the CAN engine.

\[ f_{Tq} = \frac{f_{CANCLK}}{\text{(Prescaler value)}} \]

A bit time is subdivided into three segments\(^2\) (reference Table 44-17):

---

\(^2\) For further explanation of the underlying concepts please refer to ISO/DIS 11519-1, Section 10.3. Reference also the Bosch CAN 2.0A/B protocol specification dated September 1991 for bit timing.
• **SYNC_SEG**: This segment has a fixed length of one time quantum. Signal edges are expected to happen within this section.

• **Time Segment 1**: This segment includes the Propagation Segment and the Phase Segment 1 of the CAN standard. It can be programmed by setting the PROPSEG and the PSEG1 fields of the CTRL Register so that their sum (plus 2) is in the range of 2 to 16 time quanta.

• **Time Segment 2**: This segment represents the Phase Segment 2 of the CAN standard. It can be programmed by setting the PSEG2 field of the CTRL Register (plus 1) to be 2 to 8 time quanta long.

\[
\text{Bit Rate} = \frac{f_{Tq}}{(\text{number of Time Quanta})}
\]

![Diagram of segments within the bit time](image)

**Figure 44-2. Segments within the Bit Time**

Whenever CAN bit is used as a measure of duration (e.g. MCR[FRZ_ACK] and MCR[LPM_ACK] in Module Configuration Register (FLEXCAN_MCR)), the number of peripheral clocks in one CAN bit can be calculated as:

\[
NCCP = \frac{f_{sys} \times [1 + (PSEG1 + 1) + (PSEG2 + 1) + (PROPSEG + 1)] \times (PRESDIV + 1)}{f_{CANCLK}}
\]

where:
NCCP is the number of peripheral clocks in one CAN bit;

$f_{\text{CANCLK}}$ is the Protocol Engine (PE) Clock in Hz;

$f_{\text{SYS}}$ is the frequency of operation of the system (CHI) clock, in Hz;

PSEG1 is the value in CTRL1[PSEG1] field;

PSEG2 is the value in CTRL1[PSEG2] field;

PROPSEG is the value in CTRL1[PROPSEG] field;

PRESDIV is the value in CTRL1[PRESDIV] field.

For example, $180 \text{ CAN bits} = 180 \times \text{NCCP peripheral clock periods}$.

Figure 44-2 gives an overview of the CAN compliant segment settings and the related parameter values.

### Table 44-17. Time Segment Syntax

<table>
<thead>
<tr>
<th>Syntax</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SYNC_SEG</td>
<td>System expects transitions to occur on the bus during this period.</td>
</tr>
<tr>
<td>Transmit Point</td>
<td>A node in transmit mode transfers a new value to the CAN bus at this point.</td>
</tr>
<tr>
<td>Sample Point</td>
<td>A node samples the bus at this point. If the three samples per bit option is selected, then this point marks the position of the third sample.</td>
</tr>
</tbody>
</table>

### Table 44-18. CAN Standard Compliant Bit Time Segment Settings

<table>
<thead>
<tr>
<th>Time Segment 1</th>
<th>Time Segment 2</th>
<th>Re-synchronization Jump Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>5 .. 10</td>
<td>2</td>
<td>1 .. 2</td>
</tr>
<tr>
<td>4 .. 11</td>
<td>3</td>
<td>1 .. 3</td>
</tr>
<tr>
<td>5 .. 12</td>
<td>4</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>6 .. 13</td>
<td>5</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>7 .. 14</td>
<td>6</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>8 .. 15</td>
<td>7</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>9 .. 16</td>
<td>8</td>
<td>1 .. 4</td>
</tr>
</tbody>
</table>

### 44.7.9.5 Arbitration and Matching Timing

During normal reception and transmission of frames, the matching, arbitration, move-in and move-out processes are executed during certain time windows inside the CAN frame, as shown in the following figures.
When doing matching and arbitration, FlexCAN needs to scan the whole Message Buffer memory during the available time window. In order to have sufficient time to do that, the following requirements must be observed:

- A valid CAN bit timing must be programmed, as indicated in Table 44-18
- The peripheral clock frequency can not be smaller than the oscillator clock frequency, i.e. the PLL can not be programmed to divide down the oscillator clock
- There must be a minimum ratio between the peripheral clock frequency and the CAN bit rate, as specified in the following table.
Table 44-19. Minimum Ratio Between Peripheral Clock Frequency and CAN Bit Rate

<table>
<thead>
<tr>
<th>Number of Message Buffers</th>
<th>RFEN</th>
<th>Minimum Number of Peripheral Clocks per CAN bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>16 and 32</td>
<td>0</td>
<td>16</td>
</tr>
<tr>
<td>64</td>
<td>0</td>
<td>25</td>
</tr>
<tr>
<td>16</td>
<td>1</td>
<td>16</td>
</tr>
<tr>
<td>32</td>
<td>1</td>
<td>17</td>
</tr>
<tr>
<td>64</td>
<td>1</td>
<td>30</td>
</tr>
</tbody>
</table>

A direct consequence of the first requirement is that the minimum number of time quanta per CAN bit must be 8, so the oscillator clock frequency should be at least 8 times the CAN bit rate. The minimum frequency ratio specified in Table 44-19 can be achieved by choosing a high enough peripheral clock frequency when compared to the oscillator clock frequency, or by adjusting one or more of the bit timing parameters (PRESDIV, PROPSEG, PSEG1, PSEG2). As an example, taking the case of 64 MBs, if the oscillator and peripheral clock frequencies are equal and the CAN bit timing is programmed to have 8 time quanta per bit, then the prescaler factor (PRESDIV + 1) should be at least 2. For prescaler factor equal to one and CAN bit timing with 8 time quanta per bit, the ratio between peripheral and oscillator clock frequencies should be at least 2.

44.7.10 Modes of Operation Details

The FlexCAN module has four functional modes (Normal Mode, Freeze Mode, Listen-Only Mode and Loop-Back Mode) and two low power modes (Disable Mode and Stop Mode). See in Modes of Operation an introductory description of all these modes of operation. The following sub-sections bring functional details on Freeze mode and the low power modes.

44.7.10.1 Freeze Mode

This mode is requested by Arm through the assertion of the HALT bit in the MCR Register or when the MCU is put into Debug Mode. In both cases it is also necessary that the FRZ bit is asserted in the MCR Register and the module is not in any of the low power modes (Disable, Stop). The acknowledgement is obtained through the assertion by the FlexCAN of FRZ_ACK bit in the same register. The Arm must only consider the FlexCAN in Freeze Mode when both request and acknowledgement conditions are satisfied.

When Freeze Mode is requested during transmission or reception, FlexCAN does the following:
• Waits to be in either Intermission, Passive Error, Bus Off or Idle state
• Waits for all internal activities like arbitration, matching, move-in and move-out to finish. Pending move-in is not taken in account
• Ignores the FLEXCAN_RX input pin and drives the FLEXCAN_TX pin as recessive
• Stops the prescaler, thus halting all CAN protocol activities
• Grants write access to the Error Counters Register, which is read-only in other modes
• Sets the NOT_RDY and FRZ_ACK bits in MCR

After requesting Freeze Mode, the user must wait for the FRZ_ACK bit to be asserted in MCR before executing any other action, otherwise FlexCAN may operate in an unpredictable way. In Freeze mode, all memory mapped registers are accessible, except for CTRL1[CLK_SRC] bit that can be read but cannot be written.

Exiting Freeze Mode is done in one of the following ways:

• Arm negates the FRZ bit in the MCR Register
• The Arm is removed from Debug Mode and the HALT bit is negated

The FRZ_ACK bit is negated after protocol engine recognizes the negation of freeze request. Once out of Freeze Mode, FlexCAN tries to re-synchronize to the CAN bus by waiting for 11 consecutive recessive bits.

44.7.10.2 Module Disable Mode

This low power mode is normally used to temporarily disable a complete FlexCAN block, with no power consumption. It is requested by the Arm through the assertion of the MDIS bit in the MCR Register and the acknowledgement is obtained through the assertion by the FlexCAN of the LPM_ACK bit in the same register. The Arm must only consider the FlexCAN in Disable Mode when both request and acknowledgement conditions are satisfied.

If the module is disabled during Freeze Mode, it requests to disable the clocks to the PE and CHI sub-modules, sets the LPM_ACK bit and negates the FRZ_ACK bit. The ability to shut down the clocks depends on how FlexCAN is integrated into the MCU. If the module is disabled during transmission or reception, FlexCAN does the following:

• Waits to be in either Idle or Bus Off state, or else waits for the third bit of Intermission and then checks it to be recessive
• Waits for all internal activities like arbitration, matching, move-in and move-out to finish. Pending move-in is not taken in account
• Ignores its FLEXCAN_RX input pin and drives its FLEXCAN_TX pin as recessive
• May shut down the clocks to the PE and CHI sub-modules, depending on how FlexCAN is integrated into the MCU
• Sets the NOT_RDY and LPM_ACK bits in MCR

The Bus Interface Unit continues to operate, enabling the Arm to access memory mapped registers, except the Rx Mailboxes Global Mask Registers, the Rx Buffer 14 Mask Register, the Rx Buffer 15 Mask Register, the Rx FIFO Global Mask Register. The Rx FIFO Information Register, the Message Buffers, the Rx Individual Mask Registers, and the reserved words within RAM may not be accessed when the module is in Disable Mode depending on how FlexCAN RAM is integrated into the Arm. Exiting from this mode is done by negating the MDIS bit by Arm, which make FlexCAN requests to resume the clocks and negates the LPM_ACK bit after CAN protocol engine recognizes the negation of disable mode requested by Arm.

### 44.7.10.3 Stop Mode

This is a system low power mode in which system clocks can be stopped for maximum power savings. To enter stop mode, the CPU should manually assert a global Stop Mode request (see the CAN1_STOP_REQ and CAN2_STOP_REQ bit in the register IOMUXC_GPR4) and check the acknowledgement asserted by the FlexCAN (see the CAN1_STOP_ACK and CAN2_STOP_ACK in the register IOMUXC_GPR4). The CPU must only consider the FlexCAN in Stop Mode when both request and acknowledgement conditions are satisfied.

If FlexCAN receives the global Stop Mode request during Freeze Mode, it sets the LPM_ACK bit, negates the FRZ_ACK bit and then sends the Stop Acknowledge signal to the CPU, in order to shut down the clocks globally. If Stop Mode is requested during transmission or reception, FlexCAN does the following:

• Waits to be in either Idle or Bus Off state, or else waits for the third bit of Intermission and checks it to be recessive
• Waits for all internal activities like arbitration, matching, move-in and move-out to finish. Pending move-in is not taken in account
• Ignores its FLEXCAN_RX input pin and drives its FLEXCAN_TX pin as recessive
• Sets the NOT_RDY and LPM_ACK bits in MCR
• Sends a Stop Acknowledge signal to the CPU, so that it can shut down the clocks globally

Exiting Stop Mode is done in one of the following ways:

• Arm resuming the clocks and removing the Stop Mode request
• Arm resuming the clocks and Stop Mode request as a result of the Self Wake mechanism
In the Self Wake mechanism, if the SLF_WAK bit in MCR Register was set at the time FlexCAN entered Stop Mode, then upon detection of a recessive to dominant transition on the CAN bus, FlexCAN sets the WAK_INT bit in the ESR Register and, if enabled by the WAK_MSK bit in MCR, generates a Wake Up interrupt to the Arm. Upon receiving the interrupt, the Arm should resume the clocks and remove the Stop Mode request manually. FlexCAN will then wait for 11 consecutive recessive bits to synchronize to the CAN bus. As a consequence, it will not receive the frame that woke it up.

The sensitivity to CAN bus activity can be modified by applying a low-pass filter function to the FLEXCAN_RX input line while in Stop Mode. See the WAK_SRC bit in Module Configuration Register (FLEXCAN_MCR). This feature can be used to protect FlexCAN from waking up due to short glitches on the CAN bus lines. Such glitches can result from electromagnetic interference within noisy environments, the glitch filter width can be set in Glitch Filter Width Register (FLEXCAN_GFWR).

44.7.11 Interrupts

The module can generate up to 70 interrupt sources (64 interrupts due to message buffers and 6 interrupts due to Ored interrupts from MBs, Bus Off, Error, Tx Warning, Rx Warning and Wake Up)).

The number of actual sources depends on the configured number of message buffers.

Each one of the message buffers can be an interrupt source, if its corresponding IMASK bit is set. There is no distinction between Tx and Rx interrupts for a particular buffer, under the assumption that the buffer is initialized for either transmission or reception. Each of the buffers has assigned a flag bit in the IFLAG Registers. The bit is set when the corresponding buffer completes a successful transmission/reception and is cleared when the Arm writes it to '1' (unless another interrupt is generated at the same time).

If the Rx FIFO is enabled (bit RFEN on MCR set), the interrupts corresponding to MBs 0 to 7 have a different behavior. Bit 7 of the IFLAG1 becomes the "FIFO Overflow" flag; bit 6 becomes the FIFO Warning flag, bit 5 becomes the "Frames Available in FIFO flag" and bits 4-0 are unused. See Interrupt Flags 1 Register (FLEXCAN_IFLAG1) for more information.

A combined interrupt for all MBs is also generated by an Or of all the interrupt sources from MBs. This interrupt gets generated when any of the Mailboxes or FIFO generates an interrupt. The Arm must read the IFLAG Registers to determine which MB or FIFO caused the interrupt.
The other 5 interrupt sources (Bus Off, Error, Tx Warning, Rx Warning and Wake Up generate interrupts like the MB ones, and can be read from both the Error and Status Register 1 and 2. The Bus Off, Error, Tx Warning and Rx Warning interrupt mask bits are located in the Control 1 Register and the Wake-Up interrupt mask bit is located in the MCR.

44.8 Initialization/Application Information

This section provide instructions for initializing the FLEXCAN module.

44.8.1 FLEXCAN Initialization Sequence

The FLEXCAN module may be reset in two ways:

- SOC level hard reset which resets all memory mapped registers asynchronously
- SOFT_RST bit in MCR, which resets some of the memory mapped registers synchronously

Soft reset is synchronous and has to follow an internal request/acknowledge procedure across clock domains. Therefore, it may take some time to fully propagate its effects. The SOFT_RST bit remains asserted while soft reset is pending, so software can poll this bit to know when the reset has completed. Also, soft reset can not be applied while clocks are shut down in any of the low power modes. The low power mode should be exited and the clocks resumed before applying soft reset.

After the module is enabled (MDIS bit negated), FLEXCAN automatically goes to Freeze Mode. In Freeze Mode, FLEXCAN is un-synchronized to the CAN bus, the HALT and FRZ bits in MCR Register are set, the internal state machines are disabled and the FRZ_ACK and NOT_RDY bits in the MCR Register are set. The FLEXCAN_TX pin is in recessive state and FLEXCAN does not initiate any transmission or reception of CAN frames. Note that the Message Buffers and the Rx Individual Mask Registers are not affected by reset, so they are not automatically initialized.

For any configuration change/initialization it is required that FLEXCAN is put into Freeze Mode. The following is a generic initialization sequence applicable to the FLEXCAN module:

- Initialize the Module Configuration Register
  - Enable the individual filtering per MB and reception queue features by setting the IRMQ bit
  - Enable the warning interrupts by setting the WRN_EN bit
• If required, disable frame self reception by setting the SRX_DIS bit
• Enable the FIFO by setting the RFEN bit
• Enable the abort mechanism by setting the AEN bit
• Enable the local priority feature by setting the LPRIO_EN bit
• Initialize the Control Register
  • Determine the bit timing parameters: PROPSEG, PSEG1, PSEG2, RJW
  • Determine the bit rate by programming the PRESDIV field
  • Determine the internal arbitration mode (LBUF bit)
• Initialize the Message Buffers
  • The Control and Status word of all Message Buffers must be initialized
  • If FIFO was enabled, the 8-entry ID table must be initialized
  • Other entries in each Message Buffer should be initialized as required
• Initialize the Rx Individual Mask Registers
• Set required interrupt mask bits in the IMASK Registers (for all MB interrupts), in
  CTRL Register (for Bus Off and Error interrupts) and in MCR Register for Wake-Up
  interrupt
• Negate the HALT bit in MCR

Starting with the last event, FLEXCAN attempts to synchronize to the CAN bus.

### 44.9 FLEXCAN Memory Map/Register Definition

The complete memory map for a FLEXCAN module with 64 MBs capability is shown in
the following table. Each individual register is identified by its complete name and the
corresponding mnemonic. The access type can be Supervisor (S) or Unrestricted (U).
Most of the registers can be configured to have either Supervisor or Unrestricted access
by programming the SUPV bit in the MCR Register. The MCR register allows only
Supervisor access regardless the SUPV bit state.

The FLEXCAN module stores CAN messages for transmission and reception using a
Mailboxes and Rx FIFO structure.

#### FLEXCAN memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/ page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_0000</td>
<td>Module Configuration Register (FLEXCAN1_MCR)</td>
<td>32</td>
<td>R/W</td>
<td>5980_000Fh</td>
<td>44.9.1/2563</td>
</tr>
<tr>
<td>401D_0004</td>
<td>Control 1 Register (FLEXCAN1_CTRL1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.2/2568</td>
</tr>
<tr>
<td>401D_0008</td>
<td>Free Running Timer Register (FLEXCAN1_TIMER)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.3/2570</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_0010</td>
<td>Rx Mailboxes Global Mask Register (FLEXCAN1_RXMGMASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9/4/2571</td>
</tr>
<tr>
<td>401D_0014</td>
<td>Rx Buffer 14 Mask Register (FLEXCAN1_RX14MASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9/5/2572</td>
</tr>
<tr>
<td>401D_0018</td>
<td>Rx Buffer 15 Mask Register (FLEXCAN1_RX15MASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9/6/2573</td>
</tr>
<tr>
<td>401D_001C</td>
<td>Error Counter Register (FLEXCAN1_ECR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/7/2573</td>
</tr>
<tr>
<td>401D_0020</td>
<td>Error and Status 1 Register (FLEXCAN1_ESR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/8/2575</td>
</tr>
<tr>
<td>401D_0024</td>
<td>Interrupt Masks 2 Register (FLEXCAN1_IMASK2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/9/2578</td>
</tr>
<tr>
<td>401D_0028</td>
<td>Interrupt Masks 1 Register (FLEXCAN1_IMASK1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/10/2579</td>
</tr>
<tr>
<td>401D_002C</td>
<td>Interrupt Flags 2 Register (FLEXCAN1_IFLAG2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/11/2580</td>
</tr>
<tr>
<td>401D_0030</td>
<td>Interrupt Flags 1 Register (FLEXCAN1_IFLAG1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/12/2580</td>
</tr>
<tr>
<td>401D_0034</td>
<td>Control 2 Register (FLEXCAN1_CTRL2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/13/2582</td>
</tr>
<tr>
<td>401D_0038</td>
<td>Error and Status 2 Register (FLEXCAN1_ESR2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>44.9/14/2587</td>
</tr>
<tr>
<td>401D_0044</td>
<td>CRC Register (FLEXCAN1_CRCRC)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>44.9/15/2589</td>
</tr>
<tr>
<td>401D_0048</td>
<td>Rx FIFO Global Mask Register (FLEXCAN1_RXFGMASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9/16/2590</td>
</tr>
<tr>
<td>401D_004C</td>
<td>Rx FIFO Information Register (FLEXCAN1_RXFIR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>44.9/17/2591</td>
</tr>
<tr>
<td>401D_0880</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_0884</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_0888</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_088C</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_0890</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_0894</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_0898</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR6)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_089C</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR7)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_08A0</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR8)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
<tr>
<td>401D_08A4</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR9)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9/18/2592</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_08A8</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08AC</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08B0</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08B4</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08B8</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08BC</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08C0</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR16)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08C4</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR17)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08C8</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR18)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08CC</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR19)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08D0</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR20)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08D4</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR21)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08D8</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR22)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08DC</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR23)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08E0</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR24)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08E4</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR25)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08E8</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR26)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08EC</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR27)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08F0</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR28)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08F4</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR29)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08F8</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR30)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_08FC</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR31)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## FLEXCAN memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_0900</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR32)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0904</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR33)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0908</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR34)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_090C</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR35)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0910</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR36)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0914</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR37)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0918</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR38)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_091C</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR39)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0920</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR40)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0924</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR41)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0928</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR42)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_092C</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR43)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0930</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR44)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0934</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR45)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0938</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR46)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_093C</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR47)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0940</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR48)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0944</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR49)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0948</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR50)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_094C</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR51)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0950</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR52)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_0954</td>
<td>Rx Individual Mask Registers (FLEXCAN1_RXIMR53)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### FLEXCAN memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_09E0</td>
<td>Glitch Filter Width Registers (FLEXCAN1_GFWR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_007Fh</td>
<td>44.9.19/2592</td>
</tr>
<tr>
<td>401D_4000</td>
<td>Module Configuration Register (FLEXCAN2_MCR)</td>
<td>32</td>
<td>R/W</td>
<td>5980_000Fh</td>
<td>44.9.1/2563</td>
</tr>
<tr>
<td>401D_4004</td>
<td>Control 1 Register (FLEXCAN2_CTRL1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.2/2568</td>
</tr>
<tr>
<td>401D_4008</td>
<td>Free Running Timer Register (FLEXCAN2_TIMER)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.3/2570</td>
</tr>
<tr>
<td>401D_4010</td>
<td>Rx Mailboxes Global Mask Register (FLEXCAN2_RXMGMASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9.4/2571</td>
</tr>
<tr>
<td>401D_4014</td>
<td>Rx Buffer 14 Mask Register (FLEXCAN2_RX14MASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9.5/2572</td>
</tr>
<tr>
<td>401D_4018</td>
<td>Rx Buffer 15 Mask Register (FLEXCAN2_RX15MASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9.6/2573</td>
</tr>
<tr>
<td>401D_401C</td>
<td>Error Counter Register (FLEXCAN2_ECR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.7/2573</td>
</tr>
<tr>
<td>401D_4020</td>
<td>Error and Status 1 Register (FLEXCAN2_ESR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.8/2575</td>
</tr>
<tr>
<td>401D_4024</td>
<td>Interrupt Masks 2 Register (FLEXCAN2_IMASK2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.9/2578</td>
</tr>
<tr>
<td>401D_4028</td>
<td>Interrupt Masks 1 Register (FLEXCAN2_IMASK1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.10/2579</td>
</tr>
<tr>
<td>401D_402C</td>
<td>Interrupt Flags 2 Register (FLEXCAN2_IFLAG2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.11/2580</td>
</tr>
<tr>
<td>401D_4030</td>
<td>Interrupt Flags 1 Register (FLEXCAN2_IFLAG1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.12/2580</td>
</tr>
<tr>
<td>401D_4034</td>
<td>Control 2 Register (FLEXCAN2_CTRL2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.13/2582</td>
</tr>
<tr>
<td>401D_4038</td>
<td>Error and Status 2 Register (FLEXCAN2_ESR2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>44.9.14/2587</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### FLEXCAN memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_4044</td>
<td>CRC Register (FLEXCAN2_CRCR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>44.9.15/2589</td>
</tr>
<tr>
<td>401D_4048</td>
<td>Rx FIFO Global Mask Register (FLEXCAN2_RXFGMASK)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>44.9.16/2590</td>
</tr>
<tr>
<td>401D_404C</td>
<td>Rx FIFO Information Register (FLEXCAN2_RXFIR)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>44.9.17/2591</td>
</tr>
<tr>
<td>401D_4880</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4884</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4888</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_488C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4890</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4894</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4898</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR6)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_489C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR7)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48A0</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR8)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48A4</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR9)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48A8</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR10)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48AC</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR11)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48B0</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR12)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48B4</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR13)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48B8</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR14)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48BC</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR15)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48C0</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR16)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48C4</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR17)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48C8</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR18)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### FLEXCAN memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_48CC</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR19)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48D0</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR20)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48D4</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR21)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48D8</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR22)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48DC</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR23)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48E0</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR24)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48E4</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR25)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48E8</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR26)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48EC</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR27)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48F0</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR28)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48F4</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR29)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48F8</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR30)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_48FC</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR31)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4900</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR32)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4904</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR33)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4908</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR34)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_490C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR35)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4910</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR36)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4914</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR37)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4918</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR38)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_491C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR39)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4920</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR40)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## FLEXCAN memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_4924</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR41)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4928</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR42)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_492C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR43)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4930</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR44)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4934</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR45)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4938</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR46)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_493C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR47)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4940</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR48)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4944</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR49)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4948</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR50)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_494C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR51)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4950</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR52)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4954</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR53)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4958</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR54)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_495C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR55)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4960</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR56)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4964</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR57)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4968</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR58)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_496C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR59)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4970</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR60)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4974</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR61)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_4978</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR62)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### FLEXCAN memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_497C</td>
<td>Rx Individual Mask Registers (FLEXCAN2_RXIMR63)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>44.9.18/2592</td>
</tr>
<tr>
<td>401D_49E0</td>
<td>Glitch Filter Width Registers (FLEXCAN2_GFWR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_007Fh</td>
<td>44.9.19/2592</td>
</tr>
</tbody>
</table>

### 44.9.1 Module Configuration Register (FLEXCANx_MCR)

This register defines global system configurations, such as the module operation mode (e.g., low power) and maximum message buffer configuration.

Address: Base address + 0h offset

![Module Configuration Register Diagram]
### FLEXCANx_MCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 MDIS</td>
<td>This bit controls whether FLEXCAN is enabled or not. When disabled, FLEXCAN shuts down the clocks to the CAN Protocol Interface and Message Buffer Management sub-modules. This is the only bit in MCR not affected by soft reset. See Module Disable Mode for more information.</td>
</tr>
<tr>
<td>1</td>
<td>Disable the FLEXCAN module</td>
</tr>
<tr>
<td>0</td>
<td>Enable the FLEXCAN module</td>
</tr>
<tr>
<td>30 FRZ</td>
<td>The FRZ bit specifies the FLEXCAN behavior when the HALT bit in the MCR Register is set or when Debug Mode is requested at Arm level. When FRZ is asserted, FLEXCAN is enabled to enter Freeze Mode. Negation of this bit field causes FLEXCAN to exit from Freeze Mode.</td>
</tr>
<tr>
<td>1</td>
<td>Enabled to enter Freeze Mode</td>
</tr>
<tr>
<td>0</td>
<td>Not enabled to enter Freeze Mode</td>
</tr>
<tr>
<td>29 RFEN</td>
<td>This bit controls whether the Rx FIFO feature is enabled or not. When RFEN is set, MBs 0 to 5 cannot be used for normal reception and transmission because the corresponding memory region (0x80-0xDC) is used by the FIFO engine as well as additional MBs (up to 32, depending on CTRL2[RFFN] setting) which are used as Rx FIFO ID Filter Table elements. RFEN also impacts the definition of the minimum number of peripheral clocks per CAN bit as described in Table 44-19 (see Arbitration and Matching Timing). This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>1</td>
<td>FIFO enabled</td>
</tr>
<tr>
<td>0</td>
<td>FIFO not enabled</td>
</tr>
<tr>
<td>28 HALT</td>
<td>Assertion of this bit puts the FLEXCAN module into Freeze Mode. The Arm should clear it after initializing the Message Buffers and Control Register. No reception or transmission is performed by FLEXCAN before this bit is cleared. Freeze Mode can not be entered while FLEXCAN is in any of the low power modes. See Freeze Mode for more information</td>
</tr>
<tr>
<td>1</td>
<td>Enters Freeze Mode if the FRZ bit is asserted.</td>
</tr>
<tr>
<td>0</td>
<td>No Freeze Mode request.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### FLEXCANx_MCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 27 NOT_RDY | This read-only bit indicates that FLEXCAN is either in Disable Mode, Stop Mode or Freeze Mode. It is negated once FLEXCAN has exited these modes.  
1. FLEXCAN module is either in Disable Mode, Stop Mode or Freeze Mode  
0. FLEXCAN module is either in Normal Mode, Listen-Only Mode or Loop-Back Mode |
| 26 WAK_MSK | This bit enables the Wake Up Interrupt generation.  
1. Wake Up Interrupt is enabled  
0. Wake Up Interrupt is disabled |
| 25 SOFT_RST | When this bit is asserted, FlexCAN resets its internal state machines and some of the memory mapped registers. The following registers are reset: MCR (except the MDIS bit), TIMER, ECR, ESR1, ESR2, IMASK1, IMASK2, IFLAG1, IFLAG2 and CRCR. Configuration registers that control the interface to the CAN bus are not affected by soft reset. The following registers are unaffected:  
CTRL1, CTRL2, RXIMR0_RXIMR63, RXGMASK, RX14MASK, RX15MASK, RXFIMGASK, RXFIR and all Message Buffers  
The SOFT_RST bit can be asserted directly by the Arm when it writes to the MCR Register. It may take some time to fully propagate its effect. The SOFT_RST bit remains asserted while reset is pending, and is automatically negated when reset completes. Therefore, software can poll this bit to know when the soft reset has completed.  
Soft reset cannot be applied while clocks are shut down in any of the low power modes. The module should be first removed from low power mode, and then soft reset can be applied.  
1. Reset the registers  
0. No reset request |
| 24 FRZ_ACK | This read-only bit indicates that FLEXCAN is in Freeze Mode and its prescaler is stopped. The Freeze Mode request cannot be granted until current transmission or reception processes have finished. Therefore the software can poll the FRZ_ACK bit to know when FLEXCAN has actually entered Freeze Mode. If Freeze Mode request is negated, then this bit is negated once the FLEXCAN prescaler is running again. If Freeze Mode is requested while FLEXCAN is in any of the low power modes, then the FRZ_ACK bit will only be set when the low power mode is exited. See Freeze Mode for more information  
1. FLEXCAN in Freeze Mode, prescaler stopped  
0. FLEXCAN not in Freeze Mode, prescaler running |
| 23 SUPV | This bit configures some of the FLEXCAN registers to be either in Supervisor or User Mode. Reset value of this bit is ‘1’, so the affected registers start with Supervisor access allowance only. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.  
1. FlexCAN is in Supervisor Mode. Affected registers allow only Supervisor access. Unrestricted access behaves as though the access was done to an unimplemented register location  
0. FlexCAN is in User Mode. Affected registers allow both Supervisor and Unrestricted accesses |
| 22 SLF_WAK | This bit enables the Self Wake Up feature when FLEXCAN is in Stop Mode. If this bit had been asserted by the time FLEXCAN entered Stop Mode, then FLEXCAN will look for a recessive to dominant transition on the bus during these modes. If a transition from recessive to dominant is detected during Stop Mode, then FLEXCAN generates, if enabled to do so, a Wake Up interrupt to the Arm so that it can resume the clocks globally and FlexCAN can request to resume the clocks. This bit can not be written while the module is in Stop Mode.  
1. FLEXCAN Self Wake Up feature is enabled  
0. FLEXCAN Self Wake Up feature is disabled |
| 21 WRN_EN | When asserted, this bit enables the generation of the TWRN_INT and RWRN_INT flags in the Error and Status Register. If WRN_EN is negated, the TWRN_INT and RWRN_INT flags will always be zero,  
Table continues on the next page...
### FLEXCANx_MCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>independent of the values of the error counters, and no warning interrupt will ever be generated. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>20 LPM_ACK</td>
<td>This read-only bit indicates that FLEXCAN is either in Disable Mode or Stop Mode. Either of these low power modes cannot be entered until all current transmission or reception processes have finished, so the Arm can poll the LPM_ACK bit to know when FLEXCAN has actually entered low power mode. See Module Disable Mode, and Stop Mode for more information.</td>
</tr>
<tr>
<td>19 WAK_SRC</td>
<td>This bit defines whether the integrated low-pass filter is applied to protect the FLEXCAN_RX input from spurious wake up. See Stop Mode for more information. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>18 SRX_DIS</td>
<td>This bit defines whether FlexCAN is allowed to receive frames transmitted by itself. If this bit is asserted, frames transmitted by the module will not be stored in any MB, regardless if the MB is programmed with an ID that matches the transmitted frame, and no interrupt flag or interrupt signal will be generated due to the frame reception. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>16 IRMQ</td>
<td>This bit indicates whether Rx matching process will be based either on individual masking and queue or on masking scheme with RXMGMASK, RX14MASK and RX15MASK, RXFGMASK. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>15–14</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>13 LPRIO_EN</td>
<td>This bit is provided for backwards compatibility reasons. It controls whether the local priority feature is enabled or not. It is used to extend the ID used during the arbitration process. With this extended ID concept, the arbitration process is done based on the full 32-bit word, but the actual transmitted ID still has 11-bit for standard frames and 29-bit for extended frames. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>12 AEN</td>
<td>This bit is supplied for backwards compatibility reasons. When asserted, it enables the Tx abort feature. This feature guarantees a safe procedure for aborting a pending transmission, so that no frame is sent in the CAN bus without notification. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### FLEXCANx_MCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11-10</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>9-8</td>
<td>This 2-bit field identifies the format of the elements of the Rx FIFO filter table, as shown below. Note that all elements of the table are configured at the same time by this field (they are all the same format). See Rx FIFO Structure. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td></td>
<td>00 Format A One full ID (standard or extended) per ID filter Table element.</td>
</tr>
<tr>
<td></td>
<td>01 Format B Two full standard IDs or two partial 14-bit extended IDs per ID filter Table element.</td>
</tr>
<tr>
<td></td>
<td>10 Format C Four partial 8-bit IDs (standard or extended) per ID filter Table element.</td>
</tr>
<tr>
<td></td>
<td>11 Format D All frames rejected.</td>
</tr>
<tr>
<td>7</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>MAXMB</td>
<td>This 7-bit field defines the number of the last Message Buffers that will take part in the matching and arbitration processes. The reset value (0x0F) is equivalent to 16 MB configuration. This field can only be written in Freeze Mode as it is blocked by hardware in other modes. Number of the last MB = MAXMB. <strong>NOTE:</strong> Additionally, the value of MAXMB must encompass the FIFO size defined by CTRL2[RFFN] MAXMB also impacts the definition of the minimum number of peripheral clocks per CAN bit as described in Table 44-19 (see Arbitration and Matching Timing).</td>
</tr>
</tbody>
</table>
44.9.2 Control 1 Register (FLEXCANx_CTRL1)

This register is defined for specific FLEXCAN control features related to the CAN bus, such as bit-rate, programmable sampling point within an Rx bit, Loop Back Mode, Listen Only Mode, Bus Off recovery behavior and interrupt enabling (Bus-Off, Error, Warning). It also determines the Division Factor for the clock prescaler.

Address: Base address + 4h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

FLEXCANx_CTRL1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–24 PRESDIV | This 8-bit field defines the ratio between the PE clock frequency and the Serial Clock (Sclock) frequency. The Sclock period defines the time quantum of the CAN protocol. For the reset value, the Sclock frequency is equal to the PE clock frequency. The Maximum value of this register is 0xFF, that gives a minimum Sclock frequency equal to the PE clock frequency divided by 256. For more information refer to Protocol Timing. This field can only be written in Freeze mode as it is blocked by hardware in other modes.

    Sclock frequency = CPI clock frequency / (PRESDIV+1) |
| 23–22 RJW | This 2-bit field defines the maximum number of time quanta that a bit time can be changed by one resynchronization. The valid programmable values are 0-3. This field can only be written in Freeze mode as it is blocked by hardware in other modes

    Resync Jump Width = RJW + 1. |

Table continues on the next page...
### FLEXCANx_CTRL1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>21–19 PSEG1</td>
<td>This 3-bit field defines the length of Phase Buffer Segment 1 in the bit time. The valid programmable values are 0-7. This field can only be written in Freeze mode as it is blocked by hardware in other modes. Phase Buffer Segment 1 = (PSEG1 + 1) x Time-Quanta.</td>
</tr>
<tr>
<td>18–16 PSEG2</td>
<td>This 3-bit field defines the length of Phase Buffer Segment 2 in the bit time. The valid programmable values are 1-7. This field can only be written in Freeze mode as it is blocked by hardware in other modes. Phase Buffer Segment 2 = (PSEG2 + 1) x Time-Quanta.</td>
</tr>
<tr>
<td>15 BOFF_MSK</td>
<td>This bit provides a mask for the Bus Off Interrupt.</td>
</tr>
<tr>
<td>14 ERR_MSK</td>
<td>This bit provides a mask for the Error Interrupt.</td>
</tr>
<tr>
<td>13</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>12 LPB</td>
<td>This bit configures FlexCAN to operate in Loop-Back Mode. In this mode, FlexCAN performs an internal loop back that can be used for self test operation. The bit stream output of the transmitter is fed back internally to the receiver input. The FLEXCAN_RX input pin is ignored and the FLEXCAN_TX output goes to the recessive state (logic ‘1’). FlexCAN behaves as it normally does when transmitting, and treats its own transmitted message as a message received from a remote node. In this mode, FlexCAN ignores the bit sent during the ACK slot in the CAN frame acknowledge field, generating an internal acknowledge bit to ensure proper reception of its own message. Both transmit and receive interrupts are generated. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>11 TWRN_MSK</td>
<td>This bit provides a mask for the Tx Warning Interrupt associated with the TWRN_INT flag in the Error and Status Register. This bit is read as zero when MCR[WRN_EN] bit is negated. This bit can only be written if MCR[WRN_EN] bit is asserted.</td>
</tr>
<tr>
<td>10 RWRN_MSK</td>
<td>This bit provides a mask for the Rx Warning Interrupt associated with the RWRN_INT flag in the Error and Status Register. This bit is read as zero when MCR[WRN_EN] bit is negated. This bit can only be written if MCR[WRN_EN] bit is asserted.</td>
</tr>
<tr>
<td>9–8</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7 SMP</td>
<td>This bit defines the sampling mode of CAN bits at the FLEXCAN_RX. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>6 BOFF_REC</td>
<td>This bit defines how FLEXCAN recovers from Bus Off state. If this bit is negated, automatic recovering from Bus Off state occurs according to the CAN Specification 2.0B. If the bit is asserted, automatic recovering from Bus Off is disabled and the module remains in Bus Off state until the bit is negated by the...</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### FLEXCAN Field Descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>user. If the negation occurs before 128 sequences of 11 recessive bits are detected on the CAN bus, then Bus Off recovery happens as if the BOFF_REC bit had never been asserted. If the negation occurs after 128 sequences of 11 recessive bits occurred, then FLEXCAN will re-synchronize to the bus by waiting for 11 recessive bits before joining the bus. After negation, the BOFF_REC bit can be re-asserted again during Bus Off, but it will only be effective the next time the module enters Bus Off. If BOFF_REC was negated when the module entered Bus Off, asserting it during Bus Off will not be effective for the current Bus Off recovery.</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Automatic recovering from Bus Off state disabled</td>
</tr>
<tr>
<td>0</td>
<td>Automatic recovering from Bus Off state enabled, according to CAN Spec 2.0 part B</td>
</tr>
<tr>
<td>5</td>
<td>TSYN</td>
</tr>
<tr>
<td>This bit enables a mechanism that resets the free-running timer each time a message is received in Message Buffer 0. This feature provides means to synchronize multiple FLEXCAN stations with a special “SYNC” message (i.e., global network time). If the RFEN bit in MCR is set (FIFO enabled), the first available Mailbox, according to CTRL2[RFFN] setting, is used for timer synchronization instead of MB0. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Timer Sync feature enabled</td>
</tr>
<tr>
<td>0</td>
<td>Timer Sync feature disabled</td>
</tr>
<tr>
<td>4</td>
<td>LBUF</td>
</tr>
<tr>
<td>This bit defines the ordering mechanism for Message Buffer transmission. When asserted, the LPRIO_EN bit does not affect the priority arbitration. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Lowest number buffer is transmitted first</td>
</tr>
<tr>
<td>0</td>
<td>Buffer with highest priority is transmitted first</td>
</tr>
<tr>
<td>3</td>
<td>LOM</td>
</tr>
<tr>
<td>This bit configures FLEXCAN to operate in Listen Only Mode. In this mode, transmission is disabled, all error counters are frozen and the module operates in a CAN Error Passive mode. Only messages acknowledged by another CAN station will be received. If FLEXCAN detects a message that has not been acknowledged, it will flag a BIT0 error (without changing the REC), as if it was trying to acknowledge the message. Listen-Only Mode acknowledgement can be obtained by the state of ESR1[FLT_CONF] field which is Passive Error when Listen-Only Mode is entered. There can be some delay between the Listen-Only Mode request and acknowledge. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>FLEXCAN module operates in Listen Only Mode</td>
</tr>
<tr>
<td>0</td>
<td>Listen Only Mode is deactivated</td>
</tr>
<tr>
<td>PROPSEG</td>
<td>This 3-bit field defines the length of the Propagation Segment in the bit time. The valid programmable values are 0-7. This field can only be written in Freeze mode as it is blocked by hardware in other modes. Propagation Segment Time = (PROPSEG + 1) * Time-Quanta. Time-Quantum = one Sclock period.</td>
</tr>
</tbody>
</table>

1. One time quantum is equal to the Sclock period.

### 44.9.3 Free Running Timer Register (FLEXCANx_TIMER)

This register represents a 16-bit free running counter that can be read and written by the Arm. The timer starts from $0000$ after Reset, counts linearly to $FFFF$, and wraps around.
The timer is clocked by the FLEXCAN bit-clock (which defines the baud rate on the CAN bus). During a message transmission/reception, it increments by one for each bit that is received or transmitted. When there is no message on the bus, it counts using the previously programmed baud rate. During Freeze Mode, disable, and stop mode, the timer is not incremented.

The timer value is captured at the beginning of the identifier field of any frame on the CAN bus. This captured value is written into the Time Stamp entry in a message buffer after a successful reception or transmission of a message.

If bit CTRL1[TSYN] is asserted the Timer is reset whenever a message is received in the first available Mailbox, according to CTRL2[RFFN] setting.

Arm can write to this register anytime. However, if the write occurs at the same time that the Timer is being reset by a reception in the first Mailbox, then the write value is discarded.

Reading this register affects the Mailbox Unlocking procedure. For additional details, refer to Message Buffer Lock Mechanism.

---

**FLEXCANx_TIMER field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>TIMER</td>
<td>TIMER</td>
</tr>
</tbody>
</table>

---

**44.9.4 Rx Mailboxes Global Mask Register (FLEXCANx_RXMGMASK)**

RXMGMASK is provided for legacy support. Asserting the MCR[IRMQ] bit causes the RXMGMASK Register to have no effect on the module operation.

RXMGMASK is used to mask the filter fields of all Rx MBs, excluding MBs 14-15, which have individual mask registers.

This register can only be written in Freeze mode as it is blocked by hardware in other modes.
### Table 44-20. Rx Mailboxes Global Mask usage

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>-</td>
<td>0</td>
<td>-</td>
<td>Note⁸</td>
<td>Note³</td>
<td>MG[28:0]</td>
<td>MG[31:29]</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>MG[28:0]</td>
<td>MG[31:0]</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>MG[28:0]</td>
<td>MG[31:29]</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>MG[31]</td>
<td>MG[30]</td>
<td>MG[28:0]</td>
<td>MG[29]</td>
<td></td>
</tr>
</tbody>
</table>

1. RTR bit of the Incoming Frame. It is saved into an auxiliary MB called Rx Serial Message Buffer (Rx SMB).
2. If CTRL2[EACEN] bit is negated the RTR bit of Mailbox is never compared with the RTR bit of the Incoming Frame (Rx SMB[RTR]).
3. If CTRL2[EACEN] bit is negated the IDE bit of Mailbox is always compared with the IDE bit of the Incoming Frame (Rx SMB[IDE]).

Address: Base address + 10h offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

**FLEXCANx_RXMGMASK field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MG31_MG0</td>
<td>These bits mask the Mailbox filter bits as shown in the figure above. Note that the alignment with the ID word of the Mailbox is not perfect as the two most significant MG bits affect the fields RTR and IDE which are located in the Control and Status word of the Mailbox. Rx Mailboxes Global Mask Register (FLEXCAN_RXMGMASK) shows in detail which MG bits mask each Mailbox filter field.</td>
</tr>
</tbody>
</table>

1. The corresponding bit in the filter is checked against the one received
2. The corresponding bit in the filter is "don't care"

### 44.9.5 Rx Buffer 14 Mask Register (FLEXCANx_RX14MASK)

RX14MASK is provided for legacy support, asserting the MCR[IRMQ] bit causes the RX14MASK to have no effect on the module operation.

RX14MASK is used to mask the filter fields of Message Buffer 14.

This register can only be programmed while the module is in Freeze Mode as it is blocked by hardware in other modes.

Address: Base address + 14h offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| W   | RX14M31_RX14M0 |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
## 44.9.6 Rx Buffer 15 Mask Register (FLEXCANx_RX15MASK)

RX15MASK is provided for legacy support, asserting the MCR[IRMQ] bit causes the RX15MASK Register to have no effect on the module operation.

RX15MASK is used to mask the filter fields of Message Buffer 15.

This register can only be programmed while the module is in Freeze Mode as it is blocked by hardware in other modes.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>RX15M31</td>
</tr>
<tr>
<td>30</td>
<td>RX15M30</td>
</tr>
<tr>
<td>29</td>
<td>RX15M29</td>
</tr>
<tr>
<td>28</td>
<td>RX15M28</td>
</tr>
<tr>
<td>27</td>
<td>RX15M27</td>
</tr>
<tr>
<td>26</td>
<td>RX15M26</td>
</tr>
<tr>
<td>25</td>
<td>RX15M25</td>
</tr>
<tr>
<td>24</td>
<td>RX15M24</td>
</tr>
<tr>
<td>23</td>
<td>RX15M23</td>
</tr>
<tr>
<td>22</td>
<td>RX15M22</td>
</tr>
<tr>
<td>21</td>
<td>RX15M21</td>
</tr>
<tr>
<td>20</td>
<td>RX15M20</td>
</tr>
<tr>
<td>19</td>
<td>RX15M19</td>
</tr>
<tr>
<td>18</td>
<td>RX15M18</td>
</tr>
<tr>
<td>17</td>
<td>RX15M17</td>
</tr>
<tr>
<td>16</td>
<td>RX15M16</td>
</tr>
<tr>
<td>15</td>
<td>RX15M15</td>
</tr>
<tr>
<td>14</td>
<td>RX15M14</td>
</tr>
<tr>
<td>13</td>
<td>RX15M13</td>
</tr>
<tr>
<td>12</td>
<td>RX15M12</td>
</tr>
<tr>
<td>11</td>
<td>RX15M11</td>
</tr>
<tr>
<td>10</td>
<td>RX15M10</td>
</tr>
<tr>
<td>9</td>
<td>RX15M9</td>
</tr>
<tr>
<td>8</td>
<td>RX15M8</td>
</tr>
<tr>
<td>7</td>
<td>RX15M7</td>
</tr>
<tr>
<td>6</td>
<td>RX15M6</td>
</tr>
<tr>
<td>5</td>
<td>RX15M5</td>
</tr>
<tr>
<td>4</td>
<td>RX15M4</td>
</tr>
<tr>
<td>3</td>
<td>RX15M3</td>
</tr>
<tr>
<td>2</td>
<td>RX15M2</td>
</tr>
<tr>
<td>1</td>
<td>RX15M1</td>
</tr>
<tr>
<td>0</td>
<td>RX15M0</td>
</tr>
</tbody>
</table>

### FLEXCANx_RX15MASK field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>RX15M31</td>
<td>These bits mask Mailbox 15 filter bits in the same fashion as RXMGMASK masks other Mailboxes filters (see Rx Mailboxes Global Mask Register (FLEXCAN_RXMGMASK)).</td>
</tr>
<tr>
<td>RX15M0</td>
<td>1 The corresponding bit in the filter is checked</td>
</tr>
<tr>
<td></td>
<td>0 the corresponding bit in the filter is &quot;don't care&quot;</td>
</tr>
</tbody>
</table>

## 44.9.7 Error Counter Register (FLEXCANx_ECR)

This register has 2 8-bit fields reflecting the value of two FLEXCAN error counters: Transmit Error Counter (Tx_Err_Counter field) and Receive Error Counter (Rx_Err_Counter field). The rules for increasing and decreasing these counters are described in the CAN protocol and are completely implemented in the FLEXCAN module. Both counters are read only except in Freeze Mode, where they can be written by the Arm.
FLEXCAN responds to any bus state as described in the protocol, e.g. transmit 'Error Active' or 'Error Passive' flag, delay its transmission start time ('Error Passive') and avoid any influence on the bus when in 'Bus Off' state. The following are the basic rules for FLEXCAN bus state transitions.

- If the value of Tx_Err.Counter or Rx_Err.Counter increases to be greater than or equal to 128, the FLT_CONF field in the Error and Status Register is updated to reflect 'Error Passive' state.
- If the FLEXCAN state is 'Error Passive', and either Tx_Err.Counter or Rx_Err.Counter decrements to a value less than or equal to 127 while the other already satisfies this condition, the FLT_CONF field in the Error and Status Register is updated to reflect 'Error Active' state.
- If the value of Tx_Err.Counter increases to be greater than 255, the FLT_CONF field in the Error and Status Register is updated to reflect 'Bus Off' state, and an interrupt may be issued. The value of Tx_Err.Counter is then reset to zero.
- If FLEXCAN is in 'Bus Off' state, then Tx_Err.Counter is cascaded together with another internal counter to count the 128th occurrences of 11 consecutive recessive bits on the bus. Hence, Tx_Err.Counter is reset to zero and counts in a manner where the internal counter counts 11 such bits and then wraps around while incrementing the Tx_Err.Counter. When Tx_Err.Counter reaches the value of 128, the FLT_CONF field in the Error and Status Register is updated to be 'Error Active' and both error counters are reset to zero. At any instance of dominant bit following a stream of less than 11 consecutive recessive bits, the internal counter resets itself to zero without affecting the Tx_Err.Counter value.
- If during system start-up, only one node is operating, then its Tx_Err.Counter increases in each message it is trying to transmit, as a result of acknowledge errors (indicated by the ACK_ERR bit in the Error and Status Register). After the transition to 'Error Passive' state, the Tx_Err.Counter does not increment anymore by acknowledge errors. Therefore the device never goes to the 'Bus Off' state.
- If the Rx_Err.Counter increases to a value greater than 127, it is not incremented further, even if more errors are detected while being a receiver. At the next successful message reception, the counter is set to a value between 119 and 127 to resume to 'Error Active' state.
### FLEXCANx_ECR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 -</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>15–8 RX_ERR_COUNTER</td>
<td>Rx_Err_Counter</td>
</tr>
<tr>
<td>15–8 TX_ERR_COUNTER</td>
<td>Tx_Err_Counter</td>
</tr>
</tbody>
</table>

#### 44.9.8 Error and Status 1 Register (FLEXCANx_ESR1)

This register reflects various error conditions, some general status of the device and it is the source of four interrupts to the Arm.

The Arm read action clears bits 15-10, therefore the reported *error conditions* (bits 15-10) are those that occurred since the last time the Arm read this register. Bits 9-3 are status bits.

Some bits in this register are read-only and some are not.

<table>
<thead>
<tr>
<th>SYCH</th>
<th>IDLE</th>
<th>TX</th>
<th>RX</th>
<th>FlexCAN state</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Not synchronized to CAN bus</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>x</td>
<td>x</td>
<td>Idle</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Transmitting</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Receiving</td>
</tr>
<tr>
<td>other combinations</td>
<td></td>
<td></td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

**Table 44-21. FlexCAN State**

Address: Base address + 20h offset

![Address Diagram](image)
### FLEXCANx_ESR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–19   | This field is reserved.  
 Reserved |
| 18      | SYNCH       |
|         | This read-only flag indicates whether the FlexCAN is synchronized to the CAN bus and able to participate  
 in the communication process. It is set and cleared by the FlexCAN. Refer to Table 44-21  
 1 FlexCAN is synchronized to the CAN bus  
 0 FlexCAN is not synchronized to the CAN bus |
| 17      | TWRN_INT    |
|         | If the WRN_EN bit in MCR is asserted, the TWRN_INT bit is set when the TX_WRN flag transition from '0'  
 to ‘1’, meaning that the Tx error counter reached 96. If the corresponding mask bit in the Control Register  
 (TWRN_MSK) is set, an interrupt is generated to the Arm. This bit is cleared by writing it to ‘1’. When  
 WRN_EN is negated, this flag is masked. Arm must clear this flag before disabling the bit. Otherwise it will  
 be set when the WRN_EN is set again. Writing '0' has no effect. This flag is not generated during "Bus Off"  
 state. This bit is not updated during Freeze mode.  
 1 The Tx error counter transition from < 96 to >= 96  
 0 No such occurrence |
| 16      | RWRN_INT    |
|         | If the WRN_EN bit in MCR is asserted, the RWRN_INT bit is set when the RX_WRN flag transition from '0'  
 to ‘1’, meaning that the Rx error counters reached 96. If the corresponding mask bit in the Control Register  
 (RWRN_MSK) is set, an interrupt is generated to the Arm. This bit is cleared by writing it to ‘1’. When  
 WRN_EN is negated, this flag is masked. Arm must clear this flag before disabling the bit. Otherwise it will  
 be set when the WRN_EN is set again. Writing '0' has no effect. This bit is not updated during Freeze  
 mode.  
 1 The Rx error counter transition from < 96 to >= 96  
 0 No such occurrence |
| 15      | BIT1_ERR    |
|         | This bit indicates when an inconsistency occurs between the transmitted and the received bit in a  
 message.  
 This bit is not set by a transmitter in case of arbitration field or ACK slot, or in case of a node sending a  
 passive error flag that detects dominant bits.  
 1 At least one bit sent as recessive is received as dominant  
 0 No such occurrence |
### FLEXCANx_ESR1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14 BIT0_ERR</td>
<td>This bit indicates when an inconsistency occurs between the transmitted and the received bit in a message.</td>
</tr>
<tr>
<td>1</td>
<td>At least one bit sent as dominant is received as recessive</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>13 ACK_ERR</td>
<td>This bit indicates that an Acknowledge Error has been detected by the transmitter node, i.e., a dominant bit has not been detected during the ACK SLOT.</td>
</tr>
<tr>
<td>1</td>
<td>An ACK error occurred since last read of this register</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>12 CRC_ERR</td>
<td>This bit indicates that a CRC Error has been detected by the receiver node, i.e., the calculated CRC is different from the received.</td>
</tr>
<tr>
<td>1</td>
<td>A CRC error occurred since last read of this register</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>11 FRM_ERR</td>
<td>This bit indicates that a Form Error has been detected by the receiver node, i.e., a fixed-form bit field contains at least one illegal bit.</td>
</tr>
<tr>
<td>1</td>
<td>A Form Error occurred since last read of this register</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>10 STF_ERR</td>
<td>This bit indicates that a Stuffing Error has been detected.</td>
</tr>
<tr>
<td>1</td>
<td>A Stuffing Error occurred since last read of this register</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>9 TX_WRN</td>
<td>This bit indicates when repetitive errors are occurring during message transmission.</td>
</tr>
<tr>
<td>1</td>
<td>TX_Err.Counter ≥ 96</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>8 RX_WRN</td>
<td>This bit indicates when repetitive errors are occurring during message reception.</td>
</tr>
<tr>
<td>1</td>
<td>Rx_Err.Counter ≥ 96</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>7 IDLE</td>
<td>This bit indicates when CAN bus is in IDLE state. Refer to Table 44-21.</td>
</tr>
<tr>
<td>1</td>
<td>CAN bus is now IDLE</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>6 TX</td>
<td>This bit indicates if FLEXCAN is transmitting a message. Refer to Table 44-21.</td>
</tr>
<tr>
<td>1</td>
<td>FLEXCAN is transmitting a message</td>
</tr>
<tr>
<td>0</td>
<td>FLEXCAN is receiving a message</td>
</tr>
<tr>
<td>5–4 FLT_CONF</td>
<td>If the LOM bit in the Control Register is asserted, after some delay that depends on the CAN bit timing the FLT_CONF field will indicate &quot;Error Passive&quot;. The very same delay affects the way how FLT_CONF reflects an update to ECR register by the Arm. It may be necessary up to one CAN bit time to get them coherent again. Since the Control Register is not affected by soft reset, the FLT_CONF field will not be affected by soft reset if the LOM bit is asserted. This 2-bit field indicates the Confinement State of the FLEXCAN module, as shown in below:</td>
</tr>
<tr>
<td>00</td>
<td>Error Active</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field Descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>01</td>
<td>Error Passive</td>
</tr>
<tr>
<td>1x</td>
<td>Bus off</td>
</tr>
<tr>
<td>3 RX</td>
<td>This bit indicates if FlexCAN is receiving a message. Refer to Table 44-21.</td>
</tr>
<tr>
<td>1</td>
<td>FlexCAN is transmitting a message</td>
</tr>
<tr>
<td>0</td>
<td>FlexCAN is receiving a message</td>
</tr>
<tr>
<td>2 BOFF_INT</td>
<td>This bit is set when FlexCAN enters 'Bus Off' state. If the corresponding mask bit in the Control Register (BOFF_MSK) is set, an interrupt is generated to the Arm. This bit is cleared by writing it to '1'. Writing '0' has no effect.</td>
</tr>
<tr>
<td>1</td>
<td>FlexCAN module entered 'Bus Off' state</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>1 ERR_INT</td>
<td>This bit indicates that at least one of the Error Bits (bits 15-10) is set. If the corresponding mask bit in the Control Register (ERR_MSK) is set, an interrupt is generated to the Arm. This bit is cleared by writing it to '1'. Writing '0' has no effect.</td>
</tr>
<tr>
<td>1</td>
<td>Indicates setting of any Error Bit in the Error and Status Register</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
<tr>
<td>0 WAK_INT</td>
<td>When FlexCAN is Stop Mode and a recessive to dominant transition is detected on the CAN bus and if the WAK_MSK bit in the MCR Register is set, an interrupt is generated to the Arm. This bit is cleared by writing it to '1'. When SLF_WAK is negated, this flag is masked. Arm must clear this flag before disabling the bit. Otherwise it will be set when the SLF_WAK is set again. Writing '0' has no effect</td>
</tr>
<tr>
<td>1</td>
<td>Indicates a recessive to dominant transition received on the CAN bus when the FlexCAN module is in Stop Mode</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
</tbody>
</table>

### 44.9.9 Interrupt Masks 2 Register (FLEXCANx_IMASK2)

This register allows any number of a range of 32 Message Buffer Interrupts to be enabled or disabled. It contains one interrupt mask bit per buffer, enabling the Arm to determine which buffer generates an interrupt after a successful transmission or reception (i.e. when the corresponding IFLAG2 bit is set).

Address: Base address + 24h offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### FLEXCANx_IMASK2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUF63M_BUF32M</td>
<td>Each bit enables or disables the respective FLEXCAN Message Buffer (MB32 to MB63) Interrupt.</td>
</tr>
</tbody>
</table>
FLEXCANx_IMASK2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Setting or clearing a bit in the IMASK2 Register can assert or negate an interrupt request, if the corresponding IFLAG2 bit is set.</td>
</tr>
<tr>
<td></td>
<td>1  The corresponding buffer Interrupt is enabled</td>
</tr>
<tr>
<td></td>
<td>0  The corresponding buffer Interrupt is disabled</td>
</tr>
</tbody>
</table>

44.9.10  Interrupt Masks 1 Register (FLEXCANx_IMASK1)

This register allows to enable or disable any number of a range of 32 Message Buffer Interrupts. It contains one interrupt mask bit per buffer, enabling the Arm to determine which buffer generates an interrupt after a successful transmission or reception (i.e., when the corresponding IFLAG1 bit is set).

Address: Base address + 28h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>29</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28</td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

FLEXCANx_IMASK1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUF31M_BUF0M</td>
<td>Each bit enables or disables the respective FLEXCAN Message Buffer (MB0 to MB31) Interrupt.</td>
</tr>
<tr>
<td></td>
<td>Setting or clearing a bit in the IMASK1 Register can assert or negate an interrupt request, if the corresponding IFLAG1 bit is set</td>
</tr>
<tr>
<td></td>
<td>1  The corresponding buffer Interrupt is enabled</td>
</tr>
<tr>
<td></td>
<td>0  The corresponding buffer Interrupt is disabled</td>
</tr>
</tbody>
</table>
44.9.11 Interrupt Flags 2 Register (FLEXCANx_IFLAG2)

This register defines the flags for 32 Message Buffer interrupts. It contains one interrupt flag bit per buffer. Each successful transmission or reception sets the corresponding IFLAG2 bit. If the corresponding IMASK2 bit is set, an interrupt will be generated. The interrupt flag must be cleared by writing it to '1'. Writing '0' has no effect. Before updating MCR[MAXMB] field, Arm must treat the IFLAG2 bits which MB value is greater than the MCR[MAXMB] to be updated, otherwise they will keep set and be inconsistent with the amount of MBs available.

Address: Base address + 2Ch offset

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
<th>BUF63I_BUF32I</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUF63I_BUF32I</td>
<td>Each bit flags the respective FLEXCAN Message Buffer (MB32 to MB63) interrupt.</td>
</tr>
<tr>
<td>1</td>
<td>The corresponding buffer has successfully completed transmission or reception</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
</tbody>
</table>

44.9.12 Interrupt Flags 1 Register (FLEXCANx_IFLAG1)

This register defines the flags for 32 Message Buffer interrupts and FIFO interrupts. It contains one interrupt flag bit per buffer. Each successful transmission or reception sets the corresponding IFLAG1 bit. If the corresponding IMASK1 bit is set, an interrupt will be generated. The Interrupt flag must be cleared by writing it to '1'. Writing '0' has no effect.

When the RFEN bit in the MCR is set (Rx FIFO enabled), the function of the 8 least significant interrupt flags (BUF7I - BUF0I) is changed to support the FIFO operation. BUF7I, BUF6I and BUF5I indicate operating conditions of the FIFO, while BUF4I to BUF0I are not used. Before enabling the RFEN, Arm must service the IFLAGS asserted in the Rx FIFO region (see Rx FIFO). Otherwise, these IFLAGS will mistakenly show the related MBs now belonging to FIFO as having contents to be serviced. When the RFEN is negated, the FIFO flags must be cleared. The same care must be taken when a
RFFN value is selected extending Rx FIFO filters beyond MB7 (see Control 2 Register (FLEXCAN_CTRL2)). For example, when RFFN is 0x8, the MB0-23 range is occupied by Rx FIFO filters and related IFLAGS must be cleared.

Before updating MCR[MAXMB] field, Arm must service the IFLAG1 which MB value is greater than the MCR[MAXMB] to be updated, otherwise they will keep set and be inconsistent with the amount of MBs available.

Address: Base address + 30h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BUF31I_BUF8I</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BUF31I_BUF8I</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BUF7I</td>
<td></td>
<td>BUF6I</td>
<td></td>
<td>BUF5I</td>
<td></td>
<td>BUF4I_BUF0I</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BUF31I_BUF8I</td>
<td></td>
<td>BUF31I_BUF8I</td>
<td></td>
<td>BUF31I_BUF8I</td>
<td></td>
<td>BUF31I_BUF8I</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**FLEXCANx_IFLAG1 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–8 BUF31I_BUF8I | Each bit flags the respective FLEXCAN Message Buffer (MB8 to MB31) interrupt.  
1 The corresponding MB has successfully completed transmission or reception  
0 No such occurrence |
| 7 BUF7I      | If the Rx FIFO is not enabled, this bit flags the interrupt for MB7.  
If the MCR[RFEN] bit is asserted, this flag indicates that a message was lost because Rx FIFO is full. Note that the flag will not be asserted when the Rx FIFO is full and the message was captured by a Mailbox.  
This flag is cleared by the FlexCAN whenever the bit MCR[RFEN] is changed by Arm writes.  
1 MB7 completed transmission/reception or FIFO overflow  
0 No such occurrence |
| 6 BUF6I      | If the Rx FIFO is not enabled, this bit flags the interrupt for MB6.  
If the MCR[RFEN] bit is asserted, this flag indicates when the number of unread messages within the Rx FIFO is increased to 5 from 4 due to the reception of a new one, meaning that the Rx FIFO is almost full. Note that if the flag is cleared while the number of unread messages is greater than 4 it will not assert again until the number of unread messages within the Rx FIFO is decreased to equal or less than 4.  
This flag is cleared by the FlexCAN whenever the bit MCR[RFEN] is changed by Arm writes.  
1 MB6 completed transmission/reception or FIFO almost full  
0 No such occurrence |
| 5 BUF5I      | If the Rx FIFO is not enabled, this bit flags the interrupt for MB5. If the Rx FIFO is enabled, this flag indicates that at least one frame is available to be read from the Rx FIFO.  
This flag is cleared by the FlexCAN whenever the bit MCR[RFEN] is changed by Arm writes.  
1 MB5 completed transmission/reception or FIFO almost full  
0 No such occurrence |

Table continues on the next page...
### FLEXCANx_IFLAG1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>MB5 completed transmission/reception or frames available in the FIFO</td>
</tr>
<tr>
<td>0</td>
<td>No such occurrence</td>
</tr>
</tbody>
</table>

**BUF4I_BUF0I**
- If the Rx FIFO is not enabled, these bits flag the interrupts for MB0 to MB4. If the Rx FIFO is enabled, these flags are not used and must be considered as reserved locations.
- These flags are cleared by the FlexCAN whenever the bit MCR[RFEN] is changed by Arm writes.
- 1 Corresponding MB completed transmission/reception
- 0 No such occurrence

### 44.9.13 Control 2 Register (FLEXCANx_CTRL2)

This register contains control bits for CAN errors, FIFO features and mode selection.

#### Table 44-22. Rx FIFO Filters

<table>
<thead>
<tr>
<th>RFFN[3:0]</th>
<th>Number of Rx FIFO filters</th>
<th>Message Buffers occupied by Rx FIFO and ID Filter Table</th>
<th>Remaining Available Mailboxes(^1)</th>
<th>Rx FIFO ID Filter Table Elements Affected by Rx Individual Masks(^2)</th>
<th>Rx FIFO ID Filter Table Elements Affected by Rx FIFO Global Mask(^2)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0</td>
<td>8</td>
<td>MB 0-7</td>
<td>MB 8-63</td>
<td>Elements 0-7</td>
<td>none</td>
</tr>
<tr>
<td>0x1</td>
<td>16</td>
<td>MB 0-9</td>
<td>MB 10-63</td>
<td>Elements 0-9</td>
<td>Elements 10-15</td>
</tr>
<tr>
<td>0x2</td>
<td>24</td>
<td>MB 0-11</td>
<td>MB 12-63</td>
<td>Elements 0-11</td>
<td>Elements 12-23</td>
</tr>
<tr>
<td>0x3</td>
<td>32</td>
<td>MB 0-13</td>
<td>MB 14-63</td>
<td>Elements 0-13</td>
<td>Elements 14-31</td>
</tr>
<tr>
<td>0x4</td>
<td>40</td>
<td>MB 0-15</td>
<td>MB 16-63</td>
<td>Elements 0-15</td>
<td>Elements 16-39</td>
</tr>
<tr>
<td>0x5</td>
<td>48</td>
<td>MB 0-17</td>
<td>MB 18-63</td>
<td>Elements 0-17</td>
<td>Elements 18-47</td>
</tr>
<tr>
<td>0x6</td>
<td>56</td>
<td>MB 0-19</td>
<td>MB 20-63</td>
<td>Elements 0-19</td>
<td>Elements 20-55</td>
</tr>
<tr>
<td>0x7</td>
<td>64</td>
<td>MB 0-21</td>
<td>MB 22-63</td>
<td>Elements 0-21</td>
<td>Elements 22-63</td>
</tr>
<tr>
<td>0x8</td>
<td>72</td>
<td>MB 0-23</td>
<td>MB 24-63</td>
<td>Elements 0-23</td>
<td>Elements 24-71</td>
</tr>
<tr>
<td>0x9</td>
<td>80</td>
<td>MB 0-25</td>
<td>MB 26-63</td>
<td>Elements 0-25</td>
<td>Elements 26-79</td>
</tr>
<tr>
<td>0xA</td>
<td>88</td>
<td>MB 0-27</td>
<td>MB 28-63</td>
<td>Elements 0-27</td>
<td>Elements 28-87</td>
</tr>
<tr>
<td>0xB</td>
<td>96</td>
<td>MB 0-29</td>
<td>MB 30-63</td>
<td>Elements 0-29</td>
<td>Elements 30-95</td>
</tr>
<tr>
<td>0xC</td>
<td>104</td>
<td>MB 0-31</td>
<td>MB 32-63</td>
<td>Elements 0-31</td>
<td>Elements 32-103</td>
</tr>
<tr>
<td>0xD</td>
<td>112</td>
<td>MB 0-33</td>
<td>MB 34-63</td>
<td>Elements 0-31</td>
<td>Elements 32-111</td>
</tr>
<tr>
<td>0xE</td>
<td>120</td>
<td>MB 0-35</td>
<td>MB 36-63</td>
<td>Elements 0-31</td>
<td>Elements 32-119</td>
</tr>
<tr>
<td>0xF</td>
<td>128</td>
<td>MB 0-37</td>
<td>MB 38-63</td>
<td>Elements 0-31</td>
<td>Elements 32-127</td>
</tr>
</tbody>
</table>

1. The number of the last remaining available mailboxes is defined by the MCR[MAXMB] field.
2. If Rx Individual Mask Registers are not enabled then all Rx FIFO filters are affected by the Rx FIFO Global Mask.

Each group of eight filters occupies a memory space equivalent to two Message Buffers which means that the more filters are implemented the less Mailboxes will be available.
Considering that the Rx FIFO occupies the memory space originally reserved for MB0-5, RFFN should be programmed with a value corresponding to a number of filters not greater than the number of available memory words which can be calculated as follows:

\[(\text{SETUP}_\text{MB} - 6) \times 4\]

where SETUP_MB is MAXMB.

The number of remaining Mailboxes available will be:

\[\text{SETUP}_\text{MB} - 8 - (\text{RFFN} \times 2)\]

If the Number of Rx FIFO Filters programmed through RFFN exceeds the SETUP_MB value, the exceeding ones will not be functional. Unshaded regions in Table 44-23 indicate the valid combinations of MAXMB, RFEN and RFFN, shaded regions are not functional.

**Table 44-23. Valid Combinations of MAXMB, RFEN and RFFN**

<table>
<thead>
<tr>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
<th>RFFN</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
</tr>
<tr>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
<td>6</td>
</tr>
<tr>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
<td>7</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
<td>9</td>
</tr>
<tr>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
</tr>
<tr>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
<td>12</td>
</tr>
<tr>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
<td>13</td>
</tr>
<tr>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
<td>14</td>
</tr>
<tr>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
</tr>
<tr>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
<td>16</td>
</tr>
<tr>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
<td>17</td>
</tr>
<tr>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
<td>18</td>
</tr>
<tr>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
<td>19</td>
</tr>
<tr>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
</tr>
<tr>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
<td>21</td>
</tr>
<tr>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
<td>22</td>
</tr>
<tr>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
<td>23</td>
</tr>
<tr>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
<td>24</td>
</tr>
<tr>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
<td>26</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 44-23. Valid Combinations of MAXMB, RFEN and RFFN (continued)

<table>
<thead>
<tr>
<th>RFF N</th>
<th>0</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>RFEN</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>MAX MB</th>
<th>27 - 28</th>
<th>29 - 30</th>
<th>31 - 32</th>
<th>33 - 34</th>
<th>35 - 36</th>
<th>37 - 63</th>
</tr>
</thead>
</table>

Address: Base address + 34h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

FLEXCANx_CTRL2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>must be written as 0</td>
</tr>
<tr>
<td>30–29</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
| 28 WRMFRZ | Enable unrestricted write access to FlexCAN memory in Freeze mode. This bit can only be written in Freeze mode and has no effect out of Freeze mode.  

1 Enable unrestricted write access to FlexCAN memory  
0 Keep the write access restricted in some regions of FlexCAN memory |

Table continues on the next page...
### FLEXCANx_CTRL2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>27–24 RFFN</td>
<td>This 4-bit field defines the number of Rx FIFO filters according to Table 44-22. The maximum selectable number of filters is determined by the Arm. This field can only be written in Freeze mode as it is blocked by hardware in other modes. RFFN defines a number of Message Buffers occupied by Rx FIFO and ID Filter (see Table 44-22) that may not exceed the number of available Mailboxes present in module, defined by MCR[MAXMB]. Default RFFN value is 0x0, which leads to a total of 8 Rx FIFO filters, occupies the first 8 Message Buffers (MB 0-7) and makes available the next Message Buffers (MB 8-63) for Mailboxes. As a second example, when RFFN is set to 0xD, there will be 112 Rx FIFO filters, located in MB 0-33, and MB 34-63 are available for Mailboxes. Notice that, in this case, individual masks (RXIMR) will just cover Rx FIFO filters in 0-31 range, and filters 32-111 will use RXFGMASK. In case of reducing the number of last Message Buffers, MCR[MAXMB] (see Module Configuration Register (FLEXCAN_MCR)) can be adjusted by the application to minimum of 33, in order to give room to the Rx FIFO and its ID Filter Table defined by RFFN. On the contrary, if the application sets MCR[MAXMB] to 16, for instance, the maximum RFFN is limited to 0x4. RFFN also impacts the definition of the minimum number of peripheral clocks per CAN bit as described in Table 44-19 (see Arbitration and Matching Timing).</td>
</tr>
<tr>
<td>23–19 TASD</td>
<td>This 5-bit field indicates how many CAN bits the Tx arbitration process start point can be delayed from the first bit of CRC field on CAN bus. This field can only be written in Freeze mode as it is blocked by hardware in other modes. This field is useful to optimize the transmit performance based on factors such as: peripheral/serial clock ratio, CAN bit timing and number of MBs. The duration of an arbitration process, in terms of CAN bits, is directly proportional to the number of available MBs and CAN baud rate and inversely proportional to the peripheral clock frequency. The optimal arbitration timing is that in which the last MB is scanned right before the first bit of the Intermission field of a CAN frame. Therefore, if there are few MBs and the system/serial clock ratio is high and the CAN baud rate is low then the arbitration can be delayed and vice-versa. If TASD is 0 then the arbitration start is not delayed, thus Arm has less time to configure a Tx MB for the next arbitration. In the other hand, if TASD is 24 then Arm can configure a Tx MB later and less time is reserved for arbitration. If too little time is reserved for arbitration the FlexCAN may be not able to find winner MBs in time to compete with other nodes for the CAN bus. If the arbitration ends too much time before the first bit of Intermission field then there is a chance that Arm reconfigure some Tx MBs and the winner MB is not the best to be transmitted. The reset value is different on various platforms, according to their peripheral clock frequency, number of MBs and target CAN baud rate. The optimal configuration for TASD can be calculated as:</td>
</tr>
</tbody>
</table>

\[
TASD = 25 - \left\{ \frac{f_{\text{CANCLK}} \times [\text{MAXMB} + 3 - (\text{RFEN} \times 8) - (\text{RFEN} \times \text{RFFN} \times 2)] \times 2}{f_{\text{sys}} \times [1 + (\text{PSEG1} + 1) + (\text{PSEG2} + 1) + (\text{PROPSEG} + 1)] \times (\text{PRESDIV} + 1)} \right\}
\]

where:

- \(f_{\text{CANCLK}}\) is the Protocol Engine (PE) Clock in Hz; PE clock is derived from CAN_CLK_ROOT in CCM. See the Clock controller module.

Table continues on the next page...
FLEXCANx_CTRL2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>fSYS</td>
<td>is the peripheral clock in Hz;</td>
</tr>
<tr>
<td>MAXMB</td>
<td>is the value in CTRL1[MAXMB] field;</td>
</tr>
<tr>
<td>RFEN</td>
<td>is the value in CTRL1[RFEN] bit;</td>
</tr>
<tr>
<td>RFFN</td>
<td>is the value in CTRL2[RFFN] field;</td>
</tr>
<tr>
<td>PSEG1</td>
<td>is the value in CTRL1[PSEG1] field;</td>
</tr>
<tr>
<td>PSEG2</td>
<td>is the value in CTRL1[PSEG2] field;</td>
</tr>
<tr>
<td>PROPSEG</td>
<td>is the value in CTRL1[PROPSEG] field;</td>
</tr>
<tr>
<td>PRESDIV</td>
<td>is the value in CTRL1[PRESDIV] field.</td>
</tr>
</tbody>
</table>

Please refer to Arbitration process and Protocol Timing for more details.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>18</td>
<td>MRP</td>
</tr>
</tbody>
</table>

If this bit is set the matching process starts from the Mailboxes and if no match occurs the matching continues on the Rx FIFO. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Matching starts from Mailboxes and continues on Rx FIFO</td>
</tr>
<tr>
<td>0</td>
<td>Matching starts from Rx FIFO and continues on Mailboxes</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>17</td>
<td>RRS</td>
</tr>
</tbody>
</table>

If this bit is asserted Remote Request Frame is submitted to a matching process and stored in the corresponding Message Buffer in the same fashion of a Data Frame. No automatic Remote Response Frame will be generated.

If this bit is negated the Remote Request Frame is submitted to a matching process and an automatic Remote Response Frame is generated if a Message Buffer with CODE=0b1010 is found with the same ID.

This bit can only be written in Freeze mode as it is blocked by hardware in other modes.

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Remote Request Frame is stored</td>
</tr>
<tr>
<td>0</td>
<td>Remote Response Frame is generated</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>EACEN</td>
</tr>
</tbody>
</table>

This bit controls the comparison of IDE and RTR bits within Rx Mailboxes filters with their corresponding bits in the incoming frame by the matching process. This bit does not affect matching for Rx FIFO. This bit can only be written in Freeze mode as it is blocked by hardware in other modes.

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Enables the comparison of both Rx Mailbox filter's IDE and RTR bit with their corresponding bits within the incoming frame. Mask bits do apply.</td>
</tr>
<tr>
<td>0</td>
<td>Rx Mailbox filter's IDE bit is always compared and RTR is never compared despite mask bits.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

- This field is reserved.

Reserved
44.9.14 Error and Status 2 Register (FLEXCANx_ESR2)

This register reflects various interrupt flags and some general status.

Address: Base address + 38h offset

Bit 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16

R

Reserved

LPTM

W

Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

Bit 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0

R

VPS IMB

Reserved

W

Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

Chapter 44 Flexible Controller Area Network (FLEXCAN)

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
## FLEXCANx_ESR2 Field Descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–23</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>22–16</td>
<td>LPTM</td>
</tr>
<tr>
<td></td>
<td>If ESR2[VPS] is asserted, his 7-bit field indicates the lowest number inactive Mailbox (refer to IMB bit description). If there is no inactive Mailbox then the Mailbox indicated depends on CTRL1[LBUF] bit value. If CTRL1[LBUF] bit is negated then the Mailbox indicated is the one which has the greatest arbitration value (see Highest Mailbox priority first). If CTRL1[LBUF] bit is asserted then the Mailbox indicated is the highest number active Tx Mailbox. If a Tx Mailbox is being transmitted it is not considered in LPTM calculation. If ESR2[IMB] is not asserted and a frame is transmitted successfully, LPTM is updated with its Mailbox number.</td>
</tr>
<tr>
<td>15</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>14</td>
<td>VPS</td>
</tr>
<tr>
<td></td>
<td>This bit indicates whether IMB and LPTM contents are currently valid or not. VPS is asserted upon every complete Tx arbitration process unless the Arm writes to Control and Status word of a Mailbox that has already been scanned (i.e. it is behind Tx Arbitration Pointer) during the Tx arbitration process. If there is no inactive Mailbox and only one Tx Mailbox which is being transmitted then VPS is not asserted. VPS is negated upon the start of every Tx arbitration process or upon a write to Control and Status word of any Mailbox. ESR2[VPS] is not affected by any Arm write into Control Status (C/S) of a MB which is blocked by abort mechanism. When MCR[AEN] is asserted, the abort code write in C/S of a MB that is been transmitted (pending abort), or any write attempt into a Tx MB with IFLAG set is blocked.</td>
</tr>
<tr>
<td></td>
<td>1 Contents of IMB and LPTM are valid</td>
</tr>
<tr>
<td></td>
<td>0 Contents of IMB and LPTM are invalid</td>
</tr>
<tr>
<td>13</td>
<td>IMB</td>
</tr>
<tr>
<td></td>
<td>If ESR2[VPS] is asserted, this bit indicates whether there is any inactive Mailbox (CODE field is either 0b1000 or 0b0000). This bit is asserted in the following cases:</td>
</tr>
<tr>
<td></td>
<td>(1) During arbitration, if a LPTM is found and it is inactive.</td>
</tr>
<tr>
<td></td>
<td>(2) If IMB is not asserted and a frame is transmitted successfully.</td>
</tr>
<tr>
<td></td>
<td>(3) This bit is cleared in all start of arbitration (see Arbitration process).</td>
</tr>
<tr>
<td></td>
<td>LPTM mechanism have the following behavior: if a MB is successfully transmitted and ESR2[IMB]=0 (no inactive Mailbox), then ESR2[VPS] and ESR2[IMB] are asserted and the index related to the MB just transmitted is loaded into ESR2[LPTM].</td>
</tr>
<tr>
<td></td>
<td>1 If ESR2[VPS] is asserted, there is at least one inactive Mailbox. LPTM content is the number of the first one.</td>
</tr>
<tr>
<td></td>
<td>0 If ESR2[VPS] is asserted, the ESR2[LPTM] is not an inactive Mailbox.</td>
</tr>
<tr>
<td>-</td>
<td>This field is reserved. Reserved</td>
</tr>
</tbody>
</table>
44.9.15 CRC Register (FLEXCANx_CRC)<

This register provides information about the CRC of transmitted messages.

Address: Base address + 44h offset

```plaintext
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

- **Reserved**
- **MBCRC**
- **TXCRC**
### FLEXCANx_CRC field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–23</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>22–16 MBCRC</td>
<td>This field indicates the number of the Mailbox corresponding to the value in TXCRC field.</td>
</tr>
<tr>
<td>15</td>
<td>This field is reserved. Reserved</td>
</tr>
<tr>
<td>TXCRC</td>
<td>This field indicates the CRC value of the last message transmitted. This field is updated at the same time the Tx Interrupt Flag is asserted.</td>
</tr>
</tbody>
</table>

### 44.9.16 Rx FIFO Global Mask Register (FLEXCANx_RXFGMASK)

If Rx FIFO is enabled RXFGMASK is used to mask the Rx FIFO ID Filter Table elements that do not have a corresponding RXIMR according to CTRL2[RFFN] field setting.

This register can only be written in Freeze Mode as it is blocked by hardware in other modes.

#### Table 44-24. Rx FIFO Global Mask usage

<table>
<thead>
<tr>
<th>Rx FIFO ID Filter Table Elements Format (MCR[IDAM])</th>
<th>Identifier Acceptance Filter fields</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>RTR</td>
</tr>
<tr>
<td></td>
<td>-</td>
</tr>
</tbody>
</table>

1. If MCR[IDAM] field is equivalent to the format B only the fourteen most significant bits of the Identifier of the incoming frame are compared with the Rx FIFO filter.
2. If MCR[IDAM] field is equivalent to the format C only the eight most significant bits of the Identifier of the incoming frame are compared with the Rx FIFO filter.
### FLEXCANx_RXFGMASK field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>FGM31_FGM0</td>
<td>These bits mask the ID Filter Table elements bits in a perfect alignment. Rx FIFO Global Mask Register (FLEXCAN_RXFGMASK) shows in detail which FGM bits mask each IDAF field. Clear this register has the effect of disabling the ID Filter.</td>
</tr>
</tbody>
</table>

- **1**: The corresponding bit in the filter is checked
- **0**: The corresponding bit in the filter is "don't care"

### 44.9.17 Rx FIFO Information Register (FLEXCANx_RXFIR)

Rx FIFO provides information on Rx FIFO.

This register is the port through which Arm accesses the output of the RXFIR FIFO located in RAM. The RXFIR FIFO is written by the FlexCAN whenever a new message is moved into the Rx FIFO as well as its output is updated whenever the output of the Rx FIFO is updated with the next message. Refer to Rx FIFO to find instructions on reading this register.

### FLEXCANx_RXFIR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–9</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>IDHIT</td>
<td>This 9-bit field indicates which Identifier Acceptance Filter (see Rx FIFO Structure) was hit by the received message that is in the output of the Rx FIFO. (refer to Rx FIFO for details) If multiple filters match the incoming message ID then the first matching IDAF found (lowest number) by the matching process is indicated. This field is valid only while the IFLAG[BUF5I] is asserted.</td>
</tr>
</tbody>
</table>
44.9.18  Rx Individual Mask Registers (FLEXCANx_RXIMRn)

RXIMR are used as acceptance masks for ID filtering in Rx MBs and the Rx FIFO. If the Rx FIFO is not enabled, one mask register is provided for each available Mailbox, providing ID masking capability on a per Mailbox basis.

When the Rx FIFO is enabled (MCR[RFEN] bit is asserted), up to 32 Rx Individual Mask Registers can apply to the Rx FIFO ID Filter Table elements on a one-to-one correspondence depending on CTRL2[RFFN] setting. Refer to Control 2 Register (FLEXCAN_CTRL2) for details.

RXIMR can only be written by the Arm while the module is in Freeze Mode, otherwise they are blocked by hardware.

The Individual Rx Mask Registers are not affected by reset and must be explicitly initialized prior to any reception.

Address: Base address + 880h offset + (4d × i), where i=0d to 63d

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MI31_MI0</td>
<td>These bits mask both Mailbox filter and Rx FIFO ID Filter Table element in distinct ways.</td>
</tr>
<tr>
<td></td>
<td>For Mailbox filter refer to Rx Mailboxes Global Mask Register (FLEXCAN_RXMG MASK).</td>
</tr>
<tr>
<td></td>
<td>For Rx FIFO ID Filter Table element refer to Rx FIFO Global Mask Register (FLEXCAN_RXFGMASK).</td>
</tr>
<tr>
<td></td>
<td>1  The corresponding bit in the filter is checked</td>
</tr>
<tr>
<td></td>
<td>0  the corresponding bit in the filter is &quot;don't care&quot;</td>
</tr>
</tbody>
</table>

44.9.19  Glitch Filter Width Registers (FLEXCANx_GFWR)

The Glitch Filter just takes effects when FLEXCAN enters the STOP mode.

Address: Base address + 9E0h offset

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MI31_MI0</td>
<td>1  The corresponding bit in the filter is checked</td>
</tr>
<tr>
<td></td>
<td>0  the corresponding bit in the filter is &quot;don't care&quot;</td>
</tr>
</tbody>
</table>
## FLEXCANx_GFWR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| GFWR        | It determines the Glitch Filter Width. The width will be divided from Oscillator clock by GFWR values. By default, it is 5.33 μs when the oscillator is 24 MHz.  
  Filter Pulse Width = [(GFWR FIELD + 1) x (1 / Osc. Frequency)] |
Chapter 45
Flexible Data-rate Controller Area Network (CANFD/FlexCAN3)

45.1 Chip-specific FLEXCAN information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

45.2 Introduction
The FlexCAN module is a communication controller implementing the CAN protocol according to the ISO 11898-1 standard and CAN 2.0 B protocol specifications. A general block diagram is shown in Figure 45-1, which describes the main subblocks implemented in the FlexCAN module, including:

- One associated memory for storing message buffers
- Receive Global Mask registers
- Receive Individual Mask registers
- Receive FIFO filters
- Receive FIFO ID filters

The functions of the submodules are described in subsequent sections.
NOTE

Rx FIFO cannot be used in FD mode.

![FlexCAN block diagram](image)

**Figure 45-1. FlexCAN block diagram**

### 45.2.1 Overview

The CAN protocol was primarily designed to be used as a vehicle serial data bus, meeting the specific requirements of this field:

- Real-time processing
- Reliable operation in the EMI environment of a vehicle
- Cost-effectiveness
- Required bandwidth

The FlexCAN module is a full implementation of the CAN protocol specification, the CAN with Flexible Data rate (CAN FD) protocol, and the CAN 2.0 version B protocol, which supports both standard and extended message frames and long payloads up to 64 bytes, transferred at faster rates (up to 8 Mb/s). The message buffers are stored in an embedded RAM dedicated to the FlexCAN module. See the chip-specific FlexCAN information for the actual number of message buffers configured in the chip.

The Protocol Engine (PE) submodule manages the serial communication on the CAN bus:

- Requesting RAM access for receiving and transmitting message frames
- Validating received messages
• Performing error handling
• Detecting CAN FD messages

The Controller Host Interface (CHI) submodule manages message buffer selection for reception and transmission, taking care of arbitration and ID matching algorithms for both CAN FD and non-CAN FD message formats.

The Bus Interface Unit (BIU) submodule controls access to and from the internal interface bus, in order to establish connection to the CPU and to other blocks. Clocks, address and data buses, interrupt outputs, DMA and test signals are accessed through the BIU.

### 45.2.2 FlexCAN module features

The FlexCAN module includes these distinctive features:

- Full implementation of the CAN with Flexible Data Rate (CAN FD) protocol specification and CAN protocol specification, Version 2.0 B
  - Standard data frames
  - Extended data frames
  - Zero to sixty four bytes data length
  - Programmable bit rate (see the chip-specific FlexCAN information for the specific maximum rate configuration)
  - Content-related addressing
- Compliant with the ISO 11898-1 standard
- Flexible mailboxes configurable to store 0 to 8, 16, 32, or 64 bytes data length
- Each mailbox configurable as receive or transmit, all supporting standard and extended messages
- Individual Rx Mask registers per mailbox
- Full-featured Rx FIFO with storage capacity for up to six frames and automatic internal pointer handling with DMA support
- Transmission abort capability
- Flexible message buffers (MBs), totaling 64 message buffers of 8 bytes data length each, configurable as Rx or Tx
- Programmable clock source to the CAN Protocol Interface, either peripheral clock or oscillator clock
- RAM not used by reception or transmission structures can be used as general purpose RAM space
- Listen-Only mode capability
- Programmable Loop-Back mode supporting self-test operation
• Programmable transmission priority scheme: lowest ID, lowest buffer number, or highest priority
• Time stamp based on 16-bit free running timer, with an optional external time tick
• Global network time, synchronized by a specific message
• Maskable interrupts
• Independence from the transmission medium (an external transceiver is assumed)
• Short latency time due to an arbitration scheme for high-priority messages
• Low power modes, with programmable wakeup on bus activity
• Transceiver delay compensation feature when transmitting CAN FD messages at faster data rates
• Remote request frames may be managed automatically or by software
• CAN bit time settings and configuration bits can only be written in Freeze mode
• Tx mailbox status (Lowest priority buffer or empty buffer)
• Identifier Acceptance Filter Hit Indicator (IDHIT) register for received frames
• SYNCH bit available in Error in Status 1 register to indicate that the module is synchronous with CAN bus
• CRC status for transmitted message
• Rx FIFO Global Mask register
• Selectable priority between mailboxes and Rx FIFO during matching process
• Powerful Rx FIFO ID filtering, capable of matching incoming IDs against either 128 extended, 256 standard, or 512 partial (8 bit) IDs, with up to 32 individual masking capability
• 100% backward compatibility with previous FlexCAN version

45.2.3 Modes of operation

The FlexCAN module has these functional modes:

• Normal mode (User or Supervisor):

  In Normal mode, the module operates receiving and/or transmitting message frames, errors are managed normally, and all CAN Protocol functions are enabled. User and Supervisor modes differ in the access to some restricted control registers.

• Freeze mode:

  Freeze mode is enabled when MCR[FRZ] is asserted. If enabled, Freeze mode is entered when MCR[HALT] is set or when Debug mode is requested at chip level and MCR[FRZ_ACK ] is asserted by the FlexCAN. In this mode, no transmission or reception of frames is done and synchronicity to the CAN bus is lost. See Freeze mode for more information.

• Loop-Back mode:
The module enters this mode when CTRL1[LPB] is asserted. In this mode, FlexCAN performs an internal loop back that can be used for self-test operation. The bit stream output of the transmitter is internally fed back to the receiver input. The Rx CAN input pin is ignored and the Tx CAN output goes to the recessive state (logic '1'). FlexCAN behaves as it normally does when transmitting and treats its own transmitted message as a message received from a remote node. In this mode, FlexCAN ignores the bit sent during the ACK slot in the CAN frame acknowledge field to ensure proper reception of its own message. Both transmit and receive interrupts are generated.

- **Listen-Only mode:**

  The module enters this mode when CTRL1[LOM] is asserted. In this mode, transmission is disabled, all error counters are frozen, and the module operates in a CAN Error Passive mode. Only messages acknowledged by another CAN station will be received. If FlexCAN detects a message that has not been acknowledged, it will flag a BIT0 error (without changing the REC), as if it was trying to acknowledge the message.

- **CAN FD Active mode:**

  In this mode, FlexCAN is capable of transmitting and receiving all messages formatted according to the CAN FD Protocol and CAN 2.0 Protocol 2.0 in an interleaved fashion. The CPU can set the FlexCAN into CAN FD Active mode by configuring MCR[FDEN] in Freeze mode.

  It is important to know which features are available in CAN FD active mode. This table lists the differences between FD and classical modes.

<table>
<thead>
<tr>
<th>Feature</th>
<th>CAN classical</th>
<th>CAN FD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rx FIFO DMA</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Rx FIFO</td>
<td>Yes</td>
<td>No</td>
</tr>
</tbody>
</table>

  For low-power operation, the FlexCAN module has:

  - **Module Disable mode:**

    This low-power mode is entered when MCR[MDIS] is asserted by the CPU and MCR[LPM_ACK] is asserted by FlexCAN. When disabled, the module issues a request to disable the clocks to the CAN Protocol Engine and Controller Host Interface submodules. Exit from this mode is done by negating MCR[MDIS]. See Module Disable mode for more information.
• Doze mode:

This low power mode is entered when MCR[DOZE] is asserted and Doze mode is requested at chip level, and MCR[LPM_ACK] is asserted by FlexCAN. When in Doze mode, the module issues a request to disable the clocks to the CAN Protocol Engine and the CAN Controller-Host Interface submodules. Exit from this mode happens when MCR[DOZE] is negated, when the chip is removed from Doze mode, or when activity is detected on the CAN bus and the Self Wake Up mechanism is enabled. See Doze mode for more information.

• Stop mode:

This low power mode is entered when Stop mode is requested at chip level and MCR[LPM_ACK] is asserted by the FlexCAN. When in Stop Mode, the module puts itself in an inactive state and then informs the CPU that the clocks can be shut down globally. Exit from this mode happens when the Stop mode request is removed, or when activity is detected on the CAN bus and the Self Wake Up mechanism is enabled. See Stop mode for more information.

### 45.3 FlexCAN signal descriptions

The FlexCAN module has two I/O signals connected to the external chip pins. These signals are summarized in the following table and described in more detail in the next subsections.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>CAN Rx</td>
<td>CAN receive pin</td>
<td>Input</td>
</tr>
<tr>
<td>CAN Tx</td>
<td>CAN transmit pin</td>
<td>Output</td>
</tr>
</tbody>
</table>

### 45.3.1 CAN Rx

This pin is the receive pin from the CAN bus transceiver. Dominant state is represented by logic level 0. Recessive state is represented by logic level 1.
45.3.2 CAN Tx

This pin is the transmit pin to the CAN bus transceiver. Dominant state is represented by logic level 0. Recessive state is represented by logic level 1.

45.4 Functional description

The FlexCAN module is a CAN protocol engine with a very flexible mailbox system for transmitting and receiving CAN frames. The mailbox system is composed of a set of message buffers (MB) that store configuration and control data, time stamp, message ID, and data (see Message buffer structure). The memory corresponding to the first 38 MBs can be configured to support a FIFO reception scheme with a powerful ID filtering mechanism, capable of checking incoming frames against a table of IDs (up to 128 extended IDs or 256 standard IDs or 512 8-bit ID slices), with individual mask register for up to 32 ID filter table elements.

For Classical CAN frames, simultaneous reception through FIFO and mailbox is supported. For CAN FD frames, reception is supported through mailboxes only. For mailbox reception, a matching algorithm makes it possible to store received frames only into MBs that have the same ID programmed in the ID field. A masking scheme makes it possible to match the ID programmed on the MB with a range of IDs on received CAN frames. For transmission, an arbitration algorithm decides the prioritization of MBs to be transmitted based on the message ID (optionally augmented by 3 local priority bits) or the MB ordering.

Before proceeding with the functional description, an important concept must be explained. A message buffer is said to be active at a given time if it can participate in both the matching and arbitration processes. An Rx MB with a 0b0000 code is inactive (see Table 45-24). Similarly, a Tx MB with a 0b1000 or 0b1001 code is also inactive (see Table 45-25).

The FlexCAN module is also able to receive and transmit messages in CAN FD format. The message buffers are sized to adequately store the quantity of data bytes selected by the FDCTRL[MBDSRn] fields. The quantity of FD MBs available for a given quantity of data bytes is described in the FDCTRL register. See also FlexCAN memory partition for CAN FD.

45.4.1 Transmit process

To transmit a CAN frame, the CPU must prepare a message buffer for transmission by executing the following procedure:
1. Check whether the respective interrupt bit is set and clear it.
2. If the MB is active (transmission pending), write the ABORT code (0b1001) to the CODE field of the Control and Status word to request an abort of the transmission.
3. Wait for the corresponding IFLAG bit to be asserted by polling the IFLAG register, or by the interrupt request if enabled by the respective IMASK bit.
4. Read back the CODE field to check if the transmission was aborted or transmitted (see Transmission abort mechanism).
5. Clear the corresponding interrupt flag.
6. Write the ID register (containing the local priority if enabled via MCR[LPRIO_EN]).
7. Write payload data bytes.
8. Configure the Control and Status word with the desired configuration.
   a. Set ID type via MB_CS[IDE].
   b. Set Remote Transmission Request (if needed) via MB_CS[RTR].
   c. If MCR[FDEN] is enabled, also configure the MB_CS[EDL] and MB_CS[BRS] fields. For details about the relationship between the written value and transmitted value of the MB_CS[ESI] field, see Table 45-8.\(^1\)
   d. Set Data Length Code in bytes via MB_CS[DLC]. See Table 45-26 for detailed information.
   e. Activate the message buffer to transmit the CAN frame by setting MB_CS[CODE] to 0xC.

**NOTE**

It is strongly recommended that all the fields in MB_CS word be configured in only one 32-bit write operation to maximize software performance. If the fields are configured in separate writes, the MB_CS[CODE] must be the last write in the C/S word.

When the MB is activated, it participates in the arbitration process and is eventually transmitted according to its priority. When the DLC value stored in the MB selected for transmission is larger than the respective MB payload size, FlexCAN adds the necessary number of bytes with constant 0xCC pattern to complete the expected DLC.

At the end of the successful transmission:
- The value of the free running timer is written into the Time Stamp field.
- The CODE field in the Control and Status word is updated.
- Both CRC and FDCRC registers are updated.

---

\(^1\) The ESI field does not need to be written, and will automatically be transmitted dominant by error active nodes and recessive by error passive nodes. Note that there is an exception if the FlexCAN is operating as a network gateway: In that case, the CPU writes the MB_CS[ESI] bit according to the error status of the node which sent the message.
A status flag is set in the Interrupt Flag register.
An interrupt is generated if allowed by the corresponding Interrupt Mask Register bit.

The new CODE field after transmission depends on the code that was used to activate the MB (see Table 45-24 and Table 45-25 in Message buffer structure).

When the Abort feature is enabled (MCR[AEN] is asserted), after the Interrupt flag is asserted for a mailbox configured as transmit buffer, the mailbox is blocked. Therefore the CPU is not able to update it until the Interrupt Flag is negated by the CPU. This means that the CPU must clear the corresponding IFLAG bit before starting to prepare this MB for a new transmission or reception.

**NOTE**

If backwards compatibility is desired (MCR[AEN] is negated), write the INACTIVE code (0b1000) to the CODE field to inactivate the MB. However, in this case the pending frame may be transmitted without notification (see Mailbox inactivation).

45.4.2 Arbitration process

The arbitration process scans the mailboxes, searching for the Tx mailbox that holds the message to be sent in the next opportunity. This mailbox is called the arbitration winner.

The scan starts from the lowest number mailbox and runs toward the higher ones.

The arbitration process is triggered in the following events:

- From the CRC field of the CAN frame. The start point depends on the value of CTRL2[TASD].
- During the Error Delimiter field of a CAN frame.
- During the Overload Delimiter field of a CAN frame.
- When the winner is inactivated and the CAN bus has still not reached the first bit of the Intermission field.
- When there is a CPU write to the C/S word of a winner MB and the CAN bus has still not reached the first bit of the Intermission field.
- When CHI is in Idle state and the CPU writes to the C/S word of any MB.
- When FlexCAN exits Bus Off state.
- Upon leaving Freeze mode or Low Power mode.

If the arbitration process does not manage to evaluate all mailboxes before the CAN bus has reached the first bit of the Intermission field, the temporary arbitration winner is invalidated and the FlexCAN will not compete for the CAN bus in the next opportunity.
The arbitration process selects the winner among the active Tx mailboxes at the end of the scan according to the settings of both CTRL1[LBUF] and MCR[LPRIOEN].

### 45.4.2.1 Lowest-number mailbox first

If CTRL1[LBUF] is asserted, the first (lowest number) active Tx mailbox found is the arbitration winner. MCR[LPRIOEN] has no effect when CTRL1[LBUF] is asserted.

### 45.4.2.2 Highest-priority mailbox first

If CTRL1[LBUF] is negated, then the arbitration process searches the active Tx mailbox with the highest priority, which means that this mailbox’s frame would have a higher probability to win the arbitration on CAN bus when multiple external nodes compete for the bus at the same time.

The sequence of bits considered for this arbitration is called the *arbitration value* of the mailbox. The highest-priority Tx mailbox is the one that has the lowest arbitration value among all Tx mailboxes.

If two or more mailboxes have equivalent arbitration values, the mailbox with the lowest number is the arbitration winner.

The composition of the arbitration value depends on the MCR[LPRIOEN] setting.

#### 45.4.2.2.1 Local priority disabled

If MCR[LPRIOEN] is negated the arbitration value is built in the exact sequence of bits as they would be transmitted in a CAN frame (see the following table) in such a way that the local priority is disabled.

<table>
<thead>
<tr>
<th>Format</th>
<th>Mailbox arbitration value (32 bits)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard (IDE = 0)</td>
<td>Standard ID (11 bits) RTR (1 bit) IDE (1 bit) - (18 bits) - (1 bit)</td>
</tr>
<tr>
<td>Extended (IDE = 1)</td>
<td>Extended ID[28:18] (11 bits) SRR (1 bit) IDE (1 bit) Extended ID[17:0] (18 bits) RTR (1 bit)</td>
</tr>
</tbody>
</table>

#### 45.4.2.2.2 Local priority enabled

To enable local priority, MCR[LPRIOEN] must be asserted. In this case the mailbox PRIO field is included at the very left of the arbitration value (see the following table).
Table 45-5. Composition of the arbitration value when local priority is enabled

<table>
<thead>
<tr>
<th>Format</th>
<th>Mailbox arbitration value (35 bits)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard (IDE = 0)</td>
<td>PRIO (3 bits) Standard ID (11 bits) RTR (1 bit) IDE (1 bit) - (18 bits) - (1 bit)</td>
</tr>
<tr>
<td>Extended (IDE = 1)</td>
<td>PRIO (3 bits) Extended ID[28:18] (11 bits) SRR (1 bit) IDE (1 bit) Extended ID[17:0] (18 bits) RTR (1 bit)</td>
</tr>
</tbody>
</table>

Because the PRIO field is the most significant part of the arbitration value, mailboxes with low PRIO values have higher priority than mailboxes with high PRIO values regardless of the rest of their arbitration values.

Note that the PRIO field is not part of the frame on the CAN bus. Its purpose is only to affect the internal arbitration process.

**45.4.2.3 Arbitration process (continued)**

After the arbitration winner is found, its content is copied to a hidden auxiliary MB called Tx Serial Message Buffer (Tx SMB), which has the same structure as a normal MB but is not user accessible. This operation is called move-out and after it is done, write access to the C/S word of the corresponding MB is blocked (if MCR[AEN] is asserted). Write access is restored in the following events:

- After the MB is transmitted and the corresponding IFLAG bit is cleared by the CPU.
- FlexCAN enters Freeze mode or Bus Off.
- FlexCAN loses the bus arbitration or there is an error during the transmission.

At the first opportunity window on the CAN bus, the message on the Tx SMB is transmitted according to the CAN protocol rules.

Arbitration process can be triggered in the following situations:

- During Rx and Tx frames from CAN CRC field to end of frame. CTRL2[TASD] value may be changed to optimize the arbitration start point.
- During CAN Bus Off state from TX_ERR_CNT=124 to 128. CTRL2[TASD] value may be changed to optimize the arbitration start point.
- During C/S write by CPU in Bus Idle. First C/S write starts arbitration process, and a second C/S write during this same arbitration restarts the process. If other C/S writes are performed, Tx arbitration process is pending. If there is no arbitration winner after the arbitration process has finished, then the TX arbitration machine begins a new arbitration process. If there is a pending arbitration and Bus Idle state starts, then an arbitration process is triggered. In this case the first and second C/S write in Bus Idle will not restart the arbitration process. It is possible that there is not enough time...
to finish arbitration in Wait For Bus Idle state and the next state is Idle. In this case
the scan is not interrupted, and it is completed during Bus Idle state. During this
arbitration C/S write does not cause arbitration restart.

- Arbitration winner deactivation during a valid arbitration window.
- Upon exiting Freeze mode (first bit of the Wait For Bus Idle state). If there is a re-
synchronization during Wait For Bus Idle, the arbitration process is restarted.

Arbitration process stops in the following situations:

- All mailboxes were scanned.
- A Tx active mailbox is found if lowest buffer feature is enabled.
- Arbitration winner inactivation or abort during any arbitration process.
- There was not enough time to finish Tx arbitration process (for instance, when a
deactivation was performed near the end of frame). In this case arbitration process is
pending.
- Error or overload flag in the bus.
- Low Power or Freeze mode request in Idle state.

Arbitration is considered pending as described below:

- It was not possible to finish arbitration process in time.
- C/S write during arbitration if write is performed in a MB whose number is lower
than the Tx arbitration pointer.
- Any C/S write if there is no Tx arbitration process in progress.
- Rx Match has just updated a Rx code to Tx code.
- Entering Bus Off state.

C/S write during arbitration has the following effect:

- If C/S write is performed in the arbitration winner, a new process is restarted
immediately.
- If C/S write is performed in a MB whose number is higher than the Tx arbitration
pointer, the ongoing arbitration process will scan this MB as normal.

45.4.3 Receive process

To be able to receive CAN frames into a mailbox, the CPU must prepare it for reception
by executing the following steps:

1. If the mailbox is active (either Tx or Rx) inactivate the mailbox (see Mailbox
   inactivation), preferably with a safe inactivation (see Transmission abort
   mechanism).
2. Write the ID word
3. Write the EMPTY code (0b0100) to the CODE field of the Control and Status word to activate the mailbox. No setup is required for EDL, BRS, and ESI bits—they are overwritten by the respective bit fields in the received message.

After the MB is activated, it will be able to receive frames that match the programmed filter. At the end of a successful reception, the mailbox is updated by the move-in process (see Move-in) as follows:

1. The received data field (8 bytes at most for Classical CAN message format and up to 64 bytes for CAN FD message format) is stored.
2. The received Identifier field is stored.
3. The value of the Free Running Timer at the time of the second bit of frame's Identifier field is written into the mailbox's Time Stamp field.
4. The received SRR, IDE, RTR, EDL, BRS, ESI, and DLC fields are stored.
5. The CODE field in the Control and Status word is updated (see Table 45-24 and Table 45-25 in Section Message buffer structure).
6. A status flag is set in the Interrupt Flag Register and an interrupt is generated if allowed by the corresponding Interrupt Mask Register bit.

The recommended way for the CPU to service (read) the frame received in a mailbox is by the following procedure:

1. Read the Control and Status word of that mailbox.
2. Check if the BUSY bit is deasserted, indicating that the mailbox is locked. Repeat step 1) while it is asserted. See Mailbox lock mechanism.
3. Read the contents of the mailbox. After the mailbox is locked, its contents won't be modified by FlexCAN move-in processes. See Move-in.
4. Acknowledge the proper flag at IFLAG registers.
5. Read the free running timer. It is optional but recommended to unlock the mailbox as soon as possible and make it available for reception.

The CPU should poll for frame reception by the status flag bit for the specific mailbox in one of the IFLAG registers and not by the CODE field of that mailbox. Polling the CODE field does not work because after a frame is received and the CPU services the mailbox (by reading the C/S word followed by unlocking the mailbox), the CODE field will not return to EMPTY. It will remain FULL, as explained in Table 45-24. If the CPU tries to work around this behavior by writing to the C/S word to force an EMPTY code after reading the mailbox without a prior safe inactivation, a newly received frame matching the filter of that mailbox may be lost.

**CAUTION**

In summary: never do polling by reading directly the C/S word of the mailboxes. Instead, read the IFLAG registers.
Note that the received frame's Identifier field is always stored in the matching mailbox, thus the contents of the ID field in a mailbox may change if the match was due to masking. When MCR[SRXDIS] is asserted, FlexCAN will not store frames transmitted by itself in any MB, even if it contains a matching Rx mailbox, and no interrupt flag or interrupt signal will be generated. Otherwise, when MCR[SRXDIS] is deasserted, FlexCAN can receive frames transmitted by itself if a matching Rx mailbox exists.

To be able to receive CAN frames through the Rx FIFO, the CPU must enable and configure the Rx FIFO during Freeze mode (see Rx FIFO). Upon receiving the Frames Available in Rx FIFO interrupt (see the description of IFLAG1[BUF5I] "Frames available in Rx FIFO"), the CPU should service the received frame using the following procedure:

1. Read the Control and Status word (optional: needed only if a mask was used for IDE and RTR bits).
2. Read the ID field (optional: needed only if a mask was used).
3. Read the data field.
4. Read the RXFIR register (optional).
5. Clear the Frames Available in Rx FIFO interrupt by writing one to IFLAG1[BUF5I] (mandatory: releases the MB and allows the CPU to read the next Rx FIFO entry).

When MCR[DMA] is asserted, upon receiving a frame in FIFO, IFLAG1[BUF5I] generates a DMA request and does not generate a CPU interrupt (see Rx FIFO under DMA operation). The IMASK1 bits in Rx FIFO region are not used.

The DMA controller must service the received frame using the following procedure:

1. Read the Control and Status word (read 0x80 address, optional).
2. Read the ID field (read 0x84 address, optional).
3. Read all data bytes (start read at 0x88 address, optional).
4. Read the last data bytes (read 0x8C address is mandatory).

### 45.4.4 Matching process

The matching process scans the MB memory looking for Rx MBs programmed with the same ID as the one received from the CAN bus. If the FIFO is enabled, the priority of scanning can be selected between mailboxes and FIFO filters. The matching starts from the lowest number message buffer toward the higher ones. If no match is found within the first structure then the other is scanned subsequently. In the event that the FIFO is full, the matching algorithm always looks for a matching MB outside the FIFO region.

For Rx FIFO see Rx FIFO.
As the frame is being received, it is stored in a hidden auxiliary MB called Rx Serial Message Buffer (Rx SMB).

The matching process start point depends on the following conditions:

- If the received frame is a remote frame, the start point is the CRC field of the frame.
- If the received frame is a data frame with DLC field equal to zero, the start point is the CRC field of the frame.
- If the received frame is a data frame with DLC field different than zero, the start point is the DATA field of the frame.

If a matching ID is found in the FIFO table or in one of the mailboxes, the contents of the Rx SMB are transferred to the FIFO or to the matched mailbox by the move-in process. If any CAN protocol error is detected then no match results are transferred to the FIFO or to the matched mailbox at the end of reception.

The matching process scans all matching elements of both Rx FIFO (if enabled) and the active Rx mailboxes (CODE is EMPTY, FULL, OVERRUN, or RANSWER) in search of a successful comparison with the matching elements of the Rx SMB that is receiving the frame on the CAN bus. The Rx SMB has the same structure as a mailbox. The reception structures (Rx FIFO or mailboxes) associated with the matching elements that had a successful comparison are the matched structures. The matching winner is selected at the end of the scan among those matched structures and depends on conditions described ahead. See the following table.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Mailbox</td>
<td>0</td>
<td>—</td>
<td>0</td>
<td>cmp^2</td>
<td>no_cmp^3</td>
<td>cmp_msk</td>
<td>EMPTY or FULL or OVERRUN</td>
</tr>
<tr>
<td>Mailbox</td>
<td>0</td>
<td>—</td>
<td>1</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>EMPTY or FULL or OVERRUN</td>
</tr>
<tr>
<td>Mailbox</td>
<td>1</td>
<td>0</td>
<td>—</td>
<td>cmp</td>
<td>no_cmp</td>
<td>cmp</td>
<td>RANSWER</td>
</tr>
<tr>
<td>Mailbox</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>cmp</td>
<td>no_cmp</td>
<td>cmp_msk</td>
<td>EMPTY or FULL or OVERRUN</td>
</tr>
<tr>
<td>Mailbox</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>EMPTY or FULL or OVERRUN</td>
</tr>
<tr>
<td>FIFO</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>cmp_msk</td>
<td>—</td>
</tr>
</tbody>
</table>

1. For mailbox structure, If SMB[IDE] is asserted, the ID is 29 bits (ID Standard + ID Extended). If SMB[IDE] is negated, the ID is only 11 bits (ID Standard). For FIFO structure, the ID depends on IDAM.
2. cmp: Compares the Rx SMB contents with the MB contents regardless the masks.
3. no_cmp: The Rx SMB contents are not compared with the MB contents.
4. cmp_msk: Compares the Rx SMB contents with MB contents taking into account the masks.
5. SMB[IDE] and SMB[RTR] are not taken into account when IDAM is type C.

A reception structure is free-to-receive when any of the following conditions is satisfied:

- The CODE field of the mailbox is EMPTY.
- The CODE field of the mailbox is either FULL or OVERRUN and it has already been serviced (the C/S word was read by the CPU and unlocked as described in Mailbox lock mechanism).
- The CODE field of the mailbox is either FULL or OVERRUN and an inactivation (see Mailbox inactivation) is performed.
- The Rx FIFO is not full.

The scan order for mailboxes and Rx FIFO is from the matching element with lowest number to the higher ones.

The matching winner search for mailboxes is affected by MCR[IRMQ]. If it is negated, the matching winner is the first matched mailbox regardless if it is free-to-receive or not. If it is asserted, the matching winner is selected according to the priority below:

1. the first free-to-receive matched mailbox;
2. the last non free-to-receive matched mailbox.

It is possible to select the priority of scan between mailboxes and Rx FIFO with CTRL2[MRP].

If the selected priority is Rx FIFO first:

- If the Rx FIFO is a matched structure and is free-to-receive, then the Rx FIFO is the matching winner regardless of the scan for mailboxes.
- Otherwise (the Rx FIFO is not a matched structure or is not free-to-receive), then the matching winner is searched among mailboxes as described above.

If the selected priority is mailboxes first:

- If a free-to-receive matched mailbox is found, it is the matching winner regardless of the scan for Rx FIFO.
- If no matched mailbox is found, then the matching winner is searched in the scan for the Rx FIFO.
- If both conditions above are not satisfied and a non–free-to-receive matched mailbox is found, then the matching winner determination is conditioned by MCR[IRMQ]:
  - If MCR[IRMQ] is negated, the matching winner is the first matched mailbox.
  - If MCR[IRMQ] is asserted, the matching winner is the Rx FIFO if it is a free-to-receive matched structure; otherwise, the matching winner is the last non–free-to-receive matched mailbox.
See the following table for a summary of matching possibilities.

<table>
<thead>
<tr>
<th>RFEN</th>
<th>IRMQ</th>
<th>MRP</th>
<th>Matched in MB</th>
<th>Matched in FIFO</th>
<th>Reception structure</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>None</td>
<td></td>
<td>None</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>X^1</td>
<td>None^2</td>
<td>—^3</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>X</td>
<td>Free^4</td>
<td>—</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>X</td>
<td>None</td>
<td>—</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>X</td>
<td>Free</td>
<td>—</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>X</td>
<td>Not free</td>
<td>—</td>
<td>Last MB</td>
<td>Overrun</td>
</tr>
</tbody>
</table>

**FIFO enabled, no match in FIFO is as if FIFO does not exist**

<table>
<thead>
<tr>
<th>RFEN</th>
<th>IRMQ</th>
<th>MRP</th>
<th>Matched in MB</th>
<th>Matched in FIFO</th>
<th>Reception structure</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>None</td>
<td>None^5</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>Free</td>
<td>None</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
<td>None</td>
<td>None</td>
<td>None</td>
<td>Frame lost by no match</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
<td>Free</td>
<td>None</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
<td>Not free</td>
<td>None</td>
<td>Last MB</td>
<td>Overrun</td>
</tr>
</tbody>
</table>

**FIFO enabled, Queue disabled**

<table>
<thead>
<tr>
<th>RFEN</th>
<th>IRMQ</th>
<th>MRP</th>
<th>Matched in MB</th>
<th>Matched in FIFO</th>
<th>Reception structure</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>X</td>
<td>Not full^6</td>
<td>FIFO</td>
<td>Frame lost by FIFO full (FIFO overflow)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>None</td>
<td>Full^7</td>
<td>None</td>
<td>Frame lost by FIFO full (FIFO overflow)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Free</td>
<td>Full</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Not free</td>
<td>Full</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>None</td>
<td>Not full</td>
<td>FIFO</td>
<td>Frame lost by FIFO full (FIFO overflow)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Free</td>
<td>Full</td>
<td>None</td>
<td>Frame lost by FIFO full (FIFO overflow)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Free</td>
<td>X</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Not free</td>
<td>X</td>
<td>First MB</td>
<td></td>
</tr>
</tbody>
</table>

**FIFO enabled, queue enabled**

<table>
<thead>
<tr>
<th>RFEN</th>
<th>IRMQ</th>
<th>MRP</th>
<th>Matched in MB</th>
<th>Matched in FIFO</th>
<th>Reception structure</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>Not full</td>
<td>FIFO</td>
<td>Frame lost by FIFO full (FIFO overflow)</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>None</td>
<td>Full</td>
<td>None</td>
<td>Frame lost by FIFO full (FIFO overflow)</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Free</td>
<td>Full</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Not free</td>
<td>Full</td>
<td>Last MB</td>
<td>Overrun</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>None</td>
<td>Not full</td>
<td>FIFO</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Free</td>
<td>X</td>
<td>First MB</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Not free</td>
<td>Not full</td>
<td>FIFO</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Not free</td>
<td>Full</td>
<td>Last MB</td>
<td>Overrun</td>
</tr>
</tbody>
</table>
1. This is a don't care condition.
2. Matched in MB "None" means that the frame has not matched any MB (free-to-receive or non–free-to-receive).
3. This is a forbidden condition.
4. Matched in MB "Free" means that the frame matched at least one MB free-to-receive regardless of whether it has matched MBs non-free-to-receive.
5. Matched in FIFO "None" means that the frame has not matched any filter in FIFO. It is as if the FIFO didn't exist (CTRL2[RFEN]=0).
6. Matched in FIFO "Not full" means that the frame has matched a FIFO filter and has empty slots to receive it.
7. Matched in FIFO "Full" means that the frame has matched a FIFO filter but couldn't store it because it has no empty slots to receive it.

If a non-safe mailbox inactivation (see Mailbox inactivation) occurs during matching process and the mailbox inactivated is the temporary matching winner, then the temporary matching winner is invalidated. The matching elements scan is not stopped nor restarted—it continues normally. The consequence is that the current matching process works as if the matching elements compared before the inactivation did not exist, therefore a message may be lost.

Suppose, for example, that the FIFO is disabled, IRMQ is enabled, there are two MBs with the same ID, and FlexCAN starts receiving messages with that ID. Let us say that these MBs are the second and the fifth in the array. When the first message arrives, the matching algorithm finds the first match in MB number 2. The code of this MB is EMPTY, so the message is stored there. When the second message arrives, the matching algorithm finds MB number 2 again, but it is not "free-to-receive", so it keeps looking, finds MB number 5 and stores the message there. If yet another message with the same ID arrives, the matching algorithm finds out that there are no matching MBs that are "free-to-receive", so it decides to overwrite the last matched MB, which is number 5. In doing so, it sets the CODE field of the MB to indicate OVERRUN.

The ability to match the same ID in more than one MB can be exploited to implement a reception queue (in addition to the full featured FIFO) to allow more time for the CPU to service the MBs. By programming more than one MB with the same ID, received messages are queued into the MBs. The CPU can examine the Time Stamp field of the MBs to determine the order in which the messages arrived.

Matching to a range of IDs is possible by using ID acceptance masks. FlexCAN supports individual masking per MB (see the description of Rx Individual Mask registers (RXIMR0 - RXIMR63)). During the matching algorithm, if a mask bit is asserted, then the corresponding ID bit is compared. If the mask bit is negated, the corresponding ID bit is a "don't care". Note that the Individual Mask Registers are implemented in RAM, so they are not initialized out of reset. Also, they can only be programmed when the module is in Freeze mode; otherwise, they are blocked by hardware.

FlexCAN also supports an alternate masking scheme with only four mask registers (RXFGMASK, RXMGMASK, RX14MASK, and RX15MASK) for backwards compatibility with legacy applications. This alternate masking scheme is enabled when the IRMQ bit in the MCR register is negated.
45.4.5 Move process

There are two types of move process: move-in and move-out.

45.4.5.1 Move-in

The move-in process is the copy of a message received by an Rx SMB to an Rx mailbox or FIFO that has matched it. If the move destination is the Rx FIFO, attributes of the message are also copied to the CAN_RXFIR FIFO. Each Rx SMB has its own move-in process, but only one is performed at a given time as described ahead. The move-in starts only when the message held by the Rx SMB has a corresponding matching winner (see Matching process) and all of the following conditions are true:

- The CAN bus has either reached or already gone past:
  - The second bit of Intermission field next to the frame that carried the message that is in the Rx SMB.
  - The first bit of an overload frame next to the frame that carried the message that is in the Rx SMB.
- There is no ongoing matching process.
- The destination mailbox is not locked by the CPU.
- There is no ongoing move-in process from another Rx SMB. If more than one move-in process is to be started at the same time, both are performed and the newest substitutes for the oldest.

The term pending move-in is used throughout the documentation and stands for a move-to-be that still does not satisfy all of the aforementioned conditions.

The move-in is cancelled and the Rx SMB is able to receive another message if any of the following conditions is satisfied:

- The destination mailbox is inactivated after the CAN bus has reached the first bit of Intermission field next to the frame that carried the message and its matching process has finished.
- There is a previous pending move-in to the same destination mailbox.
- The Rx SMB is receiving a frame transmitted by the FlexCAN itself and self-reception is disabled (MCR[SRXDIS] is asserted).
- Any CAN protocol error is detected.
Note that the pending move-in is not cancelled if the module enters Freeze or Low-Power mode. It stays on hold, only waiting for Freeze and Low-Power mode to be exited and the module to be unlocked. If an MB is unlocked during Freeze mode, the move-in happens immediately.

The move-in process is the execution by the FlexCAN of the following steps:

1. Push IDHIT into the RXFIR FIFO if the message is destined for the Rx FIFO.
2. Read all data words from the Rx SMB in accordance with the selected payload size for the Rx storage element.
3. Write all data words to the Rx mailbox in accordance with the selected payload size for the Rx storage element. If the data size of the storage element is smaller than the original payload size described in the message's DLC field, the payload is truncated and the high order bytes that do not fit the destination size are lost.
4. Read the Control/Status and ID words from the Rx SMB.
5. Write Control/Status and ID words to the Rx mailbox, and update the CODE field.

The move-in process is not atomic, in such a way that it is immediately cancelled by the inactivation of the destination mailbox (see Mailbox inactivation). In this case the mailbox may remain partially updated, thus incoherent. The exception is if the move-in destination is a Rx FIFO message buffer; then the process cannot be cancelled.

The BUSY Bit (least significant bit of the CODE field) of the destination message buffer is asserted while the move-in is being performed to alert the CPU that the message buffer content is temporarily incoherent.

### 45.4.5.2 Move-out

The move-out process is the copy of the content from a Tx Mailbox to the Tx SMB when a message for transmission is available (see Arbitration process). The move-out occurs in the following conditions:

- The first bit of Intermission field
- During Bus Off state when TX Error Counter is in the 124 to 128 range
- During Bus Idle state
- During Wait For Bus Idle state

The move-out process is not atomic. Only the CPU has priority to access the memory concurrently out of Bus Idle state. In Bus Idle, the move-out has the lowest priority to the concurrent memory accesses.
45.4.6 Data coherence

In order to maintain data coherency and FlexCAN proper operation, the CPU must obey the rules described in Transmit process and Receive process.

45.4.6.1 Transmission abort mechanism

The abort mechanism provides a safe way to request the abort of a pending transmission. A feedback mechanism is provided to inform the CPU if the transmission was aborted or if the frame could not be aborted and was transmitted instead.

Two primary conditions must be fulfilled in order to abort a transmission:

- MCR[AEN] must be asserted.
- The first CPU action must be the writing of abort code (0b1001) into the CODE field of the Control and Status word.

Active MBs configured for transmission must be aborted first before they can be updated. If the abort code is written to a Mailbox that is currently being transmitted or to a Mailbox that was already loaded into the Tx SMB for transmission, the write operation is blocked and the transmission is not disturbed. However, the abort request is captured and kept pending until one of the following conditions is satisfied:

- The module loses the bus arbitration.
- There is an error during the transmission.
- The module is put into Freeze mode.
- The module enters Bus Off state.
- There is an overload frame.

If none of the conditions above are reached:

- The MB is transmitted correctly.
- The interrupt flag is set in the IFLAG register.
- An interrupt to the CPU is generated (if enabled).

The abort request is automatically cleared when the interrupt flag is set. On the other hand, if only one of the above conditions is reached, the frame is not transmitted; therefore:

- The abort code is written into the CODE field.
- The interrupt flag is set in the IFLAG.
- An interrupt is (optionally) generated to the CPU.

If the CPU writes the abort code before the transmission begins internally, then the write operation is not blocked; therefore, the MB is updated and the interrupt flag is set. In this way the CPU only needs to read the abort code to make sure the active MB was safely
inactivated. Although the AEN bit is asserted and the CPU wrote the abort code, in this case the MB is inactivated and not aborted, because the transmission did not start yet. One Mailbox is aborted only when the abort request is captured and kept pending until one of the previous conditions is satisfied.

### 45.4.6.2 Mailbox inactivation

Inactivation is a mechanism provided to protect the mailbox against updates by the FlexCAN internal processes, thus allowing the CPU to rely on mailbox data coherence after having updated it, even in Normal mode.

Inactivation of transmission mailboxes must be performed just when MCR[AEN] is deasserted.

If a mailbox is inactivated, it participates in neither the arbitration process nor the matching process until it is reactivated. See Transmit process and Receive process for more detailed instructions on how to inactivate and reactivate a mailbox.

To inactivate a mailbox, the CPU must update its CODE field to INACTIVE (either 0b0000 or 0b1000).

Because you will not be able to synchronize the CODE field update with the FlexCAN internal processes, an inactivation can have the following consequences:

- A frame in the bus that matches the filtering of the inactivated Rx mailbox may be lost without notice, even if there are other mailboxes with the same filter.
- A frame containing the message within the inactivated Tx mailbox may be transmitted without setting the respective IFLAG.

In order to perform a safe inactivation and avoid the above consequences for Tx mailboxes, the CPU must use the transmission abort mechanism (see Transmission abort mechanism).

The inactivation automatically unlocks the mailbox (see Mailbox lock mechanism).

**NOTE**

Message buffers that are part of the Rx FIFO cannot be inactivated. There is no write protection on the FIFO region by FlexCAN. CPU must maintain data coherency in the FIFO region when RFEN is asserted.
45.4.6.3 Mailbox lock mechanism

Other than mailbox inactivation, FlexCAN has another data coherence mechanism for the receive process. When the CPU reads the Control and Status word of an Rx MB with codes FULL or OVERRUN, FlexCAN assumes that the CPU wants to read the whole MB in an atomic operation, and therefore it sets an internal lock flag for that MB. The lock is released when the CPU reads the free running timer (global unlock operation), or when it reads the Control and Status word of another MB regardless of its code. A CPU write into the C/S word also unlocks the MB, but this procedure is not recommended for normal unlock use because it cancels a pending move and potentially may lose a received message. The MB locking prevents a new frame from being written into the MB while the CPU is reading it.

NOTE

The locking mechanism applies only to Rx MBs that are not part of the FIFO and have a code different than INACTIVE (0b0000) or EMPTY\(^1\) (0b0100). Also, Tx MBs cannot be locked.

Suppose, for example, that the FIFO is disabled and the second and the fifth MBs of the array are programmed with the same ID, and FlexCAN has already received and stored messages into these two MBs. Suppose now that the CPU decides to read MB number 5 and at the same time another message with the same ID is arriving. When the CPU reads the Control and Status word of MB number 5, this MB is locked. The new message arrives and the matching algorithm finds out that there are no free-to-receive MBs, so it decides to override MB number 5. However, this MB is locked, so the new message cannot be written there. It will remain in the Rx SMB waiting for the MB to be unlocked, and only then will be written to the MB.

If the MB is not unlocked in time and yet another new message with the same ID arrives, then the new message overwrites the one on the Rx SMB and there will be no indication of lost messages either in the CODE field of the MB or in the Error and Status Register.

While the message is being moved in from the Rx SMB to the MB, the BUSY bit on the CODE field is asserted. If the CPU reads the Control and Status word and finds out that the BUSY bit is set, it should defer accessing the MB until the BUSY bit is negated.

Note

If the BUSY bit is asserted or if the MB is empty, then reading the Control and Status word does not lock the MB.

---

1. In previous FlexCAN versions, reading the C/S word locked the MB even if it was EMPTY. This behavior is maintained when the IRMQ bit is negated.
Inactivation takes precedence over locking. If the CPU inactivates a locked Rx MB, then its lock status is negated and the MB is marked as invalid for the current matching round. Any pending message on the Rx SMB will not be transferred anymore to the MB. An MB is unlocked when the CPU reads the Free Running Timer Register (see Free Running Timer (TIMER)), or the C/S word of another MB.

Lock and unlock mechanisms have the same functionality in both Normal and Freeze modes.

An unlock during Normal or Freeze mode results in the move-in of the pending message. However, the move-in is postponed if an unlock occurs during a low power mode (see Modes of operation), and it takes place only when the module returns to Normal or Freeze modes.

### 45.4.7 Rx FIFO

The Rx FIFO is receive-only and is enabled by asserting MCR[RFEN]. The reset value of this bit is zero to maintain software backward compatibility with previous versions of the module that did not have the FIFO feature.

**CAUTION**

Rx FIFO must not be enabled when CAN FD feature is enabled.

The FIFO is 6-message deep. The memory region occupied by the FIFO structure (both message buffers and FIFO engine) is described in Rx FIFO structure. The CPU can read the received messages sequentially, in the order they were received, by repeatedly reading a message buffer structure at the output of the FIFO.

IFLAG1[BUF5I] (Frames available in Rx FIFO) is asserted when there is at least one frame available to be read from the FIFO. An interrupt is generated if it is enabled by the corresponding mask bit. Upon receiving the interrupt, the CPU can read the message (accessing the output of the FIFO as a message buffer) and the RXFIR register, and then clear the interrupt. If there are more messages in the FIFO the act of clearing the interrupt updates the output of the FIFO with the next message and updates RXFIR with the attributes of that message, reissuing the interrupt to the CPU. Otherwise, the flag remains negated. The output of the FIFO is valid only while IFLAG1[BUF5I] is asserted.

IFLAG1[BUF6I] (Rx FIFO Warning) is asserted when the number of unread messages within the Rx FIFO is increased to five from four due to the reception of a new one, meaning that the Rx FIFO is almost full. The flag remains asserted until the CPU clears it.
IFLAG1[BUF7I] (Rx FIFO Overflow) is asserted when an incoming message was lost because the Rx FIFO is full. Note that the flag will not be asserted when the Rx FIFO is full and the message was captured by a Mailbox. The flag remains asserted until the CPU clears it.

Clearing one of those three flags does not affect the state of the other two.

An interrupt is generated if an IFLAG bit is asserted and the corresponding mask bit is asserted too.

A powerful filtering scheme is provided to accept only frames intended for the target application, reducing the interrupt servicing workload. The filtering criteria is specified by programming a table of up to 128 32-bit registers, according to CTRL2[RFFN] setting, that can be configured to one of the following formats (see also Rx FIFO structure):

- Format A: 128 IDAFs (extended or standard IDs including IDE and RTR)
- Format B: 256 IDAFs (standard IDs or extended 14-bit ID slices including IDE and RTR)
- Format C: 512 IDAFs (standard or extended 8-bit ID slices)

**Note**
A chosen format is applied to all entries of the filter table. It is not possible to mix formats within the table.

Every frame available in the FIFO has a corresponding IDHIT (Identifier Acceptance Filter Hit Indicator) that can read in the IDHIT field from C/S word, as shown in the Rx FIFO Structure description. Another way the CPU can obtain this information is by accessing the RXFIR register. RXFIR[IDHIT] refers to the message at the output of the FIFO and is valid while the IFLAG1[BUF5I] flag is asserted. The RXFIR register must be read only before clearing the flag, which guarantees that the information refers to the correct frame within the FIFO.

Up to 32 elements of the filter table are individually affected by the Individual Mask Registers (RXIMRx), according to the setting of CTRL2[RFFN], allowing very powerful filtering criteria to be defined. If MCR[IRMQ] is negated, then the FIFO filter table is affected by RXFGMASK.

**NOTE**
For more information about the difference between FD and non-FD regarding this feature, see Table 45-2.
45.4.7.1 Rx FIFO under DMA operation

The receive-only FIFO can support DMA. This feature is enabled by asserting both MCR[RFEN] and MCR[DMA]. The reset value of MCR[DMA] is zero to maintain backward compatibility with previous versions of the module that did not have the DMA feature.

The DMA controller can read the received message by reading a message buffer structure at the FIFO output port at the 0x80-0x8C address range.

When MCR[DMA] is asserted the CPU must not access the FIFO output port address range. Before enabling MCR[DMA], the CPU must service the IFLAGS asserted in the Rx FIFO region. Otherwise, these IFLAGS may show that the FIFO has data to be serviced, and mistakenly generate a DMA request. Before disabling MCR[DMA], the CPU must perform a clear FIFO operation.

IFLAG1[BUF5I] (Frames available in Rx FIFO) is asserted when there is at least one frame available to be read from the FIFO. Consequently a DMA request is generated simultaneously. Upon receiving the request, the DMA controller can read the message (accessing the output of the FIFO as a message buffer). The DMA reading process must end by reading address 0x8C, which clears IFLAG1[BUF5I] and updates both the FIFO output with the next message (if FIFO is not empty) and the RXFIR register with the attributes of the new message. If there are more messages stored in the FIFO, IFLAG1[BUF5I] will be re-asserted and another DMA request is issued. Otherwise, the flag remains negated.

NOTE
RXFIR register contents cannot be read after DMA completes the FIFO read. The IDHIT information is also available in the C/S word at address 0x080 (see Rx FIFO structure.

IFLAG1[BUF6I] and IFLAG1[BUF7I] are not used when the DMA feature is enabled.

When FlexCAN is working with DMA, the CPU does not receive any Rx FIFO interruption and must not clear the related IFLAGS. In addition, the related IMASKs are not used to mask the generation of DMA requests.

NOTE
For more information about the difference between FD and non-FD regarding this feature, see Table 45-2.
45.4.7.2 Clear FIFO operation

When MCR[RFEN] is asserted, the clear FIFO operation is a feature used to empty FIFO contents. With MCR[RFEN] asserted the Clear FIFO occurs when the CPU writes one in IFLAG1[BUF0I]. This operation can only be performed in Freeze mode and is blocked by hardware in other modes. This operation does not clear the FIFO IFLAGs; consequently the CPU must service all FIFO IFLAGs before executing the clear FIFO task.

When Rx FIFO is working with DMA, the clear FIFO operation clears IFLAG1[BUF5I] and the DMA request is canceled.

CAUTION
Clear FIFO operation does not clear IFLAGs, except when MCR[DMA] is asserted; in this case only IFLAG1[BUF5I] is cleared.

45.4.8 CAN protocol related features

This section describes the CAN protocol related features.

45.4.8.1 CAN FD ISO compliance

The CAN FD protocol has been improved to increase the failure detection capability that was in the original CAN FD protocol, which is also called non-ISO CAN FD, by CAN in Automation (CiA). A three-bit stuff counter and a parity bit have been introduced in the improved CAN FD protocol, now called ISO CAN FD. The CRC calculation has also been modified. All these improvements make the ISO CAN FD protocol incompatible with the non-FD CAN FD protocol. The non-ISO CAN FD is still supported by FlexCAN so that it can be used mainly during an intermediate phase, for evaluation and development purposes.

Therefore, it is strongly recommended to configure FlexCAN to the ISO CAN FD protocol by setting the ISOCANFDEN field in the CTRL2 register.

45.4.8.2 CAN FD frames

The ISO 11898-1 standard specifies the Classical Frame format compliant to ISO 11898-1 (2003) and introduces the CAN Flexible Data Rate Frame format. The Classical Frame format allows bit rates up to 1 Mbit/s and payloads up to 8 bytes per frame. The
Flexible Data Rate Frame format allows bit rates higher than 1 Mbit/s and payloads longer than 8 bytes per frame. FlexCAN can receive and transmit CAN FD messages interleaved with Classical CAN messages.

There are three additional control bits in the CAN FD frame. The Extended Data Length (EDL) bit enables a longer data payload with different data length coding. The Bit Rate Switch (BRS) bit decides whether the bit rate is switched inside a CAN FD format frame. The Error State Indicator (ESI) flag is transmitted dominant by error active nodes, and recessive by error passive nodes. There are no Remote Frames (see Remote frames) in the CAN FD format. A message configured to transmit a Remote Frame is always sent out in the Classical CAN format. When an FD frame is received and matches a mailbox, the RTR bit in the receiving message buffer is negated. The RTR bit must be considered in classical frames only.

CAN FD messages may be formatted as long frames where the data field exceeds 8 bytes, and may range from 12 up to 64 bytes. They can also be configured to support bit rate switching, where the control field, the data field, and the CRC field of a CAN frame are transmitted with a higher bit rate than the beginning and the end of the frame. Messages in Classical CAN format are limited to transport a maximum payload of 8 bytes at nominal rate. The following figure illustrates the message formats for Classical and FD frames with either standard or extended ID.
The ability to receive and transmit CAN FD messages is enabled by MCR[FDEN]. Either a recessive R0 bit in CAN frames with 11-bit identifiers or a recessive R1 bit in CAN frames with 29-bit identifiers are decoded as an EDL bit (not a reserved one). A CAN FD frame is recognized by a recessive EDL bit, and a Classical CAN frame is recognized by a dominant EDL bit. The BRS bit specifies whether this frame switches the bit rate in its data phase. A long frame is decoded in accordance with the DLC field value (see DLC definition in Message buffer structure).

CAN FD messages can be transmitted with two different bit rates. The first part of a CAN FD frame, from the Start Of Frame (SOF) bit until the Bit Rate Switch (BRS) bit, also called the arbitration phase, is transmitted with the nominal bit rate based on a set of nominal CAN bit timing configuration values. The second part, from the BRS bit until the CRC Delimiter bit, also named the data phase, is transmitted with the data bit rate.
defined by a second set of CAN data bit timing configuration values. Finally, from the
CRC Delimiter until the Intermission bits, the transmission returns to nominal bit rate. In
CAN FD frames with bit rate switching, the bit timing is changed inside the frame at the
sample point of the BRS bit if this bit is recessive. Before the BRS bit, in the CAN FD
arbitration phase, the nominal CAN bit timing is used as defined by the CBT register
(also by CTRL1 register for backward compatibility). Upon detecting a recessive BRS
bit, the CAN data bit timing is used as defined by the FDCBT register.

**NOTE**

If the length of the time quantum in the nominal bit timing and
the length of the time quantum in the data bit timing are not
identical, a quantization error of up to one time quantum of the
arbitration phase may be present as a phase error. This situation
can occur after the switch from arbitration to data phase and
will last until the next synchronization event. Thus, the length
of the time quantum should be the same in nominal and data bit
timing in order to minimize the chance of error frames on the
CAN bus, and to optimize the clock tolerance in networks that
use FD frames.

FDCTRL[FDRATE] enables the transmission of all frames with bit rate switching if the
BRS bit in the selected Tx MB is set. If FDRATE is negated, the transmission is
performed at nominal rate regardless of the BRS bit value. FDCTRL[FDRATE] can be
written any time but takes effect only for the next message transmitted or received.

The nominal bit timing is resumed at either the sample point of the CRC Delimiter bit or
when an error is detected, whichever occurs first. The following figure describes the
mechanism for entering and leaving the data phase when BRS bit is recessive.
Figure 45-3. Bit rate switching mechanism for CAN FD messages

NOTE
In Classical CAN frames, the CRC delimiter is one single recessive bit. In CAN FD frames, the CRC delimiter may consist of one or two recessive bits. FlexCAN sends only one recessive bit as the CRC delimiter, but it accepts two recessive bits before the edge from recessive to dominant that starts the acknowledge slot. As a receiver, FlexCAN sends its acknowledge bit after the first CRC delimiter bit. In CAN FD frames, FlexCAN accepts a two-bit dominant ACK slot as a valid ACK to compensate for phase shifts between the receivers.
The maximum configurable bit rate in the CAN FD data phase depends on the clock frequency of CAN_PE subblock. For example, with a CAN_PE clock frequency of 40 MHz and the shortest configurable bit time of 5 time quanta, the bit rate in the data phase is 8 Mbit/s.\(^3\)

The value of the ESI bit is determined either by the transmitter's error state at the start of the transmission, if the frame is originated in the FlexCAN node, or by the original transmitting node in case FlexCAN is acting as a gateway for the message. If the transmitter is error passive, ESI is transmitted recessive; otherwise, it is transmitted dominant. The permutations of the relationship between the written value and the transmitted value of the ESI are shown in this table.

<table>
<thead>
<tr>
<th>FlexCAN fault confinement status at start of frame</th>
<th>ESI bit Of Tx MB</th>
<th>Transmitted ESI</th>
</tr>
</thead>
<tbody>
<tr>
<td>Error active</td>
<td>0</td>
<td>0 (Error Active)</td>
</tr>
<tr>
<td>Error passive</td>
<td>0</td>
<td>1 (Error Passive)</td>
</tr>
<tr>
<td>Error active</td>
<td>1</td>
<td>1 (Error Passive)</td>
</tr>
<tr>
<td>Error passive</td>
<td>1</td>
<td>1 (Error Passive)</td>
</tr>
</tbody>
</table>

There are different CRC polynomials for different CAN frame formats. The first polynomial, CRC_15, is used for all frames in Classical CAN format. The second, CRC_17, is used for frames in CAN FD format with a data field up to sixteen bytes long. The third, CRC_21, is used for frames in CAN FD format with a data field longer than sixteen bytes. Each polynomial results in a Hamming distance of 6. At the start of the frame, all three CRC polynomials are calculated concurrently. The CRC sequence to be transmitted is selected by the values of the EDL bit and the DLC bit field. When receiving a message, FlexCAN decodes EDL and DLC to select the adequate CRC polynomial to check for a CRC error.

In CAN FD format frames, stuff bits are included in the bit stream for CRC calculation. In Classical CAN format frames, stuff bits are not included. After the transmission of the last bit relevant to the CRC calculation, the FDCRC register stores the calculated CRC for the transmitted message, with the adequate length in accordance to the type of message, for both CAN FD and non-FD messages. The CRCR register reports a valid CRC for Classical CAN messages only.

In CAN FD format frames, the CAN bit stuffing method is changed for the CRC sequence so that the stuff bits are inserted at fixed positions. When FlexCAN is transmitting a CAN FD frame, a fixed stuff bit is inserted just before the first bit of the CRC sequence, even if the last bits of the preceding field do not fulfill the CAN stuff

---

\(^3\) The frequency used in this example may not be supported on this chip; it is shown only to demonstrate how the maximum configurable bit rate is calculated.
condition. Additional stuff bits are inserted after each fourth bit of the CRC sequence. The value of any fixed stuff bit is the inverse value of its preceding bit. When FlexCAN is receiving a CAN FD frame, it discards the fixed stuff bits from the bit stream for the CRC check. A stuff error is detected if the fixed stuff bit has the same value as its preceding bit.

FlexCAN detects errors in CAN FD frames the same way as in Classical CAN frames. The error counters RXERRCNT and TXERRCNT in the ECR register accumulate the counts of Rx and Tx errors, respectively, for both FD and non-FD frames indiscriminately. There are two extra error counters (RXERRCNT_FAST and TXERRCNT_FAST) that accumulate Rx and Tx errors occurring in the data phase of CAN FD frames with the BRS bit set only. The rules for updating the error counters are the same for both CAN FD and non-FD frames (see ECR register).

Error Flags BITERR1, BITERR0, ACKERR, CRCERR, FRMERR, and STFERR in the ESR1 register report errors in both CAN FD and non-FD frames. They also generate the ERRINT interrupt if CTRL1[ERRMSK] is asserted. The ESR1 register has additional error flags (BITERR1_FAST, BITERR0_FAST, CRCERR_FAST, FRMERR_FAST, and STFERR_FAST) to individually indicate the occurrence of errors in the data phase of CAN FD frames with the BRS bit set. There is no ACKERR detected in the data phase of a CAN FD frame. Fault confinement status reported in ESR1[FLTCONF] is the same for both CAN FD and Classical CAN frames, and is based on RXERRCNT and TXERRCNT error counters only. Information contained in RXERRCNT_FAST and TXERRCNT_FAST counters may be considered as status to help detect the error nature related to the bit rate value.

When FlexCAN is in the data phase, either transmitting or receiving a CAN FD message, and detects an error, it immediately switches back to the arbitration phase and to the nominal rate to start an error flag.

Resynchronization and hard synchronization occur in CAN FD frames in the same way as in Classical CAN ones. Additionally, a hard synchronization is also performed at the recessive to dominant edge from EDL to R0 in CAN FD format frames. FlexCAN does not resynchronize while transmitting in the CAN FD data phase.

### 45.4.8.3 Transceiver delay compensation

The CAN FD protocol allows the transmission and reception of data at a higher bit rate than the nominal rate used in the arbitration phase when the message's BRS bit is set. This feature enables the use of rates up to 8 Mbps.
During the data phase of a CAN FD frame, the transmitter detects a bit error if it cannot receive its own latest transmitted bit at the sample point of that bit. When bit rate switching is enabled (BRS bit is asserted), the length of the CAN bit time in the data phase can become shorter than the transceiver's loop delay, thus impeding the correct comparison between the transmitted bit and the received bit within the current CAN bit time interval.

Note that the TDC process defines a secondary sample point where the transmitted bit is correctly compared with the received bit in order to check for bit errors.

The TDC mechanism can be enabled by FDCTRL[TDCEN] and is effective only during the data phase of FD frames having the BRS bit set. It has no effect either on non-FD frames, or on FD frames transmitted at normal bit rate. The TDC is active from the sample point of the BRS bit until the sample point of the CRC Delimiter bit, provided the respective message under transmission has the BRS bit set. When it is active, a comparison is done between the real received bit and the delayed transmitted bit, where the delay is calculated based on the measured transceiver loop delay.

**NOTE**

The actual value of the CRC Delimiter bit is disregarded by transmitters using the transceiver delay compensation mechanism. A global error at the end of the CRC field will cause the receivers to send error frames that the transmitter will detect during Acknowledge or End of Frame.

For every transmitted FD frame having the BRS bit set, the delay measurement is triggered by the transition from the recessive EDL bit to the dominant R0 bit (as shown in the next figure). The loop delay is measured in Protocol Engine (PE) clock periods (CANCLK, see Protocol timing), from the transmitted EDL-R0 edge to the received EDL-R0 edge. The position of the secondary sample point is defined by the measured loop delay time added to an offset value specified in FDCTRL[TDCOFF]. FDCTRL[TDCVAL] stores the result of this calculation. The TDCVAL value saturates at its maximum value of 63 CANCLK when the delay measurement is too long.
The measured loop delay is not enough to be used to define the secondary sample point because it relates to the CAN bit edges. The transceiver delay compensation offset TDCOFF is used to shift the secondary sample point from the edge to an intermediate point inside the bit time, far away from its edges. Therefore, the TDCOFF value cannot be larger than the CAN bit duration in the data phase.

If the secondary sample point is set very near the CAN bit edge (SYNC field), then problems may occur during the bit sampling in the data phase. For the TDC to work reliably, the offset has to use optimal settings. To be sure the bit sampling is performed in the best region, the TDC offset should be configured as shown in this equation:

\[
\text{Offset} = (\text{FPSEG1} + \text{FPROPSEG} + 2) \times (\text{FPRESDIV} + 1)
\]

The following figure shows the SSP position when these settings are used.

During the data phase of CAN FD frames with bit rate switching enabled, at the onset of every Tx CAN bit, the transmitted Tx bit value is temporarily stored in a buffer and a time countdown based on FDCTRL[TDCVAL] is started which ends with the comparison of the received Rx bit (delayed by the external loop delay plus the specified offset) with the stored Tx bit. If a bit error is detected at the secondary sample point, the FlexCAN issues an error flag to the CAN bus at the next sample point.
During the arbitration phase the delay compensation is always disabled. The maximum delay which can be compensated by the FlexCAN's transceiver delay compensation during the data phase is 3 CAN bit times – 2 Tq. Beyond this limit, the FDCTRL[TDCFAIL] flag is set to indicate when the transceiver delay compensation mechanism is out of range, unable to compensate the transceiver loop delay.

### 45.4.8.4 Remote frames

A remote frame is a special kind of frame. You can program a mailbox to be a remote request frame by configuring the mailbox as Transmit with the RTR bit set to one. After the remote request frame is transmitted successfully, the mailbox becomes a receive message buffer, with the same ID as before.

When a remote request frame is received by FlexCAN, it can be treated in three ways, depending on remote request storing (CTRL2[RRS]) and Rx FIFO Enable (MCR[RFEN]):

- If RRS is negated the frame's ID is compared to the IDs of the transmit message buffers with the CODE field 0b1010. If there is a matching ID, then this mailbox frame will be transmitted. Note that if the matching mailbox has the RTR bit set, then FlexCAN will transmit a remote frame as a response. The received remote request frame is not stored in a receive buffer. It is only used to trigger a transmission of a frame in response. The mask registers are not used in remote frame matching, and all ID bits (except RTR) of the incoming received frame should match. In the case that a remote request frame is received and matches a mailbox, this message buffer immediately enters the internal arbitration process, but is considered as a normal Tx mailbox, with no higher priority. The data length of this frame is independent of the DLC field in the remote frame that initiated its transmission.

- If RRS is asserted the frame's ID is compared to the IDs of the receive mailboxes with the CODE field 0b0100, 0b0010, or 0b0110. If there is a matching ID, then this mailbox will store the remote frame in the same fashion of a data frame. No automatic remote response frame will be generated. The mask registers are used in the matching process.

- If RFEN is asserted FlexCAN will not generate an automatic response for remote request frames that match the FIFO filtering criteria. If the remote frame matches one of the target IDs, it will be stored in the FIFO and presented to the CPU. Note that for filtering formats A and B, it is possible to select whether remote frames are accepted or not. For format C, remote frames are always accepted (if they match the ID). Remote request frames are considered as normal frames, and generate a FIFO overflow when a successful reception occurs and the FIFO is already full.
NOTE
There is no remote frame in the CAN FD format. The RTR bit is replaced by a fixed dominant RRS bit. FlexCAN receives and transmits remote frames in the Classical CAN format.

45.4.8.5 Overload frames
FlexCAN does transmit overload frames when the following conditions are detected on the CAN bus:

- Detection of a dominant bit in the first/second bit of Intermission
- Detection of a dominant bit at the 7th bit (last) of End of Frame field (Rx frames)
- Detection of a dominant bit at the 8th bit (last) of Error Frame Delimiter or Overload Frame Delimiter

45.4.8.6 Time stamp
The value of the free running timer is sampled at the beginning of the Identifier field on the CAN bus, and is stored at the end of move-in in the TIME STAMP field, providing network behavior with respect to time.

When CTRL2[TIMER_SRC] is asserted, the free running timer is continuously clocked by an external time tick.

When CTRL2[TIMER_SRC] is negated, the free running timer is clocked by the FlexCAN bit-clock, which defines the baud rate on the CAN bus. During a message transmission/reception, it increments by one for each bit that is received or transmitted. When there is no message on the bus, it counts using the previously programmed baud rate.

The free running timer is not incremented during Disable, Doze, Stop, and Freeze modes. It can be reset upon a specific frame reception, enabling network time synchronization. See the TSYN description in Control 1 register (CTRL1).
45.4.8.7 Protocol timing

The following figure shows the structure of the clock generation circuitry that feeds the CAN Protocol Engine (PE) submodule. The clock source field CTRL1[CLKSRC] defines whether the internal clock is connected to the output of a crystal oscillator (oscillator clock) or to the peripheral clock. In order to guarantee reliable operation, the clock source should be selected when the module is in Disable mode (MCR[MDIS] is set).

NOTE

Please see the clock distribution chapter (module clocks table) to identify the proper clock source.

![Figure 45-6. CAN engine clocking scheme](image)

The oscillator clock should be selected whenever a tight tolerance (up to 0.1%) is required in the CAN bus timing. The crystal oscillator clock has better jitter performance than the peripheral clock.

The FlexCAN module supports a variety of means to set up bit timing parameters that are required by the CAN protocol. The Control 1 register (CTRL1) has various fields used to control bit timing parameters: PRESDIV, PROPSEG, PSEG1, PSEG2, and RJW.

The CAN Bit Timing register (CBT) extends the range of the CAN bit timing variables in CTRL1. The CAN FD Bit Timing register (FDCBT) provides a second set of CAN bit timing variables to be applied at the data phase of CAN FD frames with the Bit Rate Switch (BRS) set.

NOTE

When the CAN FD feature is enabled, always set CBT[BTF] and configure the CAN bit timing variables in CBT. See CAN Bit Timing register (CBT).

The PRESDIV field (as well as its extended range EPRESDIV and FDPRESDIV for the data phase bits of CAN FD messages) defines the prescaler value (see the equation below) that generates the serial clock (Sclock), whose period defines the time quantum used to compose the CAN waveform. A time quantum (Tq) is the atomic unit of time managed by the CAN engine.
The bit rate, which defines the rate the CAN message is either received or transmitted, is given by the formula:

\[ \text{Bit Rate} = \frac{1}{\text{CAN Bit Time}} \]

\[ \text{CAN Bit Time} = (\text{Number of Time Quanta in 1 bit time}) \times T_q \]

A bit time is subdivided into three segments\(^1\) (see Figure 45-7, Figure 45-8 and Table 45-9):

- **SYNC SEG**: This segment has a fixed length of one time quantum. Signal edges are expected to happen within this section.

- **Time Segment 1**: This segment includes the propagation segment and the phase segment 1 of the CAN standard. It can be programmed by setting \(\text{CTRL1[PROPSEG]}\) and \(\text{CTRL1[PSEG1]}\) so that their sum (plus 2) is in the range of 2 to 16 time quanta. When \(\text{CBT[BTF]}\) is asserted, FlexCAN uses \(\text{EPROPSEG}\) and \(\text{EPSEG1}\) fields from \(\text{CBT}\) register so that their sum (plus 2) is in the range of 2 to 96 time quanta. For messages in CAN FD format with the BRS bit set, FlexCAN uses \(\text{FDPROPSEG}\) and \(\text{FDPSEG1}\) from \(\text{FDCBT}\) instead, so that their sum (plus 1) is in the range of 2 to 39 time quanta.

- **Time Segment 2**: This segment represents the phase segment 2 of the CAN standard. It can be programmed by setting \(\text{CTRL1[PSEG2]}\) (plus 1) to be 2 to 8 time quanta long. When \(\text{CBT[BTF]}\) is asserted, FlexCAN uses \(\text{EPSEG2}\) fields of \(\text{CBT}\) register so that its value (plus 1) is in the range of 2 to 32 time quanta. For messages in CAN FD format with the BRS bit set, FlexCAN uses \(\text{FDPSEG2}\) from \(\text{FDCBT}\) instead, so that its value (plus 1) is in the range of 2 to 8 time quanta. The time segment 2 cannot be smaller than the Information Processing Time (IPT), which value is 2 time quanta in FlexCAN.

**NOTE**

The bit time defined by the above time segments must not be smaller than five time quanta. For bit time calculations, use an Information Processing Time (IPT) of two, which is the value implemented in the FlexCAN module.

---

\(^1\) For further explanation of the underlying concepts, see ISO 11898-1. See also the CAN 2.0A/B protocol specification for bit timing.
Figure 45-7. Segments within the bit time (example using CTRL1 bit timing variables for Classical CAN format)
Figure 45-8. Segments within the bit time (example using CBT and FDCBT bit timing variables for CAN FD format)

Table 45-9. Time segment syntax

<table>
<thead>
<tr>
<th>Syntax</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SYNC_SEG</td>
<td>System expects transitions to occur on the bus during this period.</td>
</tr>
<tr>
<td>TSEG1</td>
<td>Corresponds to the sum of PROPSEG and PSEG1.</td>
</tr>
<tr>
<td>TSEG2</td>
<td>Corresponds to the PSEG2 value.</td>
</tr>
<tr>
<td>Transmit point</td>
<td>A node in transmit mode transfers a new value to the CAN bus at this point.</td>
</tr>
<tr>
<td>Sample point</td>
<td>A node samples the bus at this point. If the three samples per bit option is selected, then this point marks the position of the third sample.</td>
</tr>
</tbody>
</table>

The following table gives some examples of the CAN compliant segment settings for Classical CAN format (Bosch CAN 2.0B) (non-FD) messages.
Table 45-10. Bosch CAN 2.0B standard compliant bit time segment settings

<table>
<thead>
<tr>
<th>Time segment 1</th>
<th>Time segment 2</th>
<th>Re-synchronization jump width</th>
</tr>
</thead>
<tbody>
<tr>
<td>5 .. 10</td>
<td>2</td>
<td>1 .. 2</td>
</tr>
<tr>
<td>4 .. 11</td>
<td>3</td>
<td>1 .. 3</td>
</tr>
<tr>
<td>5 .. 12</td>
<td>4</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>6 .. 13</td>
<td>5</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>7 .. 14</td>
<td>6</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>8 .. 15</td>
<td>7</td>
<td>1 .. 4</td>
</tr>
<tr>
<td>9 .. 16</td>
<td>8</td>
<td>1 .. 4</td>
</tr>
</tbody>
</table>

Note

The user must ensure the bit time settings are in compliance with the CAN Protocol standard (ISO 11898-1).

Whenever CAN bit is used as a measure of time duration (for example, estimating the occurrence of a CAN bit event in a message), the number of peripheral clocks in one CAN bit (NumClkBit) can be calculated as:

\[
\text{NumClkBit} = \frac{f_{\text{SYS}}}{f_{\text{CANCLK}}} \times (\text{PRESDIV} + 1) \times (\text{PROPSEG} + \text{PSEG1} + \text{PSEG2} + 4)
\]

where:

- \( \text{NumClkBit} \) is the number of peripheral clocks in one CAN bit.
- \( f_{\text{CANCLK}} \) is the Protocol Engine (PE) Clock (see Figure 45-6), in Hz.
- \( f_{\text{SYS}} \) is the frequency of operation of the system (CHI) clock, in Hz.
- \( \text{PSEG1} \) is the value in CTRL1[PSEG1] field.
- \( \text{PSEG2} \) is the value in CTRL1[PSEG2] field.
- \( \text{PROPSEG} \) is the value in CTRL1[PROPSEG] field.
- \( \text{PRESDIV} \) is the value in CTRL1[PRESDIV] field.

The formula above is also applicable to the alternative CAN bit timing variables described in the CAN Bit Timing register (CBT) and also to the CAN FD Bit Timing register (FDCBT).

For example, 180 CAN bits = (180 x NumClkBit) peripheral clock periods.

45.4.8.8 Arbitration and matching timing

During normal reception and transmission, the matching, arbitration, move-in, and move-out processes are executed during certain time windows inside the CAN frame, as shown in the following figures.
NOTE
In the preceding figures, the matching and arbitration timing does not take into account the delay caused by the concurrent memory access due to the CPU or other internal FlexCAN subblocks.

45.4.8.9  Tx arbitration start delay
CTRL2[TASD] (Tx Arbitration Start Delay) is a variable that indicates the number of CAN bits used by FlexCAN to delay the Tx arbitration process start point from the first bit of CRC field of the current frame. This variable can be written only in Freeze mode because it is blocked by hardware in other modes.

The transmission performance is impacted by the ability of the CPU to reconfigure message buffers (MBs) for transmission after the end of the internal arbitration process, where FlexCAN finds the winner MB for transmission (see Arbitration process). If the
arbitration ends too early before the first bit of Intermission field, then there is a chance that the CPU reconfigures some Tx MBs and the winner MB is no longer the best candidate to be transmitted.

TASD is useful to optimize the transmission performance by defining the arbitration start point, as shown in the next figure, based on factors such as:

- Peripheral-to-oscillator clock ratio
- CAN bit timing variables that determine the CAN bit rate
- Number of message buffers (MBs) in use by the matching and arbitration processes

![Diagram of arbitration process](image)

**Figure 45-12. Optimal Tx Arbitration start point**

The duration of an arbitration process, in terms of CAN bits, is directly proportional to the number of available MBs and to the CAN bit rate, and inversely proportional to the peripheral clock frequency.

The optimal arbitration timing is that in which the last MB is scanned just before the first bit of the Intermission field of a CAN frame. For instance, if there are few MBs and the peripheral/oscillator clock ratio is high and the CAN baud rate is low, then the arbitration can be placed closer to the frame's end, adding more delay to its start point, and vice-versa.

If TASD is set to 0 then the arbitration start is not delayed and more time is reserved for arbitration. On the other hand, if TASD is close to 24 then the CPU can configure a Tx MB later and less time is reserved for arbitration. If too little time is reserved for arbitration the FlexCAN may be not be able to find a winner MB in time to be transmitted with the best chance to win the bus arbitration against external nodes on the CAN bus.

The optimal TASD value can be calculated as follows:
For CAN FD frames and \((\text{MAXMB} + 1) \leq \text{NMB}_{\text{END}}\)

\[
\text{TASD} = 31 - \frac{2 \times (\text{MAXMB} + 1) + 4}{\text{CPCB}_N}
\]

For CAN FD frames and \((\text{MAXMB} + 1) > \text{NMB}_{\text{END}}\)

\[
\text{TASD} = 22 - \frac{2 \times (\text{MAXMB} + 1) - \text{NMB}_{\text{END}}}{\text{CPCB}_F}
\]

For non-FD frames

\[
\text{TASD} = 25 - \frac{2 \times (\text{MAXMB} + 1) + 4}{\text{CPCB}}
\]

where:

\[
\text{NMB}_{\text{END}} = \frac{(9 \times \text{CPCB}_N) - 4}{2}
\]

\[
\text{BITRATE}_N = \left( \frac{\text{f}_{\text{CANCLK}}}{[1 + (\text{EPSEG1} + 1) + (\text{EPSEG2} + 1) + (\text{EPROPSEG} + 1)] \times (\text{EPRESDIV} + 1)} \right)
\]

\[
\text{BITRATE}_F = \left( \frac{\text{f}_{\text{CANCLK}}}{[1 + (\text{FPSEG1} + 1) + (\text{FPSEG2} + 1) + \text{FPROPSEG}] \times (\text{FPRESDIV} + 1)} \right)
\]

\[
\text{CPCB}_N = \frac{\text{f}_{\text{SYS}}}{\text{BITRATE}_N}
\]

\[
\text{CPCB}_F = \frac{\text{f}_{\text{SYS}}}{\text{BITRATE}_F}
\]

\[
\text{CPCB} = \text{CPCB}_N
\]

- MAXMB is the value in \text{CTRL1}[MAXMB].
- \text{NMB}_{\text{END}} is the number of message buffers that can be scanned by the arbitration process during the 9 last CAN bits at the end of a frame (see the figure above).
- \text{BITRATE}_N is the CAN bit rate in bits per second calculated by the nominal CAN bit time variables.
- \text{BITRATE}_F is the CAN bit rate in bits per second calculated by the data CAN bit time variables.
- \text{CPCB}_N is the number of peripheral clocks per CAN bit in nominal bit rate for CAN FD frames.
- \text{CPCB}_F is the number of peripheral clocks per CAN bit in data bit rate for CAN FD frames.
- CPCB is the number of peripheral clocks per CAN bit for non-FD frames.
- \text{f}_{\text{CANCLK}} is the oscillator clock, in Hz.
- \text{f}_{\text{SYS}} is the peripheral clock, in Hz.
- \text{EPSEG1} is the value in \text{CBT}[\text{EPSEG1}] (\text{CTRL1}[\text{PSEG1}] can also be used).
- \text{EPSEG2} is the value in \text{CBT}[\text{EPSEG2}] (\text{CTRL1}[\text{PSEG2}] can also be used).
• EPROPSEG is the value in CBT[EPROPSEG] (CTRL1[PROPSEG] can also be used).
• EPRESDIV is the value in CBT[EPRESDIV] (CTRL1[PRESDIV] can also be used).
• FPSEG1 is the value in FDCBT[FPSEG1].
• FPSEG2 is the value in FDCBT[FPSEG2].
• FPROPSEG is the value in FDCBT[FPROPSEG].
• FPRESDIV is the value in FDCBT[FPRESDIV].

See also Protocol timing for more details.

The following tables give the TASD value calculated for some configuration cases.

Case 1:
• Clock ratio = 2:1 (example: peripheral clock 80 MHz and oscillator clock 40 MHz)
• Bit rate in arbitration phase = 1 Mbaud

<table>
<thead>
<tr>
<th>Number of message buffers</th>
<th>TASD value</th>
<th>Maximum bit rate in data phase (MBd)</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>24</td>
<td>Invalid</td>
</tr>
<tr>
<td>32</td>
<td>24</td>
<td>8.0</td>
</tr>
<tr>
<td>64</td>
<td>23</td>
<td>8.0</td>
</tr>
</tbody>
</table>

Case 2:
• Clock ratio = 1:1 (example: peripheral clock 40 MHz and oscillator clock 40 MHz)
• Bit rate in arbitration phase = 1 Mbaud

<table>
<thead>
<tr>
<th>Number of message buffers</th>
<th>TASD value</th>
<th>Maximum bit rate in data phase (MBd)</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>24</td>
<td>Invalid</td>
</tr>
<tr>
<td>32</td>
<td>23</td>
<td>6.67</td>
</tr>
<tr>
<td>54</td>
<td>22</td>
<td>5.0</td>
</tr>
<tr>
<td>64</td>
<td>21</td>
<td>3.33</td>
</tr>
</tbody>
</table>

Case 3:
• Clock ratio = 2:1 (example: peripheral clock 40 MHz and oscillator clock 20 MHz)
• Bit rate in arbitration phase = 1 Mbaud
Table 45-13. TASD values:

<table>
<thead>
<tr>
<th>Number of message buffers</th>
<th>TASD value</th>
<th>Maximum bit rate in data phase (MBd)</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>24</td>
<td>Invalid</td>
</tr>
<tr>
<td>32</td>
<td>23</td>
<td>4.0</td>
</tr>
<tr>
<td>54</td>
<td>22</td>
<td>4.0</td>
</tr>
<tr>
<td>64</td>
<td>21</td>
<td>3.33</td>
</tr>
</tbody>
</table>

45.4.9 Clock domains and restrictions

The FlexCAN module has two clock domains asynchronous to each other:

- The bus domain feeds the Control Host Interface (CHI) submodule and is derived from the peripheral clock.
- The oscillator domain feeds the CAN Protocol Engine (PE) submodule and is derived directly from a crystal oscillator clock, so that very low jitter performance can be achieved on the CAN bus.

When CTRL1[CLKSRC] is set, synchronous operation occurs because both domains are connected to the peripheral clock (creating a 1:1 ratio between the peripheral and oscillator clocks).

When the two domains are connected to clocks with different frequencies and/or phases, there are restrictions on the frequency relationship between the two clock domains. In the case of asynchronous operation, the bus domain clock frequency must always be greater than the oscillator domain clock frequency.

NOTE
Asynchronous operation with a 1:1 ratio between peripheral and oscillator clocks is not allowed.

When doing matching and arbitration, FlexCAN needs to scan the whole message buffer memory during the time slot of one CAN frame, comprised of a number of CAN bits. In order to have sufficient time to do that, the following requirements must be observed:

- The peripheral clock frequency cannot be smaller than the oscillator clock frequency.
- There must be a minimum number of peripheral clocks per CAN bit, as specified in the table shown below.
### Table 45-14. Minimum number of peripheral clocks per CAN bit for Classical CAN format

<table>
<thead>
<tr>
<th>Number of mailboxes</th>
<th>Value of MCR[RFEN]</th>
<th>Minimum number of peripheral clocks per CAN bit</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>0</td>
<td>16</td>
</tr>
<tr>
<td>32</td>
<td>0</td>
<td>16</td>
</tr>
<tr>
<td>64</td>
<td>0</td>
<td>25</td>
</tr>
<tr>
<td>16</td>
<td>1</td>
<td>25</td>
</tr>
<tr>
<td>32</td>
<td>1</td>
<td>17</td>
</tr>
<tr>
<td>64</td>
<td>1</td>
<td>30</td>
</tr>
</tbody>
</table>

For classical frame format, the minimum number of peripheral clocks per CAN bit specified in the preceding table determines the minimum peripheral clock frequency for a given number of mailboxes and for an expected CAN bit rate. The CAN bit rate depends on the number of time quanta in a CAN bit, which can be defined by adjusting one or more of the bit timing values contained in either the Control 1 register (CTRL1) or CAN Bit Time register (CBT). The time quantum (Tq) is defined in Protocol timing. The minimum number of time quanta per CAN bit must be 8; therefore, the oscillator clock frequency should be at least 8 times the CAN bit rate.

For CAN FD frame format, there are some constraints that need to be satisfied. The number of peripheral clocks per CAN bit in nominal bit rate (NumClkNomBit) can be calculated by the equation below.

\[
\text{NumClkNomBit} = \frac{f_{\text{SYS}}}{f_{\text{CANCLK}}} \times (\text{PRESDIV} + 1) \times (\text{PROPSEG} + \text{PSEG1} + \text{PSEG2} + 4)
\]

where PRESDIV, PSEG1, and PSEG2 are CAN bit time values in CTRL1 register. Alternatively, EPRESDIV, EPSEG1, and EPSEG2 values in CBT register can be used instead. NumClkNomBit can also be calculated as a function of the expected nominal bit rate used in the arbitration phase (NomBitRate), as shown in the equation above.

The number of CAN bits in the data phase of an FD frame with the BRS bit set (fast CAN bits, in short) depends on the number of data bytes in the payload. The number of fast CAN bits (NumOfFastBits) can be determined in the table below. The fewer the number of data bytes, the fewer the number of fast CAN bits, and less time is available for FlexCAN to scan the whole message buffer memory during the internal matching and arbitration processes.
Table 45-15. Number of fast CAN bits in a CAN FD frame

<table>
<thead>
<tr>
<th>Minimum number of data bytes</th>
<th>DLC field</th>
<th>NumOfFastBits</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0x0</td>
<td>21</td>
</tr>
<tr>
<td>1</td>
<td>0x1</td>
<td>29</td>
</tr>
<tr>
<td>2</td>
<td>0x2</td>
<td>37</td>
</tr>
<tr>
<td>3</td>
<td>0x3</td>
<td>45</td>
</tr>
<tr>
<td>4</td>
<td>0x4</td>
<td>53</td>
</tr>
<tr>
<td>5</td>
<td>0x5</td>
<td>61</td>
</tr>
<tr>
<td>6</td>
<td>0x6</td>
<td>69</td>
</tr>
<tr>
<td>7</td>
<td>0x7</td>
<td>77</td>
</tr>
<tr>
<td>8</td>
<td>0x8</td>
<td>85</td>
</tr>
<tr>
<td>12</td>
<td>0x9</td>
<td>117</td>
</tr>
<tr>
<td>16</td>
<td>0xA</td>
<td>149</td>
</tr>
<tr>
<td>20</td>
<td>0xB</td>
<td>186</td>
</tr>
<tr>
<td>24</td>
<td>0xC</td>
<td>218</td>
</tr>
<tr>
<td>32</td>
<td>0xD</td>
<td>282</td>
</tr>
<tr>
<td>48</td>
<td>0xE</td>
<td>410</td>
</tr>
<tr>
<td>64</td>
<td>0xF</td>
<td>538</td>
</tr>
</tbody>
</table>

The critical part of a CAN FD frame is during the data phase, where the CAN bit rate is faster than in the arbitration phase. The minimum number of peripheral clocks per fast CAN bit (MinNumClkFastBit) can be calculated to guarantee that enough time is available for FlexCAN to scan the message buffer memory during reception and transmission. The equation below calculates this constraint.

\[
\text{MinNumClkFastBit}_A = \frac{(8.5 \times \text{MaxNumOfMb}) + 64 - (9 \times \text{NumClkNomBit})}{\text{NumOfFastBits}}
\]

where MaxNumOfMb is the maximum number of available mailboxes defined in MCR[MAXMB].

The clock domain crossing circuit between the CHI and PE subblocks also imposes a minimum number of peripheral clocks per fast CAN bit for the handshake mechanism to work properly without losing status information through the interface, as shown in the equation below.

\[
\text{MinNumClkFastBit}_B = 3 \times \left(1 + \frac{f_{\text{SYS}}}{f_{\text{CANCLK}}}\right)
\]

Therefore, the minimum number of peripheral clocks per fast CAN bit (MinNumClkFastBit) is determined by the larger of the two values calculated above.
Then, the maximum CAN bit rate in the data phase of CAN FD frames (\(\text{DataBitRateMAX}\)) can be calculated as below.

\[
\text{DataBitrate}_{\text{MAX}} = \frac{f_{\text{CANCLK}}}{\text{ROUNDUP} \left( \frac{\text{MinNumClkFastBit} \times f_{\text{CANCLK}}}{f_{\text{SYS}}} \right)}
\]

The peripheral and oscillator clock frequencies, the maximum number of mailboxes, and the expected nominal bit rate affect the maximum data bit rate attainable by FlexCAN in CAN FD mode. Also, the data bit rate depends on the minimum payload size of FD frames used in a given application.

To illustrate how the CAN FD bit rate is affected by the configuration of FlexCAN variables, an application example with the peripheral and oscillator clock frequencies set to 50 MHz and 40 MHz, respectively, is considered.

1. Considering the nominal bit rate as 1 Mbps, the number of peripheral clocks per CAN bit in nominal bit rate is calculated as below.

\[
\text{NumClkNomBit} = \frac{50 \times 10^6}{1 \times 10^6} = 50
\]

2. The number of fast CAN bits (\(\text{NumOfFastBits}\)) is determined in the table presented above. For example, if the minimum payload in FD frames is 8 bytes, then there are 85 CAN bits in the data phase.

3. Assuming the maximum number of mailboxes is 96, the minimum number of peripheral clocks per fast CAN bit (\(\text{MinNumClkFastBit}\)) can be calculated.

\[
\text{MinNumClkFastBit}_A = \frac{(8.5 \times 96) + 64 - (9 \times 50)}{85} = 5.06
\]

\[
\text{MinNumClkFastBit}_B = 3 \times \left( 1 + \frac{50}{40} \right) = 6.75
\]

\[
\text{MinNumClkFastBit} = \text{Maximum} (5.06, 6.75) = 6.75
\]

4. The maximum CAN bit rate in the data phase can finally be found.

\[
\text{DataBitRate}_{\text{MAX}} = \frac{40 \times 10^6}{\text{ROUNDUP} \left( \frac{6.75 \times 40 \times 10^6}{50 \times 10^6} \right)} = 6.667 \text{ Mbps}
\]
As demonstrated in this example, even though the oscillator clock frequency (40 MHz) is adequate to generate a data rate of 8 Mbps in CAN FD mode, the specific FlexCAN configuration limits this rate to 6.667 Mbps. This limitation is mainly due to the low peripheral clock frequency that imposes the MinNumClkFastBitB bound.

The table below shows the maximum data rate for CAN FD according to clock frequencies, payload size, and number of available mailboxes. See in this table that, for some cases, if the number of available mailboxes is reduced, the FlexCAN can then achieve a data rate up to 8 Mbps.

**Table 45-16. Maximum CAN bit rate in data phase on CAN FD frames**

<table>
<thead>
<tr>
<th>Peripheral clock frequency (MHz)</th>
<th>Payload size</th>
<th>Number of available mailboxes</th>
<th>Maximum data rate (Mbps)</th>
</tr>
</thead>
<tbody>
<tr>
<td>40</td>
<td>8</td>
<td>94</td>
<td>6.667</td>
</tr>
<tr>
<td>40</td>
<td>8</td>
<td>114</td>
<td>5.0</td>
</tr>
<tr>
<td>40</td>
<td>12</td>
<td>117</td>
<td>6.667</td>
</tr>
<tr>
<td>40</td>
<td>12</td>
<td>128</td>
<td>5.714</td>
</tr>
<tr>
<td>50</td>
<td>12 to 64</td>
<td>128</td>
<td>6.667</td>
</tr>
<tr>
<td>60</td>
<td>8</td>
<td>126</td>
<td>8.0</td>
</tr>
<tr>
<td>60</td>
<td>12</td>
<td>128</td>
<td>8.0</td>
</tr>
<tr>
<td>67</td>
<td>6</td>
<td>128</td>
<td>8.0</td>
</tr>
<tr>
<td>80</td>
<td>3</td>
<td>128</td>
<td>8.0</td>
</tr>
<tr>
<td>100</td>
<td>0</td>
<td>128</td>
<td>8.0</td>
</tr>
</tbody>
</table>

**45.4.10 Modes of operation details**

The FlexCAN module has functional modes and low-power modes. See *Modes of operation* for an introductory description of all the modes of operation. The following sub-sections contain functional details on Freeze mode and the low-power modes.

**CAUTION**

"Permanent Dominant" failure on CAN Bus line is not supported by FlexCAN. If a Low-Power request or Freeze mode request is done during a "Permanent Dominant", the corresponding acknowledge can never be asserted.
Freeze mode

This mode is requested either by the CPU through the assertion of MCR[HALT] or when the chip is put into Debug mode. In both cases it is also necessary that MCR[FRZ] be asserted and the module not be in a low-power mode.

The acknowledgement is obtained through the assertion by the FlexCAN of MECR[FRZ_ACK]. The CPU must only consider the FlexCAN in Freeze mode when both request and acknowledgement conditions are satisfied.

When Freeze mode is requested, FlexCAN does the following:

- Waits to be in either Intermission, Passive Error, Bus Off, or Idle state.
- Waits for all internal activities like arbitration, matching, move-in, and move-out to finish. A pending move-in does not prevent entering Freeze mode.
- Ignores the Rx input pin and drives the Tx pin as recessive.
- Stops the prescaler, thus halting all CAN protocol activities.
- Grants write access to the Error Counters register, which is read-only in other modes.
- Sets MCR[NOTRDY] and MCR[FRZACK].

After requesting Freeze mode, the user must wait for MCR[FRZ_ACK] to be asserted before executing any other action; otherwise FlexCAN may operate in an unpredictable way. In Freeze mode, all memory-mapped registers are accessible, except for CTRL1[CLKSRC], which can be read but cannot be written.

Exiting Freeze mode is done in one of the following ways:

- CPU negates MCR[FRZ].
- The chip is removed from Debug mode and/or the HALT bit is negated.

MCR[FRZ_ACK] is negated after the protocol engine recognizes the negation of the freeze request. When out of Freeze mode, FlexCAN tries to resynchronize to the CAN bus by waiting for 11 consecutive recessive bits.
45.4.10.2 Module Disable mode

This low-power mode is normally used to temporarily disable a complete FlexCAN block, with no power consumption. It is requested by the CPU through the assertion of MCR[MDIS], and the acknowledgement is obtained through the assertion by the FlexCAN of MCR[LPMACK]. The CPU must only consider the FlexCAN in Disable mode when both request and acknowledgement conditions are satisfied.

If the module is disabled during Freeze mode, it requests to disable the clocks to the PE and CHI submodules, sets MCR[LPMACK] and negates MCR[FRZACK].

If the module is disabled during transmission or reception, FlexCAN does the following:

- Waits to be in either Idle or Bus Off state, or else waits for the third bit of Intermission and then checks it to be recessive.
- Waits for all internal activities like arbitration, matching, move-in, and move-out to finish. A pending move-in is not taken into account.
- Ignores its Rx input pin and drives its Tx pin as recessive.
- Shuts down the clocks to the PE and CHI submodules
- Sets MCR[NOTRDY] and MCR[LPMACK].

The Bus Interface Unit continues to operate, enabling the CPU to access memory-mapped registers, except the Rx Mailboxes Global Mask registers, the Rx Buffer 14 Mask register, the Rx Buffer 15 Mask register, the Rx FIFO Global Mask register. The Rx FIFO Information register, the message buffers, the Rx Individual Mask registers, and the reserved words within RAM may not be accessed when the module is in Disable mode. Exiting from this mode is done by negating the MDIS bit by the CPU, which causes the FlexCAN to request to resume the clocks and negate the LPMACK bit after the CAN protocol engine recognizes the negation of disable mode requested by the CPU.

45.4.10.3 Doze mode

This is a system low power mode in which the CPU bus is kept alive and a global Doze mode request is sent to all peripherals asking them to enter low-power mode. When Doze mode is globally requested, MCR[DOZE] needs to have been asserted previously for Doze mode to be triggered. The acknowledgement is obtained through the assertion by the FlexCAN of MCR[LPMACK]. The CPU must only consider the FlexCAN to be in Doze mode when both request and acknowledgement conditions are satisfied.
If Doze mode is triggered during Freeze mode, FlexCAN requests to shut down the
clocks to the PE and CHI submodules, sets MCR[LPMACK] and negates
MCR[FRZACK]. If Doze mode is triggered during transmission or reception, FlexCAN
does the following:

- Waits to be in either Idle or Bus Off state, or else waits for the third bit of
  Intermission and checks it to be recessive.
- Waits for all internal activities like arbitration, matching, move-in, and move-out to
  finish. A pending move-in is not taken into account.
- Ignores its Rx input pin and drives its Tx pin as recessive.
- Shuts down the clocks to the PE and CHI submodules.
- Sets MCR[NOTRDY] and MCR[LPMACK].

The Bus Interface Unit continues to operate, enabling the CPU to access memory-
mapped registers, except the Rx Mailboxes Global Mask registers, the Rx Buffer 14
Mask register, the Rx Buffer 15 Mask register, the Rx FIFO Global Mask register. The
Rx FIFO Information register, the message buffers, the Rx Individual Mask registers, and
the reserved words within RAM may not be accessed when the module is in Doze mode.

Exiting Doze mode is done in one of the following ways:

- CPU removing the Doze mode request
- CPU negating MCR [DOZE]
- Self Wake mechanism

In the Self Wake mechanism, if MCR[SLFWAK] was set at the time FlexCAN entered
Doze mode, then upon detection of a recessive to dominant transition on the CAN bus,
FlexCAN negates the DOZE bit, requests to resume its clocks and negates the LPMACK
after the CAN protocol engine recognizes the negation of the Doze mode request. It also
sets ESR [WAKINT] and, if enabled by MCR[WAKMSK], generates a Wake-Up
interrupt to the CPU. FlexCAN will then wait for 11 consecutive recessive bits to
synchronize to the CAN bus. As a consequence, it will not receive the frame that woke it
up. The following table details the effect of SLFWAK and WAKMSK upon wakeup from
Doze mode.

<table>
<thead>
<tr>
<th>SLFWAK</th>
<th>WAKINT</th>
<th>WAKMSK</th>
<th>FlexCAN clocks enabled</th>
<th>Wakeup interrupt generated</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>No</td>
</tr>
</tbody>
</table>

Table 45-17. Wakeup from Doze mode

Table continues on the next page...
### Table 45-17. Wakeup from Doze mode (continued)

<table>
<thead>
<tr>
<th>SLFWAK</th>
<th>WAKINT</th>
<th>WAKMSK</th>
<th>FlexCAN clocks enabled</th>
<th>Wakeup interrupt generated</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Yes</td>
<td>Yes</td>
</tr>
</tbody>
</table>

The sensitivity to CAN bus activity can be modified by applying a low-pass filter function to the Rx CAN input line when in Doze mode. (See MCR[WAKSRC].) This feature can be used to protect FlexCAN from waking up due to short glitches on the CAN bus lines. Such glitches can result from electromagnetic interference within noisy environments.

### 45.4.10.4 Stop mode

This is a system low-power mode in which all chip clocks can be stopped for maximum power savings. The Stop mode is globally requested by the CPU and acknowledgement is obtained through the assertion by the FlexCAN of a Stop Acknowledgement signal. The CPU must only consider the FlexCAN in Stop mode when both request and acknowledgement conditions are satisfied.

If FlexCAN receives the global Stop mode request during Freeze mode, it sets MCR[LPMACK], negates MCR[FRZACK], and then sends the Stop Acknowledge signal to the CPU, in order to shut down the clocks globally.

If Stop mode is requested during transmission or reception, FlexCAN does the following:

- Waits to be in either Idle or Bus Off state, or else waits for the third bit of Intermission and checks it to be recessive
- Waits for all internal activities like arbitration, matching, move-in, and move-out to finish. A pending move-in is not taken into account.
- Ignores its Rx input pin and drives its Tx pin as recessive
- Sets MCR[NOTRDY] and MCR[LPMACK]
- Sends a Stop Acknowledge signal to the CPU, so that it can shut down the clocks globally

Stop mode is exited when the CPU resumes the clocks and removes the Stop mode request. This can be as a result of the Self Wake mechanism.
In the Self Wake mechanism, if MCR[SLFWAK] was set at the time FlexCAN entered Stop mode, then upon detection of a recessive to dominant transition on the CAN bus, FlexCAN sets ESR[WAKINT] and, if enabled by MCR[WAKMSK], generates a Wake Up interrupt to the CPU. Upon receiving the interrupt, the CPU should resume the clocks and remove the Stop mode request. FlexCAN will then wait for 11 consecutive recessive bits to synchronize to the CAN bus. As a consequence, it will not receive the frame that woke it up. The following table details the effect of MCR[SLFWAK] and MCR[WAKMSK] upon wakeup from Stop mode. Note that wakeup from Stop mode only works when both bits are asserted.

After the CAN protocol engine recognizes the negation of the Stop mode request, the FlexCAN negates MCR[LPMACK]. FlexCAN will then wait for 11 consecutive recessive bits to synchronize to the CAN bus. As a consequence, it will not receive the frame that woke it up.

<table>
<thead>
<tr>
<th>SLFWAK</th>
<th>WAKINT</th>
<th>WAKMSK</th>
<th>Chip clocks enabled</th>
<th>Wakeup interrupt generated</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>0</td>
<td>—</td>
<td>—</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Yes</td>
<td>Yes</td>
</tr>
</tbody>
</table>

The sensitivity to CAN bus activity can be modified by applying a low-pass filter function to the Rx CAN input line when in Stop mode. (See the description in MCR[WAKSRC].) This feature can be used to protect FlexCAN from waking up due to short glitches on the CAN bus lines. Such glitches can result from electromagnetic interference within noisy environments.

### 45.4.11 Interrupts

The module has many interrupt sources: interrupts due to message buffers and interrupts due to the ORed interrupts from MBs, Bus Off, Bus Off Done, Error, Error Fast (errors detected in the data phase of CAN FD format messages with the BRS bit set), Wake Up, Tx Warning, and Rx Warning.

Each one of the message buffers can be an interrupt source, if its corresponding IMASK bit is set. There is no distinction between Tx and Rx interrupts for a particular buffer, under the assumption that the buffer is initialized for either transmission or reception.
Each of the buffers has an assigned flag bit in the IFLAG registers. The bit is set when the corresponding buffer completes a successful transfer and is cleared when the CPU writes one to it (unless another interrupt is generated at the same time).

**Note**

It must be guaranteed that the CPU clears only the bit causing the current interrupt. For this reason, bit manipulation instructions (BSET) must not be used to clear interrupt flags. These instructions may cause accidental clearing of interrupt flags which are set after entering the current interrupt service routine.

If the Rx FIFO is enabled (MCR[RFEN] = 1) and DMA is disabled (MCR[DMA] = 0), the interrupts corresponding to MBs 0 to 7 have different meanings. Bit 7 of the IFLAG1 register becomes the "FIFO Overflow" flag; bit 6 becomes the "FIFO Warning" flag, bit 5 becomes the "Frames Available in FIFO" flag and bits 4-0 are unused. See the description of **Interrupt Flags 1 register (IFLAG1)** for more information.

If both Rx FIFO and DMA are enabled (MCR[RFEN] and MCR[DMA] = 1) the FlexCAN does not generate any FIFO interrupt. Bit 5 of the IFLAG1 register still indicates "Frames Available in FIFO" and generates a DMA request. Bits 7, 6, 4-0 are unused.

**CAUTION**

FIFO cannot be enabled when CAN FD feature is enabled.

For a combined interrupt where multiple MB interrupt sources are OR'd together, the interrupt is generated when any of the associated MBs (or FIFO, if applicable) generates an interrupt. In this case, the CPU must read the IFLAG registers to determine which MB or FIFO source caused the interrupt.

The following interrupt sources generate interrupts like the MB interrupt sources, and can be read from ESR1 register

- Bus Off
- Bus Off Done
- Error
- Error Fast
- Wake Up
- Tx Warning
- Rx Warning

The Bus Off, Error, Tx Warning, and Rx Warning interrupt mask bits are located in the CTRL1 register; the Wake-Up interrupt mask bit is located in MCR.
45.4.12  Bus interface

CPU access to FlexCAN registers is subject to the following rules:

- Unrestricted read and write access to supervisor registers (registers identified with S/U in Table 45-19 in Supervisor Mode or with S only) results in an access error.
- Read and write access to implemented reserved address space results in an access error.
- Write access to positions whose bits are all currently read-only results in an access error. If at least one of the bits is not read-only then no access error is issued. Write permission to positions or some of their bits can change depending on the mode of operation or transitory state. See register and field descriptions for details.
- Read and write access to unimplemented address space results in an access error.
- Read and write access to RAM located positions during Low Power mode results in an access error.
- It is possible for the RXIMR memory region to be considered as general purpose memory and available for access. There are two ways of doing this:
  a. If MCR[IRMQ] is cleared, the individual masks (RXIMR) are disabled. In this case the RXIMR memory region is considered as general purpose memory.
  b. If MCR[MAXMB] is programmed with a value smaller than the available number of MBs, then the unused memory space can be used as general purpose RAM space. Note that reserved words within RAM cannot be used. As an example, suppose FlexCAN's RAM can support up to 16 MBs, CTRL2[RFFN] is 0x0, and MCR[MAXMB] is programmed with zero. The maximum number of MBs in this case becomes one. The RAM starts at 0x0080, and the space from 0x0080 to 0x008F is used by the one MB. The memory space from 0x0090 to 0x017F is available. The space between 0x0180 and 0x087F is reserved. The space from 0x0880 to 0x0883 is used by the one individual mask and the available memory in the mask registers space would be from 0x0884 to 0x08BF. From 0x08C0 through 0x09DF there are reserved words for internal use which cannot be used as general purpose RAM. As a general rule, free memory space for general purpose depends only on MAXMB.
  c. If MCR[FDEN] is enabled, general purpose memory can be used out of Freeze mode only.

45.5  Initialization/application information

This section provides instructions for initializing the FlexCAN module.
45.5.1 FlexCAN initialization sequence

The FlexCAN module may be reset in three ways:

1. Chip level hard reset, which resets all memory-mapped registers asynchronously.
2. MCR[SOFTRST], which resets some of the memory-mapped registers synchronously. See Table 45-19 to see what registers are affected by soft reset.
3. Chip level soft reset, which has the same effect as MCR[SOFTRST].

Soft reset is synchronous and has to follow an internal request/acknowledge procedure across clock domains. Therefore, it may take some time to fully propagate its effects. MCR[SOFTRST] remains asserted while soft reset is pending, so software can poll this bit to know when the reset has completed. Also, soft reset cannot be applied while clocks are shut down in a low-power mode. The low-power mode should be exited and the clocks resumed before applying soft reset.

The clock source should be selected when the module is in Disable mode (see CTRL1[CLKSRC] description in Control 1 register (CTRL1)). After the clock source is selected and the module is enabled (MCR[MDIS] bit negated), FlexCAN automatically enters Freeze mode. In Freeze mode, FlexCAN is un-synchronized to the CAN bus, MCR[HALT] and MCR[FRZ] are set, the internal state machines are disabled, then MCR[FRZACK] and MCR[NOTRDY] are set. The Tx pin is in recessive state and FlexCAN does not initiate any transmission or reception of CAN frames. Note that the message buffers and the Rx Individual Mask registers are not affected by reset, so they are not automatically initialized.

For any configuration change/initialization it is required that FlexCAN be put into Freeze mode (see Freeze mode). The following is a generic initialization sequence applicable to the FlexCAN module:

1. Initialize the Module Configuration register (MCR).
   a. Enable the individual filtering per MB and reception queue features by setting IRMQ.
   b. Enable the warning interrupts by setting WRNEN.
   c. If required, disable frame self reception by setting SRXDIS.
   d. Enable the Rx FIFO by setting RFEN.
   e. If Rx FIFO is enabled and DMA is required, set DMA.
   f. Enable the abort mechanism by setting AEN.
   g. Enable the local priority feature by setting LPRIOEN.
2. Initialize the Control 1 register (CTRL1) and optionally the CAN Bit Timing register (CBT). Initialize also the CAN FD CAN Bit Timing register (FDCBT).
   a. Determine the bit timing parameters: PROPSEG, PSEG1, PSEG2, and RJW.
b. Optionally determine the bit timing parameters: EPROPSEG, EPSEG1, EPSEG2, and ERJW.
c. Determine the CAN FD bit timing parameters: FPROPSEG, FPSEG1, FPSEG2, and FRJW.
d. Determine the bit rate by programming the PRESDIV field and optionally the EPRESDIV field.
e. Determine the CAN FD bit rate by programming the FPRESDIV field.
f. Determine the internal arbitration mode (LBUF).

3. Initialize the message buffers.
   a. The control and status word of all message buffers must be initialized.
   b. If Rx FIFO was enabled, the ID filter table must be initialized.
   c. Other entries in each message buffer should be initialized as required.

4. Initialize the Rx Individual Mask registers (RXIMRn).

5. Set required interrupt mask bits in
   • IMASK registers (for all MB interrupts)
   • MCR register (for Wake-Up interrupt)
   • CTRL1 / CTRL2 registers (for Bus Off and Error interrupts)

6. Negate MCR[HALT].

After the last step listed above, FlexCAN attempts to synchronize to the CAN bus.

### 45.6 Memory map/register definition

This section describes the registers and data structures in the FlexCAN module. The base address of the module depends on the particular memory map of the chip.

#### 45.6.1 FlexCAN memory mapping

The memory map for the FlexCAN module is shown in the following table.

The address space occupied by FlexCAN has 128 bytes for registers starting at the module base address, followed by embedded RAM starting at address offset 0x0080.

Each individual register is identified by its complete name and the corresponding mnemonic. The access type can be Supervisor (S) or Unrestricted (U). Most of the registers can be configured to have either Supervisor or Unrestricted access by programming MCR[SUPV]. These registers are identified as S/U in the Access column of Table 45-19.
NOTE
An invalid register access will result in a bus error. This includes reading a write-only register, writing a read-only register, or accessing an invalid address.

Table 45-19. Register access and reset information

<table>
<thead>
<tr>
<th>Register</th>
<th>Access type</th>
<th>Affected by hard reset</th>
<th>Affected by soft reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Module Configuration Register (MCR)</td>
<td>S</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Control 1 register (CTRL1)</td>
<td>S/U</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Free Running Timer register (TIMER)</td>
<td>S</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Rx Mailboxes Global Mask register (RXMGMASK)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Rx Buffer 14 Mask register (RX14MASK)</td>
<td>S/U</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>Rx Buffer 15 Mask register (RX15MASK)</td>
<td>S/U</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>Error Counter Register (ECR)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Error and Status 1 Register (ESR1)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Interrupt Masks 2 register (IMASK2)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Interrupt Masks 1 register (IMASK1)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Interrupt Flags 2 register (IFLAG2)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Interrupt Flags 1 register (IFLAG1)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Control 2 Register (CTRL2)</td>
<td>S/U</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Error and Status 2 Register (ESR2)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>CRC Register (CRCR)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>Rx FIFO Global Mask register (RXFGMASK)</td>
<td>S/U</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>Rx FIFO Information Register (RXFIR)</td>
<td>S/U</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>CAN Bit Timing Register (CBT)</td>
<td>S/U</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>Message buffers</td>
<td>S/U</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>Rx Individual Mask Registers</td>
<td>S/U</td>
<td>No</td>
<td>No</td>
</tr>
<tr>
<td>CAN FD Control register (FDCTRL)</td>
<td>S/U</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>CAN FD Bit Timing register (FDCBT)</td>
<td>S/U</td>
<td>Yes</td>
<td>No</td>
</tr>
<tr>
<td>CAN FD CRC register (FDCRC)</td>
<td>S/U</td>
<td>Yes</td>
<td>Yes</td>
</tr>
</tbody>
</table>

The FlexCAN module can store CAN messages for transmission and reception using mailboxes and Rx FIFO structures.

45.6.2 CAN register descriptions

The table below shows the FlexCAN memory map.
The address range from offset 0x80 to 0x47F allocates the sixty-four 128-bit message buffers (MBs).

The memory maps for the message buffers are in FlexCAN message buffer memory map.

### 45.6.2.1 CAN memory map

FlexCAN3(CANFD) base address: 401D_8000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Module Configuration register (MCR)</td>
<td>32</td>
<td>RW</td>
<td>5980_000Fh</td>
</tr>
<tr>
<td>4h</td>
<td>Control 1 register (CTRL1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8h</td>
<td>Free Running Timer (TIMER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>Rx Mailboxes Global Mask register (RXMGMAKSK)</td>
<td>32</td>
<td>RW</td>
<td>Table 45-19</td>
</tr>
<tr>
<td>14h</td>
<td>Rx 14 Mask register (RX14MASK)</td>
<td>32</td>
<td>RW</td>
<td>Table 45-19</td>
</tr>
<tr>
<td>18h</td>
<td>Rx 15 Mask register (RX15MASK)</td>
<td>32</td>
<td>RW</td>
<td>Table 45-19</td>
</tr>
<tr>
<td>1Ch</td>
<td>Error Counter (ECR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>20h</td>
<td>Error and Status 1 register (ESR1)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>24h</td>
<td>Interrupt Masks 2 register (IMASK2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>28h</td>
<td>Interrupt Masks 1 register (IMASK1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>2Ch</td>
<td>Interrupt Flags 2 register (IFLAG2)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>30h</td>
<td>Interrupt Flags 1 register (IFLAG1)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>34h</td>
<td>Control 2 register (CTRL2)</td>
<td>32</td>
<td>RW</td>
<td>0080_0000h</td>
</tr>
<tr>
<td>38h</td>
<td>Error and Status 2 register (ESR2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>44h</td>
<td>CRC register (CRCR)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>48h</td>
<td>Rx FIFO Global Mask register (RXFGMASK)</td>
<td>32</td>
<td>RW</td>
<td>Table 45-21</td>
</tr>
<tr>
<td>4Ch</td>
<td>Rx FIFO Information register (RXFIR)</td>
<td>32</td>
<td>RO</td>
<td>Table 45-21</td>
</tr>
<tr>
<td>50h</td>
<td>CAN Bit Timing register (CBT)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>880h - 97Ch</td>
<td>Rx Individual Mask registers (RXIMR0 - RXIMR63)</td>
<td>32</td>
<td>RW</td>
<td>Table 45-21</td>
</tr>
<tr>
<td>C00h</td>
<td>CAN FD Control register (FDCTRL)</td>
<td>32</td>
<td>RW</td>
<td>8000_0100h</td>
</tr>
<tr>
<td>C04h</td>
<td>CAN FD Bit Timing register (FDCBT)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C08h</td>
<td>CAN FD CRC register (FDCRC)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

### 45.6.2.2 Module Configuration register (MCR)
### 45.6.2.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR</td>
<td>0h</td>
</tr>
</tbody>
</table>

### 45.6.2.2.2 Function

This register defines global system configurations, such as the module operation modes and the maximum message buffer configuration.

### 45.6.2.2.3 Diagram

![Diagram of the register settings]

### 45.6.2.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 MDIS | Module Disable  
  This bit controls whether FlexCAN is enabled or not. When disabled, FlexCAN disables the clocks to the CAN Protocol Engine and Controller Host Interface submodules. This bit is not affected by soft reset.  
  0b - Enable the FlexCAN module.  
  1b - Disable the FlexCAN module.  |
| 30 FRZ | Freeze Enable  
  The FRZ bit specifies the FlexCAN behavior when MCR[HALT] is set or when Debug mode is requested at chip level. When FRZ is asserted, FlexCAN is enabled to enter Freeze mode. Negation of this bit field causes FlexCAN to exit from Freeze mode.  
  0b - Not enabled to enter Freeze mode.  
  1b - Enabled to enter Freeze mode.  |
| 29 RFEN | Rx FIFO Enable  |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>This bit controls whether the Rx FIFO feature is enabled or not. When RFEN is set, MBs 0 to 5 cannot be used for normal reception and transmission because the corresponding memory region (0x80-0xDC) is used by the FIFO engine as well as additional MBs (up to 32, depending on CTRL2[RFFN] setting) which are used as Rx FIFO ID filter table elements. RFEN also impacts the definition of the minimum number of peripheral clocks per CAN bit as described in Table 45-14. This bit can be written in Freeze mode only, because it is blocked by hardware in other modes.</td>
<td></td>
</tr>
<tr>
<td>NOTE: This bit cannot be set when CAN FD operation is enabled (see FDEN bit).</td>
<td></td>
</tr>
<tr>
<td>0b - Rx FIFO not enabled.</td>
<td></td>
</tr>
<tr>
<td>1b - Rx FIFO enabled.</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>HALT</td>
</tr>
<tr>
<td>Assertion of this bit puts the FlexCAN module into Freeze mode. The CPU should clear it after initializing the message buffers and the Control registers CTRL1 and CTRL2. No reception or transmission is performed by FlexCAN before this bit is cleared. Freeze mode cannot be entered when FlexCAN is in a low power mode.</td>
<td></td>
</tr>
<tr>
<td>0b - No Freeze mode request.</td>
<td></td>
</tr>
<tr>
<td>1b - Enters Freeze mode if the FRZ bit is asserted.</td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>NOTRDY</td>
</tr>
<tr>
<td>This read-only bit indicates that FlexCAN is either in Disable mode, Doze mode, Stop mode or Freeze mode. It is negated when FlexCAN has exited these modes. This bit is not affected by soft reset.</td>
<td></td>
</tr>
<tr>
<td>0b - FlexCAN module is either in Normal mode, Listen-Only mode, or Loop-Back mode.</td>
<td></td>
</tr>
<tr>
<td>1b - FlexCAN module is either in Disable mode, Doze mode, Stop mode, or Freeze mode.</td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>WAKMSK</td>
</tr>
<tr>
<td>This bit enables the Wake Up interrupt generation under Self Wake Up mechanism.</td>
<td></td>
</tr>
<tr>
<td>0b - Wake Up interrupt is disabled.</td>
<td></td>
</tr>
<tr>
<td>1b - Wake Up interrupt is enabled.</td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>SOFTRST</td>
</tr>
<tr>
<td>When SOFTRST is asserted, FlexCAN resets its internal state machines and some of the memory-mapped registers.</td>
<td></td>
</tr>
<tr>
<td>SOFTRST can be asserted directly by the CPU when it writes to the MCR register, but it is also asserted when global soft reset is requested at chip level. Because soft reset is synchronous and has to follow a request/acknowledge procedure across clock domains, it may take some time to fully propagate its effect. The SOFTRST bit remains asserted when reset is pending, and is automatically negated when reset completes. Therefore, software can poll this bit to know when the soft reset has completed.</td>
<td></td>
</tr>
<tr>
<td>Soft reset cannot be applied when clocks are shut down in a low power mode. The module should be first removed from low power mode, and then soft reset can be applied. This bit is not affected by soft reset.</td>
<td></td>
</tr>
<tr>
<td>0b - No reset request.</td>
<td></td>
</tr>
<tr>
<td>1b - Resets the registers affected by soft reset.</td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>FRZACK</td>
</tr>
<tr>
<td>This read-only bit indicates that FlexCAN is in Freeze mode and its prescaler is stopped. The Freeze mode request cannot be granted until current transmission or reception processes have finished. Therefore the software can poll the FRZACK bit to know when FlexCAN has actually entered Freeze mode. If Freeze mode request is negated, then this bit is negated after the FlexCAN prescaler is running again. If Freeze mode is requested when FlexCAN is in a low power mode, then the FRZACK bit will be set only when the low-power mode is exited. See Freeze mode. This bit is not affected by soft reset.</td>
<td></td>
</tr>
<tr>
<td>NOTE: FRZACK will be asserted within 178 CAN bits from the Freeze mode request by the CPU, and negated within 2 CAN bits after the Freeze mode request removal (see Protocol timing).</td>
<td></td>
</tr>
<tr>
<td>0b - FlexCAN not in Freeze mode, prescaler running.</td>
<td></td>
</tr>
<tr>
<td>1b - FlexCAN in Freeze mode, prescaler stopped.</td>
<td></td>
</tr>
<tr>
<td>23</td>
<td>Supervisor Mode</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field | Function
---|---
**SUPV** | This bit configures the FlexCAN to be either in Supervisor or User mode. The registers affected by this bit are marked as S/U in the "Access type" column of Table 45-19. Reset value of this bit is 1, so the affected registers start with Supervisor access allowance only. This bit can be written only in Freeze mode because it is blocked by hardware in other modes.  
0b - FlexCAN is in User mode. Affected registers allow both Supervisor and Unrestricted accesses.  
1b - FlexCAN is in Supervisor mode. Affected registers allow only Supervisor access. Unrestricted access behaves as though the access was done to an unimplemented register location.  

22 | Self Wake Up  
SLFWAK | This feature enables the Self Wake Up feature when FlexCAN is in a low-power mode other than Disable mode. When this feature is enabled, the FlexCAN module monitors the bus for wakeup event, that is, a recessive-to-dominant transition.  
If a wakeup event is detected during Doze mode, FlexCAN requests to resume its clocks and, if enabled to do so, generates a Wake Up interrupt to the CPU.  
If a wakeup event is detected during Stop mode, then FlexCAN generates, if enabled to do so, a Wake Up interrupt to the CPU so that it can exit Stop mode globally and FlexCAN can request to resume the clocks.  
When FlexCAN is in a low-power mode other than Disable mode, this bit cannot be written as it is blocked by hardware.  
0b - FlexCAN Self Wake Up feature is disabled.  
1b - FlexCAN Self Wake Up feature is enabled.  

21 | Warning Interrupt Enable  
WRNEN | When asserted, this bit enables the generation of the TWRNINT and RWRNINT flags in the Error and Status Register 1 (ESR1). If WRNEN is negated, the TWRNINT and RWRNINT flags will always be zero, independent of the values of the error counters, and no warning interrupt will ever be generated. This bit can be written in Freeze mode only, because it is blocked by hardware in other modes.  
0b - TWRNINT and RWRNINT bits are zero, independent of the values in the error counters.  
1b - TWRNINT and RWRNINT bits are set when the respective error counter transitions from less than 96 to greater than or equal to 96.  

20 | Low-Power Mode Acknowledge  
LPMACK | This read-only bit indicates that FlexCAN is in a low-power mode (Disable mode, Doze mode, Stop mode). A low-power mode cannot be entered until all current transmission or reception processes have finished, so the CPU can poll the LPMACK bit to know when FlexCAN has actually entered low power mode. This bit is not affected by soft reset.  
**NOTE:** LPMACK will be asserted within 180 CAN bits from the low-power mode request by the CPU, and negated within 2 CAN bits after the low-power mode request removal (see Protocol timing).  
0b - FlexCAN is not in a low-power mode.  
1b - FlexCAN is in a low-power mode.  

19 | Wake Up Source  
WAKSRC | This bit defines whether the integrated low-pass filter is applied to protect the Rx CAN input from spurious wakeup. This bit can be written only in Freeze mode because it is blocked by hardware in other modes.  
0b - FlexCAN uses the unfiltered Rx input to detect recessive to dominant edges on the CAN bus.  
1b - FlexCAN uses the filtered Rx input to detect recessive to dominant edges on the CAN bus.  

18 | Doze Mode Enable  
DOZE | This bit defines whether FlexCAN is allowed to enter low-power mode when Doze mode is requested at chip level. This bit is automatically reset when FlexCAN wakes up from Doze mode upon detecting activity on the CAN bus (self wakeup enabled).  
0b - FlexCAN is not enabled to enter low-power mode when Doze mode is requested.  
1b - FlexCAN is enabled to enter low-power mode when Doze mode is requested.  

17 | Self Reception Disable

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| SRXDIS | This bit defines whether FlexCAN is allowed to receive frames transmitted by itself. If this bit is asserted, frames transmitted by the module will not be stored in any MB, regardless if the MB is programmed with an ID that matches the transmitted frame, and no interrupt flag or interrupt signal will be generated due to the frame reception. This bit can be written only in Freeze mode because it is blocked by hardware in other modes.  
 0b - Self-reception enabled.  
1b - Self-reception disabled. |
| 16 | Individual Rx Masking And Queue Enable |
| IRMQ | This bit indicates whether Rx matching process will be based either on individual masking and queue or on masking scheme with RXMGMSK, RX14MASK, RX15MASK, and RXFGMASK. This bit can be written in Freeze mode only because it is blocked by hardware in other modes.  
 0b - Individual Rx masking and queue feature are disabled. For backward compatibility with legacy applications, the reading of C/S word locks the MB even if it is EMPTY.  
1b - Individual Rx masking and queue feature are enabled. |
| 15 | DMA Enable |
| DMA | DMA controls whether the DMA feature is enabled or not. The DMA feature can only be used in Rx FIFO, so consequently MCR[RFEN] must be asserted. When DMA and RFEN are set, IFLAG1[BUF5l] generates the DMA request and no RX FIFO interrupt is generated. This bit can be written in Freeze mode only as it is blocked by hardware in other modes.  
 0b - DMA feature for RX FIFO disabled.  
1b - DMA feature for RX FIFO enabled. |
| 14 | Reserved |
| 13 | Local Priority Enable |
| LPRIEN | This bit is provided for backwards compatibility with legacy applications. It controls whether the local priority feature is enabled or not. It is used to expand the ID used during the arbitration process. With this expanded ID concept, the arbitration process is done based on the full 32-bit word, but the actual transmitted ID still has 11-bit for standard frames and 29-bit for extended frames. This bit can be written only in Freeze mode because it is blocked by hardware in other modes.  
 0b - Local Priority disabled.  
1b - Local Priority enabled. |
| 12 | Abort Enable |
| AEN | When asserted, this bit enables the Tx abort mechanism. This mechanism guarantees a safe procedure for aborting a pending transmission, so that no frame is sent in the CAN bus without notification. This bit can be written only in Freeze mode because it is blocked by hardware in other modes.  
NOTE: When MCR[AEN] is asserted, only the abort mechanism (see Transmission abort mechanism) must be used for updating mailboxes configured for transmission.  
CAUTION: Writing the Abort code into Rx mailboxes can cause unpredictable results when MCR[AEN] is asserted.  
 0b - Abort disabled.  
1b - Abort enabled. |
| 11 | CAN FD operation enable |
| FDEN | This bit enables the CAN with Flexible Data rate (CAN FD) operation. This bit can be written in Freeze mode only.  
NOTE: FlexCAN is able to transmit FD frame format according to ISO 11898-1.  
NOTE: The Rx FIFO Enable (RFEN) bit cannot be set if FDEN is asserted.  
 0b - CAN FD is disabled. FlexCAN is able to receive and transmit messages in CAN 2.0 format.  
1b - CAN FD is enabled. FlexCAN is able to receive and transmit messages in both CAN FD and CAN 2.0 formats. |
### Field 10

**Function:** Reserved

### Field 9-8 (IDAM)

**ID Acceptance Mode**

This 2-bit field identifies the format of the Rx FIFO ID filter table elements. Note that all elements of the table are configured at the same time by this field (they are all the same format). See Rx FIFO structure. This field can be written only in Freeze mode because it is blocked by hardware in other modes.

- **00b - Format A:** One full ID (standard and extended) per ID filter table element.
- **01b - Format B:** Two full standard IDs or two partial 14-bit (standard and extended) IDs per ID filter table element.
- **10b - Format C:** Four partial 8-bit standard IDs per ID filter table element.
- **11b - Format D:** All frames rejected.

### Field 7-6 (MAXMB)

**Number Of The Last Message Buffer**

This 7-bit field defines the number of the last message buffers that will take part in the matching and arbitration processes. The reset value (0x0F) is equivalent to a 16 MB configuration. This field can be written only in Freeze mode because it is blocked by hardware in other modes.

Number of the last MB = MAXMB

**NOTE:** MAXMB must be programmed with a value smaller than or equal to the number of available message buffers, as described in FlexCAN memory partition for CAN FD.

Additionally, the definition of MAXMB value must take into account the region of MBs occupied by Rx FIFO and its ID filters table space defined by CTRL2[RFFN]. MAXMB also impacts the definition of the minimum number of peripheral clocks per CAN bit as described in Table 45-14.

### 45.6.2.3 Control 1 register (CTRL1)

#### 45.6.2.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL1</td>
<td>4h</td>
</tr>
</tbody>
</table>

#### 45.6.2.3.2 Function

This register is defined for specific FlexCAN control features related to the CAN bus, such as bit rate, programmable sampling point within an Rx bit, Loop Back mode, Listen-Only mode, Bus Off recovery behavior, and interrupt enabling (Bus-Off, Error, Warning). It also determines the division factor for the clock prescaler.
The CAN bit timing variables (PRESDIV, PROPSEG, PSEG1, PSEG2, and RJW) can also be configured in the CBT register, which extends the range of all these variables. If CBT[BTF] is set, PRESDIV, PROPSEG, PSEG1, PSEG2, and RJW fields of CTRL1 become read only.

**NOTE**

When the CAN FD feature is enabled, do not use the PRESDIV, RJW, PSEG1, PSEG2, and PROPSEG fields of the CTRL1 register for CAN bit timing. Instead use the CBT register's EPRESDIV, ERJW, EPSEG1, EPSEG2, and EPROPSEG fields.

The contents of this register are not affected by soft reset.

**NOTE**

The CAN bit variables in CTRL1 and in CBT are stored in the same register.

### 45.6.2.3.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>BOFFMSK</td>
<td>ERRMS</td>
<td>CLKSRC</td>
<td>LP</td>
<td>TWARMSK</td>
<td>RWRNMSK</td>
<td>Reserved</td>
<td>Reserved</td>
<td>SMP</td>
<td>BOFFRE</td>
<td>C</td>
<td>TSY</td>
<td>N</td>
<td>LBU</td>
<td>F</td>
<td>LOM</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 45.6.2.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>PRESDIV</td>
</tr>
<tr>
<td></td>
<td>Prescaler Division Factor</td>
</tr>
<tr>
<td></td>
<td>This 8-bit field defines the ratio between the PE clock frequency and the serial clock (Sclock) frequency. The Sclock period defines the time quantum of the CAN protocol. For the reset value, the Sclock frequency is equal to the PE clock frequency. The maximum value of this field is 0xFF, which gives a minimum Sclock frequency equal to the PE clock frequency divided by 256. See Protocol timing. This field can be written only in Freeze mode because it is blocked by hardware in other modes. Sclock frequency = PE clock frequency / (PRESDIV + 1)</td>
</tr>
<tr>
<td>23-22</td>
<td>Resync Jump Width</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>RJW</td>
<td>This 2-bit field defines the maximum number of time quanta that a bit time can be changed by one resynchronization. One time quantum is equal to the Sclock period. The valid programmable values are 0–3. This field can be written only in Freeze mode because it is blocked by hardware in other modes. Resync Jump Width = RJW + 1.</td>
</tr>
<tr>
<td>PSEG1</td>
<td>Phase Segment 1 This 3-bit field defines the length of phase segment 1 in the bit time. The valid programmable values are 0–7. This field can be written only in Freeze mode because it is blocked by hardware in other modes. Phase Buffer Segment 1 = (PSEG1 + 1) × Time-Quanta.</td>
</tr>
<tr>
<td>PSEG2</td>
<td>Phase Segment 2 This 3-bit field defines the length of phase segment 2 in the bit time. The valid programmable values are 1–7. This field can be written only in Freeze mode because it is blocked by hardware in other modes. Phase Buffer Segment 2 = (PSEG2 + 1) × Time-Quanta.</td>
</tr>
<tr>
<td>BOFFMSK</td>
<td>Bus Off Interrupt Mask This bit provides a mask for the Bus Off interrupt ESR1[BOFFINT]. 0b - Bus Off interrupt disabled. 1b - Bus Off interrupt enabled.</td>
</tr>
<tr>
<td>ERRMSK</td>
<td>Error Interrupt Mask This bit provides a mask for the Error interrupt ESR1[ERRINT]. 0b - Error interrupt disabled. 1b - Error interrupt enabled.</td>
</tr>
<tr>
<td>CLKSRC</td>
<td>CAN Engine Clock Source This bit selects the clock source to the CAN Protocol Engine (PE) to be either the peripheral clock or the oscillator clock. The selected clock is the one fed to the prescaler to generate the serial clock (Sclock). In order to guarantee reliable operation, this bit can be written only in Disable mode because it is blocked by hardware in other modes. See Protocol timing.</td>
</tr>
<tr>
<td>LPB</td>
<td>Loop Back Mode This bit configures FlexCAN to operate in Loop-Back mode. In this mode, FlexCAN performs an internal loop back that can be used for self-test operation. The bit stream output of the transmitter is fed back internally to the receiver input. The Rx CAN input pin is ignored and the Tx CAN output goes to the recessive state (logic 1). FlexCAN behaves as it normally does when transmitting, and treats its own transmitted message as a message received from a remote node. In this mode, FlexCAN ignores the bit sent during the ACK slot in the CAN frame acknowledge field, generating an internal acknowledge bit to ensure proper reception of its own message. Both transmit and receive interrupts are generated. This bit can be written only in Freeze mode because it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td>TWRNMSK</td>
<td>Tx Warning Interrupt Mask</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
|       | This bit provides a mask for the Tx Warning interrupt associated with the TWRNINT flag in the Error and Status Register 1 (ESR1). This bit is read as zero when MCR[WRNEN] is negated. This bit can be written only if MCR[WRNEN] is asserted.  
0b - Tx Warning interrupt disabled.  
1b - Tx Warning interrupt enabled. |
| 10    | Rx Warning Interrupt Mask  
This bit provides a mask for the Rx Warning interrupt associated with the RWRNINT flag in the Error and Status Register 1 (ESR1). This bit is read as zero when MCR[WRNEN] bit is negated. This bit can be written only if MCR[WRNEN] bit is asserted.  
0b - Rx Warning interrupt disabled.  
1b - Rx Warning interrupt enabled. |
| 9     | Reserved |
| 8     | Reserved |
| 7     | CAN Bit Sampling  
This bit defines the sampling mode of CAN bits at the Rx input. It can be written in Freeze mode only, because it is blocked by hardware in other modes.  
NOTE: For proper operation, to assert SMP it is necessary to guarantee a minimum value of two TQs in CTRL1[PSEG1] (or CBT[EPSEG1]). This bit cannot be asserted when CAN FD is enabled (MCR[FDEN] = 1).  
0b - Just one sample is used to determine the bit value.  
1b - Three samples are used to determine the value of the received bit: the regular one (sample point) and two preceding samples; a majority rule is used. |
| 6     | Bus Off Recovery  
This bit defines how FlexCAN recovers from Bus Off state. If this bit is negated, automatic recovering from Bus Off state occurs according to the CAN Specification 2.0B. If the bit is asserted, automatic recovering from Bus Off is disabled and the module remains in Bus Off state until the bit is negated by the user. If the negation occurs before 128 sequences of 11 recessive bits are detected on the CAN bus, then Bus Off recovery happens as if the BOFFREC bit had never been asserted. If the negation occurs after 128 sequences of 11 recessive bits occurred, then FlexCAN will resynchronize to the bus by waiting for 11 recessive bits before joining the bus. After negation, the BOFFREC bit can be reasserted again during Bus Off, but it will be effective only the next time the module enters Bus Off. If BOFFREC was negated when the module entered Bus Off, asserting it during Bus Off will not be effective for the current Bus Off recovery.  
NOTE: See Bus off in the CAN Protocol standard (ISO 11898-1) for details.  
0b - Automatic recovering from Bus Off state enabled.  
1b - Automatic recovering from Bus Off state disabled. |
| 5     | Timer Sync  
This bit enables a mechanism that resets the free running timer each time a message is received in message buffer 0. This feature provides means to synchronize multiple FlexCAN stations with a special “SYNC” message, that is, global network time. If MCR[RFEN] is set (Rx FIFO enabled), the first available mailbox, according to CTRL2[RFFN] setting, is used for timer synchronization instead of MB0. This bit can be written in Freeze mode only because it is blocked by hardware in other modes.  
0b - Timer sync feature disabled  
1b - Timer sync feature enabled |
| 4     | Lowest Buffer Transmitted First |

Table continues on the next page...
### Table 1

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>3 LOM</td>
<td>Listen-Only Mode</td>
</tr>
<tr>
<td>2-0 PROPSEG</td>
<td>Propagation Segment</td>
</tr>
</tbody>
</table>

#### 45.6.2.4 Free Running Timer (TIMER)

#### 45.6.2.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMER</td>
<td>8h</td>
</tr>
</tbody>
</table>

#### 45.6.2.4.2 Function

This register represents a 16-bit free-running counter that can be read and written by the CPU. The timer starts from 0x0 after Reset, counts linearly to 0xFFFF, and wraps around.

When CTRL2[TIMER_SRC] is asserted, the timer is continuously incremented by an external time tick. The time tick must be synchronous to the peripheral clock, with a minimum pulse width of one clock cycle.
When CTRL2[TIMER_SRC] is negated, the timer is incremented by the CAN bit clock, which defines the baud rate on the CAN bus. During a message transmission/reception, it increments by one for each bit that is received or transmitted. When there is no message on the bus, it counts using the previously programmed baud rate. The timer is not incremented during Disable, Doze, Stop and Freeze modes.

The timer value is captured when the second bit of the identifier field of any frame is on the CAN bus. This captured value is written into the time stamp entry in a message buffer after a successful reception or transmission of a message.

If CTRL1[TSYN] is asserted, the timer is reset whenever a message is received in the first available mailbox, according to CTRL2[RFFN] setting.

The CPU can write to this register anytime. However, if the write occurs at the same time that the timer is being reset by a reception in the first mailbox, then the write value is discarded.

Reading this register affects the mailbox unlocking procedure (see Mailbox lock mechanism).

**45.6.2.4.3 Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**45.6.2.4.4 Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-0</td>
<td>Timer Value</td>
</tr>
<tr>
<td>TIMER</td>
<td>Contains the free-running counter value.</td>
</tr>
</tbody>
</table>
45.6.2.5  Rx Mailboxes Global Mask register (RXMGMASK)

45.6.2.5.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RXMGMASK</td>
<td>10h</td>
</tr>
</tbody>
</table>

45.6.2.5.2  Function

This register is located in RAM.

RXMGMASK is provided for legacy application support.

- When MCR[IRMQ] is negated, RXMGMASK is always in effect (the bits in the MG field will mask the mailbox filter bits).
- When MCR[IRMQ] is asserted, RXMGMASK has no effect (the bits in the MG field will not mask the mailbox filter bits).

RXMGMASK is used to mask the filter fields of all Rx MBs, excluding MBs 14-15, which have individual mask registers.

This register can only be written in Freeze mode as it is blocked by hardware in other modes.

45.6.2.5.3  Diagram

```
+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+
| Bits   | 31     | 30     | 29     | 28     | 27     | 26     | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
| R      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| W      |        |        |        |        |        |        |        | MG     |        |        |        |        |        |        |        |        |
| Reset  | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       |
+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+
| Bits   | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| R      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| W      |        |        |        |        |        |        | MG     |        |        |        |        |        |        |        |        |        |
| Reset  | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       | u       |
+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+
```

45.6.2.5.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Rx Mailboxes Global Mask Bits</td>
</tr>
<tr>
<td>MG</td>
<td></td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors 2667
These bits mask the mailbox filter bits. Note that the alignment with the ID word of the mailbox is not perfect as the two most significant MG bits affect the fields RTR and IDE, which are located in the Control and Status word of the mailbox. The following table shows in detail which MG bits mask each mailbox filter field.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>—</td>
<td>0</td>
<td>note-1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>—</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>MG[31]</td>
</tr>
</tbody>
</table>

1. RTR bit of the incoming frame. It is saved into an auxiliary MB called Rx serial message buffer (Rx SMB).
2. If CTRL2[EACEN] is negated, the RTR bit of mailbox is never compared with the RTR bit of the incoming frame.
3. If CTRL2[EACEN] is negated, the IDE bit of mailbox is always compared with the IDE bit of the incoming frame.

0b - The corresponding bit in the filter is "don't care."
1b - The corresponding bit in the filter is checked.

### 45.6.2.6 Rx 14 Mask register (RX14MASK)

#### 45.6.2.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RX14MASK</td>
<td>14h</td>
</tr>
</tbody>
</table>

#### 45.6.2.6.2 Function

This register is located in RAM.

RX14MASK is provided for legacy application support. When MCR[IRMQ] is asserted, RX14MASK has no effect.

RX14MASK is used to mask the filter fields of message buffer 14.
This register can only be programmed when the module is in Freeze mode as it is blocked by hardware in other modes.

45.6.2.6.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RX14M</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RX14M</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

45.6.2.6.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Rx Buffer 14 Mask Bits</td>
</tr>
<tr>
<td>RX14M</td>
<td>Each mask bit masks the corresponding mailbox 14 filter field in the same way that RXMGMASK masks other mailboxes' filters. See the description of the RXMGMASK register.</td>
</tr>
<tr>
<td></td>
<td>0b - The corresponding bit in the filter is &quot;don't care.&quot;</td>
</tr>
<tr>
<td></td>
<td>1b - The corresponding bit in the filter is checked.</td>
</tr>
</tbody>
</table>

45.6.2.7  Rx 15 Mask register (RX15MASK)

45.6.2.7.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RX15MASK</td>
<td>18h</td>
</tr>
</tbody>
</table>

45.6.2.7.2  Function

This register is located in RAM.

RX15MASK is provided for legacy application support. When MCR[IRMQ] is asserted, RX15MASK has no effect.
RX15MASK is used to mask the filter fields of message buffer 15.

This register can be programmed only when the module is in Freeze mode because it is blocked by hardware in other modes.

### 45.6.2.7.3 Diagram

![Diagram](image)

### 45.6.2.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Rx Buffer 15 Mask Bits</td>
</tr>
<tr>
<td>RX15M</td>
<td>Each mask bit masks the corresponding mailbox 15 filter field in the same way that RXMGMASK masks other mailboxes' filters. See the description of the RXMGMASK register.</td>
</tr>
<tr>
<td></td>
<td>0b - The corresponding bit in the filter is &quot;don't care.&quot;</td>
</tr>
<tr>
<td></td>
<td>1b - The corresponding bit in the filter is checked.</td>
</tr>
</tbody>
</table>

### 45.6.2.8 Error Counter (ECR)

#### 45.6.2.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ECR</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

### 45.6.2.8.2 Function

This register has four 8-bit fields reflecting the value of the FlexCAN error counters:

- Transmit Error Counter (TXERRCNT field)
• Receive Error Counter (RXERRCNT field)
• Transmit Error Counter for errors detected in the data phase of CAN FD messages with the BRS bit set (TXERRCNT_FAST field)
• Receive Error Counter for errors detected in the data phase of CAN FD messages with the BRS bit set (RXERRCNT_FAST field)

The TXERRCNT and RXERRCNT counters take into account all errors in both CAN FD and non-FD message formats. TXERRCNT_FAST and RXERRCNT_FAST are dedicated to count only the errors that occur in the data phase of CAN FD frames with the BRS bit set.

The Fault Confinement state (ESR1[FLTCONF]) is updated based on TXERRCNT and RXERRCNT counters only. TXERRCNT and RXERRCNT counters can be written in Freeze mode only. TXERRCNT_FAST and RXERRCNT_FAST counters are read-only except in Freeze mode when the CPU can write value zero. The rules for increasing and decreasing these counters are described in the CAN protocol and are completely implemented in the FlexCAN module.

The following are the basic rules for FlexCAN bus state transitions:

• If the value of TXERRCNT or RXERRCNT becomes greater than or equal to 128, ESR1[FLTCONF] is updated to reflect Error Passive state.
• If the FlexCAN state is Error Passive, and either TXERRCNT or RXERRCNT decrements to a value less than or equal to 127 when the other already satisfies this condition, ESR1[FLTCONF] is updated to reflect Error Active state.
• If the value of TXERRCNT becomes greater than 255, ESR1[FLTCONF] is updated to reflect Bus Off state, and an interrupt may be issued. The value of TXERRCNT is then reset to zero.
• If FlexCAN is in Bus Off state, then TXERRCNT is cascaded together with another internal counter to count the 128th occurrences of 11 consecutive recessive bits on the bus. Hence, TXERRCNT is reset to zero and counts in a manner where the internal counter counts 11 such bits and then wraps around when incrementing the TXERRCNT. When TXERRCNT reaches the value of 128, ESR1[FLTCONF] is updated to be Error Active and both error counters are reset to zero. At any instance of dominant bit following a stream of less than 11 consecutive recessive bits, the internal counter resets itself to zero without affecting the TXERRCNT value. The TXERRCNT_FAST counter is frozen during Bus Off.
• If during system startup only one node is operating, then its TXERRCNT increases in each message it is trying to transmit, as a result of acknowledge errors (indicated by the ACKERR bit in the Error and Status Register). After the transition to Error Passive state, TXERRCNT does not increment anymore by acknowledge errors. Therefore the device never goes to the Bus Off state.
- If RXERRCNT increases to a value greater than 127, it is not incremented further, even if more errors are detected when being a receiver. At the next successful message reception, the counter is set to a value between 119 and 127 to return to Error Active state.

- TXERRCNT_FAST and RXERRCNT_FAST error counter values increment and decrement based on errors detected only in the data phase of CAN FD frames with the BRS bit set, following the same increment and decrement rules as TXERRCNT and RXERRCNT counters. These counters do not wrap around and get stuck at their maximum value (255). They stop counting and keep their values frozen when FlexCAN is in Bus Off state. They are reset when FlexCAN leaves Bus Off state and restart counting after FlexCAN returns to Error Active state.

**NOTE**

See Fault confinement in the CAN Protocol standard (ISO 11898-1) for details.

### 45.6.2.8.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RXERRCNT_FAST</td>
<td>TXERRCNT_FAST</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RXERRCNT</td>
<td>TXERRCNT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 45.6.2.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24 RXERRCNT_FAST</td>
<td>Receive Error Counter for fast bits</td>
</tr>
<tr>
<td></td>
<td>Receive error counter for errors detected in the data phase of received CAN FD messages with the BRS bit set. The RXERRCNT_FAST counter is read-only except in Freeze mode, where the CPU can write an 8-bit zero value only.</td>
</tr>
<tr>
<td>23-16 TXERRCNT_FAST</td>
<td>Transmit Error Counter for fast bits</td>
</tr>
<tr>
<td></td>
<td>Transmit error counter for errors detected in the data phase of transmitted CAN FD messages with the BRS bit set. The TXERRCNT_FAST counter is read-only except in Freeze mode, where the CPU can write an 8-bit zero value only.</td>
</tr>
<tr>
<td>15-8 RXERRCNT</td>
<td>Receive Error Counter</td>
</tr>
<tr>
<td></td>
<td>Receive error counter for all errors detected in received messages. The RXERRCNT counter is read-only except in Freeze mode, where it can be written by the CPU.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-0 TXERRCNT</td>
<td>Transmit error counter for all errors detected in transmitted messages. The TXERRCNT counter is read-only except in Freeze mode, where it can be written by the CPU.</td>
</tr>
</tbody>
</table>

### 45.6.2.9 Error and Status 1 register (ESR1)

#### 45.6.2.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ESR1</td>
<td>20h</td>
</tr>
</tbody>
</table>

#### 45.6.2.9.2 Function

This register reports various error conditions detected in the reception and transmission of a CAN frame, some general status of the device, and is the source of some interrupts to the CPU. The reported error conditions are:

- Errors detected in CAN frames of any format:
  - BIT1ERR
  - BIT0ERR
  - ACKKERR
  - CRCERR
  - FRMERR
  - STFERR
- Errors detected in the data phase of CAN FD frames with the BRS bit set only:
  - BIT1ERR_FAST
  - BIT0ERR_FAST
  - CRCERR_FAST
  - FRMERR_FAST
  - STFERR_FAST

An error detected in a single CAN frame may be reported by one or more error flags. Also, error reporting is cumulative, in case more error events happen in the next frames when the CPU does not attempt to read this register.

Status bits:
- TXWRN
- RXWRN
It is recommended that the CPU use the following procedure when servicing interrupt requests generated by these bits:

1. Read this register to capture all error condition and status bits. This action clears the respective bits that were set since the last read access.
2. Write 1 to clear the interrupt bit that has triggered the interrupt request.
3. Write 1 to clear the ERR_OVR bit, if it is set.

Starting from all error flags cleared, a first error event sets either the ERRINT or the ERRINT_FAST (provided the corresponding mask bit is asserted). If other error events in subsequent frames happen before the CPU serves the interrupt request, the ERR_OVR bit is set to indicate that errors from different frames have accumulated.

<table>
<thead>
<tr>
<th>SYNCH</th>
<th>IDLE</th>
<th>TX</th>
<th>RX</th>
<th>FlexCAN state</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Not synchronized to CAN bus</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>x</td>
<td>x</td>
<td>Idle</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Transmitting</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Receiving</td>
</tr>
</tbody>
</table>

**NOTE**
See Fault confinement in the CAN Protocol standard (ISO 11898-1) for details.
45.6.2.9.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>BIT1ERR_FAS</td>
<td>BIT0ERR_FAS</td>
<td>0</td>
<td>CRCERR_FAS</td>
<td>FRMERR_FAS</td>
<td>STFERR_FAS</td>
<td>0</td>
<td>ERROV</td>
<td>R</td>
<td>ERRINT_FAS</td>
<td>T</td>
<td>BOFFDONEINT</td>
<td>T</td>
<td>SYNCH</td>
<td>TWINT</td>
<td>RWINT</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>BIT1ERR</td>
<td>BIT0ERR</td>
<td>ACKERR</td>
<td>CRCERR</td>
<td>FRMERR</td>
<td>STFERR</td>
<td>TXWRN</td>
<td>RXWRN</td>
<td>IDLE</td>
<td>TX</td>
<td>FLTCNF</td>
<td>R</td>
<td>X</td>
<td>BOFFINT</td>
<td>ERRINT</td>
<td>T</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

45.6.2.9.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 BIT1ERR_FAST</td>
<td>Bit1 Error in the Data Phase of CAN FD frames with the BRS bit set. This bit indicates when an inconsistency occurs between the transmitted and the received bit in the data phase of CAN FD frames with the BRS bit set.</td>
</tr>
<tr>
<td>0b - No such occurrence.</td>
<td></td>
</tr>
<tr>
<td>1b - At least one bit sent as recessive is received as dominant.</td>
<td></td>
</tr>
<tr>
<td>30 BIT0ERR_FAST</td>
<td>Bit0 Error in the Data Phase of CAN FD frames with the BRS bit set. This bit indicates when an inconsistency occurs between the transmitted and the received bit in the data phase of CAN FD frames with the BRS bit set.</td>
</tr>
<tr>
<td>0b - No such occurrence.</td>
<td></td>
</tr>
<tr>
<td>1b - At least one bit sent as dominant is received as recessive.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>28 CRCERR_FAST</td>
<td>Cyclic Redundancy Check Error in the CRC field of CAN FD frames with the BRS bit set. This bit indicates that a CRC error has been detected by the receiver node in the CRC field of CAN FD frames with the BRS bit set, that is, the calculated CRC is different from the received.</td>
</tr>
<tr>
<td>0b - No such occurrence.</td>
<td></td>
</tr>
<tr>
<td>1b - A CRC error occurred since last read of this register.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>27 FRMERR_FAST</td>
<td>Form Error in the Data Phase of CAN FD frames with the BRS bit set. This bit indicates that a form error has been detected by the receiver node in the data phase of CAN FD frames with the BRS bit set, that is, a fixed-form bit field contains at least one illegal bit.</td>
</tr>
<tr>
<td>0b - No such occurrence.</td>
<td></td>
</tr>
<tr>
<td>1b - A form error occurred since last read of this register.</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>26</td>
<td>STFERR_FAST: Stuffing Error in the Data Phase of CAN FD frames with the BRS bit set.</td>
</tr>
<tr>
<td></td>
<td>This bit indicates that a stuffing error has been detected in the data phase of CAN FD frames with the BRS bit set.</td>
</tr>
<tr>
<td></td>
<td>0b - No such occurrence.</td>
</tr>
<tr>
<td></td>
<td>1b - A stuffing error occurred since last read of this register.</td>
</tr>
<tr>
<td>25-22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>ERROVR: Error Overrun</td>
</tr>
<tr>
<td></td>
<td>This bit indicates that an error condition occurred when any error flag is already set.</td>
</tr>
<tr>
<td></td>
<td>This bit is cleared by writing it to 1.</td>
</tr>
<tr>
<td></td>
<td>0b - Overrun has not occurred.</td>
</tr>
<tr>
<td></td>
<td>1b - Overrun has occurred.</td>
</tr>
<tr>
<td>20</td>
<td>ERRINT_FAST: Error interrupt for errors detected in Data Phase of CAN FD frames with BRS bit set</td>
</tr>
<tr>
<td></td>
<td>This bit indicates that at least one of the error bits detected in the data phase of CAN FD frames with the BRS bit set (BIT1ERR_FAST, BIT0ERR_FAST, CRCERR_FAST, FRMERR_FAST, or STFERR_FAST) is set.</td>
</tr>
<tr>
<td></td>
<td>If the corresponding mask bit CTRL2[ERRMSK_FAST] is set, an interrupt is generated to the CPU.</td>
</tr>
<tr>
<td></td>
<td>This bit is cleared by writing it to 1. Writing 0 has no effect.</td>
</tr>
<tr>
<td></td>
<td>0b - No such occurrence.</td>
</tr>
<tr>
<td></td>
<td>1b - Indicates setting of any error bit detected in the data phase of CAN FD frames with the BRS bit set.</td>
</tr>
<tr>
<td>19</td>
<td>BOFFDONEINT: Bus Off Done Interrupt</td>
</tr>
<tr>
<td></td>
<td>This bit is set when the Tx Error Counter (TXERRCNT) has finished counting 128 occurrences of 11 consecutive recessive bits on the CAN bus and is ready to leave Bus Off.</td>
</tr>
<tr>
<td></td>
<td>If the corresponding mask bit in the Control 2 Register (BOFFDONEMSK) is set, an interrupt is generated to the CPU.</td>
</tr>
<tr>
<td></td>
<td>This bit is cleared by writing it to 1. Writing 0 has no effect.</td>
</tr>
<tr>
<td></td>
<td>0b - No such occurrence.</td>
</tr>
<tr>
<td></td>
<td>1b - FlexCAN module has completed Bus Off process.</td>
</tr>
<tr>
<td>18</td>
<td>SYNCH: CAN Synchronization Status</td>
</tr>
<tr>
<td></td>
<td>This read-only flag indicates whether the FlexCAN is synchronized to the CAN bus and able to participate in the communication process.</td>
</tr>
<tr>
<td></td>
<td>It is set and cleared by the FlexCAN. See the table in the overall ESR1 register description.</td>
</tr>
<tr>
<td></td>
<td>0b - FlexCAN is not synchronized to the CAN bus.</td>
</tr>
<tr>
<td></td>
<td>1b - FlexCAN is synchronized to the CAN bus.</td>
</tr>
<tr>
<td>17</td>
<td>TWRNINT: Tx Waring Interrupt Flag</td>
</tr>
<tr>
<td></td>
<td>If MCR[WRNEN] is asserted, TWRNINT is set when the TXWRN flag transitions from 0 to 1, meaning that the Tx error counter reached 96.</td>
</tr>
<tr>
<td></td>
<td>If the corresponding mask bit in the Control 1 Register (CTRL1[TWRNMSK]) is set, an interrupt is generated to the CPU.</td>
</tr>
<tr>
<td></td>
<td>When WRNEN is negated, this flag is masked. CPU must clear this flag before disabling the bit.</td>
</tr>
<tr>
<td></td>
<td>Otherwise it will be set when WRNEN is set again. Writing 0 has no effect. This flag is not generated during Bus Off state.</td>
</tr>
<tr>
<td></td>
<td>This bit is not updated during Freeze mode.</td>
</tr>
<tr>
<td></td>
<td>0b - No such occurrence.</td>
</tr>
<tr>
<td></td>
<td>1b - The Tx error counter transitioned from less than 96 to greater than or equal to 96.</td>
</tr>
<tr>
<td>16</td>
<td>RWRNINT: Rx Warning Interrupt Flag</td>
</tr>
<tr>
<td></td>
<td>If MCR[WRNEN] is asserted, RWRNINT is set when the RXWRN flag transitions from 0 to 1, meaning that the Rx error counters reached 96.</td>
</tr>
<tr>
<td></td>
<td>If the corresponding mask bit in the Control 1 Register (CTRL1[RWRNMSK]) is set, an interrupt is generated to the CPU.</td>
</tr>
<tr>
<td></td>
<td>When WRNEN is negated, this flag is masked. CPU must clear this flag before disabling the bit.</td>
</tr>
<tr>
<td></td>
<td>Otherwise it will be set when WRNEN is set again. Writing 0 has no effect. This bit is not updated during Freeze mode.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15 BIT1ERR | Bit1 Error  
This bit indicates when an inconsistency occurs between the transmitted and the received bit in a non-CAN FD message or in the arbitration or data phase of a CAN FD message.  
**NOTE:** This bit is not set by a transmitter in case of arbitration field or ACK slot, or in case of a node sending a passive error flag that detects dominant bits.  
0b - No such occurrence.  
1b - At least one bit sent as recessive is received as dominant. |
| 14 BIT0ERR | Bit0 Error  
This bit indicates when an inconsistency occurs between the transmitted and the received bit in a non-CAN FD message or in the arbitration or data phase of a CAN FD message.  
0b - No such occurrence.  
1b - At least one bit sent as dominant is received as recessive. |
| 13 ACKERR | Acknowledge Error  
This bit indicates that an Acknowledge Error has been detected by the transmitter node, that is, a dominant bit has not been detected during the ACK SLOT.  
0b - No such occurrence.  
1b - An ACK error occurred since last read of this register. |
| 12 CRCERR | Cyclic Redundancy Check Error  
This bit indicates that a CRC error has been detected by the receiver node either in a non-FD message or in the arbitration or data phase of a frame in CAN FD format, that is, the calculated CRC is different from the received.  
0b - No such occurrence.  
1b - A CRC error occurred since last read of this register. |
| 11 FRMERR | Form Error  
This bit indicates that a form error has been detected in a non-FD message or else in an FD message's arbitration or data phase by the receiver node, that is, a fixed-form bit field contains at least one illegal bit.  
0b - No such occurrence.  
1b - A Form Error occurred since last read of this register. |
| 10 STFERR | Stuffing Error  
This bit indicates that a stuffing error has been detected in a non-FD message or else in an FD message's arbitration or data phase by the receiver node.  
0b - No such occurrence.  
1b - A stuffing error occurred since last read of this register. |
| 9 TXWRN | TX Error Warning  
This bit indicates when repetitive errors are occurring during message transmission and is affected by the value of TXERRCNT in ECR register only. This bit is not updated during Freeze mode.  
0b - No such occurrence.  
1b - TXERRCNT is greater than or equal to 96. |
| 8 RXWRN | Rx Error Warning  
This bit indicates when repetitive errors are occurring during message reception and is affected by the value of RXERRCNT in ECR register only. This bit is not updated during Freeze mode.  
0b - No such occurrence.  
1b - RXERRCNT is greater than or equal to 96. |
| 7 IDLE | |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| **IDLE** | This bit indicates when CAN bus is in IDLE state. See the table in the overall ESR1 register description.  
|        | 0b - No such occurrence.  
|        | 1b - CAN bus is now IDLE. |
| **6 TX** | FlexCAN In Transmission  
|         | This bit indicates if FlexCAN is transmitting a message. See the table in the overall ESR1 register description.  
|         | 0b - FlexCAN is not transmitting a message.  
|         | 1b - FlexCAN is transmitting a message. |
| **5-4 FLTCONF** | Fault Confinement State  
|               | This 2-bit field indicates the confinement state of the FlexCAN module.  
|               | If CTRL1[LOM] is asserted, after a delay that depends on the CAN bit timing, ESR1[FLTCONF] will indicate Error Passive. The very same delay affects the way that ESR1[FLTCONF] reflects an update to ECR register by the CPU. It may be necessary to wait up to one CAN bit time to get them coherent again.  
|               | This bit field is affected by soft reset, but if the LOM bit is asserted, its reset value lasts just one CAN bit. After this time, ESR1[FLTCONF] reports Error Passive.  
|               | 00b - Error Active  
|               | 01b - Error Passive  
|               | 1xb - Bus Off |
| **3 RX** | FlexCAN In Reception  
|          | This bit indicates if FlexCAN is receiving a message. See the table in the overall ESR1 register description.  
|          | 0b - FlexCAN is not receiving a message.  
|          | 1b - FlexCAN is receiving a message. |
| **2 BOFFINT** | Bus Off Interrupt  
|             | This bit is set when FlexCAN enters Bus Off state. If the corresponding mask bit in the Control Register 1 (CTRL1[BOFFMSK]) is set, an interrupt is generated to the CPU. This bit is cleared by writing it to 1. Writing 0 has no effect.  
|             | 0b - No such occurrence.  
|             | 1b - FlexCAN module entered Bus Off state. |
| **1 ERRINT** | Error Interrupt  
|             | This bit indicates that at least one of the error bits (BIT1ERR, BIT0ERR, ACKERR, CRCERR, FRMERR, or STFERR) is set. If the corresponding mask bit CTRL1[ERRMSK] is set, an interrupt is generated to the CPU. This bit is cleared by writing it to 1. Writing 0 has no effect.  
|             | 0b - No such occurrence.  
|             | 1b - Indicates setting of any error bit in the Error and Status register. |
| **0 WAKINT** | Wake-Up Interrupt  
|             | This field applies when FlexCAN is in low-power mode under Self Wake Up mechanism:  
|             | • Doze mode  
|             | • Stop mode  
|             | When a recessive-to-dominant transition is detected on the CAN bus and if MCR[WAKMSK] is set, an interrupt is generated to the CPU. This bit is cleared by writing it to 1.  
|             | When MCR[SLFWAK] is negated, this flag is masked. The CPU must clear this flag before disabling the bit. Otherwise it will be set when SLFWAK is set again. Writing 0 has no effect.  
|             | 0b - No such occurrence.  
|             | 1b - Indicates a recessive to dominant transition was received on the CAN bus. |
45.6.2.10 Interrupt Masks 2 register (IMASK2)

45.6.2.10.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMASK2</td>
<td>24h</td>
</tr>
</tbody>
</table>

45.6.2.10.2 Function

This register allows any number of a range of the 32 message buffer interrupts to be enabled or disabled for MB63 to MB32. It contains one interrupt mask bit per buffer, enabling the CPU to determine which buffer generates an interrupt after a successful transmission or reception, that is, when the corresponding IFLAG2 bit is set.

45.6.2.10.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

45.6.2.10.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Buffer MB i Mask</td>
</tr>
<tr>
<td>BUF63TO32M</td>
<td>Each bit enables or disables the corresponding FlexCAN message buffer interrupt for MB63 to MB32.</td>
</tr>
</tbody>
</table>

**NOTE:** Setting or clearing a bit in the IMASK2 Register can assert or negate an interrupt request, if the corresponding IFLAG2 bit is set.

- 0b - The corresponding buffer interrupt is disabled.
- 1b - The corresponding buffer interrupt is enabled.
### 45.6.2.11 Interrupt Masks 1 register (IMASK1)

#### 45.6.2.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMASK1</td>
<td>28h</td>
</tr>
</tbody>
</table>

#### 45.6.2.11.2 Function

This register allows any number of a range of the 32 message buffer interrupts to be enabled or disabled for MB31 to MB0. It contains one interrupt mask bit per buffer, enabling the CPU to determine which buffer generates an interrupt after a successful transmission or reception, that is, when the corresponding IFLAG1 bit is set.

#### 45.6.2.11.3 Diagram

#### 45.6.2.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUF31TO0M</td>
<td>Buffer MB i Mask</td>
</tr>
<tr>
<td></td>
<td>Each bit enables or disables the corresponding FlexCAN message buffer interrupt for MB31 to MB0.</td>
</tr>
</tbody>
</table>

**NOTE:** Setting or clearing a bit in the IMASK1 Register can assert or negate an interrupt request, if the corresponding IFLAG1 bit is set.

- 0b - The corresponding buffer interrupt is disabled.
- 1b - The corresponding buffer interrupt is enabled.
45.6.2.12  Interrupt Flags 2 register (IFLAG2)

45.6.2.12.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IFLAG2</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

45.6.2.12.2  Function

This register defines the flags for the 32 message buffer interrupts for MB63 to MB32. It contains one interrupt flag bit per buffer. Each successful transmission or reception sets the respective IFLAG2 bit. If the corresponding IMASK2 bit is set, an interrupt will be generated. The interrupt flag must be cleared by writing 1 to it. Writing 0 has no effect.

Before updating MCR[MAXMB], CPU must service the IFLAG2 bits whose MB value is greater than the MAXMB to be updated; otherwise, they will remain set and be inconsistent with the number of MBs available.

45.6.2.12.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

45.6.2.12.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Buffer MB i Interrupt</td>
</tr>
<tr>
<td>BUF63TO32I</td>
<td>Each bit flags the corresponding FlexCAN message buffer interrupt for MB63 to MB32.</td>
</tr>
<tr>
<td></td>
<td>0b - The corresponding buffer has no occurrence of successfully completed transmission or reception.</td>
</tr>
<tr>
<td></td>
<td>1b - The corresponding buffer has successfully completed transmission or reception.</td>
</tr>
</tbody>
</table>
### 45.6.2.13 Interrupt Flags 1 register (IFLAG1)

#### 45.6.2.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IFLAG1</td>
<td>30h</td>
</tr>
</tbody>
</table>

#### 45.6.2.13.2 Function

This register defines the flags for the 32 message buffer interrupts for MB31 to MB0. It contains one interrupt flag bit per buffer. Each successful transmission or reception sets the corresponding IFLAG1 bit. If the corresponding IMASK1 bit is set, an interrupt will be generated. The interrupt flag must be cleared by writing 1 to it. Writing 0 has no effect. There is an exception when DMA for Rx FIFO is enabled, as described below.

The BUF7I to BUF5I flags are also used to represent FIFO interrupts when the Rx FIFO is enabled. When MCR[RFEN] is set and MCR[DMA] is negated, the function of the eight least significant interrupt flags changes: BUF7I, BUF6I, and BUF5I indicate operating conditions of the FIFO, BUF0I is used to empty FIFO, and BUF4I to BUF1I bits are reserved.

Before enabling MCR[RFEN], the CPU must service the IFLAG bits asserted in the Rx FIFO region; see Rx FIFO. Otherwise, these IFLAG bits will mistakenly show the related MBs now belonging to FIFO as having contents to be serviced. When MCR[RFEN] is negated, the FIFO flags must be cleared. The same care must be taken when a CTRL2[RFFN] value is selected, extending Rx FIFO filters beyond MB7. For example, when RFFN is 0x8, the MB0–23 range is occupied by Rx FIFO filters and related IFLAG bits must be cleared.

When both the MCR[RFEN] and MCR[DMA] bits are asserted (DMA feature for Rx FIFO enabled), the function of the eight least significant interrupt flags (BUF7I–BUF0I) are changed to support the DMA operation. BUF7I and BUF6I are not used, as well as BUF4I–BUF1I. BUF5I indicates operating condition of FIFO, and BUF0I is used to empty FIFO. Moreover, BUF5I does not generate a CPU interrupt, but generates a DMA request. IMASK1 bits in Rx FIFO region are not considered when bit MCR[DMA] is enabled. In addition the CPU must not clear the flag BUF5I when DMA is enabled. Before enabling MCR[DMA], the CPU must service the IFLAGs asserted in the Rx FIFO region. When MCR[DMA] is negated, the FIFO must be empty. FIFO must be disabled when MCR[FDEN] is enabled.
Before updating MCR[MAXMB], CPU must service the IFLAG1 bits whose MB value is greater than the MCR[MAXMB] to be updated; otherwise, they will remain set and be inconsistent with the number of MBs available.

### 45.6.2.13.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 45.6.2.13.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-8</td>
<td>Buffer MBi Interrupt</td>
</tr>
<tr>
<td>BUF31TO8I</td>
<td>Each bit flags the corresponding FlexCAN message buffer interrupt for MB31 to MB8.</td>
</tr>
<tr>
<td></td>
<td>0b - The corresponding buffer has no occurrence of successfully completed transmission or reception.</td>
</tr>
<tr>
<td></td>
<td>1b - The corresponding buffer has successfully completed transmission or reception.</td>
</tr>
<tr>
<td>7</td>
<td>Buffer MB7 Interrupt Or Rx FIFO Overflow</td>
</tr>
<tr>
<td>BUF7I</td>
<td>When MCR[RFEN] is cleared (Rx FIFO disabled), this bit flags the interrupt for MB7.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This flag is cleared by the FlexCAN whenever MCR[RFEN] is changed by CPU writes.</td>
</tr>
<tr>
<td></td>
<td>The BUF7I flag represents Rx FIFO overflow when MCR[RFEN] is set. In this case, the flag indicates that a message was lost because the Rx FIFO is full. Note that the flag will not be asserted when the Rx FIFO is full and the message was captured by a mailbox.</td>
</tr>
<tr>
<td></td>
<td>0b - No occurrence of MB7 completing transmission/reception when MCR[RFEN]=0, or of Rx FIFO overflow when MCR[RFEN]=1</td>
</tr>
<tr>
<td></td>
<td>1b - MB7 completed transmission/reception when MCR[RFEN]=0, or Rx FIFO overflow when MCR[RFEN]=1</td>
</tr>
<tr>
<td>6</td>
<td>Buffer MB6 Interrupt Or Rx FIFO Warning</td>
</tr>
<tr>
<td>BUF6I</td>
<td>When MCR[RFEN] is cleared (Rx FIFO disabled), this bit flags the interrupt for MB6.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>This flag is cleared by the FlexCAN whenever MCR[RFEN] is changed by CPU writes.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
---|---
| Field | Function |
| The BUF6I flag represents Rx FIFO warning when MCR[RFEN] is set. In this case, the flag indicates when the number of unread messages within the Rx FIFO is increased to five from four due to the reception of a new one, meaning that the Rx FIFO is almost full. Note that if the flag is cleared when the number of unread messages is greater than four, it does not assert again until the number of unread messages within the Rx FIFO is decreased to be equal to or less than four. |
| 0b - No occurrence of MB6 completing transmission/reception when MCR[RFEN]=0, or of Rx FIFO almost full when MCR[RFEN]=1 |
| 1b - MB6 completed transmission/reception when MCR[RFEN]=0, or Rx FIFO almost full when MCR[RFEN]=1 |
| 5 | BUF5I | Buffer MB5 Interrupt Or Frames available in Rx FIFO |
| When MCR[RFEN] is cleared (Rx FIFO disabled), this field flags the interrupt for MB5. |
| NOTE: This flag is cleared by the FlexCAN whenever MCR[RFEN] is changed by CPU writes. |
| When MCR[RFEN] is set (Rx FIFO enabled), the BUF5I flag represents "Frames available in Rx FIFO" and indicates that at least one frame is available to be read from the Rx FIFO. When the MCR[DMA] bit is enabled, this flag generates a DMA request and the CPU must not clear this bit by writing 1 in BUF5I. |
| 0b - No occurrence of MB5 completing transmission/reception when MCR[RFEN]=0, or of frame(s) available in the FIFO, when MCR[RFEN]=1 |
| 1b - MB5 completed transmission/reception when MCR[RFEN]=0, or frame(s) available in the Rx FIFO when MCR[RFEN]=1. It generates a DMA request in case of MCR[RFEN] and MCR[DMA] are enabled. |
| 4-1 | BUF4TO1I | Buffer MBi Interrupt Or Reserved |
| When MCR[RFEN] is cleared (Rx FIFO disabled), these bits flag the interrupts for MB4 to MB1. |
| NOTE: These flags are cleared by the FlexCAN whenever MCR[RFEN] is changed by CPU writes. |
| The BUF4TO1I flags are reserved when MCR[RFEN] is set. |
| 0b - The corresponding buffer has no occurrence of successfully completed transmission or reception when MCR[RFEN]=0. |
| 1b - The corresponding buffer has successfully completed transmission or reception when MCR[RFEN]=0. |
| 0 | BUF0I | Buffer MB0 Interrupt Or Clear FIFO bit |
| When MCR[RFEN] is cleared (Rx FIFO disabled), this field flags the interrupt for MB0. If the Rx FIFO is enabled, this bit is used to trigger the clear FIFO operation. This operation empties FIFO contents. Before performing this operation the CPU must service all FIFO related IFLAGs. When MCR[DMA] is enabled this operation also clears the BUF5I flag and consequently aborts the DMA request. The clear FIFO operation occurs when the CPU writes 1 in BUF0I. It is only allowed in Freeze mode and is blocked by hardware in other conditions. |
| 0b - The corresponding buffer has no occurrence of successfully completed transmission or reception when MCR[RFEN]=0. |
| 1b - The corresponding buffer has successfully completed transmission or reception when MCR[RFEN]=0. |

### 45.6.2.14 Control 2 register (CTRL2)
45.6.2.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL2</td>
<td>34h</td>
</tr>
</tbody>
</table>

45.6.2.14.2 Function

This register complements Control1 register, providing control bits for memory write access in Freeze mode, for extending FIFO filter quantity, and to adjust the operation of internal FlexCAN processes like matching and arbitration.

The contents of this register are not affected by soft reset.

This table shows how the Rx FIFO filter structure is determined by the value of CTRL2[RFFN]. See the CTRL2[RFFN] field description for more information.

<table>
<thead>
<tr>
<th>RFFN[3:0]</th>
<th>Number of Rx FIFO filter elements</th>
<th>Message buffers occupied by Rx FIFO and ID filter table</th>
<th>Remaining available mailboxes</th>
<th>Rx FIFO ID filter table elements affected by Rx individual masks</th>
<th>Rx FIFO ID filter table elements affected by Rx FIFO global mask</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0</td>
<td>8</td>
<td>MB 0-7</td>
<td>MB 8-63</td>
<td>Elements 0-7</td>
<td>none</td>
</tr>
<tr>
<td>0x1</td>
<td>16</td>
<td>MB 0-9</td>
<td>MB 10-63</td>
<td>Elements 0-9</td>
<td>Elements 10-15</td>
</tr>
<tr>
<td>0x2</td>
<td>24</td>
<td>MB 0-11</td>
<td>MB 12-63</td>
<td>Elements 0-11</td>
<td>Elements 12-23</td>
</tr>
<tr>
<td>0x3</td>
<td>32</td>
<td>MB 0-13</td>
<td>MB 14-63</td>
<td>Elements 0-13</td>
<td>Elements 14-31</td>
</tr>
<tr>
<td>0x4</td>
<td>40</td>
<td>MB 0-15</td>
<td>MB 16-63</td>
<td>Elements 0-15</td>
<td>Elements 16-39</td>
</tr>
<tr>
<td>0x5</td>
<td>48</td>
<td>MB 0-17</td>
<td>MB 18-63</td>
<td>Elements 0-17</td>
<td>Elements 18-47</td>
</tr>
<tr>
<td>0x6</td>
<td>56</td>
<td>MB 0-19</td>
<td>MB 20-63</td>
<td>Elements 0-19</td>
<td>Elements 20-55</td>
</tr>
<tr>
<td>0x7</td>
<td>64</td>
<td>MB 0-21</td>
<td>MB 22-63</td>
<td>Elements 0-21</td>
<td>Elements 22-63</td>
</tr>
<tr>
<td>0x8</td>
<td>72</td>
<td>MB 0-23</td>
<td>MB 24-63</td>
<td>Elements 0-23</td>
<td>Elements 24-71</td>
</tr>
<tr>
<td>0x9</td>
<td>80</td>
<td>MB 0-25</td>
<td>MB 26-63</td>
<td>Elements 0-25</td>
<td>Elements 26-79</td>
</tr>
<tr>
<td>0xA</td>
<td>88</td>
<td>MB 0-27</td>
<td>MB 28-63</td>
<td>Elements 0-27</td>
<td>Elements 28-87</td>
</tr>
<tr>
<td>0xB</td>
<td>96</td>
<td>MB 0-29</td>
<td>MB 30-63</td>
<td>Elements 0-29</td>
<td>Elements 30-95</td>
</tr>
<tr>
<td>0xC</td>
<td>104</td>
<td>MB 0-31</td>
<td>MB 32-63</td>
<td>Elements 0-31</td>
<td>Elements 32-103</td>
</tr>
<tr>
<td>0xD</td>
<td>112</td>
<td>MB 0-33</td>
<td>MB 34-63</td>
<td>Elements 0-31</td>
<td>Elements 32-111</td>
</tr>
<tr>
<td>0xE</td>
<td>120</td>
<td>MB 0-35</td>
<td>MB 36-63</td>
<td>Elements 0-31</td>
<td>Elements 32-119</td>
</tr>
<tr>
<td>0xF</td>
<td>128</td>
<td>MB 0-37</td>
<td>MB 38-63</td>
<td>Elements 0-31</td>
<td>Elements 32-127</td>
</tr>
</tbody>
</table>
### 45.6.2.14.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>ERRMSK_FAS</td>
<td>T</td>
<td>BOFFDONEMS</td>
<td>RFFN</td>
<td></td>
<td>TASD</td>
<td></td>
<td>MRP</td>
<td>RR</td>
<td>S</td>
<td>EACE</td>
<td>N</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>TIMER_SRC</td>
<td>PREXCE</td>
<td></td>
<td>ISOCANFDEN</td>
<td>EDFLTDI</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 45.6.2.14.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>ERRMSK_FAST</td>
</tr>
<tr>
<td>ERRMSK_FAST</td>
<td>Error Interrupt Mask for errors detected in the data phase of fast CAN FD frames</td>
</tr>
<tr>
<td>This bit provides a mask for the ERRINT_FAST interrupt in ESR1 register.</td>
<td></td>
</tr>
<tr>
<td>0b - ERRINT_FAST error interrupt disabled.</td>
<td></td>
</tr>
<tr>
<td>1b - ERRINT_FAST error interrupt enabled.</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>BOFFDONEMS_K</td>
</tr>
<tr>
<td>BOFFDONEMS_K</td>
<td>Bus Off Done Interrupt Mask</td>
</tr>
<tr>
<td>This bit provides a mask for the bus off done interrupt in ESR1 register.</td>
<td></td>
</tr>
<tr>
<td>0b - Bus off done interrupt disabled.</td>
<td></td>
</tr>
<tr>
<td>1b - Bus off done interrupt enabled.</td>
<td></td>
</tr>
<tr>
<td>29</td>
<td>Reserved</td>
</tr>
<tr>
<td>28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-24</td>
<td>RFFN</td>
</tr>
<tr>
<td>RFFN</td>
<td>Number Of Rx FIFO Filters</td>
</tr>
<tr>
<td>This 4-bit field defines the number of Rx FIFO filters, as shown in Table 45-20. The maximum selectable number of filters is determined by the chip. This field can only be written in Freeze mode as it is blocked by hardware in other modes. This field must not be programmed with values that cause the number of message buffers occupied by Rx FIFO and ID Filter to exceed the number of mailboxes present, as defined by MCR[MAXMB].</td>
<td></td>
</tr>
<tr>
<td>NOTE: Each group of eight filters occupies a memory space equivalent to two message buffers, which means that the more filters are implemented the fewer mailboxes will be available.</td>
<td></td>
</tr>
<tr>
<td>Considering that the Rx FIFO occupies the memory space originally reserved for MB0-5, RFFN should be programmed with a value corresponding to a number of filters not greater than the number of available memory words, which can be calculated as follows:</td>
<td></td>
</tr>
<tr>
<td>(SETUP_MB - 6) × 4</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
where SETUP_MB is the smaller of the parameter NUMBER_OF_MB and MCR[\text{MAXMB}].

The number of remaining mailboxes available will be:

\[(\text{SETUP_MB} - 8) - (\text{RFFN} \times 2)\]

If the number of Rx FIFO filters programmed through RFFN exceeds the SETUP_MB value (memory space available), then the exceeding ones will not be functional.

**NOTE:**
- The number of the last remaining available mailboxes is defined by the smaller of \(\text{NUMBER_OF_MB} - 1\) and \(\text{MCR[MAXMB]}\).
- If Rx Individual Mask registers are not enabled then all Rx FIFO filters are affected by the Rx FIFO Global Mask.

### Field | Function
--- | ---

| 23-19 | Tx Arbitration Start Delay |
|       | This 5-bit field indicates how many CAN bits the Tx arbitration process start point can be delayed from the first bit of CRC field on CAN bus. See Tx arbitration start delay for more details. This field can be written only in Freeze mode because it is blocked by hardware in other modes. |

| 18 | Mailboxes Reception Priority |
|     | If this bit is set the matching process starts from the mailboxes and if no match occurs the matching continues on the Rx FIFO. This bit can be written only in Freeze mode because it is blocked by hardware in other modes. |
|     | 0b - Matching starts from Rx FIFO or Enhanced Rx FIFO and continues on mailboxes. |
|     | 1b - Matching starts from mailboxes and continues on Rx FIFO. |

| 17 | Remote Request Storing |
|     | If this bit is asserted a remote request frame is submitted to a matching process and stored in the corresponding message buffer in the same fashion as a data frame. No automatic remote response frame will be generated. |
|     | If this bit is negated the remote request frame is submitted to a matching process and an automatic remote response frame is generated if a message buffer with CODE=0b1010 is found with the same ID. |
|     | This bit can be written only in Freeze mode because it is blocked by hardware in other modes. |
|     | 0b - Remote response frame is generated. |
|     | 1b - Remote request frame is stored. |

| 16 | Entire Frame Arbitration Field Comparison Enable For Rx Mailboxes |
|     | This bit controls the comparison of IDE and RTR bits within Rx mailbox filters with their corresponding bits in the incoming frame by the matching process. This bit does not affect matching for Rx FIFO. This bit can be written only in Freeze mode because it is blocked by hardware in other modes. |
|     | 0b - Rx mailbox filter’s IDE bit is always compared and RTR is never compared despite mask bits. |
|     | 1b - Enables the comparison of both Rx mailbox filter’s IDE and RTR bit with their corresponding bits within the incoming frame. Mask bits do apply. |

| 15 | Timer Source |
|     | Selects the time tick source used for incrementing the free running timer counter. This bit can be written in Freeze mode only. |
|     | 0b - The free running timer is clocked by the CAN bit clock, which defines the baud rate on the CAN bus. |
|     | 1b - The free running timer is clocked by an external time tick. The period can be either adjusted to be equal to the baud rate on the CAN bus, or a different value as required. See the device-specific section for details about the external time tick. |

| 14 | Protocol Exception Enable |
|     | This bit enables the protocol exception feature. |
|     | This field is writable only in Freeze mode. |

**NOTE:** See Protocol exception event in the CAN Protocol standard (ISO 11898-1) for details.
### 45.6.2.15 Error and Status 2 register (ESR2)

#### 45.6.2.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>ESR2</td>
<td>38h</td>
</tr>
</tbody>
</table>

#### 45.6.2.15.2 Function

This register reports some general status information.
45.6.2.15.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>LPTM</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>VPS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>IMB</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

45.6.2.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-23</td>
<td>Reserved</td>
</tr>
<tr>
<td>22-16</td>
<td>Lowest Priority Tx Mailbox</td>
</tr>
<tr>
<td>LPTM</td>
<td>If ESR2[VPS] is asserted, this field indicates the lowest number inactive mailbox (see the ESR2[IMB] bit description). If there is no inactive mailbox then the mailbox indicated depends on the value of CTRL1[LBUF]. If CTRL1[LBUF] is negated, then the mailbox indicated is the one that has the greatest arbitration value (see Highest-priority mailbox first). If CTRL1[LBUF] is asserted then the mailbox indicated is the highest number active Tx mailbox. If a Tx mailbox is being transmitted it is not considered in LPTM calculation. If ESR2[IMB] is not asserted and a frame is transmitted successfully, LPTM is updated with its mailbox number.</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Valid Priority Status</td>
</tr>
<tr>
<td>VPS</td>
<td>This bit indicates whether ESR2[IMB] and ESR2[LPTM] contents are currently valid or not. It is asserted upon every complete Tx arbitration process unless the CPU writes to Control and Status word of a mailbox that has already been scanned, that is, it is behind Tx Arbitration Pointer, during the Tx arbitration process. If there is no inactive mailbox and only one Tx mailbox that is being transmitted then VPS is not asserted. This bit is negated upon the start of every Tx arbitration process or upon a write to Control and Status word of any mailbox.</td>
</tr>
<tr>
<td>NOTE: ESR2[VPS] is not affected by any CPU write into Control Status (C/S) of an MB that is blocked by abort mechanism. When MCR[AEN] is asserted, the abort code write in C/S of an MB that is being transmitted (pending abort), or any write attempt into a Tx MB with IFLAG set is blocked. 0b - Contents of IMB and LPTM are invalid. 1b - Contents of IMB and LPTM are valid.</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Inactive Mailbox</td>
</tr>
<tr>
<td>IMB</td>
<td>If ESR2[VPS] is asserted, this bit indicates whether there is any inactive mailbox (CODE field is either 0b1000 or 0b0000). This bit is asserted in the following cases:</td>
</tr>
<tr>
<td></td>
<td>• During arbitration, if an ESR2[LPTM] is found and it is inactive.</td>
</tr>
<tr>
<td></td>
<td>• If ESR2[IMB] is not asserted and a frame is transmitted successfully.</td>
</tr>
<tr>
<td></td>
<td>This bit is always cleared in start of arbitration (see Arbitration process).</td>
</tr>
</tbody>
</table>

Table continues on the next page...
45.6.2.16 CRC register (CRCR)

45.6.2.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CRCR</td>
<td>44h</td>
</tr>
</tbody>
</table>

45.6.2.16.2 Function

This register provides information about the CRC of transmitted messages for non-FD messages. This register only reports the 15 low order bits of CRC calculations for messages in CAN FD format that require either 17 or 21 bits. For CAN FD format frames, the FDCRC register must be used. This register is updated at the same time the Tx interrupt flag is asserted.

NOTE
See CRC sequence calculation in the CAN Protocol standard (ISO 11898-1) for details.

45.6.2.16.3 Diagram
45.6.2.16.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-23</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>22-16</td>
<td>MBCRC</td>
</tr>
<tr>
<td></td>
<td>CRC Mailbox</td>
</tr>
<tr>
<td></td>
<td>This field indicates the number of the mailbox corresponding to the value in CRCR[TXCRC] field.</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>14-0</td>
<td>TXCRC</td>
</tr>
<tr>
<td></td>
<td>Transmitted CRC value</td>
</tr>
<tr>
<td></td>
<td>This field indicates the CRC value of the last transmitted message for non-FD frames. For FD frames, CRC value is reported in FDCRC register.</td>
</tr>
</tbody>
</table>

45.6.2.17 Rx FIFO Global Mask register (RXFGMASK)

45.6.2.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RXFGMASK</td>
<td>48h</td>
</tr>
</tbody>
</table>

45.6.2.17.2 Function

This register is located in RAM.

If Rx FIFO is enabled, RXFGMASK is used to mask the Rx FIFO ID filter table elements that do not have a corresponding RXIMR according to CTRL2[RFFN] field setting.

This register can only be written in Freeze mode as it is blocked by hardware in other modes.

The following table shows how the FGM bits correspond to each IDAF field.
Table 45-21. Correspondence of Rx FIFO global mask bits to IDF fields

<table>
<thead>
<tr>
<th>Rx FIFO ID filter table elements format (MCR[IDAM])</th>
<th>Identifier acceptance filter fields</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>RTR</td>
</tr>
<tr>
<td>C</td>
<td>—</td>
</tr>
</tbody>
</table>

1. If MCR[IDAM] is equivalent to format B, only the fourteen most significant bits of the identifier of the incoming frame are compared with the Rx FIFO filter.
2. If MCR[IDAM] is equivalent to format C, only the eight most significant bits of the identifier of the incoming frame are compared with the Rx FIFO filter.

45.6.2.17.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FGM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FGM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

45.6.2.17.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Rx FIFO Global Mask Bits</td>
</tr>
<tr>
<td>FGM</td>
<td>These bits mask the ID filter table elements bits in a perfect alignment. 0b - The corresponding bit in the filter is &quot;don't care.&quot; 1b - The corresponding bit in the filter is checked.</td>
</tr>
</tbody>
</table>

45.6.2.18 Rx FIFO Information register (RXFIR)
45.6.2.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RXFIR</td>
<td>4Ch</td>
</tr>
</tbody>
</table>

45.6.2.18.2 Function

RXFIR provides information on Rx FIFO.

This register is the port through which the CPU accesses the output of the RXFIR FIFO located in RAM. The RXFIR FIFO is written by the FlexCAN whenever a new message is moved into the Rx FIFO. Also, its output is updated whenever the output of the Rx FIFO is updated with the next message. See Rx FIFO for instructions on reading this register.

45.6.2.18.3 Diagram

45.6.2.18.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-9</td>
<td>Reserved</td>
</tr>
<tr>
<td>8-0 IDHIT</td>
<td>Identifier Acceptance Filter Hit Indicator</td>
</tr>
<tr>
<td></td>
<td>This field indicates which Identifier Acceptance filter was hit by the received message that is in the output of the Rx FIFO. If multiple filters match the incoming message ID then the first matching IDAF found (lowest number) by the matching process is indicated. This field is valid only when IFLAG1[BUF5I] is asserted.</td>
</tr>
</tbody>
</table>
45.6.2.19 CAN Bit Timing register (CBT)

45.6.2.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CBT</td>
<td>50h</td>
</tr>
</tbody>
</table>

45.6.2.19.2 Function

This register is an alternative way to store the CAN bit timing variables described in CTRL1 register. EPRESDIV, EPROPSEG, EPSEG1, EPSEG2, and ERJW are extended versions of PRESDIV, PROPSEG, PSEG1, PSEG2, and RJW fields respectively.

The BTF bit selects the use of the timing variables defined in this register.

The contents of this register are not affected by soft reset.

**NOTE**

The CAN bit variables in CTRL1 and in CBT are stored in the same register.

**NOTE**

When the CAN FD feature is enabled (MCR[FDEN] is set), always set CBT[BTF].

**NOTE**

The user must ensure bit time settings and protocol engine tolerance are in compliance with the CAN Protocol standard (ISO 11898-1).

45.6.2.19.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### 45.6.2.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 BTF | Bit Timing Format Enable  
Enables the use of extended CAN bit timing fields EPRESDIV, EPROPSEG, EPSEG1, EPSEG2, and ERJW replacing the CAN bit timing variables defined in CTRL1 register. This field can be written in Freeze mode only.  
0b - Extended bit time definitions disabled.  
1b - Extended bit time definitions enabled. |
| 30-21 EPRESDIV | Extended Prescaler Division Factor  
This 10-bit field defines the ratio between the PE clock frequency and the serial clock (Sclock) frequency when CBT[BTF] is asserted, otherwise it has no effect. It extends the CTRL1[PRESDIV] value range.  
The Sclock period defines the time quantum of the CAN protocol. For the reset value, the Sclock frequency is equal to the PE clock frequency (see Protocol timing). This field can be written only in Freeze mode because it is blocked by hardware in other modes.  
Sclock frequency = PE clock frequency / (EPRESDIV + 1) |
| 20-16 ERJW | Extended Resync Jump Width  
This 5-bit field defines the maximum number of time quanta that a bit time can be changed by one resynchronization when CBT[BTF] bit is asserted, otherwise it has no effect. It extends the CTRL1[RJW] value range.  
One time quantum is equal to the Sclock period. This field can be written only in Freeze mode because it is blocked by hardware in other modes.  
Resync Jump Width = ERJW + 1. |
| 15-10 EPROPSEG | Extended Propagation Segment  
This 6-bit field defines the length of the propagation segment in the bit time when CBT[BTF] bit is asserted, otherwise it has no effect. It extends the CTRL1[PROPSEG] value range. This field can be written only in Freeze mode because it is blocked by hardware in other modes.  
Propagation Segment Time = (EPROPSEG + 1) × Time-Quanta.  
Time-Quantum = one Sclock period. |
| 9-5 EPSEG1 | Extended Phase Segment 1  
This 5-bit field defines the length of phase segment 1 in the bit time when CBT[BTF] bit is asserted, otherwise it has no effect. It extends the CTRL1[PSEG1] value range. This field can be written only in Freeze mode because it is blocked by hardware in other modes.  
Phase Buffer Segment 1 = (EPSEG1 + 1) × Time-Quanta.  
Time-Quantum = one Sclock period. |
| 4-0 EPSEG2 | Extended Phase Segment 2  
This 5-bit field defines the length of phase segment 2 in the bit time when CBT[BTF] bit is asserted, otherwise it has no effect. It extends the CTRL1[PSEG2] value range. This field can be written only in Freeze mode because it is blocked by hardware in other modes.  
Phase Buffer Segment 1 = (EPSEG2 + 1) × Time-Quanta.  
Time-Quantum = one Sclock period. |
45.6.2.20  Rx Individual Mask registers (RXIMR0 - RXIMR63)

45.6.2.20.1  Offset

For \( n = 0 \) to \( 63 \):

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RXIMRn</td>
<td>( 880h + (n \times 4h) )</td>
</tr>
</tbody>
</table>

45.6.2.20.2  Function

The RX Individual Mask Registers are used to store the acceptance masks for ID filtering in Rx MBs and the Rx FIFO.

When the Rx FIFO is disabled (MCR[RFEN] bit is negated), an individual mask is provided for each available Rx mailbox on a one-to-one correspondence. When the Rx FIFO is enabled (MCR[RFEN] bit is asserted), an individual mask is provided for each Rx FIFO ID filter table element on a one-to-one correspondence depending on the setting of CTRL2[RFFN] (see Rx FIFO).

RXIMR0 stores the individual mask associated with either MB0 or ID filter table element 0, RXIMR1 stores the individual mask associated with either MB1 or ID filter table element 1, and so on.

RXIMR registers can only be accessed by the CPU when the module is in Freeze mode; otherwise, they are blocked by hardware. These registers are not affected by reset. They are located in RAM and must be explicitly initialized prior to any reception.

It is possible for the RXIMR memory region to be accessed as general purpose memory. See Bus interface for more information.

45.6.2.20.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MI</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MI</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
<td>u</td>
</tr>
</tbody>
</table>
```
45.6.2.20.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0 MI</td>
<td>Individual Mask Bits</td>
</tr>
<tr>
<td></td>
<td>Each individual mask bit masks the corresponding bit in both the mailbox filter and Rx FIFO ID filter table element in distinct ways.</td>
</tr>
<tr>
<td></td>
<td>For mailbox filters, see the RXMG MASK register description.</td>
</tr>
<tr>
<td></td>
<td>For Rx FIFO ID filter table elements, see the RXFG MASK register description.</td>
</tr>
<tr>
<td></td>
<td>0b - The corresponding bit in the filter is &quot;don't care.&quot;</td>
</tr>
<tr>
<td></td>
<td>1b - The corresponding bit in the filter is checked.</td>
</tr>
</tbody>
</table>

45.6.2.21 CAN FD Control register (FDCTRL)

45.6.2.21.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FDCTRL</td>
<td>C00h</td>
</tr>
</tbody>
</table>

45.6.2.21.2 Function

This register contains control bits for the CAN FD operation. It also defines the data size of message buffers allocated in different partitions of RAM (memory blocks) as described in the table below.

When an 8-byte payload is selected:
- Block R0 allocates MB0 to MB31.
- Block R1 allocates MB32 to MB63.

When a payload larger than 8 bytes is selected, the maximum number of MBs in a block is limited as described below:

<table>
<thead>
<tr>
<th>Payload size</th>
<th>Maximum number of message buffers per RAM block</th>
</tr>
</thead>
<tbody>
<tr>
<td>8 bytes</td>
<td>32</td>
</tr>
<tr>
<td>16 bytes</td>
<td>21</td>
</tr>
<tr>
<td>32 bytes</td>
<td>12</td>
</tr>
<tr>
<td>64 bytes</td>
<td>7</td>
</tr>
</tbody>
</table>
NOTE

One memory block fits exactly 32 MBs with an 8-byte payload. For other possible payload sizes, empty memory may exist between the last MB in a block and the beginning of the next block. This empty memory corresponds to less than one MB, and must not be used.

The contents of this register are not affected by soft reset.

45.6.2.21.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FD RATE</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>MBDSR1</td>
<td>Reserved</td>
<td>MBDSR0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TDCEN</td>
<td>Reserved</td>
<td>TDOFF</td>
<td>Reserved</td>
<td>TDCVAL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W1C</td>
<td>Reserved</td>
<td>TDFAIL</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>TDCOFF</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

45.6.2.21.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 FDRATE</td>
<td>Bit Rate Switch Enable</td>
</tr>
<tr>
<td>This bit enables the effect of the Bit Rate Switch (BRS bit) during the data phase of Tx messages. The CPU can write this bit any time. However, its effect turns active only when the CAN bus is in Wait for Bus Idle, Bus Idle, or Bus Off state, or when the current frame under reception or transmission reaches the interframe space. By negating FDCTRL[FDRATE], the CPU can force all bits in CAN FD messages to be transmitted in nominal bit rate, no matter what the value is in the BRS bit of the Tx MBs. 0b - Transmit a frame in nominal rate. The BRS bit in the Tx MB has no effect. 1b - Transmit a frame with bit rate switching if the BRS bit in the Tx MB is recessive.</td>
<td></td>
</tr>
<tr>
<td>30-27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26-25</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20-19</td>
<td>Message Buffer Data Size for Region 1</td>
</tr>
<tr>
<td>MBDRS1</td>
<td>This two-bit field selects the data size (8, 16, 32, or 64 bytes) for region R1 of message buffers allocated in RAM. It can be written in Freeze mode only.</td>
</tr>
<tr>
<td></td>
<td>00b - Selects 8 bytes per message buffer.</td>
</tr>
<tr>
<td></td>
<td>01b - Selects 16 bytes per message buffer.</td>
</tr>
<tr>
<td></td>
<td>10b - Selects 32 bytes per message buffer.</td>
</tr>
<tr>
<td></td>
<td>11b - Selects 64 bytes per message buffer.</td>
</tr>
<tr>
<td>18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17-16</td>
<td>Message Buffer Data Size for Region 0</td>
</tr>
<tr>
<td>MBDSR0</td>
<td>This two-bit field selects the data size (8, 16, 32, or 64 bytes) for region R0 of message buffers allocated in RAM. It can be written in Freeze mode only.</td>
</tr>
<tr>
<td></td>
<td>00b - Selects 8 bytes per message buffer.</td>
</tr>
<tr>
<td></td>
<td>01b - Selects 16 bytes per message buffer.</td>
</tr>
<tr>
<td></td>
<td>10b - Selects 32 bytes per message buffer.</td>
</tr>
<tr>
<td></td>
<td>11b - Selects 64 bytes per message buffer.</td>
</tr>
<tr>
<td>15</td>
<td>Transceiver Delay Compensation Enable</td>
</tr>
<tr>
<td>TDCEN</td>
<td>This bit can be used to enable and disable the TDC feature. It can be written in Freeze mode only.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> See Transmitter delay compensation in the CAN Protocol standard (ISO 11898-1) for details.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> TDC must be disabled when Loop Back mode is enabled (see CTRL1[LPB]).</td>
</tr>
<tr>
<td></td>
<td>0b - TDC is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - TDC is enabled</td>
</tr>
<tr>
<td>14</td>
<td>Transceiver Delay Compensation Fail</td>
</tr>
<tr>
<td>TDCFAIL</td>
<td>This bit indicates when the Transceiver Delay Compensation (TDC) mechanism is out of range, unable to compensate the transceiver's loop delay and successfully compare the delayed received bits to the transmitted ones (see Transceiver delay compensation). TDCFAIL sets in the first time FlexCAN detects the out of range condition. The CPU needs to write one to clear it.</td>
</tr>
<tr>
<td></td>
<td>0b - Measured loop delay is in range.</td>
</tr>
<tr>
<td></td>
<td>1b - Measured loop delay is out of range.</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-8</td>
<td>Transceiver Delay Compensation Offset</td>
</tr>
<tr>
<td>TDCOFF</td>
<td>This bit field contains the offset value to be added to the measured transceiver's loop delay in order to define the position of the delayed comparison point when bit rate switching is active. See Transceiver delay compensation for more details on how the loop delay measurement is performed.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
TDCOFF can be written in Freeze mode only. Its value can be defined in Protocol Engine (PE) Clock periods (CANCLK, see Protocol timing for more details), and must be selected to be smaller than the CAN bit duration in the data bit rate for proper operation.

**NOTE:** It is not recommended to have TDCOFF equal to zero.

### 45.6.2.22 CAN FD Bit Timing register (FDCBT)

#### 45.6.2.22.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FDCBT</td>
<td>C04h</td>
</tr>
</tbody>
</table>

#### 45.6.2.22.2 Function

This register stores the CAN bit timing variables used in the data phase of CAN FD messages when the FDCTRL[FDRATE] is set, compatible with CAN FD specification. FPRESDIV, FPROPSEG, FPSEG1, FPSEG2, and FRJW are used to define the time quantum duration, the number of time quanta per CAN bit, and the sample point position for the data bit rate portion of a CAN FD message with the BRS bit set.

The contents of this register are not affected by soft reset.

**NOTE**

The sum of the Fast Propagation Segment (FPROPSEG) and Fast Phase Segment 1 (FPSEG1) must be at least two time quanta.

**NOTE**

The user must ensure bit time settings and protocol engine tolerance are in compliance with the CAN Protocol standard (ISO 11898-1).
45.6.2.22.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>FPRSDV</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>FPROP</td>
<td></td>
<td></td>
<td>Reserved</td>
<td>FPSEG</td>
<td></td>
<td></td>
<td>Reserved</td>
<td>FPSEG</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

45.6.2.22.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29-20</td>
<td>Fast Prescaler Division Factor</td>
</tr>
<tr>
<td>FPRSDIV</td>
<td>This 10-bit field defines the ratio between the PE clock frequency and the serial clock (Sclock) frequency in the data bit rate portion of a CAN FD message with the BRS bit set.</td>
</tr>
<tr>
<td></td>
<td>The Sclock period defines the time quantum of the CAN FD protocol for the data bit rate. This field can be written only in Freeze mode because it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td></td>
<td>Sclock frequency = PE clock frequency / (FPRSDIV + 1).</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> To minimize errors when processing FD frames, use the same value for FPRSDIV and PRESDIV (in CBT or CTRL1). For more details see the first NOTE in section CAN FD frames.</td>
</tr>
<tr>
<td>19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18-16</td>
<td>Fast Resync Jump Width</td>
</tr>
<tr>
<td>FRJW</td>
<td>This 3-bit field defines the maximum number of time quanta that a bit time can be changed by one resynchronization in the data bit rate portion of a CAN FD message with the BRS bit set.</td>
</tr>
<tr>
<td></td>
<td>One time quantum is equal to the Sclock period. This field can be written only in Freeze mode because it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td></td>
<td>Resync Jump Width = FSJW + 1.</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14-10</td>
<td>Fast Propagation Segment</td>
</tr>
<tr>
<td>FPROPSEG</td>
<td>This 5-bit field defines the length of the propagation segment in the bit time in the data bit rate portion of a CAN FD message with the BRS bit set. This field can be written only in Freeze mode because it is blocked by hardware in other modes.</td>
</tr>
<tr>
<td></td>
<td>Propagation Segment Time = FPROPSEG x Time-Quanta.</td>
</tr>
</tbody>
</table>
45.6.2.23 **CAN FD CRC register (FDCRC)**

### 45.6.2.23.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FDCRC</td>
<td>C08h</td>
</tr>
</tbody>
</table>

### 45.6.2.23.2 Function

This register provides information about the CRC of transmitted messages.

FlexCAN uses different CRC polynomials for different frame formats, as shown below.

The CRC_15 polynomial is used for all frames in CAN format. The CRC_17 polynomial is used for frames in CAN FD format with a DATA FIELD up to sixteen bytes. The CRC_21 polynomial is used for frames in CAN FD format with a DATA FIELD longer than sixteen bytes. Each polynomial shown below results in a Hamming distance of 6.

This register is updated at the same time the Tx Interrupt flag is asserted.
CRC_15 = 0xC599: \((x^{15} + x^{14} + x^{10} + x^8 + x^7 + x^4 + x^3 + 1)\)
CRC_17 = 0x3685B: \((x^{17} + x^{16} + x^{14} + x^{13} + x^{11} + x^6 + x^4 + x^3 + x + 1)\)
CRC_21 = 0x302899: \((x^{21} + x^{20} + x^{11} + x^{7} + x^4 + x^3 + 1)\)

**NOTE**

See CRC sequence calculation in the CAN Protocol standard (ISO 11898-1) for details.

### 45.6.2.23.3 Diagram

#### Bits

<table>
<thead>
<tr>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>FD_MBCRC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### Bits

<table>
<thead>
<tr>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>FD_TXCRC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 45.6.2.23.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30-24</td>
<td></td>
</tr>
<tr>
<td>FD_MBCRC</td>
<td>CRC Mailbox Number for FD_TXCRC</td>
</tr>
<tr>
<td></td>
<td>This field indicates the number of the mailbox corresponding to the value in the FD_TXCRC field, for both FD and non-FD frames.</td>
</tr>
<tr>
<td></td>
<td>It reports the same information as in CRCR[MBCRC].</td>
</tr>
<tr>
<td>23-21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20-0</td>
<td></td>
</tr>
<tr>
<td>FD_TXCRC</td>
<td>Extended Transmitted CRC value</td>
</tr>
<tr>
<td></td>
<td>This 21-bit field contains the CRC value calculated over the most recent transmitted message. Different CRC polynomials are used for different frame formats. A 15-bit polynomial, CRC_15, is used for all frames in CAN format. The second 17-bit polynomial, CRC_17, is used for frames in CAN FD format with a data field up to sixteen bytes long. The third 21-bit polynomial, CRC_21, is used for frames in CAN FD format with a data field longer than sixteen bytes.</td>
</tr>
<tr>
<td></td>
<td>For CRC_15 and CRC_17, the 6 most significant bits and the 4 most significant bits are reported as zeros, respectively.</td>
</tr>
<tr>
<td></td>
<td>For CRC_15, this register has the same content as CRC register.</td>
</tr>
</tbody>
</table>
45.6.3 Message buffer structure

The message buffer structure used by the FlexCAN module is represented in the following figure. Both extended (29-bit identifier) and standard (11-bit identifier) frames used in the CAN specification (Version 2.0 Part B) are represented. Each individual MB is formed by 16, 24, 40, or 72 bytes, depending on the quantity of data bytes allocated for the message payload: 8, 16, 32, or 64 data bytes, respectively.

The memory area from 0x80 to 0x47F is used by the mailboxes. When CAN FD is enabled, the exact address for each MB depends on the size of its payload. See FlexCAN memory partition for CAN FD for more detailed information.

<table>
<thead>
<tr>
<th>Table 45-23. Message buffer structure — example with 64-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x0</td>
</tr>
<tr>
<td>EDL</td>
</tr>
<tr>
<td>PRIO</td>
</tr>
<tr>
<td>0x0</td>
</tr>
<tr>
<td>0x4</td>
</tr>
<tr>
<td>0x8</td>
</tr>
<tr>
<td>0xC</td>
</tr>
<tr>
<td>0x10</td>
</tr>
<tr>
<td>0x14</td>
</tr>
<tr>
<td>0x18</td>
</tr>
<tr>
<td>0x1C</td>
</tr>
<tr>
<td>0x20</td>
</tr>
<tr>
<td>0x24</td>
</tr>
<tr>
<td>0x28</td>
</tr>
<tr>
<td>0x2C</td>
</tr>
<tr>
<td>0x30</td>
</tr>
<tr>
<td>0x34</td>
</tr>
<tr>
<td>0x38</td>
</tr>
<tr>
<td>0x3C</td>
</tr>
</tbody>
</table>

EDL — Extended Data Length

This bit distinguishes between CAN format and CAN FD format frames. The EDL bit must not be set for message buffers configured to RANSWER with code field 0b1010 (see table below).
**BRS — Bit Rate Switch**

This bit defines whether the bit rate is switched inside a CAN FD format frame.

**ESI — Error State Indicator**

This bit indicates if the transmitting node is error active or error passive.

**CODE — Message Buffer Code**

This 4-bit field can be accessed (read or write) by the CPU and by the FlexCAN module itself, as part of the message buffer matching and arbitration process. The encoding is shown in Table 45-24 and Table 45-25. See Functional description for additional information.

### Table 45-24. Message buffer code for Rx buffers

<table>
<thead>
<tr>
<th>CODE description</th>
<th>Rx code BEFORE receive new frame</th>
<th>SRV(^1)</th>
<th>Rx code AFTER successful reception(^2)</th>
<th>RRS(^3)</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b0000: INACTIVE — MB is not active.</td>
<td>INACTIVE</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>MB does not participate in the matching process.</td>
</tr>
<tr>
<td>0b0100: EMPTY — MB is active and empty.</td>
<td>EMPTY</td>
<td>—</td>
<td>FULL</td>
<td>—</td>
<td>When a frame is received successfully (after the Move-in process), the CODE field is automatically updated to FULL.</td>
</tr>
<tr>
<td>0b0010: FULL — MB is full.</td>
<td>FULL</td>
<td>Yes</td>
<td>FULL</td>
<td>—</td>
<td>The act of reading the C/S word followed by unlocking the MB (SRV) does not make the code return to EMPTY. It remains FULL. If a new frame is moved to the MB after the MB was serviced, the code still remains FULL. See Matching process for matching details related to FULL code.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>CODE description</th>
<th>Rx code BEFORE receive new frame</th>
<th>SRV&lt;sup&gt;1&lt;/sup&gt;</th>
<th>Rx code AFTER successful reception&lt;sup&gt;2&lt;/sup&gt;</th>
<th>RRS&lt;sup&gt;3&lt;/sup&gt;</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b0110: OVERRUN — MB is being overwritten into a full buffer.</td>
<td>OVERRUN</td>
<td>Yes</td>
<td>FULL</td>
<td>—</td>
<td>CODE field is automatically updated to OVERRUN. See Matching process for details about overrun behavior.</td>
</tr>
<tr>
<td>0b1010: RANSWER&lt;sup&gt;4&lt;/sup&gt; — A frame was configured to recognize a Remote Request frame and transmit a Response frame in return.</td>
<td>RANSWER</td>
<td>—</td>
<td>TANSWER(0b1110 )</td>
<td>0</td>
<td>A Remote Answer was configured to recognize a remote request frame received. After that an MB is set to transmit a response frame. The code is automatically changed to TANSWER (0b1110). See Matching process for details. If CTRL2[RRS] is negated, transmit a response frame whenever a remote request frame with the same ID is received.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 45-24. Message buffer code for Rx buffers (continued)

<table>
<thead>
<tr>
<th>CODE description</th>
<th>Rx code BEFORE receive new frame</th>
<th>SRV(^1)</th>
<th>Rx code AFTER successful reception(^2)</th>
<th>RRS(^3)</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>CODE[0]=1: BUSY — FlexCAN is updating the contents of the MB. The CPU must not access the MB.</td>
<td>BUSY(^6)</td>
<td>—</td>
<td>FULL</td>
<td>—</td>
<td>matching and arbitration process. See Matching process for details.</td>
</tr>
<tr>
<td>1. SRV: Serviced MB. MB was read and unlocked by reading TIMER or other MB.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2. A frame is considered a successful reception after the frame to be moved to MB (move-in process). See Move-in for details.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3. Remote Request Stored bit, see “Control 2 register (CTRL2)“ for details.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4. Code 0b1010 is not considered Tx and an MB with this code should not be aborted.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5. Code 0b1010 must be used in message buffers configured in CAN FD format, having the EDL bit set.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6. Note that for Tx MBs, the BUSY bit should be ignored upon read, except when AEN bit is set in the MCR register. If this bit is asserted, the corresponding MB does not participate in the matching process.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Table 45-25. Message buffer code for Tx buffers

<table>
<thead>
<tr>
<th>CODE Description</th>
<th>Tx Code BEFORE tx frame</th>
<th>MB RTR</th>
<th>Tx Code AFTER successful transmission</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b1000: INACTIVE — MB is not active</td>
<td>INACTIVE</td>
<td>—</td>
<td>—</td>
<td>MB does not participate in arbitration process.</td>
</tr>
<tr>
<td>0b1001: ABORT — MB is aborted</td>
<td>ABORT</td>
<td>—</td>
<td>—</td>
<td>MB does not participate in arbitration process.</td>
</tr>
<tr>
<td>0b1100: DATA — MB is a Tx data frame (MB RTR must be 0)</td>
<td>DATA</td>
<td>0</td>
<td>INACTIVE</td>
<td>Transmit data frame unconditionally once. After transmission, the MB automatically returns to the INACTIVE state.</td>
</tr>
<tr>
<td>0b1100: REMOTE — MB is a Tx Remote Request frame (MB RTR must be 1)</td>
<td>REMOTE</td>
<td>1</td>
<td>EMPTY</td>
<td>Transmit remote request frame unconditionally once. After transmission, the MB automatically becomes an Rx Empty MB with the same ID.</td>
</tr>
<tr>
<td>0b1110: TANSWER — MB is a Tx Response frame from an incoming Remote Request frame</td>
<td>TANSWER</td>
<td>—</td>
<td>RANSWER</td>
<td>This is an intermediate code that is automatically written to the MB by the CHI as a result of a match to a remote request frame.</td>
</tr>
</tbody>
</table>
### Table 45-25. Message buffer code for Tx buffers

<table>
<thead>
<tr>
<th>CODE Description</th>
<th>Tx Code BEFORE tx frame</th>
<th>MB RTR</th>
<th>Tx Code AFTER successful transmission</th>
<th>Comment</th>
</tr>
</thead>
</table>

The remote response frame will be transmitted unconditionally once, and then the code will automatically return to RANSWER (0b1010). The CPU can also write this code with the same effect. The remote response frame can be either a data frame or another remote request frame depending on the RTR bit value. See Matching process and Arbitration process for details.

**SRR — Substitute Remote Request**

Fixed recessive bit, used only in extended format. It must be set to one by the user for transmission (Tx Buffers) and will be stored with the value received on the CAN bus for Rx receiving buffers. It can be received as either recessive or dominant. If FlexCAN receives this bit as dominant, then it is interpreted as an arbitration loss.

1 = Recessive value is compulsory for transmission in extended format frames

0 = Dominant is not a valid value for transmission in extended format frames

**IDE — ID Extended Bit**

This field identifies whether the frame format is standard or extended.

1 = Frame format is extended

0 = Frame format is standard

**RTR — Remote Transmission Request**

This bit affects the behavior of remote frames and is part of the reception filter. See Table 45-24, Table 45-25, and the description of the RRS field in Control 2 register (CTRL2) for additional details.
If FlexCAN transmits this bit as '1' (recessive) and receives it as '0' (dominant), it is interpreted as an arbitration loss. If this bit is transmitted as '0' (dominant), then if it is received as '1' (recessive), the FlexCAN module treats it as a bit error. If the value received matches the value transmitted, it is considered a successful bit transmission.

1 = Indicates the current MB may have a remote request frame to be transmitted if MB is Tx. If the MB is Rx then incoming remote request frames may be stored.

0 = Indicates the current MB has a data frame to be transmitted. In Rx MB it may be considered in matching processes.

**NOTE**
When configuring CAN FD frames, the RTR bit must be negated.

**DLC** — Length of Data in Bytes

This 4-bit field is the length (in bytes) of the Rx or Tx data, which is located in offset 0x8 through 0xF of the MB space (see Table 45-23). In reception, this field is written by the FlexCAN module, copied from the DLC (Data Length Code) field of the received frame. In transmission, this field is written by the CPU and corresponds to the DLC field value of the frame to be transmitted. When RTR = 1, the frame to be transmitted is a remote frame and does not include the data field, regardless of the DLC field (see Table 45-26).

**TIME STAMP** — Free-Running Counter Time Stamp

This 16-bit field is a copy of the Free-Running Timer, captured for Tx and Rx frames at the time when the beginning of the Identifier field appears on the CAN bus.

**PRIO** — Local priority

This 3-bit field is used only when MCR[LPRIO_EN] is set, and it only makes sense for Tx mailboxes. These bits are not transmitted. They are appended to the regular ID to define the transmission priority. See Arbitration process.

**ID** — Frame Identifier

In standard frame format, only the 11 most significant bits (28 to 18) are used for frame identification in both receive and transmit cases. The 18 least significant bits are ignored. In extended frame format, all bits are used for frame identification in both receive and transmit cases.

**DATA BYTE 0 to 63** — Data Field

Up to sixty four bytes can be used for a data frame, depending on the size of payload selected for the message buffers.
For Rx frames, the data is stored as it is received from the CAN bus. DATA BYTE \((n)\) is valid only if \(n\) is less than DLC as shown in the table below.

<table>
<thead>
<tr>
<th>DLC</th>
<th>Valid DATA BYTEs</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>none</td>
</tr>
<tr>
<td>1</td>
<td>DATA BYTE 0</td>
</tr>
<tr>
<td>2</td>
<td>DATA BYTE 0 to 1</td>
</tr>
<tr>
<td>3</td>
<td>DATA BYTE 0 to 2</td>
</tr>
<tr>
<td>4</td>
<td>DATA BYTE 0 to 3</td>
</tr>
<tr>
<td>5</td>
<td>DATA BYTE 0 to 4</td>
</tr>
<tr>
<td>6</td>
<td>DATA BYTE 0 to 5</td>
</tr>
<tr>
<td>7</td>
<td>DATA BYTE 0 to 6</td>
</tr>
<tr>
<td>8</td>
<td>DATA BYTE 0 to 7</td>
</tr>
<tr>
<td>9</td>
<td>DATA BYTE 0 to 11</td>
</tr>
<tr>
<td>10</td>
<td>DATA BYTE 0 to 15</td>
</tr>
<tr>
<td>11</td>
<td>DATA BYTE 0 to 19</td>
</tr>
<tr>
<td>12</td>
<td>DATA BYTE 0 to 23</td>
</tr>
<tr>
<td>13</td>
<td>DATA BYTE 0 to 31</td>
</tr>
<tr>
<td>14</td>
<td>DATA BYTE 0 to 47</td>
</tr>
<tr>
<td>15</td>
<td>DATA BYTE 0 to 63</td>
</tr>
</tbody>
</table>

### 45.6.4 FlexCAN memory partition for CAN FD

When CAN FD is enabled, the FlexCAN RAM can be partitioned in blocks of 512 bytes. Each block can accommodate a number of message buffers which depends on the configuration provided by FDCTRL\[MBDSRn\] bit fields as shown in table below.

<table>
<thead>
<tr>
<th>RAM block</th>
<th>Number of MBs with 8 bytes (default range)</th>
<th>Size control bit field in FDCTRL register</th>
<th>Number of MBs of different sizes, per block</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0 to 31</td>
<td>MBDSR0</td>
<td>MBDSR0=00, 32 MBs with 8 bytes payload</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MBDSR0=01, 21 MBs with 16 bytes payload</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MBDSR0=10, 12 MBs with 32 bytes payload</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>MBDSR0=11, 7 MBs with 64 bytes payload</td>
</tr>
<tr>
<td>1</td>
<td>32 to 63</td>
<td>MBDSR1</td>
<td>MBDSR1=00, 32 MBs with 8 bytes payload</td>
</tr>
</tbody>
</table>
### Table 45-27. RAM partition

<table>
<thead>
<tr>
<th>RAM block</th>
<th>Number of MBs with 8 bytes (default range)</th>
<th>Size control bit field in FDCTRL register</th>
<th>Number of MBs of different sizes, per block</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>MBDSR1=01, 21 MBs with 16 bytes payload</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>MBDSR1=10, 12 MBs with 32 bytes payload</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>MBDSR1=11, 7 MBs with 64 bytes payload</td>
<td></td>
</tr>
</tbody>
</table>

When payload sizes of 16, 32, or 64 bytes are configured in some or all RAM blocks, the total number of MBs and its respective number order may differ from the default configuration of 8 bytes. For example, suppose Block0 is configured to 8 bytes payload, Block1 to 16 bytes, then the following table indicates how the message buffers will be arranged in RAM.

### Table 45-28. RAM partition example

<table>
<thead>
<tr>
<th>RAM block</th>
<th>Payload size</th>
<th>Number of MBs in the RAM block</th>
<th>Message buffer range</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>FDCTRL[MBDSR0]=00, 8 bytes payload</td>
<td>32</td>
<td>0 to 31</td>
</tr>
<tr>
<td>1</td>
<td>FDCTRL[MBDSR1]=01, 16 bytes payload</td>
<td>21</td>
<td>32 to 52</td>
</tr>
</tbody>
</table>

### 45.6.5 FlexCAN message buffer memory map

The FlexCAN memory buffers are allocated in memory according to the tables below.

### Table 45-29. 8-byte message buffers

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b00 8-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0080</td>
<td>MB0</td>
</tr>
<tr>
<td>0090</td>
<td>MB1</td>
</tr>
<tr>
<td>00A0</td>
<td>MB2</td>
</tr>
<tr>
<td>00B0</td>
<td>MB3</td>
</tr>
<tr>
<td>00C0</td>
<td>MB4</td>
</tr>
<tr>
<td>00D0</td>
<td>MB5</td>
</tr>
<tr>
<td>00E0</td>
<td>MB6</td>
</tr>
<tr>
<td>00F0</td>
<td>MB7</td>
</tr>
<tr>
<td>0100</td>
<td>MB8</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 45-29. 8-byte message buffers (continued)

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b00 8-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0110</td>
<td>MB9</td>
</tr>
<tr>
<td>0120</td>
<td>MB10</td>
</tr>
<tr>
<td>0130</td>
<td>MB11</td>
</tr>
<tr>
<td>0140</td>
<td>MB12</td>
</tr>
<tr>
<td>0150</td>
<td>MB13</td>
</tr>
<tr>
<td>0160</td>
<td>MB14</td>
</tr>
<tr>
<td>0170</td>
<td>MB15</td>
</tr>
<tr>
<td>0180</td>
<td>MB16</td>
</tr>
<tr>
<td>0190</td>
<td>MB17</td>
</tr>
<tr>
<td>01A0</td>
<td>MB18</td>
</tr>
<tr>
<td>01B0</td>
<td>MB19</td>
</tr>
<tr>
<td>01C0</td>
<td>MB20</td>
</tr>
<tr>
<td>01D0</td>
<td>MB21</td>
</tr>
<tr>
<td>01E0</td>
<td>MB22</td>
</tr>
<tr>
<td>01F0</td>
<td>MB23</td>
</tr>
<tr>
<td>0200</td>
<td>MB24</td>
</tr>
<tr>
<td>0210</td>
<td>MB25</td>
</tr>
<tr>
<td>0220</td>
<td>MB26</td>
</tr>
<tr>
<td>0230</td>
<td>MB27</td>
</tr>
<tr>
<td>0240</td>
<td>MB28</td>
</tr>
<tr>
<td>0250</td>
<td>MB29</td>
</tr>
<tr>
<td>0260</td>
<td>MB30</td>
</tr>
<tr>
<td>0270</td>
<td>MB31</td>
</tr>
<tr>
<td>0280</td>
<td>MB32</td>
</tr>
<tr>
<td>0290</td>
<td>MB33</td>
</tr>
<tr>
<td>02A0</td>
<td>MB34</td>
</tr>
<tr>
<td>02B0</td>
<td>MB35</td>
</tr>
<tr>
<td>02C0</td>
<td>MB36</td>
</tr>
<tr>
<td>02D0</td>
<td>MB37</td>
</tr>
<tr>
<td>02E0</td>
<td>MB38</td>
</tr>
<tr>
<td>02F0</td>
<td>MB39</td>
</tr>
<tr>
<td>0300</td>
<td>MB40</td>
</tr>
<tr>
<td>0310</td>
<td>MB41</td>
</tr>
<tr>
<td>0320</td>
<td>MB42</td>
</tr>
<tr>
<td>0330</td>
<td>MB43</td>
</tr>
<tr>
<td>0340</td>
<td>MB44</td>
</tr>
<tr>
<td>0350</td>
<td>MB45</td>
</tr>
<tr>
<td>0360</td>
<td>MB46</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 45-29. 8-byte message buffers (continued)

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b00 8-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0370</td>
<td>MB47</td>
</tr>
<tr>
<td>0380</td>
<td>MB48</td>
</tr>
<tr>
<td>0390</td>
<td>MB49</td>
</tr>
<tr>
<td>03A0</td>
<td>MB50</td>
</tr>
<tr>
<td>03B0</td>
<td>MB51</td>
</tr>
<tr>
<td>03C0</td>
<td>MB52</td>
</tr>
<tr>
<td>03D0</td>
<td>MB53</td>
</tr>
<tr>
<td>03E0</td>
<td>MB54</td>
</tr>
<tr>
<td>03F0</td>
<td>MB55</td>
</tr>
<tr>
<td>0400</td>
<td>MB56</td>
</tr>
<tr>
<td>0410</td>
<td>MB57</td>
</tr>
<tr>
<td>0420</td>
<td>MB58</td>
</tr>
<tr>
<td>0430</td>
<td>MB59</td>
</tr>
<tr>
<td>0440</td>
<td>MB60</td>
</tr>
<tr>
<td>0450</td>
<td>MB61</td>
</tr>
<tr>
<td>0460</td>
<td>MB62</td>
</tr>
<tr>
<td>0470</td>
<td>MB63</td>
</tr>
</tbody>
</table>

### Table 45-30. 16-byte message buffers

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b01 16-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0080</td>
<td>MB0</td>
</tr>
<tr>
<td>0098</td>
<td>MB1</td>
</tr>
<tr>
<td>00B0</td>
<td>MB2</td>
</tr>
<tr>
<td>00C8</td>
<td>MB3</td>
</tr>
<tr>
<td>00E0</td>
<td>MB4</td>
</tr>
<tr>
<td>00F8</td>
<td>MB5</td>
</tr>
<tr>
<td>0110</td>
<td>MB6</td>
</tr>
<tr>
<td>0128</td>
<td>MB7</td>
</tr>
<tr>
<td>0140</td>
<td>MB8</td>
</tr>
<tr>
<td>0158</td>
<td>MB9</td>
</tr>
<tr>
<td>0170</td>
<td>MB10</td>
</tr>
<tr>
<td>0188</td>
<td>MB11</td>
</tr>
<tr>
<td>01A0</td>
<td>MB12</td>
</tr>
<tr>
<td>01B8</td>
<td>MB13</td>
</tr>
<tr>
<td>01D0</td>
<td>MB14</td>
</tr>
<tr>
<td>01E8</td>
<td>MB15</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 45-30. 16-byte message buffers (continued)

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b01 16-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0200</td>
<td>MB16</td>
</tr>
<tr>
<td>0218</td>
<td>MB17</td>
</tr>
<tr>
<td>0230</td>
<td>MB18</td>
</tr>
<tr>
<td>0248</td>
<td>MB19</td>
</tr>
<tr>
<td>0260</td>
<td>MB20</td>
</tr>
<tr>
<td>0280</td>
<td>MB21</td>
</tr>
<tr>
<td>0298</td>
<td>MB22</td>
</tr>
<tr>
<td>02B0</td>
<td>MB23</td>
</tr>
<tr>
<td>02C8</td>
<td>MB24</td>
</tr>
<tr>
<td>02E0</td>
<td>MB25</td>
</tr>
<tr>
<td>02F8</td>
<td>MB26</td>
</tr>
<tr>
<td>0310</td>
<td>MB27</td>
</tr>
<tr>
<td>0328</td>
<td>MB28</td>
</tr>
<tr>
<td>0340</td>
<td>MB29</td>
</tr>
<tr>
<td>0358</td>
<td>MB30</td>
</tr>
<tr>
<td>0370</td>
<td>MB31</td>
</tr>
<tr>
<td>0388</td>
<td>MB32</td>
</tr>
<tr>
<td>03A0</td>
<td>MB33</td>
</tr>
<tr>
<td>03B8</td>
<td>MB34</td>
</tr>
<tr>
<td>03D0</td>
<td>MB35</td>
</tr>
<tr>
<td>03E8</td>
<td>MB36</td>
</tr>
<tr>
<td>0400</td>
<td>MB37</td>
</tr>
<tr>
<td>0418</td>
<td>MB38</td>
</tr>
<tr>
<td>0430</td>
<td>MB39</td>
</tr>
<tr>
<td>0448</td>
<td>MB40</td>
</tr>
<tr>
<td>0460</td>
<td>MB41</td>
</tr>
</tbody>
</table>

### Table 45-31. 32-byte message buffers

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b10 32-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0080</td>
<td>MB0</td>
</tr>
<tr>
<td>00A8</td>
<td>MB1</td>
</tr>
<tr>
<td>00D0</td>
<td>MB2</td>
</tr>
<tr>
<td>00F8</td>
<td>MB3</td>
</tr>
<tr>
<td>0120</td>
<td>MB4</td>
</tr>
<tr>
<td>0148</td>
<td>MB5</td>
</tr>
<tr>
<td>0170</td>
<td>MB6</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 45-31. 32-byte message buffers (continued)

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b10 32-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0198</td>
<td>MB7</td>
</tr>
<tr>
<td>01C0</td>
<td>MB8</td>
</tr>
<tr>
<td>01E8</td>
<td>MB9</td>
</tr>
<tr>
<td>0210</td>
<td>MB10</td>
</tr>
<tr>
<td>0238</td>
<td>MB11</td>
</tr>
<tr>
<td>0280</td>
<td>MB12</td>
</tr>
<tr>
<td>02A8</td>
<td>MB13</td>
</tr>
<tr>
<td>02D0</td>
<td>MB14</td>
</tr>
<tr>
<td>02F8</td>
<td>MB15</td>
</tr>
<tr>
<td>0320</td>
<td>MB16</td>
</tr>
<tr>
<td>0348</td>
<td>MB17</td>
</tr>
<tr>
<td>0370</td>
<td>MB18</td>
</tr>
<tr>
<td>0398</td>
<td>MB19</td>
</tr>
<tr>
<td>03C0</td>
<td>MB20</td>
</tr>
<tr>
<td>03E8</td>
<td>MB21</td>
</tr>
<tr>
<td>0410</td>
<td>MB22</td>
</tr>
<tr>
<td>0438</td>
<td>MB23</td>
</tr>
</tbody>
</table>

### Table 45-32. 64-byte message buffers

<table>
<thead>
<tr>
<th>Address offset (hex)</th>
<th>MBDSR=b11 64-byte payload</th>
</tr>
</thead>
<tbody>
<tr>
<td>0080</td>
<td>MB0</td>
</tr>
<tr>
<td>00C8</td>
<td>MB1</td>
</tr>
<tr>
<td>0110</td>
<td>MB2</td>
</tr>
<tr>
<td>0158</td>
<td>MB3</td>
</tr>
<tr>
<td>01A0</td>
<td>MB4</td>
</tr>
<tr>
<td>01E8</td>
<td>MB5</td>
</tr>
<tr>
<td>0230</td>
<td>MB6</td>
</tr>
<tr>
<td>0280</td>
<td>MB7</td>
</tr>
<tr>
<td>02C8</td>
<td>MB8</td>
</tr>
<tr>
<td>0310</td>
<td>MB9</td>
</tr>
<tr>
<td>0358</td>
<td>MB10</td>
</tr>
<tr>
<td>03A0</td>
<td>MB11</td>
</tr>
<tr>
<td>03E8</td>
<td>MB12</td>
</tr>
<tr>
<td>0430</td>
<td>MB13</td>
</tr>
</tbody>
</table>
45.6.6  Rx FIFO structure

When MCR[RFEN] is set, the memory area from 0x80 to 0xDC (which is normally occupied by MBs 0–5) is used by the reception FIFO engine.

The region 0x80-0x8C contains the output of the FIFO which must be read by the CPU as a message buffer. This output contains the oldest message that has been received but not yet read. The region 0x90-0xDC is reserved for internal use of the FIFO engine.

An additional memory area, which starts at 0xE0 and may extend up to 0x2DC (normally occupied by MBs 6–37) depending on the CTRL2[RFFN] field setting, contains the ID filter table (configurable from 8 to 128 table elements) that specifies filtering criteria for accepting frames into the FIFO.

Out of reset, the ID filter table flexible memory area defaults to 0xE0 and extends only to 0xFC, which corresponds to MBs 6 to 7 for RFFN = 0, for backward compatibility with previous versions of FlexCAN.

The following shows the Rx FIFO data structure.

<table>
<thead>
<tr>
<th>Table 45-33. Rx FIFO structure</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
</tr>
<tr>
<td>0x80</td>
</tr>
<tr>
<td>0x84</td>
</tr>
<tr>
<td>0x88</td>
</tr>
<tr>
<td>0x8C</td>
</tr>
<tr>
<td>0x90</td>
</tr>
<tr>
<td>0x90 to 0xDC</td>
</tr>
<tr>
<td>0xE0</td>
</tr>
<tr>
<td>0xE4</td>
</tr>
<tr>
<td>0x88 to 0x24D4</td>
</tr>
<tr>
<td>0x2D8</td>
</tr>
<tr>
<td>0x2DC</td>
</tr>
</tbody>
</table>

Each ID filter table element occupies an entire 32-bit word and can be compounded by one, two, or four Identifier Acceptance Filters (IDAF) depending on the MCR[IDAM] field setting. The following figures show the IDAF indexation.
The following table shows the three different formats of the ID table elements. Note that all elements of the table must have the same format. See **Rx FIFO** for more information.

### Table 45-34. ID table structure

<table>
<thead>
<tr>
<th>Format</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>24</th>
<th>23</th>
<th>16</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>8</th>
<th>7</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>RTR</td>
<td>IDE</td>
<td>RXIDA</td>
<td>(standard = 29–19, extended = 29–1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B</td>
<td>RTR</td>
<td>IDE</td>
<td>RXIDB_0</td>
<td>(standard = 29–19, extended = 29–16)</td>
<td>RTR</td>
<td>IDE</td>
<td>RXIDB_1</td>
<td>(standard = 13–3, extended = 13–0)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>RXIDC_0</td>
<td>(std/ext = 31–24)</td>
<td>RXIDC_1</td>
<td>(std/ext = 23–16)</td>
<td>RXIDC_2</td>
<td>(std/ext = 15–8)</td>
<td>RXIDC_3</td>
<td>(std/ext = 7–0)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

= Unimplemented or Reserved

**RTR** — Remote frame

This bit specifies if remote frames are accepted into the FIFO if they match the target ID.

1 = Remote frames can be accepted and data frames are rejected

0 = Remote frames are rejected and data frames can be accepted

**IDE** — Extended frame

Specifies whether extended or standard frames are accepted into the FIFO if they match the target ID.

1 = Extended frames can be accepted and standard frames are rejected

0 = Extended frames are rejected and standard frames can be accepted

**RXIDA** — Rx frame identifier (Format A)

Specifies an ID to be used as acceptance criteria for the FIFO. In the standard frame format, only the 11 most significant bits (29 to 19) are used for frame identification. In the extended frame format, all bits are used.

**RXIDB_0, RXIDB_1** — Rx frame identifier (Format B)

Specifies an ID to be used as acceptance criteria for the FIFO. In the standard frame format, the 11 most significant bits (a full standard ID) (29 to 19 and 13 to 3) are used for frame identification. In the extended frame format, all 14 bits of the field are compared to the 14 most significant bits of the received ID.

**RXIDC_0, RXIDC_1, RXIDC_2, RXIDC_3** — Rx frame identifier (Format C)
Specifies an ID to be used as acceptance criteria for the FIFO. In both standard and extended frame formats, all 8 bits of the field are compared to the 8 most significant bits of the received ID.

**IDHIT — Identifier acceptance filter hit indicator**

This 9-bit field indicates which identifier acceptance filter was hit by the received message that is in the output of the Rx FIFO. See Rx FIFO for more information.
# Chapter 46
Keypad Port (KPP)

## 46.1 Chip-specific KPP information

### Table 46-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>
46.2 Overview

The Keypad Port (KPP) is a 16-bit peripheral that can be used as a keypad matrix interface or as general purpose input/output (I/O).

The figure below shows the KPP block diagram. The KPP provides interface for the keypad matrix with 2-point contact or 3-point contact keys. The KPP is designed to simplify the software task of scanning a keypad matrix. With appropriate software support, the KPP is capable of detecting, debouncing, and decoding one or multiple keys pressed simultaneously on the keypad.

Figure 46-1. KPP Peripheral Block Diagram
46.2.1 Features

The KPP includes these distinctive features:

- Supports up to an 8 x 8 external key pad matrix
- Port pins can be used as general purpose I/O
- Open drain design
- Glitch suppression circuit design
- Multiple-key detection
- Long key-press detection
- Standby key-press detection
- Synchronizer chain clear
- Supports a 2-point and 3-point contact key matrix

46.2.2 Modes and Operations

This block supports the following modes:

- Run Mode-This is the normal functional mode in which the KPP can detect any key press event.
- Low Power Mode-The keypad can detect any key press even in low power modes (when there is no MCU clock).

46.3 Clocks

The table found here describes the clock sources for KPP.

Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk_32k</td>
<td>ckil_sync_clk_root</td>
<td>Low-frequency reference clock (32 kHz)</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
</tbody>
</table>
46.4 External Signals

There are several pins dedicated to the KPP. Keypads of any configuration up to eight rows and eight columns are supported through the software configuration of the peripheral pins. Any pins not used for the keypad are available as general purpose I/O. The registers are configured such that the pins can be treated as an I/O port up to 16 bits wide.

See the table below for the list of external signals.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>KPP_ROW0</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_14</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL0</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_15</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_ROW1</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_12</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL1</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_13</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_ROW2</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_10</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL2</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_11</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_ROW3</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_08</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL3</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_09</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_ROW4</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_06</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL4</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_07</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_ROW5</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_04</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL5</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_05</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_ROW6</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_02</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL6</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_03</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_ROW7</td>
<td>Row input or output pin, from chip</td>
<td>GPIO_AD_B1_00</td>
<td>ALT7</td>
<td>IO</td>
</tr>
<tr>
<td>KPP_COL7</td>
<td>Column input or output pin, from chip</td>
<td>GPIO_AD_B1_01</td>
<td>ALT7</td>
<td>IO</td>
</tr>
</tbody>
</table>
46.4.1 Input Pins

Any of the 16 pins associated with the KPP can be configured as inputs by writing a "0" to the appropriate bits in the KPP_KDDR. Additionally, the least significant 8 bits (ROW inputs) corresponding to KPP_KDDR[KRDD] have internal pull-ups, which are enabled when the pin is used as an input.

46.4.2 Output Pins

Any of the 16 pins associated with the KPP can be configured as outputs by writing the appropriate bits in the KPP_KDDR to a "1". Additionally, the 8 most significant bits (15-8) can be designated as open drain outputs by writing a "1" to the appropriate bits in the KPP_KPCR. The lower 8 bits (7-0) are always in "totem pole" style, driven when configured as outputs.

See the table below.

<table>
<thead>
<tr>
<th>KPP_KDDR (15:8)</th>
<th>KPP_KPCR (15:8)</th>
<th>Pin Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>x</td>
<td>Input</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Totem-Pole Output</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Open-Drain Output</td>
</tr>
</tbody>
</table>

**NOTE**

Totem pole capability should be provided for column pins. Totem pole configuration helps for a faster discharge of keypad capacitance when all columns need to be quickly brought to a "1" during the scan routine. With this configuration, delay between the scanning of two subsequent columns is reduced.

46.4.3 Generation of Transfer Error Signal on Peripheral Bus

If there is an access to an address which is not implemented, then the KPP asserts a transfer error signal on Peripheral Bus.
46.5 Functional Description

The Keypad Port (KPP) is designed to simplify the software task of scanning a keypad matrix. With appropriate software support and matrix organization, the KPP is capable of detecting, debouncing, and decoding one or more keys pressed simultaneously on the keypad.

Logic in the KPP is capable of detecting a key press even while the processor is in one of the low power standby modes provided that a low frequency reference clock (ipg_clk_32k) is on. The KPP may generate an Arm platform interrupt any time a key press or key release is detected. This interrupt is capable of forcing the processor out of a low power mode.

46.5.1 Keypad Matrix Construction

The KPP is designed to interface to a keypad matrix, which shorts the intersecting row and column lines together whenever a key is depressed. The interface is not optimized for any other switch configuration.

46.5.2 Keypad Port Configuration

The software must initialize the KPP for the size of the keypad matrix. Pins connected to the keypad columns should be configured as open-drain outputs. Pins connected to the keypad rows should be configured as inputs. On-chip, pull-up resistors should be implemented for active keypad rows.

In addition to enabled row inputs in the Keypad Control register, corresponding interrupt (depress or/and release) must also be enabled to generate an interrupt.

Discrete switches that are not part of the matrix may be connected to any unused row inputs. The second terminal of the discrete switch is connected to ground. The hardware detects closures of these switches without the need for software polling.

46.5.3 Keypad Matrix Scanning

Keypad scanning is performed by a software loop that walks a zero across each of the keypad columns, reading the value on the rows at each step. The process is repeated several times in succession, with the results of each pass optionally compared to those
from the previous pass. When several (3 or 4) consecutive scans yield the same key closures, a valid key press has been detected. Software then can decode exactly which switch was depressed and pass the value up to the next higher software layer.

The basic debouncing period, which must be defined in the software routine, may be controlled with an internal timer. The basic period is the period between the scan of two consecutive columns, so the debouncing time between two consecutive scans of the whole matrix shall be the number of columns multiplied by the basic period.

### 46.5.4 Keypad Standby

There is no need for the Arm platform to continually scan the keypad. Between key presses, the keypad can be left in a state that requires no software intervention until the next key press is detected. To place the keypad in a standby state, software should write all column outputs low. Row inputs are left enabled. At this point, the Arm platform can attend to other tasks or revert to a low power standby mode. The KPP will interrupt the Arm platform if any key is pressed.

Upon receiving a keypad interrupt, the Arm platform should set all the column strobes high, and begin a normal keypad scanning routine to determine which key was pressed. It is important that open-drain drivers be used when scanning to prevent a possible DC path between power and ground through two or more switches.

### 46.5.5 Glitch Suppression on Keypad Inputs

A glitch suppression circuit qualifies the keypad inputs to prevent noise from inadvertently interrupting the Arm platform. The circuit is a 4-state synchronizer clocked from a low frequency reference clock (ipg_clk_32k) source. This clock must continue to run in any low power mode where the keypad is a wake-up source, as the Arm platform interrupt is generated from the synchronized input. An interrupt is not generated until all four synchronizer stages have latched a valid key assertion. This guarantees the filtering out of any noise less than three clock periods in duration of a low frequency reference clock. Noise filtering of the duration between three to four clock periods cannot be guaranteed. The interrupt output is latched in an S-R latch and remains asserted until cleared by the software. The Set input of the latch is rising-edge clocked. See the figure below.
46.5.6 Multiple Key Closures

Using the key press and key release interrupts, the software can detect multiple keys or achieve n key rollover. The key scanning routine can be programmed accordingly (See Initialization/Application Information for more information).

The following figures illustrate the interface of a 2-contact keypad matrix with the KPP controller. With proper enabling of row lines and the performing scan-routine, multiple key presses can be detected. When keys present on the same row are pressed, corresponding row lines (multiple lines) become low when the column is driven low during a scan-routine. By reading the data-register, pressed keys can be detected.
Similarly, when keys present on same row line are pressed, the corresponding row line (only one line) becomes low when logic "0" is driven on the column line during a scan-routine.

**Figure 46-3. Multiple Key Presses on Same Column Line (Simplified View)**
**Figure 46-4. Multiple Key Presses on Same Row Line (Simplified View)**

**NOTE**
An n key rollover is a technique with which the system can recognize the order in which keys are pressed.

### 46.5.6.1 Ghost Key Problem and Correction

The KPP detects if one or multiple keys are pressed or released. In the case where a simple keypad matrix with two-contact switches is used, there is a chance of "ghost" key detection when three or more keys are pressed. This is a limitation imposed by such a keypad matrix.
As seen in Figure 46-5, three keys pressed simultaneously can cause a short between the column currently "scanned" by the software and another column. Depending on the location of the third key pressed, a "ghost" key press may be detected.

However, this can be corrected by using a keypad matrix that provides "ghost" key protection. Such a matrix implements a one-way "diode" at all keypad points between rows and columns. This way, the multiple pressing of three keys will not cause a short at a fourth key (see Figure 46-6).

![Figure 46-5. Decoding Wrong Three-Key-Presses](image-url)
46.5.7 3-Point Contact Keys Support

The KPP supports interfacing to a matrix consisting of 3-point contact keys. As shown in Figure 46-7, two points of such a key are connected to keypad lines, while a third point is connected to ground (low logic).

The keypad lines should be configured as input and a pull-up should to be present on these lines. When such a key is pressed, corresponding keypad lines go low and an interrupt is generated. There is no need to perform a scanning routine for identification of pressed key as it can be done by reading the keypad data-register. A limitation with such a matrix is that for every key at least one keypad row line should be used.

Figure 46-6. Matrix with "Ghost" Key Protections
46.6 Initialization/Application Information

46.6.1 Typical Keypad Configuration and Scanning Sequence

Perform the following steps to configure the keypad:

1. Enable the number of rows in the keypad (KPP_KPCR[KRE]).
2. Write 0s to KPP_KPDR[KCD].
3. Configure the keypad columns as open-drain (KPP_KPCR[KCO]).
4. Configure columns as output (KPP_KDDR[KCDD]) and rows as input (KPP_KDDR[KRDD]).
5. Clear the KPKD Status Flag and Synchronizer chain.
6. Set the KDIE control bit, and clear the KRIE control bit (avoid false release events).
7. (The system is now in standby mode, and awaiting a key press.)

46.6.2 Key Press Interrupt Scanning Sequence

Perform the following steps to perform a keypad scanning routine:

1. Disable both (depress and release) keypad interrupts.
2. Write 1s to KPP_KPDR[KCD], setting column data to 1s.
3. Configure columns as totem pole outputs (for quick discharging of keypad capacitance).
4. Configure columns as open-drain.
5. Write a single column to 0, and other columns to 1.
6. Sample row inputs and save data. Multiple key presses can be detected on a single column.
7. Repeat Steps 2-6 for remaining columns.
8. Return all columns to 0 in preparation for standby mode.
9. Clear KPKD and KPKR status bit(s) by writing to a "1"; set the KPKR synchronizer chain by writing a "1" to the KPP_KRSS register; and clear the KPKD synchronizer chain by writing a "1" to the KDSC register.
10. Re-enable the appropriate keypad interrupt(s) so that the KDIE detects a key hold condition, or the KRIE detects a key-release event.

46.6.3 Additional Comments

The order of key press detection can be done in software only. Therefore, the software may need to run the scan routines at very short intervals of time per the application's demands. The reason that such functionality cannot be put in the KPP is that the block is limited by the number of external pins.

For the keys that require a very precise order (such as game keys), individual GPIO pins may be more useful.

46.7 KPP Memory Map/Register Definition

The KPP contains four registers.
KPP memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401F_C000</td>
<td>Keypad Control Register (KPP_KPCR)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>46.7.1/2733</td>
</tr>
<tr>
<td>401F_C002</td>
<td>Keypad Status Register (KPP_KPSR)</td>
<td>16</td>
<td>R/W</td>
<td>0400h</td>
<td>46.7.2/2734</td>
</tr>
<tr>
<td>401F_C004</td>
<td>Keypad Data Direction Register (KPP_KDDR)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>46.7.3/2735</td>
</tr>
<tr>
<td>401F_C006</td>
<td>Keypad Data Register (KPP_KPDR)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>46.7.4/2736</td>
</tr>
</tbody>
</table>

46.7.1 Keypad Control Register (KPP_KPCR)

The Keypad Control Register determines which of the eight possible column strobes are to be open drain when configured as outputs, and which of the eight row sense lines are considered in generating an interrupt to the core.

It is up to the programmer to ensure that pins being used for functions other than the keypad are properly disabled. The KPP_KPCR register is byte- or half-word-addressable.

Address: 401F_C000h base + 0h offset = 401F_C000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>KCO</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>KRE</td>
</tr>
</tbody>
</table>

KPP_KPCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–8</td>
<td>Keypad Column Strobe Open-Drain Enable. Setting a column open-drain enable bit (KCO7-KCO0) disables the pull-up driver on that pin. Clearing the bit allows the pin to drive to the high state. This bit has no effect when the pin is configured as an input.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Configuration of external port control logic (for example, IOMUX) should be done properly so that the KPP controls an open-drain enable of the pin.</td>
</tr>
<tr>
<td>0</td>
<td>TOTEM_POLE — Column strobe output is totem pole drive.</td>
</tr>
<tr>
<td>1</td>
<td>OPEN_DRAIN — Column strobe output is open drain.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>KRE</td>
<td>Keypad Row Enable. Setting a row enable control bit in this register enables the corresponding row line to participate in interrupt generation. Likewise, clearing a bit disables that row from being used to generate an interrupt. This register is cleared by a reset, disabling all rows. The row-enable logic is independent of the programmed direction of the pin. Writing a &quot;0&quot; to the data register of the pins configured as outputs will cause a keypad interrupt to be generated if the row enable associated with that bit is set.</td>
</tr>
<tr>
<td>0</td>
<td>Row is not included in the keypad key press detect.</td>
</tr>
<tr>
<td>1</td>
<td>Row is included in the keypad key press detect.</td>
</tr>
</tbody>
</table>
### 46.7.2 Keypad Status Register (KPP_KPSR)

The Keypad Status Register reflects the state of the key press detect circuit. The KPP_KPSR register is byte- or half-word-addressable.

Address: 401F_C000h base + 2h offset = 401F_C002h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>KRIE</td>
<td>KDIE</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>3</td>
<td>2</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>KPKR</td>
<td>KPKD</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>KRSS</td>
<td>KDSC</td>
<td>w1c</td>
<td>w1c</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### KPP_KPSR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–10 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>9 KRIE</td>
<td>Keypad Release Interrupt Enable. The software should ensure that the interrupt for a Key Release event is masked until it has entered the key pressed state, and vice versa, unless this activity is desired (as might be the case when a repeated interrupt is to be generated). The synchronizer chains are capable of being initialized to detect repeated key presses or releases. If they are not initialized when the corresponding event flag is cleared, false interrupts may be generated for depress (or release) events shorter than the length of the corresponding chain.</td>
</tr>
<tr>
<td>0</td>
<td>No interrupt request is generated when KPKR is set.</td>
</tr>
<tr>
<td>1</td>
<td>An interrupt request is generated when KPKR is set.</td>
</tr>
<tr>
<td>8 KDIE</td>
<td>Keypad Key Depress Interrupt Enable. Software should ensure that the interrupt for a Key Release event is masked until it has entered the key pressed state, and vice-versa, unless this activity is desired (as might be the case when a repeated interrupt is to be generated). The synchronizer chains are capable of being initialized to detect repeated key presses or releases. If they are not initialized when the corresponding event flag is cleared, false interrupts may be generated for depress (or release) events shorter than the length of the corresponding chain.</td>
</tr>
<tr>
<td>0</td>
<td>No interrupt request is generated when KPKD is set.</td>
</tr>
<tr>
<td>1</td>
<td>An interrupt request is generated when KPKD is set.</td>
</tr>
<tr>
<td>7–4 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>3 KRSS</td>
<td>Key Release Synchronizer Set. Self-clear bit. The Key release synchronizer is set by writing a logic one into this bit. Reads return a value of &quot;0&quot;.</td>
</tr>
<tr>
<td>0</td>
<td>No effect</td>
</tr>
<tr>
<td>1</td>
<td>Set bits which sets keypad release synchronizer chain</td>
</tr>
</tbody>
</table>

_Table continues on the next page..._
### KPP_KPSR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>2 KDSC</td>
<td>Key Depress Synchronizer Clear. Self-clear bit. The Key depress synchronizer is cleared by writing a logic “1” into this bit. Reads return a value of “0”.</td>
</tr>
<tr>
<td>0</td>
<td>No effect</td>
</tr>
<tr>
<td>1</td>
<td>Set bits that clear the keypad depress synchronizer chain</td>
</tr>
<tr>
<td>1 KPKR</td>
<td>Keypad Key Release. The keypad key release (KPKR) status bit is set when all enabled rows are detected high after synchronization (the KPKR status bit will be set when cleared by a reset). The KPKR bit may be used to generate a maskable key release interrupt. The key release synchronizer may be set high by software after scanning the keypad to ensure a known state. Due to the logic function of the release and depress synchronizer chains, it is possible to see the re-assertion of a status flag (KPKD or KPKR) if it is cleared by software prior to the system exiting the state it represents. Reset value of register is “0” as long as reset is asserted. However when reset is de-asserted, the value of the register depends upon the external row pins and can become “1”.</td>
</tr>
<tr>
<td>0</td>
<td>No key release detected</td>
</tr>
<tr>
<td>1</td>
<td>All keys have been released</td>
</tr>
<tr>
<td>0 KPKD</td>
<td>Keypad Key Depress. The keypad key depress (KPKD) status bit is set when one or more enabled rows are detected low after synchronization. The KPKD status bit remains set until cleared by the software. The KPKD bit may be used to generate a maskable key depress interrupt. If desired, the software may clear the key press synchronizer chain to allow a repeated interrupt to be generated while a key remains pressed. In this case, a new interrupt will be generated after the synchronizer delay (4 cycles of the low frequency reference clock (ipg_clk_32K) elapses if a key remains pressed. This functionality can be used to detect a long key press. Due to the logic function of the release and depress synchronizer chains, it is possible to see the re-assertion of a status flag (KPKD or KPKR) if it is cleared by the software prior to the system exiting the state it represents.</td>
</tr>
<tr>
<td>0</td>
<td>No key presses detected</td>
</tr>
<tr>
<td>1</td>
<td>A key has been depressed</td>
</tr>
</tbody>
</table>

### 46.7.3 Keypad Data Direction Register (KPP_KDDR)

The bits in the KPP_KDDR control the direction of the keypad port pins. The upper eight bits in the register affect the pins designated as column strobes, while the lower eight bits affect the row sense pins. Setting any bit in this register configures the corresponding pin as an output. Clearing any bit in this register configures the corresponding port pin as an input. For the Keypad Row DDR, an internal pull-up is enabled if the corresponding bit is clear. This register is cleared by a reset, configuring all pins as inputs. The KPP_KDDR register is byte- or half-word addressable.

**NOTE**

When a pin is used as row pin for keypad purposes, all corresponding pull-ups should be enabled at the upper level (for example, IOMUX) when the bit in KRDD is cleared.
Address: 401F_C000h base + 4h offset = 401F_C004h

<table>
<thead>
<tr>
<th>Bit</th>
<th>KCDD</th>
<th>KRDD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read/Write</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

KPP_KDDR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–8</td>
<td>Keypad Column Data Direction Register. Setting a bit configures the corresponding COLn pin as an output (where $n = 7$ through 0).</td>
</tr>
</tbody>
</table>
| KCDD  | 0  INPUT — COLn pin is configured as an input.  
|       | 1  OUTPUT — COLn pin is configured as an output. |

| KRDD  | Keypad Row Data Direction. Setting a bit configures the corresponding ROWn pin as an output (where $n = 7$ through 0). |
|       | 0  INPUT — ROWn pin configured as an input.  
|       | 1  OUTPUT — ROWn pin configured as an output. |

46.7.4 Keypad Data Register (KPP_KPDR)

This 16-bit register is used to access the column and row data. Data written to this register is stored in an internal latch, and for each pin configured as an output, the stored data is driven onto the pin. A read of this register returns the value on the pin for those bits configured as inputs. Otherwise, the value read is the value stored in the register.

The KPP_KPDR register is byte- or half-word addressable. This register is not initialized by a reset. Valid data should be written to this register before any bits are configured as outputs.

Address: 401F_C000h base + 6h offset = 401F_C006h

<table>
<thead>
<tr>
<th>Bit</th>
<th>KCD</th>
<th>KRD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read/Write</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0</td>
<td>0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

KPP_KPDR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–8</td>
<td>Keypad Column Data. A read of these bits returns the value on the pin for those bits configured as inputs. Otherwise, the value read is the value stored in the register.</td>
</tr>
</tbody>
</table>
| KCD   | 0  Read/Write "0" from/to column ports  
|       | 1  Read/Write "1" from/to column ports |

| KRD   | Keypad Row Data. A read of these bits returns the value on the pin for those bits configured as inputs. Otherwise, the value read is the value stored in the register. |
|       | 0  Read/Write "0" from/to row ports  
<p>|       | 1  Read/Write &quot;1&quot; from/to row ports |</p>
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>

KPP_KPDR field descriptions (continued)
Chapter 47
Low Power Inter-Integrated Circuit (LPI2C)

47.1 Chip-specific LPI2C information

Table 47-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

**NOTE**

For LPI2C on this device, only LPI2C1 fully supports the 5 wires, while other instances (LPI2C2, ...) have only 2 wires.
47.2 Introduction

The LPI2C is a low power Inter-Integrated Circuit (I2C) module that supports an efficient interface to an I2C bus as a master and/or as a slave.

- The LPI2C implements logic support for standard-mode, fast-mode, fast-mode plus and ultra-fast modes of operation.
- The LPI2C is designed to use little CPU overhead, with DMA offloading of FIFO register accesses.
- The LPI2C can continue operating in stop modes if an appropriate clock is available.

The LPI2C module also complies with the System Management Bus (SMBus) Specification, version 2. From Wikipedia: The System Management Bus (abbreviated to SMBus or SMB) is a single-ended simple two-wire bus for the purpose of lightweight communication.
47.2.1 Features

The LPI2C supports:

- Standard, Fast, Fast+ and Ultra Fast modes are supported
- High speed mode (HS) in slave mode
- High speed mode (HS) in master mode, if SCL pin implements current source pull-up (device-specific)
• Multi-master support, including synchronization and arbitration. Multi-master means any number of master nodes can be present. Additionally, master and slave roles may be changed between messages (after a STOP is sent).
• Clock stretching: From Wikipedia: multiple nodes may be driving the lines simultaneously. If any node is driving the line low, then the line will be low. I2C nodes that are trying to transmit a logical one (i.e., letting the line float high) can detect this condition (line is low), and conclude that another node is active at the same time.
  • When node detection is used on the SCL line, this is called clock stretching, and it is used as a flow control mechanism for slaves.
  • When node detection is used on the SDA line, this is called arbitration, and it ensures that there is only one transmitter at a time.
• General call, 7-bit and 10-bit addressing
• Software reset, START byte and Device ID (also require software support)

The LPI2C master supports:
• Command/transmit FIFO of 4 words.
• Receive FIFO of 4 words.
• Command FIFO will wait for idle I2C bus before initiating transfer
• Command FIFO can initiate (repeated) START and STOP conditions and one or more master-receiver transfers
• STOP condition can be generated from command FIFO, or generated automatically when the transmit FIFO is empty
• Host request input to control the start time of an I2C bus transfer
• Flexible receive data match can generate interrupt on data match and/or discard unwanted data
• Flag and optional interrupt to signal Repeated START condition, STOP condition, loss of arbitration, unexpected NACK, and command word errors
• Supports configurable bus idle timeout and pin-stuck-low timeout

The LPI2C slave supports:
• Separate I2C slave registers to minimize software overhead because of master/slave switching
• Support for 7-bit or 10-bit addressing, address range, SMBus alert and general call address
• Transmit data register that supports interrupt or DMA requests
• Receive data register that supports interrupt or DMA requests
• Software-controllable ACK or NACK, with optional clock stretching on ACK/NACK bit
• Configurable clock stretching, to avoid transmit FIFO underrun and receive FIFO overrun errors
• Flag and optional interrupt at end of packet, STOP condition, or bit error detection

47.2.2 Block Diagram

Figure 47-4. LPI2C block diagram
### 47.2.3 Modes of operation

**Table 47-2. Chip modes supported by the LPI2C module**

<table>
<thead>
<tr>
<th>Chip mode</th>
<th>LPI2C Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>Run</td>
<td>Normal operations</td>
</tr>
<tr>
<td>Stop</td>
<td>Can continue operating in stop mode if the Doze Enable bit (MCR[DOZEN]) is clear and the LPI2C is using an external or internal clock source that remains operating during stop mode.</td>
</tr>
<tr>
<td>Debug</td>
<td>Can continue operating in debug mode if the Debug Enable bit (MCR[DBGE]) is set.</td>
</tr>
</tbody>
</table>

### 47.2.4 Signal Descriptions

**Table 47-3. Signals**

<table>
<thead>
<tr>
<th>Signal</th>
<th>Name</th>
<th>2-Wire Scheme</th>
<th>4-Wire Scheme</th>
<th>I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCL</td>
<td>LPI2C clock line</td>
<td>SCL</td>
<td>In 4-wire mode, this is the SCL input pin.</td>
<td>I/O</td>
</tr>
<tr>
<td>SDA</td>
<td>LPI2C data line</td>
<td>SDA</td>
<td>In 4-wire mode, this is the SDA input pin.</td>
<td>I/O</td>
</tr>
<tr>
<td>HREQ</td>
<td>Host request</td>
<td></td>
<td>If host request is asserted and the I2C bus is idle, then it will initiate an LPI2C master transfer.</td>
<td>I</td>
</tr>
<tr>
<td>SCLS</td>
<td>Secondary I2C clock line</td>
<td>Not used</td>
<td>In 4-wire mode, this is the SCLS output pin. If LPI2C master/slave are configured to use separate pins, then this the LPI2C slave SCL pin.</td>
<td>I/O</td>
</tr>
<tr>
<td>SDAS</td>
<td>Secondary I2C data line</td>
<td>Not used</td>
<td>In 4-wire mode, this is the SDAS output pin. If LPI2C master/slave are configured to use separate pins, then this the LPI2C slave SDA pin.</td>
<td>I/O</td>
</tr>
</tbody>
</table>

### 47.2.5 Wiring options

LPI2C can be used to implement 2-wire or 4-wire I²C serial busses.
Figure 47-5. 2-Wire scheme

Some applications can provide a lot of load and noise on the I²C bus; to ensure robust I²C operations, a 4-wire interface with the MCU can be used, splitting the 2 lines into inputs and outputs. Using a few transistors, resistors and diodes, designers can make their own inexpensive line drivers.
47.3 Functional description

47.3.1 Clocking and Resets

Table 47-4. Clocks

<table>
<thead>
<tr>
<th>LPi2C Functional clock</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>The LPi2C functional clock is asynchronous to the bus clock and can remain enabled in low power modes to support I2C bus transfers by the LPi2C master. The functional clock is also used by the LPi2C slave to support digital filter and data hold time configurations. The LPi2C master divides the...</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 47-4. Clocks (continued)

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>functional</td>
<td>clock by a prescaler and the resulting frequency must be at least 8 times faster than the I2C bus bandwidth.</td>
</tr>
<tr>
<td>external</td>
<td>The LPI2C slave logic is clocked directly from the external pins SCL and SDA (or SCLS and SDAS if master and slave are implemented on separate pins). This allows the LPI2C slave to remain operational, even when the LPI2C functional clock is disabled.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>The LPI2C slave digital filter must be disabled if the LPI2C functional clock is disabled, and this can affect compliance with some of the timing parameters of the I2C specification, such as the data hold time.</td>
</tr>
<tr>
<td>bus clock</td>
<td>The bus clock is only used for bus accesses to the control and configuration registers. The bus clock frequency must be sufficient to support the data bandwidth requirements of the LPI2C master and slave registers.</td>
</tr>
</tbody>
</table>

Table 47-5. Resets

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip reset</td>
<td>The logic and registers for the LPI2C master and slave are reset to their default state on a chip reset.</td>
</tr>
</tbody>
</table>
| Software reset| • The LPI2C master implements a software reset bit in its Control Register. The MCR[RST] will reset all master logic and registers to their default state, except for the MCR itself.  
• The LPI2C slave implements a software reset bit in its Control Register. The SCR[RST] will reset all slave logic and registers to their default state, except for the SCR itself. |
| FIFO reset    | • The LPI2C master implements write-only control bits that reset the transmit FIFO (MCR[RTF]) and receive FIFO (MCR[RRF]). After a FIFO is reset, that FIFO is empty.  
• The LPI2C slave implements write-only control bits that reset the transmit data register (SCR[RTF]) and receive data register (SCR[RRF]). After a data register is reset, that data register is empty. |

47.3.2 Master Mode

The LPI2C master logic operates independently from the slave logic to perform all master mode transfers on the I2C bus.

47.3.2.1 Transmit and Command FIFO commands

The transmit FIFO stores command data to initiate the various I2C operations. The following operations can be initiated through commands in the transmit FIFO:

• START or Repeated START condition with address byte and expecting ACK or NACK.
• Transmit data (this is the default for zero extended byte writes to the transmit FIFO).
• Receive 1-256 bytes of data (can also be configured to discard receive data and not store in receive FIFO).
• STOP condition (can also be configured to send STOP condition when transmit FIFO is empty).
Multiple transmit and receive commands can be inserted between the START condition and STOP condition; transmit and receive commands must not be interleaved (to comply with the I2C specification). The receive data command and the receive data and discard commands can be interleaved, to ensure that only the desired received data is stored in the receive FIFO (or compared with the data match logic).

The LPI2C master will automatically transmit a NACK on the last byte of a receive data command unless the next command in the FIFO is also a receive data command. A NACK is also automatically transmitted if the transmit FIFO is empty when a receive data command completes.

The LPI2C master supports 10-bit addressing through a (repeated) START condition, followed by a transmit data byte containing the second address byte, followed by any number of data bytes with the master-transmit data.

A START or Repeated START condition that is expecting a NACK (for example, HS-mode master code) must be followed by a STOP or (repeated) START condition.

### 47.3.2.2 Master operations

Whenever the LPI2C is enabled, it monitors the I2C bus to detect when the I2C bus is idle (MSR[BBF]). The I2C bus is no longer considered idle if either SCL or SDA are low, and the I2C bus becomes idle if a STOP condition is detected or if a bus idle timeout is detected (as configured by MCFGR2[BUSIDLE]). After the I2C bus is idle, the transmit FIFO is not empty, and the host request is either asserted or disabled, then the LPI2C master will initiate a transfer on the I2C bus. This involves the following steps:

- Wait the bus idle time equal to (MCCR0[CLKLO] + 1) multiplied by the prescaler (MCFGR1[PRESCALE]).
- Transmit a START condition and address byte using the timing configuration in the Master Clock Configuration Register 0 (MCCR0); if a high speed mode transfer is configured, then the timing configuration from Master Clock Configuration Register 1 (MCCR1) is used instead.
- Perform master-transmit or master-receive transfers, as configured by the transmit FIFO.
- Transmit NACK on the last byte of a master-receive transfer, unless the next command in the transmit FIFO is also a receive data command and the transmit FIFO is not empty.
- Transmit a Repeated START or STOP condition as configured by the transmit FIFO and/or MCFGR1[AUTOSTOP]. A repeated START can change which timing configuration register is used.
When the LPI2C master is disabled (either due to MCR[MEN] being clear or automatically due to mode entry), the LPI2C will continue to empty the transmit FIFO until a STOP condition is transmitted. However, the LPI2C will no longer stall the I2C bus waiting for the transmit or receive FIFO, and after the transmit FIFO is empty, the LPI2C will generate a STOP condition automatically.

The LPI2C master can stall the I2C bus under certain conditions; this will result in SCL pulled low continuously on the first bit of a byte, until the condition is removed:

- LPI2C master is enabled and busy, the transmit FIFO is empty, and MCFGR1[AUTOSTOP] is clear.
- LPI2C master is enabled and receiving data, receive data is not being discarded (due to command or receive data match), and the receive FIFO is full.

### 47.3.2.3 Receive FIFO and Data Matching

The receive FIFO is used to store receive data during master-receiver transfers. Receive data can also be configured to discard receive data instead of storing in the receive FIFO; this is configured by the command word in the transmit FIFO.

Receive data supports a receive data match function that can match received data against one of two bytes or against a masked data byte. The data match function can also be configured to compare only the first one or two received data words since the last (repeated) START condition. Receive data that is already discarded due to the command word cannot cause the data match to set, and will delay the match on the first received data word until after the discarded data is received. The receiver match function can also be configured to discard all receive data until a data match is detected, using the MCFGR0[RDMO] control bit. When clearing the MCFGR0[RDMO] control bit following a data match, clear MCFGR0[RDMO] before clearing MSR[DMF], to allow all subsequent data to be received.

### 47.3.2.4 Timing Parameters

The following timing parameters can be configured by the LPI2C master. Parameters are configured separately for high speed mode (MCCR1) and other modes (MCCR0). This allows the high speed mode master code to be sent using the regular timing parameters, and then switch to the high speed mode timing (following a repeated START) until the next STOP condition.
The LPI2C master timing parameters in LPI2C functional clock cycles are configured as follows. They must be configured to meet the I2C timing specification for the required mode.

### Table 47-6. Timing Parameters

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>hold time (repeated) START condition</td>
<td>tHD:STA</td>
<td>(SETHOLD +1) x (2 ^ PRESCALE)</td>
</tr>
<tr>
<td>LOW period of the SCL clock</td>
<td>tLOW</td>
<td>(CLKLO + 1) x (2 ^ PRESCALE)</td>
</tr>
<tr>
<td>HIGH period of the SCL clock</td>
<td>tHIGH</td>
<td>(CLKHI + 1 + SCL_LATENCY) x (2 ^ PRESCALE)</td>
</tr>
<tr>
<td>setup time for a repeated START condition or STOP condition</td>
<td>tSU:STA, tSU:STO</td>
<td>(SETHOLD + 1 + SCL_LATENCY) x (2 ^ PRESCALE)</td>
</tr>
<tr>
<td>data hold time</td>
<td>tHD:DAT</td>
<td>(DATAVD + 1) x (2 ^ PRESCALE)</td>
</tr>
<tr>
<td>data setup time</td>
<td>tSU:DAT</td>
<td>(SDA_LATENCY + 1) x (2 ^ PRESCALE)</td>
</tr>
<tr>
<td>bus free time between a STOP and START condition</td>
<td>tBUF</td>
<td>(CLKLO + 1 + SDA_LATENCY) x (2 ^ PRESCALE)</td>
</tr>
<tr>
<td>data valid time, data valid acknowledge time</td>
<td>tVD:DAT, tVD:ACK</td>
<td>(DATAVD + 1) x (2 ^ PRESCALE)</td>
</tr>
</tbody>
</table>

The latency parameters are defined in the following table, these parameters assume the risetime is less than one LPI2C functional clock cycle. The risetime depends on a number of factors, including the I2C bus loading and external pull-up resistor sizing. A larger risetime will increase the number of cycles that the signal takes to propagate through the synchronizer (and glitch filter), which increases the latency.

### Table 47-7. Synchronization Latency

<table>
<thead>
<tr>
<th>Timing Parameter</th>
<th>Timing Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCL_LATENCY</td>
<td>ROUNDDOWN ( (2 + FILTSCL + SCL_RISETIME) / (2 ^ PRESCALE) )</td>
</tr>
<tr>
<td>SDA_LATENCY</td>
<td>ROUNDDOWN ( (2 + FILTSDA + SDA_RISETIME) / (2 ^ PRESCALE) )</td>
</tr>
</tbody>
</table>

The following timing restrictions must be enforced to avoid unexpected START or STOP conditions on the I2C bus, or to avoid unexpected START or STOP conditions detected by the LPI2C master. The timing restrictions can be summarized as SDA cannot change when SCL is high outside of a transmitted (repeated) START or STOP condition.

### Table 47-8. LPI2C Timing Parameter Restrictions

<table>
<thead>
<tr>
<th>Timing Parameter</th>
<th>Minimum</th>
<th>Maximum</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKLO</td>
<td>0x03</td>
<td>-</td>
<td>Also: CLKLO x (2 ^ PRESCALE) &gt; SCL_LATENCY</td>
</tr>
<tr>
<td>CLKHI</td>
<td>0x01</td>
<td>-</td>
<td>Configure CLKHI to meet the duty cycle requirements in the I2C specification</td>
</tr>
<tr>
<td>SETHOLD</td>
<td>0x02</td>
<td>-</td>
<td></td>
</tr>
</tbody>
</table>
Table 47-8. LPI2C Timing Parameter Restrictions (continued)

<table>
<thead>
<tr>
<th>Timing Parameter</th>
<th>Minimum</th>
<th>Maximum</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATAVD</td>
<td>0x01</td>
<td>CLKLO - SDA_LATENCY - 1</td>
<td>Configure DATAVD to meet the data hold requirement in the I2C specification</td>
</tr>
<tr>
<td>FILTSCL</td>
<td>0x00</td>
<td>[CLKLO × (2^PRESCALE)] - 3</td>
<td>FILTSC and FILTSDA are the only parameters not multiplied by (2^PRESCALE)</td>
</tr>
<tr>
<td>FILTSDA</td>
<td>FILTSCL</td>
<td>[CLKLO × (2^PRESCALE)] - 3</td>
<td>Configuring FILTSDA greater than FILTSCL can delay the SDA input to compensate for board level skew</td>
</tr>
<tr>
<td>BUSIDLE</td>
<td>(CLKLO+SETHOLD+2) × 2</td>
<td>-</td>
<td>Must also be greater than (CLKHI+1)</td>
</tr>
</tbody>
</table>

The timing parameters must be configured to meet the requirements of the I2C specification; this will depend on the mode being supported and the LPI2C functional clock frequency. When switching between two modes using the different clock configuration registers (for example, Fast and HS-mode), the PRESCALE factor must remain constant between the modes. Some example timing configurations are provided below.

Table 47-9. LPI2C Example Timing Configurations

<table>
<thead>
<tr>
<th>I2C Mode</th>
<th>Clock Frequency</th>
<th>Baud Rate</th>
<th>PRESCALE</th>
<th>FILTSC/ FILTSDA</th>
<th>SETHOLD</th>
<th>CLKLO</th>
<th>CLKHI</th>
<th>DATAVD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Fast</td>
<td>8 MHz</td>
<td>400 kbps</td>
<td>0x0</td>
<td>0x0/0x0</td>
<td>0x04</td>
<td>0x0B</td>
<td>0x05</td>
<td>0x02</td>
</tr>
<tr>
<td>Fast+</td>
<td>8 MHz</td>
<td>1 Mbps</td>
<td>0x0</td>
<td>0x0/0x0</td>
<td>0x02</td>
<td>0x03</td>
<td>0x01</td>
<td>0x01</td>
</tr>
<tr>
<td>Fast</td>
<td>48 MHz</td>
<td>400 kbps</td>
<td>0x0</td>
<td>0x1/0x1</td>
<td>0x1D</td>
<td>0x3E</td>
<td>0x35</td>
<td>0x0F</td>
</tr>
<tr>
<td>Fast+</td>
<td>48 MHz</td>
<td>400 kbps</td>
<td>0x2</td>
<td>0x1/0x1</td>
<td>0x03</td>
<td>0x06</td>
<td>0x04</td>
<td>0x04</td>
</tr>
<tr>
<td>HS-mode</td>
<td>48 MHz</td>
<td>3.2 Mbps</td>
<td>0x0</td>
<td>0x0/0x0</td>
<td>0x07</td>
<td>0x11</td>
<td>0x0B</td>
<td>0x03</td>
</tr>
<tr>
<td>Fast</td>
<td>60 MHz</td>
<td>400 kbps</td>
<td>0x1</td>
<td>0x2/0x2</td>
<td>0x11</td>
<td>0x28</td>
<td>0x1F</td>
<td>0x08</td>
</tr>
<tr>
<td>Fast+</td>
<td>60 MHz</td>
<td>1 Mbps</td>
<td>0x1</td>
<td>0x2/0x2</td>
<td>0x07</td>
<td>0x0F</td>
<td>0x0B</td>
<td>0x01</td>
</tr>
<tr>
<td>HS-mode</td>
<td>60 MHz</td>
<td>3.33 Mbps</td>
<td>0x1</td>
<td>0x0/0x0</td>
<td>0x04</td>
<td>0x04</td>
<td>0x02</td>
<td>0x01</td>
</tr>
</tbody>
</table>

1. Your specific device may not support all clock frequencies and baud rates; check the module instantiation and system information.

47.3.2.5 Error Conditions

The LPI2C master will monitor for errors while it is active, the following conditions will generate an error flag and block a new START condition from being sent, until the flag is cleared by software:
- A START or STOP condition is detected and is not generated by the LPI2C master (sets MSR[ALF]).
- Transmitting data on SDA and different values are being received (sets MSR[ALF]).
- NACK is detected when transmitting data, and MCFGR1[IGNACK] is clear (sets MSR[NDF]).
- NACK is detected and is expecting ACK for the address byte, and MCFGR1[IGNACK] is clear (sets MSR[NDF]).
- ACK is detected and is expecting NACK for the address byte, and MCFGR1[IGNACK] is clear (sets MSR[NDF]).
- Transmit FIFO is requesting to transmit or receive data without a START condition (sets MSR[FEF]).
- SCL (or SDA if MCFGR1[TIMECFG] is set) is low for (MCFGR2[TIMELOW] * 256) prescaler cycles without a pin transition (sets MSR[PLTF]).

Software must respond to the MSR[PTLF] flag to terminate the existing command either cleanly (by clearing MCR[MEN]), or abruptly (by setting MCR[SWRST]).

The MCFGR2[BUSIDLE] field can be used to force the I2C bus to be considered idle when SCL and SDA remain high for (BUSIDLE+1) prescaler cycles. The I2C bus is normally considered idle when the LPI2C master is first enabled, but when BUSIDLE is configured greater than zero then SCL and/or SDA must be high for (BUSIDLE+1) prescaler cycles before the I2C bus is first considered idle.

### 47.3.2.6 Pin Configuration

- **Open-drain support:** The LPI2C master defaults to open-drain configuration of the SDA and SCL pins. Support for true open drain depends on the specific device, and requires the pins where LPI2C pins are muxed to support true open drain.
- **High Speed mode support:** Support for high speed mode also depends on the specific device, and requires the SCL pin to support the current source pull-up required in the I2C specification.
- **Ultra-Fast mode support:** The LPI2C master also supports the output-only push-pull function required for I2C ultra-fast mode using the SDA and SCL pins. Support for ultra-fast mode also requires the IGNACK bit to be set.
- **Push-pull 2-wire support:** A push-pull 2-wire configuration is also available to the LPI2C master that may support a partial high speed mode, if the LPI2C is the only master and all I2C pins on the bus are at the same voltage. This will configure the SCL pin as push-pull for every clock except the 9th clock pulse, to allow high speed mode compatible slaves to perform clock stretching. In this mode, the SDA pin is tristated for master-receive data bits and master-transmit ACK/NACK bits, and is configured as push-pull at other times. To avoid the risk of contention when SDA is
push-pull, the pin can be configured for open-drain operation, as part of the device-specific configuration.

- **Push-pull 4-wire support**: The push-pull 4-wire configuration separates the SCL input data and output data into separate pins, and separates the SDA input data and output data into separate pins. The SCL/SDA pins are used for input data; the SCLS/SDAS pins are used for output data, with configurable polarity. This simplifies external connections when connecting the LPI2C to the I2C bus through external level shifters or discrete components. When using this 4-wire configuration, the LPI2C master logic and LPI2C slave logic are not able to connect to separate I2C buses.

### 47.3.3 Slave Mode

To perform all slave mode transfers on the I2C bus, the LPI2C slave logic operates independently from the LPI2C master logic.

#### 47.3.3.1 Address Matching

The LPI2C slave can be configured:

- to match one of two addresses, using either 7-bit or 10-bit addressing modes for each address
- to match a range of addresses in either 7-bit or 10-bit addressing modes
- to match the General Call Address, and generate appropriate flags
- to match the SMBus Alert Address, and generate appropriate flags
- to detect the high speed mode master code, and to disable the digital filters and output valid delay time until the next STOP condition is detected

After a valid address is matched, the LPI2C slave will automatically perform slave-transmit or slave-receive transfers until:

- a NACK is detected (unless IGNACK is set)
- a bit error is detected (the LPI2C slave is driving SDA, but a different value is sampled)
- a (repeated) START or STOP condition is detected

#### 47.3.3.2 Transmit and Receive Data

- The Transmit and Receive Data registers are double-buffered and only update during a slave-transmit and slave-receive transfer, respectively.
The slave address that was received can be configured to be read from either the Receive Data register (for example, when using DMA to transfer data), or from the Address Status register.

The Transmit Data register can be configured to only request data after a slave-transmit transfer is detected, or to request new data whenever the Transmit Data register is empty.

The Transmit Data register should only be written when the Transmit Data flag is set.

The Receive Data register should only be read when the Received Data flag is set (or the Address Valid flag is set and RXCFG=1).

The Address Status register should only be read when the Address Valid flag is set.

### 47.3.3.3 Clock Stretching

The LPI2C slave supports many configurable options for when clock stretching is performed. The following conditions can be configured to perform clock stretching:

- During the 9th clock pulse of the address byte and the Address Valid flag is set.
- During the 9th clock pulse of a slave-transmit transfer and the Transmit Data flag is set.
- During the 9th clock pulse of a slave-receive transfer and the Receive Data flag is set.
- During the 8th clock pulse of an address byte or a slave-receive transfer and the Transmit ACK flag is set. In high speed mode, this is disabled.
- Clock stretching can also be extended for CLKHOLD cycles, to allow additional setup time to sample the SDA pin externally. In high speed mode, this is disabled.

Unless extended by the CLKHOLD configuration, clock stretching will extend for one peripheral bus clock cycle after SDA updates when clock stretching is enabled.

### 47.3.3.4 Timing Parameters

The LPI2C slave can configure the following timing parameters. These parameters are disabled when SCR[FILTEN] is clear, when SCR[FILTDZ] is set in Doze mode, and when LPI2C slave detects high speed mode. When disabled, the LPI2C slave is clocked directly from the I2C bus, and may not satisfy all timing requirements of the I2C specification (such as SDA minimum hold time in Standard/Fast mode).

- SDA data valid time from SCL negation to SDA update
- SCL hold time when clock stretching is enabled to increase setup time when sampling SDA externally
• SCL glitch filter time
• SDA glitch filter time

The LPI2C slave imposes the following restrictions on the timing parameters:

• FILTSDA must be configured to greater than or equal to FILTSCL (unless compensating for board level skew between SDA and SCL).
• DATAVD must be configured less than the minimum SCL low period.

### 47.3.3.5 Error Conditions

The LPI2C slave can detect the following error conditions:

• Bit error flag will set when the LPI2C slave is driving SDA, but samples a different value than what is expected.
• FIFO error flag will set due to a transmit data underrun or a receive data overrun. To eliminate the possibility of underrun and overrun occurring, enable clock stretching.
• FIFO error flag will also set due to an address overrun when RXCFG is set, otherwise an address overrun is not flagged. To eliminate the possibility of overrun occurring, enable clock stretching.

The LPI2C slave does not implement a timeout due to SCL and/or SDA being stuck low. If this detection is required, then the LPI2C master logic should be used and so software can reset the LPI2C slave when this condition is detected.

### 47.3.4 Interrupts and DMA Requests

Depending on the specific device, interrupts and DMA requests can be combined in some ways:

• The LPI2C master and slave interrupts may be combined
• The LPI2C master and slave transmit DMA requests may be combined
• The LPI2C master and slave receive DMA requests may be combined

#### 47.3.4.1 Master mode

The next table lists the master mode sources that can generate LPI2C master interrupts and LPI2C master transmit/receive DMA requests.
### Table 47-10. Master Interrupts and DMA Requests

<table>
<thead>
<tr>
<th>Flag</th>
<th>Name</th>
<th>Description</th>
<th>Can generate</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt?</td>
</tr>
<tr>
<td>TDF</td>
<td>Transmit Data Flag</td>
<td>Data can be written to Transmit FIFO, as configured by the Transmit FIFO Watermark MFCR[TXWATER]</td>
<td>Y</td>
</tr>
<tr>
<td>RDF</td>
<td>Receive Data Flag</td>
<td>Data can be read from the Receive FIFO, as configured by the Receive FIFO Watermark MFCR[RXWATER]</td>
<td>Y</td>
</tr>
<tr>
<td>EPF</td>
<td>End Packet Flag</td>
<td>Master has transmitted a Repeated START or STOP condition</td>
<td>Y</td>
</tr>
<tr>
<td>SDF</td>
<td>STOP Detect Flag</td>
<td>Master has transmitted a STOP condition</td>
<td>Y</td>
</tr>
</tbody>
</table>
| NDF  | NACK Detect Flag | • During an address byte, the master expected an ACK but detected a NACK  
• During an address byte, the master expected a NACK but detected an ACK  
• During a master-transmitter data byte, the master detected a NACK | Y | N | Y |
| ALF  | Arbitration Lost Flag | • The master lost arbitration due to a START/STOP condition detected at the wrong time  
• Or the master was transmitting data but received different data than the data that was transmitted | Y | N | Y |
| FEF  | FIFO Error Flag | The master is expecting a START condition in the Command FIFO, but the next entry in the Command FIFO is not a START condition | Y | N | Y |
| PLTF | Pin Low Timeout Flag | Pin low timeout is enabled and SCL (or SDA if configured) is low for longer than the configured timeout | Y | N | Y |
| DMF  | Data Match Flag | The received data matches the configured data match, but the received data is not discarded due to a command FIFO entry | Y | N | Y |
| MBF  | Master Busy Flag | LPI2C master is busy transmitting/receiving data | N | N | N |
| BBF  | Bus Busy Flag | LPI2C master is enabled and activity is detected on I2C bus, but a STOP condition has not been detected and a bus idle timeout (if enabled) has not occurred. | N | N | N |

#### 47.3.4.2 Slave mode

The next table lists the slave mode sources that can generate LPI2C slave interrupts and the LPI2C slave transmit/receive DMA requests.
### Table 47-11. Slave Interrupts and DMA Requests

<table>
<thead>
<tr>
<th>Flag</th>
<th>Name</th>
<th>Description</th>
<th>Can generate</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>Interrupt?</td>
<td>DMA Request?</td>
<td>Low Power Wakeup?</td>
</tr>
<tr>
<td>TDF</td>
<td>Transmit Data Flag</td>
<td>Data can be written to the Slave Transmit Data Register (STDR)</td>
<td>Y</td>
<td>TX</td>
<td>Y</td>
</tr>
<tr>
<td>RDF</td>
<td>Receive Data Flag</td>
<td>Data can be read from the Slave Receive Data Register (SRDR)</td>
<td>Y</td>
<td>RX</td>
<td>Y</td>
</tr>
<tr>
<td>AVF</td>
<td>Address Valid Flag</td>
<td>Address can be read from the Slave Address Status Register (SASR)</td>
<td>Y</td>
<td>RX</td>
<td>Y</td>
</tr>
<tr>
<td>TAF</td>
<td>Transmit ACK Flag</td>
<td>ACK/NACK can be written to the Slave Transmit ACK Register (STAR)</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>RSF</td>
<td>Repeated Start Flag</td>
<td>Slave has detected an address match followed by a Repeated START condition</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>SDF</td>
<td>STOP Detect Flag</td>
<td>Slave has detected an address match followed by a STOP condition</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>BEF</td>
<td>Bit Error Flag</td>
<td>Slave was transmitting data, but received different data than what was transmitted</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
</tbody>
</table>
| FEF  | FIFO Error Flag        | • Transmit data underrun  
• Receive data overrun  
• Address status overrun (when Receive Data Configuration SCFG1[RXCFG] = 1, )  
FEF flag can only set when clock stretching is disabled. | Y            | N            | Y             |
| AM0F | Address Match 0 Flag   | Slave detected an address match with SAMR[ADDR0] field                     | Y            | N            | N             |
| AM1F | Address Match 1 Flag   | Slave detected an address match with SAMR[ADDR1] field or using an address range | Y            | N            | N             |
| GCF  | General Call Flag      | Slave detected an address match with the General Call address               | Y            | N            | N             |
| SARF | SMBus Alert Response Flag | Slave detected an address match with the SMBus Alert address                  | Y            | N            | N             |
| SBF  | Slave Busy Flag        | LPI2C slave is busy receiving an address byte or is transmitting/receiving data | N            | N            | N             |
| BBF  | Bus Busy Flag          | LPI2C slave is enabled and a START condition is detected on I2C bus, but a STOP condition has not been detected | N            | N            | N             |
47.3.5 Peripheral Triggers

The connection of the LPI2C peripheral triggers to other peripherals depend upon the specific device being used.

<table>
<thead>
<tr>
<th>Trigger</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Master Output Trigger</td>
<td>The LPI2C master generates an output trigger that can be connected to other peripherals on the device. The master output trigger asserts on both a Repeated START or STOP condition, and the master output trigger remains asserted for one cycle of the LPI2C functional clock divided by the prescaler.</td>
</tr>
<tr>
<td>Slave Output Trigger</td>
<td>The LPI2C slave generates an output trigger that can be connected to other peripherals on the device. The slave output trigger asserts on both a Repeated START or STOP condition that occurs after a slave address match, and the slave output trigger remains asserted until the next slave SCL pin negation.</td>
</tr>
<tr>
<td>Input Trigger</td>
<td>To control the start of a LPI2C bus transfer, the LPI2C input trigger can be selected instead of the HREQ input. The input trigger is synchronized and to be detected, the input trigger must assert for at least 2 cycles of the LPI2C functional clock divided by the PRESCALE configuration. When the LPI2C is busy, the HREQ input (and therefore the input trigger) is ignored.</td>
</tr>
</tbody>
</table>

47.4 Memory Map and Registers

47.4.1 LPI2C register descriptions

47.4.1.1 LPI2C Memory map

Base address: 403F_0000 for LPI2C1; 403F_4000 for LPI2C2; 403F_8000 for LPI2C3; 403F_C000 for LPI2C4.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Version ID Register (VERID)</td>
<td>32</td>
<td>RO</td>
<td>0100_0003h</td>
</tr>
<tr>
<td>4h</td>
<td>Parameter Register (PARAM)</td>
<td>32</td>
<td>RO</td>
<td>0000_0202h</td>
</tr>
<tr>
<td>10h</td>
<td>Master Control Register (MCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Master Status Register (MSR)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0001h</td>
</tr>
<tr>
<td>18h</td>
<td>Master Interrupt Enable Register (MIER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>Master DMA Enable Register (MDER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>20h</td>
<td>Master Configuration Register 0 (MCFGR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>24h</td>
<td>Master Configuration Register 1 (MCFGR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 47.4.1.2 Version ID Register (VERID)

#### 47.4.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VERID</td>
<td>0h</td>
</tr>
</tbody>
</table>

#### 47.4.1.2.2 Function

.
Memory Map and Registers

47.4.1.2.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>MAJOR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>MINOR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 1</td>
<td>0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>FEATURE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

47.4.1.2.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Major Version Number</td>
</tr>
<tr>
<td>MAJOR</td>
<td>Returns the major version number for the module design specification. Read-only field.</td>
</tr>
<tr>
<td>23-16</td>
<td>Minor Version Number</td>
</tr>
<tr>
<td>MINOR</td>
<td>Returns the minor version number for the module design specification. Read-only field.</td>
</tr>
<tr>
<td>15-0</td>
<td>Feature Specification Number</td>
</tr>
<tr>
<td>FEATURE</td>
<td>Returns the feature set number. Read-only field.</td>
</tr>
<tr>
<td></td>
<td>0000000000000010b - Master only, with standard feature set</td>
</tr>
<tr>
<td></td>
<td>0000000000000011b - Master and slave, with standard feature set</td>
</tr>
</tbody>
</table>

47.4.1.3  Parameter Register (PARAM)

47.4.1.3.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PARAM</td>
<td>4h</td>
</tr>
</tbody>
</table>

47.4.1.3.2  Function
### 47.4.1.3.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 47.4.1.3.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-8</td>
<td>Master Receive FIFO Size Configures the number of words in the master receive FIFO to $2^{MRXFIFO}$</td>
</tr>
<tr>
<td>7-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3-0</td>
<td>Master Transmit FIFO Size Configures the number of words in the master transmit FIFO to $2^{MTXFIFO}$</td>
</tr>
</tbody>
</table>

### 47.4.1.4  Master Control Register (MCR)

#### 47.4.1.4.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR</td>
<td>10h</td>
</tr>
</tbody>
</table>
### 47.4.1.4.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RR F</td>
<td>RT F</td>
<td></td>
<td></td>
<td></td>
<td>DBGE N</td>
<td>DOZEN</td>
<td>RS T</td>
<td>MEN</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 47.4.1.4.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>RRF</td>
</tr>
<tr>
<td></td>
<td>Reset Receive FIFO</td>
</tr>
<tr>
<td></td>
<td>0b - No effect</td>
</tr>
<tr>
<td></td>
<td>1b - Receive FIFO is reset</td>
</tr>
<tr>
<td>8</td>
<td>RTF</td>
</tr>
<tr>
<td></td>
<td>Reset Transmit FIFO</td>
</tr>
<tr>
<td></td>
<td>0b - No effect</td>
</tr>
<tr>
<td></td>
<td>1b - Transmit FIFO is reset</td>
</tr>
<tr>
<td>7-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>DBGEN</td>
</tr>
<tr>
<td></td>
<td>Debug Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Master is disabled in debug mode</td>
</tr>
<tr>
<td></td>
<td>1b - Master is enabled in debug mode</td>
</tr>
<tr>
<td>2</td>
<td>DOZEN</td>
</tr>
<tr>
<td></td>
<td>Doze mode enable</td>
</tr>
<tr>
<td></td>
<td>Enables or disables the master in Doze mode</td>
</tr>
<tr>
<td></td>
<td>0b - Master is enabled in Doze mode</td>
</tr>
<tr>
<td></td>
<td>1b - Master is disabled in Doze mode</td>
</tr>
<tr>
<td>1</td>
<td>RST</td>
</tr>
<tr>
<td></td>
<td>Software Reset</td>
</tr>
<tr>
<td></td>
<td>Reset all internal master logic and registers, except the Master Control Register. RST remains set until cleared by software.</td>
</tr>
<tr>
<td></td>
<td>0b - Master logic is not reset</td>
</tr>
<tr>
<td></td>
<td>1b - Master logic is reset</td>
</tr>
<tr>
<td>0</td>
<td>MEN</td>
</tr>
<tr>
<td></td>
<td>Master Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Master logic is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Master logic is enabled</td>
</tr>
</tbody>
</table>
47.4.1.5 Master Status Register (MSR)

47.4.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MSR</td>
<td>14h</td>
</tr>
</tbody>
</table>

47.4.1.5.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td>W1C</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

47.4.1.5.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-26</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>Bus Busy Flag</td>
</tr>
<tr>
<td>BBF</td>
<td>0b - I2C Bus is idle</td>
</tr>
<tr>
<td></td>
<td>1b - I2C Bus is busy</td>
</tr>
<tr>
<td>24</td>
<td>Master Busy Flag</td>
</tr>
<tr>
<td>MBF</td>
<td>0b - I2C Master is idle</td>
</tr>
<tr>
<td></td>
<td>1b - I2C Master is busy</td>
</tr>
<tr>
<td>23-15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>Data Match Flag</td>
</tr>
<tr>
<td>DMF</td>
<td>Indicates that the received data has matched the MATCH0 and/or MATCH1 fields (as configured by MCFGR1[MATCFG], Match Configuration). Received data <em>that is discarded due to CMD field</em> does not cause Data Match Flag to set.</td>
</tr>
<tr>
<td></td>
<td>0b - Have not received matching data</td>
</tr>
<tr>
<td></td>
<td>1b - Have received matching data</td>
</tr>
<tr>
<td>13</td>
<td>Pin Low Timeout Flag</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| PLTF  | Will set when the SCL and/or SDA input is low for more than PINLOW cycles (Pin Low Timeout, MCFGR3[PINLOW]), even when the LPI2C master is idle.  
  • Software is responsible for resolving the pin low condition.  
  • Pin Low Timeout Flag cannot be cleared as long as the pin low timeout continues.  
  • Before the LPI2C can initiate a START condition, the Pin Low Timeout Flag must be cleared.  
  0b - Pin low timeout has not occurred or is disabled  
  1b - Pin low timeout has occurred |
| 12    | FIFO Error Flag  
  Detects an attempt to send or receive data without first generating a (repeated) START condition. This can occur if the transmit FIFO underflows when the AUTOSTOP bit is set. When FIFO Error Flag is set, the LPI2C master will send a STOP condition (if busy), and will not initiate a new START condition until FIFO Error Flag has been cleared.  
  0b - No error  
  1b - Master sending or receiving data without a START condition |
| 11    | Arbitration Lost Flag  
  Set:  
  • if the LPI2C master transmits a logic one and detects a logic zero on the I2C bus  
  • or if the LPI2C master detects a START or STOP condition while the LPI2C master is transmitting data  
  When the Arbitration Lost Flag sets, the LPI2C master will release the I2C bus (go idle), and the LPI2C master will not initiate a new START condition until the Arbitration Lost Flag has been cleared.  
  0b - Master has not lost arbitration  
  1b - Master has lost arbitration |
| 10    | NACK Detect Flag  
  Set if the LPI2C master detects a NACK when transmitting an address or data. When set, the master will transmit a STOP condition and will not initiate a new START condition until NACK Detect Flag has been cleared. If a NACK is expected for a given address (as configured by the command word), then the NACK Detect Flag will set if a NACK is not generated.  
  0b - Unexpected NACK was not detected  
  1b - Unexpected NACK was detected |
| 9     | STOP Detect Flag  
  Set when the LPI2C master generates a STOP condition.  
  0b - Master has not generated a STOP condition  
  1b - Master has generated a STOP condition |
| 8     | End Packet Flag  
  Set when the LPI2C master generates either a repeated START condition or a STOP condition. Does not set when the master first generates a START condition.  
  0b - Master has not generated a STOP or Repeated START condition  
  1b - Master has generated a STOP or Repeated START condition |
| 7-2   | Reserved |
| 1     | Receive Data Flag  
  The Receive Data Flag is set whenever the number of words in the receive FIFO is greater than RXWATER.  
  0b - Receive Data is not ready  
  1b - Receive data is ready |
| 0     | Transmit Data Flag |
### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| The Transmit Data Flag is set whenever the number of words in the transmit FIFO is equal or less than TXWATER. | 0b - Transmit data is not requested  
1b - Transmit data is requested |

#### 47.4.1.6 Master Interrupt Enable Register (MIER)

#### 47.4.1.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MIER</td>
<td>18h</td>
</tr>
</tbody>
</table>

#### 47.4.1.6.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>0</td>
<td>DMIE</td>
<td>PLTIE</td>
<td>FEIE</td>
<td>ALIE</td>
<td>NDIE</td>
<td>SDIE</td>
<td>EPI</td>
<td>EPI</td>
<td>RDI</td>
<td>TDI</td>
<td>E</td>
<td>E</td>
<td>E</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 47.4.1.6.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 14    | Data Match Interrupt Enable  
 0b - Disabled  
 1b - Enabled |
| DMIE  | PIN Low Timeout Interrupt Enable  
 0b - Disabled  
 1b - Enabled |
| FEIE  | FIFO Error Interrupt Enable  
 0b - Enabled  
 1b - Disabled |

* Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 11 ALIE | Arbitration Lost Interrupt Enable  
0b - Disabled  
1b - Enabled |
| 10 NDIE | NACK Detect Interrupt Enable  
0b - Disabled  
1b - Enabled |
| 9 SDIE | STOP Detect Interrupt Enable  
0b - Disabled  
1b - Enabled |
| 8 EPIE | End Packet Interrupt Enable  
0b - Disabled  
1b - Enabled |
| 7-2 | Reserved |
| 1 RDIE | Receive Data Interrupt Enable  
0b - Disabled  
1b - Enabled |
| 0 TDIE | Transmit Data Interrupt Enable  
0b - Disabled  
1b - Enabled |

### 47.4.1.7 Master DMA Enable Register (MDER)

#### 47.4.1.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MDER</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

#### 47.4.1.7.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

R - Read  
W - Write  
Reset - Initial Value
47.4.1.7.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 1     | Receive Data DMA Enable  
        | 0b - DMA request is disabled  
        | 1b - DMA request is enabled |
| 0     | Transmit Data DMA Enable  
        | 0b - DMA request is disabled  
        | 1b - DMA request is enabled |

47.4.1.8 Master Configuration Register 0 (MCFGR0)

47.4.1.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCFGR0</td>
<td>20h</td>
</tr>
</tbody>
</table>

47.4.1.8.2 Diagram

47.4.1.8.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>Receive Data Match Only</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>RDMO</td>
<td>When enabled, all received data that does not cause the Data Match Flag (MSR[DMF]) to set is discarded. After the Data Match Flag is set, the RDMO configuration is ignored. When disabling RDMO, clear RDMO before clearing the Data Match Flag, to ensure that no receive data is lost.  0b - Received data is stored in the receive FIFO  1b - Received data is discarded unless the the Data Match Flag (MSR[DMF]) is set</td>
</tr>
</tbody>
</table>
| 8     | Circular FIFO Enable  
When enabled, the transmit FIFO read pointer is saved to a temporary register. The transmit FIFO will be emptied as normal, but after the LPI2C master is idle and the transmit FIFO is empty, then the read pointer value will be restored from the temporary register. This will cause the contents of the transmit FIFO to be cycled through repeatedly. If AUTOSTOP is set, then a STOP condition will be sent whenever the transmit FIFO is empty and the read pointer is restored.  0b - Circular FIFO is disabled  1b - Circular FIFO is enabled |
| 7-3   | Reserved |
| 2     | Host Request Select  
Selects the source of the host request input. When host request input is enabled, the Host Request Select field should remain static (the Host Request Select should not change).  0b - Host request input is pin HREQ  1b - Host request input is input trigger |
| 1     | Host Request Polarity  
Configures the polarity of the host request input pin. When host request input is enabled, the Host Request Polarity field should remain static (Host Request Polarity should not change).  0b - Active low  1b - Active high |
| 0     | Host Request Enable  
When enabled, the LPI2C master will only initiate a START condition if the host request input is asserted and the bus is idle. A repeated START is not affected by the host request.  0b - Host request input is disabled  1b - Host request input is enabled |

### 47.4.1.9 Master Configuration Register 1 (MCFGR1)

#### 47.4.1.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCFGR1</td>
<td>24h</td>
</tr>
</tbody>
</table>

#### 47.4.1.9.2 Function

The MCFGR1 should only be written when the I2C Master is disabled.
47.4.1.9.3  **Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>PINCFG</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MATCFG</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

47.4.1.9.4  **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26-24</td>
<td>Pin Configuration</td>
</tr>
<tr>
<td>PINCFG</td>
<td>Configures the pin mode for LPI2C.</td>
</tr>
</tbody>
</table>

Table 47-13. 2-pin / 4-pin pin configurations for masters and slaves

<table>
<thead>
<tr>
<th>PINCFG</th>
<th>SCL / SDA pins</th>
<th>SCLS / SDAS pins</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>Bi-directional open drain for master and slave</td>
<td>Not used</td>
</tr>
<tr>
<td>001</td>
<td>Output-only (ultra-fast mode) open drain for master and slave</td>
<td>Not used</td>
</tr>
<tr>
<td>010</td>
<td>Bi-directional push-pull for master and slave</td>
<td>Not used</td>
</tr>
<tr>
<td>011</td>
<td>Input only for master and slave</td>
<td>Output-only push-pull for master and slave</td>
</tr>
<tr>
<td>100</td>
<td>Bi-directional open drain for master</td>
<td>Bi-directional open drain for slave</td>
</tr>
<tr>
<td>101</td>
<td>Output-only (ultra-fast mode) open drain for master</td>
<td>Output-only open drain for slave</td>
</tr>
<tr>
<td>110</td>
<td>Bi-directional push-pull for master</td>
<td>Bi-directional push-pull for slave</td>
</tr>
<tr>
<td>111</td>
<td>Input only for master and slave</td>
<td>Inverted output-only push-pull for master and slave</td>
</tr>
</tbody>
</table>

000b - 2-pin open drain mode
001b - 2-pin output only mode (ultra-fast mode)
010b - 2-pin push-pull mode
011b - 4-pin push-pull mode
100b - 2-pin open drain mode with separate LPI2C slave
101b - 2-pin output only mode (ultra-fast mode) with separate LPI2C slave
110b - 2-pin push-pull mode with separate LPI2C slave

*Table continues on the next page...*
### Master Configuration Register 2 (MCFGR2)

#### Field | Function
--- | ---
| 111b - 4-pin push-pull mode (inverted outputs) | 23-19 
| Reserved | 18-16 
| Match Configuration | MATCFG
- Configures the condition that will cause the DMF to set.
  - 000b - Match is disabled
  - 001b - Reserved
  - 010b - Match is enabled (1st data word equals MATCH0 OR MATCH1)
  - 011b - Match is enabled (any data word equals MATCH0 OR MATCH1)
  - 100b - Match is enabled (1st data word equals MATCH0 AND 2nd data word equals MATCH1)
  - 101b - Match is enabled (any data word equals MATCH0 AND next data word equals MATCH1)
  - 110b - Match is enabled (any data word AND MATCH1 equals MATCH0 AND MATCH1)
| Reserved | 15-11 
| TimeCFG | 10 
| Timeout Configuration | TIMECFG
- 0b - Pin Low Timeout Flag will set if SCL is low for longer than the configured timeout
- 1b - Pin Low Timeout Flag will set if either SCL or SDA is low for longer than the configured timeout
| IgnACK | 9 
| When set, the received NACK field is ignored and assumed to be ACK. IGNACK bit is required to be set in Ultra-Fast Mode. | IGNACK
- 0b - LPI2C Master will receive ACK and NACK normally
- 1b - LPI2C Master will treat a received NACK as if it (NACK) was an ACK
| AUTOSTOP | 8 
| Automatic STOP Generation | AUTOSTOP
- When enabled, a STOP condition is generated whenever the LPI2C master is busy and the transmit FIFO is empty. The STOP condition can also be generated using a transmit FIFO command.
- 0b - No effect
- 1b - STOP condition is automatically generated whenever the transmit FIFO is empty and the LPI2C master is busy
| Reserved | 7-3 
| Prescaler | PRESCALE
- Configures the clock prescaler used for all LPI2C master logic, except for the digital glitch filters.
  - 000b - Divide by 1
  - 001b - Divide by 2
  - 010b - Divide by 4
  - 011b - Divide by 8
  - 100b - Divide by 16
  - 101b - Divide by 32
  - 110b - Divide by 64
  - 111b - Divide by 128

---

47.4.1.10 Master Configuration Register 2 (MCFGR2)
47.4.1.10.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCFGR2</td>
<td>28h</td>
</tr>
</tbody>
</table>

47.4.1.10.2  Function

The Master Configuration Register 2 should only be written when the I2C Master is disabled.

47.4.1.10.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>FILTSDA</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>BUSIDLE</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

47.4.1.10.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-24</td>
<td>FILTSDA</td>
</tr>
<tr>
<td>19-16</td>
<td>FILTSCl</td>
</tr>
</tbody>
</table>

FILTSDA

- Configures the I2C master digital glitch filters for SDA input.
  - A configuration of 0 will disable the glitch filter
  - Glitches equal to or less than FILTSDA cycles long will be filtered out and ignored
  - The latency through the glitch filter is equal to FILTSDA cycles, and must be configured to be less than the minimum SCL low or high period
  - The glitch filter cycle count is not affected by the PRESCALE configuration, and the glitch filter cycle count is automatically bypassed in High Speed mode

Table continues on the next page...
### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-0</td>
<td>BUSIDLE</td>
</tr>
</tbody>
</table>

**BUSIDLE**
- Configures the bus idle timeout period in clock cycles.
- If both SCL and SDA are high for longer than BUSIDLE cycles, then the I2C bus is assumed to be idle and the master can generate a START condition.
- When Bus Idle Timeout is set to zero, the Bus Idle Timeout is disabled.

### 47.4.1.11 Master Configuration Register 3 (MCFGR3)

#### 47.4.1.11.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCFGR3</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

#### 47.4.1.11.2 Function

The MCFGR3 should only be written when the I2C Master is disabled.

#### 47.4.1.11.3 Diagram

![Diagram of MCFGR3 Register](image)
### 47.4.1.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-8</td>
<td>PINLOW Pin Low Timeout</td>
</tr>
<tr>
<td></td>
<td>Configures the pin low timeout</td>
</tr>
<tr>
<td></td>
<td>flag in clock cycles.</td>
</tr>
<tr>
<td></td>
<td>• If SCL or, either SCL or SDA,</td>
</tr>
<tr>
<td></td>
<td>is low for longer than (PINLOW*256) cycles, then PLTF is set</td>
</tr>
<tr>
<td></td>
<td>• When Pin Low Timeout is set</td>
</tr>
<tr>
<td></td>
<td>to zero, the Pin Low Timeout</td>
</tr>
<tr>
<td></td>
<td>feature is disabled</td>
</tr>
<tr>
<td>7-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 47.4.1.12 Master Data Match Register (MDMR)

#### 47.4.1.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MDMR</td>
<td>40h</td>
</tr>
</tbody>
</table>

#### 47.4.1.12.2 Function

The MDMR should only be written when the I2C Master is disabled or idle.

#### 47.4.1.12.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

MATCH1

MATCH0
### 47.4.1.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-16</td>
<td>MATCH1</td>
</tr>
<tr>
<td></td>
<td>Match 1 Value</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>MATCH0</td>
</tr>
<tr>
<td></td>
<td>Match 0 Value</td>
</tr>
<tr>
<td></td>
<td>Compared against the received data when receive data match is enabled.</td>
</tr>
</tbody>
</table>

### 47.4.1.13 Master Clock Configuration Register 0 (MCCR0)

#### 47.4.1.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCCR0</td>
<td>48h</td>
</tr>
</tbody>
</table>

#### 47.4.1.13.2 Function

The MCCR0 cannot be changed when the I2C master is enabled and is used for standard, fast, fast-mode plus and ultra-fast transfers.

#### 47.4.1.13.3 Diagram

```
+---------+---------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+        |
| Bits    | 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18      | 17      | 16      |
| R       | 0       |         |         |         |         |         |         |         |         | 0       |         |         |         |         |         |         |         |
| W       |         |         |         |         |         |         |         |         |         |         | 0       |         |         |         |         |         |         |
| Reset   | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

+---------+---------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+        |
| Bits    | 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       |         |         |         |         |         |         |         |         |         |
| R       | 0       |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |
| W       |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |
| Reset   | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |
```

```
+---------+---------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+--------+        |
| Bits    | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |         |         |         |         |         |         |         |         |         |
| R       | 0       |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |
| W       |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |
| Reset   | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |
```
### 47.4.1.13.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Reserved</td>
</tr>
<tr>
<td>29-24</td>
<td>DATAVD</td>
</tr>
<tr>
<td></td>
<td>Data Valid Delay</td>
</tr>
<tr>
<td></td>
<td>Minimum number of cycles (minus one) that is used as the data hold time for SDA. Must be configured less than the minimum SCL low period.</td>
</tr>
<tr>
<td>23-22</td>
<td>Reserved</td>
</tr>
<tr>
<td>21-16</td>
<td>SETHOLD</td>
</tr>
<tr>
<td></td>
<td>Setup Hold Delay</td>
</tr>
<tr>
<td></td>
<td>Minimum number of cycles (minus one) that is used by the master</td>
</tr>
<tr>
<td></td>
<td>• as the hold time for a START condition</td>
</tr>
<tr>
<td></td>
<td>• as the setup and hold time for a repeated START condition</td>
</tr>
<tr>
<td></td>
<td>• as the setup time for a STOP condition</td>
</tr>
<tr>
<td></td>
<td>The setup time is extended by the time it takes to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to ((2 + \text{FILTSCL}) / 2^{\text{PRESCALE}}) cycles.</td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13-8</td>
<td>CLKHI</td>
</tr>
<tr>
<td></td>
<td>Clock High Period</td>
</tr>
<tr>
<td></td>
<td>Minimum number of cycles (minus one) that the SCL clock is driven high by the master. The SCL high time is extended by the time it takes to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to ((2 + \text{FILTSCL}) / 2^{\text{PRESCALE}}) cycles.</td>
</tr>
<tr>
<td>7-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-0</td>
<td>CLKLO</td>
</tr>
<tr>
<td></td>
<td>Clock Low Period</td>
</tr>
<tr>
<td></td>
<td>Minimum number of cycles (minus one) that the SCL clock is driven low by the master. The Clock Low Period value is also used for the minimum bus free time between a STOP and a START condition; this is extended by the time it takes to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to ((2 + \text{FILTSCL}) / 2^{\text{PRESCALE}}) cycles.</td>
</tr>
</tbody>
</table>

### 47.4.1.14 Master Clock Configuration Register 1 (MCCR1)

#### 47.4.1.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCCR1</td>
<td>50h</td>
</tr>
</tbody>
</table>
47.4.1.14.2 Function
The MCCR1 cannot be changed when the I2C master is enabled and is used for high speed mode transfers. The separate clock configuration for high speed mode allows arbitration to take place in Fast mode (with timing configured by MCCR0), before switching to high speed mode (with timing configured by MCCR1).

47.4.1.14.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

47.4.1.14.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>Reserved</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>29-24</td>
<td>Data Valid Delay</td>
</tr>
<tr>
<td>DATAVD</td>
<td>Minimum number of cycles (minus one) that is used as the data hold time for SDA. The Data Valid Delay must be configured to be less than the minimum SCL low period.</td>
</tr>
<tr>
<td>23-22</td>
<td>Reserved</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>21-16</td>
<td>Setup Hold Delay</td>
</tr>
<tr>
<td>SETHOLD</td>
<td>Minimum number of cycles (minus one) that is used by the master</td>
</tr>
<tr>
<td></td>
<td>• as the hold time for a START condition</td>
</tr>
<tr>
<td></td>
<td>• as the setup and hold time for a repeated START condition</td>
</tr>
<tr>
<td></td>
<td>• as the setup time for a STOP condition</td>
</tr>
<tr>
<td></td>
<td>The setup time is extended by the time it takes to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to (2 + FILTSCL) / 2^PRESCALE cycles.</td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>13-8</td>
<td>Clock High Period</td>
</tr>
<tr>
<td>CLKHI</td>
<td>Minimum number of cycles (minus one) that the SCL clock is driven high by the master. The SCL high time is extended by the time it takes to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to (2 + FILTSCL) / 2^PRESCALE cycles.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5-0</td>
<td>Clock Low Period</td>
</tr>
<tr>
<td>CLKLO</td>
<td>Minimum number of cycles (minus one) that the SCL clock is driven low by the master. The Clock Low Period value is also used for the minimum bus free time between a STOP and a START condition; this is extended by the time it takes to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to ((2 + \text{FILTSCL}) / 2^\text{PRESCALE}) cycles.</td>
</tr>
</tbody>
</table>

### 47.4.1.15 Master FIFO Control Register (MFCR)

#### 47.4.1.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MFCR</td>
<td>58h</td>
</tr>
</tbody>
</table>

#### 47.4.1.15.2 Function

The Master FIFO control register is only used in Stop mode when the MFCR register is static (i.e., the MFCR register is not changing).

#### 47.4.1.15.3 Diagram

```plaintext
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RXWATER</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```
47.4.1.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17-16</td>
<td>RXWATER</td>
</tr>
<tr>
<td>RXWATER</td>
<td>Receive FIFO Watermark</td>
</tr>
<tr>
<td>The Receive Data Flag is set whenever the number of words in the receive FIFO is greater than RXWATER. Writing a value equal to or greater than the FIFO size will be truncated.</td>
<td></td>
</tr>
<tr>
<td>15-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1-0</td>
<td>TXWATER</td>
</tr>
<tr>
<td>TXWATER</td>
<td>Transmit FIFO Watermark</td>
</tr>
<tr>
<td>The Transmit Data Flag is set whenever the number of words in the transmit FIFO is equal or less than TXWATER. Writing a value equal to or greater than the FIFO size will be truncated.</td>
<td></td>
</tr>
</tbody>
</table>

47.4.1.16 Master FIFO Status Register (MFSR)

47.4.1.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MFSR</td>
<td>5Ch</td>
</tr>
</tbody>
</table>

47.4.1.16.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

47.4.1.16.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-19</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>18-16 RXCOUNT</td>
<td>Receive FIFO Count</td>
</tr>
<tr>
<td></td>
<td>Returns the number of words in the receive FIFO.</td>
</tr>
<tr>
<td>15-3 —</td>
<td>Reserved</td>
</tr>
<tr>
<td>2-0 TXCOUNT</td>
<td>Transmit FIFO Count</td>
</tr>
<tr>
<td></td>
<td>Returns the number of words in the transmit FIFO.</td>
</tr>
</tbody>
</table>

### 47.4.1.17 Master Transmit Data Register (MTDR)

#### 47.4.1.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MTDR</td>
<td>60h</td>
</tr>
</tbody>
</table>

#### 47.4.1.17.2 Function

- An 8-bit write to the CMD field will store the data in the Command FIFO, but does not increment the FIFO write pointer.
- An 8-bit write to the DATA field will zero extend the CMD field, unless the CMD field has been written separately since the last FIFO write; it (the 8-bit write) also increments the FIFO write pointer.
- A 16-bit or 32-bit will write both the CMD and DATA fields and increment the FIFO.

#### 47.4.1.17.3 Diagram

![Diagram of MTDR register](image-url)
### 47.4.1.17.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10-8</td>
<td>Command Data</td>
</tr>
</tbody>
</table>
| CMD   | - 000b - Transmit DATA[7:0]  
       | - 001b - Receive (DATA[7:0] + 1) bytes  
       | - 010b - Generate STOP condition  
       | - 011b - Receive and discard (DATA[7:0] + 1) bytes  
       | - 100b - Generate (repeated) START and transmit address in DATA[7:0]  
       | - 101b - Generate (repeated) START and transmit address in DATA[7:0]. This transfer expects a NACK to be returned.  
       | - 110b - Generate (repeated) START and transmit address in DATA[7:0] using high speed mode  
       | - 111b - Generate (repeated) START and transmit address in DATA[7:0] using high speed mode. This transfer expects a NACK to be returned. |
| 7-0   | Transmit Data  
      | Performing an 8-bit write to DATA will zero extend the CMD field. |

### 47.4.1.18 Master Receive Data Register (MRDR)

#### 47.4.1.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MRDR</td>
<td>70h</td>
</tr>
</tbody>
</table>

#### 47.4.1.18.2 Diagram

![Diagram](image-url)
47.4.1.18.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>RX Empty</td>
</tr>
<tr>
<td>RXEMPTY</td>
<td>RX Empty</td>
</tr>
<tr>
<td></td>
<td>0b - Receive FIFO is not empty</td>
</tr>
<tr>
<td></td>
<td>1b - Receive FIFO is empty</td>
</tr>
<tr>
<td>13-8</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>7-0</td>
<td>Receive Data</td>
</tr>
<tr>
<td>DATA</td>
<td>Reading the Receive Data register returns the data received by the I2C master that has not been discarded. Receive data can be discarded due to the CMD field, or the master can be configured to discard non-matching data.</td>
</tr>
</tbody>
</table>

47.4.1.19 Slave Control Register (SCR)

47.4.1.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCR</td>
<td>110h</td>
</tr>
</tbody>
</table>

47.4.1.19.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
47.4.1.19.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-10</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 9     | Reset Receive FIFO  
|       | 0b - No effect  
|       | 1b - Receive Data Register is now empty |
| 8     | Reset Transmit FIFO  
|       | 0b - No effect  
|       | 1b - Transmit Data Register is now empty |
| 7-6   | Reserved |
| 5     | Filter Doze Enable  
|       | Filter Doze Enable bit should only be updated when the I2C Slave is disabled.  
|       | 0b - Filter remains enabled in Doze mode  
|       | 1b - Filter is disabled in Doze mode |
| 4     | Filter Enable  
|       | Filter Enable bit should only be updated when the I2C Slave is disabled.  
|       | 0b - Disable digital filter and output delay counter for slave mode  
|       | 1b - Enable digital filter and output delay counter for slave mode |
| 3-2   | Reserved |
| 1     | Software Reset  
|       | 0b - Slave mode logic is not reset  
|       | 1b - Slave mode logic is reset |
| 0     | Slave Enable  
|       | 0b - I2C Slave mode is disabled  
|       | 1b - I2C Slave mode is enabled |

47.4.1.20 Slave Status Register (SSR)

47.4.1.20.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSR</td>
<td>114h</td>
</tr>
</tbody>
</table>
47.4.1.20.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-26</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 25    | Bus Busy Flag  
| BBF   | Indicates if an I2C bus is idle or busy.  
|       | 0b - I2C Bus is idle  
|       | 1b - I2C Bus is busy |
| 24    | Slave Busy Flag  
| SBF   | Indicates if an I2C slave is idle or busy.  
|       | 0b - I2C Slave is idle  
|       | 1b - I2C Slave is busy |
| 23-16 | Reserved |
| 15    | SMBus Alert Response Flag  
| SARF  | • SMBus Alert Response Flag is cleared by reading the Address Status Register  
|       | • SMBus Alert Response Flag cannot generate an asynchronous wakeup  
|       | 0b - SMBus Alert Response is disabled or not detected  
|       | 1b - SMBus Alert Response is enabled and detected |
| 14    | General Call Flag  
| GCF   | Indicates whether a slave has detected the General Call Address.  
|       | • General Call Flag is cleared by reading the Address Status Register  
|       | • General Call Flag cannot generate an asynchronous wakeup  
|       | 0b - Slave has not detected the General Call Address or the General Call Address is disabled  
|       | 1b - Slave has detected the General Call Address |
| 13    | Address Match 1 Flag  
| AM1F  | Indicates that the received address has matched the ADDR1 field or ADDR0 to ADDR1 range as configured by ADDRCFG.  

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
|        | • Address Match 1 Flag is cleared by reading the Address Status Register  
|        | • Address Match 1 Flag cannot generate an asynchronous wakeup  
|        | 0b - Have not received an ADDR1 or ADDR0/ADDR1 range matching address  
|        | 1b - Have received an ADDR1 or ADDR0/ADDR1 range matching address  
| 12 AM0F | Address Match 0 Flag  
|        | Indicates that the received address has matched the ADDR0 field as configured by ADDRCFG.  
|        | • Address Match 0 Flag is cleared by reading the Address Status Register  
|        | • Address Match 0 Flag cannot generate an asynchronous wakeup  
|        | 0b - Have not received an ADDR0 matching address  
|        | 1b - Have received an ADDR0 matching address  
| 11 FEF | FIFO Error Flag  
|        | FIFO error flag can only be set when clock stretching is disabled.  
|        | 0b - FIFO underflow or overflow was not detected  
|        | 1b - FIFO underflow or overflow was detected  
| 10 BEF | Bit Error Flag  
|        | Bit Error Flag will set if the LPI2C slave transmits a logic one and detects a logic zero on the I2C bus. The slave will ignore the rest of the transfer until the next (repeated) START condition.  
|        | 0b - Slave has not detected a bit error  
|        | 1b - Slave has detected a bit error  
| 9 SDF | STOP Detect Flag  
|        | STOP Detect Flag will set when the LPI2C slave detects a STOP condition and if the LPI2C slave matched the last address byte.  
|        | 0b - Slave has not detected a STOP condition  
|        | 1b - Slave has detected a STOP condition  
| 8 RSF | Repeated Start Flag  
|        | Repeated Start Flag will set when the LPI2C slave detects a repeated START condition and if the LPI2C slave matched the last address byte. The Repeated Start Flag does not set when the slave first detects a START condition.  
|        | 0b - Slave has not detected a Repeated START condition  
|        | 1b - Slave has detected a Repeated START condition  
| 7-4 | Reserved  
| 3 TAF | Transmit ACK Flag  
|        | Transmit ACK Flag is cleared by writing the Transmit ACK register.  
|        | 0b - Transmit ACK/NACK is not required  
|        | 1b - Transmit ACK/NACK is required  
| 2 AVF | Address Valid Flag  
|        | Address Valid Flag is cleared by reading the address status register. When Receive Data Configuration (SCFGR1[RXCFG]) is set, the Address Valid Flag is also cleared by reading the Receive Data register.  
|        | 0b - Address Status Register is not valid  
|        | 1b - Address Status Register is valid  
| 1 RDF | Receive Data Flag  
|        | Receive Data Flag is cleared by reading the receive data register. When Receive Data Configuration (SCFGR1[RXCFG]) is set, the Receive Data Flag is not cleared when reading the Receive Data register and if AVF is set.  
|        | 0b - Receive data is not ready  
|        | 1b - Receive data is ready  

Table continues on the next page...
Transmit Data Flag is cleared by writing the Transmit Data register. When Transmit Flag Configuration (TXCFG) is clear, and if a NACK or Repeated START or STOP condition is detected, then Transmit Data Flag is also cleared.

0b - Transmit data not requested
1b - Transmit data is requested

### Table

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0 TDF</td>
<td>Transmit Data Flag</td>
</tr>
</tbody>
</table>

47.4.1.21 Slave Interrupt Enable Register (SIER)

#### 47.4.1.21.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SIER</td>
<td>118h</td>
</tr>
</tbody>
</table>

#### 47.4.1.21.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>SARIE</td>
<td>GCI</td>
<td>AMIF</td>
<td>AM0IE</td>
<td>FEI</td>
<td>BEI</td>
<td>SDE</td>
<td>FSE</td>
<td>TAIE</td>
<td>AVIE</td>
<td>RDI</td>
<td>TDIE</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 47.4.1.21.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>SMBus Alert Response Interrupt Enable</td>
</tr>
<tr>
<td>SARIE</td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>14</td>
<td>General Call Interrupt Enable</td>
</tr>
<tr>
<td>GCIE</td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field | Function
--- | ---
13 AM1F | Address Match 1 Interrupt Enable
0b - Disabled
1b - Enabled
12 AM0IE | Address Match 0 Interrupt Enable
0b - Enabled
1b - Disabled
11 FEIE | FIFO Error Interrupt Enable
0b - Disabled
1b - Enabled
10 BEIE | Bit Error Interrupt Enable
0b - Disabled
1b - Enabled
9 SDIE | STOP Detect Interrupt Enable
0b - Disabled
1b - Enabled
8 RSIE | Repeated Start Interrupt Enable
0b - Disabled
1b - Enabled
7-4 | Reserved
3 TAIE | Transmit ACK Interrupt Enable
0b - Disabled
1b - Enabled
2 AVIE | Address Valid Interrupt Enable
0b - Disabled
1b - Enabled
1 RDIE | Receive Data Interrupt Enable
0b - Disabled
1b - Enabled
0 TDIE | Transmit Data Interrupt Enable
0b - Disabled
1b - Enabled

### 47.4.1.22 Slave DMA Enable Register (SDER)

#### 47.4.1.22.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SDER</td>
<td>11Ch</td>
</tr>
</tbody>
</table>
47.4.1.22.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

47.4.1.22.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-3</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>AVDE</td>
</tr>
<tr>
<td></td>
<td>Address Valid DMA Enable</td>
</tr>
<tr>
<td></td>
<td>The Address Valid DMA request is shared with the Receive Data DMA request. If both Address Valid DMA request and Receive Data DMA request are enabled, then set Receive Data Configuration (SCFGR1[RXCFG]), to allow the DMA to read the address from the Receive Data Register.</td>
</tr>
<tr>
<td>0b</td>
<td>DMA request is disabled</td>
</tr>
<tr>
<td>1b</td>
<td>DMA request is enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>RDDE</td>
</tr>
<tr>
<td></td>
<td>Receive Data DMA Enable</td>
</tr>
<tr>
<td></td>
<td>0b - DMA request is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - DMA request is enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>TDDE</td>
</tr>
<tr>
<td></td>
<td>Transmit Data DMA Enable</td>
</tr>
<tr>
<td></td>
<td>0b - DMA request is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - DMA request is enabled</td>
</tr>
</tbody>
</table>

47.4.1.23  Slave Configuration Register 1 (SCFGR1)

47.4.1.23.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCFGR1</td>
<td>124h</td>
</tr>
</tbody>
</table>
47.4.1.23.2  Function
The Slave Configuration Register 1 should only be written when the I2C Slave is disabled.

47.4.1.23.3  Diagram

47.4.1.23.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18-16</td>
<td>ADDRCFG</td>
</tr>
<tr>
<td>18-16</td>
<td>Address Configuration</td>
</tr>
<tr>
<td></td>
<td>Configures the condition that will cause an address to match.</td>
</tr>
<tr>
<td></td>
<td>000b - Address match 0 (7-bit)</td>
</tr>
<tr>
<td></td>
<td>001b - Address match 0 (10-bit)</td>
</tr>
<tr>
<td></td>
<td>010b - Address match 0 (7-bit) or Address match 1 (7-bit)</td>
</tr>
<tr>
<td></td>
<td>011b - Address match 0 (10-bit) or Address match 1 (10-bit)</td>
</tr>
<tr>
<td></td>
<td>100b - Address match 0 (7-bit) or Address match 1 (10-bit)</td>
</tr>
<tr>
<td></td>
<td>101b - Address match 0 (10-bit) or Address match 1 (7-bit)</td>
</tr>
<tr>
<td></td>
<td>110b - From Address match 0 (7-bit) to Address match 1 (7-bit)</td>
</tr>
<tr>
<td></td>
<td>111b - From Address match 0 (10-bit) to Address match 1 (10-bit)</td>
</tr>
<tr>
<td>15-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>HSMEN</td>
</tr>
<tr>
<td>13</td>
<td>High Speed Mode Enable</td>
</tr>
<tr>
<td></td>
<td>Enables detection of the High-Speed Mode master code of slave address 0000_1XX, but does not cause an address match on this code. When set and any HS-mode master code is detected, the FILTEN and ACKSTALL bits are ignored until the next STOP condition is detected.</td>
</tr>
<tr>
<td></td>
<td>0b - Disables detection of HS-mode master code</td>
</tr>
<tr>
<td></td>
<td>1b - Enables detection of HS-mode master code</td>
</tr>
<tr>
<td>12</td>
<td>IGNACK</td>
</tr>
<tr>
<td>12</td>
<td>Ignore NACK</td>
</tr>
<tr>
<td></td>
<td>When Ignore NACK is set, the LP12C slave will continue transfers after a NACK is detected. Ignore NACK bit is required to be set in Ultra-Fast Mode.</td>
</tr>
<tr>
<td></td>
<td>0b - Slave will end transfer when NACK is detected</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>11 RXCFG</td>
<td>Receive Data Configuration&lt;br&gt;0b - Reading the Receive Data register will return received data and clear the Receive Data flag (MSR[RDF]).&lt;br&gt;1b - Reading the Receive Data register when the Address Valid flag (SSR[AVF]) is set, will return the Address Status register and clear the Address Valid flag. Reading the Receive Data register when the Address Valid flag is clear, will return received data and clear the Receive Data flag (MSR[RDF]).</td>
</tr>
<tr>
<td>10 TXCFG</td>
<td>Transmit Flag Configuration&lt;br&gt;The transmit data flag will always assert before a NACK is detected at the end of a slave-transmit transfer. This can cause an extra word to be written to the transmit data FIFO.&lt;br&gt;• When TXCFG=0, the Transmit Data register is automatically emptied when a slave-transmit transfer is detected. This causes the transmit data flag to assert whenever a slave-transmit transfer is detected, and causes the transmit data flag to negate at the end of the slave-transmit transfer.&lt;br&gt;• When TXCFG=1, the Transmit Data flag will assert whenever the Transmit Data register is empty, and the Transmit Data flag will negate when the Transmit Data register is full. This allows the Transmit Data register to be filled before a slave-transmit transfer is detected, but can cause the Transmit Data register to be written before a NACK is detected on the last byte of a slave transmit transfer.</td>
</tr>
<tr>
<td>9 SAEN</td>
<td>SMBus Alert Enable&lt;br&gt;0b - Disables match on SMBus Alert&lt;br&gt;1b - Enables match on SMBus Alert</td>
</tr>
<tr>
<td>8 GCEN</td>
<td>General Call Enable&lt;br&gt;0b - General Call address is disabled&lt;br&gt;1b - General Call address is enabled</td>
</tr>
<tr>
<td>7-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3 ACKSTALL</td>
<td>ACK SCL Stall&lt;br&gt;Enables SCL clock stretching during slave-transmit address byte(s) and slave-receiver address and data byte(s), to allow software to write the Transmit ACK Register before the ACK or NACK is transmitted. Clock stretching occurs when transmitting the 9th bit, and is therefore not compatible with high speed mode. When ACKSTALL is enabled, there is no need to set either RX SCL Stall (SCFGR1[RXSTALL]) or Address SCL Stall (SCFGR1[ADRSTALL]).&lt;br&gt;0b - Clock stretching is disabled&lt;br&gt;1b - Clock stretching is enabled</td>
</tr>
<tr>
<td>2 TXDSTALL</td>
<td>TX Data SCL Stall&lt;br&gt;Enables SCL clock stretching when the Transmit Data flag (SSR[TDF]) is set during a slave-transmit transfer. Clock stretching occurs following the 9th bit, and is therefore compatible with high speed mode.&lt;br&gt;0b - Clock stretching is disabled&lt;br&gt;1b - Clock stretching is enabled</td>
</tr>
<tr>
<td>1 RXSTALL</td>
<td>RX SCL Stall&lt;br&gt;Enables SCL clock stretching when the Receive Data flag (SSR[RDF]) is set during a slave-receive transfer. Clock stretching occurs following the 9th bit, and is therefore compatible with high speed mode.&lt;br&gt;0b - Clock stretching is disabled&lt;br&gt;1b - Clock stretching is enabled</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Slave Configuration Register 2 (SCFGR2)

#### Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCFGR2</td>
<td>128h</td>
</tr>
</tbody>
</table>

#### Function

The Slave Configuration Register 2 should only be written when the I2C Slave is disabled.

#### Diagram

![Diagram of SCFGR2 register](image-url)

#### Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-24</td>
<td>Glitch Filter SDA</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
FILTSDA | Configures the I2C slave digital glitch filters for SDA input.
- A configuration of 0 will disable the glitch filter
- Glitches equal to or less than FILTSDA cycles long will be filtered out and ignored
- The latency through the glitch filter is equal to FILTSDA+3 cycles, and must be configured to be less than the minimum SCL low or high period
- The glitch filter cycle count is not affected by the PRESCALE configuration, and the glitch filter cycle count is disabled in high speed mode

| Field | Function |
--- | --- |
23-20 | Reserved |
19-16 | Glitch Filter SCL
FILTSCL | Configures the I2C slave digital glitch filters for SCL input.
- A configuration of 0 will disable the glitch filter
- Glitches equal to or less than FILTSCL cycles long will be filtered out and ignored
- The latency through the glitch filter is equal to FILTSCL+3 cycles, and must be configured to be less than the minimum SCL low or high period
- The glitch filter cycle count is not affected by the PRESCALE configuration, and the glitch filter cycle count is disabled in high speed mode |
15-14 | Reserved |
13-8 | Data Valid Delay
DATAVD | Configures the SDA data valid delay time for the I2C slave, and is equal to FILTSCL+DATAVD+3 cycles.
- The data valid delay must be configured to be less than the minimum SCL low period
- The I2C slave data valid delay time is not affected by the PRESCALE configuration, and the I2C slave data valid delay time is disabled in high speed mode |
7-4 | Reserved |
3-0 | Clock Hold Time
CLKHOLD | Configures the minimum clock hold time for the I2C slave, when clock stretching is enabled.
- The minimum hold time is equal to CLKHOLD+3 cycles
- The I2C slave clock hold time is not affected by the PRESCALE configuration, and the I2C slave clock hold time is disabled in high speed mode |

### 47.4.1.25 Slave Address Match Register (SAMR)

#### 47.4.1.25.1 Offset

| Register | Offset |
--- | --- |
SAMR | 140h |

#### 47.4.1.25.2 Function

The SAMR should only be written when the I2C Slave is disabled.
### 47.4.1.25.3 Diagram

![Diagram of register values](image)

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 47.4.1.25.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26-17</td>
<td>Address 1 Value</td>
</tr>
<tr>
<td>ADDR1</td>
<td>Compared against the received address to detect the Slave Address.</td>
</tr>
<tr>
<td></td>
<td>• In 10-bit mode, the first address byte is compared to {11110, ADDR1[26:25]} and the second address byte is compared to ADDR1[24:17]</td>
</tr>
<tr>
<td></td>
<td>• In 7-bit mode, the address is compared to ADDR1[23:17]</td>
</tr>
<tr>
<td>16-11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10-1</td>
<td>Address 0 Value</td>
</tr>
<tr>
<td>ADDR0</td>
<td>Compared against the received address to detect the Slave Address.</td>
</tr>
<tr>
<td></td>
<td>• In 10-bit mode, the first address byte is compared to {11110, ADDR0[10:9]} and the second address byte is compared to ADDR0[8:1]</td>
</tr>
<tr>
<td></td>
<td>• In 7-bit mode, the address is compared to ADDR0[7:1]</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 47.4.1.26 Slave Address Status Register (SASR)

#### 47.4.1.26.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SASR</td>
<td>150h</td>
</tr>
</tbody>
</table>
### 47.4.1.26.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>ANV</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 47.4.1.26.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14</td>
<td>Address Not Valid</td>
</tr>
</tbody>
</table>
| ANV   | 0b - Received Address (RADDR) is valid  
        1b - Received Address (RADDR) is not valid |
| 13-11 | Reserved |
| 10-0  | Received Address |
| RADDR | The Received Address updates whenever the AMF is set; the AMF is cleared by reading the Slave Address Status register.  
        • In 7-bit mode, the address byte is store in RADDR[7:0]  
        • In 10-bit mode, the first address byte is { 11110, RADDR[10:9], RADDR[0] } and the second address byte is RADDR[8:1]. The R/W bit is therefore always stored in RADDR[0] |

### 47.4.1.27 Slave Transmit ACK Register (STAR)

#### 47.4.1.27.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STAR</td>
<td>154h</td>
</tr>
</tbody>
</table>
47.4.1.27.2 Function
The Slave Transmit ACK Register can only be written when the ACK SCL Stall bit is set in Slave Configuration Register 1 (SCFGR1[ACKSTALL]).
- The ACKSTALL bit will enable clock stretching during the ACK/NACK bit slot, and during this time, the STAR register can be written by software.
- The logic ensures that the clock stretching continues for at least 1 bus clock cycle after the STAR register is updated.
- This clock stretching time can be extended more using the Clock Hold Time field (SCFGR2[CLKHOLD], Slave Configuration Register 2).

47.4.1.27.3 Diagram

47.4.1.27.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Transmit NACK</td>
</tr>
<tr>
<td>TXNACK</td>
<td>After receiving each word, software can transmit either an ACK (logic 0) or a NACK (logic 1); Transmit NACK selects which to use: ACK or NACK.</td>
</tr>
<tr>
<td></td>
<td>• When ACKSTALL is set, a Transmit NACK must be written once for each matching address byte and each received word. ACKSTALL must be set, because that will stall the data transfer until software reads the received word (and decides whether to respond with an ACK or NACK).</td>
</tr>
<tr>
<td></td>
<td>• To configure the default ACK/NACK, Transmit NACK can also be written when LPI2C Slave is disabled or idle.</td>
</tr>
<tr>
<td></td>
<td>0b - Write a Transmit ACK for each received word</td>
</tr>
<tr>
<td></td>
<td>1b - Write a Transmit NACK for each received word</td>
</tr>
</tbody>
</table>
47.4.1.28 Slave Transmit Data Register (STDR)

47.4.1.28.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STDR</td>
<td>160h</td>
</tr>
</tbody>
</table>

47.4.1.28.2 Function

Clock stretching (enabled or disabled) affects when the transmit data is transferred. The TXDSTALL bit will enable clock stretching during the 1st data bit of a slave-transmit transfer.

- **If clock stretching is enabled** (TXDSTALL=1), then the transmit data transfer is stalled until the Slave Transmit register (STDR) is updated. Clock stretching is extended by at least 1 bus clock cycle after the Slave Transmit Data Register (STDR) is updated, and clock stretching can be delayed even more using the Clock Hold Time field (SCFGR2[CLKHOLD], Slave Configuration Register 2).
- **If clock stretching is disabled** (TXDSTALL=0), then the transmit data should be written before the start of the slave-transmit transfer; otherwise (i.e., if the transmit data is not written before the start of the slave-transmit transfer), the FIFO Error Flag (SSR[FEF]) will be set.

47.4.1.28.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

47.4.1.28.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-8</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-0 DATA</td>
<td>Transmit Data</td>
</tr>
<tr>
<td></td>
<td>Writing to the Slave Transmit Data Register (STDR) will store I2C slave transmit data in the Slave Transmit Data Register</td>
</tr>
</tbody>
</table>

#### 47.4.1.29 Slave Receive Data Register (SRDR)

**47.4.1.29.1 Offset**

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRDR</td>
<td>170h</td>
</tr>
</tbody>
</table>

**47.4.1.29.2 Diagram**

![Diagram of SRDR Register](image)

**47.4.1.29.3 Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15 SOF</td>
<td>Start Of Frame</td>
</tr>
<tr>
<td>0b</td>
<td>Indicates this is not the first data word since a (repeated) START or STOP condition</td>
</tr>
<tr>
<td>1b</td>
<td>Indicates this is the first data word since a (repeated) START or STOP condition</td>
</tr>
<tr>
<td>14 RXEMPTY</td>
<td>RX Empty</td>
</tr>
<tr>
<td>0b</td>
<td>The Receive Data Register is not empty</td>
</tr>
<tr>
<td>1b</td>
<td>The Receive Data Register is empty</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>13-8</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>7-0</td>
<td>Receive Data</td>
</tr>
<tr>
<td>DATA</td>
<td>Reading the Slave Receive Data Register returns the data received by the I2C slave</td>
</tr>
</tbody>
</table>
Chapter 48
Low Power Serial Peripheral Interface (LPSPI)

48.1 Chip-specific LPSPI information

Table 48-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
</tbody>
</table>

NOTE
The "Output Triggers" section is not applicable for this device.

48.2 Introduction

48.2.1 Overview

The LPSPI is a low power Serial Peripheral Interface (SPI) module that supports an efficient interface to an SPI bus as a master and/or a slave. The LPSPI can continue operating in stop modes provided an appropriate clock is available and is designed for low CPU overhead with DMA offloading of FIFO register accesses.
48.2.2 Features

The LPSPI supports the following features:

- Word size = 32 bits
- Command/transmit FIFO of 16 words.
- Receive FIFO of 16 words.
- Host request input can be used to control the start time of an SPI bus transfer.

48.2.3 Block Diagram

![Block Diagram of LPSPI](image)

48.2.4 Modes of operation

The LPSPI module supports the chip modes described in the following table.
### Table 48-2. Chip modes supported by the LPSPI module

<table>
<thead>
<tr>
<th>Chip mode</th>
<th>LPSPI Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>Run</td>
<td>Normal operation</td>
</tr>
<tr>
<td>Stop</td>
<td>Can continue operating if the Doze Enable bit (CR[DOZEN]) is clear and the LPSPI is using an external or internal clock source that remains operating during stop mode.</td>
</tr>
<tr>
<td>Debug (the core is in Debug/Halted mode)</td>
<td>Can continue operating if the Debug Enable bit (CR[DBGEN]) is set.</td>
</tr>
</tbody>
</table>

### 48.2.5 Signal Descriptions

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCK</td>
<td>Serial clock. Input in slave mode, output in master mode.</td>
<td>I/O</td>
</tr>
<tr>
<td>PCS[0]</td>
<td>Peripheral Chip Select. Input in slave mode, output in master mode.</td>
<td>I/O</td>
</tr>
<tr>
<td>PCS[1] / HREQ</td>
<td>Peripheral Chip Select or Host Request. Host Request pin is selected when HREN=1 and HRSEL=0. Input in either slave mode or when used as Host Request, output in master mode.</td>
<td>I/O</td>
</tr>
<tr>
<td>SOUT / DATA[0]</td>
<td>Serial Data Output. Can be configured as serial data input signal. Used as data pin 0 in quad-data and dual-data transfers.</td>
<td>I/O</td>
</tr>
<tr>
<td>SIN / DATA[1]</td>
<td>Serial Data Input. Can be configured as serial data output signal. Used as data pin 1 in quad-data and dual-data transfers.</td>
<td>I/O</td>
</tr>
</tbody>
</table>

### 48.3 Functional description
48.3.1 Clocking and Resets

48.3.1.1 Functional clock
The LPSPI functional clock is asynchronous to the bus clock and if it remains enabled in low power modes then LPSPI can perform SPI bus transfers and low power wakeups in both master and slave modes. The LPSPI divides the functional clock by a prescaler and the resulting frequency must be at least two times faster than the SPI external clock (LPSPI_SCK) frequency.

48.3.1.2 External clock
The LPSPI shift register is clocked directly by the LPSPI_SCK clock that is either generated internally in master mode or supplied externally in slave mode.

48.3.1.3 Bus clock
The bus clock is only used for bus accesses to the control and configuration registers. The bus clock frequency must be sufficient to support the data bandwidth requirements of the LPSPI registers, including FIFOs.

48.3.1.4 Chip reset
The logic and registers for the LPSPI are reset to their default state on a chip reset.

48.3.1.5 Software reset
The LPSPI implements a software reset bit in the Control Register. The CR[RST] will reset all logic and registers to their default state, except for the CR itself.

48.3.1.6 FIFO reset
The LPSPI implements write-only control bits that resets the transmit/command FIFO (CR[RTF] and receive FIFO (CR[RRF]). A FIFO is empty after being reset.
48.3.2 Master Mode

48.3.2.1 Transmit and Command FIFO

The transmit and command FIFO is a combined FIFO that includes both transmit data and command words. Command words are stored to the transmit/command FIFO by writing the transmit command register. Transmit data words are stored to the transmit/command FIFO by writing the transmit data register.

When a command word is at the top of the transmit/command FIFO, the following actions can occur:

- If the LPSPI is between frames, the command word is pulled from the FIFO and controls all subsequent transfers.
- If the LPSPI is busy and either the existing CONT bit is clear or the new CONTC value is clear, the SPI frame will complete at the end of the existing word, ignoring the FRAMESZ configuration. The command word is then pulled from the FIFO and controls all subsequent transfers (or until the next update to the command word).
- If the LPSPI is busy and the existing CONT bit is set and the new CONTC value is set, the command word is pulled from the FIFO during the last LPSPI_SCK pulse of the existing frame (based on FRAMESZ configuration) and the frame continues using the new command value for the rest of the frame (or until the next update to the command word). When CONTC is set, only the lower 24-bits of the command word are updated.

The current state of the existing command word can be read by reading the transmit command register. It requires at least three LPSPI functional clock cycles for the transmit command register to update after it is written (assuming an empty FIFO) and the LPSPI must be enabled (CR[MEN] is set).

Writing the transmit command register does not initiate a SPI bus transfer, unless the TXMSK bit is set. When TXMSK is set, a new command word will not be loaded until the end of the existing frame (based on FRAMESZ configuration) and the TXMSK bit will be cleared at the end of the transfer.

The following table describes the attributes that are controlled by the command word.

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
<th>Modify During Transfer</th>
</tr>
</thead>
<tbody>
<tr>
<td>CPOL</td>
<td>Configures polarity of the LPSPI_SCK pin. Any change of CPOL value will cause a transition on the LPSPI_SCK pin.</td>
<td>N</td>
</tr>
<tr>
<td>CPHA</td>
<td>Configures clock phase of transfer.</td>
<td>N</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## Table 48-3. LPSPI Command Word in Master Mode (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
<th>Modify During Transfer</th>
</tr>
</thead>
<tbody>
<tr>
<td>PRESCALE</td>
<td>Configures prescaler used to divide the LPSPI functional clock to generate the timing parameters of the SPI bus transfer. Changing PRESCALE in conjunction with PCS allows the LPSPI to connect to different slave devices at different frequencies.</td>
<td>N</td>
</tr>
<tr>
<td>PCS</td>
<td>Configures which LPSPI_PCS asserts for the transfer, the polarity of LPSPI_PCS is static and configured by PCSPOL. If PCSCFG is set, then PCS[3:2] should not be selected.</td>
<td>N</td>
</tr>
<tr>
<td>LSBF</td>
<td>Configures if LSB (bit 0) or MSB (bit 31 for a 32-bit word) is transmitted/received first.</td>
<td>Y</td>
</tr>
<tr>
<td>BYSW</td>
<td>Enables byte swap on each 32-bit word when transmitting and receiving data. Can be useful when interfacing to devices that organize data as big endian.</td>
<td>Y</td>
</tr>
<tr>
<td>CONT</td>
<td>Configures for a continuous transfer that keeps PCS asserted between frames (as configured by FRAMESZ). A new command word is required to cause PCS to negate. Also supports changing the command word at frame size boundaries.</td>
<td>Y</td>
</tr>
<tr>
<td>CONTC</td>
<td>Indicates that this is a new command word for the existing continuous transfer. CONTC bit is ignored when not written to the transmit/command FIFO on a frame boundary.</td>
<td>Y</td>
</tr>
<tr>
<td>RXMSK</td>
<td>Masks the receive data and does not store to the receive FIFO or perform receive data matching. Useful for half-duplex transfers or to configure which fields are compared during receive data matching.</td>
<td>Y</td>
</tr>
<tr>
<td>TXMSK</td>
<td>Masks the transmit data, so that data is not pulled from transmit FIFO and the output data pin is tristated (unless configured by OUTCFG). Useful for half-duplex transfers.</td>
<td>Y</td>
</tr>
<tr>
<td>WIDTH</td>
<td>Configures the number of bits shifted on each LPSI_SCK pulse.</td>
<td>Y</td>
</tr>
<tr>
<td></td>
<td>• 1-bit transfers support traditional SPI bus transfers in either half-duplex or full-duplex data formats.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• 2-bit and 4-bit transfers are useful for interfacing to QuadSPI memory devices, and only support half-duplex data formats (at least one of TXMSK or RXMSK must also be set).</td>
<td></td>
</tr>
<tr>
<td>FRAMESZ</td>
<td>Configures the frame size in number of bits equal to (FRAMESZ + 1).</td>
<td>Y</td>
</tr>
<tr>
<td></td>
<td>• The minimum frame size is 8 bits.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• If the frame size is larger than 32 bits, then the frame is divided into multiple words of 32-bits; each word is loaded from the transmit FIFO and stored in the receive FIFO separately.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• If the size of the frame is not divisible by 32, then the last load of the transmit FIFO and store of the receive FIFO will contain the remainder bits. For example, a 72-bit transfer will consist of 3 words: the 1st and 2nd words are 32-bit, and the 3rd word is 8-bit.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>• The minimum word size is 2 bits; a frame size of 33 bits (or similar) is not supported.</td>
<td></td>
</tr>
</tbody>
</table>

The LPSPI initiates a SPI bus transfer when data is written to the transmit FIFO, the HREQ pin is asserted (or disabled) and the LPSPI is enabled. The SPI bus transfer uses the attributes configured in the transmit command register and timing parameters from the clock configuration register to perform the transfer. The SPI bus transfer ends once the FRAMESZ configuration is reached, or at the end of a word when a new transmit
command word is at the top of the transmit/command FIFO. The HREQ input is only checked the next time the LPSPI goes idle (completes the current transfer and transmit/command register is empty).

The transmit/command FIFO also supports a Circular FIFO feature. This allows the LPSPI master to (periodically) repeat a short data transfer that can fit within the transmit/command FIFO, without requiring additional FIFO accesses. When the circular FIFO is enabled, the current state of the FIFO read pointer is saved and the status flags do not update. Once the transmit/command FIFO is considered empty and the LPSPI is idle, the FIFO read pointer is restored with the saved version, so the contents of the transmit/command FIFO are not permanently pulled from the FIFO while circular FIFO mode is enabled.

### 48.3.2.2 Receive FIFO and Data Match

The receive FIFO is used to store receive data during SPI bus transfers. When RXMSK is set, receive data is discarded instead of storing in the receive FIFO.

The receive data is written to the receive FIFO at the end of the frame. During a multiple word or continuous transfer, the receive data is also written to the receive FIFO at the same time as new transmit data is read from the transmit FIFO. If the transmit FIFO is empty during a continuous transfer, the receive data is only written to the receive FIFO after the transmit FIFO is written or the command register is written to end the frame.

Receive data supports a receive data match function that can match received data against one of two words or against a masked data word. The data match function can also be configured to compare only the first one or two received data words since the start of the frame. Receive data that is already discarded due to RXMSK bit cannot cause the data match to set and will delay the match on first received data word until after all discarded data is received. The receiver match function can also be configured to discard all receive data until a data match is detected, using the CFGR0[RDMO] control bit. When clearing the CFGR0[RDMO] control bit following a data match, clear CFGR0[RDMO] before clearing SR[DMF] to allow all subsequent data to be received.

### 48.3.2.3 Timing Parameters

The following table lists the timing parameters that are used for all SPI bus transfers, these timing parameters are relative to the LPSPI functional clock divided by the PRESCALE configuration. Although the Clock Configuration Register cannot be
changed when the LPSPI is busy, the PRESCALE configuration can be altered between transfers using the command register, to support interfacing to different slave devices at different frequencies.

Table 48-4. LPSPI Timing Parameters

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
<th>Min</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCKDIV</td>
<td>Configures the LPSPI_SCK clock period to (SCKDIV+2) cycles. When configured to an odd number of cycles, the first half of the LPSPI_SCK cycle is one cycle longer than the second half.</td>
<td>0 (2 cycles)</td>
<td>255 (257 cycles)</td>
</tr>
<tr>
<td>DBT</td>
<td>Configures the minimum delay between PCS negation and the next PCS assertion to (DBT + 2) cycles. When the command word is updated between transfers, there is a minimum of (DBT/2)+1 cycles between the command word update and any change on LPSPI_PCS pins.</td>
<td>0 (2 cycles)</td>
<td>255 (257 cycles)</td>
</tr>
<tr>
<td>DBT</td>
<td>Configures the delay during a continuous transfer between the last SCK edge of a frame and the first SCK edge of the continuing frame to (DBT + 1) cycles. This is useful where the external slave requires a large delay between different words of a SPI bus transfer.</td>
<td>0 (1 cycle)</td>
<td>255 (256 cycles)</td>
</tr>
<tr>
<td>PCSSCK</td>
<td>Configures the minimum delay between PCS assertion and the first SCK edge to (PCSSCK + 1) cycles.</td>
<td>0 (1 cycle)</td>
<td>255 (256 cycles)</td>
</tr>
<tr>
<td>SCKPCS</td>
<td>Configures the minimum delay between the last SCK edge and the PCS assertion to (SCKPCS + 1) cycles.</td>
<td>0 (1 cycle)</td>
<td>255 (256 cycles)</td>
</tr>
</tbody>
</table>

**48.3.2.4 Pin Configuration**

The LPSPI_SIN and LPSPI_SOUT pins can be configured via the PINCFG configuration to swap directions or even support half-duplex transfers on the same pin.
The OUTCFG configuration can be used to determine if output data pin (eg: LPSPI_SOUT) will tristate when the LPSPI_PCS is negated, or if it will simply retain the last value. When configuring for half-duplex transfers using the same data pin in single bit transfer mode, or any transfer in 2-bit and 4-bit transfer modes, then the output data pins must be configured to tristate when LPSPI_PCS is negated.

The PCSCFG configuration is used to disable LPSPI_PCS[3:2] functions and to use them for quad-data transfers. This option must be enabled when performing quad-data transfers.

### 48.3.3 Slave Mode

LPSPI slave mode uses the same shift register and logic as the master mode, but does not use the clock configuration register and the transmit command register must remain static during SPI bus transfers.

### 48.3.3.1 Transmit and Command FIFO

The transmit command register should be initialized before enabling the LPSPI in slave mode, although the command register will not update until after the LPSPI is enabled. Once enabled, the transmit command register should only be changed if the LPSPI is idle. The following table lists how the command register functions in slave mode.

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CPOL</td>
<td>Configures polarity of the external LPSPI_SCK input.</td>
</tr>
<tr>
<td>CPHA</td>
<td>Configures clock phase of transfer.</td>
</tr>
<tr>
<td>PRESCALE</td>
<td>Configures LPSPI functional clock prescaler.</td>
</tr>
<tr>
<td>PCS</td>
<td>Configures which LPSPI_PCS is used, the polarity of LPSPI_PCS is static and configured by PCSPOL. If PCSCFG is set, then PCS[3:2] should not be selected.</td>
</tr>
<tr>
<td>LSBF</td>
<td>Configures if LSB (bit 0) or MSB (bit 31 for a 32-bit word) is transmitted/received first.</td>
</tr>
<tr>
<td>BYSW</td>
<td>Enables byte swap on each 32-bit word when transmitting and receiving data. Can be useful when interfacing to devices that organize data as big endean.</td>
</tr>
<tr>
<td>CONT</td>
<td>When set, only the first FRAMSZ bits will be transmitted/received by the LPSPI.</td>
</tr>
<tr>
<td>CONTC</td>
<td>CONTC bit is reserved in slave mode.</td>
</tr>
<tr>
<td>RXMSK</td>
<td>Masks the receive data and does not store to the receive FIFO or perform receive data matching. Useful for half-duplex transfers or to configure which fields are compared during receive data matching.</td>
</tr>
<tr>
<td>TXMSK</td>
<td>Masks the transmit data, so that data is not pulled from transmit FIFO and the output data pin is tristated (unless configured by OUTCFG). Useful for half-duplex transfers.</td>
</tr>
<tr>
<td>WIDTH</td>
<td>Configures the number of bits shifted on each LPSPI_SCK pulse.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 48-5. LPSPI Command Word in Slave Mode (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>• 1-bit transfers support traditional SPI bus transfers in either half-duplex or full-duplex data formats.</td>
</tr>
<tr>
<td></td>
<td>• 2-bit and 4-bit transfers are useful for interfacing to QuadSPI memory devices, and only support half-duplex data formats (at least one of TXMSK or RXMSK must also be set).</td>
</tr>
<tr>
<td>FRAMESZ</td>
<td>Configures the frame size in number of bits equal to (FRAMESZ + 1).</td>
</tr>
<tr>
<td></td>
<td>• The minimum frame size is 8 bits.</td>
</tr>
<tr>
<td></td>
<td>• If the frame size is larger than 32 bits, then the frame is divided into multiple words of 32-bits; each word is loaded from the transmit FIFO and stored in the receive FIFO separately.</td>
</tr>
<tr>
<td></td>
<td>• If the size of the frame is not divisible by 32, then the last load of the transmit FIFO and store of the receive FIFO will contain the remainder bits. For example, a 72-bit transfer will consist of 3 words: the 1st and 2nd words are 32-bit, and the 3rd word is 8-bit.</td>
</tr>
<tr>
<td></td>
<td>• The minimum word size is 2 bits; a frame size of 33 bits (or similar) is not supported.</td>
</tr>
</tbody>
</table>

The transmit FIFO must be filled with transmit data before the LPSPI_PCS input asserts, otherwise the transmit error flag will set.

#### 48.3.3.2 Receive FIFO and Data Match

The receive FIFO is used to store receive data during SPI bus transfers. When RXMSK is set, receive data is discarded instead of storing in the receive FIFO.

Receive data supports a receive data match function that can match received data against one of two words or against a masked data word. The data match function can also be configured to compare only the first one or two received data words since the start of the frame. Receive data that is already discarded due to RXMSK bit cannot cause the data match to set and will delay the match on first received data word until after all discarded data is received. The receiver match function can also be configured to discard all receive data until a data match is detected, using the CFGR0[RDMO] control bit. When clearing the CFGR0[RDMO] control bit following a data match, clear CFGR0[RDMO] before clearing SR[DMF] to allow all subsequent data to be received.

#### 48.3.3.3 Clocked Interface

The LPSPI supports interfacing to external masters that provide only clock and data pins (LPSPI_PCS is not required). This requires using CPHA=1, configuring the LPSPI_PCS input to be always asserted (configure PCSPOL) and setting the AUTOPCS bit. When AUTOPCS is set, a minimum of 4 LPSPI functional clock cycles (divided by PRESCALE configuration) is required between the last LPSPI_SCK edge of one word and the first LPSPI_SCK edge of the next word.
### 48.3.4 Interrupts and DMA Requests

The following table illustrates the status flags that can generate the LPSPI interrupt and LPSPI transmit/receive DMA requests.

#### Table 48-6. LPSPI Interrupts and DMA Requests

<table>
<thead>
<tr>
<th>Flag</th>
<th>Description</th>
<th>Interrupt</th>
<th>DMA Request</th>
<th>Low Power Wakeup</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDF</td>
<td>Data can be written to transmit FIFO, as configured by TXWATER.</td>
<td>Y</td>
<td>TX</td>
<td>Y</td>
</tr>
<tr>
<td>RDF</td>
<td>Data can be read from the receive FIFO, as configured by RXWATER.</td>
<td>Y</td>
<td>RX</td>
<td>Y</td>
</tr>
<tr>
<td>WCF</td>
<td>Word complete, last bit of word has been sampled.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>FCF</td>
<td>Frame complete, PCS has negated.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>TCF</td>
<td>Transfer complete, PCS has negated and transmit/command FIFO is empty.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>TEF</td>
<td>Transmit error flag, indicates transmit/command FIFO underrun. This bit cannot set in master mode when NOSTALL is clear.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>REF</td>
<td>Receive error flag, indicates receive FIFO overflow. This bit cannot set in master mode when NOSTALL is clear.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>DMF</td>
<td>Data match flag, received data has matched the configured data match value.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>MBF</td>
<td>LPSPI is busy performing a SPI bus transfer.</td>
<td>N</td>
<td>N</td>
<td>N</td>
</tr>
</tbody>
</table>
### 48.3.5 Peripheral Triggers

The connection of the LPSPI peripheral triggers with other peripherals are device specific.

#### 48.3.5.1 Output Triggers

The LPSPI generates two output triggers that can be connected to other peripherals on the device. The frame output trigger asserts at the end of each frame (when PCS negates) and remains asserted until PCS next asserts. The word output trigger asserts at the end of each received word and remains asserted for one LPSPI_SCK period.

#### 48.3.5.2 Input Trigger

The LPSPI input trigger can be selected in place of the LPSPI_HREQ input to control the start of a LPSPI bus transfer. The input trigger is synchronized and must assert for at least two cycles of the LPSPI functional clock divided by the PRESCALE configuration to be detected. Note that the LPSPI_HREQ input (and therefore the input trigger) is ignored when the LPSPI is busy.

### 48.4 Memory Map and Registers

#### 48.4.1 LPSPI register descriptions

##### 48.4.1.1 LPSPI Memory map

Base address:
- LPSPI1: 4039_4000h
- LPSPI2: 4039_8000h
- LPSPI3: 4039_C000h
- LPSPI4: 403A_0000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (ln bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Version ID Register (VERID)</td>
<td>32</td>
<td>RO</td>
<td>0102_0004h</td>
</tr>
<tr>
<td>4h</td>
<td>Parameter Register (PARAM)</td>
<td>32</td>
<td>RO</td>
<td>0004_0404h</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>10h</td>
<td>Control Register (CR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Status Register (SR)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0001h</td>
</tr>
<tr>
<td>18h</td>
<td>Interrupt Enable Register (IER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>DMA Enable Register (DER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>20h</td>
<td>Configuration Register 0 (CFG0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>24h</td>
<td>Configuration Register 1 (CFG1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>30h</td>
<td>Data Match Register 0 (DMR0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>34h</td>
<td>Data Match Register 1 (DMR1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>40h</td>
<td>Clock Configuration Register (CCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>58h</td>
<td>FIFO Control Register (FCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>5Ch</td>
<td>FIFO Status Register (FSR)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>60h</td>
<td>Transmit Command Register (TCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0001Fh</td>
</tr>
<tr>
<td>64h</td>
<td>Transmit Data Register (TDR)</td>
<td>32</td>
<td>WO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>70h</td>
<td>Receive Status Register (RSR)</td>
<td>32</td>
<td>RO</td>
<td>0000_00002h</td>
</tr>
<tr>
<td>74h</td>
<td>Receive Data Register (RDR)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

### 48.4.1.2 Version ID Register (VERID)

#### 48.4.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VERID</td>
<td>0h</td>
</tr>
</tbody>
</table>

#### 48.4.1.2.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>MAJOR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>FEATURE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```
48.4.1.2.3  **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Major Version Number</td>
</tr>
<tr>
<td>MAJOR</td>
<td>Returns the major version number for the module specification. Read-only field.</td>
</tr>
<tr>
<td>23-16</td>
<td>Minor Version Number</td>
</tr>
<tr>
<td>MINOR</td>
<td>Returns the minor version number for the module specification. Read-only field.</td>
</tr>
<tr>
<td>15-0</td>
<td>Module Identification Number</td>
</tr>
<tr>
<td>FEATURE</td>
<td>Returns the feature set number. Read-only field. 000000000000100b - Standard feature set supporting a 32-bit shift register.</td>
</tr>
</tbody>
</table>

48.4.1.3  **Parameter Register (PARAM)**

48.4.1.3.1  **Offset**

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PARAM</td>
<td>4h</td>
</tr>
</tbody>
</table>

48.4.1.3.2  **Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PCSNUM</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RXFIFO</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TXFIFO</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

48.4.1.3.3  **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-16</td>
<td>PCS Number</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>PCSNUM</td>
<td>Sets the number of PCS pins supported by the peripheral.</td>
</tr>
<tr>
<td>15-8 RXFIFO</td>
<td>Receive FIFO Size</td>
</tr>
<tr>
<td>7-0 TXFIFO</td>
<td>Transmit FIFO Size</td>
</tr>
</tbody>
</table>

### 48.4.1.4 Control Register (CR)

#### 48.4.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CR</td>
<td>10h</td>
</tr>
</tbody>
</table>

#### 48.4.1.4.2 Diagram

#### 48.4.1.4.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-10</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| 9 RRF | Reset Receive FIFO  
|       | 0b - No effect  
|       | 1b - Receive FIFO is reset |
| 8 RTF | Reset Transmit FIFO  
|       | 0b - No effect  
|       | 1b - Transmit FIFO is reset |

Table continues on the next page...
### 48.4.1.5 Status Register (SR)

#### 48.4.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SR</td>
<td>14h</td>
</tr>
</tbody>
</table>

#### 48.4.1.5.2 Diagram

![Status Register (SR) Diagram](image-url)
### 48.4.1.5.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-25</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>24</td>
<td>Module Busy Flag</td>
</tr>
<tr>
<td></td>
<td>0b - LPSPI is idle</td>
</tr>
<tr>
<td></td>
<td>1b - LPSPI is busy</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>23-14</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Data Match Flag</td>
</tr>
<tr>
<td></td>
<td>Indicates that the received data has matched the MATCH0 and/or MATCH1 fields (as configured by CFGR1[MATCFG], Configuration Register 1).</td>
</tr>
<tr>
<td></td>
<td>0b - Have not received matching data</td>
</tr>
<tr>
<td></td>
<td>1b - Have received matching data</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>Receive Error Flag</td>
</tr>
<tr>
<td></td>
<td>The Receive Error Flag will set when the Receiver FIFO overflows. When the Receive Error Flag is set, it is recommended to first end the transfer, empty the Receive FIFO, clear the Receive Error Flag and then restart the transfer from the beginning.</td>
</tr>
<tr>
<td></td>
<td>0b - Receive FIFO has not overflowed</td>
</tr>
<tr>
<td></td>
<td>1b - Receive FIFO has overflowed</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Transmit Error Flag</td>
</tr>
<tr>
<td></td>
<td>The Transmit Error Flag will set when the Transmit FIFO underruns. When the Transmit Error Flag is set, it is recommended to first end the transfer, clear the Transmit Error Flag and then restart the transfer from the beginning.</td>
</tr>
<tr>
<td></td>
<td>0b - Transmit FIFO underrun has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - Transmit FIFO underrun has occurred</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>Transfer Complete Flag</td>
</tr>
<tr>
<td></td>
<td>In master mode when the LPSPI returns to idle state with the transmit FIFO empty, the Transfer Complete Flag will set.</td>
</tr>
<tr>
<td></td>
<td>0b - All transfers have not completed</td>
</tr>
<tr>
<td></td>
<td>1b - All transfers have completed</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>Frame Complete Flag</td>
</tr>
<tr>
<td></td>
<td>The Frame Complete Flag will set at the end of each frame transfer, when the PCS negates.</td>
</tr>
<tr>
<td></td>
<td>0b - Frame transfer has not completed</td>
</tr>
<tr>
<td></td>
<td>1b - Frame transfer has completed</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>Word Complete Flag</td>
</tr>
<tr>
<td></td>
<td>The Word Complete Flag will set when the last bit of a received word is sampled.</td>
</tr>
<tr>
<td></td>
<td>0b - Transfer of a received word has not yet completed</td>
</tr>
<tr>
<td></td>
<td>1b - Transfer of a received word has completed</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>7-2</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Receive Data Flag</td>
</tr>
<tr>
<td></td>
<td>The Receive Data Flag is set whenever the number of words in the receive FIFO is greater than FCR[RXWATER] (FIFO Control Register)</td>
</tr>
<tr>
<td></td>
<td>0b - Receive Data is not ready</td>
</tr>
<tr>
<td></td>
<td>1b - Receive data is ready</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>Transmit Data Flag</td>
</tr>
</tbody>
</table>
### 48.4.1.6 Interrupt Enable Register (IER)

#### 48.4.1.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IER</td>
<td>18h</td>
</tr>
</tbody>
</table>

#### 48.4.1.6.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 48.4.1.6.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-14</td>
<td>Reserved</td>
</tr>
<tr>
<td>13</td>
<td>Data Match Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>DMIE</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>Receive Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>REIE</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Transmit Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>TEIE</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### 48.4.1.7 DMA Enable Register (DER)

#### 48.4.1.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DER</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

#### 48.4.1.7.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

0b - Disabled
1b - Enabled
48.4.1.7.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Receive Data DMA Enable</td>
</tr>
<tr>
<td>RDDE</td>
<td>0b - DMA request is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - DMA request is enabled</td>
</tr>
<tr>
<td>0</td>
<td>Transmit Data DMA Enable</td>
</tr>
<tr>
<td>TDDE</td>
<td>0b - DMA request is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - DMA request is enabled</td>
</tr>
</tbody>
</table>

48.4.1.8 Configuration Register 0 (CFGR0)

48.4.1.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFGR0</td>
<td>20h</td>
</tr>
</tbody>
</table>

48.4.1.8.2 Diagram

48.4.1.8.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-10</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>Receive Data Match Only</td>
</tr>
</tbody>
</table>
### Field Function

- **RDMO**
  - When Receive Data Match Only is enabled, all received data that does not cause the Data Match Flag (SR[DMF]) to set is discarded.
  - Receive Data Match Only bit should be set when the LPSPI is idle and the Data Match Flag is clear.
  - After the Data Match Flag (DMF) is set, the Receive Data Match Only bit configuration is ignored.
  - When disabling RDMO and to ensure that no receive data is lost, before clearing the Data Match Flag, first clear Receive Data Match Only (RDMO).

  - 0b - Received data is stored in the receive FIFO as in normal operations
  - 1b - Received data is discarded unless the Data Match Flag (DMF) is set

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>RDMO</td>
<td>When Receive Data Match Only is enabled, all received data that does not cause the Data Match Flag (SR[DMF]) to set is discarded. Normally, this is used in master mode to ensure no receive data is lost. However, when disabling RDMO and Data Match Only, data is discarded unless the Data Match Flag (DMF) is set.</td>
</tr>
</tbody>
</table>

- **CIRFIFO**
  - Circular FIFO Enable
    - When enabled, the transmit FIFO read pointer is saved to a temporary register. The transmit FIFO will be emptied as it normally is, but after the LPSPI is idle and the transmit FIFO is empty, then the read pointer value will be restored from the temporary register. This restoring of the read pointer will cause the contents of the transmit FIFO to be cycled through repeatedly.
    - 0b - Circular FIFO is disabled
    - 1b - Circular FIFO is enabled

- **HRSEL**
  - Host Request Select
    - Selects the source of the host request input. When the host request function is enabled with the LPSPI_HREQ pin, the LPSPI_PCS[1] function is disabled.
    - 0b - Host request input is the LPSPI_HREQ pin
    - 1b - Host request input is the input trigger

- **HRPOL**
  - Host Request Polarity
    - Configures the polarity of the host request pin.
    - 0b - Active low
    - 1b - Active high

- **HREN**
  - Host Request Enable
    - When enabled in master mode, the LPSPI will only start a new SPI bus transfer if the host request input is asserted. When the LPSPI is busy, the host request input is ignored.
    - 0b - Host request is disabled
    - 1b - Host request is enabled

### 48.4.1.9 Configuration Register 1 (CFGR1)

#### 48.4.1.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CFGR1</td>
<td>24h</td>
</tr>
</tbody>
</table>

#### 48.4.1.9.2 Function

The CFGR1 should only be written when the LPSPI is disabled.
48.4.1.9.3  Diagram

### Bits 31-28

**Reserved**

### Bits 27

**PCSCFG**

Peripheral Chip Select Configuration

If performing 4-bit transfers, the Peripheral Chip Select Configuration bit must be set.

- 0b - PCS[3:2] are enabled
- 1b - PCS[3:2] are disabled

### Bits 26

**OUTCFG**

Output Config

Configures if the output data is tristated between accesses (LPSPI_PCS is negated).

- 0b - Output data retains last value when chip select is negated
- 1b - Output data is tristated when chip select is negated

### Bits 25-24

**PINCFG**

Pin Configuration

Configures which pins are used for input and output data during single bit transfers.

- 00b - SIN is used for input data and SOUT is used for output data
- 01b - SIN is used for both input and output data
- 10b - SOUT is used for both input and output data
- 11b - SOUT is used for input data and SIN is used for output data

### Bits 23-19

**Reserved**

### Bits 18-16

**MATCFG**

Match Configuration

Configures the condition that will cause the DMF to set.

**NOTE:** Syntax: * is boolean AND, + is boolean OR

- 000b - Match is disabled
- 001b - Reserved
- 010b - 010b - Match is enabled, if 1st data word equals MATCH0 OR MATCH1, i.e., (1st data word = MATCH0 + MATCH1)

Table continues on the next page...
### Field | Function
--- | ---
011b - 011b | Match is enabled, if any data word equals MATCH0 OR MATCH1, i.e., (any data word = MATCH0 + MATCH1)
100b - 100b | Match is enabled, if 1st data word equals MATCH0 AND 2nd data word equals MATCH1, i.e., [(1st data word = MATCH0) * (2nd data word = MATCH1)]
101b - 101b | Match is enabled, if any data word equals MATCH0 AND the next data word equals MATCH1, i.e., [(any data word = MATCH0) * (next data word = MATCH1)]
110b - 110b | Match is enabled, if (1st data word AND MATCH1) equals (MATCH0 AND MATCH1), i.e., [(1st data word * MATCH1) = (MATCH0 * MATCH1)]
111b - 111b | Match is enabled, if (any data word AND MATCH1) equals (MATCH0 AND MATCH1), i.e., [(any data word * MATCH1) = (MATCH0 * MATCH1)]

| Field | Function |
--- | --- |
15-12 | Reserved |
11-8 | Peripheral Chip Select Polarity |
PCSPOL | Configures the polarity of each Peripheral Chip Select pin. |
| | 0000b - The Peripheral Chip Select pin PCSx is active low |
| | 0001b - The Peripheral Chip Select pin PCSx is active high |
7-4 | Reserved |
3 | No Stall |
NOSTALL | In master mode, the LPSPI will stall transfers when the transmit FIFO is empty or when the receive FIFO is full, ensuring that no transmit FIFO underrun or receive FIFO overrun can occur. Setting the No Stall bit will disable this functionality. |
| | 0b - Transfers will stall when the transmit FIFO is empty or the receive FIFO is full |
| | 1b - Transfers will not stall, allowing transmit FIFO underruns or receive FIFO overruns to occur |
2 | Automatic PCS |
AUTOPCS | For correct operations, the LPSPI slave normally requires the PCS to negate between frames. Setting the Automatic PCS bit will cause the LPSPI to generate an internal PCS signal at the end of each transfer word when the Clock Phase bit TCR[CPHA] = 1. |
| | When the Automatic PCS bit is set, the SCK must remain idle for at least 4 LPSPI functional clock cycles (divided by the Prescaler Value TCR[PRESCALE] configuration) between each word, to ensure correct operations |
| | In master mode, the Automatic PCS bit is ignored |
| | 0b - Automatic PCS generation is disabled |
| | 1b - Automatic PCS generation is enabled |
1 | Sample Point |
SAMPLE | When set, the LPSPI master will sample the input data on a delayed LPSPI_SCK edge, which improves the setup time when sampling data. |
| | The input data setup time in master mode with delayed LPSPI_SCK edge is equal to the input data setup time in slave mode |
| | In slave mode, the SAMPLE bit is ignored |
| | 0b - Input data is sampled on SCK edge |
| | 1b - Input data is sampled on delayed SCK edge |
0 | Master Mode |
MASTER | Configures the LPSPI in master or slave mode. The Master Mode bit directly controls the direction of the LPSPI_SCK and LPCPI_PCS pins. |
| | 0b - Slave mode |
| | 1b - Master mode |
48.4.1.10  Data Match Register 0 (DMR0)

48.4.1.10.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMR0</td>
<td>30h</td>
</tr>
</tbody>
</table>

48.4.1.10.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>R</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>MATCH0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
</tr>
</tbody>
</table>

48.4.1.10.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Match 0 Value</td>
</tr>
<tr>
<td>MATCH0</td>
<td>When Receive Data Match Only (CFGR0[RDMO]) is enabled, the Match 0 Value is compared against the received data.</td>
</tr>
</tbody>
</table>

48.4.1.11  Data Match Register 1 (DMR1)

48.4.1.11.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMR1</td>
<td>34h</td>
</tr>
</tbody>
</table>
### 48.4.1.11.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>MATCH1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>MATCH1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 48.4.1.11.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0 MATCH1</td>
<td>Match 1 Value</td>
</tr>
<tr>
<td>MATCH1</td>
<td>When Receive Data Match Only (CFGR0[RDMO]) is enabled, the Match 1 Value is compared against the received data.</td>
</tr>
</tbody>
</table>

### 48.4.1.12 Clock Configuration Register (CCR)

#### 48.4.1.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CCR</td>
<td>40h</td>
</tr>
</tbody>
</table>

#### 48.4.1.12.2 Function

The Clock Configuration Register is only used in master mode, and the Clock Configuration Register cannot be changed when the LP SPI is enabled.
### 48.4.1.12.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SCKPCS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>PCSSCK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DBT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SCKDIV</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 48.4.1.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>SCK-to-PCS Delay</td>
</tr>
<tr>
<td>SCKPCS</td>
<td>In master mode: configures the delay from the last SCK edge to the PCS negation.</td>
</tr>
<tr>
<td>-</td>
<td>The delay is equal to ((SCKPCS + 1)) cycles of the LPSPI functional clock divided by the Prescaler Value TCR[PRESCALE] configuration.</td>
</tr>
<tr>
<td>-</td>
<td>The minimum delay is 1 cycle.</td>
</tr>
<tr>
<td>23-16</td>
<td>PCS-to-SCK Delay</td>
</tr>
<tr>
<td>PCSSCK</td>
<td>In master mode: configures the delay from the PCS assertion to the first SCK edge.</td>
</tr>
<tr>
<td>-</td>
<td>The delay is equal to ((PCSSCK + 1)) cycles of the LPSPI functional clock divided by the Prescaler Value TCR[PRESCALE] configuration.</td>
</tr>
<tr>
<td>-</td>
<td>The minimum delay is 1 cycle.</td>
</tr>
<tr>
<td>15-8</td>
<td>Delay Between Transfers</td>
</tr>
<tr>
<td>DBT</td>
<td>In master mode:</td>
</tr>
<tr>
<td>-</td>
<td>Configures the delay from the PCS negation to the next PCS assertion.</td>
</tr>
<tr>
<td>-</td>
<td>The delay is equal to ((DBT + 2)) cycles of the LPSPI functional clock divided by the Prescaler Value TCR[PRESCALE] configuration.</td>
</tr>
<tr>
<td>-</td>
<td>The minimum delay is 2 cycles.</td>
</tr>
<tr>
<td>-</td>
<td>Half of the delay occurs before PCS assertion and the other half of the delay occurs after PCS negation. If the command word is updated between 2 transfers, then the command word is updated half-way between the PCS negation of the last transfer and PCS assertion of the next transfer.</td>
</tr>
<tr>
<td>-</td>
<td>The command word sets which PCS signal is used (of PCS[3:0]}, the polarity/phase of the SCK signal, and the Prescaler Value.</td>
</tr>
<tr>
<td>-</td>
<td>Configures the delay from the last SCK edge of a transfer word and the first SCK edge of the next transfer word, in a continuous transfer.</td>
</tr>
<tr>
<td>-</td>
<td>The delay is equal to ((DBT + 1)) cycles of the LPSPI functional clock divided by the Prescaler Value TCR[PRESCALE] configuration.</td>
</tr>
<tr>
<td>-</td>
<td>The minimum delay is 1 cycle.</td>
</tr>
<tr>
<td>7-0</td>
<td>SCK Divider</td>
</tr>
<tr>
<td>SCKDIV</td>
<td>In master mode, the SCK Divider configures the divide ratio of the SCK pin.</td>
</tr>
<tr>
<td>-</td>
<td>The SCK period is equal to ((SCKDIV+2)) cycles of the LPSPI functional clock divided by the Prescaler Value TCR[PRESCALE] configuration.</td>
</tr>
<tr>
<td>-</td>
<td>The minimum SCK period is 2 cycles.</td>
</tr>
<tr>
<td>-</td>
<td>If the SCK period is an odd number of cycles, then the 1st half of the SCK period will be 1 cycle longer than the 2nd half of the SCK period.</td>
</tr>
</tbody>
</table>
48.4.1.13 FIFO Control Register (FCR)

48.4.1.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCR</td>
<td>58h</td>
</tr>
</tbody>
</table>

48.4.1.13.2 Diagram

![Diagram of FCR Register]

48.4.1.13.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-20</td>
<td>Reserved</td>
</tr>
<tr>
<td>19-16</td>
<td>Receive FIFO Watermark</td>
</tr>
<tr>
<td>RXWATER</td>
<td>The Receive Data Flag is set whenever the number of words in the receive FIFO is greater than RXWATER. Writing a value equal or greater than the FIFO size will be truncated.</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3-0</td>
<td>Transmit FIFO Watermark</td>
</tr>
<tr>
<td>TXWATER</td>
<td>The Transmit Data Flag is set whenever the number of words in the transmit FIFO is equal or less than TXWATER. Writing a value equal or greater than the FIFO size will be truncated.</td>
</tr>
</tbody>
</table>
48.4.1.14 FIFO Status Register (FSR)

48.4.1.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FSR</td>
<td>5Ch</td>
</tr>
</tbody>
</table>

48.4.1.14.2 Diagram

```
Bits  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16
R     0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0
W          RXCOUNT
Reset 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0

Bits  15  14  13  12  11  10  9   8   7   6   5   4   3   2   1   0
R     0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0
W          TXCOUNT
Reset 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0
```

48.4.1.14.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-21</td>
<td>Reserved</td>
</tr>
<tr>
<td>20-16</td>
<td>Receive FIFO Count</td>
</tr>
<tr>
<td>RXCOUNT</td>
<td>Returns the number of words currently stored in the receive FIFO.</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4-0</td>
<td>Transmit FIFO Count</td>
</tr>
<tr>
<td>TXCOUNT</td>
<td>Returns the number of words currently stored in the transmit FIFO.</td>
</tr>
</tbody>
</table>
48.4.1.15 Transmit Command Register (TCR)

48.4.1.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCR</td>
<td>60h</td>
</tr>
</tbody>
</table>

48.4.1.15.2 Function

Writes to either the Transmit Command Register or Transmit Data Register will push the data into the transmit FIFO, in the order that the data are written. Command Register writes will be tagged and cause the command register to update, after that entry reaches the top of the FIFO. This allows changes to the command word and the transmit data itself to be interleaved. Changing the command word will cause all subsequent SPI bus transfers to be performed using the new command word.

- **In master mode**, writing a new command word does not initiate a new transfer, unless TXMSK is set. Transfers are initiated by transmit data in the transmit FIFO, or by a new command word (with TXMSK set). Hardware will clear TXMSK when the LPSPI_PCS negates.
- **In master mode**, if the command word is changed before an existing frame has completed, then the existing frame will terminate and the command word will then update. The command word can be changed during a continuous transfer, if CONTC of the new command word is set and the command word is written on a frame size boundary.
- **In slave mode**, the command word should be changed only when the LPSPI is idle and there is no SPI bus transfer.

**Avoid register reading problems:** Reading the Transmit Command Register will return the current state of the command register. Reading the Transmit Command Register at the same time that the Transmit Command Register is loaded from the transmit FIFO, can return an incorrect Transmit Command Register value. It is recommended:

- to either read the Transmit Command Register when the transmit FIFO is empty,
- or to read the Transmit Command Register more than once and then compare the returned values.
48.4.1.15.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>CPOL</td>
<td>CPHA</td>
<td>PRESCALE</td>
<td>PC</td>
<td>S</td>
<td>LSB F</td>
<td>BVS W</td>
<td>CONT</td>
<td>CONTC</td>
<td>RXMSK</td>
<td>TXMSK</td>
<td>WIDTH</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>FRAMESZ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

48.4.1.15.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Clock Polarity</td>
</tr>
<tr>
<td>CPOL</td>
<td>The Clock Polarity field is only updated between frames.</td>
</tr>
<tr>
<td></td>
<td>0b - The inactive state value of SCK is low</td>
</tr>
<tr>
<td></td>
<td>1b - The inactive state value of SCK is high</td>
</tr>
<tr>
<td>30</td>
<td>Clock Phase</td>
</tr>
<tr>
<td>CPHA</td>
<td>The Clock Phase field is only updated between frames.</td>
</tr>
<tr>
<td></td>
<td>0b - Data is captured on the leading edge of SCK and changed on the following edge of SCK</td>
</tr>
<tr>
<td></td>
<td>1b - Data is changed on the leading edge of SCK and captured on the following edge of SCK</td>
</tr>
<tr>
<td>29-27</td>
<td>Prescaler Value</td>
</tr>
<tr>
<td>PRESCALE</td>
<td>For all SPI bus transfers, the Prescaler value applied to the clock configuration register. The Prescaler Value field is only updated between frames.</td>
</tr>
<tr>
<td></td>
<td>000b - Divide by 1</td>
</tr>
<tr>
<td></td>
<td>001b - Divide by 2</td>
</tr>
<tr>
<td></td>
<td>010b - Divide by 4</td>
</tr>
<tr>
<td></td>
<td>011b - Divide by 8</td>
</tr>
<tr>
<td></td>
<td>100b - Divide by 16</td>
</tr>
<tr>
<td></td>
<td>101b - Divide by 32</td>
</tr>
<tr>
<td></td>
<td>110b - Divide by 64</td>
</tr>
<tr>
<td></td>
<td>111b - Divide by 128</td>
</tr>
<tr>
<td>26</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>25-24</td>
<td>Peripheral Chip Select</td>
</tr>
<tr>
<td>PCS</td>
<td>Configures the peripheral chip select used for the transfer. The Peripheral Chip Select field is only updated between frames.</td>
</tr>
<tr>
<td></td>
<td>00b - Transfer using LPSPI_PCS[0]</td>
</tr>
<tr>
<td></td>
<td>01b - Transfer using LPSPI_PCS[1]</td>
</tr>
<tr>
<td></td>
<td>10b - Transfer using LPSPI_PCS[2]</td>
</tr>
<tr>
<td></td>
<td>11b - Transfer using LPSPI_PCS[3]</td>
</tr>
<tr>
<td>23</td>
<td>LSB First</td>
</tr>
<tr>
<td></td>
<td>0b - Data is transferred MSB first</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>LSBF</td>
<td>1b - Data is transferred LSB first</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>BYSW</th>
<th>Byte Swap</th>
</tr>
</thead>
<tbody>
<tr>
<td>Byte swap will swap the contents of [31:24] with [7:0] and [23:16] with [15:8] for each transmit data word read from the FIFO and for each received data word stored to the FIFO (or compared with match registers).</td>
<td></td>
</tr>
<tr>
<td>0b - Byte swap is disabled</td>
<td></td>
</tr>
<tr>
<td>1b - Byte swap is enabled</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>CONT</th>
<th>Continuous Transfer</th>
</tr>
</thead>
<tbody>
<tr>
<td>In master mode, continuous transfer will keep the PCS asserted at the end of the frame size, until a command word is received that starts a new frame.</td>
<td></td>
</tr>
<tr>
<td>In slave mode, when continuous transfer is enabled, the LP SPI will only transmit the first FRAMESZ bits; after which the LP SPI will transmit received data (assuming a 32-bit shift register).</td>
<td></td>
</tr>
<tr>
<td>0b - Continuous transfer is disabled</td>
<td></td>
</tr>
<tr>
<td>1b - Continuous transfer is enabled</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>CONTC</th>
<th>Continuing Command</th>
</tr>
</thead>
<tbody>
<tr>
<td>In master mode, the Continuing Command bit allows the command word to be changed within a continuous transfer.</td>
<td></td>
</tr>
<tr>
<td>• The initial command word must enable continuous transfer (CONT=1),</td>
<td></td>
</tr>
<tr>
<td>• the continuing command must set this bit (CONTC=1),</td>
<td></td>
</tr>
<tr>
<td>• and the continuing command word must be loaded on a frame size boundary.</td>
<td></td>
</tr>
<tr>
<td>For example, if the continuous transfer has a frame size of 64-bits, then a continuing command word must be loaded on a 64-bit boundary.</td>
<td></td>
</tr>
<tr>
<td>0b - Command word for start of new transfer</td>
<td></td>
</tr>
<tr>
<td>1b - Command word for continuing transfer</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>RXMSK</th>
<th>Receive Data Mask</th>
</tr>
</thead>
<tbody>
<tr>
<td>When set, receive data is masked (receive data is not stored in receive FIFO).</td>
<td></td>
</tr>
<tr>
<td>0b - Normal transfer</td>
<td></td>
</tr>
<tr>
<td>1b - Receive data is masked</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TXMSK</th>
<th>Transmit Data Mask</th>
</tr>
</thead>
<tbody>
<tr>
<td>When set, transmit data is masked (no data is loaded from transmit FIFO and output pin is tristated). In master mode, the Transmit Data Mask bit will initiate a new transfer which cannot be aborted by another command word; the Transmit Data Mask bit will be cleared by hardware at the end of the transfer.</td>
<td></td>
</tr>
<tr>
<td>0b - Normal transfer</td>
<td></td>
</tr>
<tr>
<td>1b - Mask transmit data</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>WIDTH</th>
<th>Transfer Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>For 2-bit or 4-bit transfers, either Receive Data Mask (RXMSK) or Transmit Data Mask (TXMSK) must be set.</td>
<td></td>
</tr>
<tr>
<td>00b - 1 bit transfer</td>
<td></td>
</tr>
<tr>
<td>01b - 2 bit transfer</td>
<td></td>
</tr>
<tr>
<td>10b - 4 bit transfer</td>
<td></td>
</tr>
<tr>
<td>11b - Reserved</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>FRAMESZ</th>
<th>Frame Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>Configures the frame size in number of bits equal to (FRAMESZ + 1).</td>
<td></td>
</tr>
<tr>
<td>• The minimum frame size is 8 bits</td>
<td></td>
</tr>
<tr>
<td>• The minimum word size is 2 bits; a frame size of 33 bits (or similar) is not supported.</td>
<td></td>
</tr>
</tbody>
</table>
48.4.1.16 Transmit Data Register (TDR)

48.4.1.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TDR</td>
<td>64h</td>
</tr>
</tbody>
</table>

48.4.1.16.2 Function

 Writes to either the Transmit Command Register or Transmit Data Register will push the data into the transmit FIFO, in the order that it (the data) was written.

48.4.1.16.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

48.4.1.16.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Transmit Data</td>
</tr>
<tr>
<td>DATA</td>
<td>Both 8-bit and 16-bit writes of transmit data will zero-extend the data written and push the data into the transmit FIFO. To zero-extend 8-bit and 16-bit writes (to 32 bits), means that the higher order (most significant) empty parts of the 8-bit and 16-bit writes are filled with zeroes.</td>
</tr>
</tbody>
</table>
48.4.1.17 Receive Status Register (RSR)

48.4.1.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RSR</td>
<td>70h</td>
</tr>
</tbody>
</table>

48.4.1.17.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>RX EMPTY</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Start Of Frame</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

48.4.1.17.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1 RXEMPTY</td>
<td>RX FIFO Empty</td>
</tr>
<tr>
<td></td>
<td>0b - RX FIFO is not empty</td>
</tr>
<tr>
<td></td>
<td>1b - RX FIFO is empty</td>
</tr>
<tr>
<td>0 SOF</td>
<td>Start Of Frame</td>
</tr>
<tr>
<td></td>
<td>Indicates that this is the first data word received after LPSPI_PCS assertion.</td>
</tr>
<tr>
<td></td>
<td>0b - Subsequent data word received after LPSPI_PCS assertion</td>
</tr>
<tr>
<td></td>
<td>1b - First data word received after LPSPI_PCS assertion</td>
</tr>
</tbody>
</table>

48.4.1.18 Receive Data Register (RDR)
### 48.4.1.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>RDR</td>
<td>74h</td>
</tr>
</tbody>
</table>

### 48.4.1.18.2 Diagram

#### Bits 31-0

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### Bits 15-0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 48.4.1.18.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Receive Data</td>
</tr>
<tr>
<td>DATA</td>
<td></td>
</tr>
</tbody>
</table>
Chapter 49
Low Power Universal Asynchronous Receiver/Transmitter (LPUART)

49.1 Chip-specific LPUART information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

49.2 Introduction

49.2.1 Features

Features of the LPUART module include:
- Full-duplex, standard non-return-to-zero (NRZ) format
- Programmable baud rates (13-bit modulo divider) with configurable oversampling ratio from 4x to 32x
- Transmit and receive baud rate can operate asynchronous to the bus clock:
  - Baud rate can be configured independently of the bus clock frequency
  - Supports operation in Stop modes
• Interrupt, DMA or polled operation:
  • Transmit data register empty and transmission complete
  • Receive data register full
  • Receive overrun, parity error, framing error, and noise error
  • Idle receiver detect
  • Active edge on receive pin
  • Break detect supporting LIN
  • Receive data match
• Hardware parity generation and checking
• Programmable 7-bit, 8-bit, 9-bit or 10-bit character length
• Programmable 1-bit or 2-bit stop bits
• Three receiver wakeup methods:
  • Idle line wakeup
  • Address mark wakeup
  • Receive data match
• Automatic address matching to reduce ISR overhead:
  • Address mark matching
  • Idle line address matching
  • Address match start, address match end
• Optional 13-bit break character generation / 11-bit break character detection
• Configurable idle length detection supporting 1, 2, 4, 8, 16, 32, 64 or 128 idle characters
• Selectable transmitter output and receiver input polarity
• Hardware flow control support for request to send (RTS) and clear to send (CTS) signals
• Selectable IrDA 1.4 return-to-zero-inverted (RZI) format with programmable pulse width
• Independent FIFO structure for transmit and receive
  • Separate configurable watermark for receive and transmit requests
  • Option for receiver to assert request after a configurable number of idle characters if receive FIFO is not empty

49.2.2 Modes of operation

49.2.2.1 Stop mode

The LPUART will remain functional during Stop mode, provided the CTRL[DOZEEN] bit is clear and the asynchronous transmit and receive clock remain enabled. The LPUART can generate an interrupt or DMA request to cause a wakeup from Stop mode.
If the LPUART is disabled in Stop mode, then it can generate a wakeup via the STAT[RXEDGIF] flag if the receiver detects an active edge.

### 49.2.2.2 Wait mode

The LPUART can be configured to Stop in Wait modes, when the CTRL[DOZEEN] bit is set. The transmitter and receiver will finish transmitting/receiving the current word.

### 49.2.3 Signal Descriptions

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>TXD</td>
<td>Transmit data. This pin is normally an output, but is an input (tristated) in single wire mode whenever the transmitter is disabled or transmit direction is configured for receive data.</td>
<td>I/O</td>
</tr>
<tr>
<td>RXD</td>
<td>Receive data.</td>
<td>I</td>
</tr>
<tr>
<td>CTS_B</td>
<td>Clear to send.</td>
<td>I</td>
</tr>
<tr>
<td>RTS_B</td>
<td>Request to send.</td>
<td>O</td>
</tr>
</tbody>
</table>

### 49.2.4 Block diagram

The following figure shows the transmitter portion of the LPUART.
Figure 49-1. LPUART transmitter block diagram

The following figure shows the receiver portion of the LPUART.
49.3 Functional description

The LPUART supports full-duplex, asynchronous, NRZ serial communication and comprises a baud rate generator, transmitter, and receiver block. The transmitter and receiver operate independently, although they use the same baud rate generator. The following describes each of the blocks of the LPUART.

49.3.1 Clocking and Resets

Table 49-2. Clocks

<table>
<thead>
<tr>
<th>LPUART Functional clock</th>
<th>The LPUART functional clock is asynchronous to the bus clock and can remain enabled in low power modes to support transmit and/or receive, including low power wakeups.</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bus clock</td>
<td>The bus clock is only used for bus accesses to the control and configuration registers. The bus clock frequency must be sufficient to support the data bandwidth requirements of the LPUART transmit and receive registers, including the FIFOs.</td>
</tr>
</tbody>
</table>
Table 49-3. Resets

<table>
<thead>
<tr>
<th>resets</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip reset</td>
<td>The logic and registers for the LPUART transmitter and receiver are reset to their default state on a chip reset.</td>
</tr>
<tr>
<td>Software reset</td>
<td>Resets the LPUART logic and registers to their default state, except for the Global Register. The LPUART software reset is in the Global Register GLOBAL[RST].</td>
</tr>
<tr>
<td>FIFO reset</td>
<td>The LPUART implements write-only control bits that reset the transmit FIFO (FIFO[TXFLUSH]) and receive FIFO (FIFO[RXFLUSH]). After a FIFO is reset, that FIFO is empty.</td>
</tr>
</tbody>
</table>

49.3.2 Baud rate generation

A 13-bit modulus counter in the baud rate generator derives the baud rate for both the receiver and the transmitter. The value from 1 to 8191 written to BAUD[SBR] determines the baud clock divisor for the asynchronous LPUART baud clock. The baud rate clock drives the receiver, while the transmitter is driven by a bit clock which is generated from baud rate clock divided by the over sampling ratio. Depending on the over sampling ratio, the receiver has an acquisition rate of 4 to 32 samples per bit time.

![Diagram of LPUART baud rate generation](image)

**Figure 49-3. LPUART baud rate generation**

Baud rate generation is subject to two sources of error:

- Integer division of the asynchronous LPUART baud clock may not give the exact target frequency.
- Synchronization with the asynchronous LPUART baud clock can cause phase shift.

The baud rate generation is a free-running counter that continues whenever the transmitter or receiver is enabled. The transmitter bit clock continues whenever the transmitter is enabled, each transmitted character will align to the next edge of the transmit bit clock.
49.3.3 Transmitter functional description

This section describes the overall block diagram for the LPUART transmitter, as well as specialized functions for sending break and idle characters.

The transmitter output (TXD) idle state defaults to logic high, CTRL[TXINV] is cleared following reset. The transmitter output is inverted by setting CTRL[TXINV]. The transmitter is enabled by setting the CTRL[TE] bit. This queues a preamble character that is one full character frame of the idle state. The transmitter then remains idle until data is available in the transmit data buffer. Programs store data into the transmit data buffer by writing to the DATA register.

The central element of the LPUART transmitter is the transmit shift register that is 9-bit to 13 bits long depending on the setting in the CTRL[M], CTRL[M7], BAUD[M10] and BAUD[SBNS] control bits. For the remainder of this section, assume CTRL[M], CTRL[M7], BAUD[M10] and BAUD[SBNS] are cleared, selecting the normal 8-bit data mode. In 8-bit data mode, the shift register holds a start bit, eight data bits, and a stop bit. When the transmit shift register is available for a new character, the value waiting in the transmit data register is transferred to the shift register, synchronized with the baud rate clock, and the transmit data register empty (STAT[TDRE]) status flag is set to indicate another character may be written to the transmit data buffer at the DATA register.

If no new character is waiting in the transmit data buffer after a stop bit is shifted out the TXD pin, the transmitter sets the transmit complete flag and enters an idle mode, with TXD high, waiting for more characters to transmit.

Writing 0 to CTRL[TE] does not immediately disable the transmitter. The current transmit activity in progress must first be completed (that could include a data character, idle character or break character), although the transmitter will not start transmitting another character.

49.3.3.1 Send break and queued idle

The CTRL[SBK] bit sends break characters originally used to gain the attention of old teletype receivers. Break characters are a full character time of logic 0, 9-bit to 12-bit times including the start and stop bits. A longer break of 13-bit times can be enabled by setting STAT[BRK13]. Normally, a program would wait for STAT[TDRE] to become set to indicate the last character of a message has moved to the transmit shifter, write 1, and then write 0 to the CTRL[SBK] bit. This action queues a break character to be sent as soon as the shifter is available. If CTRL[SBK] remains 1 when the queued break moves into the shifter, synchronized to the baud rate clock, an additional break character is queued. When the LPUART is the receiving device, a break character is received as 0s in all data bits and a framing error (STAT[FE] = 1) is detected.
A break character can also be transmitted by writing to the DATA register with bit 13 set and the data bits clear. This supports transmitting the break character as part of the normal data stream and also allows the DMA to transmit a break character.

When idle-line wakeup is used, a full character time of idle (logic 1) is needed between messages to wake up any sleeping receivers. Normally, a program would wait for STAT[TDRE] to become set to indicate the last character of a message has moved to the transmit shifter, then write 0 and then write 1 to the CTRL[TE] bit. This action queues an idle character to be sent as soon as the shifter is available. As long as the character in the shifter does not finish while CTRL[TE] is cleared, the LPUART transmitter never actually releases control of the TXD pin.

An idle character can also be transmitted by writing to the DATA register with bit 13 set and the data bits also set. This supports transmitting the idle character as part of the normal data stream and also allows the DMA to transmit an idle character.

The length of the break character is affected by the STAT[BRK13], CTRL[M], CTRL[M7], BAUD[M10] and BAUD[SNBS] bits as shown below.

<table>
<thead>
<tr>
<th>BRK13</th>
<th>M</th>
<th>M10</th>
<th>M7</th>
<th>SBNS</th>
<th>Break character length</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>10 bit times</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>11 bit times</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>9 bit times</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>10 bit times</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>11 bit times</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>1</td>
<td>12 bit times</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>1</td>
<td>X</td>
<td>0</td>
<td>12 bit times</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>1</td>
<td>X</td>
<td>1</td>
<td>13 bit times</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>13 bit times</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>13 bit times</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>12 bit times</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>12 bit times</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>14 bit times</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>1</td>
<td>14 bit times</td>
</tr>
<tr>
<td>1</td>
<td>X</td>
<td>1</td>
<td>X</td>
<td>0</td>
<td>15 bit times</td>
</tr>
<tr>
<td>1</td>
<td>X</td>
<td>1</td>
<td>X</td>
<td>1</td>
<td>15 bit times</td>
</tr>
</tbody>
</table>
49.3.3.2 Hardware flow control

The transmitter supports hardware flow control by gating the transmission with the value of CTS_B. If the clear-to-send operation is enabled, the character is transmitted when CTS_B is asserted. If CTS_B is deasserted in the middle of a transmission with characters remaining in the transmitter data buffer, the character in the shift register is sent and TXD remains in the mark state until CTS_B is reasserted. The CTS_B pin must assert for longer than one bit period to guarantee a new transmission is started when the transmitter is idle with data to send.

If the clear-to-send operation is disabled, the transmitter ignores the state of CTS_B.

The transmitter's CTS_B signal can also be enabled even if the same LPUART receiver's RTS_B signal is disabled.

49.3.3.3 Transceiver driver enable

The transmitter can use RTS_B as an enable signal for the driver of an external transceiver. See Transceiver driver enable using RTS_B for details. If the request-to-send operation is enabled, when a character is placed into an empty transmitter data buffer, RTS_B asserts one bit time before the start bit is transmitted. RTS_B remains asserted for the whole time that the transmitter data buffer has any characters. RTS_B deasserts one bit time after all characters in the transmitter data buffer and shift register are completely sent, including the last stop bit. Transmitting a break character also asserts RTS_B, with the same assertion and deassertion timing as having a character in the transmitter data buffer.

The transmitter's RTS_B signal asserts only when the transmitter is enabled. However, the transmitter's RTS_B signal is unaffected by its CTS_B signal. RTS_B will remain asserted until the transfer is completed, even if the transmitter is disabled mid-way through a data transfer.

49.3.3.4 Transceiver driver enable using RTS_B

RS-485 is a multiple drop communication protocol in which the LPUART transceiver's driver is 3-stated unless the LPUART is driving. The RTS_B signal can be used by the transmitter to enable the driver of a transceiver. The polarity of RTS_B can be matched to the polarity of the transceiver's driver enable signal.
In the figure, the receiver enable signal is asserted. Another option for this connection is to connect RTS_B to both DE and RE_B. The transceiver's receiver is disabled while driving. A pullup can pull RXD to a non-floating value during this time. This option can be refined further by operating the LPUART in single wire mode, freeing the RXD pin for other uses.

### 49.3.4 Receiver functional description

In this section, the receiver block diagram is a guide for the overall receiver functional description. Next, the data sampling technique used to reconstruct receiver data is described in more detail. Finally, different variations of the receiver wakeup function are explained.

The receiver input is inverted by setting STAT[RXINV]. The receiver is enabled by setting the CTRL[RE] bit. Character frames consist of a start bit of logic 0, seven to ten data bits (msb or lsb first), and one or two stop bits of logic 1. For information about 7-bit, 9-bit or 10-bit data mode, refer to Data Modes. For the remainder of this discussion, assume the LPUART is configured for normal 8-bit data mode.

After receiving the stop bit into the receive shifter, and provided the receive data register is not already full, the data character is transferred to the receive data register and the receive data register full (STAT[RDRF]) status flag is set. If [RDRF] was already set indicating the receive data register (buffer) was already full, the overrun (OR) status flag is set and the new data is lost. Because the LPUART receiver is double-buffered, the program has one full character time after [RDRF] is set before the data in the receive data buffer must be read to avoid a receiver overrun.

When a program detects that the receive data register is full (STAT[RDRF] = 1), it gets the data from the receive data register by reading the DATA register. Refer to Interrupts and status flags for details about flag clearing.
49.3.4.1 Data sampling technique

The LPUART receiver supports a configurable oversampling rate of between 4× and 32× of the baud rate clock for sampling. The receiver starts by taking logic level samples at the oversampling rate times the baud rate to search for a falling edge on the RXD serial data input pin. A falling edge is defined as a logic 0 sample after three consecutive logic 1 samples. The oversampling baud rate clock divides the bit time into 4 to 32 segments from 1 to OSR (where OSR is the configured oversampling ratio). When a falling edge is located, three more samples are taken at (OSR/2), (OSR/2)+1, and (OSR/2)+2 to make sure this was a real start bit and not merely noise. If at least two of these three samples are 0, the receiver assumes it is synchronized to a received character. If another falling edge is detected before the receiver is considered synchronized, the receiver restarts the sampling from the first segment.

The receiver then samples each bit time, including the start and stop bits, at (OSR/2), (OSR/2)+1, and (OSR/2)+2 to determine the logic level for that bit. The logic level is interpreted to be that of the majority of the samples taken during the bit time. If any sample in any bit time, including the start and stop bits, in a character frame fails to agree with the logic level for that bit, the noise flag (STAT[NF]) is set when the received character is transferred to the receive data buffer.

When the LPUART receiver is configured to sample on both edges of the baud rate clock, the number of segments in each received bit is effectively doubled (from 1 to OSR×2). The start and data bits are then sampled at OSR, OSR+1 and OSR+2. Sampling on both edges of the clock must be enabled for oversampling rates of 4× to 7× and is optional for higher oversampling rates.

The falling edge detection logic continuously looks for falling edges. If an edge is detected, the sample clock is resynchronized to bit times (unless resynchronization has been disabled). This improves the reliability of the receiver in the presence of noise or mismatched baud rates. It does not improve worst case analysis because some characters do not have any extra falling edges anywhere in the character frame.

In the case of a framing error, provided the received character was not a break character, the sampling logic that searches for a falling edge is filled with three logic 1 samples so that a new start bit can be detected almost immediately.

49.3.4.2 Receiver wakeup operation

Receiver wakeup and receiver address matching is a hardware mechanism that allows an LPUART receiver to ignore the characters in a message intended for a different receiver.
During receiver wakeup, all receivers evaluate the first character(s) of each message, and as soon as they determine the message is intended for a different receiver, they write logic 1 to the receiver wake up control bit (CTRL[RWU]). When CTRL[RWU] and STAT[RWUID] bit are set, the status flags associated with the receiver, with the exception of the idle bit, STAT[IDLE], are inhibited from setting, thus eliminating the software overhead for handling the unimportant message characters. At the end of a message, or at the beginning of the next message, all receivers automatically force CTRL[RWU] to 0 so all receivers wake up in time to look at the first character(s) of the next message.

During receiver address matching, the address matching is performed in hardware and the LPUART receiver will ignore all characters that do not meet the address match requirements.

### Table 49-5. Receiver Wakeup Options

<table>
<thead>
<tr>
<th>RWU</th>
<th>MA1</th>
<th>MA2</th>
<th>MATCFG</th>
<th>WAKE:RWUID</th>
<th>Receiver Wakeup</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td></td>
<td>X</td>
<td>X</td>
<td>Normal operation</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td>00</td>
<td>00</td>
<td>Receiver wakeup on idle line, IDLE flag not set</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td>00</td>
<td>01</td>
<td>Receiver wakeup on idle line, IDLE flag set</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td>00</td>
<td>10</td>
<td>Receiver wakeup on address mark</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td></td>
<td>11</td>
<td>10</td>
<td>Receiver wakeup on data match</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td></td>
<td>00</td>
<td>X0</td>
<td>Address mark address match, IDLE flag set for discarded characters</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td></td>
<td>00</td>
<td>X1</td>
<td>Address mark address match, IDLE flag set for discarded characters</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td></td>
<td>01</td>
<td>X0</td>
<td>Idle line address match</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td></td>
<td>10</td>
<td>X0</td>
<td>Address match on and address match off, IDLE flag not set for discarded characters</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td></td>
<td>10</td>
<td>X1</td>
<td>Address match on and address match off, IDLE flag set for discarded characters</td>
</tr>
</tbody>
</table>
49.3.4.2.1 Idle-line wakeup

When wake is cleared, the receiver is configured for idle-line wakeup. In this mode, CTRL[RWU] is cleared automatically when the receiver detects a full character time of the idle-line level. The CTRL[M], CTRL[M7] and BAUD[M10] control bit selects 7-bit to 10-bit data mode and the BAUD[SBNS] bit selects 1-bit or 2-bit stop bit number that determines how many bit times of idle are needed to constitute a full character time, 9 to 13 bit times because of the start and stop bits.

When CTRL[RWU] is one and STAT[RWUID] is 0, the idle condition that wakes up the receiver does not set the STAT[IDLE] flag. The receiver wakes up and waits for the first data character of the next message that sets the STAT[RDRF] flag and generates an interrupt if enabled. When STAT[RWUID] is 1, any idle condition sets the STAT[IDLE] flag and generates an interrupt if enabled, regardless of whether CTRL[RWU] is 0 or 1.

The idle-line type (CTRL[ILT]) control bit selects one of two ways to detect an idle line. When CTRL[ILT] is cleared, the idle bit counter starts after the start bit so the stop bit and any logic 1s at the end of a character count toward the full character time of idle. When CTRL[ILT] is set, the idle bit counter does not start until after the stop bit time, so the idle detection is not affected by the data in the last character of the previous message.

49.3.4.2.2 Address-mark wakeup

When CTRL[WAKE] is set, the receiver is configured for address-mark wakeup. In this mode, CTRL[RWU] is cleared automatically when the receiver detects a logic 1 in the most significant bit of the received character. When parity is enabled, the second most significant bit is used for address-mark wakeup.

Address-mark wakeup allows messages to contain idle characters, but requires one bit be reserved for use in address frames. The logic 1 in the most significant bit (or second most significant bit when parity is enabled) of an address frame clears the CTRL[RWU] bit and sets the STAT[RDRF] flag. In this case, the character with the address-mark bit is received even though the receiver was sleeping during most of this character time.

49.3.4.2.3 Data match wakeup

When CTRL[RWU] is set, CTRL[WAKE] is set and BAUD[MATCFG] equals 11, the receiver is configured for data match wakeup. In this mode, CTRL[RWU] is cleared automatically when the receiver detects a character that matches MATCH[MA1] field when BAUD[MAEN1] is set, or that matches MATCH[MA2] when BAUD[MAEN2] is set.
49.3.4.2.4  Address Match operation

Address match operation is enabled when the BAUD[MAEN1] or BAUD[MAEN2] bit is set and BAUD[MATCFG] is equal to 00. In this function, a character received by the RXD pin with a logic 1 in the most significant bit (or second most significant bit when parity is enabled) is considered an address and is compared with the associated MATCH[MA1] or MATCH[MA2] field. The character is only transferred to the receive buffer, and STAT[RDRF] is set, if the comparison matches. All subsequent characters received with a logic 0 in the most significant bit (or second most significant bit when parity is enabled) are considered to be data associated with the address and are transferred to the receive data buffer. If no marked address match occurs then no transfer is made to the receive data buffer, and all following characters with logic zero in the most significant bit (or second most significant bit when parity is enabled) are also discarded. If both the BAUD[MAEN1] and BAUD[MAEN2] bits are negated, the receiver operates normally and all data received is transferred to the receive data buffer.

Address match operation functions in the same way for both MATCH[MA1] and MATCH[MA2] fields.

- If only one of BAUD[MAEN1] and BAUD[MAEN2] is asserted, a marked address is compared only with the associated match register field and data is transferred to the receive data buffer only on a match.

- If BAUD[MAEN1] and BAUD[MAEN2] are asserted, a marked address is compared with both match registers and data is transferred only on a match with either of the MATCH[MA1] or MATCH[MA2] fields.

49.3.4.2.5  Idle Match operation

Idle match operation is enabled when the BAUD[MAEN1] or BAUD[MAEN2] bit is set and BAUD[MATCFG] is equal to 01. In this function, the first character received by the RXD pin after an idle line condition is considered an address and is compared with the associated MATCH[MA1] or MATCH[MA2] field. The character is only transferred to the receive buffer, and STAT[RDRF] is set, if the comparison matches. All subsequent characters are considered to be data associated with the address and are transferred to the receive data buffer until the next idle line condition is detected. If no address match occurs then no transfer is made to the receive data buffer, and all following frames until the next idle condition are also discarded. If both the BAUD[MAEN1] and BAUD[MAEN2] bits are negated, the receiver operates normally and all data received is transferred to the receive data buffer.

Idle match operation functions in the same way for both MATCH[MA1] or MATCH[MA2] fields.
• If only one of BAUD[MAEN1] and BAUD[MAEN2] is asserted, the first character after an idle line is compared only with the associated match register and data is transferred to the receive data buffer only on a match.

• If BAUD[MAEN1] and BAUD[MAEN2] are asserted, the first character after an idle line is compared with both MATCH[MA1] or MATCH[MA2] fields and data is transferred only on a match with either of the fields.

49.3.4.2.6 Match On Match Off operation

Match on, match off operation is enabled when both BAUD[MAEN1] and BAUD[MAEN2] are set and BAUD[MATCFG] is equal to 10. In this function, a character received by the RXD pin that matches MATCH[MA1] is received and transferred to the receive buffer, and STAT[RDRF] is set. All subsequent characters are considered to be data and are also transferred to the receive data buffer, until a character is received that matches MATCH[MA2] field. The character that matches MATCH[MA2] and all following characters are discarded; this continues until another character that matches MATCH[MA1] is received. If both the BAUD[MAEN1] and BAUD[MAEN2] bits are negated, the receiver operates normally and all data received is transferred to the receive data buffer.

NOTE
Match on, match off operation requires both BAUD[MAEN1] and BAUD[MAEN2] to be asserted.

49.3.4.3 Hardware flow control

To support hardware flow control, the receiver can be programmed to automatically deassert and assert RTS_B.

• RTS_B remains asserted until the transfer is complete, even if the transmitter is disabled midway through a data transfer. See Transceiver driver enable using RTS_B for more details.
• If the receiver request-to-send functionality is enabled, the receiver automatically deasserts RTS_B if the number of characters in the receiver data register is full or a start bit is detected that will cause the receiver data register to be full.
• The receiver asserts RTS_B when the number of characters in the receiver data register is not full and has not detected a start bit that will cause the receiver data register to be full. It is not affected if STAT[RDRF] is asserted.
• Even if RTS_B is deasserted, the receiver continues to receive characters until the receiver data buffer is overrun.
• If the receiver request-to-send functionality is disabled, the receiver RTS_B remains deasserted.

### 49.3.4.4 Infrared decoder

The infrared decoder converts the received character from the IrDA format to the NRZ format used by the receiver. It also has a OSR oversampling baud rate clock counter that filters noise and indicates when a 1 is received.

#### 49.3.4.4.1 Start bit detection

When STAT[RXINV] is cleared, the first falling edge of the received character corresponds to the start bit. The infrared decoder resets its counter. At this time, the receiver also begins its start bit detection process. After the start bit is detected, the receiver synchronizes its bit times to this start bit time. For the rest of the character reception, the infrared decoder's counter and the receiver's bit time counter count independently from each other.

#### 49.3.4.4.2 Noise filtering

Any further rising edges detected during the first half of the infrared decoder counter are ignored by the decoder. Any pulses less than one oversampling baud clock can be undetected by it regardless of whether it is seen in the first or second half of the count.

#### 49.3.4.4.3 Low-bit detection

During the second half of the decoder count, a rising edge is decoded as a 0, which is sent to the receiver. The decoder counter is also reset.

#### 49.3.4.4.4 High-bit detection

At OSR oversampling baud rate clocks after the previous rising edge, if a rising edge is not seen, then the decoder sends a 1 to the receiver.

If the next bit is a 0, which arrives late, then a low-bit is detected according to Low-bit detection. The value sent to the receiver is changed from 1 to a 0. Then, if a noise pulse occurs outside the receiver's bit time sampling period, then the delay of a 0 is not recorded as noise.
49.3.5 Additional LPUART functions

The following sections describe additional LPUART functions.

49.3.5.1 Data Modes

The LPUART transmitter and receiver can be configured to operate in 7-bit data mode by setting CTRL[M7], 9-bit data mode by setting the CTRL[M] or 10-bit data mode by setting BAUD[M10]. In 9-bit mode, there is a ninth data bit and in 10-bit mode, there is a tenth data bit. For the transmit data buffer, these bits are stored in CTRL[T8] and CTRL[T9]. For the receiver, these bits are held in CTRL[R8] and CTRL[R9]. They are also accessible via 16-bit or 32-bit accesses to the DATA register.

For coherent 8-bit writes to the transmit data buffer, write to CTRL[T8] and CTRL[T9] before writing to DATA[7:0]. For 16-bit and 32-bit writes to the DATA register, all 10 transmit bits are written to the transmit data buffer at the same time.

If the bit values to be transmitted as the ninth and tenth bit of a new character are the same as for the previous character, it is not necessary to write to CTRL[T8] and CTRL[T9] again. When data is transferred from the transmit data buffer to the transmit shifter, the value in CTRL[T8] and CTRL[T9] is copied at the same time data is transferred from DATA[7:0] to the shifter.

The 9-bit data mode is typically used with parity to allow eight bits of data plus the parity in the ninth bit, or it is used with address-mark wakeup so the ninth data bit can serve as the wakeup bit. The 10-bit data mode is typically used with parity and address-mark wakeup so the ninth data bit can serve as the wakeup bit and the tenth bit as the parity bit. In custom protocols, the ninth and/or tenth bits can also serve as software-controlled markers.

49.3.5.2 Idle length

An idle character is a character where the start bit, all data bits and stop bits are in the mark position. The CTRL[ILT] bit can be configured to start detecting an idle character from the previous start bit (any data bits and stop bits count towards the idle character detection) or from the previous stop bit.
The number of idle characters that must be received before an idle line condition is detected can also be configured using the CTRL[IDLECFG] field. This field configures the number of idle characters that must be received before the STAT[IDLE] flag is set, the STAT[RAF] flag is cleared and the DATA[IDLINE] flag is set with the next received character.

Idle-line wakeup and idle match operation are also affected by the CTRL[IDLECFG] field. When address match or match on/off operation is enabled, setting the STAT[RWUID] bit will cause any discarded characters to be treated as if they were idle characters.

### 49.3.5.3 Loop mode

When CTRL[LOOPS] is set, the CTRL[RSRC] bit chooses between loop mode (CTRL[RSRC] = 0) or single-wire mode (CTRL[RSRC] = 1). Loop mode is sometimes used to check software, independent of connections in the external system, to help isolate system problems. In this mode, the transmitter output is internally connected to the receiver input and the RXD pin is not used by the LPUART.

### 49.3.5.4 Single-wire operation

When CTRL[LOOPS] is set, the CTRL[RSRC] bit chooses between loop mode (CTRL[RSRC] = 0) or single-wire mode (CTRL[RSRC] = 1). Single-wire mode implements a half-duplex serial connection. The receiver is internally connected to the transmitter output and to the TXD pin (the RXD pin is not used).

In single-wire mode, the CTRL[TXDIR] bit controls the direction of serial data on the TXD pin. When CTRL[TXDIR] is cleared, the TXD pin is an input to the receiver and the transmitter is temporarily disconnected from the TXD pin so an external device can send serial data to the receiver. When CTRL[TXDIR] is set, the TXD pin is an output driven by the transmitter, the internal loop back connection is disabled, and as a result the receiver cannot receive characters that are sent out by the transmitter.

### 49.3.6 Infrared interface

The LPUART provides the capability of transmitting narrow pulses to an IR LED and receiving narrow pulses and transforming them to serial bits, which are sent to the LPUART. The IrDA physical layer specification defines a half-duplex infrared communication link for exchanging data. The full standard includes data rates up to 16 Mbits/s. This module covers data rates only between 2.4 kbits/s and 115.2 kbits/s.
The LPUART has an infrared transmit encoder and receive decoder. The LPUART transmits serial bits of data that are encoded by the infrared submodule to transmit a narrow pulse for every zero bit. No pulse is transmitted for every one bit. When receiving data, the IR pulses are detected using an IR photo diode and transformed to CMOS levels by the IR receive decoder, external from the LPUART. The narrow pulses are then stretched by the infrared receive decoder to get back to a serial bit stream to be received by the LPUART. The polarity of transmitted pulses and expected receive pulses can be inverted so that a direct connection can be made to external IrDA transceiver modules that use active high pulses.

The infrared submodule receives its clock sources from the LPUART. One of these two clocks are selected in the infrared submodule to generate either 1/OSR, 2/OSR, 3/OSR, or 4/OSR narrow pulses during transmission.

### 49.3.6.1 Infrared transmit encoder

The infrared transmit encoder converts serial bits of data from transmit shift register to the TXD signal. A narrow pulse is transmitted for a 0 bit and no pulse for a 1 bit. The narrow pulse is sent at the start of the bit with a duration of 1/OSR, 2/OSR, 3/OSR, or 4/OSR of a bit time. A narrow low pulse is transmitted for a 0 bit when CTRL[TXINV] is cleared, while a narrow high pulse is transmitted for a 0 bit when CTRL[TXINV] is set.

### 49.3.6.2 Infrared receive decoder

The infrared receive block converts data from the RXD signal to the receive shift register. A narrow pulse is expected for each 0 received and no pulse is expected for each 1 received. A narrow low pulse is expected for a 0 bit when STAT[RXINV] is cleared, while a narrow high pulse is expected for a 0 bit when STAT[RXINV] is set. This receive decoder meets the edge jitter requirement as defined by the IrDA serial infrared physical layer specification.

### 49.3.7 Interrupts and status flags

The LPUART transmitter has two status flags that can optionally generate hardware interrupt requests. Transmit data register empty STAT[TDRE]) indicates when there is room in the transmit data buffer to write another transmit character to the DATA register. If the transmit interrupt enable CTRL[TIE]) bit is set, a hardware interrupt is requested when STAT[TDRE] is set. Transmit complete (STAT[TC]) indicates that the transmitter is finished transmitting all data, preamble, and break characters and is idle with TXD at
the inactive level. This flag is often used in systems with modems to determine when it is safe to turn off the modem. If the transmit complete interrupt enable (CTRL[TCIE]) bit is set, a hardware interrupt is requested when STAT[TC] is set. Instead of hardware interrupts, software polling may be used to monitor the STAT[TDRE] and STAT[TC] status flags if the corresponding CTRL[TIE] or CTRL[TCIE] local interrupt masks are cleared.

When a program detects that the receive data register is full (STAT[RDRF] = 1), it gets the data from the receive data register by reading the DATA register. The STAT[RDRF] flag is cleared by reading the DATA register.

The IDLE status flag includes logic that prevents it from getting set repeatedly when the RXD line remains idle for an extended period of time. IDLE is cleared by writing 1 to the STAT[IDLE] flag. After STAT[IDLE] has been cleared, it cannot become set again until the receiver has received at least one new character and has set STAT[RDRF].

If the associated error was detected in the received character that caused STAT[RDRF] to be set, the error flags - noise flag (STAT[NF]), framing error (STAT[FE]), and parity error flag (STAT[PF]) - are set at the same time as STAT[RDRF]. These flags are not set in overrun cases.

If STAT[RDRF] was already set when a new character is ready to be transferred from the receive shifter to the receive data buffer, the overrun (STAT[OR]) flag is set instead of the data along with any associated NF, FE, or PF condition is lost.

If the received character matches the contents of MATCH[MA1] and/or MATCH[MA2] then the STAT[MA1F] and/or STAT[MA2F] flags are set at the same time that STAT[RDRF] is set.

At any time, an active edge on the RXD serial data input pin causes the STAT[RXEDGIF] flag to set. The STAT[RXEDGIF] flag is cleared by writing a 1 to it. This function depends on the receiver being enabled (CTRL[RE] = 1).

### 49.3.8 Peripheral Triggers

The connection of the LPUART peripheral triggers with other peripherals are device specific.

#### 49.3.8.1 Output Triggers

The LPUART generates three output triggers that can be connected to other peripherals on the device.
• The transmit word trigger asserts at the end of each transmitted word, it negates after one bit period.
• The receive word trigger asserts at the end of each received word that is written to the receive FIFO, for one oversampling clock period.
• The receive idle trigger asserts at when the idle flag would set, for one oversampling clock period.

### 49.3.8.2 Input Trigger

The LPUART supports one peripheral input trigger, that can be configured in one of the following ways.

• The input trigger can be connected in place of the CTS_B pin input. The input trigger must assert for longer than one bit clock period when the transmitter is idle with data to send to guarantee a new transmission.
• The input trigger can modulate the transmit data output (trigger is logically ANDed with the TXD output). The input trigger is expected to be generated from a PWM source with a period that is less than the bit clock frequency.
• The input trigger can be connected in place of the RXD pin input. The input trigger is expected to be generated from a receive data source, such as analog comparator or external pin.

### 49.4 Register definition

The LPUART includes registers to control baud rate, select options, report status, and store transmit/receive data. Access to an address outside the valid memory map will generate a bus error.

**NOTE**

Writing a Read-Only (RO) register or reading a Write-Only (WO) register can cause bus errors. This module will not check if programmed values in the registers are correct; the application software must ensure that valid programmed values are being written.

### 49.4.1 LPUART register descriptions
49.4.1.1 LPUART Memory map

LPUART\textsubscript{n} base address: 4018\_4000h + (n-1)\times4000h, where n is from 1 to 8.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Version ID Register (VERID)</td>
<td>32</td>
<td>RO</td>
<td>0401_0003h</td>
</tr>
<tr>
<td>4h</td>
<td>Parameter Register (PARAM)</td>
<td>32</td>
<td>RO</td>
<td>0000_0202h</td>
</tr>
<tr>
<td>8h</td>
<td>LPUART Global Register (GLOBAL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>LPUART Pin Configuration Register (PINCFG)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>LPUART Baud Rate Register (BAUD)</td>
<td>32</td>
<td>RW</td>
<td>0F00_0004h</td>
</tr>
<tr>
<td>14h</td>
<td>LPUART Status Register (STAT)</td>
<td>32</td>
<td>RW</td>
<td>00C0_0000h</td>
</tr>
<tr>
<td>18h</td>
<td>LPUART Control Register (CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>LPUART Data Register (DATA)</td>
<td>32</td>
<td>RW</td>
<td>0000_1000h</td>
</tr>
<tr>
<td>20h</td>
<td>LPUART Match Address Register (MATCH)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>24h</td>
<td>LPUART Modem IrDA Register (MODIR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>28h</td>
<td>LPUART FIFO Register (FIFO)</td>
<td>32</td>
<td>RW</td>
<td>00C0_0011h</td>
</tr>
<tr>
<td>2Ch</td>
<td>LPUART Watermark Register (WATER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

49.4.1.2 Version ID Register (VERID)

49.4.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VERID</td>
<td>0h</td>
</tr>
</tbody>
</table>

49.4.1.2.2 Function

The Version ID register indicates the version integrated for this instance on the device and also indicates inclusion/exclusion of several optional features.
### 49.4.1.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

### 49.4.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Major Version Number</td>
</tr>
<tr>
<td>MAJOR</td>
<td>This read only field returns the major version number for the module specification.</td>
</tr>
<tr>
<td>23-16</td>
<td>Minor Version Number</td>
</tr>
<tr>
<td>MINOR</td>
<td>This read only field returns the minor version number for the module specification.</td>
</tr>
<tr>
<td>15-0</td>
<td>Feature Identification Number</td>
</tr>
<tr>
<td>FEATURE</td>
<td>This read only field returns the feature set number.</td>
</tr>
<tr>
<td></td>
<td>0000000000000001b - Standard feature set.</td>
</tr>
<tr>
<td></td>
<td>0000000000000011b - Standard feature set with MODEM/IrDA support.</td>
</tr>
</tbody>
</table>

### 49.4.1.3 Parameter Register (PARAM)

#### 49.4.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PARAM</td>
<td>4h</td>
</tr>
</tbody>
</table>

#### 49.4.1.3.2 Function

The Parameter register indicates the parameter configuration for this instance on the device.
49.4.1.3.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>RXFIFO</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>TXFIFO</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

49.4.1.3.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-8</td>
<td>Receive FIFO Size</td>
</tr>
<tr>
<td>RXFIFO</td>
<td>The number of words in the receive FIFO is $2^{RXFIFO}$.</td>
</tr>
<tr>
<td>7-0</td>
<td>Transmit FIFO Size</td>
</tr>
<tr>
<td>TXFIFO</td>
<td>The number of words in the transmit FIFO is $2^{TXFIFO}$.</td>
</tr>
</tbody>
</table>

49.4.1.4  LPUART Global Register (GLOBAL)

49.4.1.4.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>GLOBAL</td>
<td>8h</td>
</tr>
</tbody>
</table>
49.4.1.4.2 Diagram

Bits  31  30  29  28  27  26  25  24 |  23  22  21  20  19  18  17  16
R     0
W     0
Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

Bits  15  14  13  12  11  10  9  8 |  7  6  5  4  3  2  1  0
R     0
W     0
Reset 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0

49.4.1.4.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Software Reset</td>
</tr>
<tr>
<td>RST</td>
<td>Resets all internal logic and registers, except the Global Register. Remains set until cleared by software. 0b - Module is not reset. 1b - Module is reset.</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

49.4.1.5 LPUART Pin Configuration Register (PINCFG)

49.4.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PINCFG</td>
<td>Ch</td>
</tr>
</tbody>
</table>
49.4.1.5.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

49.4.1.5.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1-0</td>
<td>TRGSEL</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRGSEL</td>
<td>Trigger Select</td>
</tr>
<tr>
<td></td>
<td>Configures the input trigger usage. This field should only be changed when the transmitter and receiver are both disabled.</td>
</tr>
<tr>
<td></td>
<td>00b - Input trigger is disabled.</td>
</tr>
<tr>
<td></td>
<td>01b - Input trigger is used instead of RXD pin input.</td>
</tr>
<tr>
<td></td>
<td>10b - Input trigger is used instead of CTS_B pin input.</td>
</tr>
<tr>
<td></td>
<td>11b - Input trigger is used to modulate the TXD pin output. The TXD pin output (after TXINV configuration) is ANDed with the input trigger.</td>
</tr>
</tbody>
</table>

49.4.1.6  LPUART Baud Rate Register (BAUD)

49.4.1.6.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>BAUD</td>
<td>10h</td>
</tr>
</tbody>
</table>
49.4.1.6.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>MAEN1</td>
<td>MAEN2</td>
<td>M10</td>
<td>OS</td>
<td>R</td>
<td>TDMAE</td>
<td>RDMAE</td>
<td>RIDMAE</td>
<td>MATCFG</td>
<td>BOTHEDGE</td>
<td>RESYNCDI</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>LBKDI</td>
<td>RXEDGI</td>
<td>SBN</td>
<td>SB</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

49.4.1.6.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31 MAEN1 | Match Address Mode Enable 1
| 0b - Normal operation.
| 1b - Enables automatic address matching or data matching mode for MATCH[MA1]. |
| 30 MAEN2 | Match Address Mode Enable 2
| 0b - Normal operation.
| 1b - Enables automatic address matching or data matching mode for MATCH[MA2]. |
| 29 M10 | 10-bit Mode select
| The M10 bit causes a tenth bit to be part of the serial transmission. This bit should only be changed when the transmitter and receiver are both disabled.
| 0b - Receiver and transmitter use 7-bit to 9-bit data characters.
| 1b - Receiver and transmitter use 10-bit data characters. |
| 28-24 OSR | Oversampling Ratio
| This field configures the oversampling ratio for the receiver. This field should only be changed when the transmitter and receiver are both disabled.
| 00000b - Writing 0 to this field will result in an oversampling ratio of 16
| 00001b - Reserved
| 00010b - Reserved
| 00011b - Oversampling ratio of 4, requires BOTHEDGE to be set.
| 00100b - Oversampling ratio of 5, requires BOTHEDGE to be set.
| 00101b - Oversampling ratio of 6, requires BOTHEDGE to be set.
| 00110b - Oversampling ratio of 7, requires BOTHEDGE to be set.
| 00111b - Oversampling ratio of 8.
| 01000b - Oversampling ratio of 9.
| 01001b - Oversampling ratio of 10.
| 01010b - Oversampling ratio of 11.
| 01011b - Oversampling ratio of 12.
| 01100b - Oversampling ratio of 13.
| 01101b - Oversampling ratio of 14.
| 01110b - Oversampling ratio of 15.
| 01111b - Oversampling ratio of 16.
| 10000b - Oversampling ratio of 17. |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>10001b</td>
<td>Oversampling ratio of 18.</td>
</tr>
<tr>
<td>10010b</td>
<td>Oversampling ratio of 19.</td>
</tr>
<tr>
<td>10011b</td>
<td>Oversampling ratio of 20.</td>
</tr>
<tr>
<td>10100b</td>
<td>Oversampling ratio of 21.</td>
</tr>
<tr>
<td>10101b</td>
<td>Oversampling ratio of 22.</td>
</tr>
<tr>
<td>10110b</td>
<td>Oversampling ratio of 23.</td>
</tr>
<tr>
<td>10111b</td>
<td>Oversampling ratio of 24.</td>
</tr>
<tr>
<td>11000b</td>
<td>Oversampling ratio of 25.</td>
</tr>
<tr>
<td>11001b</td>
<td>Oversampling ratio of 26.</td>
</tr>
<tr>
<td>11010b</td>
<td>Oversampling ratio of 27.</td>
</tr>
<tr>
<td>11011b</td>
<td>Oversampling ratio of 28.</td>
</tr>
<tr>
<td>11100b</td>
<td>Oversampling ratio of 29.</td>
</tr>
<tr>
<td>11101b</td>
<td>Oversampling ratio of 30.</td>
</tr>
<tr>
<td>11110b</td>
<td>Oversampling ratio of 31.</td>
</tr>
<tr>
<td>11111b</td>
<td>Oversampling ratio of 32.</td>
</tr>
</tbody>
</table>

**23**

<table>
<thead>
<tr>
<th>TDMAE</th>
<th>Transmitter DMA Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>DMA request disabled.</td>
</tr>
<tr>
<td>1b</td>
<td>DMA request enabled.</td>
</tr>
</tbody>
</table>

**22**

| Reserved |

**21**

<table>
<thead>
<tr>
<th>RDMAE</th>
<th>Receiver Full DMA Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>DMA request disabled.</td>
</tr>
<tr>
<td>1b</td>
<td>DMA request enabled.</td>
</tr>
</tbody>
</table>

**20**

<table>
<thead>
<tr>
<th>RIDMAE</th>
<th>Receiver Idle DMA Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>DMA request disabled.</td>
</tr>
<tr>
<td>1b</td>
<td>DMA request enabled.</td>
</tr>
</tbody>
</table>

**19-18**

<table>
<thead>
<tr>
<th>MATCFG</th>
<th>Match Configuration</th>
</tr>
</thead>
<tbody>
<tr>
<td>00b</td>
<td>Address Match Wakeup</td>
</tr>
<tr>
<td>01b</td>
<td>Idle Match Wakeup</td>
</tr>
<tr>
<td>10b</td>
<td>Match On and Match Off</td>
</tr>
<tr>
<td>11b</td>
<td>Enables RWU on Data Match and Match On/Off for transmitter CTS input</td>
</tr>
</tbody>
</table>

**17**

<table>
<thead>
<tr>
<th>BOTHEDGE</th>
<th>Both Edge Sampling</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>Receiver samples input data using the rising edge of the baud rate clock.</td>
</tr>
<tr>
<td>1b</td>
<td>Receiver samples input data using the rising and falling edge of the baud rate clock.</td>
</tr>
</tbody>
</table>

**16**

<table>
<thead>
<tr>
<th>RESYNCDIS</th>
<th>Resynchronization Disable</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>Resynchronization during received data word is supported</td>
</tr>
<tr>
<td>1b</td>
<td>Resynchronization during received data word is disabled</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>LIN Break Detect Interrupt Enable</td>
</tr>
<tr>
<td>LBK DIE</td>
<td>LBK DIE enables the LIN break detect flag, STAT[LBKDIF], to generate interrupt requests.</td>
</tr>
<tr>
<td>0b - Hardware interrupts from STAT[LBKDIF] flag are disabled (use polling).</td>
<td></td>
</tr>
<tr>
<td>1b - Hardware interrupt requested when STAT[LBKDIF] flag is 1.</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>RX Input Active Edge Interrupt Enable</td>
</tr>
<tr>
<td>RXEDGIE</td>
<td>Enables the receive input active edge, STAT[RXEDGIF], to generate interrupt requests. Changing CTRL[LOOP] or CTRL[RSRC] when RXEDGIE is set can cause the STAT[RXEDGIF] flag to set.</td>
</tr>
<tr>
<td>0b - Hardware interrupts from STAT[RXEDGIF] are disabled.</td>
<td></td>
</tr>
<tr>
<td>1b - Hardware interrupt is requested when STAT[RXEDGIF] flag is 1.</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>Stop Bit Number Select</td>
</tr>
<tr>
<td>SBNS</td>
<td>SBNS determines whether data characters have one or two stop bits. This bit should only be changed when the transmitter and receiver are both disabled.</td>
</tr>
<tr>
<td>0b - One stop bit.</td>
<td></td>
</tr>
<tr>
<td>1b - Two stop bits.</td>
<td></td>
</tr>
<tr>
<td>12-0</td>
<td>Baud Rate Modulo Divisor.</td>
</tr>
<tr>
<td>SBR</td>
<td>The 13 bits in SBR[12:0] set the modulo divide rate for the baud rate generator. When SBR is 1 - 8191, the baud rate equals “baud clock / ((OSR+1) × SBR)”. The 13-bit baud rate setting [SBR12:SBR0] must be updated only when the transmitter and receiver are both disabled (CTRL[RE] and CTRL[TE] are both 0).</td>
</tr>
</tbody>
</table>

### 49.4.1.7 LPUART Status Register (STAT)

#### 49.4.1.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>STAT</td>
<td>14h</td>
</tr>
</tbody>
</table>
### 49.4.1.7.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>LBKDIF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W1C</td>
<td>W1C</td>
<td>MSF</td>
<td>RXINV</td>
<td>RWUID</td>
<td>BRK13</td>
<td>LBKDE</td>
<td>RAF</td>
<td>TDR</td>
<td>E</td>
<td>TC</td>
<td>RDR</td>
<td>F</td>
<td>IDL</td>
<td>E</td>
<td>OR</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>MA1F</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W1C</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 49.4.1.7.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 31    | LIN Break Detect Interrupt Flag | LBKDIF is set when the LIN break detect circuitry is enabled and a LIN break character is detected. LBKDIF is cleared by writing a 1 to it.  
0b - No LIN break character has been detected.  
1b - LIN break character has been detected. |
| 30    | RXD Pin Active Edge Interrupt Flag | RXEDGIF is set whenever the receiver is enabled and an active edge, falling if RXINV = 0, rising if RXINV=1, on the RXD pin occurs. RXEDGIF is cleared by writing a 1 to it.  
0b - No active edge on the receive pin has occurred.  
1b - An active edge on the receive pin has occurred. |
| 29    | MSB First | Setting this bit reverses the order of the bits that are transmitted and received on the wire. This bit does not affect the polarity of the bits, the location of the parity bit or the location of the start or stop bits. This bit should only be changed when the transmitter and receiver are both disabled.  
0b - LSB (bit0) is the first bit that is transmitted following the start bit. Further, the first bit received after the start bit is identified as bit0.  
1b - MSB (bit9, bit8, bit7 or bit6) is the first bit that is transmitted following the start bit depending on the setting of CTRL[M], CTRL[PE] and BAUD[M10]. Further, the first bit received after the start bit is identified as bit9, bit8, bit7 or bit6 depending on the setting of CTRL[M] and CTRL[PE]. |
| 28    | Receive Data Inversion | Setting this bit reverses the polarity of the received data input. This bit should only be changed when the receiver is disabled.  
**NOTE:** Setting RXINV inverts the RXD input for all cases: data bits, start and stop bits, break, and idle.  
0b - Receive data not inverted.  
1b - Receive data inverted. |
| 27    | Receive Wake Up Idle Detect | |

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| RWUID | For RWU on idle character, RWUID controls whether the idle character that wakes up the receiver sets the IDLE bit. For address match wakeup, RWUID controls if the IDLE bit is set when the address does not match. This bit should only be changed when the receiver is disabled.  
0b - During receive standby state (RWU = 1), the IDLE bit does not get set upon detection of an idle character. During address match wakeup, the IDLE bit does not set when an address does not match.  
1b - During receive standby state (RWU = 1), the IDLE bit gets set upon detection of an idle character. During address match wakeup, the IDLE bit does set when an address does not match. |

| 26 | Break Character Generation Length |
| BRK13 | BRK13 selects a longer transmitted break character length. Detection of a framing error is not affected by the state of this bit. This bit can be set by writing the transmit FIFO with DATA[FRETSC] set and DATA[R9T9] clear.  
0b - Break character is transmitted with length of 9 to 13 bit times.  
1b - Break character is transmitted with length of 12 to 15 bit times. |

| 25 | LIN Break Detection Enable |
| LBKDE | LBKDE selects a longer break character detection length. While LBKDE is set, receive data is not stored in the receive data buffer.  
0b - LIN break detect is disabled, normal break character can be detected.  
1b - LIN break detect is enabled. LIN break character is detected at length of 11 bit times (if M = 0) or 12 (if M = 1) or 13 (M10 = 1). |

| 24 | Receiver Active Flag |
| RAF | RAF is set when the receiver detects the beginning of a valid start bit, and RAF is cleared automatically when the receiver detects an idle line.  
0b - LPUART receiver idle waiting for a start bit.  
1b - LPUART receiver active (RXD input not idle). |

| 23 | Transmit Data Register Empty Flag |
| TDRE | When the transmit FIFO is enabled, TDRE will set when the number of datawords in the transmit FIFO (DATA register) is equal to or less than the number indicated by WATER[TXWATER]). To clear TDRE, write to the DATA register until the number of words in the transmit FIFO is greater than the number indicated by WATER[TXWATER]. When the transmit FIFO is disabled, TDRE will set when the transmit DATA register is empty. To clear TDRE, write to the DATA register.  
TDRE is not affected by a character that is in the process of being transmitted; it is updated at the start of each transmitted character.  
0b - Transmit data buffer full.  
1b - Transmit data buffer empty. |

| 22 | Transmission Complete Flag |
| TC | TC is cleared when there is a transmission in progress or when a preamble or break character is loaded. TC is set when the transmit buffer is empty and no data, preamble, or break character is being transmitted. When TC is set, the transmit data output signal becomes idle (logic 1). TC is cleared by writing to the DATA register to transmit new data, queuing a preamble by clearing and then setting CTRL[TE], queuing a break character by writing 1 to CTRL[SBK].  
0b - Transmitter active (sending data, a preamble, or a break).  
1b - Transmitter idle (transmission activity complete). |

| 21 | Receive Data Register Full Flag |
| RDRF | When the receive FIFO is enabled, RDRF is set when the number of datawords in the receive buffer is greater than the number indicated by WATER[RXWATER]. To clear RDRF, read the DATA register until the number of datawords in the receive data buffer is equal to or less than the number indicated by WATER[RXWATER]. When the receive FIFO is disabled, RDRF is set when the receive buffer (the DATA register) is full. To clear RDRF, read the DATA register.  
Table continues on the next page...
A character that is in the process of being received does not cause a change in RDRF until the entire character is received. Even if RDRF is set, the character will continue to be received until an overrun condition occurs once the entire character is received.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>Receive data buffer empty.</td>
</tr>
<tr>
<td>1b</td>
<td>Receive data buffer full.</td>
</tr>
</tbody>
</table>

**IDLE**

IDLE is set when the LPUART receive line becomes idle for a full character time after a period of activity. When CTRL[ILT] is cleared, the receiver starts counting idle bit times after the start bit. If the receive character is all 1s, these bit times and the stop bits time count toward the full character time of logic high, 10 to 13 bit times, needed for the receiver to detect an idle line. When CTRL[ILT] is set, the receiver doesn't start counting idle bit times until after the stop bits. The stop bits and any logic high bit times at the end of the previous character do not count toward the full character time of logic high needed for the receiver to detect an idle line.

To clear IDLE, write logic 1 to the IDLE flag. After IDLE has been cleared, it cannot be set again until after a new character has been stored in the receive buffer or a LIN break character has set the LBKDIF flag. IDLE is set only once even if the receive line remains idle for an extended period.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>No idle line detected.</td>
</tr>
<tr>
<td>1b</td>
<td>Idle line was detected.</td>
</tr>
</tbody>
</table>

**OR**

OR is set when software fails to prevent the receive data register from overflowing with data. The OR bit is set immediately after the stop bit has been completely received for the dataword that overflows the buffer and all the other error flags (FE, NF, and PF) are prevented from setting. The data in the shift register is lost, but the data already in the LPUART data registers is not affected. If LBKDE is enabled and a LIN Break is detected, the OR field asserts if LBKDIF is not cleared before the next data character is received.

While the OR flag is set, no additional data is stored in the data buffer even if sufficient room exists. To clear OR, write logic 1 to the OR flag.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>No overrun.</td>
</tr>
<tr>
<td>1b</td>
<td>Receive overrun (new LPUART data lost).</td>
</tr>
</tbody>
</table>

**NF**

The advanced sampling technique used in the receiver takes three samples in each of the received bits. If any of these samples disagrees with the rest of the samples within any bit time in the frame then noise is detected for that character. NF is set whenever the next character to be read from the DATA register was received with noise detected within the character. To clear NF, write logic 1 to the NF field.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>No noise detected.</td>
</tr>
<tr>
<td>1b</td>
<td>Noise detected in the received character in the DATA register.</td>
</tr>
</tbody>
</table>

**FE**

FE is set whenever the next character to be read from the DATA register was received with logic 0 detected where a stop bit was expected. To clear FE, write logic 1 to the FE field.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>No framing error detected. This does not guarantee the framing is correct.</td>
</tr>
<tr>
<td>1b</td>
<td>Framing error.</td>
</tr>
</tbody>
</table>

**PF**

PF is set whenever the next character to be read from the DATA register was received when parity is enabled (PE = 1) and the parity bit in the received character does not agree with the expected parity value. To clear PF, write a logic 1 to the PF field.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>No parity error.</td>
</tr>
<tr>
<td>1b</td>
<td>Parity error.</td>
</tr>
</tbody>
</table>

**MA1F**

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>14</td>
<td>MA2F</td>
</tr>
<tr>
<td></td>
<td>Match 2 Flag</td>
</tr>
<tr>
<td></td>
<td>MA2F is set whenever the next character to be read from the DATA register matches MA2. To clear MA2F, write a logic 1 to the MA2F field.</td>
</tr>
<tr>
<td></td>
<td>0b - Received data is not equal to MA2</td>
</tr>
<tr>
<td></td>
<td>1b - Received data is equal to MA2</td>
</tr>
<tr>
<td>13-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 49.4.1.8 LPUART Control Register (CTRL)

#### 49.4.1.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL</td>
<td>18h</td>
</tr>
</tbody>
</table>

#### 49.4.1.8.2 Function

This read/write register controls various optional features of the LPUART system. This register should only be altered when the transmitter and receiver are both disabled.

#### 49.4.1.8.3 Diagram

```plaintext

```

```

```

```

```markdown

```
## 49.4.1.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Receive Bit 8 / Transmit Bit 9</td>
</tr>
<tr>
<td>R8T9</td>
<td>R8 is the ninth data bit received when the LPUART is configured for 9-bit or 10-bit data formats. When reading 9-bit or 10-bit data, read R8 before reading the DATA register. T9 is the tenth data bit transmitted when the LPUART is configured for 10-bit data formats. When writing 10-bit data, write T9 before writing the DATA register. If T9 does not need to change from its previous value, such as when it is used to generate address mark or parity, it need not be written each time the DATA register is written. <strong>NOTE:</strong> R8 is a read-only bit and T9 is a write-only bit, the value read is different from the value written.</td>
</tr>
<tr>
<td>30</td>
<td>Receive Bit 9 / Transmit Bit 8</td>
</tr>
<tr>
<td>R9T8</td>
<td>R9 is the tenth data bit received when the LPUART is configured for 10-bit data formats. When reading 10-bit data, read R9 before reading the DATA register  T8 is the ninth data bit transmitted when the LPUART is configured for 9-bit or 10-bit data formats. When writing 9-bit or 10-bit data, write T8 before writing the DATA register. If T8 does not need to change from its previous value, such as when it is used to generate address mark or parity, then it need not be written each time the DATA register is written. <strong>NOTE:</strong> R9 is a read-only bit and T8 is a write-only bit, the value read is different from the value written.</td>
</tr>
<tr>
<td>29</td>
<td>TXD Pin Direction in Single-Wire Mode</td>
</tr>
<tr>
<td>TXDIR</td>
<td>When the LPUART is configured for single-wire half-duplex operation (LOOPS = RSRC = 1), this bit determines the direction of data at the TXD pin. When clearing TXDIR, the transmitter will finish receiving the current character (if any) before the receiver starts receiving data from the TXD pin. 0b - TXD pin is an input in single-wire mode. 1b - TXD pin is an output in single-wire mode.</td>
</tr>
<tr>
<td>28</td>
<td>Transmit Data Inversion</td>
</tr>
<tr>
<td>TXINV</td>
<td>Setting this bit reverses the polarity of the transmitted data output. <strong>NOTE:</strong> Setting TXINV inverts the TXD output for all cases: data bits, start and stop bits, break, and idle. 0b - Transmit data not inverted. 1b - Transmit data inverted.</td>
</tr>
<tr>
<td>27</td>
<td>Overrun Interrupt Enable</td>
</tr>
<tr>
<td>ORIE</td>
<td>This bit enables the overrun flag (OR) to generate hardware interrupt requests. 0b - OR interrupts disabled; use polling. 1b - Hardware interrupt requested when OR is set.</td>
</tr>
<tr>
<td>26</td>
<td>Noise Error Interrupt Enable</td>
</tr>
<tr>
<td>NEIE</td>
<td>This bit enables the noise flag (NF) to generate hardware interrupt requests. 0b - NF interrupts disabled; use polling. 1b - Hardware interrupt requested when NF is set.</td>
</tr>
<tr>
<td>25</td>
<td>Framing Error Interrupt Enable</td>
</tr>
<tr>
<td>FEIE</td>
<td>This bit enables the framing error flag (FE) to generate hardware interrupt requests. 0b - FE interrupts disabled; use polling. 1b - Hardware interrupt requested when FE is set.</td>
</tr>
<tr>
<td>24</td>
<td>Parity Error Interrupt Enable</td>
</tr>
<tr>
<td>PEIE</td>
<td>This bit enables the parity error flag (PF) to generate hardware interrupt requests. 0b - PF interrupts disabled; use polling. 1b - Hardware interrupt requested when PF is set.</td>
</tr>
<tr>
<td>23</td>
<td>Transmit Interrupt Enable</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field | Function
--- | ---
TIE | Enables STAT[TDRE] to generate interrupt requests.  
   0b - Hardware interrupts from TDRE disabled; use polling.  
   1b - Hardware interrupt requested when TDRE flag is 1.  

| 22 | Transmission Complete Interrupt Enable for  
TCIE | TCIE enables the transmission complete flag, TC, to generate interrupt requests.  
   0b - Hardware interrupts from TC disabled; use polling.  
   1b - Hardware interrupt requested when TC flag is 1.  

| 21 | Receiver Interrupt Enable  
RIE | Enables STAT[RDRF] to generate interrupt requests.  
   0b - Hardware interrupts from RDRF disabled; use polling.  
   1b - Hardware interrupt requested when RDRF flag is 1.  

| 20 | Idle Line Interrupt Enable  
ILIE | ILIE enables the idle line flag, STAT[IDLE], to generate interrupt requests.  
   0b - Hardware interrupts from IDLE disabled; use polling.  
   1b - Hardware interrupt requested when IDLE flag is 1.  

| 19 | Transmitter Enable  
TE | Enables the LPUART transmitter. TE can also be used to queue an idle preamble by clearing and then setting TE. When TE is cleared, this register bit will read as 1 until the transmitter has completed the current character and the TXD pin is tristated.  
   A single idle character can also be queued by writing to the transmit FIFO with DATA[FRETSC] set and DATA[R9T9] set.  
   0b - Transmitter disabled.  
   1b - Transmitter enabled.  

| 18 | Receiver Enable  
RE | Enables the LPUART receiver. When RE is written to 0, this register bit will read as 1 until the receiver finishes receiving the current character (if any).  
   0b - Receiver disabled.  
   1b - Receiver enabled.  

| 17 | Receiver Wakeup Control  
RWU | This field can be set to place the LPUART receiver in a standby state. RWU automatically clears when an RWU event occurs, that is, an IDLE event when CTRL[WAKE] is clear or an address match when CTRL[WAKE] is set with STAT[RWUID] is clear.  
   **NOTE:** RWU must be set only with CTRL[WAKE] = 0 (wakeup on idle) if the channel is currently not idle. This can be determined by STAT[RAF]. If the flag is set to wake up an IDLE event and the channel is already idle, it is possible that the LPUART will discard data. This is because the data must be received or a LIN break detected after an IDLE is detected before IDLE is allowed to be reasserted.  
   0b - Normal receiver operation.  
   1b - LPUART receiver in standby waiting for wakeup condition.  

| 16 | Send Break  
SBK | Writing a 1 and then a 0 to SBK queues a break character in the transmit data stream. Additional break characters of 9 to 13 bits, or 12 to 15 bits if STAT[BRK13] is set, bit times of logic 0 are queued as long as SBK is set. Depending on the timing of the set and clear of SBK relative to the character currently being transmitted, a second break character may be queued before software clears SBK.  
   A single break character can also be queued by writing to the transmit FIFO with DATA[FRETSC] set and DATA[R9T9] clear.  
   0b - Normal transmitter operation.  
   1b - Queue break character(s) to be sent.  

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15 MA1IE | Match 1 Interrupt Enable  
0b - MA1F interrupt disabled  
1b - MA1F interrupt enabled |
| 14 MA2IE | Match 2 Interrupt Enable  
0b - MA2F interrupt disabled  
1b - MA2F interrupt enabled |
| 13-12 | Reserved |
| 11 M7 | 7-Bit Mode Select  
This bit should only be changed when the transmitter and receiver are both disabled.  
0b - Receiver and transmitter use 8-bit to 10-bit data characters.  
1b - Receiver and transmitter use 7-bit data characters. |
| 10-8 IDLECFG | Idle Configuration  
Configures the number of idle characters that must be received before the IDLE flag is set.  
000b - 1 idle character  
001b - 2 idle characters  
010b - 4 idle characters  
011b - 8 idle characters  
100b - 16 idle characters  
101b - 32 idle characters  
110b - 64 idle characters  
111b - 128 idle characters |
| 7 LOOPS | Loop Mode Select  
When LOOPS is set, the RXD pin is disconnected from the LPUART and the transmitter output is internally connected to the receiver input. The transmitter and the receiver must be enabled to use the loop function.  
0b - Normal operation - RXD and TXD use separate pins.  
1b - Loop mode or single-wire mode where transmitter outputs are internally connected to receiver input (see RSRC bit). |
| 6 DOZEEN | Doze Enable  
0b - LPUART is enabled in Doze mode.  
1b - LPUART is disabled in Doze mode. |
| 5 RSRC | Receiver Source Select  
This field has no meaning or effect unless the LOOPS field is set. When LOOPS is set, the RSRC field determines the source for the receiver shift register input.  
0b - Provided LOOPS is set, RSRC is cleared, selects internal loop back mode and the LPUART does not use the RXD pin.  
1b - Single-wire LPUART mode where the TXD pin is connected to the transmitter output and receiver input. |
| 4 M | 9-Bit or 8-Bit Mode Select  
0b - Receiver and transmitter use 8-bit data characters.  
1b - Receiver and transmitter use 9-bit data characters. |
| 3 WAKE | Receiver Wakeup Method Select  
Determines which condition wakes the LPUART when RWU=1:  
- Address mark in the bit preceding the stop bit (or bit preceding the parity bit when parity is enabled) of the received data character, or  
- An idle condition on the receive pin input signal.  
0b - Configures RWU for idle-line wakeup.  
1b - Configures RWU with address-mark wakeup. |

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>Idle Line Type Select</td>
</tr>
<tr>
<td>ILT</td>
<td>Determines when the receiver starts counting logic 1s as idle character bits. The count begins either after a valid start bit or after the stop bit. If the count begins after the start bit, then a string of logic 1s preceding the stop bit can cause false recognition of an idle character. Beginning the count after the stop bit avoids false idle character recognition, but requires properly synchronized transmissions.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> In case the LPUART is programmed with ILT = 1, a logic 0 is automatically shifted after a received stop bit, therefore resetting the idle count.</td>
</tr>
<tr>
<td></td>
<td>0b - Idle character bit count starts after start bit.</td>
</tr>
<tr>
<td></td>
<td>1b - Idle character bit count starts after stop bit.</td>
</tr>
<tr>
<td>1</td>
<td>Parity Enable</td>
</tr>
<tr>
<td>PE</td>
<td>Enables hardware parity generation and checking. When parity is enabled, the bit immediately before the stop bit is treated as the parity bit.</td>
</tr>
<tr>
<td></td>
<td>0b - No hardware parity generation or checking.</td>
</tr>
<tr>
<td></td>
<td>1b - Parity enabled.</td>
</tr>
<tr>
<td>0</td>
<td>Parity Type</td>
</tr>
<tr>
<td>PT</td>
<td>Provided parity is enabled (PE = 1), this bit selects even or odd parity. Odd parity means the total number of 1s in the data character, including the parity bit, is odd. Even parity means the total number of 1s in the data character, including the parity bit, is even.</td>
</tr>
<tr>
<td></td>
<td>0b - Even parity.</td>
</tr>
<tr>
<td></td>
<td>1b - Odd parity.</td>
</tr>
</tbody>
</table>

### 49.4.1.9 LPUART Data Register (DATA)

#### 49.4.1.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATA</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

#### 49.4.1.9.2 Function

**NOTE**

This register is two separate registers. Reads return the contents of the read-only receive data buffer and writes go to the write-only transmit data buffer.

Reads and writes of this register are also involved in the automatic flag clearing mechanisms for some of the LPUART status flags.
### 49.4.1.9.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>NOISY</td>
<td>PARITYE</td>
<td>FRETSC</td>
<td>IDLINE</td>
<td>0</td>
<td>R9T9</td>
<td>R8T8</td>
<td>R7T7</td>
<td>R6T6</td>
<td>R5T5</td>
<td>R4T4</td>
<td>R3T3</td>
<td>R2T2</td>
<td>R1T1</td>
<td>R0T0</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 49.4.1.9.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15</td>
<td>NOISY</td>
</tr>
</tbody>
</table>
| NOISY | The current received dataword contained in DATA[R9:R0] was received with noise.  
       | 0b - The dataword was received without noise.  
       | 1b - The dataword was received with noise. |
| 14    | PARITYE  |
| PARITYE | The current received dataword contained in DATA[R9:R0] was received with a parity error.  
       | 0b - The dataword was received without a parity error.  
       | 1b - The dataword was received with a parity error. |
| 13    | FRETSC   |
| FRETSC | Frame Error / Transmit Special Character  
       | For reads, indicates the current received dataword contained in DATA[R9:R0] was received with a frame error.  
       | For writes, indicates a break or idle character is to be transmitted instead of the contents in DATA[T9:T0]. T9 is used to indicate a break character when 0 and a idle character when 1, the contents of DATA[T8:T0] should be zero.  
       | 0b - The dataword was received without a frame error on read, or transmit a normal character on write.  
       | 1b - The dataword was received with a frame error, or transmit an idle or break character on transmit. |
| 12    | RXEMPT   |
| RXEMPT | Receive Buffer Empty  
       | Asserts when there is no data in the receive buffer. This field does not take into account data that is in the receive shift register.  
       | 0b - Receive buffer contains valid data.  
       | 1b - Receive buffer is empty, data returned on read is not valid. |
| 11    | IDLINE   |
| IDLINE | Idle Line  
       | Indicates the receiver line was idle before receiving the character in DATA[9:0]. Unlike the IDLE flag, this bit can set for the first character received when the receiver is first enabled.  
       | 0b - Receiver was not idle before receiving this character.  
       | 1b - Receiver was idle before receiving this character. |

*Table continues on the next page...*
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9</td>
<td>R9T9</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 9 or write transmit data buffer 9.</td>
</tr>
<tr>
<td>8</td>
<td>R8T8</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 8 or write transmit data buffer 8.</td>
</tr>
<tr>
<td>7</td>
<td>R7T7</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 7 or write transmit data buffer 7.</td>
</tr>
<tr>
<td>6</td>
<td>R6T6</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 6 or write transmit data buffer 6.</td>
</tr>
<tr>
<td>5</td>
<td>R5T5</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 5 or write transmit data buffer 5.</td>
</tr>
<tr>
<td>4</td>
<td>R4T4</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 4 or write transmit data buffer 4.</td>
</tr>
<tr>
<td>3</td>
<td>R3T3</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 3 or write transmit data buffer 3.</td>
</tr>
<tr>
<td>2</td>
<td>R2T2</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 2 or write transmit data buffer 2.</td>
</tr>
<tr>
<td>1</td>
<td>R1T1</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 1 or write transmit data buffer 1.</td>
</tr>
<tr>
<td>0</td>
<td>R0T0</td>
</tr>
<tr>
<td></td>
<td>Read receive data buffer 0 or write transmit data buffer 0.</td>
</tr>
</tbody>
</table>

#### 49.4.1.10 LPUART Match Address Register (MATCH)

#### 49.4.1.10.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MATCH</td>
<td>20h</td>
</tr>
</tbody>
</table>
49.4.1.10.2  Diagram

```
Bits  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16
R     0
W     MA2
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Bits  15  14  13  12  11  10  9  8  7  6  5  4  3  2  1  0
R     0
W     MA1
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

49.4.1.10.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-26</td>
<td>Reserved</td>
</tr>
<tr>
<td>25-16</td>
<td>Match Address 2</td>
</tr>
<tr>
<td>25-16</td>
<td>The MA1 and MA2 fields are compared to input data addresses when the most significant bit is set and the associated BAUD[MAEN] bit is set. If a match occurs, the following data is transferred to the DATA register. If a match fails, the following data is discarded. Software should only write a MAx field when the associated BAUD[MAEN] bit is clear.</td>
</tr>
<tr>
<td>15-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9-0</td>
<td>Match Address 1</td>
</tr>
<tr>
<td>9-0</td>
<td>The MA1 and MA2 fields are compared to input data addresses when the most significant bit is set and the associated BAUD[MAEN] bit is set. If a match occurs, the following data is transferred to the DATA register. If a match fails, the following data is discarded. Software should only write a MAx field when the associated BAUD[MAEN] bit is clear.</td>
</tr>
</tbody>
</table>

49.4.1.11  LPUART Modem IrDA Register (MODIR)

49.4.1.11.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MODIR</td>
<td>24h</td>
</tr>
</tbody>
</table>

49.4.1.11.2  Function

The MODEM register controls options for setting the modem configuration.
49.4.11.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>IRE N</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

49.4.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-19</td>
<td>Reserved</td>
</tr>
<tr>
<td>18</td>
<td>Infrared enable</td>
</tr>
<tr>
<td>IREN</td>
<td>Enables/disables the infrared modulation/demodulation. This bit should only be changed when</td>
</tr>
<tr>
<td></td>
<td>the transmitter and receiver are both disabled.</td>
</tr>
<tr>
<td></td>
<td>0b - IR disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - IR enabled</td>
</tr>
<tr>
<td>17-16</td>
<td>Transmitter narrow pulse</td>
</tr>
<tr>
<td>TNP</td>
<td>Configures whether the LPUART transmits a 1/OSR, 2/OSR, 3/OSR or 4/OSR narrow pulse when IR</td>
</tr>
<tr>
<td></td>
<td>is enabled. This bit should only be changed when the transmitter and receiver are both</td>
</tr>
<tr>
<td></td>
<td>disabled.</td>
</tr>
<tr>
<td></td>
<td>The IR pulse width should be configured to less than half of the oversampling ratio. Common</td>
</tr>
<tr>
<td></td>
<td>pulse widths are 3/16, 1/16, 1/32 or 1/4 of the bit length. These can be configured by</td>
</tr>
<tr>
<td></td>
<td>selecting the appropriate oversample ratio and pulse width.</td>
</tr>
<tr>
<td></td>
<td>00b - 1/OSR.</td>
</tr>
<tr>
<td></td>
<td>01b - 2/OSR.</td>
</tr>
<tr>
<td></td>
<td>10b - 3/OSR.</td>
</tr>
<tr>
<td></td>
<td>11b - 4/OSR.</td>
</tr>
<tr>
<td>15-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>9-8</td>
<td>Receive RTS Configuration</td>
</tr>
<tr>
<td>RSWATER</td>
<td>Configures the assertion and negation of the RX RTS_B output. The RX RTS_B output negates</td>
</tr>
<tr>
<td></td>
<td>when the number of empty words in the receive FIFO is greater or equal to RSWATER. If</td>
</tr>
<tr>
<td></td>
<td>RSWATER is configured to zero, RTS_B negates when the receive FIFO is full. For the purpose</td>
</tr>
<tr>
<td></td>
<td>of RX RTS_B generation, the number of words in the receive FIFO updates when a start bit is</td>
</tr>
<tr>
<td></td>
<td>detected. This supports additional latency between RTS_B negation and the external transmitter</td>
</tr>
<tr>
<td></td>
<td>ceasing transmission. If both RX RTS_B and address/data matching is enabled, then RTS_B could</td>
</tr>
<tr>
<td></td>
<td>assert at the end of a character if there is not a match.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Register definition

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>This field should only be changed when the receiver is disabled.</strong></td>
<td></td>
</tr>
<tr>
<td><strong>7-6</strong></td>
<td>Reserved</td>
</tr>
</tbody>
</table>
| **5**   | TXCTSSRC  
  **Transmit CTS Source**  
  Configures the source of the CTS input.  
  0b - CTS input is the CTS_B pin.  
  1b - CTS input is the inverted Receiver Match result. |
| **4**   | TXCTSC  
  **Transmit CTS Configuration**  
  Configures if the CTS state is checked at the start of each character or only when the transmitter is idle.  
  0b - CTS input is sampled at the start of each character.  
  1b - CTS input is sampled when the transmitter is idle. |
| **3**   | RXRTSE  
  **Receiver request-to-send enable**  
  Allows the RTS output to control the CTS input of the transmitting device to prevent receiver overrun.  
  This bit should only be changed when the receiver is disabled.  
  **NOTE:** Do not set both RXRTSE and TXRTSE.  
  0b - The receiver has no effect on RTS.  
  1b - RTS is deasserted if the receiver data register is full or a start bit has been detected that would cause the receiver data register to become full. RTS is asserted if the receiver data register is not full and has not detected a start bit that would cause the receiver data register to become full. |
| **2**   | TXRTSPOL  
  **Transmitter request-to-send polarity**  
  Controls the polarity of the transmitter RTS. TXRTSPOL does not affect the polarity of the receiver RTS. RTS will remain negated in the active low state unless TXRTSE is set. This bit should only be changed when the transmitter is disabled.  
  0b - Transmitter RTS is active low.  
  1b - Transmitter RTS is active high. |
| **1**   | TXRTSE  
  **Transmitter request-to-send enable**  
  Controls RTS before and after a transmission. This bit should only be changed when the transmitter is disabled.  
  0b - The transmitter has no effect on RTS.  
  1b - When a character is placed into an empty transmitter data buffer, RTS asserts one bit time before the start bit is transmitted. RTS deasserts one bit time after all characters in the transmitter data buffer and shift register are completely sent, including the last stop bit. |
| **0**   | TXCTSE  
  **Transmitter clear-to-send enable**  
  TXCTSE controls the operation of the transmitter. TXCTSE can be set independently from the state of TXRTSE and RXRTSE.  
  0b - CTS has no effect on the transmitter.  
  1b - Enables clear-to-send operation. The transmitter checks the state of CTS each time it is ready to send a character. If CTS is asserted, the character is sent. If CTS is deasserted, the signal TXD remains in the mark state and transmission is delayed until CTS is asserted. Changes in CTS as a character is being sent do not affect its transmission. |

### 49.4.1.12 LPUART FIFO Register (FIFO)
49.4.1.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FIFO</td>
<td>28h</td>
</tr>
</tbody>
</table>

49.4.1.12.2 Function

This register provides the ability for the programmer to turn on and off FIFO functionality. It also provides the size of the FIFO that has been implemented. This register may be read at any time. This register must be written only when CTRL[RE] and CTRL[TE] are cleared/not set and when the data buffer/FIFO is empty.

49.4.1.12.3 Diagram

```
Bits  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16
R     0    0    0    0    0    0    0    0    1    1    0    0    0    0    0    0
W
Reset 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0
```

```
Bits  15  14  13  12  11  10  9  8  7  6  5  4  3  2  1  0
R     0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0
W
TXF    RXF    TXF    RXF
TXFOSIZE  RXFOSIZE
Reset 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0
```

49.4.1.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>TXEMPT</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TXEMPT</th>
<th>Transmit Buffer/FIFO Empty</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Asserts when there is no data in the Transmit FIFO/buffer. This field does not take into account data that is in the transmit shift register.</td>
</tr>
<tr>
<td>0b</td>
<td>Transmit buffer is not empty.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>22</td>
<td>RXEMPT (Receive Buffer/FIFO Empty)</td>
</tr>
<tr>
<td></td>
<td>Asserts when there is no data in the receive FIFO/Buffer. This field does not take into account data that is in the receive shift register.</td>
</tr>
<tr>
<td></td>
<td>0b - Receive buffer is not empty.</td>
</tr>
<tr>
<td></td>
<td>1b - Receive buffer is empty.</td>
</tr>
<tr>
<td>21-18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17</td>
<td>TXOF (Transmitter Buffer Overflow Flag)</td>
</tr>
<tr>
<td></td>
<td>Indicates that more data has been written to the transmit buffer than it can hold. This field will assert regardless of the value of TXOFE. However, an interrupt will be issued to the host only if TXOFE is set. This flag is cleared by writing a 1.</td>
</tr>
<tr>
<td></td>
<td>0b - No transmit buffer overflow has occurred since the last time the flag was cleared.</td>
</tr>
<tr>
<td></td>
<td>1b - At least one transmit buffer overflow has occurred since the last time the flag was cleared.</td>
</tr>
<tr>
<td>16</td>
<td>RXUF (Receiver Buffer Underflow Flag)</td>
</tr>
<tr>
<td></td>
<td>Indicates that more data has been read from the receive buffer than was present. This field will assert regardless of the value of RXUFE. However, an interrupt will be issued to the host only if RXUFE is set. This flag is cleared by writing a 1.</td>
</tr>
<tr>
<td></td>
<td>0b - No receive buffer underflow has occurred since the last time the flag was cleared.</td>
</tr>
<tr>
<td></td>
<td>1b - At least one receive buffer underflow has occurred since the last time the flag was cleared.</td>
</tr>
<tr>
<td>15</td>
<td>TXFLUSH (Transmit FIFO/Buffer Flush)</td>
</tr>
<tr>
<td></td>
<td>Writing to this field causes all data that is stored in the transmit FIFO/buffer to be flushed. This does not affect data that is in the transmit shift register.</td>
</tr>
<tr>
<td></td>
<td>0b - No flush operation occurs.</td>
</tr>
<tr>
<td></td>
<td>1b - All data in the transmit FIFO/buffer is cleared out.</td>
</tr>
<tr>
<td>14</td>
<td>RXFLUSH (Receive FIFO/Buffer Flush)</td>
</tr>
<tr>
<td></td>
<td>Writing to this field causes all data that is stored in the receive FIFO/buffer to be flushed. This does not affect data that is in the receive shift register.</td>
</tr>
<tr>
<td></td>
<td>0b - No flush operation occurs.</td>
</tr>
<tr>
<td></td>
<td>1b - All data in the receive FIFO/buffer is cleared out.</td>
</tr>
<tr>
<td>13</td>
<td>Reserved</td>
</tr>
<tr>
<td>12-10</td>
<td>RXIDEN (Receiver Idle Empty Enable)</td>
</tr>
<tr>
<td></td>
<td>When set, enables the assertion of RDRF when the receiver is idle for a number of idle characters and the FIFO is not empty.</td>
</tr>
<tr>
<td></td>
<td>000b - Disable RDRF assertion due to partially filled FIFO when receiver is idle.</td>
</tr>
<tr>
<td></td>
<td>001b - Enable RDRF assertion due to partially filled FIFO when receiver is idle for 1 character.</td>
</tr>
<tr>
<td></td>
<td>010b - Enable RDRF assertion due to partially filled FIFO when receiver is idle for 2 characters.</td>
</tr>
<tr>
<td></td>
<td>011b - Enable RDRF assertion due to partially filled FIFO when receiver is idle for 4 characters.</td>
</tr>
<tr>
<td></td>
<td>100b - Enable RDRF assertion due to partially filled FIFO when receiver is idle for 8 characters.</td>
</tr>
<tr>
<td></td>
<td>101b - Enable RDRF assertion due to partially filled FIFO when receiver is idle for 16 characters.</td>
</tr>
<tr>
<td></td>
<td>110b - Enable RDRF assertion due to partially filled FIFO when receiver is idle for 32 characters.</td>
</tr>
<tr>
<td></td>
<td>111b - Enable RDRF assertion due to partially filled FIFO when receiver is idle for 64 characters.</td>
</tr>
<tr>
<td>9</td>
<td>TXOFE (Transmit FIFO Overflow Interrupt Enable)</td>
</tr>
<tr>
<td></td>
<td>When this field is set, the TXOF flag generates an interrupt to the host.</td>
</tr>
<tr>
<td></td>
<td>0b - TXOF flag does not generate an interrupt to the host.</td>
</tr>
<tr>
<td></td>
<td>1b - TXOF flag generates an interrupt to the host.</td>
</tr>
<tr>
<td>8</td>
<td>RXUF (Receive FIFO Underflow Interrupt Enable)</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| RXUFE | When this field is set, the RXUF flag generates an interrupt to the host.  
0b - RXUF flag does not generate an interrupt to the host.  
1b - RXUF flag generates an interrupt to the host. |
| 7     | Transmit FIFO Enable  
When this field is set, the built-in FIFO structure for the transmit buffer is enabled. The size of the FIFO structure is indicated by TXFIFOSIZE. If this field is not set, the transmit buffer operates as a FIFO of depth one dataword regardless of the value in TXFIFOSIZE. Both CTRL[TE] and CTRL[RE] must be cleared prior to changing this field.  
0b - Transmit FIFO is not enabled. Buffer is depth 1.  
1b - Transmit FIFO is enabled. Buffer is depth indicated by TXFIFOSIZE. |
| 6-4   | Transmit FIFO Buffer Depth  
The maximum number of transmit datawords that can be stored in the transmit buffer. This field is read only.  
000b - Transmit FIFO/Buffer depth = 1 dataword.  
001b - Transmit FIFO/Buffer depth = 4 datawords.  
010b - Transmit FIFO/Buffer depth = 8 datawords.  
011b - Transmit FIFO/Buffer depth = 16 datawords.  
100b - Transmit FIFO/Buffer depth = 32 datawords.  
101b - Transmit FIFO/Buffer depth = 64 datawords.  
110b - Transmit FIFO/Buffer depth = 128 datawords.  
111b - Transmit FIFO/Buffer depth = 256 datawords |
| 3     | Receive FIFO Enable  
When this field is set, the built-in FIFO structure for the receive buffer is enabled. The size of the FIFO structure is indicated by the RXFIFOSIZE field. If this field is not set, the receive buffer operates as a FIFO of depth one dataword regardless of the value in RXFIFOSIZE. Both CTRL[TE] and CTRL[RE] must be cleared prior to changing this field.  
0b - Receive FIFO is not enabled. Buffer is depth 1.  
1b - Receive FIFO is enabled. Buffer is depth indicated by RXFIFOSIZE. |
| 2-0   | Receive FIFO Buffer Depth  
The maximum number of receive datawords that can be stored in the receive buffer before an overrun occurs. This field is read only.  
000b - Receive FIFO/Buffer depth = 1 dataword.  
001b - Receive FIFO/Buffer depth = 4 datawords.  
010b - Receive FIFO/Buffer depth = 8 datawords.  
011b - Receive FIFO/Buffer depth = 16 datawords.  
100b - Receive FIFO/Buffer depth = 32 datawords.  
101b - Receive FIFO/Buffer depth = 64 datawords.  
110b - Receive FIFO/Buffer depth = 128 datawords.  
111b - Receive FIFO/Buffer depth = 256 datawords. |

#### 49.4.1.13 LPUART Watermark Register (WATER)

##### 49.4.1.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WATER</td>
<td>2Ch</td>
</tr>
</tbody>
</table>

Chapter 49 Low Power Universal Asynchronous Receiver/Transmitter (LPUART)
49.4.1.13.2  Function
This register provides the ability to set a programmable threshold for notification of needing additional transmit data. This register may be read at any time but must be written only when CTRL[TE] is not set.

49.4.1.13.3  Diagram

49.4.1.13.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-27</td>
<td>Reserved</td>
</tr>
<tr>
<td>26-24</td>
<td>Receive Counter</td>
</tr>
<tr>
<td>RXCOUNT</td>
<td>The value in this register indicates the number of datawords that are in the receive FIFO/buffer. If a dataword is being received, that is, in the receive shift register, it is not included in the count. This value may be used in conjunction with FIFO[RXFIFOSIZE] to calculate how much room is left in the receive FIFO/buffer.</td>
</tr>
<tr>
<td>23-18</td>
<td>Reserved</td>
</tr>
<tr>
<td>17-16</td>
<td>Receive Watermark</td>
</tr>
<tr>
<td>RXWATER</td>
<td>When the number of datawords in the receive FIFO/buffer is greater than the value in this register field, an interrupt or a DMA request is generated. For proper operation, the value in RXWATER must be set to be less than the receive FIFO/buffer size as indicated by FIFO[RXFIFOSIZE] and FIFO[RXFE] and must be greater than 0.</td>
</tr>
<tr>
<td>15-11</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 10-8 TXCOUNT | Transmit Counter  
The value in this register indicates the number of datawords that are in the transmit FIFO/buffer. If a dataword is being transmitted, that is, in the transmit shift register, it is not included in the count. This value may be used in conjunction with FIFO[TXFIFOSIZE] to calculate how much room is left in the transmit FIFO/buffer. |
| 7-2 Reserved              |
| 1-0 TXWATER | Transmit Watermark  
When the number of datawords in the transmit FIFO/buffer is equal to or less than the value in this register field, an interrupt or a DMA request is generated. For proper operation, the value in TXWATER must be set to be less than the size of the transmit buffer/FIFO size as indicated by FIFO[TXFIFOSIZE] and FIFO[TXFE]. |
Chapter 50
Flexible I/O (FlexIO)

50.1 Chip-specific FlexIO information

Table 50-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>—</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Trigger mapping</td>
<td>-</td>
<td>Table 4-8</td>
</tr>
</tbody>
</table>

**NOTE**

In this device, FLEXIO1 and FLEXIO2/3 parameters are not exactly the same. FLEXIO1 has 16 pins, while FLEXIO2/3 has 32 pins.

**NOTE**

FlexIO cannot shift and store on the same cycle. For example, when trying to use FlexIO emulate the SSI slave device, will find it fail to shift and store on the same cycle, and the last falling edge of the clock is not used to latch the last data bit. One workaround is to use other timer count the number bit periods and generate the disable signals. However, it has two limitations: 1) it needs to know the transmitting rate, and set this timer with the same baud rate. 2) it requires the transmitting is asynchronous, does not have any clock stretch; otherwise, it will result in fail. So the slave receiving is not synchronous.
50.2 Introduction

50.2.1 Overview
The FlexIO is a highly configurable module providing a wide range of functionality including:
- Emulation of a variety of serial/parallel communication protocols
- Flexible 16-bit timers with support for a variety of trigger, reset, enable and disable conditions
- Programmable logic blocks allowing the implementation of digital logic functions on-chip and configurable interaction of internal and external modules
- Programmable state machine for offloading basic system control functions from CPU

50.2.2 Features
The FlexIO module is capable of supporting a wide range of protocols including, but not limited to:
- UART
- I2C
- SPI
- I2S
- Camera IF
- Motorola 68K/Intel 8080 bus
- PWM/Waveform generation

The following key features are provided:
- Array of 32-bit shift registers with transmit, receive and data match modes
- Double buffered shifter operation for continuous data transfer
- Shifter concatenation to support large transfer sizes
- Automatic start/stop bit generation
- 1, 2, 4, 8, 16 or 32 multi-bit shift widths for parallel interface support
- Interrupt, DMA or polled transmit/receive operation
- Programmable baud rates independent of bus clock frequency, with support for asynchronous operation during stop modes
- Highly flexible 16-bit timers with support for a variety of internal or external trigger, reset, enable and disable conditions
• Programmable logic mode for integrating external digital logic functions on-chip or combining pin/shifter/timer functions to generate complex outputs
• Programmable state machine for offloading basic system control functions from CPU with support for up to 8 states, 8 outputs and 3 selectable inputs per state

50.2.3 Block Diagram

The following diagram gives a high-level overview of the configuration of FlexIO timers and shifters.

![FlexIO block diagram](image)

Figure 50-1. FlexIO block diagram

50.2.4 Modes of operation

The FlexIO module supports the chip modes described in the following table.
Table 50-2. Chip modes supported by the FlexIO module

<table>
<thead>
<tr>
<th>Chip mode</th>
<th>FlexIO Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>Run</td>
<td>Normal operation</td>
</tr>
<tr>
<td>Stop/Wait</td>
<td>Can continue operating provided the Doze Enable bit (CTRL[DOZEN]) is clear and</td>
</tr>
<tr>
<td></td>
<td>the FlexIO is using an external or internal clock source which remains operating during stop/wait modes.</td>
</tr>
<tr>
<td>Low Leakage Stop</td>
<td>The Doze Enable (CTRL[DOZEN]) bit is ignored and the FlexIO will wait for all</td>
</tr>
<tr>
<td></td>
<td>Timers to complete any pending operation before acknowledging low leakage mode entry.</td>
</tr>
<tr>
<td>Debug</td>
<td>Can continue operating provided the Debug Enable bit (CTRL[DBGE]) is set.</td>
</tr>
</tbody>
</table>

50.2.5 FlexIO Signal Descriptions

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>FXIO_Dn (n=0...31)</td>
<td>Bidirectional FlexIO Shifter and Timer</td>
<td>I/O</td>
</tr>
<tr>
<td></td>
<td>pin inputs/outputs</td>
<td></td>
</tr>
</tbody>
</table>

50.3 Functional description

50.3.1 Clocking and Resets

50.3.1.1 Functional clock

The FlexIO functional clock is asynchronous to the bus clock and can remain enabled in low power modes. The FlexIO functional clock must be enabled before accessing any FlexIO registers.

50.3.1.2 Bus clock

The bus clock is only used for bus accesses to the control and configuration registers.

50.3.1.3 Chip reset

The logic and registers for the FlexIO are reset to their default state on a chip reset.
50.3.1.4 Software reset

The FlexIO implements a software reset bit in its Control Register. The CTRL[RST] will reset all logic and registers to their default state, except for the CTRL itself.

50.3.2 Shifter operation

Shifters are responsible for buffering and shifting data into or out of the FlexIO. The timing of shift, load and store events are controlled by the Timer assigned to the Shifter via the SHIFTCTL[TIMSEL] register. The Shifters are designed to support either DMA, interrupt or polled operation. The following block diagram provides a detailed view of the Shifter microarchitecture.

![Shifter Microarchitecture](image)

**Figure 50-2. Shifter Microarchitecture**

50.3.2.1 Transmit Mode

When configured for Transmit mode (SHIFTCTL[SMOD]=Transmit), the shifter will load data from the SHIFTBUF register and shift data out when a load event is signalled by the assigned Timer. An optional start/stop bit can also be automatically loaded before/after SHIFTBUF data by configuring the SHIFTCFG[SSTART], TIMCFG[TSTART] or SHIFTCFG[SSTOP], TIMCFG[TSTOP] registers in the Shifter and Timer. Note that the shifter will immediately load a stop bit when the Shifter is initially configured for Transmit mode if a stop bit is enabled.

The Shifter Status Flag (SHIFTSTAT[SSF]) and any enabled interrupts or DMA requests will set when data has been loaded from the SHIFTBUF register into the Shifter or when the Shifter is initially configured into Transmit mode. The flag will clear when new data has been written into the SHIFTBUF register.
The Shifter Error Flag (SHIFTERR[SEF]) and any enabled interrupts will set when an attempt to load data from an empty SHIFTBUF register occurs (buffer underrun). The flag can be cleared by writing it with logic 1.

50.3.2.2 Receive Mode

When configured for Receive mode (SHIFTCTL[SMOD]=Receive), the shifter will shift data in and store data into the SHIFTBUF register when a store event is signalled by the assigned Timer. Checking for a start/stop bit can be enabled before/after shifter data is sampled by configuring the SHIFTCFG[SSTART], TIMCFG[TSTART] or SHIFTCFG[SSTOP], TIMCFG[TSTOP] registers in the Shifter and Timer.

The Shifter Status Flag (SHIFTSTAT[SSF]) and any enabled interrupts or DMA requests will set when data has been stored into the SHIFTBUF register from the Shifter. The flag will clear when the data has been read from the SHIFTBUF register.

The Shifter Error Flag (SHIFTERR[SEF]) and any enabled interrupts will set when an attempt to store data into a full SHIFTBUF register occurs (buffer overrun) or when a mismatch occurs on a start/stop bit check. The flag can be cleared by writing it with logic 1.

50.3.2.3 Match Store Mode

When configured for Match Store mode (SHIFTCTL[SMOD]=Match Store), the shifter will shift data in, check for a match result and store matched data into the SHIFTBUF register when a store event is signalled by the assigned Timer. Checking for a start/stop bit can be enabled before/after shifter data is sampled by configuring the SHIFTCFG[SSTART], TIMCFG[TSTART] or SHIFTCFG[SSTOP], TIMCFG[TSTOP] registers in the Shifter and Timer. Up to 16-bits of data can be compared using SHIFTBUF[31:16] to configure the data to be matched and SHIFTBUF[15:0] to mask the match result.

The Shifter Status Flag (SHIFTSTAT[SSF]) and any enabled interrupts or DMA requests will set when a match occurs and matched data has been stored into the SHIFTBUF register from the Shifter. The flag will clear when the matched data has been read from the SHIFTBUF register.

The Shifter Error Flag (SHIFTERR[SEF]) and any enabled interrupts will set when an attempt to store matched data into a full SHIFTBUF register occurs (buffer overrun) or when a mismatch occurs on a start/stop bit check. The flag can be cleared by writing it with logic 1.
50.3.2.4 Match Continuous Mode

When configured for Match Continuous mode (SHIFTCTL[SMOD]=Match Continuous), the shifter will shift data in and continuously check for a match result whenever a shift event is signalled by the assigned Timer. Up to 16-bits of data can be compared using SHIFTBUF[31:16] to configure the data to be matched and SHIFTBUF[15:0] to mask the match result.

The Shifter Status Flag (SHIFTSTAT[SSF]) and any enabled interrupts or DMA requests will set when a match occurs. The flag will clear automatically as soon as there is no longer a match between Shifter data and SHIFTBUF register.

The Shifter Error Flag (SHIFTERR[SEF]) and any enabled interrupts will set when a match occurs. The flag will clear when there is a read from the SHIFTBUF register or it written with logic 1.

50.3.2.5 State Mode

Using State mode enables the user to implement any state machine with up to 8 states, 8 outputs and 3 selectable inputs per state. This feature allows basic control functions to be offloaded from the CPU, which could potentially remain in a STOP/VLPS low power mode.

When configured for State mode (SHIFTCTL[SMOD]=State), the SHIFTBUF register is used to drive the output and compute next state values when the Shifter has been selected by the current state pointer (SHIFTSTATE[STATE]). The following diagram provides a detailed view of Shifter microarchitecture when configured for State mode.

Figure 50-3. State Microarchitecture
When Shifter i has been selected by the current state pointer, output pins FXIO_D[7:0] will be driven by SHIFTBUF[i][31:24] using the configuration set by SHIFTCTL[i][PINCFG]. When set, SHIFTCFG[i]{PINW[3:0],STOP[1:0],START[1:0]} are respectively used to disable the output drive on pins FXIO_D[7:0] for state machine applications which require less than 8 output pins.

The next state value is computed using the 3 input pins selected by SHIFTCTL[i][PINSEL] together with SHIFTBUF[i][23:0]. Note that each state could potentially use a different set of 3 input pins. The following table details how the next state value is computed when the current state pointer is pointing to Shifter i.

**Table 50-3. Next State computation for SHIFTSTATE[STATE]=i**

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>SHIFTBUF[2:0]</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>SHIFTBUF[5:3]</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>SHIFTBUF[8:6]</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>SHIFTBUF[11:9]</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>SHIFTBUF[23:21]</td>
</tr>
</tbody>
</table>

Note that other shifters/timers could potentially be configured to drive the input pins of a given state, allowing the user to create complex combinations of shifters/timers as desired e.g. the output of a Shifter configured for logic mode could potentially be used to drive a state machine input.

The next state transition is triggered using the Timer output selected by SHIFTCTL[i][TIMSEL] with polarity controlled by SHIFTCTL[i][TIMPOL]. Note that each state could potentially use a different Timer to trigger each next state transition, allowing a variety of internal/external trigger sources and clocking configurations to be used (see Timer section for more detail).

The current state pointer defaults to Shifter 0 at reset, however it can be written by the user to select a different Shifter for the initial state. If the current state pointer selects a Shifter which is not configured for State mode, then outputs will not be driven and a next state transition is never triggered.

The Shifter Status Flag (SHIFTSTAT[SSF]) and any enabled interrupts or DMA requests will set whenever the Shifter has been selected by the current state pointer. The flag will clear when the current state pointer is updated to a different Shifter.
50.3.2.6 Logic Mode

Using logic mode enables the user to implement a small amount of programmable digital logic within a FlexIO Shifter. This feature allows board-level glue logic to be integrated on-chip using FlexIO hardware.

When configured for Logic mode (SHIFTCTL[SMOD]=Logic), the SHIFTBUF register is used to implement a 5-input, 32-bit programmable logic look-up table. The following diagram provides a detailed view of Shifter microarchitecture when configured for Logic mode.

![Logic Microarchitecture Diagram](image)

The look-up table is driven using 4 pin inputs (maskable using SHIFTCFG[SSTOP] and SHFITCFG[SSTART]) plus 1 input from the internal shifter and can be configured to drive an output pin using the SHIFTCTL[PINCFG] field. Pin inputs and outputs are fixed for each logic look-up table and are not selectable. The following table lists the logic output value selected by the look-up table for Shifter 'i'.

### Table 50-4. Logic Look-up table for Shifter 'i'

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>SHIFTBUF[0]</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>SHIFTBUF[1]</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>SHIFTBUF[2]</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>SHIFTBUF[3]</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>SHIFTBUF[31]</td>
</tr>
</tbody>
</table>

1. for Shifter i=0...3, x=i
To minimize output glitches, \texttt{SHIFTCFG[SSTOP]} and \texttt{SHIFTCFG[SSTART]} can be used to mask unused input pins. When set, \{\texttt{SSTOP[1:0]}, \texttt{SSTART[1:0]}\} will mask \texttt{FXIO\_D[x+3]...FXIO\_D[x]} inputs respectively, so that any transitions on these pins will not cause the logic output to glitch.

Note that other shifters/timers could potentially be configured to drive the input pins of a given look-up table (without synchronization), allowing the user to concatenate look-up tables or create complex combinations of shifters/timers as desired.

\texttt{SHIFTCFG[PWIDTH]} will control the number of delay stages introduced by the internal shifter input (\texttt{SHIFTERi[0]}). For example, when configured for 1-bit shift (\texttt{PWIDTH}=0), the internal shifter will introduce a 32 Shift clock delay before passing its input (selected by \texttt{SHIFTCtrl[PINSEL]}) to the look-up table. When configured for 32-bit shift (\texttt{PWIDTH}=16...31), the internal shifter will introduce a 1 Shift clock delay to its input.

The Shifter Status Flag (\texttt{SHIFTSTAT[SSF]}) and any enabled interrupts or DMA requests will set whenever the output pin allocated to the logic look-up table has a value of 1 (after being synchronized to the FlexIO clock). The flag will clear when the output pin has a value of 0. This also allows the SSF flag to be used as a trigger to a Timer if desired.

The Shifter Error Flag (\texttt{SHIFTERR[SEF]}) and any enabled interrupts will set when the output pin allocated to the logic look-up table has a value of 1. The flag can be cleared by writing it with logic 1.

### 50.3.3 Timer Operation

The FlexIO 16-bit timers control the loading, shifting and storing of the shift registers, the counters load the contents of the compare register and decrement down to zero on the FlexIO clock. They can perform generic timer functions such as generating a clock or select output or a PWM waveform. Timers can be configured to enable in response to a trigger, pin or shifter condition; decrement always or only on a trigger or pin edge; reset in response to a trigger or pin condition; and disable on a trigger or pin condition or on a timer compare. Timers can optionally include a start condition and/or stop condition.

Each timer operates independently, although a timer can be configured to enable or disable at the same time as the previous timer (eg: timer1 can enable or disable at the same time as timer 0) and a timer output can be used to trigger any other timer. The trigger used by each timer is configured independently and can be configured to be a timer output, shifter status flag, pin input or an external trigger input (refer to the chip
configuration section for details on the external trigger connections). The trigger configuration is separate from the pin configuration, which can be configured for input, output data or output enable.

The Timer Configuration Register (TIMCFGn) should be configured before setting the Timer Mode (TIMOD).

### 50.3.3.1 Timer 8-bit Baud Counter Mode

In 8-bit Baud Counter Mode, the 16-bit counter is divided into two 8-bit counters. The lower 8-bits are used to configure the baud rate of the shift clock and the upper 8-bits are used to configure the number number of shift clock edges in the transfer. When the lower 8-bits decrement to zero, the timer output is toggled and the lower 8-bits reload from the compare register. The upper 8-bits only decrement when the lower 8-bits equal zero and decrement.

A timer compare event occurs when the upper 8-bits equal zero and decrements. The timer status flag is set on a timer compare event.

### 50.3.3.2 Timer 8-bit High PWM Mode

In 8-bit High PWM Mode, the 16-bit counter is divided into two 8-bit counters. The lower 8-bits are used to configure the timer output high period and the upper 8-bits are used to configure the timer output low period. The lower 8-bits decrement when the output is high. When the lower 8-bits equal zero and decrement, the timer output is cleared and the lower 8-bits are reloaded from the compare register. The upper 8-bits decrement when the output is low. When the upper 8-bits equal zero and decrement, the timer output is set and the upper 8-bits are reloaded from the compare register.

A timer compare event occurs when the upper 8-bits equal zero and decrements. The timer status flag is set on a timer compare event.

### 50.3.3.3 Timer 16-bit Counter Mode

In 16-bit Counter Mode, the 16-bit counter can be used to configure either the baud rate of the shift clock (eg: TIMDEC[1:0] != 10 or 11) or the number of shift clock edges in the transfer (eg: TIMDEC[1:0] = 10 or 11). When the 16-bit counter equals zero and decrements, the timer output toggles and the counter reloads from the compare register.

A timer compare event occurs when the 16-bit counter equals zero and decrements. The timer status flag is set on a timer compare event.
50.3.3.4 Timer Enable and Start Bit

When the TIMOD is configured for the desired mode, and the condition configured by timer enable (TIMENA) is detected then the following events occur.

- Timer counter will load the current value of the compare Register and start decrementing as configured by TIMDEC.
- Timer output will set depending on the TIMOUT configuration.
- Transmit shifters controlled by this timer will either output their start bit value, or load the shift register from the shift buffer and output the first bit, as configured by SSTART.

If the Timer start bit is enabled, the timer counter will reload with the compare register on the first rising edge of the shift clock after the timer starts decrementing. If there is no falling edge on the shift clock before the first rising edge (for example, when TIMOUT=1), a shifter that is configured to shift on falling edge and load on the first shift will not load correctly.

50.3.3.5 Timer Decrement and Reset

The Timer will then generate the timer output and timer shift clock depending on the TIMOD and TIMDEC fields. The shifter clock is either equal to the timer output (when TIMDEC != 10 or 11) or equal to the decrement clock (when TIMDEC = 10 or 11).

When TIMDEC is configured to decrement from a pin or trigger, the timer will decrement on both rising and falling edges.

When the Timer is configured to reset as configured in the TIMRST field then the Timer counter will load the current value of the compare register again, the timer output may also be affected by the reset as configured in TIMOUT.

In general, when the timer counter decrements to zero a timer compare event is triggered. The timer compare event will cause the timer counter to load the contents of the timer compare register, the timer output to toggle, any configured transmit shift registers to load, and any configured receive shift registers to store. Depending on the mode, the timer status flag may also be set,

50.3.3.6 Timer Disable and Stop Bit

When the is Timer is configured to add a stop bit on each compare, the following additional events will occur.
Transmit shifters controlled by this timer will output their stop bit value (if configured by SSTOP).

Receive shifters controlled by this timer will store the contents of the shift register in their shift buffer, as configured by SSTOP.

On the first rising edge of the shifter clock after the compare, the timer counter will reload the current value of the Compare Register.

Transmit shifters must be configured to load on the first shift when the timer is configured to insert a stop bit on each compare.

When the condition configured by timer disable (TIMDIS) is detected, the following events occur.

- Timer counter will reload the current value of the Compare Register and start decrementing as configured by TIMDEC.
- Timer output will clear.
- Transmit shifters controlled by this timer will output their stop bit value (if configured by SSTOP).
- Receive shifters controlled by this timer will store the contents of the shift register in their shift buffer, as configured by SSTOP.

If the timer stop bit is enabled, the timer counter will continue decrementing until the next rising edge of the shift clock is detected, at which point it will finish.

A timer enable condition can be detected in the same cycle as a timer disable condition (if timer stop bit is disabled), or on the first rising edge of the shift clock after the disable condition (if stop bit is enabled). Receive shift registers with stop bit enabled will store the contents of the shift register into the shift buffer and verify the state of the input data on the configured shift edge while the timer is in the stop state condition. If there is no configured edge between the timer disable and the next rising edge of the shift clock then the final store and verify do not occur.

### 50.3.4 Pin operation

The pin configuration for each timer and shifter can be configured to use any FlexIO pin with either polarity. Each timer and shifter can be configured as an input, output data, output enable or bidirectional output. A pin configured for output enable can be used as an open drain (with inverted polarity, since the output enable assertion would cause logic zero to be output on the pin) or to control the enable on the bidirectional output. Any timer or shifter could be configured to control the output enable for a pin where the bidirectional output data is driven by another timer or shifter.
50.3.4.1 Parallel Interface
Shifters can be configured to use multiple FlexIO pins in parallel using the
SHIFTCFG[PWIDTH] field. PWIDTH is used to configure the following settings of a
shifter:
1. Number of bits shifted per Shift clock.
2. Number of pins driven by the shifter per Shift clock (only on shifters supporting
   parallel transmit i.e. SHIFTER0, SHIFTER4).
3. Number of pins sampled by the shifter per Shift clock (only on Shifter supporting
   parallel receive i.e. SHIFTER3, SHIFTER7).

When configured for parallel shift, either 4, 8, 16 or 32-bits can be shifted on every Shift
clock. If an adjacent shifter is selected as the input source (SHIFTCFG[INSRC]=1), the
least significant 4, 8, 16 or 32-bits from the adjacent shifter will be sampled on each Shift
clock.

For shifters supporting parallel receive (SHIFTER3, SHIFTER7), the shifter can be
configured to sample multiple pins (SHIFTCFG[INSRC]=0), with PWIDTH and
PINSEL selecting the pins as follows: FXIO_D[PINSEL+PWIDTH]:FXIO_D[PINSEL].
Note that if PWIDTH is less than the number of bits being shifted on each Shift clock,
then the most significant bits will be masked with 0 e.g. if PINSEL=7 and PWIDTH=6,
then SHIFTER[31:24] will sample {0,0,FXIO_D[12:7]} on each Shift clock.

For shifters supporting parallel transmit (SHIFTER0, SHIFTER4), the shifter can be
configured to drive multiple pins using SHIFTCTL[PINCFG], with PWIDTH and
PINSEL selecting the pins as follows: FXIO_D[PINSEL+PWIDTH]:FXIO_D[PINSEL].
Note that if PWIDTH is less than the number of bits being shifted on each Shift clock,
then the most significant pins will not be driven e.g. if PINSEL=7 and PWIDTH=6, then
SHIFTER[5:0] will drive only FXIO_D[12:7] on each Shift clock.

50.3.4.2 Pin Synchronization
When configuring a pin as an input (this includes a timer trigger configured as a pin
input), the input signal is first synchronized to the FlexIO clock before the signal is used
by a timer or shifter. This introduces a small latency of between 0.5 to 1.5 FlexIO clock
cycles when using an external pin input to generate an output or control a shifter. This
sets the maximum setup time at 1.5 FlexIO clock cycles.

If an input is used by more than one timer or shifter then the synchronization occurs once
to ensure any edge is seen on the same cycle by all timers and shifters using that input.
Note that FlexIO pins are also connected internally, configuring a FlexIO shifter or timer to output data on an unused pin will make an internal connection that allows other shifters and timer to use this pin as an input. This allows a shifter output to be used to trigger a timer or a timer output to be shifted into a shifter. This path is also synchronized to the FlexIO clock and therefore incurs a 1 cycle latency.

So when using a Pin input as a Timer Trigger, Timer Clock or Shifter Data Input, the following synchronization delays occur:
1. 0.5 – 1.5 FlexIO clock cycles for external pin
2. 1 FlexIO clock cycle for an internally driven pin

For timing considerations such as output valid time and input setup time for specific applications (SPI Master, SPI Slave, I2C Master, I2S Master, I2S Slave) please refer to the FlexIO Application Information Section.

50.3.5 Interrupts and DMA Requests

The following table illustrates the status flags that can generate the FlexIO interrupt and DMA requests.

<table>
<thead>
<tr>
<th>Flag</th>
<th>Description</th>
<th>Interrupt</th>
<th>DMA Request</th>
<th>Low Power Wakeup</th>
</tr>
</thead>
<tbody>
<tr>
<td>SSF</td>
<td>Shifter Status Flag.</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>SEF</td>
<td>Shifter Error Flag.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
<tr>
<td>TSF</td>
<td>Timer Status Flag.</td>
<td>Y</td>
<td>N</td>
<td>Y</td>
</tr>
</tbody>
</table>

50.3.6 Peripheral Triggers

The connection of the FlexIO peripheral triggers with other peripherals are device specific.

50.3.6.1 Output Triggers

Each FlexIO Timer generates an output trigger equal to the timer output. The output trigger is not affected by the timer pin polarity configuration.
50.3.6.2 Input Trigger

FlexIO supports multiple external trigger inputs that can be used to trigger one or more FlexIO timers. The external triggers are synchronized to the FlexIO functional clock and must assert for at least two cycles of the FlexIO functional clock to be sampled correctly.

50.4 Application Information

This section provides examples for a variety of FlexIO module applications.

50.4.1 UART Transmit

UART transmit can be supported using one Timer, one Shifter and one Pin (two Pins if supporting CTS). The start and stop bit insertion is handled automatically and multiple transfers can be supported using DMA controller. The timer status flag can be used to indicate when the stop bit of each word is transmitted.

Break and idle characters require software intervention, before transmitting a break or idle character the SSTART and SSTOP fields should be altered to transmit the required state and the data to transmit must equal 0xFF or 0x00. Supporting a second stop bit requires the stop bit to be inserted into the data stream using software (and increasing the number of bits to transmit). Note that when performing byte writes to SHIFTBUF$n$ (or SHIFTBUF$F$ for transmitting MSB first), the rest of the register remains unaltered allowing an address mark bit or additional stop bit to remain undisturbed.

FlexIO does not support automatic insertion of parity bits.

Table 50-6. UART Transmit Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFG$n$</td>
<td>0x0000_0032</td>
<td>Configure start bit of 0 and stop bit of 1.</td>
</tr>
<tr>
<td>SHIFTCTL$n$</td>
<td>0x0003_0002</td>
<td>Configure transmit using Timer 0 on posedge of clock with output data on Pin 0. Can invert output data by setting PINPOL, or can support open drain by setting PINPOL=0x1 and PINCFG=0x1.</td>
</tr>
<tr>
<td>TIMCMP$n$</td>
<td>0x0000_0F01</td>
<td>Configure 8-bit transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of bits x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFG$n$</td>
<td>0x0000_2222</td>
<td>Configure start bit, stop bit, enable on trigger asserted and disable on</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 50-6. UART Transmit Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCTLn</td>
<td>0x01C0_0001</td>
<td>Configure dual 8-bit counter using Shifter 0 status flag as inverted internal trigger source. Can support CTS by configuring PINSEL=0x1 (for Pin 1) and PINPOL=0x1.</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUF[7:0] to initiate an 8-bit transfer, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request. Can support MSB first transfer by writing to SHIFTBUFBBS[7:0] register instead.</td>
</tr>
</tbody>
</table>

### 50.4.2 UART Receive

UART receive can be supported using one Timer, one Shifter and one Pin (two Timers and two Pins if supporting RTS). The start and stop bit verification is handled automatically and multiple transfers can be supported using the DMA controller. The timer status flag can be used to indicate when the stop bit of each word is received.

Triple voting of the received data is not supported by FlexIO, data is sampled only once in the middle of each bit. Another timer can be used to implement a glitch filter on the incoming data, another Timer can also be used to detect an idle line of programmable length. Break characters will cause the error flag to set and the shifter buffer register will return 0x00.

FlexIO does not support automatic verification of parity bits.

### Table 50-7. UART Receiver Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0032</td>
<td>Configure start bit of 0 and stop bit of 1.</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0080_0001</td>
<td>Configure receive using Timer 0 on negedge of clock with input data on Pin 0. Can invert input data by setting PINPOL.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_0F01</td>
<td>Configure 8-bit transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of bits x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 50-7. UART Receiver Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCFGn</td>
<td>0x0204_2422</td>
<td>Configure start bit, stop bit, enable on pin posedge and disable on compare. Enable resynchronization to received data with TIMOUT=0x2 and TIMRST=0x4.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x0000_0081</td>
<td>Configure dual 8-bit counter using inverted Pin 0 input.</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBYS[7:0], use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support MSB first transfer by reading from SHIFTBUFBIS[7:0] register instead.</td>
</tr>
</tbody>
</table>

The UART Receiver with RTS configuration uses a 2nd Timer to generate the RTS output. The RTS will assert when the start bit is detected and negate when the data is read from the shifter buffer register. No start bit will be detected while the RTS is asserted, the received data is simply ignored.

Table 50-8. UART Receiver with RTS Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0032</td>
<td>Configure start bit of 0 and stop bit of 1.</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0080_0001</td>
<td>Configure receive using Timer 0 on negedge of clock with input data on Pin 0. Can invert input data by setting PINPOL.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_0F01</td>
<td>Configure 8-bit transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of bits x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0204_2522</td>
<td>Configure start bit, stop bit, enable on pin posedge with trigger asserted and disable on compare. Enable resynchronization to received data with TIMOUT=0x2 and TIMRST=0x4.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x03C0_0081</td>
<td>Configure dual 8-bit counter using inverted Pin 0 input. Trigger is internal using inverted Pin 1 input.</td>
</tr>
<tr>
<td>TIMCMP(n+1)</td>
<td>0x0000_FFFF</td>
<td>Never compare.</td>
</tr>
<tr>
<td>TIMCFG(n+1)</td>
<td>0x0030_6100</td>
<td>Enable on Timer N enable and disable on trigger falling edge. Decrement on trigger to ensure no compare.</td>
</tr>
<tr>
<td>TIMCTL(n+1)</td>
<td>0x0143_0083</td>
<td>Configure 16-bit counter and output on Pin 1. Trigger is internal using Shifter 0 flag.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 50-8. UART Receiver with RTS Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUFn</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBYS[7:0], use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support MSB first transfer by reading from SHIFTBUFBIS[7:0] register instead.</td>
</tr>
</tbody>
</table>

#### 50.4.3 SPI Master

SPI master mode can be supported using two Timers, two Shifters and four Pins. Either CPHA=0 or CPHA=1 can be supported and transfers can be supported using the DMA controller. For CPHA=1, the select can remain asserted for multiple transfers and the timer status flag can be used to indicate the end of the transfer.

The stop bit is used to guarantee a minimum of 1 clock cycle between the slave select negating and before the next transfer. Writing to the transmit buffer by either core or DMA is used to initiate each transfer.

Due to synchronization delays, the setup time for the serial input data is 1.5 FlexIO clock cycles, so the maximum baud rate is divide by 4 of the FlexIO clock frequency.

### Table 50-9. SPI Master (CPHA=0) Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0083_0002</td>
<td>Configure transmit using Timer 0 on negedge of clock with output data on Pin 0.</td>
</tr>
<tr>
<td>SHIFTCFG(n+1)</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTL(n+1)</td>
<td>0x0000_0101</td>
<td>Configure receive using Timer 0 on posedge of clock with input data on Pin 1.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_3F01</td>
<td>Configure 32-bit transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of bits x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0100_2222</td>
<td>Configure start bit, stop bit, enable on trigger high and disable on compare, initial clock state is logic 0.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x01C3_0201</td>
<td>Configure dual 8-bit counter using Pin 2 output (shift clock), with Shifter 0 flag as</td>
</tr>
</tbody>
</table>
### Table 50-9. SPI Master (CPHA=0) Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCMP(n+1)</td>
<td>0x0000_FFFF</td>
<td>the inverted trigger. Set PINPOL to invert the output shift clock.</td>
</tr>
<tr>
<td>TIMCFG(n+1)</td>
<td>0x0000_1100</td>
<td>Enable when Timer 0 is enabled and disable when Timer 0 is disabled.</td>
</tr>
<tr>
<td>TIMCTL(n+1)</td>
<td>0x0003_0383</td>
<td>Configure 16-bit counter (never compare) using inverted Pin 3 output (as slave select).</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUF, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request. Can support MSB first transfer by writing to SHIFTBUFBBBS register instead.</td>
</tr>
<tr>
<td>SHIFTBUF(n+1)</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUF, use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support MSB first transfer by reading from SHIFTBUFBBIS register instead.</td>
</tr>
</tbody>
</table>

### Table 50-10. SPI Master (CPHA=1) Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0021</td>
<td>Start bit loads data on first shift.</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0003_0002</td>
<td>Configure transmit using Timer 0 on posedge of clock with output data on Pin 0.</td>
</tr>
<tr>
<td>SHIFTCFG(n+1)</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTL(n+1)</td>
<td>0x0080_0101</td>
<td>Configure receive using Timer 0 on negedge of clock with input data on Pin 1.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_3F01</td>
<td>Configure 32-bit transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of bits x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0100_2222</td>
<td>Configure start bit, stop bit, enable on trigger high and disable on compare, initial clock state is logic 0.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x01C3_0201</td>
<td>Configure dual 8-bit counter using Pin 2 output (shift clock), with Shifter 0 flag as the inverted trigger. Set PINPOL to invert the output shift clock. Set TIMDIS=3 to keep slave select asserted for as long as there is data in the transmit buffer.</td>
</tr>
<tr>
<td>TIMCMP(n+1)</td>
<td>0x0000_FFFF</td>
<td>Never compare.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 50-10. SPI Master (CPHA=1) Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCFG(n+1)</td>
<td>0x0000_1100</td>
<td>Enable when Timer 0 is enabled and disable when Timer 0 is disabled.</td>
</tr>
<tr>
<td>TIMCTL(n+1)</td>
<td>0x0003_0383</td>
<td>Configure 16-bit counter (never compare) using inverted Pin 3 output (as slave select).</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUF, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request. Can support MSB first transfer by writing to SHIFTBUFBBS register instead.</td>
</tr>
<tr>
<td>SHIFTBUF(n+1)</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBYS, use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support MSB first transfer by reading from SHIFTBUFBIS register instead.</td>
</tr>
</tbody>
</table>

50.4.4 SPI Slave

SPI slave mode can be supported using one Timer, two Shifters and four Pins. Either CPHA=0 or CPHA=1 can be supported and transfers can be supported using the DMA controller. For CPHA=1, the select can remain asserted for multiple transfers and the timer status flag can be used to indicate the end of the transfer.

The transmit data must be written to the transmit buffer register before the external slave select asserts, otherwise the shifter error flag will be set.

Due to synchronization delays, the output valid time for the serial output data is 2.5 FlexIO clock cycles, so the maximum baud rate is divide by 6 of the FlexIO clock frequency.

Table 50-11. SPI Slave (CPHA=0) Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0083_0002</td>
<td>Configure transmit using Timer 0 on falling edge of shift clock with output data on Pin 0.</td>
</tr>
<tr>
<td>SHIFTCFG(n+1)</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTL(n+1)</td>
<td>0x0000_0101</td>
<td>Configure receive using Timer 0 on rising edge of shift clock with input data on Pin 1.</td>
</tr>
</tbody>
</table>
### Table 50-11. SPI Slave (CPHA=0) Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCMPn</td>
<td>0x0000_003F</td>
<td>Configure 32-bit transfer. Set TIMCMP[15:0] = (number of bits x 2) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0120_6000</td>
<td>Configure enable on trigger rising edge, initial clock state is logic 0 and decrement on pin input.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x06C0_0203</td>
<td>Configure 16-bit counter using Pin 2 input (shift clock), with Pin 3 input (slave select) as the inverted trigger.</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUF, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request. Can support MSB first transfer by writing to SHIFTBUFBBSS register instead.</td>
</tr>
<tr>
<td>SHIFTBUF(n+1)</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBS, use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support MSB first transfer by reading from SHIFTBUFBBIS register instead.</td>
</tr>
</tbody>
</table>

### Table 50-12. SPI Slave (CPHA=1) Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0001</td>
<td>Shifter configured to load on first shift and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0003_0002</td>
<td>Configure transmit using Timer 0 on rising edge of shift clock with output data on Pin 0.</td>
</tr>
<tr>
<td>SHIFTCFG(n+1)</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTL(n+1)</td>
<td>0x0080_0101</td>
<td>Configure receive using Timer 0 on falling edge of shift clock with input data on Pin 1.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_003F</td>
<td>Configure 32-bit transfer. Set TIMCMP[15:0] = (number of bits x 2) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0120_6602</td>
<td>Configure start bit, enable on trigger rising edge, disable on trigger falling edge, initial clock state is logic 0 and decrement on pin input.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x06C0_0203</td>
<td>Configure 16-bit counter using Pin 2 input (shift clock), with Pin 3 input (slave select) as the inverted trigger.</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUF, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request. Can support MSB first transfer by writing to SHIFTBUFBBSS register instead.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 50-12. SPI Slave (CPHA=1) Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUF(n+1)</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBYS, use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support MSB first transfer by reading from SHIFTBUFBIS register instead.</td>
</tr>
</tbody>
</table>

## 50.4.5 I2C Master

I2C master mode can be supported using two Timers, two Shifters and two Pins. One timer is used to generate the SCL output and one timer is used to control the shifters. The two shifters are used to transmit and receive for every word, when receiving the transmitter must transmit 0xFF to tristate the output. FlexIO inserts a stop bit after every word to generate/verify the ACK/NACK. FlexIO waits for the first write to the transmit data buffer before enabling SCL generation. Data transfers can be supported using the DMA controller and the shifter error flag will set on transmit underrun or receive overflow.

The first timer generates the bit clock for the entire packet (START to Repeated START/STOP), so the compare register needs to be programmed with the total number of clock edges in the packet (minus one). The timer supports clock stretching using the reset counter when pin equal to output (although this increases both the clock high and clock low periods by at least 1 FlexIO clock cycle each). The second timer uses the SCL input pin to control the transmit/receive shift registers, this enforces an SDA data hold time by an extra 2 FlexIO clock cycles.

Both the transmit and receive shifters need to be serviced for each word in the transfer, the transmit shifter must transmit 0xFF when receiving and the receive shifter returns the data actually present on the SDA pin. The transmit shifter will load 1 additional word on the last falling edge of SCL pin, this word should be 0x00 if generating a STOP condition or 0xFF if generating a repeated START condition. During the last word of a master-receiver transfer, the transmit SSTOP bit should be set by software to generate a NACK.

The receive shift register will assert an error interrupt if a NACK is detected, but software is responsible for generating the STOP or repeated START condition. If a NACK is detected during master-transmit, the interrupt routine should immediately write the transmit shifter register with 0x00 (if generating STOP) or 0xFF (if generating repeated START). Software should then wait for the next rising edge on SCL and then disable both timers. The transmit shifter should then be disabled after waiting the setup delay for a repeated START or STOP condition.
Due to synchronization delays, the data valid time for the transmit output is 2 FlexIO clock cycles, so the maximum baud rate is divide by 6 of the FlexIO clock frequency.

The I2C master data valid is delayed 2 cycles because the clock output is passed through a synchronizer before clocking the transmit/receive shifter (to guarantee some SDA hold time). Since the SCL output is synchronous with FlexIO clock, the synchronization delay is 1 cycle and then 1 cycle to generate the output.

### Table 50-13. I2C Master Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0032</td>
<td>Start bit enabled (logic 0) and stop bit enabled (logic 1).</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0101_0082</td>
<td>Configure transmit using Timer 1 on rising edge of clock with inverted output enable (open drain output) on Pin 0.</td>
</tr>
<tr>
<td>SHIFTCFG(n+1)</td>
<td>0x0000_0020</td>
<td>Start bit disabled and stop bit enabled (logic 0) for ACK/NACK detection.</td>
</tr>
<tr>
<td>SHIFTCTL(n+1)</td>
<td>0x0180_0001</td>
<td>Configure receive using Timer 1 on falling edge of clock with input data on Pin 0.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_2501</td>
<td>Configure 2 word transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of words x 18) + 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0102_2222</td>
<td>Configure start bit, stop bit, enable on trigger high, disable on compare, reset if output equals pin. Initial clock state is logic 0 and is not affected by reset.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x01C1_0101</td>
<td>Configure dual 8-bit counter using Pin 1 output enable (SCL open drain), with Shifter 0 flag as the inverted trigger.</td>
</tr>
<tr>
<td>TIMCMP(n+1)</td>
<td>0x0000_00FF</td>
<td>Configure 8-bit transfer. Set TIMCMP[15:0] = (number of bits x 2) - 1.</td>
</tr>
<tr>
<td>TIMCFG(n+1)</td>
<td>0x0020_1112</td>
<td>Enable when Timer 0 is enabled, disable when Timer 0 is disabled, enable start bit and stop bit at end of each word, decrement on pin input.</td>
</tr>
<tr>
<td>TIMCTL(n+1)</td>
<td>0x01C0_0183</td>
<td>Configure 16-bit counter using inverted Pin 1 input (SCL).</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUFBBS[7:0], use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request.</td>
</tr>
<tr>
<td>SHIFTBUF(n+1)</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBIS[7:0], use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request.</td>
</tr>
</tbody>
</table>
50.4.6 I2S Master

I2S master mode can be supported using two Timers, two Shifters and four Pins. One timer is used to generate the bit clock and control the shifters and one timer is used to generate the frame sync. FlexIO waits for the first write to the transmit data buffer before enabling bit clock and frame sync generation. Data transfers can be supported using the DMA controller and the shifter error flag will set on transmit underrun or receive overflow.

The bit clock frequency is an even integer divide of the FlexIO clock frequency, and the initial frame sync assertion occurs at the same time as the first bit clock edge. The timer uses the start bit to ensure the frame sync is generated one clock cycle before the first output data.

Due to synchronization delays, the setup time for the receiver input is 1.5 FlexIO clock cycles, so the maximum baud rate is divide by 4 of the FlexIO clock frequency.

Table 50-14. I2S Master Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0001</td>
<td>Load transmit data on first shift and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0003_0002</td>
<td>Configure transmit using Timer 0 on rising edge of clock with output data on Pin 0.</td>
</tr>
<tr>
<td>SHIFTCFG(n+1)</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTL(n+1)</td>
<td>0x0080_0101</td>
<td>Configure receive using Timer 0 on falling edge of clock with input data on Pin 1.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_3F01</td>
<td>Configure 32-bit transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of bits x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0000_0202</td>
<td>Configure start bit, enable on trigger high and never disable. Initial clock state is logic 1.</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x01C3_0201</td>
<td>Configure dual 8-bit counter using Pin 2 output (bit clock), with Shifter 0 flag as the inverted trigger. Set PINPOL to invert the output shift clock.</td>
</tr>
<tr>
<td>TIMCMP(n+1)</td>
<td>0x0000_007F</td>
<td>Configure 32-bit transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:0] = (number of bits x baud rate divider) - 1.</td>
</tr>
<tr>
<td>TIMCFG(n+1)</td>
<td>0x0000_0100</td>
<td>Enable when Timer 0 is enabled and never disable.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 50-14. I2S Master Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCTL(n+1)</td>
<td>0x0003_0383</td>
<td>Configure 16-bit counter using inverted Pin 3 output (as frame sync).</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUFBIS, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request. Can support LSB first transfer by writing to SHIFTBUF register instead.</td>
</tr>
<tr>
<td>SHIFTBUF(n+1)</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBIS, use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support LSB first transfer by reading from SHIFTBUF register instead.</td>
</tr>
</tbody>
</table>

50.4.7 I2S Slave

I2S slave mode can be supported using three Timers, two Shifters and four Pins (for single transmit and single receive, other combinations of transmit and receive are possible).

The transmit data must be written to the transmit buffer register before the external frame sync asserts, otherwise the shifter error flag will be set.

Due to synchronization delays, the output valid time for the serial output data is 2.5 FlexIO clock cycles, so the maximum baud rate is divide by 6 of the FlexIO clock frequency.

The output valid time of I2S slave is max 2.5 cycles because there is a maximum 1.5 cycle delay on the clock synchronization plus 1 cycle to output the data.

Timer 2 detects the falling edge of frame sync (start of new frame) and asserts output until falling edge of bit clock (when frame sync is normally sampled). Timer 0 detects falling edge of bit clock with Timer 2 output asserted and asserts output for length of frame. Timer 1 detects rising edge of bit clock with Timer 0 output asserted and controls shift registers for 32-bit transfers.

Table 50-15. I2S Slave Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFGn</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>Register</td>
<td>Value</td>
<td>Comments</td>
</tr>
<tr>
<td>-----------------</td>
<td>------------------</td>
<td>--------------------------------------------------------------------------</td>
</tr>
<tr>
<td>SHIFTCTLn</td>
<td>0x0103_0002</td>
<td>Configure transmit using Timer 1 on rising edge of shift clock with output data on Pin 0.</td>
</tr>
<tr>
<td>SHIFTCFG(n+1)</td>
<td>0x0000_0000</td>
<td>Start and stop bit disabled.</td>
</tr>
<tr>
<td>SHIFTCTL(n+1)</td>
<td>0x0180_0101</td>
<td>Configure receive using Timer 1 on falling edge of shift clock with input data on Pin 1.</td>
</tr>
<tr>
<td>TIMCMPn</td>
<td>0x0000_007F</td>
<td>Configure two 32-bit transfers per frame. Set TIMCMP[15:0] = (number of bits x 4) - 1.</td>
</tr>
<tr>
<td>TIMCFGn</td>
<td>0x0020_2500</td>
<td>Configure enable on pin rising edge (inverted bit clock) with trigger high (Timer 2) and disable on compare, initial clock state is logic 1 and decrement on pin input (bit clock).</td>
</tr>
<tr>
<td>TIMCTLn</td>
<td>0x0B40_0283</td>
<td>Configure 16-bit counter using inverted Pin 2 input (bit clock), with Timer 2 output as the trigger.</td>
</tr>
<tr>
<td>TIMCMP(n+1)</td>
<td>0x0000_003F</td>
<td>Configure 32-bit transfers. Set TIMCMP[15:0] = (number of bits x 2) - 1.</td>
</tr>
<tr>
<td>TIMCFG(n+1)</td>
<td>0x0020_2500</td>
<td>Configure enable on pin (bit clock) rising edge with trigger (Timer 0) high and disable on compare, initial clock state is logic 1 and decrement on pin input (bit clock).</td>
</tr>
<tr>
<td>TIMCTL(n+1)</td>
<td>0x0340_0283</td>
<td>Configure 16-bit counter using inverted Pin 2 input (bit clock), with Timer 0 output as the trigger.</td>
</tr>
<tr>
<td>TIMCMP(n+2)</td>
<td>0x0000_0000</td>
<td>Compare on zero (first edge).</td>
</tr>
<tr>
<td>TIMCFG(n+2)</td>
<td>0x0020_6400</td>
<td>Configure enable on inverted pin (frame sync) rising edge and disable on trigger falling edge (bit clock), initial clock state is logic 1 and decrement on inverted pin input (frame sync).</td>
</tr>
<tr>
<td>TIMCTL(n+2)</td>
<td>0x0440_0383</td>
<td>Configure 16-bit counter using inverted Pin 3 input (frame sync), with Pin 2 input (bit clock) as the trigger.</td>
</tr>
<tr>
<td>SHIFTBUFn</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUFBIS, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request. Can support LSB first transfer by writing to SHIFTBUFB register instead.</td>
</tr>
<tr>
<td>SHIFTBUF(n+1)</td>
<td>Data to receive</td>
<td>Received data can be read from SHIFTBUFBIS, use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request. Can support LSB first transfer by reading from SHIFTBUF register instead.</td>
</tr>
</tbody>
</table>
50.4.8 Camera Interface

Camera Interface can be supported using one Timer, one or more Shifters and multiple Pins. Multiple transfers can be supported using DMA controller.

The example below describes FlexIO configuration for interfacing to an 8-bit CMOS sensor with PCLK, VSYNC, HREF and D[7:0] outputs. The example uses a 128-bit buffer to capture 16-pixels of image data before interrupt or DMA transfer, however a bigger or smaller buffer may be used depending on system DMA performance and FlexIO resource usage by other applications. Note that additional timers may be used to track number of pixels per row and number of rows per frame or HREF/VSYNC may be assigned as GPIO interrupts for software tracking.

<table>
<thead>
<tr>
<th>Table 50-16. Camera Interface Configuration for 8-bit CMOS sensor</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Register</strong></td>
</tr>
<tr>
<td>SHIFTCFGn...n+2(^1)</td>
</tr>
<tr>
<td>SHIFTCFGn+3</td>
</tr>
<tr>
<td>SHIFTCTLn...n+3</td>
</tr>
<tr>
<td>TIMCMPn</td>
</tr>
<tr>
<td>TIMCFGn</td>
</tr>
<tr>
<td>TIMCTLn</td>
</tr>
<tr>
<td>SHIFTBUFn...n+3</td>
</tr>
</tbody>
</table>

\(^1\) \(n=0 \) or 4
50.4.9  Motorola 68K/Intel 8080 Bus Interface

The Motorola 68K and Intel 8080 bus are two parallel interfaces commonly used by Smart/Asynchronous LCD controllers. In conjunction with GPIO, FlexIO is able to drive these interfaces using one Timer and one Shifter, although additional Shifters could be used to support large transfers via the DMA controller.

The configuration below provides an example of how to drive a 16-bit 68K or 8080 bus. For a 8080 bus, two GPIO are used to drive the nCS and RS pins. For a 68K bus, an additional GPIO is required to drive the RDWR pin.

Table 50-17. Motorola 68K/Intel 8080 Write Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFG0...7</td>
<td>0x000F_0100</td>
<td>Configure 16-bit parallel shift in from adjacent shifter.</td>
</tr>
<tr>
<td>SHIFTCTL0</td>
<td>0x0003_0002</td>
<td>Configure transmit using Timer 0 on posedge of clock with data output to FXIO_D[15:0].</td>
</tr>
<tr>
<td>SHIFTCTL1...7</td>
<td>0x0000_0002</td>
<td>Configure transmit using Timer 0 on posedge of clock.</td>
</tr>
<tr>
<td>TIMCMP0</td>
<td>0x0000_0101 (1-beat)</td>
<td>Configure 1 or 16-beat transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of beats x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFG0</td>
<td>0x0000_2200</td>
<td>Configure enable on trigger high and disable on compare. Timer output high on enable.</td>
</tr>
<tr>
<td>TIMCTL0</td>
<td>0x01C3_1001 (Motorola 68K, 1-beat) 0x1DC3_1001 (Motorola 68K, 16-beats) 0x01C3_1081 (Intel 8080, 1-beat) 0x1DC3_1081 (Intel 8080, 16-beats)</td>
<td>Configure dual 8-bit counter using FXIO_D[16] output (EN pin for 68K, nWR pin for 8080), with Shifter 0 (1-beat) or Shifter 7 (16-beats) flag as the inverted trigger.</td>
</tr>
<tr>
<td>SHIFTBUF0...7</td>
<td>Data to transmit</td>
<td>Transmit data can be written to SHIFTBUF0 (1-beat) or SHIFTBUF0...7 (16-beats) to initiate a transfer, use the Shifter Status Flag to indicate when data can be written using interrupt or DMA request.</td>
</tr>
</tbody>
</table>

Table 50-18. Motorola 68K/Intel 8080 Read Configuration

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFG0...6</td>
<td>0x000F_0100</td>
<td>Configure 16-bit parallel shift in from adjacent shifter.</td>
</tr>
<tr>
<td>SHIFTCFG7</td>
<td>0x000F_0000</td>
<td>Configure 16-bit parallel shift in from pin.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 50-18. Motorola 68K/Intel 8080 Read Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCTL0...7</td>
<td>0x0080_0001</td>
<td>Configure receive using Timer 0 on negedge of clock with data input from FXIO_D[15:0].</td>
</tr>
<tr>
<td>TIMCMP0</td>
<td>0x0000_0101 (1-beat)</td>
<td>Configure 1 or 16-beat transfer with baud rate of divide by 4 of the FlexIO clock. Set TIMCMP[15:8] = (number of beats x 2) - 1. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td></td>
<td>0x0000_1F01 (16-beats)</td>
<td></td>
</tr>
<tr>
<td>TIMCFG0</td>
<td>0x0000_2220</td>
<td>Configure stop_bit, enable on trigger high and disable on compare. Timer output high on enable.</td>
</tr>
<tr>
<td>TIMCTL0</td>
<td>0x1DC3_1001 (Motorola 68K, 1 beat) 0x01C3_1001 (Motorola 68K, 16 beats) 0x1DC3_1181 (Intel 8080, 1 beat) 0x01C3_1181 (Intel 8080, 16 beats)</td>
<td>Configure dual 8-bit counter using either FXIO_D[16] output (EN pin for 68K) or FXIO_D[17] output (nRD pin for 8080), with Shifter 7 flag (1-beat) or Shifter 0 flag (16-beats) as the inverted trigger.</td>
</tr>
<tr>
<td>SHIFTBUF0...7</td>
<td>Data received</td>
<td>Received data can be read from SHIFTBUF0 (1-beat) or SHIFTBUF0...7 (16-beats), use the Shifter Status Flag to indicate when data can be read using interrupt or DMA request.</td>
</tr>
</tbody>
</table>

In general, any operation to a 68K/8080 bus slave will begin with a register write cycle followed by one or more data read or write cycles. To accomplish this, the following program flow should be used:

1. Configure FlexIO with 1-beat write configuration
2. Configure GPIO to assert nCS, RS pins (and deassert RDWR pin for 68K)
3. Write register index data to SHIFTBUF0[15:0]
4. Configure GPIO to deassert RS pin (and assert RDWR pin for 68K data read)
5. Configure FlexIO with desired read or write configuration (e.g. 1 or 16-beats)
6. Use the Shifter Status Flag to trigger interrupt or DMA driven data transfers to/from SHIFTBUF registers
7. Configure GPIO to deassert nCS pin

50.4.10 Low Power State Machine

The configuration below details a hypothetical state machine example to illustrate the flexibility allowed when using Shifter state mode.

In this example, FlexIO waits for the FXIO_D[2] pin to assert and then drives a complementary square wave output at a frequency of FLEXIO_CLK/131072 on the FXIO_D[1:0] pins while the comparator output is asserted (assumes comparator is
connected to external trigger 15, see Chip Configuration chapter for actual FlexIO trigger mappings). Throughout this operation, the CPU can be kept in a STOP/VLPS mode, by clearing the CTRL[DOZEN] bit and ensuring the FLEXIO_CLK is enabled. The state diagram below shows the states and transitions implemented by this example.

![State Diagram](image)

**Figure 50-5. State Diagram**

**Table 50-19. State Machine Configuration**

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFG0…2</td>
<td>0x0000_0003</td>
<td>Enable FXIO_D[1:0] as outputs.</td>
</tr>
<tr>
<td>SHIFTCTL0</td>
<td>0x0080_0206</td>
<td>Configure for State mode using FXIO_D[4:2] as inputs to select next state and Timer0 output low to trigger next state.</td>
</tr>
<tr>
<td>SHIFTBUF0</td>
<td>0x0020_8208</td>
<td>State0: Drive FXIO_D[1:0]=00, transition to State0 if FXIO_D[2]=0, State1 if FXIO_D[2]=1.</td>
</tr>
<tr>
<td>SHIFTCTL1</td>
<td>0x0000_0206</td>
<td>Configure for State mode using FXIO_D[4:2] as inputs to select next state and Timer0 output high to trigger next state.</td>
</tr>
<tr>
<td>SHIFTBUF1</td>
<td>0x0140_8408</td>
<td>State1: Drive FXIO_D[1:0]=01, transition to State0 if FXIO_D[2]=0, State1 if CMP=0, State2 if CMP=1 (FXIO_D[3]=1)</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Table 50-19. State Machine Configuration (continued)

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCTL2</td>
<td>0x0080_0206</td>
<td>Configure for State mode using FXIO_D[4:2] as inputs to select next state and Timer0 output low to trigger next state.</td>
</tr>
<tr>
<td>SHIFTBUF2</td>
<td>0x0224_9249</td>
<td>State2: Drive FXIO_D[1:0]=10, transition to State1 when Timer0 output low</td>
</tr>
<tr>
<td>TIMCMP0</td>
<td>0x0000_FFFF</td>
<td>Configure baud rate of divide by 131072 of the FlexIO clock. Set TIMCMP[7:0] = (baud rate divider / 2) - 1.</td>
</tr>
<tr>
<td>TIMCFG0</td>
<td>0x0000_0000</td>
<td>Configure timer always enabled.</td>
</tr>
<tr>
<td>TIMCTL0</td>
<td>0x0000_0003</td>
<td>Configure single 16-bit counter.</td>
</tr>
<tr>
<td>TIMCFG1</td>
<td>0x0010_7600</td>
<td>Configure timer enabled on trigger rising edge, disabled on trigger falling edge, decrement on trigger edge.</td>
</tr>
<tr>
<td>TIMCTL1</td>
<td>0x0F03_0303</td>
<td>Configure timer output enabled on FXIO_D[3], external trigger 15 (comparator output) selected.</td>
</tr>
</tbody>
</table>

### 50.5 Memory Map and Registers

#### 50.5.1 FLEXIO Register Descriptions

##### 50.5.1.1 FLEXIO Memory Map

Base address: 401A_C000 for FlexIO1, 401B_0000 for FlexIO2, and 4202_0000 for FlexIO3.

**NOTE**

Number of Pin IO is $2^4$ for FlexIO1, $2^5$ for FlexIO2 and FlexIO3.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Version ID (VERID)</td>
<td>32</td>
<td>RO</td>
<td>01010001h</td>
</tr>
<tr>
<td>4h</td>
<td>Parameter (PARAM)</td>
<td>32</td>
<td>RO</td>
<td>02200404h</td>
</tr>
<tr>
<td>8h</td>
<td>FlexIO Control (CTRL)</td>
<td>32</td>
<td>RW</td>
<td>000000000h</td>
</tr>
<tr>
<td>Ch</td>
<td>Pin State (PIN)</td>
<td>32</td>
<td>RO</td>
<td>000000000h</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>10h</td>
<td>Shifter Status (SHIFTSTAT)</td>
<td>32</td>
<td>W1C</td>
<td>00000000h</td>
</tr>
<tr>
<td>14h</td>
<td>Shifter Error (SHIFTERR)</td>
<td>32</td>
<td>W1C</td>
<td>00000000h</td>
</tr>
<tr>
<td>18h</td>
<td>Timer Status (TIMSTAT)</td>
<td>32</td>
<td>W1C</td>
<td>00000000h</td>
</tr>
<tr>
<td>20h</td>
<td>Shifter Status Interrupt Enable (SHIFTSIEN)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>24h</td>
<td>Shifter Error Interrupt Enable (SHIFTEIEN)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>28h</td>
<td>Timer Interrupt Enable (TIMIEN)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>30h</td>
<td>Shifter Status DMA Enable (SHIFTSDEN)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>40h</td>
<td>Shifter State (SHIFTSTATE)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>80h - 8Ch</td>
<td>Shifter Control N (SHIFTCTL0 - SHIFTCTL3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>100h - 10Ch</td>
<td>Shifter Configuration N (SHIFTCFG0 - SHIFTCFG3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>200h - 20Ch</td>
<td>Shifter Buffer N (SHIFTBUF0 - SHIFTBUF3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>280h - 28Ch</td>
<td>Shifter Buffer N Bit Swapped (SHIFTBUFBIS0 - SHIFTBUFBIS3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>300h - 30Ch</td>
<td>Shifter Buffer N Byte Swapped (SHIFTUBYS0 - SHIFTUBYS3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>380h - 38Ch</td>
<td>Shifter Buffer N Bit Byte Swapped (SHIFTBUFBBS0 - SHIFTBUF BBS3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>400h - 40Ch</td>
<td>Timer Control N (TIMCTL0 - TIMCTL3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>480h - 48Ch</td>
<td>Timer Configuration N (TIMCFG0 - TIMCFG3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>500h - 50Ch</td>
<td>Timer Compare N (TIMCMP0 - TIMCMP3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>680h - 68Ch</td>
<td>Shifter Buffer NNibble Byte Swapped (SHIFTBUFNBS0 - SHIFTBUF NBS3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>700h - 70Ch</td>
<td>Shifter Buffer NHalf Word Swapped (SHIFTBUFHWS0 - SHIFTBUF HWS3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
<tr>
<td>780h - 78Ch</td>
<td>Shifter Buffer NNibble Swapped (SHIFTBUFNIS0 - SHIFTBUFNIS3)</td>
<td>32</td>
<td>RW</td>
<td>00000000h</td>
</tr>
</tbody>
</table>

### 50.5.1.2 Version ID (VERID)

#### 50.5.1.2.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>VERID</td>
<td>0h</td>
</tr>
</tbody>
</table>
50.5.1.2.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

50.5.1.2.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Major Version Number</td>
</tr>
<tr>
<td>MAJOR</td>
<td>This read only field returns the major version number for the module specification.</td>
</tr>
<tr>
<td>23-16</td>
<td>Minor Version Number</td>
</tr>
<tr>
<td>MINOR</td>
<td>This read only field returns the minor version number for the module specification.</td>
</tr>
<tr>
<td>15-0</td>
<td>Feature Specification Number</td>
</tr>
<tr>
<td>FEATURE</td>
<td>This read only field returns the feature set number.</td>
</tr>
<tr>
<td></td>
<td>0000000000000000b - Standard features implemented.</td>
</tr>
<tr>
<td></td>
<td>0000000000000001b - Supports state, logic and parallel modes.</td>
</tr>
</tbody>
</table>

50.5.1.3  Parameter (PARAM)

50.5.1.3.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PARAM</td>
<td>4h</td>
</tr>
</tbody>
</table>
50.5.1.3.2  Diagram

| Bits |    |    |    |    |    |    |    |    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |    |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 1  | 0  |    | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  |

| Bits |    |    |    |    |    |    |    |    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    | 15 | 14 | 13 | 12 | 11 | 10 |  9 |  8 |    |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  |

50.5.1.3.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Trigger Number</td>
</tr>
<tr>
<td>TRIGGER</td>
<td>Number of external triggers implemented.</td>
</tr>
<tr>
<td>23-16</td>
<td>Pin Number</td>
</tr>
<tr>
<td>PIN</td>
<td>Number of Pins implemented.</td>
</tr>
<tr>
<td>15-8</td>
<td>Timer Number</td>
</tr>
<tr>
<td>TIMER</td>
<td>Number of Timers implemented.</td>
</tr>
<tr>
<td>7-0</td>
<td>Shifter Number</td>
</tr>
<tr>
<td>SHIFTER</td>
<td>Number of Shifters implemented.</td>
</tr>
</tbody>
</table>

50.5.1.4  FlexIO Control (CTRL)

50.5.1.4.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL</td>
<td>8h</td>
</tr>
</tbody>
</table>
50.5.1.4.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>DOZE</td>
<td>DBG</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

R = Readable, W = Writable

50.5.1.4.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Doze Enable</td>
</tr>
<tr>
<td></td>
<td>Enables FlexIO operation in Doze modes.</td>
</tr>
<tr>
<td></td>
<td>0b - FlexIO enabled in Doze modes.</td>
</tr>
<tr>
<td></td>
<td>1b - FlexIO disabled in Doze modes.</td>
</tr>
<tr>
<td>30</td>
<td>Debug Enable</td>
</tr>
<tr>
<td></td>
<td>Enables FlexIO operation in Debug mode.</td>
</tr>
<tr>
<td></td>
<td>0b - FlexIO is disabled in debug modes.</td>
</tr>
<tr>
<td></td>
<td>1b - FlexIO is enabled in debug modes</td>
</tr>
<tr>
<td>29-3</td>
<td>—</td>
</tr>
<tr>
<td>2</td>
<td>Fast Access</td>
</tr>
<tr>
<td></td>
<td>Enables fast register accesses to FlexIO registers, but requires the FlexIO functional clock to be at least twice the frequency of the bus clock.</td>
</tr>
<tr>
<td></td>
<td>0b - Configures for normal register accesses to FlexIO</td>
</tr>
<tr>
<td></td>
<td>1b - Configures for fast register accesses to FlexIO</td>
</tr>
<tr>
<td>1</td>
<td>Software Reset</td>
</tr>
<tr>
<td></td>
<td>The FlexIO Control Register is not affected by the software reset, all other logic in the FlexIO is affected by the software reset and register accesses are ignored until this bit is cleared. This register bit will remain set until cleared by software, and the reset has cleared in the FlexIO clock domain.</td>
</tr>
<tr>
<td></td>
<td>0b - Software reset is disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Software reset is enabled, all FlexIO registers except the Control Register are reset.</td>
</tr>
<tr>
<td>0</td>
<td>FlexIO Enable</td>
</tr>
<tr>
<td></td>
<td>0b - FlexIO module is disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - FlexIO module is enabled.</td>
</tr>
</tbody>
</table>

50.5.1.5  Pin State (PIN)
50.5.1.5.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>PIN</td>
<td>Ch</td>
</tr>
</tbody>
</table>

50.5.1.5.2 Diagram

```
Bits 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
R     PDI
W     
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     PDI
W     
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

50.5.1.5.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Pin Data Input</td>
</tr>
<tr>
<td>PDI</td>
<td>Returns the input data on each of the FlexIO pins.</td>
</tr>
</tbody>
</table>

50.5.1.6 Shifter Status (SHIFTSTAT)

50.5.1.6.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTSTAT</td>
<td>10h</td>
</tr>
</tbody>
</table>
### 50.5.1.6.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>Shifter Status Flag</td>
</tr>
<tr>
<td>—</td>
<td>The shifter status flag is updated when one of the following events occurs:</td>
</tr>
<tr>
<td>3-0</td>
<td>For SMOD=Receive, the status flag is set when SHIFTBUF has been loaded with data from Shifter (SHIFTBUF is full), and the status flag is cleared when SHIFTBUF register is read.</td>
</tr>
<tr>
<td>SSF</td>
<td>For SMOD=Transmit, the status flag is set when SHIFTBUF data has been transferred to the Shifter (SHIFTBUF is empty) or when initially configured for SMOD=Transmit, and the status flag is cleared when the SHIFTBUF register is written.</td>
</tr>
<tr>
<td></td>
<td>For SMOD=Match Store, the status flag is set when a match has occurred between SHIFTBUF and Shifter, and the status flag is cleared when the SHIFTBUF register is read.</td>
</tr>
<tr>
<td></td>
<td>For SMOD=Match Continuous, returns the current match result between the SHIFTBUF and Shifter.</td>
</tr>
<tr>
<td></td>
<td>For SMOD=State, the status flag for a shifter will set when it is selected by the current state pointer.</td>
</tr>
<tr>
<td></td>
<td>For SMOD=Logic, returns the current value of the programmable logic block output.</td>
</tr>
<tr>
<td></td>
<td>The status flag can also be cleared by writing a logic one to the flag for all modes except Match Continuous/State/Logic.</td>
</tr>
<tr>
<td></td>
<td>0b - Status flag is clear.</td>
</tr>
<tr>
<td></td>
<td>1b - Status flag is set.</td>
</tr>
</tbody>
</table>

### 50.5.1.7 Shifter Error (SHIFTERR)

#### 50.5.1.7.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTERR</td>
<td>14h</td>
</tr>
</tbody>
</table>
50.5.1.7.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEF</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>—</td>
</tr>
<tr>
<td>3-0</td>
<td>SEF</td>
</tr>
</tbody>
</table>

Shifter Error Flags

The shifter error flag is set when one of the following events occurs:

For SMOD=Receive, indicates Shifter was ready to store new data into SHIFTBUF before the previous data was read from SHIFTBUF (SHIFTBUF Overrun), or indicates that the received start or stop bit does not match the expected value.

For SMOD=Transmit, indicates Shifter was ready to load new data from SHIFTBUF before new data had been written into SHIFTBUF (SHIFTBUF Underrun).

For SMOD=Match Store, indicates a match event occurred before the previous match data was read from SHIFTBUF (SHIFTBUF Overrun).

For SMOD=Match Continuous, the error flag is set when a match has occurred between SHIFTBUF and Shifter.

For SMOD=Logic, the error flag is set when the output of the programmable logic block has asserted.

Can be cleared by writing logic one to the flag. For SMOD=Match Continuous, can also be cleared when the SHIFTBUF register is read.

0b - Shifter Error Flag is clear.
1b - Shifter Error Flag is set.

50.5.1.8 Timer Status (TIMSTAT)
### 50.5.1.8.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMSTAT</td>
<td>18h</td>
</tr>
</tbody>
</table>

### 50.5.1.8.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>—</td>
</tr>
</tbody>
</table>
| 3-0   | Timer Status Flags  

The timer status flag sets depending on the timer mode, and can be cleared by writing logic one to the flag. 

In 8-bit counter mode, the timer status flag is set when the upper 8-bit counter equals zero and decrements, this also causes the counter to reload with the value in the compare register. 

In 8-bit PWM mode, the timer status flag is set when the upper 8-bit counter equals zero and decrements, this also causes the counter to reload with the value in the compare register. 

In 16-bit counter mode, the timer status flag is set when the 16-bit counter equals zero and decrements, this also causes the counter to reload with the value in the compare register.

- 0b - Timer Status Flag is clear.  
- 1b - Timer Status Flag is set.

### 50.5.1.9 Shifter Status Interrupt Enable (SHIFTSIEN)
50.5.1.9.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTSIEN</td>
<td>20h</td>
</tr>
</tbody>
</table>

50.5.1.9.2 Diagram

50.5.1.9.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>—</td>
</tr>
<tr>
<td>3-0</td>
<td>Shifter Status Interrupt Enable</td>
</tr>
<tr>
<td>SSIE</td>
<td>Enables interrupt generation when corresponding SSF is set.</td>
</tr>
</tbody>
</table>

  0b - Shifter Status Flag interrupt disabled.  
  1b - Shifter Status Flag interrupt enabled.

50.5.1.10 Shifter Error Interrupt Enable (SHIFTEIEN)

50.5.1.10.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTEIEN</td>
<td>24h</td>
</tr>
</tbody>
</table>
50.5.1.10.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

50.5.1.10.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>_</td>
</tr>
<tr>
<td>3-0</td>
<td>Shifter Error Interrupt Enable</td>
</tr>
<tr>
<td>SEIE</td>
<td>Enables interrupt generation when corresponding SEF is set.</td>
</tr>
<tr>
<td></td>
<td>0b - Shifter Error Flag interrupt disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Shifter Error Flag interrupt enabled.</td>
</tr>
</tbody>
</table>

50.5.1.11  Timer Interrupt Enable (TIMIEN)

50.5.1.11.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMIEN</td>
<td>28h</td>
</tr>
</tbody>
</table>
50.5.1.11.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TEIE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

50.5.1.11.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td></td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>3-0</td>
<td>Timer Status Interrupt Enable</td>
</tr>
<tr>
<td>TEIE</td>
<td>Enables interrupt generation when corresponding TSF is set.</td>
</tr>
<tr>
<td></td>
<td>0b - Timer Status Flag interrupt is disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Timer Status Flag interrupt is enabled.</td>
</tr>
</tbody>
</table>

50.5.1.12  Shifter Status DMA Enable (SHIFTSDEN)

50.5.1.12.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTSDEN</td>
<td>30h</td>
</tr>
</tbody>
</table>
50.5.1.12.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

50.5.1.12.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-4</td>
<td>—</td>
</tr>
<tr>
<td>3-0</td>
<td>SSDE</td>
</tr>
</tbody>
</table>

SSDE: Shifter Status DMA Enable

- Enables DMA request generation when corresponding SSF is set.
- 0b - Shifter Status Flag DMA request is disabled.
- 1b - Shifter Status Flag DMA request is enabled.

50.5.1.13  Shifter State (SHIFTSTATE)

50.5.1.13.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTSTATE</td>
<td>40h</td>
</tr>
</tbody>
</table>
50.5.1.13.2  Diagram

### Bits

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

50.5.1.13.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-3</td>
<td>—</td>
</tr>
<tr>
<td>2-0</td>
<td>STATE</td>
</tr>
<tr>
<td></td>
<td>Current State Pointer</td>
</tr>
</tbody>
</table>

The current state field maintains a pointer to keep track of the current Shifter (configured for State mode) enabled to drive outputs and compute the next state. Reading this register when the state pointer is updating can result in the incorrect state returned.

50.5.1.14  Shifter Control N (SHIFTCTLa)

50.5.1.14.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCTL0</td>
<td>80h</td>
</tr>
<tr>
<td>SHIFTCTL1</td>
<td>84h</td>
</tr>
<tr>
<td>SHIFTCTL2</td>
<td>88h</td>
</tr>
<tr>
<td>SHIFTCTL3</td>
<td>8Ch</td>
</tr>
</tbody>
</table>
50.5.1.14.2 Diagram

Bits | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
--- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     | PINCFG
Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Bits | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
--- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
R   | 0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
W   |     |     |     |     |     |     |     | PINSEL |     |     |     |     |     |     | PINPOL | SMOD
Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

50.5.1.14.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-26</td>
<td>_</td>
</tr>
<tr>
<td>25-24</td>
<td><strong>TIMSEL</strong>&lt;br&gt;Timer Select&lt;br&gt;Selects which Timer is used for controlling the logic/shift register and generating the Shift clock.&lt;br&gt;TIMSEL=i will select TIMERi.</td>
</tr>
<tr>
<td>23</td>
<td><strong>TIMPOL</strong>&lt;br&gt;Timer Polarity&lt;br&gt;0b - Shift on posedge of Shift clock&lt;br&gt;1b - Shift on negedge of Shift clock</td>
</tr>
<tr>
<td>22-18</td>
<td>_</td>
</tr>
<tr>
<td>17-16</td>
<td><strong>PINCFG</strong>&lt;br&gt;Shifter Pin Configuration&lt;br&gt;00b - Shifter pin output disabled&lt;br&gt;01b - Shifter pin open drain or bidirectional output enable&lt;br&gt;10b - Shifter pin bidirectional output data&lt;br&gt;11b - Shifter pin output</td>
</tr>
<tr>
<td>15-13</td>
<td>_</td>
</tr>
<tr>
<td>12-8</td>
<td><strong>PINSEL</strong>&lt;br&gt;Shifter Pin Select&lt;br&gt;Selects which pin is used by the Shifter input or output. PINSEL=i will select the FXIO_Di pin.</td>
</tr>
<tr>
<td>7</td>
<td><strong>PINPOL</strong>&lt;br&gt;Shifter Pin Polarity&lt;br&gt;0b - Pin is active high&lt;br&gt;1b - Pin is active low</td>
</tr>
<tr>
<td>6-3</td>
<td>_</td>
</tr>
<tr>
<td>2-0</td>
<td><strong>SMOD</strong>&lt;br&gt;Shifter Mode&lt;br&gt;Configures the mode of the Shifter.&lt;br&gt;000b - Disabled.</td>
</tr>
</tbody>
</table>
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>001b</td>
<td>Receive mode. Captures the current Shifter content into the SHIFTBUF on expiration of the Timer.</td>
</tr>
<tr>
<td>010b</td>
<td>Transmit mode. Load SHIFTBUF contents into the Shifter on expiration of the Timer.</td>
</tr>
<tr>
<td>011b</td>
<td>Reserved.</td>
</tr>
<tr>
<td>100b</td>
<td>Match Store mode. Shifter data is compared to SHIFTBUF content on expiration of the Timer.</td>
</tr>
<tr>
<td>101b</td>
<td>Match Continuous mode. Shifter data is continuously compared to SHIFTBUF contents.</td>
</tr>
<tr>
<td>110b</td>
<td>State mode. SHIFTBUF contents are used for storing programmable state attributes.</td>
</tr>
<tr>
<td>111b</td>
<td>Logic mode. SHIFTBUF contents are used for implementing programmable logic look up table.</td>
</tr>
</tbody>
</table>

### 50.5.1.15 Shifter Configuration N (SHIFTCFGa)

#### 50.5.1.15.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTCFG0</td>
<td>100h</td>
</tr>
<tr>
<td>SHIFTCFG1</td>
<td>104h</td>
</tr>
<tr>
<td>SHIFTCFG2</td>
<td>108h</td>
</tr>
<tr>
<td>SHIFTCFG3</td>
<td>10Ch</td>
</tr>
</tbody>
</table>

#### 50.5.1.15.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### 50.5.1.15.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-21</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field: Parallel Width

For all Shifters, this register field configures the number of bits to be shifted on each Shift clock as follows:

- 1-bit shift for PWIDTH=0
- 4-bit shift for PWIDTH=1...3
- 8-bit shift for PWIDTH=4...7
- 16-bit shift for PWIDTH=8...15
- 32-bit shift for PWIDTH=16...31

For Shifters which support parallel transmit (SHIFTER0, SHIFTER4) or parallel receive (SHIFTER3, SHIFTER7), this register field, together with SHIFTCTL[PINSEL], also selects the pins to be driven or sampled on each Shift clock as follows:

FXIO_D[PINSEL+PWIDTH]:FXIO_D[PINSEL]

For SMOD=State, this field is used to disable state outputs. See 'State Mode' section for more detail.

### Field: Input Source

Selects the input source for the shifter.

- 0b - Pin
- 1b - Shifter N+1 Output

### Field: Shifter Stop bit

For SMOD=Transmit, this field allows automatic stop bit insertion if the selected timer has also enabled a stop bit.

For SMOD=Receive or Match Store, this field allows automatic stop bit checking if the selected timer has also enabled a stop bit.

For SMOD=State, this field is used to disable state outputs. See 'State Mode' section for more detail.

For SMOD=Logic, this field is used to mask logic pin inputs. See 'Logic Mode' section for more detail.

- 00b - Stop bit disabled for transmitter/receiver/match store
- 01b - Reserved for transmitter/receiver/match store
- 10b - Transmitter outputs stop bit value 0 on store, receiver/match store sets error flag if stop bit is not 0
- 11b - Transmitter outputs stop bit value 1 on store, receiver/match store sets error flag if stop bit is not 1

### Field: Shifter Start bit

For SMOD=Transmit, this field allows automatic start bit insertion if the selected timer has also enabled a start bit.
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Shift Buffer</td>
</tr>
<tr>
<td>SHIFTBUF</td>
<td>Shift buffer data is used for a variety of functions depending on the SMOD setting:</td>
</tr>
</tbody>
</table>

For SMOD=Receive or Match Store, this field allows automatic start bit checking if the selected timer has also enabled a start bit.

For SMOD=State, this field is used to disable state outputs. See ‘State Mode’ section for more detail.

For SMOD=Logic, this field is used to mask logic pin inputs. See ‘Logic Mode’ section for more detail.

<table>
<thead>
<tr>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00b</td>
<td>Start bit disabled for transmitter/receiver/match store, transmitter loads data on enable</td>
</tr>
<tr>
<td>01b</td>
<td>Start bit disabled for transmitter/receiver/match store, transmitter loads data on first shift</td>
</tr>
<tr>
<td>10b</td>
<td>Transmitter outputs start bit value 0 before loading data on first shift, receiver/match store sets error flag if start bit is not 0</td>
</tr>
<tr>
<td>11b</td>
<td>Transmitter outputs start bit value 1 before loading data on first shift, receiver/match store sets error flag if start bit is not 1</td>
</tr>
</tbody>
</table>

#### 50.5.1.16 Shifter Buffer N (SHIFTBUFa)

##### 50.5.1.16.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUF0</td>
<td>200h</td>
</tr>
<tr>
<td>SHIFTBUF1</td>
<td>204h</td>
</tr>
<tr>
<td>SHIFTBUF2</td>
<td>208h</td>
</tr>
<tr>
<td>SHIFTBUF3</td>
<td>20Ch</td>
</tr>
</tbody>
</table>

##### 50.5.1.16.2 Diagram

#### 50.5.1.16.3 Fields
Field | Function  
---|---
For SMOD=Receive, Shifter data is transferred into SHIFTBUF at the expiration of Timer. The SHIFTBUF register should only be read when the corresponding shifter status flag is set, indicating new Shifter data is available.
For SMOD=Transmit, SHIFTBUF data is transferred into the Shifter before the Timer begins.
For SMOD=Match Store, SHIFTBUF[31:16] contains the data to be matched with the Shifter contents and SHIFTBUF[15:0] can be used to mask the match result (1=mask, 0=no mask). The Match is checked when the Timer expires and Shifter data [31:16] is written to SHIFTBUF[31:16] whenever a match event occurs. The SHIFTBUF register should only be read when the corresponding shifter status flag is set, indicating new Shifter data is available.
For SMOD=Match Continuous, SHIFTBUF[31:16] contains the data to be matched with the Shifter contents and SHIFTBUF[15:0] can be used to mask the match result (1=mask, 0=no mask).
For SMOD=Logic, SHIFTBUF[31:0] is used to implement a 5-input, 32-bit programmable logic look-up table. See 'Logic Mode' section for more detail.
For SMOD=State, SHIFTBUF[31:24] is used to drive the output value when this shifter is selected by the current state pointer and SHIFTBUF[23:0] is used to configure the value of the next state transition. See 'State Mode' section for more detail.

### 50.5.1.17 Shifter Buffer N Bit Swapped (SHIFTBUFBISa)

#### 50.5.1.17.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUFBIS0</td>
<td>280h</td>
</tr>
<tr>
<td>SHIFTBUFBIS1</td>
<td>284h</td>
</tr>
<tr>
<td>SHIFTBUFBIS2</td>
<td>288h</td>
</tr>
<tr>
<td>SHIFTBUFBIS3</td>
<td>28Ch</td>
</tr>
</tbody>
</table>

#### 50.5.1.17.2 Diagram

```
<table>
<thead>
<tr>
<th></th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```
### 50.5.1.17.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0 SHIFTBUFBIS</td>
<td>Shift Buffer Alias to SHIFTBUF register, except reads/writes to this register are bit swapped. Reads return SHIFTBUF[0:31].</td>
</tr>
</tbody>
</table>

### 50.5.1.18 Shifter Buffer N Byte Swapped (SHIFTBUFBYSa)

#### 50.5.1.18.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUFBYS0</td>
<td>300h</td>
</tr>
<tr>
<td>SHIFTBUFBYS1</td>
<td>304h</td>
</tr>
<tr>
<td>SHIFTBUFBYS2</td>
<td>308h</td>
</tr>
<tr>
<td>SHIFTBUFBYS3</td>
<td>30Ch</td>
</tr>
</tbody>
</table>

#### 50.5.1.18.2 Diagram

![Diagram](image)

#### 50.5.1.18.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0 SHIFTBUFBYS</td>
<td>Shift Buffer Alias to SHIFTBUF register, except reads/writes to this register are byte swapped. Reads return { SHIFTBUF[7:0], SHIFTBUF[15:8], SHIFTBUF[23:16], SHIFTBUF[31:24] }.</td>
</tr>
</tbody>
</table>

---

**Chapter 50 Flexible I/O (FlexIO)**

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
50.5.1.19  Shifter Buffer N Bit Byte Swapped (SHIFTBUFBBBSa)

50.5.1.19.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUFBBBS0</td>
<td>380h</td>
</tr>
<tr>
<td>SHIFTBUFBBBS1</td>
<td>384h</td>
</tr>
<tr>
<td>SHIFTBUFBBBS2</td>
<td>388h</td>
</tr>
<tr>
<td>SHIFTBUFBBBS3</td>
<td>38Ch</td>
</tr>
</tbody>
</table>

50.5.1.19.2  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Bits 15-0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

50.5.1.19.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Shift Buffer</td>
</tr>
</tbody>
</table>
| SHIFTBUFBBBS | Alias to SHIFTBUF register, except reads/writes to this register are bit swapped within each byte. Reads return { SHIFTBUF[24:31], SHIFTBUF[16:23], SHIFTBUF[8:15], SHIFTBUF[0:7] }.

50.5.1.20  Timer Control N (TIMCTLa)
### 50.5.1.20.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCTL0</td>
<td>400h</td>
</tr>
<tr>
<td>TIMCTL1</td>
<td>404h</td>
</tr>
<tr>
<td>TIMCTL2</td>
<td>408h</td>
</tr>
<tr>
<td>TIMCTL3</td>
<td>40Ch</td>
</tr>
</tbody>
</table>

### 50.5.1.20.2 Diagram

#### Bits 31-30

<table>
<thead>
<tr>
<th>R</th>
<th>TRGSEL</th>
<th>W</th>
<th>TRGP</th>
<th>TRGS</th>
<th>RC</th>
<th>PINCFG</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### Bits 29-24

<table>
<thead>
<tr>
<th>R</th>
<th>PINSEL</th>
<th>W</th>
<th>PINP</th>
<th>TIMOD</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### 50.5.1.20.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-30</td>
<td>—</td>
</tr>
</tbody>
</table>

#### Field 29-24

TRGSEL

- Trigger Select

The valid values for TRGSEL will depend on the FLEXIO_PARAM register.

- When TRGSRC = 1, the valid values for N will depend on PIN, TIMER, SHIFTER fields in the FLEXIO_PARAM register.
- When TRGSRC = 0, the valid values for N will depend on TRIGGER field in FLEXIO_PARAM register.

Refer to the chip configuration section for external trigger selection.

**NOTE:** For a pin, N=0 to 31. For a Shifter/Timer, N=0 to 3.

The internal trigger selection is configured as follows:

- $4^*N$ - Pin $2^*N$ input
- $4^*N+1$ - Shifter $N$ status flag
- $4^*N+2$ - Pin $2^*N+1$ input
- $4^*N+3$ - Timer $N$ trigger output

#### Field 23

TRGPOL

- Trigger Polarity

  0b - Trigger active high
  1b - Trigger active low

#### Field 22

Trigger Source

*Table continues on the next page...*
### Memory Map and Registers

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRGSRC</td>
<td>0b - External trigger selected</td>
</tr>
<tr>
<td></td>
<td>1b - Internal trigger selected</td>
</tr>
<tr>
<td>21-18</td>
<td></td>
</tr>
<tr>
<td>17-16</td>
<td>Timer Pin Configuration</td>
</tr>
<tr>
<td>PINCFG</td>
<td>00b - Timer pin output disabled</td>
</tr>
<tr>
<td></td>
<td>01b - Timer pin open drain or bidirectional output enable</td>
</tr>
<tr>
<td></td>
<td>10b - Timer pin bidirectional output data</td>
</tr>
<tr>
<td></td>
<td>11b - Timer pin output</td>
</tr>
<tr>
<td>15-13</td>
<td></td>
</tr>
<tr>
<td>12-8</td>
<td>Timer Pin Select</td>
</tr>
<tr>
<td>PINSEL</td>
<td>Selects which pin is used by the Timer input or output. PINSEL=i will select the FXIO_Di pin.</td>
</tr>
<tr>
<td>7</td>
<td>Timer Pin Polarity</td>
</tr>
<tr>
<td>PINPOL</td>
<td>0b - Pin is active high</td>
</tr>
<tr>
<td></td>
<td>1b - Pin is active low</td>
</tr>
<tr>
<td>6-2</td>
<td></td>
</tr>
<tr>
<td>1-0</td>
<td>Timer Mode</td>
</tr>
<tr>
<td>TIMOD</td>
<td>In 8-bit baud counter mode, the lower 8-bits of the counter and compare register are used to configure the baud rate of the timer shift clock, and the upper 8-bits are used to configure the shifter bit count.</td>
</tr>
<tr>
<td></td>
<td>In 8-bit PWM high mode, the lower 8-bits of the counter and compare register are used to configure the high period of the timer shift clock, and the upper 8-bits are used to configure the low period of the timer shift clock. The shifter bit count is configured using another timer or external signal.</td>
</tr>
<tr>
<td></td>
<td>In 16-bit counter mode, the full 16-bits of the counter and compare register are used to configure either the baud rate of the shift clock or the shifter bit count.</td>
</tr>
<tr>
<td></td>
<td>00b - Timer Disabled.</td>
</tr>
<tr>
<td></td>
<td>01b - Dual 8-bit counters baud mode.</td>
</tr>
<tr>
<td></td>
<td>10b - Dual 8-bit counters PWM high mode.</td>
</tr>
<tr>
<td></td>
<td>11b - Single 16-bit counter mode.</td>
</tr>
</tbody>
</table>

### 50.5.1.21 Timer Configuration N (TIMCFGa)

#### 50.5.1.21.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCFG0</td>
<td>480h</td>
</tr>
<tr>
<td>TIMCFG1</td>
<td>484h</td>
</tr>
<tr>
<td>TIMCFG2</td>
<td>488h</td>
</tr>
<tr>
<td>TIMCFG3</td>
<td>48Ch</td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
50.5.1.21.2  Function

The options to enable or disable the timer using the Timer N-1 enable or disable are reserved when N is evenly divisible by 4 (eg: Timer 0).

NOTE
The pin and trigger level/edges specified below refer to the signal state after being modified by the PINPOL or TRGPOL setting in the TIMCTL register. For example, "Trigger low" means a trigger is actually at logic level 1 if the TRGPOL is set to 1 (active low).

50.5.1.21.3  Diagram

50.5.1.21.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-26</td>
<td>—</td>
</tr>
<tr>
<td>25-24</td>
<td>TIMOUT</td>
</tr>
<tr>
<td>23-22</td>
<td>—</td>
</tr>
<tr>
<td>21-20</td>
<td>TIMDEC</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>19</td>
<td><strong>11b</strong> - Decrement counter on Trigger input (both edges), Shift clock equals Trigger input.</td>
</tr>
<tr>
<td>18-16</td>
<td>TIMRST</td>
</tr>
<tr>
<td></td>
<td><strong>Timer Reset</strong></td>
</tr>
<tr>
<td></td>
<td>Configures the condition that causes the timer counter (and optionally the timer output) to be reset. In 8-bit counter mode, the timer reset will only reset the lower 8-bits that configure the baud rate. In all other modes, the timer reset will reset the full 16-bits of the counter.</td>
</tr>
<tr>
<td></td>
<td>000b - Timer never reset</td>
</tr>
<tr>
<td></td>
<td>001b - Reserved</td>
</tr>
<tr>
<td></td>
<td>010b - Timer reset on Timer Pin equal to Timer Output</td>
</tr>
<tr>
<td></td>
<td>011b - Timer reset on Timer Trigger equal to Timer Output</td>
</tr>
<tr>
<td></td>
<td>100b - Timer reset on Timer Pin rising edge</td>
</tr>
<tr>
<td></td>
<td>101b - Reserved</td>
</tr>
<tr>
<td></td>
<td>110b - Timer reset on Trigger rising edge</td>
</tr>
<tr>
<td></td>
<td>111b - Timer reset on Trigger rising or falling edge</td>
</tr>
<tr>
<td>15</td>
<td>TIMDIS</td>
</tr>
<tr>
<td></td>
<td><strong>Timer Disable</strong></td>
</tr>
<tr>
<td></td>
<td>Configures the condition that causes the Timer to be disabled and stop decrementing.</td>
</tr>
<tr>
<td></td>
<td>000b - Timer never disabled</td>
</tr>
<tr>
<td></td>
<td>001b - Timer disabled on Timer N-1 disable</td>
</tr>
<tr>
<td></td>
<td>010b - Timer disabled on Timer compare</td>
</tr>
<tr>
<td></td>
<td>011b - Timer disabled on Timer compare and Trigger Low</td>
</tr>
<tr>
<td></td>
<td>100b - Timer disabled on Pin rising or falling edge</td>
</tr>
<tr>
<td></td>
<td>101b - Timer disabled on Pin rising or falling edge provided Trigger is high</td>
</tr>
<tr>
<td></td>
<td>110b - Timer disabled on Trigger falling edge</td>
</tr>
<tr>
<td></td>
<td>111b - Reserved</td>
</tr>
<tr>
<td>11</td>
<td>TIMENA</td>
</tr>
<tr>
<td></td>
<td><strong>Timer Enable</strong></td>
</tr>
<tr>
<td></td>
<td>Configures the condition that causes the Timer to be enabled and start decrementing.</td>
</tr>
<tr>
<td></td>
<td>000b - Timer always enabled</td>
</tr>
<tr>
<td></td>
<td>001b - Timer enabled on Timer N-1 enable</td>
</tr>
<tr>
<td></td>
<td>010b - Timer enabled on Trigger high</td>
</tr>
<tr>
<td></td>
<td>011b - Timer enabled on Trigger high and Pin high</td>
</tr>
<tr>
<td></td>
<td>100b - Timer enabled on Pin rising edge</td>
</tr>
<tr>
<td></td>
<td>101b - Timer enabled on Pin rising edge and Trigger high</td>
</tr>
<tr>
<td></td>
<td>110b - Timer enabled on Trigger rising edge</td>
</tr>
<tr>
<td></td>
<td>111b - Timer enabled on Trigger rising or falling edge</td>
</tr>
<tr>
<td>7-6</td>
<td>TSTOP</td>
</tr>
<tr>
<td></td>
<td><strong>Timer Stop Bit</strong></td>
</tr>
<tr>
<td></td>
<td>The stop bit can be added on a timer compare (between each word) or on a timer disable. When stop bit is enabled, configured shifters will output the contents of the stop bit when the timer is disabled. When stop bit is enabled on timer disable, the timer remains disabled until the next rising edge of the shift clock. If configured for both timer compare and timer disable, only one stop bit is inserted on timer disable.</td>
</tr>
<tr>
<td></td>
<td>00b - Stop bit disabled</td>
</tr>
<tr>
<td></td>
<td>01b - Stop bit is enabled on timer compare</td>
</tr>
<tr>
<td></td>
<td>10b - Stop bit is enabled on timer disable</td>
</tr>
<tr>
<td></td>
<td>11b - Stop bit is enabled on timer compare and timer disable</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Field | Function
---|---
3-2 | —
1 TSTART | Timer Start Bit
When start bit is enabled, configured shifters will output the contents of the start bit when the timer is enabled and the timer counter will reload from the compare register on the first rising edge of the shift clock.

0b - Start bit disabled
1b - Start bit enabled

0 | —

50.5.1.22  Timer Compare N (TIMCMPa)

50.5.1.22.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TIMCMP0</td>
<td>500h</td>
</tr>
<tr>
<td>TIMCMP1</td>
<td>504h</td>
</tr>
<tr>
<td>TIMCMP2</td>
<td>508h</td>
</tr>
<tr>
<td>TIMCMP3</td>
<td>50Ch</td>
</tr>
</tbody>
</table>

50.5.1.22.2  Diagram

| Bits | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| R | | | | | | | | | | | | | | | |
| W | 0 | | | | | | | | | | | | | | |
| Reset | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 |

| Bits | 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| R | | | | | | | | | | | | | | | |
| W | | | | | | | | CMP | | | | | | | |
| Reset | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 |

50.5.1.22.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td></td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Field | Function
---|---
15-0 | Timer Compare Value

The timer compare value is loaded into the timer counter when the timer is first enabled, when the timer is reset and when the timer decrements down to zero.

In 8-bit baud counter mode, the lower 8-bits configure the baud rate divider equal to \((\text{CMP}[7:0] + 1) * 2\). The upper 8-bits configure the number of bits in each word equal to \((\text{CMP}[15:8] + 1) / 2\).

In 8-bit PWM high mode, the lower 8-bits configure the high period of the output to \((\text{CMP}[7:0] + 1)\) and the upper 8-bits configure the low period of the output to \((\text{CMP}[15:8] + 1)\).

In 16-bit counter mode, the compare value can be used to generate the baud rate divider (if shift clock source is timer output) to equal \((\text{CMP}[15:0] + 1) * 2\). When the shift clock source is a pin or trigger input, the compare register is used to set the number of bits in each word equal to \((\text{CMP}[15:0] + 1) / 2\).

## 50.5.1.23 Shifter Buffer N Nibble Byte Swapped (SHIFTBUFNBSa)

### 50.5.1.23.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUFNBS0</td>
<td>680h</td>
</tr>
<tr>
<td>SHIFTBUFNBS1</td>
<td>684h</td>
</tr>
<tr>
<td>SHIFTBUFNBS2</td>
<td>688h</td>
</tr>
<tr>
<td>SHIFTBUFNBS3</td>
<td>68Ch</td>
</tr>
</tbody>
</table>

### 50.5.1.23.2 Diagram

![Diagram of SHIFTBUFNBS](image-url)
### 50.5.1.23.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Shift Buffer</td>
</tr>
<tr>
<td>SHIFTBUFNBS</td>
<td>Alias to SHIFTBUF register, except reads/writes to this register are nibble swapped within each byte. Reads return { SHIFTBUF[27:24], SHIFTBUF[31:28], SHIFTBUF[19:16], SHIFTBUF[23:20], SHIFTBUF[11:8], SHIFTBUF[15:12], SHIFTBUF[3:0], SHIFTBUF[7:4] }.</td>
</tr>
</tbody>
</table>

### 50.5.1.24 Shifter Buffer N Half Word Swapped (SHIFTBUFHWSa)

#### 50.5.1.24.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUFHWS0</td>
<td>700h</td>
</tr>
<tr>
<td>SHIFTBUFHWS1</td>
<td>704h</td>
</tr>
<tr>
<td>SHIFTBUFHWS2</td>
<td>708h</td>
</tr>
<tr>
<td>SHIFTBUFHWS3</td>
<td>70Ch</td>
</tr>
</tbody>
</table>

#### 50.5.1.24.2 Diagram

![Diagram](image)

#### 50.5.1.24.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Shift Buffer</td>
</tr>
<tr>
<td>SHIFTBUFHWS</td>
<td>Alias to SHIFTBUF register, except reads/writes to this register are half word swapped. Reads return { SHIFTBUF[15:0], SHIFTBUF[31:16] }.</td>
</tr>
</tbody>
</table>
50.5.1.25  Shifter Buffer N Nibble Swapped (SHIFTBUFNISa)

50.5.1.25.1  Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SHIFTBUFNIS0</td>
<td>780h</td>
</tr>
<tr>
<td>SHIFTBUFNIS1</td>
<td>784h</td>
</tr>
<tr>
<td>SHIFTBUFNIS2</td>
<td>788h</td>
</tr>
<tr>
<td>SHIFTBUFNIS3</td>
<td>78Ch</td>
</tr>
</tbody>
</table>

50.5.1.25.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

50.5.1.25.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Shift Buffer, Alias to SHIFTBUF register, except reads/writes to this register are nibble swapped. Reads return { SHIFTBUF[3:0], SHIFTBUF[7:4], SHIFTBUF[11:8], SHIFTBUF[15:12], SHIFTBUF[19:16], SHIFTBUF[23:20], SHIFTBUF[27:24], SHIFTBUF[31:28] }.</td>
</tr>
</tbody>
</table>
Chapter 51
Timers Overview

51.1 Overview
The following timers are supported in this chip:

- General Purpose Timer (GPT): A 32-bit up-counter with 12-bit pre-scaler
- Periodic Interrupt Timer (PIT): A 32-bit counter timer that features programmable count modulus, clock division features etc.
- Quad Timer (TMR): It provides four timer channels with variety of controls for individual and multi-channel features
- Quadrature Encoder/Decoder (ENC): It provides interfacing capability to position/speed sensors
- Enhanced FlexPWM: It contains PWM submodules each of which is set up to control a single half bridge power stage
- Watchdog Timer (WDOG1,2): The WDOG1 and WDOG2 protect against system failures by providing a method by which to escape from unexpected events or programming errors
- Watchdog timer (RTWDOG/WDOG3): It is a high reliability independent timer that is available for system use
- External Watchdog Monitor (EWM): It is designed to monitor external circuits, as well as the MCU software flow

51.1.1 General Purpose Timer (GPT)
The GPT has a 32-bit up-counter. The timer counter value can be captured in a register using an event on an external pin. The capture trigger can be programmed to be a rising or/and falling edge.

The GPT has a 12-bit pre-scaler, which provides a programmable clock frequency derived from multiple clock sources.
51.1.2 Periodic Interrupt Timer (PIT)

The PIT is a basic 32 bit counter timer. It features 32-bit counter timer, programmable count modulus, clock division features, interrupt generation, and a slave mode to synchronize count enable for multiple PITs.

51.1.3 Quad Timer (TMR)

The quad-timer provides four timer channels. Specific features include up/down count, cascading of counters, programmable modulo, count once/repeated, counter preload, compare registers with preload, shared use of input signals, prescaler controls, independent capture/compare, fault input control, programmable input filters, and multi-channel synchronization.

As shown in diagram below, input of QTimer can be sourced from PADs or XBAR1:

51.1.4 Enhanced Flex Pulse Width Modulator (eFlexPWM)

This module can generate various switching patterns, including highly sophisticated waveforms. Each module shall be configured with 4 channels supporting A, B, and X PWM output. All channels are configured for standard edge placement and have their capture function enabled.
51.1.5 Quadrature Encoder/Decoder (ENC)

The enhanced quadrature Encoder/decoder module provides interfacing capability to position/speed sensors used in industrial motor control applications. It has five input signals: PHASEA, PHASEB, INDEX, TRIGGER, and HOME. This module is used to decode shaft position, revolution count and speed.

51.1.6 Watchdog Timer (WDOG1,2)

The WDOG1 and WDOG2 protect against system failures by providing a method by which to escape from unexpected events or programming errors.

After WDOG1 and WDOG2 are activated, it must be serviced by the software on a periodic basis. If servicing does not take place, the timer times out. Upon timeout, the WDOG1 asserts the internal system reset signal, WDOG_RESET_B_DEB to the System Reset Controller (SRC); and WDOG2 asserts interrupt to SNVS to report the security violation condition.

51.1.7 Watchdog Timer (RTWDOG /WDOG3)

The WDOG3 module is an high reliability independent timer that is available for system use.

It provides a safety feature to ensure that software is executing as planned and that the CPU is not stuck in an infinite loop or executing unintended code. If the WDOG module is not serviced (refreshed) within a certain period, it resets the MCU.

The WDOG3 clock can be sourced from:

- 1MHz RC OSC
- 32KHz clock generated by 32 KHZ XTALOSC which could be automatically switched to 32KHz RC OSC upon XTAL clock loss
- IP Bus Clock

51.1.8 External Watchdog Monitor (EWM)

The External Watchdog Monitor provides a back-up mechanism to the internal WDOG that can reset the system. The EWM differs from the internal WDOG in that it does not reset the system.
The EWM, if allowed to time-out, provides an independent trigger pin that when asserted resets or places an external circuit into a safe mode.

The EWM clock can be sourced from:

- 1MHz RC OSC
- 32KHz clock generated by 32 KHZ XTALOSC which could be automatically switched to 32KHz RC OSC upon XTAL clock loss
- IP Bus Clock
Chapter 52  
General Purpose Timer (GPT)

52.1 Chip-specific GPT information

Table 52-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

52.2 Overview

This chapter describes the General Purpose Timer (GPT) module interface. It is also a reference for software driver programming. The GPT has a 32-bit up-counter. The timer counter value can be captured in a register using an event on an external pin. The capture trigger can be programmed to be a rising or/and falling edge. The GPT can also generate an event on the output compare pins and an interrupt when the timer reaches a programmed value. The GPT has a 12-bit prescaler, which provides a programmable clock frequency derived from multiple clock sources.
Figure 52-1. GPT Block Diagram
52.2.1 Features

- One 32-bit up-counter with clock source selection, including external clock.
- Two input capture channels with a programmable trigger edge.
- Three output compare channels with a programmable output mode. A "forced compare" feature is also available.
- Can be programmed to be active in low power and debug modes.
- Interrupt generation at capture, compare, and rollover events.
- Restart or free-run modes for counter operations.

52.2.2 Modes and Operation

The GPT supports the modes described in the indicated sections:

- Operating Modes
  - Restart Mode
  - Free-Run Mode
52.3 External Signals

The GPT follows the IP Bus protocol for interfacing with the processor core. The GPT does not have any interface signals with any other module inside the chip, except for the clock and reset inputs (from the clock and reset controller module) and for the interrupt signals to the processor interrupt handler. There are functional and clock inputs, and functional output signals going outside the chip boundary.

The following table describes all block signals that connect off-chip.

Table 52-2. GPT External Signals

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPT1_CLK</td>
<td>Input pin for an external clock that the counter can be operated at.</td>
<td>GPIO_AD_B0_13</td>
<td>ALT1</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_04</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT1_CAPTURE1</td>
<td>Input pin for a capture event for Input Capture Channel 1</td>
<td>GPIO_EMC_24</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_05</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT1_CAPTURE2</td>
<td>Input pin for a capture event for Input Capture Channel 2</td>
<td>GPIO_EMC_23</td>
<td>ALT4</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_06</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT1COMPARE1</td>
<td>Output pin that indicates a &quot;compare event&quot; occurrence in Output Compare Channel 1</td>
<td>GPIO_EMC_35</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_07</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT1COMPARE2</td>
<td>Output pin that indicates a &quot;compare event&quot; occurrence in Output Compare Channel 2</td>
<td>GPIO_EMC_36</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_08</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT1COMPARE3</td>
<td>Output pin that indicates a &quot;compare event&quot; occurrence in Output Compare Channel 3</td>
<td>GPIO_EMC_37</td>
<td>ALT2</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_B1_09</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT2_CAPTURE1</td>
<td>Input pin for a capture event for Input Capture Channel 1</td>
<td>GPIO_EMC_41</td>
<td>ALT1</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_03</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT2_CAPTURE2</td>
<td>Input pin for a capture event for Input Capture Channel 2</td>
<td>GPIO_EMC_40</td>
<td>ALT1</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_04</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT2COMPARE1</td>
<td>Output pin that indicates a &quot;compare event&quot; occurrence in Output Compare Channel 1</td>
<td>GPIO_AD_B0_06</td>
<td>ALT1</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_05</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT2COMPARE2</td>
<td>Output pin that indicates a &quot;compare event&quot; occurrence in</td>
<td>GPIO_AD_B0_07</td>
<td>ALT1</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_06</td>
<td>ALT8</td>
<td></td>
</tr>
</tbody>
</table>
### Table 52-2. GPT External Signals (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>GPT2_COMPARE3</td>
<td>Output pin that indicates a &quot;compare event&quot; occurrence in Output Compare Channel 3</td>
<td>GPIO_AD_B0_08</td>
<td>ALT1</td>
<td>O</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B1_07</td>
<td>ALT8</td>
<td></td>
</tr>
<tr>
<td>GPT2_CLK</td>
<td>Input pin for an external clock that the counter can be operated at.</td>
<td>GPIO_AD_B1_02</td>
<td>ALT8</td>
<td>I</td>
</tr>
<tr>
<td></td>
<td></td>
<td>GPIO_AD_B0_09</td>
<td>ALT7</td>
<td></td>
</tr>
</tbody>
</table>

There are six signals (three input, three output) in the GPT module that can be connected to the chip pads.

### 52.3.1 External Clock Input

The GPT counter can be operated using an external clock from outside the device, and this is the input pin used for that purpose. The external clock input (GPT_CLK) is treated as asynchronous to the peripheral clock (ipg_clk). To ensure proper operations of GPT, the external clock input frequency should be less than 1/4 of frequency of the peripheral clock (ipg_clk). Hysteresis characteristics on this pad will be required because this is a clock input.

### 52.3.2 Input Capture Trigger Signals

The GPT counter value can be stored in a register, triggered by an event from outside the device. A positive or/and negative edge on these signals GPT_CAPTURE1, GPT_CAPTURE2 can trigger this capture event. These signals are treated as asynchronous to the peripheral clock (ipg_clk). Only those transitions which occur at least a single clock cycle (the clock selected to run the counter) after the previous recorded transition are guaranteed to trigger a capture event.

### 52.3.3 Output Compare Signals

The output compare signals: GPT_COMPARE1, GPT_COMPARE2, GPT_COMPARE3, indicate that output compare events have gone through a specified transition.
52.4 Clocks

The clock that is input to the prescaler can be selected from 4 clock sources. The following table describes the clock sources for GPT. Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

Table 52-3. GPT Clocks

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
<tr>
<td>ipg_clk_32k</td>
<td>ckil_sync_clk_root</td>
<td>Low-frequency reference clock (32 kHz)</td>
</tr>
<tr>
<td>ipg_clk_highfreq</td>
<td>perclk_clk_root</td>
<td>High-frequency reference clock</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>Peripheral access clock</td>
</tr>
</tbody>
</table>

- **High-Frequency Clock (ipg_clk_highfreq)**

  Provided by the Clock Controller Module (CCM), the High Frequency Clock is intended to be ON in Normal Power mode when the Peripheral Clock (ipg_clk) is turned OFF, thereby enabling the GPT to be operated using the High Frequency Clock in Normal Power mode. The CCM is expected to provide this clock after synchronizing it to the System Bus Clock (ahb_clk) in Normal functional mode; the CCM is also expected to switch to the unsynchronized version of the High Frequency Clock in a Low Power mode.

- **Low-Reference Clock (ipg_clk_32k)**

  This 32 kHz Low Reference Clock (provided by the CCM) is intended to be ON in Low Power mode when the Peripheral Clock (ipg_clk) is turned OFF, thereby enabling the GPT to be operated using the Low Reference Clock in Low Power mode. The CCM is expected to provide the Low Reference Clock after synchronizing it to the System Bus Clock (ahb_clk) in Normal functional mode; the CCM is also expected to switch to the unsynchronized version of the Low Reference Clock in a Low Power mode.

- **Peripheral Clock (ipg_clk)**

  If the Peripheral Clock (ipg_clk) or the External Clock (GPT_CLK) is selected (CLKSRC=001 or 011) as Clock Source, then the Peripheral Clock will be ON in normal GPT operations. In Low Power modes, if the GPT is programmed to be disabled (STOPEN or WAITEN or DOZEN=0), then the Peripheral Clock (ipg_clk) can be switched OFF.

- **External Clock (GPT_CLK)**
The External Clock comes from outside the device and can be selected to run the GPT counter. The External Clock is treated as asynchronous to the Peripheral Clock, (ipg_clk) and is synchronized to the Peripheral Clock (ipg_clk), inside the module. Therefore, the External Clock frequency is limited to < 1/4 frequency of the Peripheral Clock (ipg_clk), for proper GPT operations. Note that in Low Power modes, if the Peripheral Clock (ipg_clk) is not available, then the External Clock cannot be used to run the counter.

- **Crystal Oscillator Clock (ipg_clk_24M)**

This 24 MHz Crystal Oscillator Clock (provided by the CCM) is intended to be used against frequency change of Peripheral Clock (ipg_clk) changes to provide a more accurate timer clock for operation system. The CCM is expected to provide the 24 MHz Crystal Oscillator Clock without synchronizing it to the System Bus Clock (ahb_clk) in Normal functional mode. Synchronization is done in GPT module. Before synchronization, the 24 MHz Crystal Oscillator Clock is divided by a 24 MHz clock prescaler, to make sure the clock frequency less than half of System Bus Clock (ahb_clk).

The clock input source is configured using the clock source field (CLKSRC, in the GPT_CR control register). The clock input to the prescaler can be disabled by programming the CLKSRC bits (of the GPT_CR control register) to 000. The **CLKSRC field value should be changed only after disabling the GPT** (by setting the EN bit in the GPT_CR to 0).

The PRESCALER field selects the divide ratio of the input clock that drives the main counter. The prescaler can divide the input clock by a value (from 1 to 4096) and can be changed at any time. A change in the value of the PRESCALER field immediately affects the output clock frequency.

![Prescaler Value Change Timing Diagram](image)

**Figure 52-3. Prescaler Value Change Timing Diagram**
52.5 Functional Description

This section provides a complete functional description of the GPT.

52.5.1 Operating Modes

The GPT counter can be programmed to work in either of two modes: Restart mode or Free-Run mode.

52.5.1.1 Restart Mode

In Restart mode (selectable through the GPT Control Register GPT_CR), when the counter reaches the compared value, the counter resets and starts again from 0x00000000. The Restart feature is associated only with Compare Channel 1.

Any write access to the Compare register of Channel 1 will reset the GPT counter. This is done to avoid possibly missing a compare event when compare value is changed from a higher value to lower value while counting is proceeding.

For the other two compare channels, when the compare event occurs the counter is not reset.

52.5.1.2 Free-Run Mode

In Free-Run mode, when compare events occur for all 3 channels, the counter is not reset; instead the counter continues to count until 0xffffffff, and then rolls over (to 0x00000000).

52.5.2 Operation

The General Purpose Timer (GPT) has a single counter (GPT_CNT) that is a 32-bit free-running up-counter, which starts counting after it is enabled by software (EN=1). The counter's clock source is the output of the prescaler labelled "Prescaler output" in Figure 52-1.

- If the GPT timer is disabled (EN=0), then the Main Counter and Prescaler Counter freeze their current count values. The ENMOD bit determines the value of the GPT counter when the EN bit is set and the Counter is enabled again.
• If the ENMOD bit is set (=1), then the Main Counter and Prescaler Counter values are reset to 0, when GPT is enabled (EN=1).
• If ENMOD bit is programmed to 0, then the Main Counter and Prescaler Counter restart counting from their frozen values, when GPT is enabled again (EN=1).
• If GPT is programmed to be disabled in a low power mode (STOP/WAIT), then the Main Counter and Prescaler Counter freeze at their current count values when GPT enters low power mode. When GPT exits a low power mode, the Main Counter and Prescaler Counter start counting from their frozen values regardless of the ENMOD bit value. Note that the GPT_CNT can be read at any time by the processor, and that both Input Capture Channels use the same counter (GPT_CNT).
• A hardware reset resets all the GPT registers to their respective reset values. All registers except the Output Compare Registers (OCR1, OCR2, OCR3) obtain a value of 0x0. The Compare registers are reset to 0xFFFF_FFFF.
• The software reset (SWR bit in the GPT_CR control register) resets all of the register bits except the EN, ENMOD, STOPEN, WAITEN, and DBGEN bits. The state of these bits is not affected by a software reset. Note that a software reset can be given while the GPT is disabled.

52.5.2.1 Input Capture

There are two Input Capture Channels, and each Input Capture Channel has a dedicated capture pin, capture register and input edge detection/selection logic. Each input capture function has an associated status flag, and can cause the processor to make an interrupt service request.

When a selected edge transition occurs on an Input Capture pin, the contents of the GPT_CNT is captured on the corresponding capture register and the appropriate interrupt status flag is set. An interrupt request can be generated when the transition is detected if its corresponding enable bit is set (in the Interrupt Register). The capture can be programmed to occur on the input pin's rising edge, falling edge, on both rising and falling edges, or the capture can be disabled. The events are synchronized with the clock that was selected to run the counter. Only those transitions that occur at least one clock cycle (clock selected to run the counter) after the previous recorded transition will be guaranteed to trigger a capture event. There can be up to one clock cycle of uncertainty in the latching of the input transition. The Input Capture registers can be read at any time without affecting their values.
52.5.2.2 Output Compare

The three Output Compare Channels use the same counter (GPT_CNT) as the Input Capture Channels. When the programmed content of an Output Compare register matches the value in GPT_CNT, an output compare status flag is set and an interrupt is generated (if the corresponding bit is set in the interrupt register). Consequently, the Output Compare timer pin will be set, cleared, toggled, not affected at all or provide an active-low pulse for one input clock period (subject to the restriction on the maximum frequency allowed on the pad) according to the mode bits (that were programmed).

There is also a "forced-compare" feature that allows the software to generate a compare event when required, without the condition of the counter value that is equal to the compare value. The action taken as a result of a forced compare is the same as when an output compare match occurs, except that the status flags are not set and no interrupt can be generated. Forced channels take programmed action immediately after the write to the force-compare bits. These bits are self-negating and always read as zeros.
52.5.2.3 Interrupts

There are 6 different interrupts that are generated by the GPT. If the selected clock for running the counter is available, then all interrupts can be generated in Low Power and Debug modes.

- Rollover Interrupt

The Rollover Interrupt is generated when the GPT counter reaches 0xffffffff, then resets to 0x00000000 and continues counting. The Rollover Interrupt is enabled by the ROVIE bit in the GPT_IR register; the associated status bit is the ROV bit in the GPT_SR register.

- Input Capture Interrupt 1, 2

After a capture event occurs, the associated Input Capture Channel generates an interrupt. The "capture event" interrupts are enabled by the IF2IE and IF1IE bits (in the GPT_IR register); the associated status bits are IF2 and IF1 (in the GPT_SR register). The capture of the counter value because of a capture event is not affected by a pending capture interrupt. The Capture register is updated with a new counter value when a capture event occurs, regardless of whether that Capture Channels' interrupt has been serviced or not.

- Output Compare Interrupt 1, 2, 3
After a compare event occurs, the associated Output Compare Channel generates an interrupt. The "compare event" interrupts are enabled by the OF3IE, OF2IE, and OF1IE bits (in the GPT_IR register); the associated status bits are OF3, OF2, and OF1 (in the GPT_SR register). A "forced compare" does not generate an interrupt.

A cumulative interrupt line is also present, which is asserted whenever any of the above interrupts are posted. The cumulative interrupt line has no associated enables or status bits.

### 52.5.2.4 Low Power Mode Behavior

In Low Power modes, if the clock from the selected clock source is available (except for the External Clock (GPT_CLK), which can be used only if the Peripheral Clock (ipg_clk) is available), the counter will continue to run depending on whether the control bit for that mode is set. If the clock is not present or if the corresponding low power bit in the GPT_CR control register is 0, the Main Counter and the Prescaler Counter freeze at their current values and resume counting (from their frozen values) when the Low Power mode is exited.

### 52.5.2.5 Debug Mode Behavior

In Debug mode, the modules in the device have the option of continuing to run or be halted.

- If the DBGEN bit is set, then the GPT timer will continue to run in Debug mode.
- If the DBGEN bit is not set (in the GPT_CR control register), then the GPT timer is halted.

### 52.6 Initialization/ Application Information

#### 52.6.1 Selecting the Clock Source

The CLKSRC field in the GPT_CR register selects the clock source. The CLKSRC field value should be changed only after disabling the GPT (EN=0).

The software sequence to be followed while changing clock source is:

1. Disable GPT by setting EN=0 in GPT_CR register.
2. Disable GPT interrupt register (GPT_IR).
3. Configure Output Mode to unconnected/disconnected—Write zeros in OM3, OM2, and OM1 in GPT_CR
4. Disable Input Capture Modes—Write zeros in IM1 and IM2 in GPT_CR
5. Change clock source CLKSRC to the desired value in GPT_CR register.
6. Assert the SWR bit in GPT_CR register.
7. Clear GPT status register (GPT_SR) (i.e., w1c).
8. Set ENMOD=1 in GPT_CR register, to bring GPT counter to 0x00000000.
9. Enable GPT (EN=1) in GPT_CR register.
10. Enable GPT interrupt register (GPT_IR).

52.7 GPT Memory Map/Register Definition

The GPT has 10 user-accessible 32-bit registers, which are used to configure, operate, and monitor the state of the GPT.

An IP bus write access to the GPT Control Register (GPT_CR) and the GPT Output Compare Register1 (GPT_OCR1) results in one cycle of wait state, while other valid IP bus accesses incur 0 wait states.

Irrespective of the Response Select signal value, a Write access to the GPT Status Registers (Read-only registers GPT_ICR1, GPT_ICR2, GPT_CNT) will generate a bus exception.

- If the Response Select signal is driven Low, then the Read/Write access to the unimplemented address space of GPT (ips_addr is greater than or equal to $BASE + $028) will generate a bus exception.
- If the Response Select is driven High, then the Read/Write access to the unimplemented address space of GPT will not generate any error response (like a bus exception).

### GPT memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/ page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401E_C000</td>
<td>GPT Control Register (GPT1_CR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.1/2959</td>
</tr>
<tr>
<td>401E_C004</td>
<td>GPT Prescaler Register (GPT1_PR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.2/2963</td>
</tr>
<tr>
<td>401E_C008</td>
<td>GPT Status Register (GPT1_SR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.3/2964</td>
</tr>
<tr>
<td>401E_C00C</td>
<td>GPT Interrupt Register (GPT1_IR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.4/2965</td>
</tr>
<tr>
<td>401E_C010</td>
<td>GPT Output Compare Register 1 (GPT1_OCR1)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>52.7.5/2966</td>
</tr>
<tr>
<td>401E_C014</td>
<td>GPT Output Compare Register 2 (GPT1_OCR2)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>52.7.6/2967</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401E_C018</td>
<td>GPT Output Compare Register 3 (GPT1_OCR3)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>52.7.7/2967</td>
</tr>
<tr>
<td>401E_C01C</td>
<td>GPT Input Capture Register 1 (GPT1_ICR1)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>52.7.8/2968</td>
</tr>
<tr>
<td>401E_C020</td>
<td>GPT Input Capture Register 2 (GPT1_ICR2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>52.7.9/2968</td>
</tr>
<tr>
<td>401E_C024</td>
<td>GPT Counter Register (GPT1_CNT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>52.7.10/2969</td>
</tr>
<tr>
<td>401F_0000</td>
<td>GPT Control Register (GPT2_CR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.1/2959</td>
</tr>
<tr>
<td>401F_0004</td>
<td>GPT Prescaler Register (GPT2_PR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.2/2963</td>
</tr>
<tr>
<td>401F_0008</td>
<td>GPT Status Register (GPT2_SR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.3/2964</td>
</tr>
<tr>
<td>401F_000C</td>
<td>GPT Interrupt Register (GPT2_IR)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>52.7.4/2965</td>
</tr>
<tr>
<td>401F_0010</td>
<td>GPT Output Compare Register 1 (GPT2_OCR1)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>52.7.5/2966</td>
</tr>
<tr>
<td>401F_0014</td>
<td>GPT Output Compare Register 2 (GPT2_OCR2)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>52.7.6/2967</td>
</tr>
<tr>
<td>401F_0018</td>
<td>GPT Output Compare Register 3 (GPT2_OCR3)</td>
<td>32</td>
<td>R/W</td>
<td>FFFF_FFFFh</td>
<td>52.7.7/2967</td>
</tr>
<tr>
<td>401F_001C</td>
<td>GPT Input Capture Register 1 (GPT2_ICR1)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>52.7.8/2968</td>
</tr>
<tr>
<td>401F_0020</td>
<td>GPT Input Capture Register 2 (GPT2_ICR2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>52.7.9/2968</td>
</tr>
<tr>
<td>401F_0024</td>
<td>GPT Counter Register (GPT2_CNT)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>52.7.10/2969</td>
</tr>
</tbody>
</table>
52.7.1  GPT Control Register (GPTx_CR)

The GPT Control Register (GPT_CR) is used to program and configure GPT operations. An IP Bus Write to the GPT Control Register occurs after one cycle of wait state, while an IP Bus Read occurs after 0 wait states.

Address: Base address + 0h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>OM3</td>
<td>OM2</td>
<td>OM1</td>
<td>IM2</td>
<td>IM1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FO3</td>
<td>FO2</td>
<td>FO1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>SWR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

GPTx_CR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31 FO3 | FO3 Force Output Compare Channel 3
|        | FO2 Force Output Compare Channel 2
|        | FO1 Force Output Compare Channel 1
|        | The FOn bit causes the pin action *programmed* for the timer Output Compare n pin (according to the OMan bits in this register).
|        | • The OFn flag (OF3, OF2, OF1) in the status register is not affected.
|        | • This bit is self-negating and always read as zero.
|        | 0 Writing a 0 has no effect.
|        | 1 Causes the programmed pin action on the timer Output Compare n pin; the OFn flag is not set. |
| 30 FO2 | See F03 |

Table continues on the next page...
## GPTx_CR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>29</td>
<td>See F03</td>
</tr>
<tr>
<td>28–26</td>
<td>OM3 (bits 28-26) controls the Output Compare Channel 3 operating mode.</td>
</tr>
<tr>
<td>25–23</td>
<td>OM2 (bits 25-23) controls the Output Compare Channel 2 operating mode.</td>
</tr>
<tr>
<td>22–20</td>
<td>OM1 (bits 22-20) controls the Output Compare Channel 1 operating mode.</td>
</tr>
</tbody>
</table>

The OMₙ bits specify the response that a compare event will generate on the output pin of Output Compare Channel n.

- The toggle, clear, and set options cause a change on the output pin only if a compare event occurs.
- When OMₙ is programmed as 1xx (active low pulse), the output pin is set to one immediately on the next input clock; a low pulse (that is an input clock in width) occurs when there is a compare event. Note that here, "input clock" refers to the clock selected by the CLKSRC bits of the GPT Control Register.

<table>
<thead>
<tr>
<th>OMₙ</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>Output disconnected. No response on pin.</td>
</tr>
<tr>
<td>001</td>
<td>Toggle output pin</td>
</tr>
<tr>
<td>010</td>
<td>Clear output pin</td>
</tr>
<tr>
<td>011</td>
<td>Set output pin</td>
</tr>
<tr>
<td>1xx</td>
<td>Generate an active low pulse (that is one input clock wide) on the output pin.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>19–18</th>
<th>IM2 (bits 19-18, Input Capture Channel 2 operating mode)</th>
</tr>
</thead>
<tbody>
<tr>
<td>17–16</td>
<td>IM1 (bits 17-16, Input Capture Channel 1 operating mode)</td>
</tr>
</tbody>
</table>

The IMₙ bit field determines the transition on the input pin (for Input capture channel n), which will trigger a capture event.

<table>
<thead>
<tr>
<th>IMₙ</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>capture disabled</td>
</tr>
<tr>
<td>01</td>
<td>capture on rising edge only</td>
</tr>
<tr>
<td>10</td>
<td>capture on falling edge only</td>
</tr>
<tr>
<td>11</td>
<td>capture on both edges</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>15</th>
<th>SWR</th>
<th>Software reset.</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>This is the software reset of the GPT module. It is a self-clearing bit.</td>
</tr>
</tbody>
</table>

- The SWR bit is set when the module is in reset state.
- The SWR bit is cleared when the reset procedure finishes.
- Setting the SWR bit resets all of the registers to their default reset values, except for the EN, ENMOD, STOPEN, DOZEEN, WAITEN, and DBGEN bits in the GPT Control Register (this control register).

<table>
<thead>
<tr>
<th>SWR</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>GPT is not in reset state</td>
</tr>
<tr>
<td>1</td>
<td>GPT is in reset state</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>14–11</th>
<th>Reserved</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

| 10 | EN_24M | Enable 24 MHz clock input from crystal. |

*Table continues on the next page...*
## GPTx_CR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| • A hardware reset resets the EN_24M bit.  
• A software reset *does not affect* the EN_24M bit. | |
| 0 | 24M clock disabled |
| 1 | 24M clock enabled |

| 9 | FRR | Free-Run or Restart mode.  
The FFR bit determines the behavior of the GPT when a compare event in channel 1 occurs.  
• In Restart mode, after a compare event, the counter resets to 0x00000000 and resumes counting (after the occurrence of a compare event).  
• In Free-Run mode, after a compare event, the counter continues counting until 0xFFFFFFFF and then rolls over to 0. |
| 0 | Restart mode |
| 1 | Free-Run mode |

| 8–6 | CLKSRC | Clock Source select.  
The CLKSRC bits select which clock will go to the prescaler (and subsequently be used to run the GPT counter).  
• The CLKSRC bit field value should only be changed after disabling the GPT by clearing the EN bit in this register (GPT_CR).  
• A software reset does not affect the CLKSRC bit. |
| 000 | No clock |
| 001 | Peripheral Clock (ipg_clk) |
| 010 | High Frequency Reference Clock (ipg_clk_highfreq) |
| 011 | External Clock |
| 100 | Low Frequency Reference Clock (ipg_clk_32k) |
| 101 | Crystal oscillator as Reference Clock (ipg_clk_24M) |
| others | Reserved |

| 5 | STOPEN | GPT Stop Mode enable.  
The STOPEN read/write control bit enables GPT operation *during Stop mode*.  
• A hardware reset resets the STOPEN bit.  
• A software reset *does not affect* the STOPEN bit. |
| 0 | GPT is disabled in Stop mode. |
| 1 | GPT is enabled in Stop mode. |

| 4 | DOZEEN | GPT Doze Mode Enable.  
• A hardware reset resets the DOZEEN bit.  
• A software reset *does not affect* the DOZEEN bit. |
| 0 | GPT is disabled in doze mode. |
| 1 | GPT is enabled in doze mode. |

| 3 | WAITEN | GPT Wait Mode enable.  
The WAITEN read/write control bit enables GPT operation *during Wait mode*.  
• A hardware reset resets the WAITEN bit.  
• A software reset *does not affect* the WAITEN bit. |
| 0 | GPT is disabled in wait mode. |
| 1 | GPT is enabled in wait mode. |

*Table continues on the next page...*
### GPTx_CR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 2     | GPT debug mode enable.  
The DBGEN read/write control bit enables GPT operation during Debug mode.  
• A hardware reset resets the DBGEN bit.  
• A software reset does not affect the DBGEN bit.  
| 0     | GPT is disabled in debug mode.  
| 1     | GPT is enabled in debug mode.  |

1 ENMOD  
GPT Enable mode.  
When the GPT is disabled (EN=0), then both the Main Counter and Prescaler Counter freeze their current count values. The ENMOD bit determines the value of the GPT counter when Counter is enabled again (if the EN bit is set).  
• If the ENMOD bit is 1, then the Main Counter and Prescaler Counter values are reset to 0 after GPT is enabled (EN=1).  
• If the ENMOD bit is 0, then the Main Counter and Prescaler Counter restart counting from their frozen values after GPT is enabled (EN=1).  
• If GPT is programmed to be disabled in a low power mode (STOP/WAIT), then the Main Counter and Prescaler Counter freeze at their current count values when the GPT enters low power mode.  
• When GPT exits low power mode, the Main Counter and Prescaler Counter start counting from their frozen values, regardless of the ENMOD bit value.  
• Setting the SWR bit will clear the Main Counter and Prescaler Counter values, regardless of the value of EN or ENMOD bits.  
• A hardware reset resets the ENMOD bit.  
• A software reset does not affect the ENMOD bit.  
| 0     | GPT counter will retain its value when it is disabled.  
| 1     | GPT counter value is reset to 0 when it is disabled.  |

0 EN  
GPT Enable.  
The EN bit is the GPT module enable bit.  
**Before setting the EN bit, we recommend that all registers be properly programmed.**  
• A hardware reset resets the EN bit.  
• A software reset does not affect the EN bit.  
| 0     | GPT is disabled.  
| 1     | GPT is enabled.  |
52.7.2 GPT Prescaler Register (GPTx_PR)

The GPT Prescaler Register (GPT_PR) contains bits that determine the divide value of the clock that runs the counter.

Address: Base address + 4h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>PRESCALER24M</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>PRESCALER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**GPTx_PR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–16 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 15–12 PRESCALER24M | Prescaler bits.  
24M crystal clock is divided by [PRESCALER24M + 1] before selected by the CLKSRC field. If 24M crystal clock is not selected, this field takes no effect.  
0x0  Divide by 1  
0x1  Divide by 2  
...  ...  
0xFF  Divide by 16 |

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| PRESCALER      | Prescaler bits.  
The clock selected by the CLKSRC field is divided by [PRESCALER + 1], and then used to run the counter.  
  • A change in the value of the PRESCALER bits cause the Prescaler counter to reset and a new count period to start immediately.  
  • See Figure 52-3 for the timing diagram.  
0x000  Divide by 1  
0x001  Divide by 2  
...  ...  
0xFFF  Divide by 4096 |
## 52.7.3 GPT Status Register (GPTx_SR)

The GPT Status Register (GPT_SR) contains bits that indicate that a counter has rolled over, and if any event has occurred on the Input Capture and Output Compare channels. The bits are cleared by writing a 1 to them.

**Address:** Base address + 8h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### GPTx_SR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–6</td>
<td>Reserved This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>5 ROV</td>
<td>Rollover Flag. The ROV bit indicates that the counter has reached its maximum possible value and rolled over to 0 (from which the counter continues counting). The ROV bit is only set if the counter has reached 0xFFFFFFFF in both Restart and Free-Run modes.</td>
</tr>
<tr>
<td>0</td>
<td>Rollover has not occurred.</td>
</tr>
<tr>
<td>1</td>
<td>Rollover has occurred.</td>
</tr>
<tr>
<td>4 IF2</td>
<td>IF2 Input capture 2 Flag</td>
</tr>
<tr>
<td></td>
<td>IF1 Input capture 1 Flag</td>
</tr>
<tr>
<td></td>
<td>The IFn bit indicates that a capture event has occurred on Input Capture channel n.</td>
</tr>
<tr>
<td>0</td>
<td>Capture event has not occurred.</td>
</tr>
<tr>
<td>1</td>
<td>Capture event has occurred.</td>
</tr>
<tr>
<td>3 IF1</td>
<td>See IF2</td>
</tr>
<tr>
<td>2 OF3</td>
<td>OF3 Output Compare 3 Flag</td>
</tr>
<tr>
<td></td>
<td>OF2 Output Compare 2 Flag</td>
</tr>
<tr>
<td></td>
<td>OF1 Output Compare 1 Flag</td>
</tr>
<tr>
<td></td>
<td>The OFn bit indicates that a compare event has occurred on Output Compare channel n.</td>
</tr>
<tr>
<td>0</td>
<td>Compare event has not occurred.</td>
</tr>
<tr>
<td>1</td>
<td>Compare event has occurred.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### GPTx_SR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 OF2</td>
<td>See OF3</td>
</tr>
<tr>
<td>0 OF1</td>
<td>See OF3</td>
</tr>
</tbody>
</table>

### 52.7.4 GPT Interrupt Register (GPTx_IR)

The GPT Interrupt Register (GPT_IR) contains bits that control whether interrupts are generated after rollover, input capture and output compare events.

**Address:** Base address + Ch offset

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

```
<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>ROVIE</td>
<td></td>
<td>IF2IE</td>
<td>IF1IE</td>
<td>OF3IE</td>
<td>OF2IE</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### GPTx_IR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–6</td>
<td>Reserved This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>5 ROVIE</td>
<td>Rollover Interrupt Enable. The ROVIE bit controls the Rollover interrupt. 0 Rollover interrupt is disabled. 1 Rollover interrupt enabled.</td>
</tr>
<tr>
<td>4 IF2IE</td>
<td>IF2IE Input capture 2 Interrupt Enable IF1IE Input capture 1 Interrupt Enable The IFnIE bit controls the IFnIE Input Capture n Interrupt Enable. 0 IF2IE Input Capture n Interrupt Enable is disabled. 1 IF2IE Input Capture n Interrupt Enable is enabled.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
GPTx_IR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>3 IF1IE</td>
<td>See IF2IE</td>
</tr>
</tbody>
</table>
| 2 OF3IE | OF3IE Output Compare 3 Interrupt Enable  
OF2IE Output Compare 2 Interrupt Enable  
OF1IE Output Compare 1 Interrupt Enable  
The OFnIE bit controls the Output Compare Channel n interrupt.  
0 Output Compare Channel n interrupt is disabled.  
1 Output Compare Channel n interrupt is enabled. |
| 1 OF2IE | See OF3IE |
| 0 OF1IE | See OF3IE |

52.7.5 GPT Output Compare Register 1 (GPTx_OCR1)

The GPT Compare Register 1 (GPT_OCR1) holds the value that determines when a compare event will be generated on Output Compare Channel 1. Any write access to the Compare register of Channel 1 while in Restart mode (FRR=0) will reset the GPT counter.

An IP Bus Write access to the GPT Output Compare Register1 (GPT_OCR1) occurs after one cycle of wait state; an IP Bus Read access occurs immediately (0 wait states).

Address: Base address + 10h offset

GPTx_OCR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| COMP  | Compare Value.  
When the counter value equals the COMP bit field value, a compare event is generated on Output Compare Channel 1. |
52.7.6  GPT Output Compare Register 2 (GPTx_OCR2)

The GPT Compare Register 2 (GPT_OCR2) holds the value that determines when a compare event will be generated on Output Compare Channel 2.

Address: Base address + 14h offset

| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| W   |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

GPTx_OCR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| COMP  | Compare Value.  
When the counter value equals the COMP bit field value, a compare event is generated on Output Compare Channel 2. |

52.7.7  GPT Output Compare Register 3 (GPTx_OCR3)

The GPT Compare Register 3 (GPT_OCR3) holds the value that determines when a compare event will be generated on Output Compare Channel 3.

Address: Base address + 18h offset

| Bit | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| W   |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

GPTx_OCR3 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| COMP  | Compare Value.  
When the counter value equals the COMP bit field value, a compare event is generated on Output Compare Channel 3. |
52.7.8 GPT Input Capture Register 1 (GPTx_ICR1)

The GPT Input Capture Register 1 (GPT_ICR1) is a read-only register that holds the value that was in the counter during the last capture event on Input Capture Channel 1.

Address: Base address + 1Ch offset

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|     | R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|     | W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0 |

GPTx_ICR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| CAPT  | Capture Value.  
After a capture event on Input Capture Channel 1 occurs, the current value of the counter is loaded into GPT Input Capture Register 1. |

52.7.9 GPT Input Capture Register 2 (GPTx_ICR2)

The GPT Input capture Register 2 (GPT_ICR2) is a read-only register which holds the value that was in the counter during the last capture event on input capture channel 2.

Address: Base address + 20h offset

| Bit | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|     | R   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|     | W   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0 |

GPTx_ICR2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| CAPT  | Capture Value.  
After a capture event on Input Capture Channel 2 occurs, the current value of the counter is loaded into GPT Input Capture Register 2. |
52.7.10  GPT Counter Register (GPTx_CNT)

The GPT Counter Register (GPT_CNT) is the main counter's register. GPT_CNT is a read-only register and can be read without affecting the counting process of the GPT.

Address: Base address + 24h offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

GPTx_CNT field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| COUNT | Counter Value.  
The COUNT bits show the current count value of the GPT counter. |
Chapter 53
Periodic Interrupt Timer (PIT)

53.1 Chip-specific PIT information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
<tr>
<td>PIT channel to DMA channel correspondence</td>
<td>-</td>
<td>PIT Channel Assignments For Periodic DMA Triggering</td>
</tr>
</tbody>
</table>

There are 4 PIT channels in this device.

53.2 Introduction

The PIT module is an array of timers that can be used to raise interrupts and trigger DMA channels.

53.2.1 Block diagram

The following figure shows the block diagram of PIT module.
53.2.2 Features

The key features of the module are these:

- Ability of timers to generate DMA trigger pulses
- Ability of timers to generate interrupts
- Maskable interrupts
- Independent timeout periods for each timer
53.3 Modes of operation

This subsection briefly describes all operating modes supported by PIT.

- Run mode
  All functional parts of the PIT are running during normal Run mode.
- Stop mode

53.4 PIT External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>I/O</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGGERn</td>
<td>Trigger signal</td>
<td>O</td>
</tr>
</tbody>
</table>

53.5 Functional description

This section provides the functional description of the module.

53.5.1 General operation

This section provides detailed information on the internal operation of the module. Each timer can be used to generate trigger pulses and interrupts, and each interrupt is available on a separate interrupt line.

53.5.1.1 Timers

The timers generate triggers at periodic intervals, when enabled. The timers load the start values as specified in their LDVAL registers, count down to 0 and then load the respective start values again. Each time a timer reaches 0, it generates a trigger pulse and sets the interrupt flag.

All interrupts can be enabled or masked by setting TCTRLn[TIE]. A new interrupt can be generated only after the previous one is cleared.

If desired, the current counter value of the timer can be read via the CVAL registers.
The counter period can be restarted by first disabling and then enabling the timer with TCTRLn[TEN]. See the following figure.

![Figure 53-2. Stopping and starting a timer](image)

The counter period of a running timer can be modified by first disabling the timer, setting a new load value, and then enabling the timer again. See the following figure.

![Figure 53-3. Modifying running timer period](image)

It is also possible to change the counter period without restarting the timer, by writing LDVAL with the new load value. This value then loads after the next trigger event. See the following figure.

![Figure 53-4. Dynamically setting a new load value](image)

**NOTE**

- If the pause is initiated, when the timer is nearing 0 (CVALn =0x0), the pause command may not make it to the IP before the timer expires and generates a trigger.
• Pause will be ignored if (CVALn =0x0), but the trigger will remain asserted until the pause is removed. The user is recommended to remove Pause and then clear the interrupt TFLGn[TIF].

• If the timers are to be paused, sufficient time must be ensured for the IP to react.

53.5.1.2 Debug mode

In the Debug mode, the timers are frozen based on MCR[FRZ]. This is intended to aid software development, allowing the developer to halt the processor, investigate the current state of the system, for example, the timer values, and then continue the operation.

53.5.2 Interrupts

All the timers support interrupt generation. See the MCU specification for related vector addresses and priorities.

Timer interrupts can be enabled by setting TCTRLn[TIE].

TFLGn[TIF] are set to 1 when a timeout occurs on the associated timer, and are cleared to 0 by writing a 1 to the corresponding TFLGn[TIF].

53.5.3 Chained timers

When a timer has chain mode enabled, it counts after the previous timer has expired. So if timer n-1 counts down to 0, counter n decrements the value by one. This allows to chain some of the timers together to form a longer timer. The first timer (timer 0) cannot be chained to any other timer.

53.6 Initialization and application information

In the example configuration:

• The PIT clock has a frequency of 50 MHz.
• Timer 1 creates an interrupt every 5.12 ms.
• Timer 3 creates a trigger event every 30 ms.

The PIT module must be activated by writing a 0 to MCR[MDIS].

The 50 MHz clock frequency equates to a clock period of 20 ns. Timer 1 needs to trigger every 5.12 ms/20 ns = 256,000 cycles and Timer 3 every 30 ms/20 ns = 1,500,000 cycles. The value for the LDVAL register trigger is calculated as:

\[
LDVAL \text{ trigger} = \frac{\text{period}}{\text{clock period}} - 1
\]

This means LDVAL1 and LDVAL3 must be written with 0x0003E7FF and 0x0016E35F, respectively.

The interrupt for Timer 1 is enabled by setting TCTRL1[TIE]. The timer is started by writing 1 to TCTRL1[TEN].

Timer 3 shall be used only for triggering. Therefore, Timer 3 is started by writing a 1 to TCTRL3[TEN]. Also, TCTRL3[TIE] stays at 0.

The following example code matches the described setup:

```c
// turn on PIT
PIT_MCR = 0x00;

// Timer 1
PIT_LDVAL1 = 0x0003E7FF; // setup timer 1 for 256000 cycles
PIT_TCTRL1 = TIE; // enable Timer 1 interrupts
PIT_TCTRL1 |= TEN; // start Timer 1

// Timer 3
PIT_LDVAL3 = 0x0016E35F; // setup timer 3 for 1500000 cycles
PIT_TCTRL3 |= TEN; // start Timer 3
```

53.7 Example configuration for chained timers

In the example configuration:

• The PIT clock has a frequency of 100 MHz.
• Timers 1 and 2 are available.
• An interrupt is raised every 1 minute.

The PIT module needs to be activated by writing a 0 to MCR[MDIS].
Chapter 53 Periodic Interrupt Timer (PIT)

The 100 MHz clock frequency equates to a clock period of 10 ns, so the PIT needs to count for 6000 million cycles, which is more than a single timer can do. So, Timer 1 is set up to trigger every 6 s (600 million cycles). Timer 2 is chained to Timer 1 and programmed to trigger 10 times.

The value for the LDVAL register trigger is calculated as number of cycles-1, so LDVAL1 receives the value 0x23C345FF and LDVAL2 receives the value 0x00000009.

The interrupt for Timer 2 is enabled by setting TCTRL2[TIE], the Chain mode is activated by setting TCTRL2[CHN], and the timer is started by writing a 1 to TCTRL2[TEN].

TCTRL1[TEN] needs to be set, and TCTRL1[CHN] and TCTRL1[TIE] are cleared.

The following example code matches the described setup:

```c
// turn on PIT
PIT_MCR = 0x00;

// Timer 2
PIT_LDVAL2 = 0x00000009; // setup Timer 2 for 10 counts
PIT_TCTRL2 = TIE; // enable Timer 2 interrupt
PIT_TCTRL2 |= CHN; // chain Timer 2 to Timer 1
PIT_TCTRL2 |= TEN; // start Timer 2

// Timer 1
PIT_LDVAL1 = 0x23C345FF; // setup Timer 1 for 600 000 000 cycles
PIT_TCTRL1 = TEN; // start Timer 1
```

53.8 Example configuration for the lifetime timer

To configure the lifetime timer, channels 0 and 1 need to be chained together.

First, the PIT module needs to be activated by writing a 0 to the MDIS bit in the CTRL register, and then the LDVAL registers need to be set to the maximum value.

The timer is a downcounter.

The following example code matches the described setup:

```c
// turn on PIT
PIT_MCR = 0x00;

// Timer 1
PIT_LDVAL1 = 0xFFFFFFFF; // setup timer 1 for maximum counting period
PIT_TCTRL1 = 0x0; // disable timer 1 interrupts
PIT_TCTRL1 |= CHN; // chain timer 1 to timer 0
PIT_TCTRL1 |= TEN; // start timer 1
```

Chapter 53 Periodic Interrupt Timer (PIT)

The 100 MHz clock frequency equates to a clock period of 10 ns, so the PIT needs to count for 6000 million cycles, which is more than a single timer can do. So, Timer 1 is set up to trigger every 6 s (600 million cycles). Timer 2 is chained to Timer 1 and programmed to trigger 10 times.

The value for the LDVAL register trigger is calculated as number of cycles-1, so LDVAL1 receives the value 0x23C345FF and LDVAL2 receives the value 0x00000009.

The interrupt for Timer 2 is enabled by setting TCTRL2[TIE], the Chain mode is activated by setting TCTRL2[CHN], and the timer is started by writing a 1 to TCTRL2[TEN].

TCTRL1[TEN] needs to be set, and TCTRL1[CHN] and TCTRL1[TIE] are cleared.

The following example code matches the described setup:

```c
// turn on PIT
PIT_MCR = 0x00;

// Timer 2
PIT_LDVAL2 = 0x00000009; // setup Timer 2 for 10 counts
PIT_TCTRL2 = TIE; // enable Timer 2 interrupt
PIT_TCTRL2 |= CHN; // chain Timer 2 to Timer 1
PIT_TCTRL2 |= TEN; // start Timer 2

// Timer 1
PIT_LDVAL1 = 0x23C345FF; // setup Timer 1 for 600 000 000 cycles
PIT_TCTRL1 = TEN; // start Timer 1
```

53.8 Example configuration for the lifetime timer

To configure the lifetimer timer, channels 0 and 1 need to be chained together.

First, the PIT module needs to be activated by writing a 0 to the MDIS bit in the CTRL register, and then the LDVAL registers need to be set to the maximum value.

The timer is a downcounter.

The following example code matches the described setup:

```c
// turn on PIT
PIT_MCR = 0x00;

// Timer 1
PIT_LDVAL1 = 0xFFFFFFFF; // setup timer 1 for maximum counting period
PIT_TCTRL1 = 0x0; // disable timer 1 interrupts
PIT_TCTRL1 |= CHN; // chain timer 1 to timer 0
PIT_TCTRL1 |= TEN; // start timer 1
```
To access the lifetime, read first LTMR64H and then LTMR64L.

```c
current_uptime = PIT_LTMR64H<<32;
current_uptime = current_uptime + PIT_LTMR64L;
```

## 53.9 PIT register descriptions

This section provides a detailed description of all registers accessible in the PIT module.

- See the chip-specific PIT information for the number of PIT channels used in this MCU.

### 53.9.1 PIT Memory map

PIT base address: 4008_4000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>PIT Module Control Register (MCR)</td>
<td>32</td>
<td>RW</td>
<td>0000_0002h</td>
</tr>
<tr>
<td>E0h</td>
<td>PIT Upper Lifetime Timer Register (LTMR64H)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E4h</td>
<td>PIT Lower Lifetime Timer Register (LTMR64L)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>100h</td>
<td>Timer Load Value Register (LDVAL0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>104h</td>
<td>Current Timer Value Register (CVAL0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>108h</td>
<td>Timer Control Register (TCTRL0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10Ch</td>
<td>Timer Flag Register (TFLG0)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>110h</td>
<td>Timer Load Value Register (LDVAL1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>114h</td>
<td>Current Timer Value Register (CVAL1)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>118h</td>
<td>Timer Control Register (TCTRL1)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>11Ch</td>
<td>Timer Flag Register (TFLG1)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>120h</td>
<td>Timer Load Value Register (LDVAL2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>124h</td>
<td>Current Timer Value Register (CVAL2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>128h</td>
<td>Timer Control Register (TCTRL2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>12Ch</td>
<td>Timer Flag Register (TFLG2)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>130h</td>
<td>Timer Load Value Register (LDVAL3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>134h</td>
<td>Current Timer Value Register (CVAL3)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>138h</td>
<td>Timer Control Register (TCTRL3)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>13Ch</td>
<td>Timer Flag Register (TFLG3)</td>
<td>32</td>
<td>W1C</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>
53.9.2 PIT Module Control Register (MCR)

53.9.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCR</td>
<td>0h</td>
</tr>
</tbody>
</table>

53.9.2.2 Function

This register enables or disables the PIT timer clocks and controls the timers when the PIT enters the Debug mode.

53.9.2.3 Diagram

Table continues on the next page...

53.9.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1-0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 MDIS</td>
<td>Module Disable for PIT</td>
</tr>
<tr>
<td></td>
<td>Disables the standard timers. The field must be enabled before any other setup is done.</td>
</tr>
<tr>
<td></td>
<td>0b - Clock for standard PIT timers is enabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Clock for standard PIT timers is disabled.</td>
</tr>
<tr>
<td>0 FRZ</td>
<td>Freeze</td>
</tr>
<tr>
<td></td>
<td>Allows the timers to be stopped when the device enters the Debug mode.</td>
</tr>
<tr>
<td></td>
<td>0b - Timers continue to run in Debug mode.</td>
</tr>
<tr>
<td></td>
<td>1b - Timers are stopped in Debug mode.</td>
</tr>
</tbody>
</table>

### 53.9.3 PIT Upper Lifetime Timer Register (LTMR64H)

#### 53.9.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LTMR64H</td>
<td>E0h</td>
</tr>
</tbody>
</table>

#### 53.9.3.2 Function

This register is intended for applications that chain timer 0 and timer 1 to build a 64-bit lifetimer.

#### 53.9.3.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

LTH
53.9.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Life Timer value</td>
</tr>
<tr>
<td>LTH</td>
<td>Shows the timer value of timer 1. If this register is read at a time t1, LTMR64L shows the value of timer 0 at time t1.</td>
</tr>
</tbody>
</table>

53.9.4 PIT Lower Lifetime Timer Register (LTMR64L)

53.9.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LTMR64L</td>
<td>E4h</td>
</tr>
</tbody>
</table>

53.9.4.2 Function

This register is intended for applications that chain timer 0 and timer 1 to build a 64-bit lifetimer.

To use LTMR64H and LTMR64L, timer 0 and timer 1 need to be chained. To obtain the correct value, first read LTMR64H and then LTMR64L. The value for the LTMR64H register is set to CVAL1 register at the time of the first access and the value of the LTMR64L register is set to CVAL0 register at first access. Therefore, the application is not affected by the carry-over effects of the running counter.

53.9.4.3 Diagram

```
+----+----+----+----+----+----+----+----+----+----+----+----+----+----+----+
<table>
<thead>
<tr>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

Chapter 53 Periodic Interrupt Timer (PIT)
### 53.9.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Life Timer value</td>
</tr>
<tr>
<td>LTL</td>
<td>Shows the value of timer 0 at the time LTMR64H was last read. It will only update if LTMR64H is read.</td>
</tr>
</tbody>
</table>

### 53.9.5 Timer Load Value Register (LDVAL0 - LDVAL3)

#### 53.9.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDVAL0</td>
<td>100h</td>
</tr>
<tr>
<td>LDVAL1</td>
<td>110h</td>
</tr>
<tr>
<td>LDVAL2</td>
<td>120h</td>
</tr>
<tr>
<td>LDVAL3</td>
<td>130h</td>
</tr>
</tbody>
</table>

#### 53.9.5.2 Function

These registers select the timeout period for the timer interrupts.

#### 53.9.5.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

TSV
53.9.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Timer Start Value</td>
</tr>
<tr>
<td>TSV</td>
<td>Sets the timer start value. The timer counts down until it reaches 0, then generates an interrupt and loads this register value again. Writing a new value to this register does not restart the timer; instead the value is loaded after the timer expires. To abort the current cycle and start a timer period with the new value, the timer must be disabled and enabled again.</td>
</tr>
</tbody>
</table>

53.9.6 Current Timer Value Register (CVAL0 - CVAL3)

53.9.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CVAL0</td>
<td>104h</td>
</tr>
<tr>
<td>CVAL1</td>
<td>114h</td>
</tr>
<tr>
<td>CVAL2</td>
<td>124h</td>
</tr>
<tr>
<td>CVAL3</td>
<td>134h</td>
</tr>
</tbody>
</table>

53.9.6.2 Function

These registers indicate the current timer position.

53.9.6.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

TVL
53.9.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-0</td>
<td>Current Timer Value</td>
</tr>
<tr>
<td>TVL</td>
<td>Represents the current timer value, if the timer is enabled.</td>
</tr>
</tbody>
</table>

**NOTE:**
- If the timer is disabled, do not use this field because its value is unreliable.
- The timer uses a downcounter. The timer values are frozen in the Debug mode if MCR[FRZ] is set.

53.9.7 Timer Control Register (TCTRL0 - TCTRL3)

53.9.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TCTRL0</td>
<td>108h</td>
</tr>
<tr>
<td>TCTRL1</td>
<td>118h</td>
</tr>
<tr>
<td>TCTRL2</td>
<td>128h</td>
</tr>
<tr>
<td>TCTRL3</td>
<td>138h</td>
</tr>
</tbody>
</table>

53.9.7.2 Function

These registers contain the control bits for each timer.

53.9.7.3 Diagram
53.9.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2 CHN</td>
<td>Chain Mode</td>
</tr>
<tr>
<td></td>
<td>When activated, timer n-1 needs to expire before timer n (n is &gt; 0) can decrement by 1.</td>
</tr>
<tr>
<td></td>
<td>Timer 0 cannot be chained.</td>
</tr>
<tr>
<td></td>
<td>0b - Timer is not chained.</td>
</tr>
<tr>
<td></td>
<td>1b - Timer is chained to a previous timer. For example, for channel 2, if this field is set, Timer 2 is chained to Timer 1.</td>
</tr>
<tr>
<td>1 TIE</td>
<td>Timer Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>When an interrupt is pending, or if TFLGn[TIF] is set, enabling the interrupt causes an interrupt event. To avoid this, the associated TFLGn[TIF] must be cleared first.</td>
</tr>
<tr>
<td></td>
<td>0b - Interrupt requests from Timer n are disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Interrupt is requested whenever TIF is set.</td>
</tr>
<tr>
<td>0 TEN</td>
<td>Timer Enable</td>
</tr>
<tr>
<td></td>
<td>Enables or disables the timer.</td>
</tr>
<tr>
<td></td>
<td>0b - Timer n is disabled.</td>
</tr>
<tr>
<td></td>
<td>1b - Timer n is enabled.</td>
</tr>
</tbody>
</table>

53.9.8 Timer Flag Register (TFLG0 - TFLG3)

53.9.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TFLG0</td>
<td>10Ch</td>
</tr>
<tr>
<td>TFLG1</td>
<td>11Ch</td>
</tr>
<tr>
<td>TFLG2</td>
<td>12Ch</td>
</tr>
<tr>
<td>TFLG3</td>
<td>13Ch</td>
</tr>
</tbody>
</table>

53.9.8.2 Function

These registers hold the PIT interrupt flags.
### 53.9.8.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 53.9.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-1</td>
<td>Reserved</td>
</tr>
<tr>
<td>TIF</td>
<td>Timer Interrupt Flag</td>
</tr>
<tr>
<td></td>
<td>Sets to 1 at the end of the timer period. Writing 1 to this flag clears it and writing 0 has no effect. If enabled, or, when TCTRLn[TIE] = 1, TIF causes an interrupt request.</td>
</tr>
<tr>
<td></td>
<td>0b - Timeout has not yet occurred. 1b - Timeout has occurred.</td>
</tr>
</tbody>
</table>
Chapter 54
Quad Timer (TMR)

54.1 Chip-specific TMR information

Table 54-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
<tr>
<td>and XBAR Assignments</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

54.2 Overview

Each timer module (TMR) contains four identical counter/timer groups. Each 16-bit counter/timer group contains a prescaler, a counter, a load register, a hold register, a capture register, two compare registers, two status and control registers, and one control register. All of the registers except the prescaler are read/writeable.

**NOTE**
This document uses the terms "Timer" and "Counter" interchangeably because the counter/timers may perform either or both tasks.

The load register provides the initialization value to the counter when the counter's terminal value has been reached.
The hold register captures the counter's value when other counters are being read. This feature supports the reading of cascaded counters.

The capture register enables an external signal to take a "snap shot" of the counter's current value.

The COMP1 and COMP2 registers provide the values to which the counter is compared. If a match occurs, the OFLAG (TMR Output signal) can be set, cleared, or toggled. At match time, an interrupt is generated if enabled, and the new compare value is loaded into the COMP1 or COMP2 registers from CMPLD1 and CMPLD2 if enabled.

The prescaler provides different time bases useful for clocking the counter/timer.

The counter provides the ability to count internal or external events.

Within a timer module (set of four timer/counters), the input pins are shareable.

54.3 Features

The TMR module design includes these distinctive features:

- Four 16-bit counters/timers
- Count up/down
- Counters are cascadable
- Programmable count modulo
- Max count rate equals peripheral clock/2 for external clocks
- Max count rate equals peripheral clock for internal clocks
- Count once or repeatedly
- Counters are preloadable
- Compare registers are preloadable (available with compare load feature)
- Counters can share available input pins
- Separate prescaler for each counter
- Each counter has capture and compare capability
- Programmable operation during debug mode
- Inputs may act as fault inputs
• Programmable input filter
• Counting start can be synchronized across counters

54.4 Modes of Operation
The TMR module design operates in only a single mode of operation: Functional Mode. The various counting modes are detailed in the Functional Description.

54.5 Block Diagram
Each of the timer/counter groups within the quad-timer are shown in this figure.

![Quad Timer Block Diagram](image-url)

Figure 54-1. Quad Timer Block Diagram
54.6 Memory Map and Registers

The address of a register is the sum of a base address and an address offset. The base address is defined at the chip level and the address offset is defined at the module level. Make certain to check which quad timer is available on the chip being used, and which timer channels have external I/O.

### TMR memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_C000</td>
<td>Timer Channel Compare Register 1 (TMR1_COMP10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401D_C002</td>
<td>Timer Channel Compare Register 2 (TMR1_COMP20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401D_C004</td>
<td>Timer Channel Capture Register (TMR1_CAPT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401D_C006</td>
<td>Timer Channel Load Register (TMR1_LOAD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401D_C008</td>
<td>Timer Channel Hold Register (TMR1_HOLD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401D_C00A</td>
<td>Timer Channel Counter Register (TMR1_CNTR0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401D_C00C</td>
<td>Timer Channel Control Register (TMR1_CTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401D_C00E</td>
<td>Timer Channel Status and Control Register (TMR1_SCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401D_C010</td>
<td>Timer Channel Comparator Load Register 1 (TMR1_CMPLD10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401D_C012</td>
<td>Timer Channel Comparator Load Register 2 (TMR1_CMPLD20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401D_C014</td>
<td>Timer Channel Comparator Status and Control Register (TMR1_CSCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401D_C016</td>
<td>Timer Channel Input Filter Register (TMR1_FILT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401D_C018</td>
<td>Timer Channel DMA Enable Register (TMR1_DMA0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401D_C01E</td>
<td>Timer Channel Enable Register (TMR1_ENBL)</td>
<td>16</td>
<td>R/W</td>
<td>000Fh</td>
<td>54.6.14/3008</td>
</tr>
<tr>
<td>401D_C020</td>
<td>Timer Channel Compare Register 1 (TMR1_COMP11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401D_C022</td>
<td>Timer Channel Compare Register 2 (TMR1_COMP21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401D_C024</td>
<td>Timer Channel Capture Register (TMR1_CAPT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401D_C026</td>
<td>Timer Channel Load Register (TMR1_LOAD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401D_C028</td>
<td>Timer Channel Hold Register (TMR1_HOLD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401D_C02A</td>
<td>Timer Channel Counter Register (TMR1_CNTR1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401D_C02C</td>
<td>Timer Channel Control Register (TMR1_CTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401D_C02E</td>
<td>Timer Channel Status and Control Register (TMR1_SCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### TMR memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_C030</td>
<td>Timer Channel Comparator Load Register 1 (TMR1_CMPLD11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401D_C032</td>
<td>Timer Channel Comparator Load Register 2 (TMR1_CMPLD21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401D_C034</td>
<td>Timer Channel Comparator Status and Control Register (TMR1_CSCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401D_C036</td>
<td>Timer Channel Input Filter Register (TMR1_FILT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401D_C038</td>
<td>Timer Channel DMA Enable Register (TMR1_DMA1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401D_C040</td>
<td>Timer Channel Compare Register 1 (TMR1_COMP12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401D_C042</td>
<td>Timer Channel Compare Register 2 (TMR1_COMP22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401D_C044</td>
<td>Timer Channel Capture Register (TMR1_CAPT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401D_C046</td>
<td>Timer Channel Load Register (TMR1_LOAD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401D_C048</td>
<td>Timer Channel Hold Register (TMR1_HOLD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401D_C04A</td>
<td>Timer Channel Counter Register (TMR1_CNTR2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401D_C04C</td>
<td>Timer Channel Control Register (TMR1_CTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401D_C04E</td>
<td>Timer Channel Status and Control Register (TMR1_SCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401D_C050</td>
<td>Timer Channel Comparator Load Register 1 (TMR1_CMPLD12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401D_C052</td>
<td>Timer Channel Comparator Load Register 2 (TMR1_CMPLD22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401D_C054</td>
<td>Timer Channel Comparator Status and Control Register (TMR1_CSCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401D_C056</td>
<td>Timer Channel Input Filter Register (TMR1_FILT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401D_C058</td>
<td>Timer Channel DMA Enable Register (TMR1_DMA2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401D_C060</td>
<td>Timer Channel Compare Register 1 (TMR1_COMP13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401D_C062</td>
<td>Timer Channel Compare Register 2 (TMR1_COMP23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401D_C064</td>
<td>Timer Channel Capture Register (TMR1_CAPT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401D_C066</td>
<td>Timer Channel Load Register (TMR1_LOAD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401D_C068</td>
<td>Timer Channel Hold Register (TMR1_HOLD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401D_C06A</td>
<td>Timer Channel Counter Register (TMR1_CNTR3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401D_C06C</td>
<td>Timer Channel Control Register (TMR1_CTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401D_C06E</td>
<td>Timer Channel Status and Control Register (TMR1_SCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401D_C070</td>
<td>Timer Channel Comparator Load Register 1 (TMR1_CMPLD13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401D_C072</td>
<td>Timer Channel Comparator Load Register 2 (TMR1_CMPLD23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## TMR memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401D_C074</td>
<td>Timer Channel Comparator Status and Control Register (TMR1_CSCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401D_C076</td>
<td>Timer Channel Input Filter Register (TMR1_FILT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401D_C078</td>
<td>Timer Channel DMA Enable Register (TMR1_DMA3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_0000</td>
<td>Timer Channel Compare Register 1 (TMR2_COMP10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_0002</td>
<td>Timer Channel Compare Register 2 (TMR2_COMP20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_0004</td>
<td>Timer Channel Capture Register (TMR2_CAPT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_0006</td>
<td>Timer Channel Load Register (TMR2_LOAD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_0008</td>
<td>Timer Channel Hold Register (TMR2_HOLD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_000A</td>
<td>Timer Channel Counter Register (TMR2_CNTR0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_000C</td>
<td>Timer Channel Control Register (TMR2_CTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_000E</td>
<td>Timer Channel Status and Control Register (TMR2_SCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_0010</td>
<td>Timer Channel Comparator Load Register 1 (TMR2_CMPLD10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_0012</td>
<td>Timer Channel Comparator Load Register 2 (TMR2_CMPLD20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_0014</td>
<td>Timer Channel Comparator Status and Control Register (TMR2_CSCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_0016</td>
<td>Timer Channel Input Filter Register (TMR2_FILT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_0018</td>
<td>Timer Channel DMA Enable Register (TMR2_DMA0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_001E</td>
<td>Timer Channel Enable Register (TMR2_ENBL)</td>
<td>16</td>
<td>R/W</td>
<td>000Fh</td>
<td>54.6.14/3008</td>
</tr>
<tr>
<td>401E_0020</td>
<td>Timer Channel Compare Register 1 (TMR2_COMP11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_0022</td>
<td>Timer Channel Compare Register 2 (TMR2_COMP21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_0024</td>
<td>Timer Channel Capture Register (TMR2_CAPT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_0026</td>
<td>Timer Channel Load Register (TMR2_LOAD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_0028</td>
<td>Timer Channel Hold Register (TMR2_HOLD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_002A</td>
<td>Timer Channel Counter Register (TMR2_CNTR1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_002C</td>
<td>Timer Channel Control Register (TMR2_CTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_002E</td>
<td>Timer Channel Status and Control Register (TMR2_SCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_0030</td>
<td>Timer Channel Comparator Load Register 1 (TMR2_CMPLD11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_0032</td>
<td>Timer Channel Comparator Load Register 2 (TMR2_CMPLD21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_0034</td>
<td>Timer Channel Comparator Status and Control Register (TMR2_CSCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### TMR memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401E_0036</td>
<td>Timer Channel Input Filter Register (TMR2_FILT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_0038</td>
<td>Timer Channel DMA Enable Register (TMR2_DMA1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_0040</td>
<td>Timer Channel Compare Register 1 (TMR2_COMP12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_0042</td>
<td>Timer Channel Compare Register 2 (TMR2_COMP22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_0044</td>
<td>Timer Channel Capture Register (TMR2_CAPT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_0046</td>
<td>Timer Channel Load Register (TMR2_LOAD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_0048</td>
<td>Timer Channel Hold Register (TMR2_HOLD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_004A</td>
<td>Timer Channel Counter Register (TMR2_CNTR2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_004C</td>
<td>Timer Channel Control Register (TMR2_CTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_004E</td>
<td>Timer Channel Status and Control Register (TMR2_SCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_0050</td>
<td>Timer Channel Comparator Load Register 1 (TMR2_CMPLD12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_0052</td>
<td>Timer Channel Comparator Load Register 2 (TMR2_CMPLD22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_0054</td>
<td>Timer Channel Comparator Status and Control Register (TMR2_CSCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_0056</td>
<td>Timer Channel Input Filter Register (TMR2_FILT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_0058</td>
<td>Timer Channel DMA Enable Register (TMR2_DMA2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_0060</td>
<td>Timer Channel Compare Register 1 (TMR2_COMP13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_0062</td>
<td>Timer Channel Compare Register 2 (TMR2_COMP23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_0064</td>
<td>Timer Channel Capture Register (TMR2_CAPT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_0066</td>
<td>Timer Channel Load Register (TMR2_LOAD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_0068</td>
<td>Timer Channel Hold Register (TMR2_HOLD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_006A</td>
<td>Timer Channel Counter Register (TMR2_CNTR3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_006C</td>
<td>Timer Channel Control Register (TMR2_CTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_006E</td>
<td>Timer Channel Status and Control Register (TMR2_SCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_0070</td>
<td>Timer Channel Comparator Load Register 1 (TMR2_CMPLD13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_0072</td>
<td>Timer Channel Comparator Load Register 2 (TMR2_CMPLD23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_0074</td>
<td>Timer Channel Comparator Status and Control Register (TMR2_CSCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_0076</td>
<td>Timer Channel Input Filter Register (TMR2_FILT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_0078</td>
<td>Timer Channel DMA Enable Register (TMR2_DMA3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
</tbody>
</table>
### TMR memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401E_4000</td>
<td>Timer Channel Compare Register 1 (TMR3_COMP10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_4002</td>
<td>Timer Channel Compare Register 2 (TMR3_COMP20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_4004</td>
<td>Timer Channel Capture Register (TMR3_CAPT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_4006</td>
<td>Timer Channel Load Register (TMR3_LOAD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_4008</td>
<td>Timer Channel Hold Register (TMR3_HOLD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_400A</td>
<td>Timer Channel Counter Register (TMR3_CNTR0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_400C</td>
<td>Timer Channel Control Register (TMR3_CTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_400E</td>
<td>Timer Channel Status and Control Register (TMR3_SCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_4010</td>
<td>Timer Channel Comparator Load Register 1 (TMR3_CMPLD10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_4012</td>
<td>Timer Channel Comparator Load Register 2 (TMR3_CMPLD20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_4014</td>
<td>Timer Channel Comparator Status and Control Register (TMR3_CSCCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_4016</td>
<td>Timer Channel Input Filter Register (TMR3_FILT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_4018</td>
<td>Timer Channel DMA Enable Register (TMR3_DMA0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_401E</td>
<td>Timer Channel Enable Register (TMR3_ENBL)</td>
<td>16</td>
<td>R/W</td>
<td>000Fh</td>
<td>54.6.14/3008</td>
</tr>
<tr>
<td>401E_4020</td>
<td>Timer Channel Compare Register 1 (TMR3_COMP11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_4022</td>
<td>Timer Channel Compare Register 2 (TMR3_COMP21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_4024</td>
<td>Timer Channel Capture Register (TMR3_CAPT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_4026</td>
<td>Timer Channel Load Register (TMR3_LOAD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_4028</td>
<td>Timer Channel Hold Register (TMR3_HOLD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_402A</td>
<td>Timer Channel Counter Register (TMR3_CNTR1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_402C</td>
<td>Timer Channel Control Register (TMR3_CTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_402E</td>
<td>Timer Channel Status and Control Register (TMR3_SCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_4030</td>
<td>Timer Channel Comparator Load Register 1 (TMR3_CMPLD11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_4032</td>
<td>Timer Channel Comparator Load Register 2 (TMR3_CMPLD21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_4034</td>
<td>Timer Channel Comparator Status and Control Register (TMR3_CSCCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_4036</td>
<td>Timer Channel Input Filter Register (TMR3_FILT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_4038</td>
<td>Timer Channel DMA Enable Register (TMR3_DMA1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_4040</td>
<td>Timer Channel Compare Register 1 (TMR3_COMP12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_4042</td>
<td>Timer Channel Compare Register 2 (TMR3_COMP22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## TMR memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401E_4044</td>
<td>Timer Channel Capture Register (TMR3_CAPT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_4046</td>
<td>Timer Channel Load Register (TMR3_LOAD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_4048</td>
<td>Timer Channel Hold Register (TMR3_HOLD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_404A</td>
<td>Timer Channel Counter Register (TMR3_CNTR2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_404C</td>
<td>Timer Channel Control Register (TMR3_CTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_404E</td>
<td>Timer Channel Status and Control Register (TMR3_SCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_4050</td>
<td>Timer Channel Comparator Load Register 1 (TMR3_CMPLD12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_4052</td>
<td>Timer Channel Comparator Load Register 2 (TMR3_CMPLD22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_4054</td>
<td>Timer Channel Comparator Status and Control Register (TMR3_CSCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_4056</td>
<td>Timer Channel Input Filter Register (TMR3_FILT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_4058</td>
<td>Timer Channel DMA Enable Register (TMR3_DMA2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_4060</td>
<td>Timer Channel Compare Register 1 (TMR3_COMP13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_4062</td>
<td>Timer Channel Compare Register 2 (TMR3_COMP23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_4064</td>
<td>Timer Channel Capture Register (TMR3_CAPT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_4066</td>
<td>Timer Channel Load Register (TMR3_LOAD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_4068</td>
<td>Timer Channel Hold Register (TMR3_HOLD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_406A</td>
<td>Timer Channel Counter Register (TMR3_CNTR3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_406C</td>
<td>Timer Channel Control Register (TMR3_CTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_406E</td>
<td>Timer Channel Status and Control Register (TMR3_SCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_4070</td>
<td>Timer Channel Comparator Load Register 1 (TMR3_CMPLD13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_4072</td>
<td>Timer Channel Comparator Load Register 2 (TMR3_CMPLD23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_4074</td>
<td>Timer Channel Comparator Status and Control Register (TMR3_CSCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_4076</td>
<td>Timer Channel Input Filter Register (TMR3_FILT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_4078</td>
<td>Timer Channel DMA Enable Register (TMR3_DMA3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_8000</td>
<td>Timer Channel Compare Register 1 (TMR4_COMP10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_8002</td>
<td>Timer Channel Compare Register 2 (TMR4_COMP20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_8004</td>
<td>Timer Channel Capture Register (TMR4_CAPT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_8006</td>
<td>Timer Channel Load Register (TMR4_LOAD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_8008</td>
<td>Timer Channel Hold Register (TMR4_HOLD0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### TMR memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401E_800A</td>
<td>Timer Channel Counter Register (TMR4_CNTR0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_800C</td>
<td>Timer Channel Control Register (TMR4_CTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_800E</td>
<td>Timer Channel Status and Control Register (TMR4_SCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_8010</td>
<td>Timer Channel Comparator Load Register 1 (TMR4_CMPLD10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_8012</td>
<td>Timer Channel Comparator Load Register 2 (TMR4_CMPLD20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_8014</td>
<td>Timer Channel Comparator Status and Control Register (TMR4_CSCTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_8016</td>
<td>Timer Channel Input Filter Register (TMR4_FILT0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_8018</td>
<td>Timer Channel DMA Enable Register (TMR4_DMA0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_801E</td>
<td>Timer Channel Enable Register (TMR4_ENBL)</td>
<td>16</td>
<td>R/W</td>
<td>000Fh</td>
<td>54.6.14/3008</td>
</tr>
<tr>
<td>401E_8020</td>
<td>Timer Channel Compare Register 1 (TMR4_COMP11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_8022</td>
<td>Timer Channel Compare Register 2 (TMR4_COMP21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_8024</td>
<td>Timer Channel Capture Register (TMR4_CAPT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_8026</td>
<td>Timer Channel Load Register (TMR4_LOAD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_8028</td>
<td>Timer Channel Hold Register (TMR4_HOLD1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_802A</td>
<td>Timer Channel Counter Register (TMR4_CNTR1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_802C</td>
<td>Timer Channel Control Register (TMR4_CTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_802E</td>
<td>Timer Channel Status and Control Register (TMR4_SCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_8030</td>
<td>Timer Channel Comparator Load Register 1 (TMR4_CMPLD11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_8032</td>
<td>Timer Channel Comparator Load Register 2 (TMR4_CMPLD21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_8034</td>
<td>Timer Channel Comparator Status and Control Register (TMR4_CSCTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_8036</td>
<td>Timer Channel Input Filter Register (TMR4_FILT1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_8038</td>
<td>Timer Channel DMA Enable Register (TMR4_DMA1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_8040</td>
<td>Timer Channel Compare Register 1 (TMR4_COMP12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_8042</td>
<td>Timer Channel Compare Register 2 (TMR4_COMP22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_8044</td>
<td>Timer Channel Capture Register (TMR4_CAPT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_8046</td>
<td>Timer Channel Load Register (TMR4_LOAD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_8048</td>
<td>Timer Channel Hold Register (TMR4_HOLD2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_804A</td>
<td>Timer Channel Counter Register (TMR4_CNTR2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_804C</td>
<td>Timer Channel Control Register (TMR4_CTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### TMR memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>401E_804E</td>
<td>Timer Channel Status and Control Register (TMR4_SCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_8050</td>
<td>Timer Channel Comparator Load Register 1 (TMR4_CMPLD12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_8052</td>
<td>Timer Channel Comparator Load Register 2 (TMR4_CMPLD22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_8054</td>
<td>Timer Channel Comparator Status and Control Register (TMR4_CSCTRL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_8056</td>
<td>Timer Channel Input Filter Register (TMR4_FILT2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_8058</td>
<td>Timer Channel DMA Enable Register (TMR4_DMA2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
<tr>
<td>401E_8060</td>
<td>Timer Channel Compare Register 1 (TMR4_COMP13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.1/2997</td>
</tr>
<tr>
<td>401E_8062</td>
<td>Timer Channel Compare Register 2 (TMR4_COMP23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.2/2998</td>
</tr>
<tr>
<td>401E_8064</td>
<td>Timer Channel Capture Register (TMR4_CAPT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.3/2998</td>
</tr>
<tr>
<td>401E_8066</td>
<td>Timer Channel Load Register (TMR4_LOAD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.4/2998</td>
</tr>
<tr>
<td>401E_8068</td>
<td>Timer Channel Hold Register (TMR4_HOLD3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.5/2999</td>
</tr>
<tr>
<td>401E_806A</td>
<td>Timer Channel Counter Register (TMR4_CNTR3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.6/2999</td>
</tr>
<tr>
<td>401E_806C</td>
<td>Timer Channel Control Register (TMR4_CTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.7/2999</td>
</tr>
<tr>
<td>401E_806E</td>
<td>Timer Channel Status and Control Register (TMR4_SCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.8/3002</td>
</tr>
<tr>
<td>401E_8070</td>
<td>Timer Channel Comparator Load Register 1 (TMR4_CMPLD13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.9/3003</td>
</tr>
<tr>
<td>401E_8072</td>
<td>Timer Channel Comparator Load Register 2 (TMR4_CMPLD23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.10/3004</td>
</tr>
<tr>
<td>401E_8074</td>
<td>Timer Channel Comparator Status and Control Register (TMR4_CSCTRL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.11/3004</td>
</tr>
<tr>
<td>401E_8076</td>
<td>Timer Channel Input Filter Register (TMR4_FILT3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.12/3006</td>
</tr>
<tr>
<td>401E_8078</td>
<td>Timer Channel DMA Enable Register (TMR4_DMA3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>54.6.13/3007</td>
</tr>
</tbody>
</table>

### 54.6.1 Timer Channel Compare Register 1 (TMRx_COMP1n)

Address: Base address + 0h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read/Write</td>
<td>COMPARISON_1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

---

**Chapter 54 Quad Timer (TMR)**

*NPX RT1060 Processor Reference Manual, Rev. 2, 12/2019*
### TMRx_COMP1n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARISON_1</td>
<td>Comparison Value 1&lt;br&gt;This read/write register stores the value used for comparison with the counter value in count up mode.</td>
</tr>
</tbody>
</table>

#### 54.6.2 Timer Channel Compare Register 2 (TMRx_COMP2n)

Address: Base address + 2h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**COMPARISON_2**

#### TMRx_COMP2n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARISON_2</td>
<td>Comparison Value 2&lt;br&gt;This read/write register stores the value used for comparison with the counter value in count down mode or alternating compare mode.</td>
</tr>
</tbody>
</table>

#### 54.6.3 Timer Channel Capture Register (TMRx_CAPTn)

Address: Base address + 4h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**CAPTURE**

#### TMRx_CAPTn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CAPTURE</td>
<td>Capture Value&lt;br&gt;This read/write register stores the value captured from the counter.</td>
</tr>
</tbody>
</table>

#### 54.6.4 Timer Channel Load Register (TMRx_LOADn)

Address: Base address + 6h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**LOAD**
### TMRx_LOADn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>LOAD</td>
<td>Timer Load Register</td>
</tr>
<tr>
<td></td>
<td>This read/write register stores the value used to initialize the counter after counter compare.</td>
</tr>
</tbody>
</table>

#### 54.6.5 Timer Channel Hold Register (TMRx_HOLDn)

**Address:** Base address + 8h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**Field** HOLD  
This read/write register stores the counter's values of specific channels whenever any of the four counters within a module is read.

#### 54.6.6 Timer Channel Counter Register (TMRx_CNTRn)

**Address:** Base address + Ah offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**Field** COUNTER  
This read/write register is the counter for the corresponding channel in a timer module.

#### 54.6.7 Timer Channel Control Register (TMRx_CTRLLn)

**Address:** Base address + Ch offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CM</td>
<td>PCS</td>
<td>SCS</td>
<td>ONCE</td>
<td>LENGTH</td>
<td>DIR</td>
<td>COINIT</td>
<td>OUTMODE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**Field** CM  

**Field** PCS  

**Field** SCS  

**Field** ONCE  

**Field** LENGTH  

**Field** DIR  

**Field** COINIT  

**Field** OUTMODE  

NXPA Semiconductors
## TMRx_CTRLn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–13 CM</td>
<td>Count Mode</td>
</tr>
<tr>
<td></td>
<td>These bits control the basic counting and behavior of the counter.</td>
</tr>
<tr>
<td>000</td>
<td>No operation</td>
</tr>
<tr>
<td>001</td>
<td>Count rising edges of primary source(^1)</td>
</tr>
<tr>
<td>010</td>
<td>Count rising and falling edges of primary source(^2)</td>
</tr>
<tr>
<td>011</td>
<td>Count rising edges of primary source while secondary input high active</td>
</tr>
<tr>
<td>100</td>
<td>Quadrature count mode, uses primary and secondary sources</td>
</tr>
<tr>
<td>101</td>
<td>Count rising edges of primary source; secondary source specifies direction(^3)</td>
</tr>
<tr>
<td>110</td>
<td>Edge of secondary source triggers primary count until compare</td>
</tr>
<tr>
<td>111</td>
<td>Cascaded counter mode (up/down)(^4)</td>
</tr>
<tr>
<td>12–9 PCS</td>
<td>Primary Count Source</td>
</tr>
<tr>
<td></td>
<td>These bits select the primary count source.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> A timer selecting its own output for input is not a legal choice. The result is no counting.</td>
</tr>
<tr>
<td>0000</td>
<td>Counter 0 input pin</td>
</tr>
<tr>
<td>0001</td>
<td>Counter 1 input pin</td>
</tr>
<tr>
<td>0010</td>
<td>Counter 2 input pin</td>
</tr>
<tr>
<td>0011</td>
<td>Counter 3 input pin</td>
</tr>
<tr>
<td>0100</td>
<td>Counter 0 output</td>
</tr>
<tr>
<td>0101</td>
<td>Counter 1 output</td>
</tr>
<tr>
<td>0110</td>
<td>Counter 2 output</td>
</tr>
<tr>
<td>0111</td>
<td>Counter 3 output</td>
</tr>
<tr>
<td>1000</td>
<td>IP bus clock divide by 1 prescaler</td>
</tr>
<tr>
<td>1001</td>
<td>IP bus clock divide by 2 prescaler</td>
</tr>
<tr>
<td>1010</td>
<td>IP bus clock divide by 4 prescaler</td>
</tr>
<tr>
<td>1011</td>
<td>IP bus clock divide by 8 prescaler</td>
</tr>
<tr>
<td>1100</td>
<td>IP bus clock divide by 16 prescaler</td>
</tr>
<tr>
<td>1101</td>
<td>IP bus clock divide by 32 prescaler</td>
</tr>
<tr>
<td>1110</td>
<td>IP bus clock divide by 64 prescaler</td>
</tr>
<tr>
<td>1111</td>
<td>IP bus clock divide by 128 prescaler</td>
</tr>
<tr>
<td>8–7 SCS</td>
<td>Secondary Count Source</td>
</tr>
<tr>
<td></td>
<td>These bits identify the external input pin to be used as a count command or timer command. The selected input can trigger the timer to capture the current value of CNTR. The selected input can also be used to specify the count direction. The selected signal can also be used as a fault input when CSCTRL[FAULT] is set. The polarity of the signal can be inverted by SCTRL[IPS].</td>
</tr>
<tr>
<td>00</td>
<td>Counter 0 input pin</td>
</tr>
<tr>
<td>01</td>
<td>Counter 1 input pin</td>
</tr>
<tr>
<td>10</td>
<td>Counter 2 input pin</td>
</tr>
<tr>
<td>11</td>
<td>Counter 3 input pin</td>
</tr>
<tr>
<td>6 ONCE</td>
<td>Count Once</td>
</tr>
<tr>
<td></td>
<td>This bit selects continuous or one shot counting mode.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
# TMRx_CTRLn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Count repeatedly.</td>
</tr>
<tr>
<td>1</td>
<td>Count until compare and then stop. If counting up, a successful compare occurs when the counter reaches a COMP1 value. If counting down, a successful compare occurs when the counter reaches a COMP2 value. When output mode $4$ is used, the counter re-initializes after reaching the COMP1 value, continues to count to the COMP2 value, and then stops.</td>
</tr>
<tr>
<td>5</td>
<td>Count Length</td>
</tr>
<tr>
<td>LENGTH</td>
<td>This bit determines whether the counter:</td>
</tr>
<tr>
<td></td>
<td>• counts to the compare value and then re-initializes itself to the value specified in the LOAD (or CMPLD2) register, or</td>
</tr>
<tr>
<td></td>
<td>• continues counting past the compare value to the binary rollover.</td>
</tr>
<tr>
<td>0</td>
<td>Count until roll over at $FFFF$ and continue from $0000$.</td>
</tr>
<tr>
<td>1</td>
<td>Count until compare, then re-initialize. If counting up, a successful compare occurs when the counter reaches a COMP1 value. If counting down, a successful compare occurs when the counter reaches a COMP2 value. When output mode $4$ is used, alternating values of COMP1 and COMP2 are used to generate successful comparisons. For example, the counter counts until a COMP1 value is reached, re-initializes, counts until COMP2 value is reached, re-initializes, counts until COMP1 value is reached, and so on.</td>
</tr>
<tr>
<td>4</td>
<td>Count Direction</td>
</tr>
<tr>
<td>DIR</td>
<td>This bit selects either the normal count direction up, or the reverse direction, down.</td>
</tr>
<tr>
<td>0</td>
<td>Count up.</td>
</tr>
<tr>
<td>1</td>
<td>Count down.</td>
</tr>
<tr>
<td>3</td>
<td>Co-Channel Initialization</td>
</tr>
<tr>
<td>COINIT</td>
<td>This bit enables another counter/timer within the module to force the re-initialization of this counter/timer when it has an active compare event.</td>
</tr>
<tr>
<td>0</td>
<td>Co-channel counter/timers cannot force a re-initialization of this counter/timer</td>
</tr>
<tr>
<td>1</td>
<td>Co-channel counter/timers may force a re-initialization of this counter/timer</td>
</tr>
<tr>
<td>OUTMODE</td>
<td>Output Mode</td>
</tr>
<tr>
<td></td>
<td>These bits determine the mode of operation for the OFLAG output signal.</td>
</tr>
<tr>
<td>000</td>
<td>Asserted while counter is active</td>
</tr>
<tr>
<td>001</td>
<td>Clear OFLAG output on successful compare</td>
</tr>
<tr>
<td>010</td>
<td>Set OFLAG output on successful compare</td>
</tr>
<tr>
<td>011</td>
<td>Toggle OFLAG output on successful compare</td>
</tr>
<tr>
<td>100</td>
<td>Toggle OFLAG output using alternating compare registers</td>
</tr>
<tr>
<td>101</td>
<td>Set on compare, cleared on secondary source input edge</td>
</tr>
<tr>
<td>110</td>
<td>Set on compare, cleared on counter rollover</td>
</tr>
<tr>
<td>111</td>
<td>Enable gated clock output while counter is active</td>
</tr>
</tbody>
</table>

1. Rising edges are counted only when $SCTRL[IPS] = 0$. Falling edges are counted when $SCTRL[IPS] = 1$. If the primary count source is IP bus clock divide by $1$, only rising edges are counted regardless of the value of $SCTRL[IPS]$. |
2. IP bus clock divide by $1$ cannot be used as a primary count source in edge count mode. |
3. Rising edges are counted only when $SCTRL[IPS] = 0$. Falling edges are counted when $SCTRL[IPS] = 1$. |
4. The primary count source must be set to one of the counter outputs. |
54.6.8  Timer Channel Status and Control Register (TMRx_SCTRLn)

Address: Base address + Eh offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>TCF</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>TCFIE</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>TOF</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>TOFIE</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>IEF</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>IEFIE</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>IPS</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>INPUT</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

TCFx_SCTRLn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15 TCF| Timer Compare Flag  
This bit is set when a successful compare occurs. This bit is cleared by writing a zero to this bit location. |
| 14 TCFIE| Timer Compare Flag Interrupt Enable  
This bit (when set) enables interrupts when TCF is set. |
| 13 TOF| Timer Overflow Flag  
This bit is set when the counter rolls over its maximum value $FFFF or $0000 (depending on count direction). This bit is cleared by writing a zero to this bit location. |
| 12 TOFIE| Timer Overflow Flag Interrupt Enable  
This bit (when set) enables interrupts when TOF is set. |
| 11 IEF| Input Edge Flag  
This bit is set when CAPTMODE is enabled and a proper input transition occurs (on an input selected as a secondary count source) while the count mode does not equal 000. This bit is cleared by writing a zero to this bit position. This bit can also be cleared automatically by a read of CAPT when DMA[IEFDE] is set. 
NOTE: Setting the input polarity select bit (IPS) changes the edge to be detected. Also, the control register’s secondary count source determines which external input pin is monitored by the detection circuitry. |
| 10 IEFIE| Input Edge Flag Interrupt Enable  
This bit (when set) enables interrupts when IEF is set. 
Restriction: Do not set both this bit and DMA[IEFDE]. |
| 9 IPS| Input Polarity Select  
This bit (when set) inverts the input signal polarity. |
| 8 INPUT| External Input Signal  
This read-only bit reflects the current state of the external input pin selected via the secondary count source after application of IPS and filtering. |

Table continues on the next page...
### TMRx_SCTRLn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| **7–6 CAPTURE_MODE** | Input Capture Mode  
These bits specify the operation of the capture register as well as the operation of the input edge flag. The input source is the secondary count source.  
00 Capture function is disabled  
01 Load capture register on rising edge (when IPS=0) or falling edge (when IPS=1) of input  
10 Load capture register on falling edge (when IPS=0) or rising edge (when IPS=1) of input  
11 Load capture register on both edges of input |
| **5 MSTR** | Master Mode  
This bit (when set) enables the compare function's output to be broadcasted to the other counters/timers in the module. This signal then can be used to re-initialize the other counters and/or force their OFLAG signal outputs. |
| **4 EEOF** | Enable External OFLAG Force  
This bit (when set) enables the compare from another counter/timer within the same module to force the state of this counter's OFLAG output signal. |
| **3 VAL** | Forced OFLAG Value  
This bit determines the value of the OFLAG output signal when software triggers a FORCE command. |
| **2 FORCE** | Force OFLAG Output  
This write only bit forces the current value of VAL to be written to the OFLAG output. This bit always reads as a zero. VAL and FORCE can be written simultaneously in a single write operation. Write to FORCE only if the counter is disabled. Setting this bit while the counter is enabled may yield unpredictable results. |
| **1 OPS** | Output Polarity Select  
This bit determines the polarity of the OFLAG output signal.  
0 True polarity.  
1 Inverted polarity. |
| **0 OEN** | Output Enable  
This bit determines the direction of the external pin.  
0 The external pin is configured as an input.  
1 The OFLAG output signal is driven on the external pin. Other timer groups using this external pin as their input see the driven value. The polarity of the signal is determined by OPS. |

### 54.6.9 Timer Channel Comparator Load Register 1 (TMRx_CMPLD1n)

Address: Base address + 10h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors 3003
### TMRx_CMPLD1n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARATOR_</td>
<td>This read/write register is the comparator 1 preload value for the COMP1 register for the corresponding channel in a timer module.</td>
</tr>
<tr>
<td>LOAD_1</td>
<td></td>
</tr>
</tbody>
</table>

### 54.6.10 Timer Channel Comparator Load Register 2 (TMRx_CMPLD2n)

**Address:** Base address + 12h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
</tr>
<tr>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
</tr>
<tr>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
</tr>
<tr>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>COMPARATOR_</td>
<td>LOAD_2</td>
</tr>
<tr>
<td>Description</td>
<td>This read/write register is the comparator 2 preload value for the COMP2 register for the corresponding channel in a timer module.</td>
</tr>
<tr>
<td>Read Write</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

### 54.6.11 Timer Channel Comparator Status and Control Register (TMRx_CSCTRLn)

**Address:** Base address + 14h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
</tr>
<tr>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
</tr>
<tr>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
</tr>
<tr>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>TCF2EN</td>
<td>TCF1EN</td>
</tr>
<tr>
<td>TCF2</td>
<td>TCF1</td>
</tr>
<tr>
<td>CL2</td>
<td>CL1</td>
</tr>
<tr>
<td>Description</td>
<td></td>
</tr>
<tr>
<td>Read Write</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
</tr>
</tbody>
</table>

### TMRx_CSCTRLn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 DBG_EN</td>
<td>Debug Actions Enable</td>
</tr>
<tr>
<td>Description</td>
<td>These bits allow the TMR module to perform certain actions in response to the chip entering debug mode.</td>
</tr>
<tr>
<td>Read Write</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>00 Continue with normal operation during debug mode. (default) 01 Halt TMR counter during debug mode.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>Force TMR output to logic 0 (prior to consideration of SCTRL[OPS]).</td>
</tr>
<tr>
<td>11</td>
<td>Both halt counter and force output to 0 during debug mode.</td>
</tr>
<tr>
<td>13</td>
<td>Fault Enable</td>
</tr>
<tr>
<td></td>
<td>The selected secondary input acts as a fault signal so that the timer OFLAG is cleared when the secondary input is set. When the secondary input is used in this mode, there is no resynchronization of the input so that there is a combinational path to clear the OFLAG. Fault inputs less than two clock periods wide will not be latched. Latched faults will be cleared the next time that the counter logic sets the OFLAG.</td>
</tr>
<tr>
<td>0</td>
<td>Fault function disabled.</td>
</tr>
<tr>
<td>1</td>
<td>Fault function enabled.</td>
</tr>
<tr>
<td>12</td>
<td>Alternative Load Enable</td>
</tr>
<tr>
<td></td>
<td>This bit allows for an alternative method for loading the counter during modulo counting. Normally, the counter can be loaded only with the value from the LOAD register. When this bit is set, the counter is loaded from the LOAD register when counting up and a match with COMP1 occurs, or the counter is loaded from the CMPLD2 register when counting down and a match with COMP2 occurs.</td>
</tr>
<tr>
<td>0</td>
<td>Counter can be re-initialized only with the LOAD register.</td>
</tr>
<tr>
<td>1</td>
<td>Counter can be re-initialized with the LOAD or CMPLD2 registers depending on count direction.</td>
</tr>
<tr>
<td>11</td>
<td>Reload on Capture</td>
</tr>
<tr>
<td></td>
<td>This bit enables the capture function to cause the counter to be reloaded from the LOAD register.</td>
</tr>
<tr>
<td>0</td>
<td>Do not reload the counter on a capture event.</td>
</tr>
<tr>
<td>1</td>
<td>Reload the counter on a capture event.</td>
</tr>
<tr>
<td>10</td>
<td>Triggered Count Initialization Control</td>
</tr>
<tr>
<td></td>
<td>This bit is used during triggered count mode, CTRL[CM] = 110, to enable the counter to be re-initialized when a second trigger occurs while the counter is still counting. Normally, the second trigger causes the counting to stop/pause until a third trigger occurs. With this bit set, a second trigger event causes the counter to re-initialize and continue counting.</td>
</tr>
<tr>
<td>0</td>
<td>Stop counter upon receiving a second trigger event while still counting from the first trigger event.</td>
</tr>
<tr>
<td>1</td>
<td>Reload the counter upon receiving a second trigger event while still counting from the first trigger event.</td>
</tr>
<tr>
<td>9</td>
<td>Counting Direction Indicator</td>
</tr>
<tr>
<td></td>
<td>This read-only bit is used during quadrature count mode, CTRL[CM] = 100, to read the direction of the last count. CTRL[DIR] reverses the sense of this bit.</td>
</tr>
<tr>
<td>0</td>
<td>The last count was in the DOWN direction.</td>
</tr>
<tr>
<td>1</td>
<td>The last count was in the UP direction.</td>
</tr>
<tr>
<td>8</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>7</td>
<td>Timer Compare 2 Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>An interrupt is issued when both this bit and TCF2 are set.</td>
</tr>
<tr>
<td>6</td>
<td>Timer Compare 1 Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>An interrupt is issued when both this bit and TCF1 are set.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### TMRx_CSCTRLn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 5 TCF2 | Timer Compare 2 Interrupt Flag  
When set, this bit indicates a successful comparison of the timer and the COMP2 register has occurred. This bit is sticky, and will remain set until explicitly cleared by writing a zero to this bit location. |
| 4 TCF1 | Timer Compare 1 Interrupt Flag  
When set, this bit indicates a successful comparison of the timer and the COMP1 register has occurred. This bit is sticky, and will remain set until explicitly cleared by writing a zero to this bit location. |
| 3–2 CL2 | Compare Load Control 2  
These bits control when COMP2 is preloaded with the value from CMPLD2.  
00 Never preload  
01 Load upon successful compare with the value in COMP1  
10 Load upon successful compare with the value in COMP2  
11 Reserved |
| CL1 | Compare Load Control 1  
These bits control when COMP1 is preloaded with the value from CMPLD1.  
00 Never preload  
01 Load upon successful compare with the value in COMP1  
10 Load upon successful compare with the value in COMP2  
11 Reserved |

---

### 54.6.12 Timer Channel Input Filter Register (TMRx_FILTn)

The FILT register programs the values for the filtering of the corresponding input without regard for the fact that any timer channel can use the input as a count source.

Input filter considerations:
- Set the FILT_PER value such that the sampling period is larger than the period of the expected noise. In this way, a noise spike will corrupt only one sample. Choose the FILT_CNT value to reduce the probability that noisy samples cause an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the power of (FILT_CNT + 3).
- The values of FILT_PER and FILT_CNT must also be balanced against the desire for minimal latency in recognizing input transitions. Turning on the input filter (setting FILT_PER to a non-zero value) introduces a latency of (((FILT_CNT + 3) x FILT_PER) + 2) IP bus clock periods.

Address: Base address + 16h offset + (32d x i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>FILT_CNT</td>
<td>0</td>
</tr>
</tbody>
</table>

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### TMRx_FILTn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10–8</td>
<td>FILT_CNT Input Filter Sample Count</td>
</tr>
<tr>
<td></td>
<td>These bits represent the number of consecutive samples that must agree prior to the input filter accepting an input transition. A value of 0x0 represents 3 samples. A value of 0x7 represents 10 samples. The value of FILT_CNT affects the input latency.</td>
</tr>
<tr>
<td>5–0</td>
<td>FILT_PER Input Filter Sample Period</td>
</tr>
<tr>
<td></td>
<td>These bits represent the sampling period (in IP bus clock cycles) of the TMR input signals. Each input is sampled multiple times at the rate specified by this field. If FILT_PER is 0x00 (default), then the input filter is bypassed. The value of FILT_PER affects the input latency. When changing values for FILT_PER from one non-zero value to another non-zero value, write a value of zero first to clear the filter.</td>
</tr>
</tbody>
</table>

### 54.6.13 Timer Channel DMA Enable Register (TMRx_DMA0n)

Address: Base address + 18h offset + (32d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### TMRx_DMA0n field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>CMPLD2DE Comparator Preload Register 2 DMA Enable</td>
</tr>
<tr>
<td></td>
<td>Setting this bit enables DMA write requests for CMPLD2 whenever data is transferred out of the CMPLD2 register into the CNTR or COMP2 registers.</td>
</tr>
<tr>
<td>1</td>
<td>CMPLD1DE Comparator Preload Register 1 DMA Enable</td>
</tr>
<tr>
<td></td>
<td>Setting this bit enables DMA write requests for CMPLD1 whenever data is transferred out of the CMPLD1 register into the COMP1 register.</td>
</tr>
<tr>
<td>0</td>
<td>IEFDE Input Edge Flag DMA Enable</td>
</tr>
<tr>
<td></td>
<td>Setting this bit enables DMA read requests for CAPT when SCTRL[IEF] is set.</td>
</tr>
<tr>
<td></td>
<td><strong>Restriction:</strong> Do not set both this bit and SCTRL[IEF].</td>
</tr>
</tbody>
</table>
### 54.6.14 Timer Channel Enable Register (TMRx_ENBL)

Address: Base address + 1Eh offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

#### TMRx_ENBL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–4</td>
<td>Reserved</td>
</tr>
<tr>
<td>15–4</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>15–4</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>ENBL</td>
<td>Timer Channel Enable</td>
</tr>
<tr>
<td>ENBL</td>
<td>These bits enable the prescaler (if it is being used) and counter in each channel. Multiple ENBL bits can be set at the same time to synchronize the start of separate counters. If an ENBL bit is set, then the corresponding channel starts its counter as soon as the CTRL[CM] field has a value other than 0. When an ENBL bit is clear, the corresponding counter maintains its current value.</td>
</tr>
<tr>
<td>ENBL</td>
<td>0 Timer channel is disabled.</td>
</tr>
<tr>
<td>ENBL</td>
<td>1 Timer channel is enabled. (default)</td>
</tr>
</tbody>
</table>

### 54.7 Functional Description

#### 54.7.1 General

The counter/timer has two basic modes of operation: it can count internal or external events, or it can count an internal clock source while an external input signal is asserted, thus timing the width of the external input signal.

- The counter can count the rising, falling, or both edges of the selected input pin.
- The counter can decode and count quadrature encoded input signals.
- The counter can count up and down using dual inputs in a "count with direction" format.
- The counter's terminal count value (modulo) is programmable.
- The value that is loaded into the counter after reaching its terminal count is programmable.
• The counter can count repeatedly, or it can stop after completing one count cycle.

• The counter can be programmed to count to a programmed value and then immediately reinitialize, or it can count through the compare value until the count "rolls over" to zero.

The external inputs to each counter/timer are shareable among each of the four counter/timers within the module. The external inputs can be used as:

• Count commands

• Timer commands

• They can trigger the current counter value to be "captured"

• They can be used to generate interrupt requests

The polarity of the external inputs are selectable.

The primary output of each timer/counter is the output signal OFLAG. The OFLAG output signal can be:

• Set, cleared, or toggled when the counter reaches the programmed value.

• The OFLAG output signal may be output to an external pin instead of having that pin serve as a timer input.

• The OFLAG output signal enables each counter to generate square waves, PWM, or pulse stream outputs.

• The polarity of the OFLAG output signal is selectable.

Any counter/timer can be assigned as a master. A master's compare signal can be broadcast to the other counter/timers within the module. The other counters can be configured to reinitialize their counters and/or force their OFLAG output signals to predetermined values when a master's counter/timer compare event occurs.

### 54.7.2 Usage of Compare Registers

The dual compare registers (COMP1 and COMP2) provide a bidirectional modulo count capability. The COMP1 register is used when the counter is counting up, and the COMP2 register is used when the counter is counting down. Alternating compare mode is the only exception.
The COMP1 register should be set to the desired maximum count value or FFFFH to indicate the maximum unsigned value prior to roll-over, and the COMP2 register should be set to the minimum count value or 0000h to indicate the minimum unsigned value prior to roll-under.

If CTRL[OUTMODE] is set to 100, the OFLAG will toggle while using alternating compare registers. In this variable frequency PWM mode, the COMP2 value defines the desired pulse width of the on time, and the COMP1 register defines the off time.

Use caution when changing COMP1 and COMP2 while the counter is active. If the counter has already passed the new value, it will count to FFFFH or 0000h, roll over, then begin counting toward the new value. The check is: Count=CMPx, not Count > COMP1 or Count < COMP2.

The use of the CMPLD1 and CMPLD2 registers to compare values will help to minimize this problem.

### 54.7.3 Usage of Compare Load Registers

The CMPLD1, CMPLD2, and CSCTRL registers offer a high degree of flexibility for loading compare registers with user-defined values on different compare events. To ensure correct functionality while using these registers we strongly suggest using the following method described in this section.

The purpose of the compare load feature is to allow quicker updating of the compare registers. In the past, a compare register could be updated using interrupts. However, because of the latency between an interrupt event occurring and the service of that interrupt, there was the possibility that the counter may have already counted past the new compare value by the time the compare register was updated by the interrupt service routine. The counter would then continue counting until it rolled over and reached the new compare value.

To address this, the compare registers are now updated in hardware in the same way the counter register is re-initialized to the value stored in the load register. The compare load feature allows the user to calculate new compare values and store them in to the comparator load registers. When a compare event occurs, the new compare values in the comparator load registers are written to the compare registers eliminating the use of software to do this.
The compare load feature is intended to be used in variable frequency PWM mode. The COMP1 register determines the pulse width for the logic low part of OFLAG and COMP2 determines the pulse width for the logic high part of OFLAG. The period of the waveform is determined by the COMP1 and COMP2 values and the frequency of the primary clock source. See the following figure.

![Variable PWM Waveform](image)

Figure 54-2. Variable PWM Waveform

Should we desire to update the duty cycle or period of the above waveform, we would need to update the COMP1 and COMP2 values using the compare load feature.

### 54.7.4 Usage of the Capture Register

The capture register stores a copy of the counter's value when an input edge (positive, negative, or both) is detected. After a capture event occurs, no further updating of the capture register will occur until the SCTRL[IEF] (input edge flag) is cleared by writing a zero to the SCTRL[IEF].

### 54.7.5 Functional Modes

The selected external count signals are sampled at the TMR's base clock rate and then run through a transition detector. The maximum count rate is one-half of the TMR's base clock rate. Internal clock sources can be used to clock the counters at the TMR's base clock rate.

If a counter is programmed to count to a specific value and then stop, the CTRL[CM] field is cleared when the count terminates.
54.7.5.1  Stop Mode

If CTRL[CM] is set to '000', the counter is inert. No counting will occur. Stop mode will also disable the interrupts caused by input transitions on a selected input pin.

54.7.5.2  Count Mode

If CTRL[CM] is set to '001', the counter will count the rising edges of the selected clock source. This mode is useful for generating periodic interrupts for timing purposes, or counting external events such as "widgets" on a conveyor belt passing a sensor. If the selected input is inverted by setting SCTRL[IPS] (input polarity select), then the negative edge of the selected external input signal is counted.

Example: 54.7.5.2.1  Count Pulses from External Source

```c
void Pulse_Init(void)
{
/* TMR1_CTRL: CM=0,PCS=3,SCS=0,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=0 */
setReg(TMR1_CTRL,0x0600); /* Set up mode */
/* TMR1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0,
Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */
setReg(TMR1_SCTRL,0x00);
setReg(TMR1_CNTR,0x00); /* Reset counter register */
setReg(TMR1_LOAD,0x00); /* Reset load register */
setRegBitGroup(TMR1_CTRL,CM,0x01); /* Run counter */
}
```

Example: 54.7.5.2.2  Generate Periodic Interrupt By Counting Internal Clocks

```c
void TimerInt_Init(void)
{
/* TMR0_CTRL: CM=0,PCS=0,SCS=0,ONCE=0,LENGTH=1,DIR=0,COINIT=0,OUTMODE=0 */
setReg(TMR0_CTRL,0x20); /* Stop all functions of the timer */
/* TMR0_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0,
Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */
setReg(TMR0_SCTRL,0x00);
```
54.7.5.3 Edge-Count Mode
If CTRL[CM] is set to '010', the counter will count both edges of the selected external clock source. This mode is useful for counting the changes in the external environment, such as a simpleencoder wheel.

Example: 54.7.5.3.1 Count Both Edges of External Source Signal

```c
void Pulse_Init(void)
{
    /* TMR1_CTRL: CM=0,PCS=3,SCS=0,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=0 */
    setReg(TMR1_CTRL,0x0600); /* Set up mode */
    /* TMR1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0,
        Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,CEN=0 */
    setReg(TMR1_SCTRL,0x00);
    setReg(TMR1_CNTR,0x00); /* Reset counter register */
    setReg(TMR1_LOAD,0x00); /* Reset load register */
    setRegBitGroup(TMR1_CTRL,CM,0x02); /* Run counter */
}
```

54.7.5.4 Gated-Count Mode
If CTRL[CM] is set to '011', the counter will count while the selected secondary input signal is high. This mode is used to time the duration of external events. If the selected input is inverted by setting SCTRL[IPS] (input polarity select), then the counter will count while the selected secondary input is low.

Example: 54.7.5.4.1 Capture Duration of External Pulse
54.7.5.5 Quadrature-Count Mode

If CTRL[CM] is set to '100', the counter will decode the primary and secondary external inputs as quadrature encoded signals. Quadrature signals are usually generated by rotary or linear sensors used to monitor movement of motor shafts or mechanical equipment. The quadrature signals are square waves that are 90 degrees out of phase. The decoding of quadrature signal provides both count and direction information.

This figure shows a timing diagram illustrating the basic operation of a quadrature incremental position encoder.

![Figure 54-3. Quadrature Incremental Position Encoder](image)

**Example: 54.7.5.5.1 Quadrature Count Mode Example**

```c
void Pulse_Init(void)
{
    /* TMR1_CTRL: CM=0,PCS=8,SCS=1,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=0 */
    setReg(TMR1_CTRL,0x1080);            /* Set up mode */
    /* TMR1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0,
        Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */
    setReg(TMR1_SCTRL,0x00);
    setReg(TMR1_CNTR,0x00);             /* Reset counter register */
    setReg(TMR1_LOAD,0x00);             /* Reset load register */
    setRegBitGroup(TMR1_CTRL,CM,0x03);  /* Run counter */
}
```
54.7.5.6 Quadrature-Count Mode with Index Input

As an extension to the quadrature count mode discussed in the previous paragraph, some rotary shafts have a HOME or INDEX indicator. This would be a third input to the timer that is used to reset the timer's counter.

In this example, channel 0 is used to decode the quadrature inputs, but it doesn't actually count. Because its upper and lower limits are both set to 0, its output is cascaded count up and count down signals each time the quadrature inputs indicate a change in count.

Channel 1 works in cascaded count mode receiving its counting instructions from channel 0. When an input capture event occurs, channel 1 is programmed to reset its counter value. The channel 1 counter contains the position value for the shaft.

Example: 54.7.5.6.1 Quadrature Count Mode with Index Input Example

```c
// (See Processor Expert PulseAccumulator bean.)
// This example uses TMR0 and TMR1 for counting states of a quadrature position encoder.
// Timer input 0 is used as the primary count source (PHASEA).
// Timer input 1 is used as the secondary count source (PHASEB).
// Timer input 2 is used as the index input source (INDEX).

void Pulse_Init(void)
{
    /* TMR0_CTRL: CM=0,PCS=0,SCS=1,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=0 */
    setReg(TMR0_CTRL,0x0A0); /* Set up mode */
    /* TMR0_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0,
      Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */
    setReg(TMR0_SCTRL,0x00);
    setReg(TMR0_CNTR,0x00);    /* Reset counter register */
    setReg(TMR0_LOAD,0x00);    /* Reset load register */
    setReg(TMR0_COMP1,0x00);   /* Set up compare 1 register */
    setReg(TMR0_COMP2,0x00);   /* Set up compare 2 register */
    /* TMR0_CSCCTRL: DBG_EN=0,FAULT=0,ALT_LOAD=0,ROC=0,TCI=0,UP=0,OFLAG=0,
      TCF2EN=0,TCF1EN=0,TCF2=0,TCF1=0,CL2=0,CL1=0 */
    setReg(TMR0_CSCCTRL,0x00);
    setRegBitGroup(TMR0_CTRL,CM,0x04); /* Run counter */
}
```
54.7.5.7 Signed-Count Mode

If CTRL[CM] is set to '101', the counter counts the primary clock source while the selected secondary source provides the selected count direction (up/down).

Example: 54.7.5.7.1 Signed Count Mode Example

```c
void Pulse_Init(void)
{
    /* TMR0_CTRL: CM=0,PCS=2,SCS=1,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=0 */
    setReg(TMR0_CTRL,0x0480);             /* Set up mode */
    /* TMR0_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=1,IEF=0,IEFIE=0,IPS=0,INPUT=0,
    Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */
    setReg(TMR0_SCTRL,0x1000);
    setReg(TMR0_CNTR,0x00);             /* Reset counter register */
    setReg(TMR0_LOAD,0x00);             /* Reset load register */
    setRegBitGroup(TMR0_CTRL,CM,0x05);  /* Run counter */
}
```

54.7.5.8 Triggered-Count Mode 1

If CSCTRL[TCl] is clear and CTRL[CM] is set to '110', the counter will begin counting the primary clock source after a positive transition (negative edge if SCTRL[IPS]=1) of the secondary input occurs. The counting will continue until a compare event occurs or another positive input transition is detected. If a second input transition occurs before a terminal count is reached, counting will stop and SCTRL[TCF] (timer compare flag) will be set. Subsequent secondary input transitions will continue to restart and stop the counting until a compare event occurs.
Figure 54-4. Triggered Count Mode 1 (CTRL[LENGTH]=0)

Example: 54.7.5.8.1  Triggered Count Mode 1 Example

```
// (See Processor Expert PulseAccumulator bean.)
// This example uses TMR1 for triggered mode counting.
// Timer input 3 is used as the primary count source.
// Timer input 2 is used for the trigger input.

void Pulse_Init(void)
{
    /* TMR1_CTRL: CM=0,PCS=3,SCS=2,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=0 */
    setReg(TMR1_CTRL,0x0700);            /* Set up mode */
    /* TMR1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=1,IEF=0,IEFIE=0,IPS=0,INPUT=0,
       Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,OEN=0 */
    setReg(TMR1_SCTRL,0x1000);
    setReg(TMR1_CNTR,0x00);              /* Reset counter register */
    setReg(TMR1_LOAD,0x00);              /* Reset load register */
    setReg(TMR1_COMP1,0x0012);            /* Set up compare 1 register */
    /* TMR1_CSCTRL: DBG_EN=0,FAULT=0,ALT_LOAD=0,ROC=0,TCI=0,UP=0,OFLAG=0,
       TCF2EN=0,TCF1EN=0,TCF2=0,TCF1=0,CL2=0,CL1=0 */
    setReg(TMR1_CSCTRL,0x00);            /* Set up compare 1 register */
    setRegBitGroup(TMR1_CTRL,CM,0x06);    /* Run counter */
}
```

54.7.5.9  Triggered-Count Mode 2

If CSCTRL[TCI] is set and CTRL[CM] is set to '110', the counter will begin counting the primary clock source after a positive transition (negative edge if SCTRL[IPS]=1) of the secondary input occurs. The counting will continue until a compare event occurs or another positive input transition is detected. If a second input transition occurs before a terminal count was reached, the counter will reload and continue counting. When CSCTRL[TCI] is set, the OFLAG output mode, CTRL[OUTMODE], should probably be set to '101' (cleared on init, set on compare) to ensure the output will be in a known state after the second input transition and subsequent reload takes place.
Example: 54.7.5.9.1  Triggered Count Mode 2

```c
// (See Processor Expert PulseAccumulator bean.)
// This example uses TMR1 for triggered mode counting.
// Timer input 3 is used as the primary count source.
// Timer input 2 is used for the trigger input.

void Pulse_Init(void)
{
    /* TMR1_CTRL: CM=0,PCS=3,SCS=2,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=0 */
    setReg(TMR1_CTRL,0x0700);           /* Set up mode */
    /* TMR1_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=1,IEF=0,IEFIE=0,IPS=0,INPUT=0,
        Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,FORCE=0,OPS=0,CEN=0 */
    setReg(TMR1_SCTRL,0x1000);

    setReg(TMR1_CNTR,0x00);             /* Reset counter register */
    setReg(TMR1_LOAD,0x00);             /* Reset load register */
    setReg(TMR1_COMP1,0x0012);           /* Set up compare 1 register */
    /* TMR1_CSCTRL: DBG_EN=0,FAULT=0,ALT_LOAD=0,ROC=0,TCI=0,OFLAG=0,
        TCF2EN=0,TCF1EN=0,TCF2=0,TCF1=0,CL2=0,CL1=0 */
    setReg(TMR1_CSCTRL,0x00);

    setRegBitGroup(TMR1_CTRL,CM,0x06); /* Run counter */
}
```

54.7.5.10  One-Shot Mode

If CTRL[CM] is set to '110', and the counter is set to reinitialize at a compare event (CTRL[LENGTH]=1), and CTRL[OUTMODE] is set to '101' (cleared on init, set on compare), the counter works in a one-shot mode. An external event causes the counter to count, and when the terminal count is reached, the output is asserted. This delayed output can be used to provide timing delays.

```
<table>
<thead>
<tr>
<th>LOAD = 0, COMP1 = 4</th>
</tr>
</thead>
<tbody>
<tr>
<td>Primary</td>
</tr>
<tr>
<td>Secondary</td>
</tr>
<tr>
<td>Count</td>
</tr>
<tr>
<td>timer_out</td>
</tr>
</tbody>
</table>
```

Figure 54-6. One-Shot Mode (CTRL[LENGTH]=1)
Example: 54.7.5.10.1 One-Shot Mode Example

```c
// (See Processor Expert PulseAccumulator bean.)
// This example uses TMR1 for one-shot mode counting.
// Timer input 3 is used as the primary count source.
// Timer input 2 is used for the trigger input.

void Pulse_Init(void)
{
    /* TMR1_CTRL: CM=0, PCS=3, SCS=2, ONCE=0, LENGTH=0, DIR=0, COINIT=0, OUTMODE=5 */
    setReg(TMR1_CTRL, 0x0725);           /* Set up mode */
    /* TMR1_SCTRL: TCF=0, TCFIE=0, TOF=0, TOFIE=1, IEF=0, IBFIE=0, IPS=0, INPUT=0,  
       Capture_Mode=0, MSTR=0, EEOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */ 
    setReg(TMR1_SCTRL, 0x1000);
    setReg(TMR1_CNTR, 0x00);             /* Reset counter register */
    setReg(TMR1_LOAD, 0x00);             /* Reset load register */
    setReg(TMR1_COMP1, 0x0004);           /* Set up compare 1 register */
    /* TMR1_CSCTRL: DBG_EN=0, FAULT=0, ALT_LOAD=0, ROC=0, TCI=0, UP=0, OFLAG=0,  
       TCF2EN=0, TCF1EN=0, CL2=0, CL1=0 */
    setReg(TMR1_CSCTRL, 0x00);
    setRegBitGroup(TMR1_CTRL, CM, 0x06);  /* Run counter */
}
```

54.7.5.11 Cascade-Count Mode

If CTRL[CM] is set to '111', the counter's input is connected to the output of another selected counter. The counter will count up and down as compare events occur in the selected source counter. This cascade or daisy-chained mode enables multiple counters to be cascaded to yield longer counter lengths. When operating in cascade mode, a special high-speed signal path is used between modules rather than the OFLAG output signal. If the selected source counter is counting up and it experiences a compare event, the counter will be incremented. If the selected source counter is counting down and it experiences a compare event, the counter will be decremented.

Up to four counters may be cascaded to create a 64-bit wide synchronous counter. Check the data sheet to see if there are any frequency limits for cascaded counting mode.

Whenever any counter is read within a counter module, all of the counters' values within the module are captured in their respective hold registers. This action supports the reading of a cascaded counter chain. First read any counter of a cascaded counter chain, then read the hold registers of the other counters in the chain. The cascaded counter mode is synchronous.
Note

It is possible to connect counters together by using the other (non-cascade) counter modes and selecting the outputs of other counters as a clock source. In this case, the counters are operating in a ripple mode, where higher order counters will transition a clock later than a purely synchronous design.

Example: 54.7.5.11.1 Generate Periodic Interrupt Cascading Two Counters

```c
void TimerInt_Init(void)
{
    // To do this, counter 2 is used to count 60,000 IP_bus clocks, which means it will compare and reload every 0.001 seconds.
    // Counter 3 is cascaded and used to count the 0.001 second ticks and generate the desired interrupt interval.

    // Set counter 2 to count IP_bus clocks
    setReg(TMR2_CTRL,0x1010);       /* Stop all functions of the timer */
    setReg(TMR3_CTRL,0x4010);       /* Set up cascade counter mode */
    setReg(TMR3_SCTRL,0x00);        /* Set up cascade counter mode */
    setReg(TMR2_SCTRL,0x00);        /* Set up cascade counter mode */

    /* Set counter 3 as cascaded and to count counter 2 outputs */
    setReg(TMR3_CNTR,0x00);         /* Reset counter register */
    setReg(TMR2_CNTR,0x00);         /* Reset load register */
    setReg(TMR3_LOAD,0x00);         /* Reset load register */
    setReg(TMR2_LOAD,0x00);         /* Reset load register */
    setReg(TMR3_CMP1,30000);        /* milliseconds in 30 seconds */
    setReg(TMR2_CMP1,60000);        /* milliseconds in 30 seconds */
    setReg(TMR3_CMP1,60000);        /* milliseconds in 30 seconds */

    /* Set to cycle every milisecond */
    setReg(TMR3_CSCTRL,0x00);       /* Enable compare 1 interrupt and */
    setReg(TMR3_CSCTRL,0x00);       /* compare 1 preload */
    setReg(TMR2_CSCTRL,0x00);       /* Enable compare 1 preload */
    setRegBitGroup(TMR2_CTRL,CM,0x01); /* Run counter */
}```
54.7.5.12 Pulse-Output Mode

If CTRL[CM]=001, and CTRL[OUTMODE] is set to 111’ (gated clock output), and CTRL[ONCE] is set, then the counter will output a pulse stream of pulses that has the same frequency of the selected clock source, and the number of output pulses is equal to the compare value minus the init value. This mode is useful for driving step motor systems.

Note

This does not work if CTRL[PCS] is set to 1000 (IP_bus/1).

Example: 54.7.5.12.1 Pulse Outputs Using Two Counters

```c
// (See Processor Expert PulseStream bean.)
// This example generates six 10ms pulses, from QT1 output.
// Assuming the chip is operating at 60 MHz.
// To do this, timer 3 is used to generate a clock with a period of 10ms.
// Timer 1 is used to gate these clocks and count the number of pulses that have been generated.

void PulseStream_Init(void)
{
    // Select IP_bus_clk/16 as the clock source for Timer 3
    /* TMR3_CTRL: CM=0, PCS=0x0C, SCS=0, ONCE=0, LENGTH=1, DIR=0, COINIT=0, OUTMODE=3 */
    setReg(TMR3_CTRL, 0x1823); /* Set up mode */
    /* TMR3_SCTRL: TCF=0, TCFIE=0, TOF=0, TOFIE=0, IEF=0, IEFIE=0, IPS=0, INPUT=0,
     Capture_Mode=0, MSTR=0, EOF=0, VAL=0, FORCE=0, OPS=0, OEN=0 */
    setReg(TMR3_SCTRL, 0x00);
    setReg(TMR3_LOAD, 0x00); /* Reset load register */
    setReg(TMR3_COMP1, 37500); /* (16 * 37500 ) / 60e6 = 0.01 sec */
    /* TMR3_CCTRL: DBG_EN=0, FAULT=0, ALT_LOAD=0, ROC=0, TCI=0, UP=0, OFLAG=0,
     TCF2EN=0, TCF1EN=0, TCF2=0, TCF1=0, CL2=0, CL1=0 */
    setReg(TMR3_CCTRL, 0x00); /* Set up comparator control register */

    // Timer 3 output is the clock source for this timer.
    /* TMR1_CTRL: CM=0, PCS=7, SCS=0, ONCE=1, LENGTH=1, DIR=0, COINIT=0, OUTMODE=7 */
    setReg(TMR1_CTRL, 0x0E67); /* Set up mode */
    /* TMR1_SCTRL: TCF=0, TCFIE=0, TOF=0, TOFIE=0, IEF=0, IEFIE=0, IPS=0, INPUT=0,
     Capture_Mode=0, MSTR=0, EOF=0, VAL=0, FORCE=0, OPS=0, OEN=1 */
}
```
54.7.5.13 Fixed-Frequency PWM Mode

If CTRL[CM]=001, count through roll-over (CTRL[LENGTH]=0), continuous count (CTRL[ONCE]=0) and CTRL[OUTMODE] is '110' (set on compare, cleared on counter roll-over), then the counter output yields a pulse-width modulated (PWM) signal with a frequency equal to the count clock frequency divided by 65,536 and a pulse-width duty cycle equal to the compare value divided by 65,536. This mode of operation is often used to drive PWM amplifiers used to power motors and inverters.

Example: 54.7.5.13.1 Fixed-Frequency PWM Mode Example

```c
void PWM1_Init(void)
{
    (See Processor Expert PWM bean.)
    // This example uses TMR0 for Fixed-Frequency PWM mode timing.
    // The timer will count IP_bus clocks continuously until it rolls over.
    // This results in a PWM period of 65536 / 60e6 = 1092.267 usec
    // Initially, an output pulse width of 25 usec is generated ( 1500 / 60e6 )
    // giving a PWM ratio of 1500 / 65536 = 2.289%
    // This pulse width can be changed by changing the COMP1 register value (using CMPLD1).
    //
    setReg(TMR0_CNTR,0);        /* Reset counter */
    /* TMR0_SCTRL: TCF=0,TCFIE=0,TOF=0,TOFIE=0,IEF=0,IEFIE=0,IPS=0,INPUT=0,
       Capture_Mode=0,MSTR=0,EEOF=0,VAL=0,PORCE=1,OPS=0,OEN=1 */
    setReg(TMR0_SCTRL,0x05);    /* Enable output */
    setReg(TMR0_COMP1,1500);    /* Store initial value to the duty-compare register */
    /* TMR0_CTRL: CM=1,PCS=8,SCS=0,ONCE=0,LENGTH=0,DIR=0,COINIT=0,OUTMODE=6 */
    setReg(TMR0_CTRL,0x0306);   /* Run counter */
}
54.7.5.14 Variable-Frequency PWM Mode

If CTRL[CM]=001, count until compare (CTRL[LENGTH]=1), continuous count (CTRL[ONCE] = 0) and CTRL[OUTMODE] is '100' (toggle OFLAG and alternate compare registers), then the counter output yields a pulse-width modulated (PWM) signal whose frequency and pulse width is determined by the values programmed into the COMP1 and COMP2 registers, and the input clock frequency. This method of PWM generation has the advantage of allowing almost any desired PWM frequency and/or constant on or off periods. This mode of operation is often used to drive PWM amplifiers used to power motors and inverters. The CMPLD1 and CMPLD2 registers are especially useful for this mode, as they allow the programmer time to calculate values for the next PWM cycle while the PWM current cycle is underway.

To set up the TMR to run in variable frequency PWM mode with compare preload please use the following setup for the specific counter you would like to use. When performing the setup, update the TMR_CTRL register last because the counter will start counting if the count mode is changed to any value other than 000 (assuming the primary count source is already active).

**Timer Control Register (CTRL)**

- CM=001 (count rising edges of primary source)
- PCS=1000 (IP bus clock for best granularity for waveform timing)
- SCS=Any (ignored in this mode)
- ONCE=0 (want to count repeatedly)
- LENGTH=1 (want to count until compare value is reached and re-initialize counter register)
- DIR=Any (user's choice. The compare register values must be chosen carefully to account for things like roll-under, etc.)
- COINIT=0 (user can set this if they need this function)
- OUTMODE=100 (toggle OFLAG output using alternating compare registers)

**Timer Status and Control Register (SCTRL)**

- OEN = 1 (output enable to allow OFLAG output to be put on an external pin. Set this bit as needed.)
• OPS = Any (user's choice)

• Make sure the rest of the bits are cleared for this register. We will enable interrupts in the comparator status and control register instead of in this register.

Comparator Status and Control Register (CSCTRL)

• TCF2EN=1 (allow interrupt to be issued when CSCTRL[TCF2] is set)
• TCF1EN=0 (do not allow interrupt to be issued when CSCTRL[TCF1] is set)
• TCF1=0 (clear timer compare 1 interrupt source flag. This is set when counter register equals compare register 1 value and OFLAG is low)
• TCF2=0 (clear timer compare 2 interrupt source flag. This is set when counter register equals compare register 2 value and OFLAG is high)
• CL1=10 (load compare register when CSCTRL[TCF2] is asserted)
• CL2=01 (load compare register when CSCTRL[TCF1] is asserted)

Interrupt Service Routines

To service the CSCTRL[TCF2] interrupts generated by the timer, the interrupt controller must be configured to enable the interrupts for the particular timer being used. Additionally the user will need to write an interrupt service routine to do at a minimum the following:

• Clear CSCTRL[TCF2] and CSCTRL[TCF1] flags.
• Calculate and write new values for both CMPLD1 and CMPLD2.

Timing

This figure contains the timing for using the compare preload feature. The compare preload cycle begins with a compare event on COMP2 causing CSCTRL[TCF2] to be asserted. COMP1 is loaded with the value in the CMPLD1 (c3) one IP bus clock later. In addition an interrupt is asserted by the timer and the interrupt service routine is executed during which both comparator load registers are updated with new values (c4 and c5). When CSCTRL[TCF1] is asserted, COMP2 is loaded with the value in CMPLD2 (c4). And on the subsequent CSCTRL[TCF2] event, COMP1 is loaded with the value in CMPLD1 (c5). The cycle starts over again as an interrupt is asserted and the interrupt service routine clears CSCTRL[TCF1] and CSCTRL[TCF2] and calculates new values for CMPLD1 and CMPLD2.
Step 1-- CNTR matches COMP2 value. CSCTRL[TCF2] is asserted and an interrupt request is generated.

Step 2-- One clock later, OFLAG toggles, CMPLD1 is copied to COMP1, LOAD is copied to CNTR, the counter starts counting.

Step 3-- The interrupt service routine clears CSCTRL[TCF1] and CSCTRL[TCF2] and the ISR loads CMPLD1 and CMPLD2 with the values for the next cycle. The counter continues counting until CNTR matches COMP1.

Step 4-- CSCTRL[TCF1] is asserted. One clock later, OFLAG toggles, CMPLD2 is copied to COMP2, LOAD is copied to CNTR and the counter starts counting.

Step 5-- The counter continues counting until CNTR matches COMP2.

Figure 54-8. Compare Load Timing

Example: 54.7.5.14.1 Variable Frequency PWM Mode

```c
void PPG1_Init(void)
{
    setReg(TMR0_LOAD,0); /* Clear load register */
}```
54.8 Resets

54.8.1 General

The TMR module can be reset only by the RST_B signal. This forces all registers to their reset state and clears the OFLAG signal if it is asserted. The counter will be turned off until the settings in the control register are changed.

Table 54-2. Reset Summary

<table>
<thead>
<tr>
<th>Reset</th>
<th>Priority</th>
<th>Source</th>
<th>Characteristics</th>
</tr>
</thead>
<tbody>
<tr>
<td>RST_B</td>
<td>n/a</td>
<td>Hardware Reset</td>
<td>Full System Reset</td>
</tr>
</tbody>
</table>

54.9 Clocks

54.9.1 General

The timer only receives the IP bus clock.

54.10 Interrupts

54.10.1 General

The TMR module can generate 20 interrupts, Five for each of the four counters/channels.
### Table 54-3. Interrupt Summary

<table>
<thead>
<tr>
<th>Core Interrupt</th>
<th>Interrupt</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>TMR Channel 0</td>
<td>TMR0_COMP_IRQ_B</td>
<td>Compare Interrupt Request for Timer Channel 0</td>
</tr>
<tr>
<td></td>
<td>TMR0_COMP1_IRQ_B</td>
<td>Compare 1 Interrupt Request for Timer Channel 0</td>
</tr>
<tr>
<td></td>
<td>TMR0_COMP2_IRQ_B</td>
<td>Compare 2 Interrupt Request for Timer Channel 0</td>
</tr>
<tr>
<td></td>
<td>TMR0_OVF_IRQ_B</td>
<td>Overflow Interrupt Request for Timer Channel 0</td>
</tr>
<tr>
<td></td>
<td>TMR0_EDGE_IRQ_B</td>
<td>Input Edge Interrupt Request for Timer Channel 0</td>
</tr>
<tr>
<td>TMR Channel 1</td>
<td>TMR1_COMP_IRQ_B</td>
<td>Compare Interrupt Request for Timer Channel 1</td>
</tr>
<tr>
<td></td>
<td>TMR1_COMP1_IRQ_B</td>
<td>Compare 1 Interrupt Request for Timer Channel 1</td>
</tr>
<tr>
<td></td>
<td>TMR1_COMP2_IRQ_B</td>
<td>Compare 2 Interrupt Request for Timer Channel 1</td>
</tr>
<tr>
<td></td>
<td>TMR1_OVF_IRQ_B</td>
<td>Overflow Interrupt Request for Timer Channel 1</td>
</tr>
<tr>
<td></td>
<td>TMR1_EDGE_IRQ_B</td>
<td>Input Edge Interrupt Request for Timer Channel 1</td>
</tr>
<tr>
<td>TMR Channel 2</td>
<td>TMR2_COMP_IRQ_B</td>
<td>Compare Interrupt Request for Timer Channel 2</td>
</tr>
<tr>
<td></td>
<td>TMR2_COMP1_IRQ_B</td>
<td>Compare 1 Interrupt Request for Timer Channel 2</td>
</tr>
<tr>
<td></td>
<td>TMR2_COMP2_IRQ_B</td>
<td>Compare 2 Interrupt Request for Timer Channel 2</td>
</tr>
<tr>
<td></td>
<td>TMR2_OVF_IRQ_B</td>
<td>Overflow Interrupt Request for Timer Channel 2</td>
</tr>
<tr>
<td></td>
<td>TMR2_EDGE_IRQ_B</td>
<td>Input Edge Interrupt Request for Timer Channel 2</td>
</tr>
<tr>
<td>TMR Channel 3</td>
<td>TMR3_COMP_IRQ_B</td>
<td>Compare Interrupt Request for Timer Channel 3</td>
</tr>
<tr>
<td></td>
<td>TMR3_COMP1_IRQ_B</td>
<td>Compare 1 Interrupt Request for Timer Channel 3</td>
</tr>
<tr>
<td></td>
<td>TMR3_COMP2_IRQ_B</td>
<td>Compare 2 Interrupt Request for Timer Channel 3</td>
</tr>
<tr>
<td></td>
<td>TMR3_OVF_IRQ_B</td>
<td>Overflow Interrupt Request for Timer Channel 3</td>
</tr>
<tr>
<td></td>
<td>TMR3_EDGE_IRQ_B</td>
<td>Input Edge Interrupt Request for Timer Channel 3</td>
</tr>
</tbody>
</table>

### 54.10.2 Description of Interrupt Operation

#### 54.10.2.1 Timer Compare Interrupts

These interrupts are generated when a successful compare occurs between a counter and its compare registers while SCTRL[TCFIE] is set. These interrupts are cleared by writing a zero to the appropriate SCTRL[TCF].

When a timer compare interrupt is set in TMR_SCTRL and the Compare Load registers are available, one of the following two interrupts will also be asserted.
54.10.2.1.1 Timer Compare 1 Interrupts (Available with Compare Load Feature)

These interrupts are generated when a successful compare occurs between a counter and its COMP1 register while CSCTRL[TCF1EN] is set. These interrupts are cleared by writing a zero to the appropriate CSCTRL[TCF1].

54.10.2.1.2 Timer Compare 2 Interrupts (Available with Compare Load Feature)

These interrupts are generated when a successful compare occurs between a counter and its COMP2 register while CSCTRL[TCF2EN] is set. These interrupts are cleared by writing a zero to the appropriate CSCTRL[TCF2].

54.10.2.2 Timer Overflow Interrupts

These interrupts are generated when a counter rolls over its maximum value while SCTRL[TOFIE] is set. These interrupts are cleared by writing zero to the appropriate SCTRL[TOF].

54.10.2.3 Timer Input Edge Interrupts

These interrupts are generated by a transition of the input signal (either positive or negative depending on IPS setting) while SCTRL[IEFIE] is set. These interrupts are cleared by writing a zero to the appropriate SCTRL[IEF].

54.11 DMA

The TMR module can generate twelve DMA requests: three for each of the four counters/channels. Refer to the following table.

<table>
<thead>
<tr>
<th>DMA Request</th>
<th>DMA Enable</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Channels 0-3</td>
<td>DMA[IEFDE]</td>
<td>CAPT contains a value</td>
</tr>
<tr>
<td></td>
<td>DMA[CMPLD1DE]</td>
<td>CMPLD1 needs an update</td>
</tr>
<tr>
<td></td>
<td>DMA[CMPLD2DE]</td>
<td>CMPLD2 needs an update</td>
</tr>
</tbody>
</table>
Chapter 55
Enhanced Flex Pulse Width Modulator (eFlexPWM)

55.1 Chip-specific FlexPWM information

Table 55-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

NOTE
In this device, PWMx_EXTB is not applicable. It also does not support external ADC input. Also there is No NanoEdge placement block in this device.

55.2 Introduction

The pulse width modulator (PWM) module contains PWM submodules, each of which is set up to control a single half-bridge power stage. Fault channel support is provided.

This PWM module can generate various switching patterns, including highly sophisticated waveforms. It can be used to control all known motor types and is ideal for controlling different Switched Mode Power Supplies (SMPS) topologies as well.
55.2.1 Features

- 16 bits of resolution for center, edge-aligned, and asymmetrical PWMs
- Fractional PWM clock generation for enhanced resolution of the PWM period and duty cycle
- Dithering to simulate enhanced resolution when fine edge placement is not available
- PWM outputs that can operate as complementary pairs or independent channels
- Ability to accept signed numbers for PWM generation
- Independent control of both edges of each PWM output
- Support for synchronization to external hardware or other PWM
- Double buffered PWM registers
  - Integral reload rates from 1 to 16
  - Half cycle reload capability
- Multiple output trigger events can be generated per PWM cycle via hardware
- Support for double switching PWM outputs
- Fault inputs can be assigned to control multiple PWM outputs
- Programmable filters for fault inputs
- Independently programmable PWM output polarity
- Independent top and bottom deadtime insertion
- Each complementary pair can operate with its own PWM frequency and deadtime values
- Individual software control for each PWM output
- All outputs can be programmed to change simultaneously via a FORCE_OUT event
- PWM_X pin can optionally output a third PWM signal from each submodule
- Channels not used for PWM generation can be used for buffered output compare functions
- Channels not used for PWM generation can be used for input capture functions
- Enhanced dual edge capture functionality
- The option to supply the source for each complementary PWM signal pair from any of the following:
  - Crossbar module outputs
  - External ADC input, taking into account values set in ADC high and low limit registers

55.2.2 Modes of Operation

Be careful when using this module in stop, wait and debug operating modes.

CAUTION

Some applications (such as three-phase AC motors) require regular software updates for proper operation. Failure to
provide regular software updates could result in destroying the hardware setup.

To accommodate this situation, PWM outputs are placed in their inactive states in stop mode, and they can optionally be placed in inactive states in wait and debug (EOnCE) modes. PWM outputs are reactivated (assuming they were active beforehand) when these modes are exited.

**Table 55-2. Modes when PWM Operation is Restricted**

<table>
<thead>
<tr>
<th>Mode</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Stop</td>
<td>PWM outputs are inactive.</td>
</tr>
<tr>
<td>Wait</td>
<td>PWM outputs are driven or inactive as a function of CTRL2[WAITEN].</td>
</tr>
<tr>
<td>Debug</td>
<td>CPU and peripheral clocks continue to run, but the CPU may stall for periods of time. PWM outputs are driven or inactive as a function of CTRL2[DBGEN].</td>
</tr>
</tbody>
</table>

### 55.2.3 Block Diagram

The following figure is a block diagram of the PWM.
55.3 Signal Descriptions

The PWM has pins named PWM[n]_A, PWM[n]_B, PWM[n]_X, FAULT[n], PWM[n]_EXT_SYNC, EXT_FORCE, PWM[n]_EXTA, and PWM[n]_EXTB. The PWM also has an on-chip input called EXT_CLK and output signals called PWM[n]_OUT_TRIGx.

55.3.1 PWM[n]_A and PWM[n]_B - External PWM Output Pair

These pins are the output pins of the PWM channels. These pins can be independent PWM signals or a complementary pair. When not needed as an output, they can be used as inputs to the input capture circuitry.
55.3.2 PWM[n]_X - Auxiliary PWM Output signal

These pins are the auxiliary output pins of the PWM channels. They can be independent PWM signals. When not needed as an output, they can be used as inputs to the input capture circuitry or used to detect the polarity of the current flowing through the complementary circuit at deadtime correction.

55.3.3 FAULT[n] - Fault Inputs

These are input pins for disabling selected PWM outputs.

55.3.4 PWM[n]_EXT_SYNC - External Synchronization Signal

These input signals allow a source external to the PWM to initialize the PWM counter. In this manner, the PWM can be synchronized to external circuitry.

55.3.5 EXT_FORCE - External Output Force Signal

This input signal allows a source external to the PWM to force an update of the PWM outputs. In this manner, the PWM can be synchronized to external circuitry.

55.3.6 PWM[n]_EXTA and PWM[n]_EXTB - Alternate PWM Control Signals

These pins allow an alternate source to control the PWM_A and PWM_B outputs. Typically, either the PWM_EXTA or PWM_EXTB input (depending on the state of MCTRL/IPOL) is used for the generation of a complementary pair. Typical control signals include ADC conversion high/low limits, TMR outputs, GPIO inputs, and comparator outputs.

55.3.7 PWM[n]_OUT_TRIG0 and PWM[n]_OUT_TRIG1 - Output Triggers

These outputs allow the PWM submodules to control timing of ADC conversions. See the description of the Output Trigger Control Register for information about how to enable these outputs and how the compare registers match up to the output triggers.
55.3.8 EXT_CLK - External Clock Signal

This signal allows a source external to the PWM (typically a timer or an off-chip source) to control the PWM clocking. In this manner, the PWM can be synchronized to the timer, or multiple chips can be synchronized to each other.

55.4 Functional Description

55.4.1 PWM Capabilities

This section describes some capabilities of the PWM module.

55.4.1.1 Center Aligned PWMs

Each submodule has its own timer that is capable of generating PWM signals on two output pins. The edges of each of these signals are controlled independently as shown in Figure 55-2.
The submodule timers only count in the up direction and then reset to the INIT value. Instead of having a single value that determines pulse width, there are two values that must be specified: the turn on edge and the turn off edge. This double action edge generation not only gives the user control over the pulse width, but over the relative alignment of the signal as well. As a result, there is no need to support separate PWM alignment modes since the PWM alignment mode is inherently a function of the turn on and turn off edge values.

Figure 55-2 also illustrates an additional enhancement to the PWM generation process. When the counter resets, it is reloaded with a user specified value, which may or may not be zero. If the value chosen happens to be the 2's complement of the modulus value, then the PWM generator operates in "signed" mode. This means that if each PWM's turn on and turn off edge values are also the same number but only different in their sign, the "on" portion of the output signal will be centered around a count value of zero. Therefore, only one PWM value needs to be calculated in software and then this value and its negative are provided to the submodule as the turn off and turn on edges respectively. This technique will result in a pulse width that always consists of an odd number of timer counts. If all PWM signal edge calculations follow this same convention, then the signals will be center aligned with respect to each other, which is the goal. Of course, center
alignment between the signals is not restricted to symmetry around the zero count value, as any other number would also work. However, centering on zero provides the greatest range in signed mode and also simplifies the calculations.

### 55.4.1.2 Edge Aligned PWMs

When the turn on edge for each pulse is specified to be the INIT value, then edge aligned operation results, as the following figure shows. Therefore, only the turn off edge value needs to be periodically updated to change the pulse width.

With edge aligned PWMs, another example of the benefits of signed mode can be seen. A common way to drive an H-bridge is to use a technique called "bipolar" PWMs where a 50% duty cycle results in zero volts on the load. Duty cycles less than 50% result in negative load voltages and duty cycles greater than 50% generate positive load voltages. If the module is set to signed mode operation (the INIT and VAL1 values are the same number with opposite signs), then there is a direct proportionality between the PWM turn off edge value and the motor inverter voltage, INCLUDING the sign. So once again, signed mode of operation simplifies the software interface to the PWM module since no offset calculations are required to translate the output variable control algorithm to the voltage on an H-Bridge load.
55.4.1.3 Phase Shifted PWMs

In the previous sections, the benefits of signed mode of operation were discussed in the context of simplifying the required software calculations by eliminating the requirement to bias up signed variables before applying them to the module. However, if numerical biases are applied to the turn on and turn off edges of different PWM signal, the signals will be phase shifted with respect to each other, as the following figure shows. This results in certain advantages when applied to a power stage. For example, when operating a multi-phase inverter at a low modulation index, all of the PWM switching edges from the different phases occur at nearly the same time. This can be troublesome from a noise standpoint, especially if ADC readings of the inverter must be scheduled near those times. Phase shifting the PWM signals can open up timing windows between the switching edges to allow a signal to be sampled by the ADC. However, phase shifting does NOT affect the duty cycle so average load voltage is not affected.

![Phase Shifted Outputs Example](image)

An additional benefit of phase shifted PWMs appears in Figure 55-5. In this case, an H-Bridge circuit is driven by 4 PWM signals to control the voltage waveform on the primary of a transformer. Both left and right side PWMs are configured to always generate a square wave with 50% duty cycle. This works out nicely for the H-Bridge since no narrow pulse widths are generated reducing the high frequency switching
requirements of the transistors. Notice that the square wave on the right side of the H-Bridge is phase shifted compared to the left side of the H-Bridge. As a result, the transformer primary sees the bottom waveform across its terminals. The RMS value of this waveform is directly controlled by the amount of phase shift of the square waves. Regardless of the phase shift, no DC component appears in the load voltage as long as the duty cycle of each square wave remains at 50% making this technique ideally suited for transformer loads. As a result, this topology is frequently used in industrial welders to adjust the amount of energy delivered to the weld arc.

Figure 55-5. Phase Shifted PWMs Applied to a Transformer Primary
55.4.1.4 Double Switching PWMs

Double switching PWM output is supported to aid in single shunt current measurement and three phase reconstruction. This method support two independent rising edges and two independent falling edges per PWM cycle. The VAL2 and VAL3 registers are used to generate the even channel (labelled as PWM_A in the figure) while VAL4 and VAL5 are used to generate the odd channel. The two channels are combined using XOR logic (force out logic) as the following figure shows. The DBLPWM signal can be run through the deadtime insertion logic.

Figure 55-6. Double Switching Output Example
55.4.1.5 ADC Triggering

In cases where the timing of the ADC triggering is critical, it must be scheduled as a hardware event instead of software activated. With this PWM module, multiple ADC triggers can be generated in hardware per PWM cycle without the requirement of another timer module. Figure 55-7 shows how this is accomplished. When specifying complementary mode of operation, only two edge comparators are required to generate the output PWM signals for a given submodule. This means that the other comparators are free to perform other functions. In this example, the software does not need to quickly respond after the first conversion to set up other conversions that must occur in the same PWM cycle.

![Figure 55-7. Multiple Output Trigger Generation in Hardware](image)

Because each submodule has its own timer, it is possible for each submodule to run at a different frequency. One of the options possible with this PWM module is to have one or more submodules running at a lower frequency, but still synchronized to the timer in submodule0. Figure 55-8 shows how this feature can be used to schedule ADC triggers over multiple PWM cycles. A suggested use for this configuration would be to use the lower-frequency submodule to control the sampling frequency of the software control algorithm where multiple ADC triggers can now be scheduled over the entire sampling period. In Figure 55-8, all submodule comparators are shown being used for ADC trigger generation.
**55.4.1.6 Enhanced Capture Capabilities (E-Capture)**

When a PWM pin is not being used for PWM generation, it can be used to perform input captures. Recall that for PWM generation BOTH edges of the PWM signal are specified via separate compare register values. When programmed for input capture, both of these registers work on the same pin to capture multiple edges, toggling from one to the other in either a free running or one-shot fashion. By simply programming the desired edge of each capture circuit, period and pulse width of an input signal can easily be measured without the requirement to re-arm the circuit. In addition, each edge of the input signal can clock an 8 bit counter where the counter output is compared to a user specified value (EDGCMP). When the counter output equals EDGCMP, the value of the submodule timer is captured and the counter is automatically reset. This feature allows the module to count a specified number of edge events and then perform a capture and interrupt. The following figure illustrates some of the functionality of the E-Capture circuit.
When a submodule is being used for PWM generation, its timer counts up to the modulus value used to specify the PWM frequency and then is re-initialized. Therefore, using this timer for input captures on one of the other pins (for example, PWM_X) has limited utility since it does not count through all of the numbers and the timer reset represents a discontinuity in the 16 bit number range. However, when measuring a signal that is synchronous to the PWM frequency, the timer modulus range is perfectly suited for the application. Consider the following figure as an example. In this application the output of a PWM power stage is connected to the PWM_X pin that is configured for free running input captures. Specifically, the CVAL0 capture circuitry is programmed for rising edges and the CVAL1 capture circuitry is set for falling edges. This will result in new load pulse width data being acquired every PWM cycle. To calculate the pulse width, simply subtract the CVAL0 register value from the CVAL1 register value. This measurement is extremely beneficial when performing dead-time distortion correction on a half bridge circuit driving an inductive load. Also, these values can be directly compared to the VALx registers responsible for generating the PWM outputs to obtain a measurement of system propagation delays. For details, refer to the separate discussion of deadtime distortion correction.
During deadtime, load inductance drives voltage with polarity that keeps inductive current flowing through diodes.

**Figure 55-10. Output Pulse Width Measurement Possible with the E-Capture Circuit**

### 55.4.1.7 Synchronous Switching of Multiple Outputs

Before the PWM signals are routed to the output pins, they are processed by a hardware block that permits all submodule outputs to be switched synchronously. This feature can be extremely useful in commutated motor applications where the next commutation state can be laid in ahead of time and then immediately switched to the outputs when the appropriate condition or time is reached. Not only do all the changes occur synchronously on all submodule outputs, but they occur IMMEDIATELY after the trigger event occurs eliminating any interrupt latency.

The synchronous output switching is accomplished via a signal called FORCE_OUT. This signal originates from the local FORCE bit within the submodule, from submodule0, or from external to the PWM module and, in most cases, is supplied from an external timer channel configured for output compare. In a typical application, software sets up the desired states of the output pins in preparation for the next FORCE_OUT event. This selection lays dormant until the FORCE_OUT signal transitions and then all outputs are
switched simultaneously. The signal switching is performed upstream from the deadtime generator so that any abrupt changes that might occur do not violate deadtime on the power stage when in complementary mode.

Figure 55-11 shows a popular application that can benefit from this feature. On a brushless DC motor it is desirable on many cases to spin the motor without need of hall-effect sensor feedback. Instead, the back EMF of the motor phases is monitored and this information is used to schedule the next commutation event. The top waveforms of Figure 55-11 are a simplistic representation of these back EMF signals. Timer compare events (represented by the long vertical lines in the diagram) are scheduled based on the zero crossings of the back-EMF waveforms. The PWM module is configured via software ahead of time with the next state of the PWM pins in anticipation of the compare event. When it happens, the output compare of the timer drives the FORCE_OUT signal which immediately changes the state of the PWM pins to the next commutation state with no software latency.
55.4.2 Functional Details

This section describes the implementation of various sections of the PWM in greater detail.

The following figure is a high-level block diagram of output PWM generation.

![Figure 55-11. Sensorless BLDC Commutation Using the Force Out Function](image-url)
55.4.2.1 PWM Clocking

Figure 55-13 shows the logic used to generate the main counter clock. Each submodule can select between three clock signals: the IPBus clock, EXT_CLK, and AUX_CLK. The EXT_CLK goes to all of the submodules. The AUX_CLK signal is broadcast from submodule0 and can be selected as the clock source by other submodules so that the 8-bit prescaler and MCTRL[RUN] from submodule0 can control all of the submodules.

To permit lower PWM frequencies, the prescaler produces the PWM clock frequency by dividing the IPBus clock frequency by 1-128. The prescaler bits, CTRL[PRSC], select the prescaler divisor. This prescaler is buffered and will not be used by the PWM generator until MCTRL[LDOK] is set and a new PWM reload cycle begins or CTRL[LDMOD] is set.
55.4.2.2 Register Reload Logic

The register reload logic is used to determine when the outer set of registers for all double buffered register pairs will be transferred to the inner set of registers. The register reload event can be scheduled to occur every "n" PWM cycles using CTRL[LDFQ] and CTRL[FULL]. A half cycle reload option is also supported (CTRL[HALF]) where the reload can take place in the middle of a PWM cycle. The half cycle point is defined by the VAL0 register and does not have to be exactly in the middle of the PWM cycle.

As illustrated in Figure 55-14 the reload signal from submodule0 can be broadcast as the Master Reload signal allowing the reload logic from submodule0 to control the reload of registers in other submodules.

![](image)

**Figure 55-14. Register Reload Logic**

55.4.2.3 Counter Synchronization

In the following figure, the 16 bit counter will count up until its output equals VAL1 which is used to specify the counter modulus value. The resulting compare causes a rising edge to occur on the Local Sync signal which is one of four possible sources used to cause the 16 bit counter to be initialized with INIT. If Local Sync is selected as the counter initialization signal, then VAL1 within the submodule effectively controls the timer period (and thus the PWM frequency generated by that submodule) and everything works on a local level.
The Master Sync signal originates as the Local Sync from submodule0. If configured to do so, the timer period of any submodule can be locked to the period of the timer in submodule0.

The PWM_EXT_SYNC signal originates on chip or off chip depending on the system architecture. This signal may be selected as the source for counter initialization so that an external source can control the period of all submodules.

If the Master Reload signal is selected as the source for counter initialization, then the period of the counter will be locked to the register reload frequency of submodule0. Since the reload frequency is usually commensurate to the sampling frequency of the software control algorithm, the submodule counter period will therefore equal the sampling period. As a result, this timer can be used to generate output compares or output triggers over the entire sampling period which may consist of several PWM cycles. The Master Reload signal can only originate from submodule0.

The counter can optionally initialize upon the assertion of the FORCE_OUT signal assuming that CTRL2[FRCEN] is set. As indicated by the preceding figure, this constitutes a second init input into the counter which will cause the counter to initialize regardless of which signal is selected as the counter init signal. The FORCE_OUT signal is provided mainly for commutated applications. When PWM signals are commutated on an inverter controlling a brushless DC motor, it is necessary to restart the PWM cycle at the beginning of the commutation interval. This action effectively resynchronizes the PWM waveform to the commutation timing. Otherwise, the average voltage applied to a motor winding integrated over the entire commutation interval will be a function of the
timing between the asynchronous commutation event with respect to the PWM cycle. The effect is more critical at higher motor speeds where each commutation interval may consist of only a few PWM cycles. If the counter is not initialized at the start of each commutation interval, the result will be an oscillation caused by the beating between the PWM frequency and the commutation frequency.

55.4.2.4 PWM Generation

Figure 55-16 illustrates how PWM generation is accomplished in each submodule. In each case, two comparators and associated VALx registers are utilized for each PWM output signal. One comparator and VALx register are used to control the turn-on edge, while a second comparator and VALx register control the turn-off edge.

Figure 55-16. PWM Generation Hardware
The generation of the Local Sync signal is performed exactly the same way as the other PWM signals in the submodule. While comparator 0 causes a falling edge of the Local Sync signal, comparator 1 generates a rising edge. Comparator 1 is also hardwired to the reload logic to generate the full cycle reload indicator.

If VAL1 is controlling the modulus of the counter and VAL0 is half of the VAL1 register minus the INIT value, then the half cycle reload pulse will occur exactly half way through the timer count period and the Local Sync will have a 50% duty cycle. On the other hand, if the VAL1 and VAL0 registers are not required for register reloading or counter initialization, they can be used to modulate the duty cycle of the Local Sync signal, effectively turning it into an auxiliary PWM signal (PWM_X) assuming that the PWM_X pin is not being used for another function such as input capture or deadtime distortion correction. Including the Local Sync signal, each submodule is capable of generating three PWM signals where software has complete control over each edge of each of the signals.

If the comparators and edge value registers are not required for PWM generation, they can also be used for other functions such as output compares, generating output triggers, or generating interrupts at timed intervals.

The 16-bit comparators shown in Figure 55-16 are "equal to" comparators. In addition, if both the set and reset of the flip-flop are asserted, then the flop output goes to 0.

55.4.2.5 Output Compare Capabilities

By using the VALx registers in conjunction with the submodule timer and 16 bit comparators, buffered output compare functionality can be achieved with no additional hardware required. Specifically, the following output compare functions are possible:

- An output compare sets the output high
- An output compare sets the output low
- An output compare generates an interrupt
- An output compare generates an output trigger

In PWM generation, an output compare is initiated by programming a VALx register for a timer compare, which in turn causes the output of the D flip-flop to either set or reset. For example, if an output compare is desired on the PWM_A signal that sets it high, VAL2 would be programmed with the counter value where the output compare should take place. However, to prevent the D flip-flop from being reset again after the compare has occurred, the VAL3 register must be programmed to a value outside of the modulus range of the counter. Therefore, a compare that would result in resetting the D flip-flop
output would never occur. Conversely, if an output compare is desired on the PWM_A signal that sets it low, the VAL3 register is programmed with the appropriate count value and the VAL2 register is programmed with a value outside the counter modulus range. Regardless of whether a high compare or low compare is programmed, an interrupt or output trigger can be generated when the compare event occurs.

55.4.2.6 Force Out Logic

For each submodule, software can select between eight signal sources for the FORCE_OUT signal: local CTRL2[FORCE], the Master Force signal from submodule0, the local Reload signal, the Master Reload signal from submodule0, the Local Sync signal, the Master Sync signal from submodule0, the EXT_SYNC signal from on- or off-chip, or the EXT_FORCE signal from on- or off-chip depending on the chip architecture. The local signals are used when the user simply wants to change the signals on the output pins of the submodule without regard for synchronization with other submodules. However, if it is required that all signals on all submodule outputs change at the same time, the Master, EXT_SYNC, or EXT_FORCE signals should be selected.

Figure 55-17 illustrates the Force logic. The SEL23 and SEL45 fields each choose from one of four signals that can be supplied to the submodule outputs: the PWM signal, the inverted PWM signal, a binary level specified by software via the OUT23 and OUT45 bits, or the PWM_EXTA or PWM_EXTB alternate external control signals. The selection can be determined ahead of time and, when a FORCE_OUT event occurs, these values are presented to the signal selection mux that immediately switches the requested signal to the output of the mux for further processing downstream.
The local CTRL2[FORCE] signal of submodule0 can be broadcast as the Master Force signal to other submodules. This feature allows the CTRL2[FORCE] of submodule0 to synchronously update all of the submodule outputs at the same time. The EXT_FORCE signal originates from outside the PWM module from a source such as a timer or digital comparators in the Analog-to-Digital Converter.

55.4.2.7 Independent or Complementary Channel Operation

Writing a logic one to CTRL2[INDEP] configures the pair of PWM outputs as two independent PWM channels. Each PWM output is controlled by its own VALx pair operating independently of the other output.

Writing a logic zero to CTRL2[INDEP] configures the PWM output as a pair of complementary channels. The PWM pins are paired as shown in Figure 55-18 in complementary channel operation. Which signal is connected to the output pin (PWM23 or PWM45) is determined by MCTRL[IPOL].

Figure 55-17. Force Out Logic
Figure 55-18. Complementary Channel Pair

The complementary channel operation is for driving top and bottom transistors in a motor drive circuit, such as the one in Figure 55-19.

Figure 55-19. Typical 3 Phase AC Motor Drive

Complementary operation allows the use of the deadtime insertion feature.

55.4.2.8 Deadtime Insertion Logic

The following figure shows the deadtime insertion logic of each submodule which is used to create non-overlapping complementary signals when not in independent mode.
While in the complementary mode, a PWM pair can be used to drive top/bottom transistors, as shown in the figure. When the top PWM channel is active, the bottom PWM channel is inactive, and vice versa.

**Note**

To avoid short circuiting the DC bus and endangering the transistor, there must be no overlap of conducting intervals between top and bottom transistor. But the transistor's characteristics may make its switching-off time longer than switching-on time. To avoid the conducting overlap of top and bottom transistors, deadtime needs to be inserted in the switching period, as illustrated in the following figure.

The deadtime generators automatically insert software-selectable activation delays into the pair of PWM outputs. The deadtime registers (DTCNT0 and DTCNT1) specify the number of IPBus clock cycles to use for deadtime delay. Every time the deadtime generator inputs change state, deadtime is inserted. Deadtime forces both PWM outputs in the pair to the inactive state.
When deadtime is inserted in complementary PWM signals connected to an inverter driving an inductive load, the PWM waveform on the inverter output will have a different duty cycle than what appears on the output pins of the PWM module. This results in a distortion in the voltage applied to the load. A method of correcting this, adding to or subtracting from the PWM value used, is discussed next.

![Diagram of PWM signals with and without deadtime](image)

**Figure 55-21. Deadtime Insertion**

### 55.4.2.8.1 Top/Bottom Correction

In complementary mode, either the top or the bottom transistor controls the output voltage. However, deadtime has to be inserted to avoid overlap of conducting interval between the top and bottom transistor. Both transistors in complementary mode are off during deadtime, allowing the output voltage to be determined by the current status of load and introduce distortion in the output voltage. See the following figure. On AC induction motors running open-loop, the distortion typically manifests itself as poor low-speed performance, such as torque ripple and rough operation.
During deadtime, load inductance distorts output voltage by keeping current flowing through the diodes. This deadtime current flow creates a load voltage that varies with current direction. With a positive current flow, the load voltage during deadtime is equal to the bottom supply, putting the top transistor in control. With a negative current flow, the load voltage during deadtime is equal to the top supply putting the bottom transistor in control.

Remembering that the original PWM pulse widths where shortened by deadtime insertion, the averaged sinusoidal output will be less than the desired value. However, when deadtime is inserted, it creates a distortion in the motor current waveform inverter outputs. This distortion is aggravated by dissimilar turn-on and turn-off delays of each of the transistors. By giving the PWM module information on which transistor is controlling at a given time this distortion can be corrected.

For a typical circuit in complementary channel operation, only one of the transistors will be effective in controlling the output voltage at any given time. This depends on the direction of the motor inverter current for that pair, as the preceding figure shows. To correct distortion one of two different factors must be added to the desired PWM value, depending on whether the top or bottom transistor is controlling the output voltage. Therefore, the software is responsible for calculating both compensated PWM values prior to placing them in the VALx registers. Either the VAL2/VAL3 or the VAL4/VAL5 register pair controls the pulse width at any given time. For a given PWM pair, whether the VAL2/VAL3 or VAL4/VAL5 pair is active depends on either:

- The state of the current status pin, PWMX, for that driver
- The state of the odd/even correction bit, MCTRL[IPOL], for that driver
To correct deadtime distortion, software can decrease or increase the value in the appropriate VALx register.

- In edge-aligned operation, decreasing or increasing the PWM value by a correction value equal to the deadtime typically compensates for deadtime distortion.
- In center-aligned operation, decreasing or increasing the PWM value by a correction value equal to one-half the deadtime typically compensates for deadtime distortion.

### 55.4.2.8.2 Manual Correction

To detect the current status, the voltage on each PWMX pin is sampled twice in a PWM period, at the end of each deadtime. The value is stored in CTRL[DT]. CTRL[DT] is a timing marker especially indicating when to toggle between PWM value registers. Software can then set MCTRL[IPOL] to switch between VAL2/VAL3 and VAL4/VAL5 register pairs according to CTRL[DT] values.

![Figure 55-23. Current-status Sense Scheme for Deadtime Correction](image)

Both D flip-flops latch low, CTRL[DT] = 00, during deadtime periods if current is large and flowing out of the complementary circuit. See the preceding figure. Both D flip-flops latch the high, CTRL[DT] = 11, during deadtime periods if current is also large and flowing into the complementary circuit.

However, under low-current, the output voltage of the complementary circuit during deadtime is somewhere between the high and low levels. The current cannot free-wheel through the opposition anti-body diode, regardless of polarity, giving additional distortion when the current crosses zero. **Sampled results will be CTRL[DT] = b10. Thus, the best time to change one PWM value register to another is just before the current zero crossing.**
55.4.2.9 Fractional Delay Logic

For applications where more resolution than a single IPBus clock period is needed, the fractional delay logic can be used to achieve fine resolution on the rising and falling edges of the PWM_A and PWM_B outputs and fine resolution for the PWM period. Enable the use of the fractional delay logic by setting FRCTRL[FRACx_EN]. The FRACVALx registers act as a fractional clock cycle addition to the turn on and turn off count specified by the VAL2, VAL3, VAL4, or VAL5 registers. The FRACVAL1 register acts as a fractional increase in the PWM period as defined by VAL1. If FRACVAL1 is programmed to a non-zero value, then the largest value for the VAL1 register is 0xFFFFE for unsigned usage or 0x7FFE for signed usage. This limit is needed in order to avoid counter rollovers when accumulating the fractional additional period.

The results of the fractional delay logic depend on whether or not the PWM submodule has an analog NanoEdge placer block available.
55.4.2.9.1 Fractional Delay Logic with NanoEdge Placement Block

Using the NanoEdge placer block requires that the IPBus clock to the PWM be set at a defined frequency. The NanoEdge placer is powered up by setting FRCTRL[FRAC_PU]. Enable fine edge control on the various PWM edges by setting FRCTRL[FRACx_EN]. The fractional values in the FRACVALx registers allow placing the PWM edge or PWM period to a granularity of 1/32 of the IPBus clock period. For example, if you desire the rising edge of the PWMA output to occur at a count of 12.25, then program VAL2 with 0x000C and FRACVAL2 with 0x4000. Using FRACVAL1 will adjust the PWM period with the same granularity of 1/32 of a clock period.

If the FRCTRL[FRAC_PU] bits in all of the submodules are clear, then the NanoEdge placer is powered down, and alternate clock frequencies can be used without the NanoEdge placement feature.

55.4.2.9.2 Fractional Delay Logic without NanoEdge Placement Block

For submodules that are not supported by the NanoEdge placer, the PWM can use dithering to simulate fine edge control. Enable this feature by setting the FRCTRL[FRAC1_EN], FRCTRL[FRAC23_EN], and FRCTRL[FRAC45_EN] bits. It is unnecessary to set FRCTRL[FRAC_PU]. The PWM period or the PWM edges will dither from the nearest whole number values to achieve an average value that is equivalent to the programmed fractional value. The added cycles are based on the accumulation of the fractional component. For example, if you want the PWM period to be 50.25 clock cycles, then program VAL1 with 0x0032 and FRACVAL1 with 0x4000. The PWM period will be 50 cycles long most of the time, but will occasionally be 51 cycles long to achieve a long-term average of 50.25 cycles.

In submodules that are not supported by a NanoEdge placer, the clock frequency is not required to be any specific value to achieve proper operation.

55.4.2.10 Output Logic

The following figure shows the output logic of each submodule including how each PWM output has individual fault disabling, polarity control, and output enable. This allows for maximum flexibility when interfacing to the external circuitry.

The PWM23 and PWM45 signals which are output from the deadtime logic (refer to the figure) are positive true signals. In other words, a high level on these signals should result in the corresponding transistor in the PWM inverter being turned ON. The voltage level required at the PWM output pin to turn the transistor ON or OFF is a function of the logic between the pin and the transistor. Therefore, it is imperative that the user program
OCTRL[POLA] and OCTRL[POLB] before enabling the output pins. A fault condition can result in the PWM output being tristated, forced to a logic 1, or forced to a logic 0 depending on the values programmed into the OCTRL[PWMxFS] fields.

**Figure 55-25. Output Logic**

### 55.4.2.11 E-Capture

Commensurate with the idea of controlling both edges of an output signal, the Enhanced Capture (E-Capture) logic is designed to measure both edges of an input signal. As a result, when a submodule pin is configured for input capture, the CVALx registers associated with that pin are used to record the edge values.

The following figure is a block diagram of the E-Capture circuit. Upon entering the pin input, the signal is split into two paths. One goes straight to a mux input where software can select to pass the signal directly to the capture logic for processing. The other path connects the signal to an 8 bit counter which counts both the rising and falling edges of the signal. The output of this counter is compared to an 8 bit value that is specified by the user (EDGCMPx) and when the two values are equal, the comparator generates a pulse that resets the counter. This pulse is also supplied to the mux input where software can select it to be processed by the capture logic. This feature permits the E-Capture circuit to count up to 256 edge events before initiating a capture event. This feature is useful for
dividing down high frequency signals for capture processing so that capture interrupts
don't overwhelm the CPU. Also, this feature can be used to simply generate an interrupt
after "n" events have been counted.

This logic is repeated for PWM_A, PWM_B, and PWM_X inputs.

Based on the mode selection, the mux selects either the pin input or the compare output
from the count/compare circuit to be processed by the capture logic. The selected signal
is routed to two separate capture circuits which work in tandem to capture sequential
edges of the signal. The type of edge to be captured by each circuit is determined by
CAPTCTRLx[EDGx1] and CAPTCTRLx[EDGx0], whose functionality is listed in the
preceding figure. Also, controlling the operation of the capture circuits is the arming
logic which allows captures to be performed in a free running (continuous) or one shot
fashion. In free running mode, the capture sequences will be performed indefinitely. If
both capture circuits are enabled, they will work together in a ping-pong style where a
capture event from one circuit leads to the arming of the other and vice versa. In one shot
mode, only one capture sequence will be performed. If both capture circuits are enabled,
capture circuit 0 is first armed and when a capture event occurs, capture circuit 1 is
armed. Once the second capture occurs, further captures are disabled until another
capture sequence is initiated. Both capture circuits are also capable of generating an
interrupt to the CPU.

Figure 55-26. Enhanced Capture (E-Capture) Logic
55.4.2.12 Fault Protection

Fault protection can control any combination of PWM output pins. Faults are generated by a logic one on any of the FAULTx pins. This polarity can be changed via FCTRL[FLVL]. Each FAULTx pin can be mapped arbitrarily to any of the PWM outputs. When fault protection hardware disables PWM outputs, the PWM generator continues to run, only the output pins are forced to logic 0, logic 1, or tristated depending the values of OCTRL[PWMxFS].

The fault decoder disables PWM pins selected by the fault logic and the disable mapping (DISMAPn) registers. The following figure shows an example of the fault disable logic. Each bank of bits in DISMAPn control the mapping for a single PWM pin. See the following table.

The fault protection is enabled even when the PWM module is not enabled; therefore, a fault will be latched in and must be cleared in order to prevent an interrupt when the PWM is enabled.
Figure 55-27. Fault Decoder for PWM_A

Table 55-3. Fault Mapping

<table>
<thead>
<tr>
<th>PWM Pin</th>
<th>Controlling Register Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWM_A</td>
<td>DISMAP0[DIS0A] and DISMAP1[DIS1A]</td>
</tr>
<tr>
<td>PWM_B</td>
<td>DISMAP0[DIS0B] and DISMAP1[DIS1B]</td>
</tr>
<tr>
<td>PWM_X</td>
<td>DISMAP0[DIS0X] and DISMAP1[DIS1X]</td>
</tr>
</tbody>
</table>
55.4.2.12.1 Fault Pin Filter

Each fault pin has a programmable filter that can be bypassed. The sampling period of the filter can be adjusted with FFILT[FILT_PER]. The number of consecutive samples that must agree before an input transition is recognized can be adjusted using FFILT[FILT_CNT]. Setting FFILT[FILT_PER] to all 0 disables the input filter for a given FAULTx pin.

Upon detecting a logic 0 on the filtered FAULTx pin (or a logic 1 if FCTRL[FLVLx] is set), the corresponding FSTS[FFPINx] and fault flag, FSTS[FFLAGx], bits are set. FSTS[FFPINx] remains set as long as the filtered FAULTx pin is zero. Clear FSTS[FFLAGx] by writing a logic 1 to FSTS[FFLAGx].

If the FIEx, FAULTx pin interrupt enable bit is set, FSTS[FFLAGx] generates a CPU interrupt request. The interrupt request latch remains set until:

- Software clears FSTS[FFLAGx] by writing a logic one to the bit
- Software clears the FIEx bit by writing a logic zero to it
- A reset occurs

Even with the filter enabled, there is a combinational path from the FAULTx inputs to the PWM pins. This logic is also capable of holding a fault condition in the event of loss of clock to the PWM module.

55.4.2.12.2 Automatic Fault Clearing

Setting an automatic clearing mode bit, FCTRL[FAUTOx], configures faults from the FAULTx pin for automatic clearing.

When FCTRL[FAUTOx] is set, disabled PWM pins are enabled when the FAULTx pin returns to logic one and a new PWM full or half cycle begins. See the following figure. If FSTS[FFULLx] is set, then the disabled PWM pins are enabled at the start of a full cycle. If FSTS[FHALFx] is set, then the disabled PWM pins are enabled at the start of a half cycle. Clearing FSTS[FFLAGx] does not affect disabled PWM pins when FCTRL[FAUTOx] is set.
55.4.2.12.3 Manual Fault Clearing

Clearing the automatic clearing mode bit, FCTRL[FAUTOx], configures faults from the FAULTx pin for manual clearing:

- If the fault safety mode bits, FCTRL[FSAFEx], are clear, then PWM pins disabled by the FAULTx pins are enabled when:
  - Software clears the corresponding FSTS[FFLAGx] flag
  - The pins are enabled when the next PWM full or half cycle begins regardless of the logic level detected by the filter at the FAULTx pin. See the first following figure. If FSTS[FFULLx] is set, then the disabled PWM pins are enabled at the start of a full cycle. If FSTS[FHALFx] is set, then the disabled PWM pins are enabled at the start of a half cycle.

- If the fault safety mode bits, FCTRL[FSAFEx], are set, then PWM pins disabled by the FAULTx pins are enabled when:
  - Software clears the corresponding FSTS[FFLAGx] flag
  - The filter detects a logic one on the FAULTx pin at the start of the next PWM full or half cycle boundary. See the second following figure. If FSTS[FFULLx] is set, then the disabled PWM pins are enabled at the start of a full cycle. If FSTS[FHALFx] is set, then the disabled PWM pins are enabled at the start of a half cycle.
Fault protection also applies during software output control when the SEL23 and SEL45 fields are set to select OUT23 and OUT45 bits or PWM_EXTA and PWM_EXTB. Fault clearing still occurs at half PWM cycle boundaries while the PWM generator is engaged, MCTRL[RUN] equals one. But the OUTx bits can control the PWM pins while the PWM generator is off, MCTRL[RUN] equals zero. Thus, fault clearing occurs at IPBus cycles while the PWM generator is off and at the start of PWM cycles when the generator is engaged.

55.4.2.12.4 Fault Testing

FTST[FTEST] is used to simulate a fault condition on each of the fault inputs within that fault channel.

55.4.3 PWM Generator Loading
55.4.3.1 Load Enable

MCTRL[LDOK] enables loading of the following PWM generator parameters:

- The prescaler divisor—from CTRL[PRSC]
- The PWM period and pulse width—from the INIT and VALx registers

MCTRL[LDOK] allows software to finish calculating all of these PWM parameters so they can be synchronously updated. The CTRL[PRSC], INIT, and VALx registers are loaded by software into a set of outer buffers. When MCTRL[LDOK] is set, these values are transferred to an inner set of registers at the beginning of the next PWM reload cycle to be used by the PWM generator. These values can be transferred to the inner set of registers immediately upon setting MCTRL[LDOK] if CTRL[LDMOD] is set. Set MCTRL[LDOK] by reading it when it is a logic zero and then writing a logic one to it. After loading, MCTRL[LDOK] is automatically cleared.

55.4.3.2 Load Frequency

CTRL[LDFQ] selects an integral loading frequency of one to 16 PWM reload opportunities. CTRL[LDFQ] takes effect at every PWM reload opportunity, regardless the state of MCTRL[LDOK]. CTRL[HALF] and CTRL[FULL] control reload timing. If CTRL[FULL] is set, a reload opportunity occurs at the end of every PWM cycle when the count equals VAL1. If CTRL[HALF] is set, a reload opportunity occurs at the half cycle when the count equals VAL0. If both CTRL[HALF] and CTRL[FULL] are set, a reload opportunity occurs twice per PWM cycle when the count equals VAL1 and when it equals VAL0.

![Figure 55-31. Full Cycle Reload Frequency Change](image)
55.4.3.3 Reload Flag

At every reload opportunity the PWM Reload Flag (STS[RF]) is set. Setting STS[RF] happens even if an actual reload is prevented by MCTRL[LDOK]. If the PWM reload interrupt enable bit, INTEN[RIE], is set, the STS[RF] flag generates CPU interrupt requests allowing software to calculate new PWM parameters in real time. When INTEN[RIE] is not set, reloads still occur at the selected reload rate without generating CPU interrupt requests.
55.4.3.4 Reload Errors

Whenever one of the VALx, FRACVALx, or CTRL[PRSC] registers is updated, the STS[RUF] flag is set to indicate that the data is not coherent. STS[RUF] will be cleared by a successful reload which consists of the reload signal while MCTRL[LDOK] is set. If STS[RUF] is set and MCTRL[LDOK] is clear when the reload signal occurs, a reload error has taken place and STS[REF] is set. If STS[RUF] is clear when a reload signal asserts, then the data is coherent and no error will be flagged.

55.4.3.5 Initialization

Initialize all registers and set MCTRL[LDOK] before setting MCTRL[RUN].

Note

Even if MCTRL[LDOK] is not set, setting MCTRL[RUN] also sets the STS[RF] flag. To prevent a CPU interrupt request, clear INTEN[RIE] before setting MCTRL[RUN].

The PWM generator uses the last values loaded if MCTRL[RUN] is cleared and then set while MCTRL[LDOK] equals zero.

When MCTRL[RUN] is cleared:

- The STS[RF] flag and pending CPU interrupt requests are not cleared
- All fault circuitry remains active
- Software/external output control remains active
- Deadtime insertion continues during software/external output control

55.5 Resets

All PWM registers are reset to their default values upon any system reset.

The reset forces all registers to their reset states and tri-states the PWM outputs.
## 55.6 Interrupts

Each of the submodules within the eFlexPWM module can generate an interrupt from several sources. The fault logic can also generate interrupts. The interrupt service routine (ISR) must check the related interrupt enables and interrupt flags to determine the actual cause of the interrupt.

<table>
<thead>
<tr>
<th>Core Interrupt</th>
<th>Interrupt Flag</th>
<th>Interrupt Enable</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWM_CMP0</td>
<td>SM0STS[CMPF]</td>
<td>SM0INTEN[CMPIE]</td>
<td>Submodule 0 compare interrupt</td>
<td>Compare event has occurred</td>
</tr>
<tr>
<td>PWM_CAP0</td>
<td>SM0STS[CFA1], SM0STS[CFA0], SM0STS[CFB1], SM0STS[CFB0], SM0STS[CFX1], SM0STS[CFX0]</td>
<td>SM0INTEN[CFA1IE], SM0INTEN[CFA0IE], SM0INTEN[CFB1IE], SM0INTEN[CFB0IE], SM0INTEN[CFX1IE], SM0INTEN[CFX0IE]</td>
<td>Submodule 0 input capture interrupt</td>
<td>Input capture event has occurred</td>
</tr>
<tr>
<td>PWM_RELOAD0</td>
<td>SM0STS[RF]</td>
<td>SM0INTEN[RIE]</td>
<td>Submodule 0 reload interrupt</td>
<td>Reload event has occurred</td>
</tr>
<tr>
<td>PWM_CMP1</td>
<td>SM1STS[CMPF]</td>
<td>SM1INTEN[CMPIE]</td>
<td>Submodule 1 compare interrupt</td>
<td>Compare event has occurred</td>
</tr>
<tr>
<td>PWM_CAP1</td>
<td>SM1STS[CFA1], SM1STS[CFA0], SM1STS[CFB1], SM1STS[CFB0], SM1STS[CFX1], SM1STS[CFX0]</td>
<td>SM1INTEN[CFA1IE], SM1INTEN[CFA0IE], SM1INTEN[CFB1IE], SM1INTEN[CFB0IE], SM1INTEN[CFX1IE], SM1INTEN[CFX0IE]</td>
<td>Submodule 1 input capture interrupt</td>
<td>Input capture event has occurred</td>
</tr>
<tr>
<td>PWM_RELOAD1</td>
<td>SM1STS[RF]</td>
<td>SM1INTEN[RIE]</td>
<td>Submodule 1 reload interrupt</td>
<td>Reload event has occurred</td>
</tr>
<tr>
<td>PWM_CMP2</td>
<td>SM2STS[CMPF]</td>
<td>SM2INTEN[CMPIE]</td>
<td>Submodule 2 compare interrupt</td>
<td>Compare event has occurred</td>
</tr>
<tr>
<td>PWM_CAP2</td>
<td>SM2STS[CFA1], SM2STS[CFA0], SM2STS[CFB1], SM2STS[CFB0], SM2STS[CFX1], SM2STS[CFX0]</td>
<td>SM2INTEN[CFA1IE], SM2INTEN[CFA0IE], SM2INTEN[CFB1IE], SM2INTEN[CFB0IE], SM2INTEN[CFX1IE], SM2INTEN[CFX0IE]</td>
<td>Submodule 2 input capture interrupt</td>
<td>Input capture event has occurred</td>
</tr>
<tr>
<td>PWM_RELOAD2</td>
<td>SM2STS[RF]</td>
<td>SM2INTEN[RIE]</td>
<td>Submodule 2 reload interrupt</td>
<td>Reload event has occurred</td>
</tr>
<tr>
<td>PWM_CMP3</td>
<td>SM3STS[CMPF]</td>
<td>SM3INTEN[CMPIE]</td>
<td>Submodule 3 compare interrupt</td>
<td>Compare event has occurred</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
Table 55-4. Interrupt Summary (continued)

<table>
<thead>
<tr>
<th>Core Interrupt</th>
<th>Interrupt Flag</th>
<th>Interrupt Enable</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWM_CAP3</td>
<td>SM3STS[CFA1], SM3STS[CFA0], SM3STS[CFB1], SM3STS[CFB0], SM3STS[CFX1], SM3STS[CFX0]</td>
<td>SM3INTEN[CFA1IE], SM3INTEN[CFA0IE], SM3INTEN[CFB1IE], SM3INTEN[CFB0IE], SM3INTEN[CFX1IE], SM3INTEN[CFX0IE]</td>
<td>Submodule 3 input capture interrupt</td>
<td>Submodule 3 input capture event has occurred</td>
</tr>
<tr>
<td>PWM_RELOAD3</td>
<td>SM3STS[RF]</td>
<td>SM3INTEN[RIE]</td>
<td>Submodule 3 reload interrupt</td>
<td>Submodule 3 reload event has occurred</td>
</tr>
<tr>
<td>PWM_RERR</td>
<td>SM0STS[REF]</td>
<td>SM0INTEN[REIE]</td>
<td>Submodule 0 reload error interrupt</td>
<td>Submodule 0 reload error has occurred</td>
</tr>
<tr>
<td></td>
<td>SM1STS[REF]</td>
<td>SM1INTEN[REIE]</td>
<td>Submodule 1 reload error interrupt</td>
<td></td>
</tr>
<tr>
<td></td>
<td>SM2STS[REF]</td>
<td>SM2INTEN[REIE]</td>
<td>Submodule 2 reload error interrupt</td>
<td></td>
</tr>
<tr>
<td></td>
<td>SM3STS[REF]</td>
<td>SM3INTEN[REIE]</td>
<td>Submodule 3 reload error interrupt</td>
<td></td>
</tr>
<tr>
<td>PWMFAULT</td>
<td>FSTS[FFLAG]</td>
<td>FCTRL[FIE]</td>
<td>Fault input interrupt</td>
<td>Fault condition has been detected</td>
</tr>
</tbody>
</table>

55.7 DMA

Each submodule can request a DMA read access for its capture FIFOs and a DMA write request for its double buffered VALx registers.

Table 55-5. DMA Summary

<table>
<thead>
<tr>
<th>DMA Request</th>
<th>DMA Enable</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Submodule 0 read request</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SM0DMAEN[ CX0DE ]</td>
<td>SM0DMAEN[ CX0DE ]</td>
<td>SM0 Capture FIFO X0 read request</td>
<td>SM0CVAL0 contains a value to be read</td>
</tr>
<tr>
<td>SM0DMAEN[ CX1DE ]</td>
<td>SM0DMAEN[ CX1DE ]</td>
<td>SM0 Capture FIFO X1 read request</td>
<td>SM0CVAL1 contains a value to be read</td>
</tr>
<tr>
<td>SM0DMAEN[ CA0DE ]</td>
<td>SM0DMAEN[ CA0DE ]</td>
<td>SM0 Capture FIFO A0 read request</td>
<td>SM0CVAL2 contains a value to be read</td>
</tr>
<tr>
<td>SM0DMAEN[ CA1DE ]</td>
<td>SM0DMAEN[ CA1DE ]</td>
<td>SM0 Capture FIFO A1 read request</td>
<td>SM0CVAL3 contains a value to be read</td>
</tr>
<tr>
<td>SM0DMAEN[ CB0DE ]</td>
<td>SM0DMAEN[ CB0DE ]</td>
<td>SM0 Capture FIFO B0 read request</td>
<td>SM0CVAL4 contains a value to be read</td>
</tr>
<tr>
<td>SM0DMAEN[ CB1DE ]</td>
<td>SM0DMAEN[ CB1DE ]</td>
<td>SM0 Capture FIFO B1 read request</td>
<td>SM0CVAL5 contains a value to be read</td>
</tr>
<tr>
<td>SM0DMAEN[ CAPTDE ]</td>
<td>SM0DMAEN[ CAPTDE ]</td>
<td>Selects source of submodule0 read DMA request</td>
<td></td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>DMA Request</th>
<th>DMA Enable</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Submodule 0 write request</td>
<td>SM0DMAEN[VALDE]</td>
<td>SM0VALx write request</td>
<td>SM0VALx registers need to be updated</td>
</tr>
<tr>
<td>Submodule 1 read request</td>
<td>SM1DMAEN[CX0DE]</td>
<td>SM1 Capture FIFO X0 read request</td>
<td>SM1CVAL0 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM1DMAEN[CX1DE]</td>
<td>SM1 Capture FIFO X1 read request</td>
<td>SM1CVAL1 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM1DMAEN[CA0DE]</td>
<td>SM1 Capture FIFO A0 read request</td>
<td>SM1CVAL2 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM1DMAEN[CA1DE]</td>
<td>SM1 Capture FIFO A1 read request</td>
<td>SM1CVAL3 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM1DMAEN[CB0DE]</td>
<td>SM1 Capture FIFO B0 read request</td>
<td>SM1CVAL4 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM1DMAEN[CB1DE]</td>
<td>SM1 Capture FIFO B1 read request</td>
<td>SM1CVAL5 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM1DMAEN[CAPTDE]</td>
<td>SM1 Capture FIFO read request source select</td>
<td>Selects source of submodule1 read DMA request</td>
</tr>
<tr>
<td>Submodule 1 write request</td>
<td>SM1DMAEN[VALDE]</td>
<td>SM1VALx write request</td>
<td>SM1VALx registers need to be updated</td>
</tr>
<tr>
<td>Submodule 2 read request</td>
<td>SM2DMAEN[CX0DE]</td>
<td>SM2 Capture FIFO X0 read request</td>
<td>SM2CVAL0 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM2DMAEN[CX1DE]</td>
<td>SM2 Capture FIFO X1 read request</td>
<td>SM2CVAL1 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM2DMAEN[CA0DE]</td>
<td>SM2 Capture FIFO A0 read request</td>
<td>SM2CVAL2 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM2DMAEN[CA1DE]</td>
<td>SM2 Capture FIFO A1 read request</td>
<td>SM2CVAL3 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM2DMAEN[CB0DE]</td>
<td>SM2 Capture FIFO B0 read request</td>
<td>SM2CVAL4 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM2DMAEN[CB1DE]</td>
<td>SM2 Capture FIFO B1 read request</td>
<td>SM2CVAL5 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM2DMAEN[CAPTDE]</td>
<td>SM2 Capture FIFO read request source select</td>
<td>Selects source of submodule2 read DMA request</td>
</tr>
<tr>
<td>Submodule 2 write request</td>
<td>SM2DMAEN[VALDE]</td>
<td>SM2VALx write request</td>
<td>SM2VALx registers need to be updated</td>
</tr>
<tr>
<td>Submodule 3 read request</td>
<td>SM3DMAEN[CX0DE]</td>
<td>SM3 Capture FIFO X0 read request</td>
<td>SM3CVAL0 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM3DMAEN[CX1DE]</td>
<td>SM3 Capture FIFO X1 read request</td>
<td>SM3CVAL1 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM3DMAEN[CA0DE]</td>
<td>SM3 Capture FIFO A0 read request</td>
<td>SM3CVAL2 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM3DMAEN[CA1DE]</td>
<td>SM3 Capture FIFO A1 read request</td>
<td>SM3CVAL3 contains a value to be read</td>
</tr>
<tr>
<td></td>
<td>SM3DMAEN[CB0DE]</td>
<td>SM3 Capture FIFO B0 read request</td>
<td>SM3CVAL4 contains a value to be read</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 55-5. DMA Summary (continued)

<table>
<thead>
<tr>
<th>DMA Request</th>
<th>DMA Enable</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SM3DMAEN[CB1DE]</td>
<td>SM3DMAEN[CB1DE]</td>
<td>SM3 Capture FIFO B1 read request</td>
<td>SM3CVAL5 contains a value to be read</td>
</tr>
<tr>
<td>SM3DMAEN[CAPTDE]</td>
<td>SM3DMAEN[CAPTDE]</td>
<td>SM3 Capture FIFO read request source select</td>
<td>Selects source of submodule3 read DMA request</td>
</tr>
<tr>
<td>Submodule 3 write request</td>
<td>SM3DMAEN[VALDE]</td>
<td>SM3VALx write request</td>
<td>SM3VALx registers need to be updated</td>
</tr>
</tbody>
</table>

### 55.8 PWM register descriptions

The address of a register is the sum of a base address and an address offset. The base address is defined at the core level, and the address offset is defined at the module level. The PWM module has a set of registers for each PWM submodule, for the configuration logic, and for each fault channel. While the registers are 16-bit wide, they can be accessed in pairs as 32-bit registers.

Submodule registers are repeated for each PWM submodule. To designate which submodule they are in, register names are prefixed with SM0, SM1, SM2, and SM3. The base address of submodule 0 is the same as the base address for the PWM module as a whole. The base address of submodule 1 is offset $60 from the base address for the PWM module as a whole. This $60 offset is based on the number of registers in a submodule. The base address of submodule 2 is equal to the base address of submodule 1 plus this same $60 offset. The pattern repeats for the base address of submodule 3.

The base address of the configuration registers is equal to the base address of the PWM module as a whole plus an offset of $180.

Fault channel registers are repeated for each fault channel. To designate which fault channel they are in, register names are prefixed with F0 and F1. The base address of fault channel 0 is equal to the base address of the PWM module as a whole plus an offset of $18C. The base address of fault channel 1 is the base address of fault channel 0 + $4. This $4 offset is based on the number of registers in a fault channel. Each of the four fields in the fault channel registers corresponds to fault inputs 3-0.
55.8.1 PWM Memory map

Base address: 403D_C000 for FlexPWM1; 403E_0000 for FlexPWM2; 403E_4000 for FlexPWM3; 403E_8000 for FlexPWM4.

NOTE

PWM_X only applicable to FlexPWM1, while FlexPWM2/3/4 do not have the PWMX outputs or inputs.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Counter Register (SM0CNT)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>2h</td>
<td>Initial Count Register (SM0INIT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>4h</td>
<td>Control 2 Register (SM0CTRL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>6h</td>
<td>Control Register (SM0CTRL)</td>
<td>16</td>
<td>RW</td>
<td>0400h</td>
</tr>
<tr>
<td>Ah</td>
<td>Value Register 0 (SM0VAL0)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>Fractional Value Register 1 (SM0FRACVAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>Eh</td>
<td>Value Register 1 (SM0VAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>10h</td>
<td>Fractional Value Register 2 (SM0FRACVAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>12h</td>
<td>Value Register 2 (SM0VAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Fractional Value Register 3 (SM0FRACVAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>16h</td>
<td>Value Register 3 (SM0VAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>18h</td>
<td>Fractional Value Register 4 (SM0FRACVAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>1Ah</td>
<td>Value Register 4 (SM0VAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>Fractional Value Register 5 (SM0FRACVAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>1Eh</td>
<td>Value Register 5 (SM0VAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>20h</td>
<td>Fractional Control Register (SM0FRCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>22h</td>
<td>Output Control Register (SM0OCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>24h</td>
<td>Status Register (SM0STS)</td>
<td>16</td>
<td>W1C</td>
<td>0000h</td>
</tr>
<tr>
<td>26h</td>
<td>Interrupt Enable Register (SM0INTEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>28h</td>
<td>DMA Enable Register (SM0DMAEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>2Ah</td>
<td>Output Trigger Control Register (SM0TCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>2Ch</td>
<td>Fault Disable Mapping Register 0 (SM0DISMAP0)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
<tr>
<td>2Eh</td>
<td>Fault Disable Mapping Register 1 (SM0DISMAP1)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
<tr>
<td>30h</td>
<td>Deadtime Count Register 0 (SM0DTCNT0)</td>
<td>16</td>
<td>RW</td>
<td>07FFh</td>
</tr>
<tr>
<td>32h</td>
<td>Deadtime Count Register 1 (SM0DTCNT1)</td>
<td>16</td>
<td>RW</td>
<td>07FFh</td>
</tr>
<tr>
<td>34h</td>
<td>Capture Control A Register (SM0CAPCTRLA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>36h</td>
<td>Capture Compare A Register (SM0CAPTCOMPA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>38h</td>
<td>Capture Control B Register (SM0CAPCTRLB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>3Ah</td>
<td>Capture Compare B Register (SM0CAPTCOMPB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>3Ch</td>
<td>Capture Control X Register (SM0CAPCTRLX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>3Eh</td>
<td>Capture Compare X Register (SM0CAPTCOMPX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>40h</td>
<td>Capture Value 0 Register (SM0CVAL0)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>42h</td>
<td>Capture Value 0 Cycle Register (SM0CVAL0CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>44h</td>
<td>Capture Value 1 Register (SM0CVAL1)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>46h</td>
<td>Capture Value 1 Cycle Register (SM0CVAL1CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>48h</td>
<td>Capture Value 2 Register (SM0CVAL2)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>4Ah</td>
<td>Capture Value 2 Cycle Register (SM0CVAL2CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>4Ch</td>
<td>Capture Value 3 Register (SM0CVAL3)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>4Eh</td>
<td>Capture Value 3 Cycle Register (SM0CVAL3CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>50h</td>
<td>Capture Value 4 Register (SM0CVAL4)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>52h</td>
<td>Capture Value 4 Cycle Register (SM0CVAL4CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>54h</td>
<td>Capture Value 5 Register (SM0CVAL5)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>56h</td>
<td>Capture Value 5 Cycle Register (SM0CVAL5CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>60h</td>
<td>Counter Register (SM1CNT)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>62h</td>
<td>Initial Count Register (SM1INIT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>64h</td>
<td>Control 2 Register (SM1CTRL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>66h</td>
<td>Control Register (SM1CTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>6Ah</td>
<td>Value Register 0 (SM1VAL0)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>6Ch</td>
<td>Fractional Value Register 1 (SM1FRACVAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>6Eh</td>
<td>Value Register 1 (SM1VAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>70h</td>
<td>Fractional Value Register 2 (SM1FRACVAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>72h</td>
<td>Value Register 2 (SM1VAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>74h</td>
<td>Fractional Value Register 3 (SM1FRACVAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>76h</td>
<td>Value Register 3 (SM1VAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>78h</td>
<td>Fractional Value Register 4 (SM1FRACVAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>7Ah</td>
<td>Value Register 4 (SM1VAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>7Ch</td>
<td>Fractional Value Register 5 (SM1FRACVAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>7Eh</td>
<td>Value Register 5 (SM1VAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>80h</td>
<td>Fractional Control Register (SM1FRCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>82h</td>
<td>Output Control Register (SM1OCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>84h</td>
<td>Status Register (SM1STS)</td>
<td>16</td>
<td>W1C</td>
<td>0000h</td>
</tr>
<tr>
<td>86h</td>
<td>Interrupt Enable Register (SM1INTEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>88h</td>
<td>DMA Enable Register (SM1DMAEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>8Ah</td>
<td>Output Trigger Control Register (SM1TCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>8Ch</td>
<td>Fault Disable Mapping Register 0 (SM1DISMAP0)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
<tr>
<td>8Eh</td>
<td>Fault Disable Mapping Register 1 (SM1DISMAP1)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
<tr>
<td>90h</td>
<td>Deadtime Count Register 0 (SM1DTCNT0)</td>
<td>16</td>
<td>RW</td>
<td>07F7h</td>
</tr>
<tr>
<td>92h</td>
<td>Deadtime Count Register 1 (SM1DTCNT1)</td>
<td>16</td>
<td>RW</td>
<td>07F7h</td>
</tr>
<tr>
<td>94h</td>
<td>Capture Control A Register (SM1CAPTCTRLA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>96h</td>
<td>Capture Compare A Register (SM1CAPTCOMPA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>98h</td>
<td>Capture Control B Register (SM1CAPTCTRLB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## PWM register descriptions

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>9Ah</td>
<td>Capture Compare B Register (SM1CAPTCOMPB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>9Ch</td>
<td>Capture Control X Register (SM1CAPTCTRLX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>9Eh</td>
<td>Capture Compare X Register (SM1CAPTCOMPX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>A0h</td>
<td>Capture Value 0 Register (SM1CVAL0)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>A2h</td>
<td>Capture Value 0 Cycle Register (SM1CVAL0CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>A4h</td>
<td>Capture Value 1 Register (SM1CVAL1)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>A6h</td>
<td>Capture Value 1 Cycle Register (SM1CVAL1CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>A8h</td>
<td>Capture Value 2 Register (SM1CVAL2)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>AAh</td>
<td>Capture Value 2 Cycle Register (SM1CVAL2CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>ACh</td>
<td>Capture Value 3 Register (SM1CVAL3)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>AEh</td>
<td>Capture Value 3 Cycle Register (SM1CVAL3CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>B0h</td>
<td>Capture Value 4 Register (SM1CVAL4)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>B2h</td>
<td>Capture Value 4 Cycle Register (SM1CVAL4CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>B4h</td>
<td>Capture Value 5 Register (SM1CVAL5)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>B6h</td>
<td>Capture Value 5 Cycle Register (SM1CVAL5CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>C0h</td>
<td>Counter Register (SM2CNT)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>C2h</td>
<td>Initial Count Register (SM2INIT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>C4h</td>
<td>Control 2 Register (SM2CTRL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>C6h</td>
<td>Control Register (SM2CTRL)</td>
<td>16</td>
<td>RW</td>
<td>0400h</td>
</tr>
<tr>
<td>CAh</td>
<td>Value Register 0 (SM2VAL0)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>CCh</td>
<td>Fractional Value Register 1 (SM2FRACVAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>CEh</td>
<td>Value Register 1 (SM2VAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>D0h</td>
<td>Fractional Value Register 2 (SM2FRACVAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>D2h</td>
<td>Value Register 2 (SM2VAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>D4h</td>
<td>Fractional Value Register 3 (SM2FRACVAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>D6h</td>
<td>Value Register 3 (SM2VAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>D8h</td>
<td>Fractional Value Register 4 (SM2FRACVAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>DAh</td>
<td>Value Register 4 (SM2VAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>DCh</td>
<td>Fractional Value Register 5 (SM2FRACVAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>DEh</td>
<td>Value Register 5 (SM2VAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>E0h</td>
<td>Fractional Control Register (SM2FRCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>E2h</td>
<td>Output Control Register (SM2OCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>E4h</td>
<td>Status Register (SM2STS)</td>
<td>16</td>
<td>W1C</td>
<td>0000h</td>
</tr>
<tr>
<td>E6h</td>
<td>Interrupt Enable Register (SM2INTEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>E8h</td>
<td>DMA Enable Register (SM2DMAEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>EAh</td>
<td>Output Trigger Control Register (SM2TCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>ECh</td>
<td>Fault Disable Mapping Register 0 (SM2DISMAP0)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
<tr>
<td>EEh</td>
<td>Fault Disable Mapping Register 1 (SM2DISMAP1)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
<tr>
<td>F0h</td>
<td>Deadtime Count Register 0 (SM2DTCNT0)</td>
<td>16</td>
<td>RW</td>
<td>07FFh</td>
</tr>
<tr>
<td>F2h</td>
<td>Deadtime Count Register 1 (SM2DTCNT1)</td>
<td>16</td>
<td>RW</td>
<td>07FFh</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>F4h</td>
<td>Capture Control A Register (SM2CAPTCTRLA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>F6h</td>
<td>Capture Compare A Register (SM2CAPTCOMPA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>F8h</td>
<td>Capture Control B Register (SM2CAPTCTRLB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>FAh</td>
<td>Capture Compare B Register (SM2CAPTCOMPB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>FCh</td>
<td>Capture Control X Register (SM2CAPTCTRLX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>FEh</td>
<td>Capture Compare X Register (SM2CAPTCOMPX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>100h</td>
<td>Capture Value 0 Register (SM2CVAL0)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>102h</td>
<td>Capture Value 0 Cycle Register (SM2CVAL0CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>104h</td>
<td>Capture Value 1 Register (SM2CVAL1)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>106h</td>
<td>Capture Value 1 Cycle Register (SM2CVAL1CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>108h</td>
<td>Capture Value 2 Register (SM2CVAL2)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>10Ah</td>
<td>Capture Value 2 Cycle Register (SM2CVAL2CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>10Ch</td>
<td>Capture Value 3 Register (SM2CVAL3)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>10Eh</td>
<td>Capture Value 3 Cycle Register (SM2CVAL3CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>110h</td>
<td>Capture Value 4 Register (SM2CVAL4)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>112h</td>
<td>Capture Value 4 Cycle Register (SM2CVAL4CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>114h</td>
<td>Capture Value 5 Register (SM2CVAL5)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>116h</td>
<td>Capture Value 5 Cycle Register (SM2CVAL5CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>120h</td>
<td>Counter Register (SM3CNT)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>122h</td>
<td>Initial Count Register (SM3INIT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>124h</td>
<td>Control 2 Register (SM3CTRL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>126h</td>
<td>Control Register (SM3CTRL)</td>
<td>16</td>
<td>RW</td>
<td>0400h</td>
</tr>
<tr>
<td>12Ah</td>
<td>Value Register 0 (SM3VAL0)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>12Ch</td>
<td>Fractional Value Register 1 (SM3FRACVAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>12Eh</td>
<td>Value Register 1 (SM3VAL1)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>130h</td>
<td>Fractional Value Register 2 (SM3FRACVAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>132h</td>
<td>Value Register 2 (SM3VAL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>134h</td>
<td>Fractional Value Register 3 (SM3FRACVAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>136h</td>
<td>Value Register 3 (SM3VAL3)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>138h</td>
<td>Fractional Value Register 4 (SM3FRACVAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>13Ah</td>
<td>Value Register 4 (SM3VAL4)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>13Ch</td>
<td>Fractional Value Register 5 (SM3FRACVAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>13Eh</td>
<td>Value Register 5 (SM3VAL5)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>140h</td>
<td>Fractional Control Register (SM3FRCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>142h</td>
<td>Output Control Register (SM3OCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>144h</td>
<td>Status Register (SM3STS)</td>
<td>16</td>
<td>W1C</td>
<td>0000h</td>
</tr>
<tr>
<td>146h</td>
<td>Interrupt Enable Register (SM3INTEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>148h</td>
<td>DMA Enable Register (SM3DMAEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>14Ah</td>
<td>Output Trigger Control Register (SM3TCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>14Ch</td>
<td>Fault Disable Mapping Register 0 (SM3DISMAP0)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## PWM register descriptions

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>14Eh</td>
<td>Fault Disable Mapping Register 1 (SM3DISMAP1)</td>
<td>16</td>
<td>RW</td>
<td>FFFFh</td>
</tr>
<tr>
<td>150h</td>
<td>Deadtime Count Register 0 (SM3DTCNT0)</td>
<td>16</td>
<td>RW</td>
<td>07FFh</td>
</tr>
<tr>
<td>152h</td>
<td>Deadtime Count Register 1 (SM3DTCNT1)</td>
<td>16</td>
<td>RW</td>
<td>07FFh</td>
</tr>
<tr>
<td>154h</td>
<td>Capture Control A Register (SM3CAPCTRLA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>156h</td>
<td>Capture Compare A Register (SM3CAPCOMPA)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>158h</td>
<td>Capture Control B Register (SM3CAPCTRLB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>15Ah</td>
<td>Capture Compare B Register (SM3CAPCOMPB)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>15Ch</td>
<td>Capture Control X Register (SM3CAPCTRLX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>15Eh</td>
<td>Capture Compare X Register (SM3CAPCOMPX)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>160h</td>
<td>Capture Value 0 Register (SM3CVAL0)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>162h</td>
<td>Capture Value 0 Cycle Register (SM3CVAL0CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>164h</td>
<td>Capture Value 1 Register (SM3CVAL1)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>166h</td>
<td>Capture Value 1 Cycle Register (SM3CVAL1CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>168h</td>
<td>Capture Value 2 Register (SM3CVAL2)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>16Ah</td>
<td>Capture Value 2 Cycle Register (SM3CVAL2CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>16Ch</td>
<td>Capture Value 3 Register (SM3CVAL3)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>16Eh</td>
<td>Capture Value 3 Cycle Register (SM3CVAL3CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>170h</td>
<td>Capture Value 4 Register (SM3CVAL4)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>172h</td>
<td>Capture Value 4 Cycle Register (SM3CVAL4CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>174h</td>
<td>Capture Value 5 Register (SM3CVAL5)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>176h</td>
<td>Capture Value 5 Cycle Register (SM3CVAL5CYC)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>180h</td>
<td>Output Enable Register (OUTEN)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>182h</td>
<td>Mask Register (MASK)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>184h</td>
<td>Software Controlled Output Register (SWCOUT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>186h</td>
<td>PWM Source Select Register (DTSRCSEL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>188h</td>
<td>Master Control Register (MCTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>18Ah</td>
<td>Master Control 2 Register (MCTRL2)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>18Ch</td>
<td>Fault Control Register (FCTRLR)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>18Eh</td>
<td>Fault Status Register (FSTS0)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>190h</td>
<td>Fault Filter Register (FFILTF)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>192h</td>
<td>Fault Test Register (FTST0)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>194h</td>
<td>Fault Control 2 Register (FCTRL20)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
</tbody>
</table>

### 55.8.2 Counter Register (SM0CNT - SM3CNT)
### 55.8.2.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCNT</td>
<td>0h + (a × 60h)</td>
</tr>
</tbody>
</table>

### 55.8.2.2 Function

This read-only register displays the state of the signed 16-bit submodule counter. This register is not byte accessible.

### 55.8.2.3 Diagram

![Diagram](image)

### 55.8.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Counter Register Bits</td>
</tr>
<tr>
<td>CNT</td>
<td></td>
</tr>
</tbody>
</table>

### 55.8.3 Initial Count Register (SM0INIT - SM3INIT)

#### 55.8.3.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaINIT</td>
<td>2h + (a × 60h)</td>
</tr>
</tbody>
</table>
55.8.3.2  Function

The 16-bit signed value in this buffered, read/write register defines the initial count value for the PWM in PWM clock periods. This is the value loaded into the submodule counter when local sync, master sync, or master reload is asserted (based on the value of CTRL2[INIT_SEL]) or when CTRL2[FORCE] is asserted and force init is enabled. For PWM operation, the buffered contents of this register are loaded into the counter at the start of every PWM cycle. This register is not byte accessible.

**NOTE**

The INIT register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. This register cannot be written when MCTRL[LDOK] is set. Reading INIT reads the value in a buffer and not necessarily the value the PWM generator is currently using.

55.8.3.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.3.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Initial Count Register Bits</td>
</tr>
<tr>
<td>INIT</td>
<td></td>
</tr>
</tbody>
</table>

55.8.4  Control 2 Register (SM0CTRL2 - SM3CTRL2)
55.8.4.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCTRL2</td>
<td>4h + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.4.2 Diagram

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W    | DBGE | WAITEN | INDEP | PWM23_INIT | PWM45_INIT | PWMX_INIT | INIT_SE | FRCE | FORC | FORCE_SE | RELOAD_SE | CLK_SE |    |    |    |
| Reset| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

55.8.4.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 DBGEN</td>
<td>Debug Enable</td>
</tr>
<tr>
<td></td>
<td>When set to one, the PWM will continue to run while the chip is in debug mode. If the device enters debug mode and this bit is zero, then the PWM outputs will be disabled until debug mode is exited. At that point the PWM pins will resume operation as programmed in the PWM registers.</td>
</tr>
<tr>
<td></td>
<td>For certain types of motors (such as 3-phase AC), it is imperative that this bit be left in its default state (in which the PWM is disabled in debug mode). Failure to do so could result in damage to the motor or inverter. For other types of motors (example: DC motors), this bit might safely be set to one, enabling the PWM in debug mode. The key point is PWM parameter updates will not occur in debug mode. Any motors requiring such updates should be disabled during debug mode. If in doubt, leave this bit set to zero.</td>
</tr>
<tr>
<td>14 WAITEN</td>
<td>WAIT Enable</td>
</tr>
<tr>
<td></td>
<td>When set to one, the PWM will continue to run while the chip is in WAIT mode. In this mode, the peripheral clock continues to run but the CPU clock does not. If the device enters WAIT mode and this bit is zero, then the PWM outputs will be disabled until WAIT mode is exited. At that point the PWM pins will resume operation as programmed in the PWM registers.</td>
</tr>
<tr>
<td></td>
<td>For certain types of motors (such as 3-phase AC), it is imperative that this bit be left in its default state (in which the PWM is disabled in WAIT mode). Failure to do so could result in damage to the motor or inverter. For other types of motors (example: DC motors), this bit might safely be set to one, enabling the PWM in WAIT mode. The key point is PWM parameter updates will not occur in this mode. Any motors requiring such updates should be disabled during WAIT mode. If in doubt, leave this bit set to zero.</td>
</tr>
<tr>
<td>13 INDEP</td>
<td>Independent or Complementary Pair Operation</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field: Function

This bit determines if the PWM_A and PWM_B channels will be independent PWMs or a complementary PWM pair.

- 0b - PWM_A and PWM_B form a complementary PWM pair.
- 1b - PWM_A and PWM_B outputs are independent PWMs.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>12</td>
<td>PWM23 Initial Value</td>
</tr>
<tr>
<td>11</td>
<td>PWM45 Initial Value</td>
</tr>
<tr>
<td>10</td>
<td>PWM_X Initial Value</td>
</tr>
<tr>
<td>9-8</td>
<td>Initialization Control Select</td>
</tr>
<tr>
<td>7</td>
<td>FRCEN</td>
</tr>
<tr>
<td>6</td>
<td>FORCE</td>
</tr>
<tr>
<td>5-3</td>
<td>FORCE_SEL</td>
</tr>
<tr>
<td>2</td>
<td>RELOAD_SEL</td>
</tr>
</tbody>
</table>

#### PWMM23_INIT

This read/write bit determines the initial value for PWM23 and the value to which it is forced when FORCE_INIT is asserted.

#### PWMM45_INIT

This read/write bit determines the initial value for PWM45 and the value to which it is forced when FORCE_INIT is asserted.

#### PWMM_X_INIT

This read/write bit determines the initial value for PWM_X and the value to which it is forced when FORCE_INIT is asserted.

#### INIT_SEL

These read/write bits control the source of the INIT signal which goes to the counter.

- 00b - Local sync (PWM_X) causes initialization.
- 01b - Master reload from submodule 0 causes initialization. This setting should not be used in submodule 0 as it will force the INIT signal to logic 0. The submodule counter will only reinitialize when a master reload occurs.
- 10b - Master sync from submodule 0 causes initialization. This setting should not be used in submodule 0 as it will force the INIT signal to logic 0.
- 11b - EXT_SYNC causes initialization.

#### FRCEN

This bit allows the CTRL2[FORCE] signal to initialize the counter without regard to the signal selected by CTRL2[INIT_SEL]. This is a software controlled initialization. A forced initialization will also assert the local reload if MCTRL[LDOK] is set.

- 0b - Initialization from a FORCE_OUT is disabled.
- 1b - Initialization from a FORCE_OUT is enabled.

#### FORCE

If CTRL2[FORCE_SEL] is set to 000, writing a 1 to this bit results in a FORCE_OUT event. This causes the following actions to be taken:

- The PWM_A and PWM_B output pins will assume values based on DTSRCSEL[SMxSEL23] and DTSRCSEL[SMxSEL45].
- If CTRL2[FRCEN] is set, the counter value will be initialized with the INIT register value.

#### FORCE_SEL

This read/write bit determines the source of the FORCE OUTPUT signal for this submodule.

- 000b - The local force signal, CTRL2[FORCE], from this submodule is used to force updates.
- 001b - The master force signal from submodule 0 is used to force updates. This setting should not be used in submodule 0 as it will hold the FORCE OUTPUT signal to logic 0.
- 010b - The local reload signal from this submodule is used to force updates without regard to the state of LDOK.
- 011b - The master reload signal from submodule0 is used to force updates if LDOK is set. This setting should not be used in submodule0 as it will hold the FORCE OUTPUT signal to logic 0.
- 100b - The local sync signal from this submodule is used to force updates.
- 101b - The master sync signal from submodule0 is used to force updates. This setting should not be used in submodule0 as it will hold the FORCE OUTPUT signal to logic 0.
- 110b - The external force signal, EXT_FORCE, from outside the PWM module causes updates.
- 111b - The external sync signal, EXT_SYNC, from outside the PWM module causes updates.

#### RELOAD_SEL

This read/write bit determines the source of the RELOAD signal for this submodule. When this bit is set, MCTRL[LDOK[0]] for submodule 0 should be used since the local MCTRL[LDOK] will be ignored.

---

*Table continues on the next page...*
### Chapter 55 Enhanced Flex Pulse Width Modulator (eFlexPWM)

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>The local RELOAD signal is used to reload registers.</td>
</tr>
<tr>
<td>1b</td>
<td>The master RELOAD signal (from submodule 0) is used to reload registers. This setting should not be used in submodule 0 as it will force the RELOAD signal to logic 0.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-0</td>
<td>Clock Source Select</td>
</tr>
<tr>
<td>CLK_SEL</td>
<td>These read/write bits determine the source of the clock signal for this submodule. 00b - The IPBus clock is used as the clock for the local prescaler and counter. 01b - EXT_CLK is used as the clock for the local prescaler and counter. 10b - Submodule 0’s clock (AUX_CLK) is used as the source clock for the local prescaler and counter. This setting should not be used in submodule 0 as it will force the clock to logic 0. 11b - reserved</td>
</tr>
</tbody>
</table>

---

### 55.8.5 Control Register (SM0CTRL - SM3CTRL)

#### 55.8.5.1 Offset

For $a = 0$ to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCTRL</td>
<td>$6h + (a \times 60h)$</td>
</tr>
</tbody>
</table>

#### 55.8.5.2 Diagram

![Diagram of Control Register](image)

#### 55.8.5.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>Load Frequency</td>
</tr>
<tr>
<td>LDFQ</td>
<td>These buffered read/write bits select the PWM load frequency. Reset clears LDFQ, selecting loading every PWM opportunity. A PWM opportunity is determined by HALF and FULL.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### PWM register descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>NOTE:</strong></td>
<td>LDFQ takes effect when the current load cycle is complete, regardless of the state of MCTRL[LDOK]. Reading LDFQ reads the buffered values and not necessarily the values currently in effect.</td>
</tr>
</tbody>
</table>
| | 0000b - Every PWM opportunity  
 | 0001b - Every 2 PWM opportunities  
 | 0010b - Every 3 PWM opportunities  
 | 0011b - Every 4 PWM opportunities  
 | 0100b - Every 5 PWM opportunities  
 | 0101b - Every 6 PWM opportunities  
 | 0110b - Every 7 PWM opportunities  
 | 0111b - Every 8 PWM opportunities  
 | 1000b - Every 9 PWM opportunities  
 | 1001b - Every 10 PWM opportunities  
 | 1010b - Every 11 PWM opportunities  
 | 1011b - Every 12 PWM opportunities  
 | 1100b - Every 13 PWM opportunities  
 | 1101b - Every 14 PWM opportunities  
 | 1110b - Every 15 PWM opportunities  
 | 1111b - Every 16 PWM opportunities  |
| 11 | Half Cycle Reload  
 | This read/write bit enables half-cycle reloads. A half cycle is defined by when the submodule counter matches the VAL0 register and does not have to be half way through the PWM cycle.  
 | 0b - Half-cycle reloads disabled.  
 | 1b - Half-cycle reloads enabled.  |
| 10 | Full Cycle Reload  
 | This read/write bit enables full-cycle reloads. A full cycle is defined by when the submodule counter matches the VAL1 register. Either CTRL[HALF] or CTRL[FULL] must be set in order to move the buffered data into the registers used by the PWM generators or CTRL[LDMOD] must be set. If both CTRL[HALF] and CTRL[FULL] are set, then reloads can occur twice per cycle.  
 | 0b - Full-cycle reloads disabled.  
 | 1b - Full-cycle reloads enabled.  |
| 9-8 | Deadtime  
 | These read only bits reflect the sampled values of the PWM_X input at the end of each deadtime. Sampling occurs at the end of deadtime 0 for DT[0] and the end of deadtime 1 for DT[1]. Reset clears these bits.  |
| 7 | Compare Mode  
 | This bit controls how comparisons are made between the VAL* registers and the PWM submodule counter. This bit can only be written one time after which it requires a reset to release the bit for writing again.  
 | 0b - The VAL* registers and the PWM counter are compared using an "equal to" method. This means that PWM edges are only produced when the counter is equal to one of the VAL* register values. This implies that a PWMA output that is high at the end of a period will maintain this state until a match with VAL3 clears the output in the following period.  
 | 1b - The VAL* registers and the PWM counter are compared using an "equal to or greater than" method. This means that PWM edges are produced when the counter is equal to or greater than one of the VAL* register values. This implies that a PWMA output that is high at the end of a period could go low at the start of the next period if the starting counter value is greater than (but not necessarily equal to) the new VAL3 value.  |
| 6-4 | Prescaler  
 | These buffered read/write bits select the divide ratio of the PWM clock frequency selected by CTRL2[CLK_SEL].  |

*Table continues on the next page...*
### Field Function

**NOTE:** Reading CTRL[PRSC] reads the buffered values and not necessarily the values currently in effect. CTRL[PRSC] takes effect at the beginning of the next PWM cycle and only when the load okay bit, MCTRL[LDOK], is set or CTRL[LDMOD] is set. This field cannot be written when MCTRL[LDOK] is set.

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>000b</td>
<td>PWM clock frequency = $f_{clk}$</td>
</tr>
<tr>
<td>001b</td>
<td>PWM clock frequency = $f_{clk}/2$</td>
</tr>
<tr>
<td>010b</td>
<td>PWM clock frequency = $f_{clk}/4$</td>
</tr>
<tr>
<td>011b</td>
<td>PWM clock frequency = $f_{clk}/8$</td>
</tr>
<tr>
<td>100b</td>
<td>PWM clock frequency = $f_{clk}/16$</td>
</tr>
<tr>
<td>101b</td>
<td>PWM clock frequency = $f_{clk}/32$</td>
</tr>
<tr>
<td>110b</td>
<td>PWM clock frequency = $f_{clk}/64$</td>
</tr>
<tr>
<td>111b</td>
<td>PWM clock frequency = $f_{clk}/128$</td>
</tr>
</tbody>
</table>

#### 3 SPLIT
Split the DBLPWM signal to PWMA and PWMB

This read/write bit is only used when DBLEN is set. This bit allows the two PWM pulses generated by DBLEN to be split with one pulse on PWMA and one on PWMB. The two pulses within the same PWM period are created by an XOR function of the PWMA and PWMB sources. The splitting function causes PWMA to output the pulse that occurs when the PWMA source is 1 and the PWMB source is 0. The PWMB output occurs when the PWMB source is 1 and the PWMA source is 0. (See Double Switching PWMs.)

- 0b - DBLPWM is not split. PWMA and PWMB each have double pulses.
- 1b - DBLPWM is split to PWMA and PWMB.

#### 2 LDMOD
Load Mode Select

This read/write bit selects the timing of loading the buffered registers for this submodule.

- 0b - Buffered registers of this submodule are loaded and take effect at the next PWM reload if MCTRL[LDOK] is set.
- 1b - Buffered registers of this submodule are loaded and take effect immediately upon MCTRL[LDOK] being set. In this case it is not necessary to set CTRL[FULL] or CTRL[HALF].

#### 1 DBLX
PWMX Double Switching Enable

This read/write bit enables the double switching behavior on PWMX. When this bit is set, the PWMX output shall be the exclusive OR combination of PWMA and PWMB prior to polarity and masking considerations.

- 0b - PWMX double pulse disabled.
- 1b - PWMX double pulse enabled.

#### 0 DBLEN
Double Switching Enable

This read/write bit enables the double switching PWM behavior. (See Double Switching PWMs). Double switching is not compatible with fractional PWM clock generation. Make sure this bit is clear when setting FRCTRL[FRAC23_EN], FRCTRL[FRAC45_EN], or FRCTRL[FRAC1_EN].

- 0b - Double switching disabled.
- 1b - Double switching enabled.

### 55.8.6 Value Register 0 (SM0VAL0 - SM3VAL0)

#### 55.8.6.1 Offset

For $a = 0$ to $3$:
### 55.8.6.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>VAL0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 55.8.6.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Value Register 0</td>
</tr>
</tbody>
</table>
| VAL0  | The 16-bit signed value in this buffered, read/write register defines the mid-cycle reload point for the PWM in PWM clock periods. This value also defines when the PWM_X signal is set and the local sync signal is reset. This register is not byte accessible.  
NOTE: The VAL0 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL0 cannot be written when MCTRL[LDOK] is set. Reading VAL0 reads the value in a buffer. It is not necessarily the value the PWM generator is currently using. |

### 55.8.7 Fractional Value Register 1 (SM0FRACVAL1 - SM3FRACVAL1)

#### 55.8.7.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaFRACVAL1</td>
<td>Ch + (a × 60h)</td>
</tr>
</tbody>
</table>
55.8.7.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>FRACVAL1</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.7.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-11</td>
<td>FRACVAL1</td>
</tr>
<tr>
<td>FRACVAL1</td>
<td>Fractional Value 1 Register</td>
</tr>
<tr>
<td></td>
<td>These bits act as a fractional addition to the value in the VAL1 register which controls the PWM period width. The PWM period is computed in terms of IPBus clock cycles. This fractional portion is accumulated at the end of every cycle until an additional whole IPBus cycle is reached. At this time the value being used for VAL1 is temporarily incremented and the PWM cycle is extended by one clock period to compensate for the accumulated fractional values.</td>
</tr>
<tr>
<td></td>
<td>NOTE: The FRACVAL1 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. FRACVAL1 cannot be written when MCTRL[LDOK] is set. Reading FRACVAL1 reads the value in a buffer and not necessarily the value the PWM generator is currently using.</td>
</tr>
<tr>
<td>10-0</td>
<td>RESERVED</td>
</tr>
</tbody>
</table>

55.8.8  Value Register 1 (SM0VAL1 - SM3VAL1)

55.8.8.1  Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaVAL1</td>
<td>Eh + (a × 60h)</td>
</tr>
</tbody>
</table>
55.8.8.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>VAL1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.8.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Value Register 1</td>
</tr>
</tbody>
</table>
| VAL1  | The 16-bit signed value written to this buffered, read/write register defines the modulo count value (maximum count) for the submodule counter. Upon reaching this count value, the counter reloads itself with the contents of the INIT register and asserts the local sync signal while resetting PWM_X. This register is not byte accessible.  

**NOTE:** The VAL1 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL1 cannot be written when MCTRL[LDOK] is set. Reading VAL1 reads the value in a buffer. It is not necessarily the value the PWM generator is currently using.  

**NOTE:** When using FRACVAL1, limit the maximum value of VAL1 to 0xFFFE for unsigned applications or to 0x7FFE for signed applications, to avoid counter rollovers caused by accumulating the fractional period defined by FRACVAL1.  

**NOTE:** If the VAL1 register defines the timer period (Local Sync is selected as the counter initialization signal), a 100% duty cycle cannot be achieved on the PWMX output. After the count reaches VAL1, the PWMX output is low for a minimum of one count every cycle. When the Master Sync signal (only originated by the Local Sync from sub-module 0) is used to control the timer period, the VAL1 register can be free for other functions such as PWM generation without the duty cycle limitation.

55.8.9 Fractional Value Register 2 (SM0FRACVAL2 - SM3FRACVAL2)

55.8.9.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaFRACVAL2</td>
<td>10h + (a × 60h)</td>
</tr>
</tbody>
</table>
**55.8.9.2  Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>FRACVAL2</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**55.8.9.3  Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-11</td>
<td>Fractional Value 2</td>
</tr>
<tr>
<td>FRACVAL2</td>
<td>These bits act as a fractional addition to the value in the VAL2 register which controls the PWM_A turn on timing. It is also used to control the fractional addition to the turn off delay of PWM_B when MCTRL[IPOLx]=0 in complementary mode, CTRL2[INDEP]=0.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>The FRACVAL2 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. FRACVAL2 cannot be written when MCTRL[LDOK] is set. Reading FRACVAL2 reads the value in a buffer and not necessarily the value the PWM generator is currently using.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>FRCTRL[FRAC23_EN] should be set to 0 when the values of VAL2 and VAL3 cause the high or low time of the PWM output to be 3 cycles or less.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>10-0</td>
<td>RESERVED</td>
</tr>
</tbody>
</table>

**55.8.10  Value Register 2 (SM0VAL2 - SM3VAL2)**

**55.8.10.1  Offset**

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaVAL2</td>
<td>12h + (a × 60h)</td>
</tr>
</tbody>
</table>
### 55.8.10.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>VAL2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 55.8.10.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Value Register 2</td>
</tr>
</tbody>
</table>
| VAL2  | The 16-bit signed value in this buffered, read/write register defines the count value to set PWM23 high. This register is not byte accessible. **NOTE:** The VAL2 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL2 cannot be written when MCTRL[LDOK] is set. Reading VAL2 reads the value in a buffer and not necessarily the value the PWM generator is currently using.

### 55.8.11 Fractional Value Register 3 (SM0FRACVAL3 - SM3FRACVAL3)

#### 55.8.11.1 Offset

For \( a = 0 \) to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaFRACVAL3</td>
<td>( 14h + (a \times 60h) )</td>
</tr>
</tbody>
</table>

#### 55.8.11.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FRACVAL3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
55.8.11.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-11</td>
<td>Fractional Value 3</td>
</tr>
<tr>
<td>FRACVAL3</td>
<td>These bits act as a fractional addition to the value in the VAL3 register which controls the PWM_A turn off timing. It is also used to control the fractional addition to the turn on delay of PWM_B when MCTRL[IPOLx]=0 in complementary mode, CTRL2[INDEP]=0.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> The FRACVAL3 register is buffered. The value written does not take effect until MCTRL[LDO] is set and the next PWM load cycle begins or CTRL[LDMD] is set. FRACVAL3 cannot be written when MCTRL[LDO] is set. Reading FRACVAL3 reads the value in a buffer and not necessarily the value the PWM generator is currently using.</td>
</tr>
<tr>
<td>10-0</td>
<td>RESERVED</td>
</tr>
</tbody>
</table>

55.8.12 Value Register 3 (SM0VAL3 - SM3VAL3)

55.8.12.1 Offset

For \( a = 0 \) to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaVAL3</td>
<td>16h + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.12.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>VAL3</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```
### 55.8.12.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Value Register 3</td>
</tr>
<tr>
<td>VAL3</td>
<td>The 16-bit signed value in this buffered, read/write register defines the count value to set PWM23 low. This register is not byte accessible.</td>
</tr>
</tbody>
</table>

**NOTE:** The VAL3 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL3 cannot be written when MCTRL[LDOK] is set. Reading VAL3 reads the value in a buffer and not necessarily the value the PWM generator is currently using.

### 55.8.13 Fractional Value Register 4 (SM0FRACVAL4 - SM3FRACVAL4)

#### 55.8.13.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaFRACVAL4</td>
<td>18h + (a × 60h)</td>
</tr>
</tbody>
</table>

#### 55.8.13.2 Diagram

```
Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     | | | | | | | | | | | | | | | | FRACVAL4
W     | | | | | | | | | | | | | | | 0
Reset | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0
```

#### 55.8.13.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-11</td>
<td>Fractional Value 4</td>
</tr>
<tr>
<td>FRACVAL4</td>
<td>These bits act as a fractional addition to the value in the VAL4 register which controls the PWM_B turn on timing. It is also used to control the fractional addition to the turn off delay of PWM_A when MCTRL[IPOLx]=1 in complementary mode, CTRL2[INDEP]=0.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>NOTE:</td>
<td>The FRACVAL4 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. FRACVAL4 cannot be written when MCTRL[LDOK] is set. FRACVAL4 cannot be written when MCTRL[LDOK] is set. Reading FRACVAL4 reads the value in a buffer and not necessarily the value the PWM generator is currently using.</td>
</tr>
<tr>
<td>10-0</td>
<td>RESERVED</td>
</tr>
</tbody>
</table>

### 55.8.14 Value Register 4 (SM0VAL4 - SM3VAL4)

#### 55.8.14.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaVAL4</td>
<td>1Ah + (a × 60h)</td>
</tr>
</tbody>
</table>

#### 55.8.14.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>15</td>
<td>14</td>
<td>13</td>
<td>12</td>
<td>11</td>
<td>10</td>
<td>9</td>
<td>8</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
</tr>
<tr>
<td><strong>R</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>W</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

|      |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

#### 55.8.14.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Value Register 4</td>
</tr>
<tr>
<td>VAL4</td>
<td>The 16-bit signed value in this buffered, read/write register defines the count value to set PWM45 high. This register is not byte accessible.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>The VAL4 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL4 cannot be written when MCTRL[LDOK] is set. Reading VAL4 reads the value in a buffer and not necessarily the value the PWM generator is currently using.</td>
</tr>
</tbody>
</table>
55.8.15 Fractional Value Register 5 (SM0FRACVAL5 - SM3FRACVAL5)

55.8.15.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaFRACVAL5</td>
<td>1Ch + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.15.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

55.8.15.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-11 FRACVAL5</td>
<td>Fractional Value 5</td>
</tr>
<tr>
<td></td>
<td>These bits act as a fractional addition to the value in the VAL5 register which controls the PWM_B turn off timing. It is also used to control the fractional addition to the turn on delay of PWM_A when MCTRL[IPOL]=1 in complementary mode, CTRL2[INDEP]=0.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> The FRACVAL5 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. FRACVAL5 cannot be written when MCTRL[LDOK] is set. Reading FRACVAL5 reads the value in a buffer and not necessarily the value the PWM generator is currently using.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> FRCTRL[FRAC45_EN] should be set to 0 when the values of VAL4 and VAL5 cause the high or low time of the PWM output to be 3 cycles or less.</td>
</tr>
<tr>
<td>10-0</td>
<td>RESERVED</td>
</tr>
</tbody>
</table>
55.8.16  Value Register 5 (SM0VAL5 - SM3VAL5)

55.8.16.1  Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaVAL5</td>
<td>1Eh + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.16.2  Diagram

55.8.16.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>Value Register 5</td>
</tr>
</tbody>
</table>
| VAL5  | The 16-bit signed value in this buffered, read/write register defines the count value to set PWM45 low. This register is not byte accessible.  
**NOTE:** The VAL5 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL5 cannot be written when MCTRL[LDOK] is set. Reading VAL5 reads the value in a buffer and not necessarily the value the PWM generator is currently using. |

55.8.17  Fractional Control Register (SM0FRCTRL - SM3FRCTRL)

55.8.17.1  Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaFRCTRL</td>
<td>20h + (a × 60h)</td>
</tr>
</tbody>
</table>
55.8.17.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>TES</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>FRAC_PU</td>
<td>0</td>
<td>FRAC_PU</td>
<td>0</td>
<td>FRAC_PU</td>
<td>0</td>
<td>FRAC_PU</td>
<td>0</td>
<td>FRAC_PU</td>
<td>0</td>
<td>FRAC_PU</td>
<td>0</td>
<td>FRAC_PU</td>
<td>0</td>
<td>FRAC_PU</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.17.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Test Status Bit</td>
</tr>
<tr>
<td>TEST</td>
<td>This is a read only test bit for factory use. This bit will reset to 0 but may be either 0 or 1 during PWM operation.</td>
</tr>
<tr>
<td>14-9</td>
<td>RESERVED</td>
</tr>
<tr>
<td>8</td>
<td>Fractional Delay Circuit Power Up</td>
</tr>
<tr>
<td>FRAC_PU</td>
<td>This bit is used to power up the fractional delay analog block. The fractional delay block takes 25 us to power up after the first FRAC_PU bit in any submodule is set. The fractional delay block only powers down when the FRAC_PU bits in all submodules are 0. The fractional delay logic can only be used when the IPBus clock is running at 100 MHz. When turned off, fractional placement is disabled. After setting this bit and waiting the 25ussec, load the PWM VAL* registers with values to create a PWM output with greater than 0% duty cycle and run for at least one PWM period. This can be done without the outputs enabled and is used to clear the state of the analog block that produces the fractional delays.</td>
</tr>
<tr>
<td>7-5</td>
<td>RESERVED</td>
</tr>
<tr>
<td>4</td>
<td>Fractional Cycle Placement Enable for PWM_B</td>
</tr>
<tr>
<td>FRAC45_EN</td>
<td>This bit is used to enable the fractional cycle edge placement of PWM_B using the FRACVAL4 and FRACVAL5 registers. When disabled, the fractional cycle edge placement of PWM_B is bypassed.</td>
</tr>
<tr>
<td>NOTE:</td>
<td>The FRAC45_EN bit is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. FRAC45_EN cannot be written when MCTRL[LDOK] is set. Reading FRAC45_EN reads the value in a buffer and not necessarily the value the PWM generator is currently using.</td>
</tr>
<tr>
<td>3</td>
<td>RESERVED</td>
</tr>
<tr>
<td>2</td>
<td>Fractional Cycle Placement Enable for PWM_A</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 55.8.18 Output Control Register (SM0OCTRL - SM3OCTRL)

#### 55.8.18.1 Offset

For $a = 0$ to $3$:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaOCTRL</td>
<td>$22h + (a \times 60h)$</td>
</tr>
</tbody>
</table>

#### 55.8.18.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>PWMA_IN</td>
<td>PWMB_IN</td>
<td>PWMX_IN</td>
<td>0</td>
<td>POLA</td>
<td>POLB</td>
<td>POLX</td>
<td>0</td>
<td>PWMAFS</td>
<td>PWMBFS</td>
<td>PWMXFS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### 55.8.18.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15 | PWMA_IN | PWM_A Input  
This read only bit shows the logic value currently being driven into the PWM_A input. The bit's reset state is undefined. |
| 14 | PWMB_IN | PWM_B Input  
This read only bit shows the logic value currently being driven into the PWM_B input. The bit's reset state is undefined. |
| 13 | PWMX_IN | PWM_X Input  
This read only bit shows the logic value currently being driven into the PWM_X input. The bit's reset state is undefined. |
| 12-11 | | RESERVED |
| 10 | POLA | PWM_A Output Polarity  
This bit inverts the PWM_A output polarity.  
0b - PWM_A output not inverted. A high level on the PWM_A pin represents the "on" or "active" state.  
1b - PWM_A output inverted. A low level on the PWM_A pin represents the "on" or "active" state. |
| 9 | POLB | PWM_B Output Polarity  
This bit inverts the PWM_B output polarity.  
0b - PWM_B output not inverted. A high level on the PWM_B pin represents the "on" or "active" state.  
1b - PWM_B output inverted. A low level on the PWM_B pin represents the "on" or "active" state. |
| 8 | POLX | PWM_X Output Polarity  
This bit inverts the PWM_X output polarity.  
0b - PWM_X output not inverted. A high level on the PWM_X pin represents the "on" or "active" state.  
1b - PWM_X output inverted. A low level on the PWM_X pin represents the "on" or "active" state. |
| 7-6 | | RESERVED |
| 5-4 | PWMAFS | PWM_A Fault State  
These bits determine the fault state for the PWM_A output during fault conditions and STOP mode. It may also define the output state during WAIT and DEBUG modes depending on the settings of CTRL2[WAITEN] and CTRL2[DBGEN].  
00b - Output is forced to logic 0 state prior to consideration of output polarity control.  
01b - Output is forced to logic 1 state prior to consideration of output polarity control.  
10b - Output is tristated.  
11b - Output is tristated. |
| 3-2 | PWMBFS | PWM_B Fault State  
These bits determine the fault state for the PWM_B output during fault conditions and STOP mode. It may also define the output state during WAIT and DEBUG modes depending on the settings of CTRL2[WAITEN] and CTRL2[DBGEN].  
00b - Output is forced to logic 0 state prior to consideration of output polarity control.  
01b - Output is forced to logic 1 state prior to consideration of output polarity control. |

*Table continues on the next page...*
### 55.8.19 Status Register (SM0STS - SM3STS)

#### 55.8.19.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaSTS</td>
<td>24h + (a × 60h)</td>
</tr>
</tbody>
</table>

#### 55.8.19.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>RU</td>
<td>F</td>
<td>RE</td>
<td>F</td>
<td>R</td>
<td>F</td>
<td>F</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td>W1C</td>
<td></td>
<td>W1C</td>
<td></td>
<td>W1C</td>
<td></td>
<td>W1C</td>
<td></td>
<td>W1C</td>
<td></td>
<td>W1C</td>
<td></td>
<td>W1C</td>
<td></td>
<td>W1C</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### 55.8.19.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>RESERVED</td>
</tr>
<tr>
<td>14</td>
<td>Registers Updated Flag</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## PWM register descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| RUF   | This read-only flag is set when one of the INIT, VALx, FRACVALx, or CTRL[PRSC] registers has been written, which indicates potentially non-coherent data in the set of double buffered registers. Clear this bit by a proper reload sequence consisting of a reload signal while MCTRL[LDOK] = 1. Reset clears this bit.  
  0b - No register update has occurred since last reload.  
  1b - At least one of the double buffered registers has been updated since the last reload. |
| 13    | Reload Error Flag  
  This read/write flag is set when a reload cycle occurs while MCTRL[LDOK] is 0 and the double buffered registers are in a non-coherent state (STS[RUF] = 1). Clear this bit by writing a logic one to this location. Reset clears this bit.  
  0b - No reload error occurred.  
  1b - Reload signal occurred with non-coherent data and MCTRL[LDOK] = 0. |
| 12    | Reload Flag  
  This read/write flag is set at the beginning of every reload cycle regardless of the state of MCTRL[LDOK]. Clear this bit by writing a logic one to this location when DMAEN[VALDE] is clear (non-DMA mode). This flag can also be cleared by the DMA done signal when DMAEN[VALDE] is set (DMA mode). Reset clears this bit.  
  0b - No new reload cycle since last STS[RF] clearing  
  1b - New reload cycle since last STS[RF] clearing |
| 11    | Capture Flag A1  
  This bit is set when a capture event occurs on the Capture A1 circuit. This bit is cleared by writing a one to this bit position if DMAEN[CA1DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CA1DE] is set (DMA mode). Reset clears this bit. |
| CFA1  |  
  10    | Capture Flag A0  
  This bit is set when a capture event occurs on the Capture A0 circuit. This bit is cleared by writing a one to this bit position if DMAEN[CA0DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CA0DE] is set (DMA mode). Reset clears this bit. |
| CFA0  |  
  9     | Capture Flag B1  
  This bit is set when a capture event occurs on the Capture B1 circuit. This bit is cleared by writing a one to this bit position if DMAEN[CB1DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CB1DE] is set (DMA mode). Reset clears this bit. |
| CFB1  |  
  8     | Capture Flag B0  
  This bit is set when a capture event occurs on the Capture B0 circuit. This bit is cleared by writing a one to this bit position if DMAEN[CB0DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CB0DE] is set (DMA mode). Reset clears this bit. |
| CFB0  |  
  7     | Capture Flag X1  
  This bit is set when a capture event occurs on the Capture X1 circuit. This bit is cleared by writing a one to this bit position if DMAEN[CX1DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CX1DE] is set (DMA mode). Reset clears this bit. |
| CFX1  |  
  6     | Capture Flag X0  
  This bit is set when a capture event occurs on the Capture X0 circuit. This bit is cleared by writing a one to this bit position if DMAEN[CX0DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CX0DE] is set (DMA mode). Reset clears this bit. |
| CFX0  |  
  5-0   | Compare Flags  
  These bits are set when the submodule counter value matches the value of one of the VALx registers. Clear these bits by writing a 1 to a bit position.  
  000000b - No compare event has occurred for a particular VALx value.  
  000001b - A compare event has occurred for a particular VALx value. |

---

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**

NXP Semiconductors
55.8.20  Interrupt Enable Register (SM0INTEN - SM3INTEN)

55.8.20.1  Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaINTEN</td>
<td>26h + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.20.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>R E</th>
<th>R E</th>
<th>CA1E</th>
<th>CA0E</th>
<th>CB1E</th>
<th>CB0E</th>
<th>CX1E</th>
<th>CX0E</th>
<th>CMP1E</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-14</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

55.8.20.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-14</td>
<td>RESERVED</td>
</tr>
<tr>
<td>13</td>
<td>REIE</td>
</tr>
<tr>
<td></td>
<td>Reload Error Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>This read/write bit enables the reload error flag, STS[REF], to generate CPU interrupt requests. Reset clears this bit.</td>
</tr>
<tr>
<td></td>
<td>0b - STS[REF] CPU interrupt requests disabled</td>
</tr>
<tr>
<td></td>
<td>1b - STS[REF] CPU interrupt requests enabled</td>
</tr>
<tr>
<td>12</td>
<td>RIE</td>
</tr>
<tr>
<td></td>
<td>Reload Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>This read/write bit enables the reload flag, STS[RF], to generate CPU interrupt requests. Reset clears this bit.</td>
</tr>
<tr>
<td></td>
<td>0b - STS[RF] CPU interrupt requests disabled</td>
</tr>
<tr>
<td></td>
<td>1b - STS[RF] CPU interrupt requests enabled</td>
</tr>
<tr>
<td>11</td>
<td>CA1IE</td>
</tr>
<tr>
<td></td>
<td>Capture A 1 Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>This bit allows the STS[CFA1] flag to create an interrupt request to the CPU. Do not set both this bit and DMAEN[CA1DE].</td>
</tr>
<tr>
<td></td>
<td>0b - Interrupt request disabled for STS[CFA1].</td>
</tr>
<tr>
<td></td>
<td>1b - Interrupt request enabled for STS[CFA1].</td>
</tr>
</tbody>
</table>
### PWM register descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>Capture A 0 Interrupt Enable</td>
</tr>
<tr>
<td>CA0IE</td>
<td>This bit allows the STS[CFA0] flag to create an interrupt request to the CPU. Do not set both this bit and DMAEN[CA0DE].</td>
</tr>
<tr>
<td></td>
<td>0b - Interrupt request disabled for STS[CFA0].</td>
</tr>
<tr>
<td></td>
<td>1b - Interrupt request enabled for STS[CFA0].</td>
</tr>
<tr>
<td>9</td>
<td>Capture B 1 Interrupt Enable</td>
</tr>
<tr>
<td>CB1IE</td>
<td>This bit allows the STS[CFB1] flag to create an interrupt request to the CPU. Do not set both this bit and DMAEN[CB1DE].</td>
</tr>
<tr>
<td></td>
<td>0b - Interrupt request disabled for STS[CFB1].</td>
</tr>
<tr>
<td></td>
<td>1b - Interrupt request enabled for STS[CFB1].</td>
</tr>
<tr>
<td>8</td>
<td>Capture B 0 Interrupt Enable</td>
</tr>
<tr>
<td>CB0IE</td>
<td>This bit allows the STS[CFB0] flag to create an interrupt request to the CPU. Do not set both this bit and DMAEN[CB0DE].</td>
</tr>
<tr>
<td></td>
<td>0b - Interrupt request disabled for STS[CFB0].</td>
</tr>
<tr>
<td></td>
<td>1b - Interrupt request enabled for STS[CFB0].</td>
</tr>
<tr>
<td>7</td>
<td>Capture X 1 Interrupt Enable</td>
</tr>
<tr>
<td>CX1IE</td>
<td>This bit allows the STS[CFX1] flag to create an interrupt request to the CPU. Do not set both this bit and DMAEN[CX1DE].</td>
</tr>
<tr>
<td></td>
<td>0b - Interrupt request disabled for STS[CFX1].</td>
</tr>
<tr>
<td></td>
<td>1b - Interrupt request enabled for STS[CFX1].</td>
</tr>
<tr>
<td>6</td>
<td>Capture X 0 Interrupt Enable</td>
</tr>
<tr>
<td>CX0IE</td>
<td>This bit allows the STS[CFX0] flag to create an interrupt request to the CPU. Do not set both this bit and DMAEN[CX0DE].</td>
</tr>
<tr>
<td></td>
<td>0b - Interrupt request disabled for STS[CFX0].</td>
</tr>
<tr>
<td></td>
<td>1b - Interrupt request enabled for STS[CFX0].</td>
</tr>
<tr>
<td>5-0</td>
<td>Compare Interrupt Enables</td>
</tr>
<tr>
<td>CMPIE</td>
<td>These bits enable the STS[CMPF] flags to cause a compare interrupt request to the CPU.</td>
</tr>
<tr>
<td></td>
<td>000000b - The corresponding STS[CMPF] bit will not cause an interrupt request.</td>
</tr>
<tr>
<td></td>
<td>000001b - The corresponding STS[CMPF] bit will cause an interrupt request.</td>
</tr>
</tbody>
</table>

### 55.8.21 DMA Enable Register (SM0DMAEN - SM3DMAEN)

#### 55.8.21.1 Offset

For $a = 0$ to $3$:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaDMAEN</td>
<td>$28h + (a \times 60h)$</td>
</tr>
</tbody>
</table>
55.8.21.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.21.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-10</td>
<td>RESERVED</td>
</tr>
<tr>
<td>9</td>
<td><strong>VALDE</strong> Value Registers DMA Enable</td>
</tr>
</tbody>
</table>
|        | This read/write bit enables DMA write requests for the VALx and FRACVALx registers when STS[RF] is set. Reset clears this bit.  
|        | 0b - DMA write requests disabled              |
|        | 1b - DMA write requests for the VALx and FRACVALx registers enabled |
| 8      | **FAND** FIFO Watermark AND Control           |
|        | This read/write bit works in conjunction with the DMAEN[CAPTDE] field when it is set to watermark mode (DMAEN[CAPTDE] = 01). While DMAEN[CAxDE], DMAEN[CBxDE], and DMAEN[CXxDE] determine which FIFO watermarks the DMA read request is sensitive to, this bit determines if the selected watermarks are AND’ed together or OR’ed together in order to create the request.  
|        | 0b - Selected FIFO watermarks are OR’ed together.  
|        | 1b - Selected FIFO watermarks are AND’ed together. |
| 7-6    | **CAPTDE** Capture DMA Enable Source Select   |
|        | These read/write bits select the source of enabling the DMA read requests for the capture FIFOs. Reset clears these bits.  
|        | 00b - Read DMA requests disabled.              |
|        | 01b - Exceeding a FIFO watermark sets the DMA read request. This requires at least one of DMAEN[CA1DE], DMAEN[CA0DE], DMAEN[CB1DE], DMAEN[CB0DE], DMAEN[CX1DE], or DMAEN[CX0DE] to also be set in order to determine to which watermark(s) the DMA request is sensitive.  
|        | 10b - A local sync (VAL1 matches counter) sets the read DMA request.  
|        | 11b - A local reload (STS[RF] being set) sets the read DMA request. |
| 5      | **CA1DE** Capture A1 FIFO DMA Enable           |
|        | This read/write bit enables DMA read requests for the Capture A1 FIFO data when STS[CFA1] is set. Reset clears this bit. Do not set both this bit and INTEN[CA1IE]. |
| 4      | **CA0DE** Capture A0 FIFO DMA Enable           |
|        | This read/write bit enables DMA read requests for the Capture A0 FIFO data when STS[CFA0] is set. Reset clears this bit. Do not set both this bit and INTEN[CA0IE]. |
| 3      | **CB1DE** Capture B1 FIFO DMA Enable           |
|        | This read/write bit enables DMA read requests for the Capture B1 FIFO data when STS[CFB1] is set. Reset clears this bit. Do not set both this bit and INTEN[CB1IE]. |

Table continues on the next page...
### 55.8.22 Output Trigger Control Register (SM0TCTRL - SM3T CTRL)

#### 55.8.22.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaTCTRL</td>
<td>2Ah + (a × 60h)</td>
</tr>
</tbody>
</table>

#### 55.8.22.2 Diagram

![Diagram of Output Trigger Control Register]

#### 55.8.22.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Output Trigger 0 Source Select</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>PWAOT0</td>
<td>This bit selects which signal to bring out on the PWM's PWM_OUT_TRIG0 port. The output trigger port is often connected to routing logic on the chip. This control bit allows the PWMA output signal to be driven onto the output trigger port so it can be sent to the chip routing logic.</td>
</tr>
<tr>
<td>0b - Route the PWM_OUT_TRIG0 signal to PWM_OUT_TRIG0 port.</td>
<td></td>
</tr>
<tr>
<td>1b - Route the PWMA output to the PWM_OUT_TRIG0 port.</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>Output Trigger 1 Source Select</td>
</tr>
<tr>
<td>PWBOT1</td>
<td>This bit selects which signal to bring out on the PWM's PWM_OUT_TRIG1 port. The output trigger port is often connected to routing logic on the chip. This control bit allows the PWMB output signal to be driven onto the output trigger port so it can be sent to the chip routing logic.</td>
</tr>
<tr>
<td>0b - Route the PWM_OUT_TRIG1 signal to PWM_OUT_TRIG1 port.</td>
<td></td>
</tr>
<tr>
<td>1b - Route the PWMB output to the PWM_OUT_TRIG1 port.</td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>RESERVED</td>
</tr>
<tr>
<td>12</td>
<td>Trigger frequency</td>
</tr>
<tr>
<td>TRGFRQ</td>
<td>This read/write bit allows control over the frequency of the trigger outputs when using non-zero values of CTRL[LDFQ].</td>
</tr>
<tr>
<td>0b - Trigger outputs are generated during every PWM period even if the PWM is not reloaded every period due to CTRL[LDFQ] being non-zero.</td>
<td></td>
</tr>
<tr>
<td>1b - Trigger outputs are generated only during the final PWM period prior to a reload opportunity when the PWM is not reloaded every period due to CTRL[LDFQ] being non-zero.</td>
<td></td>
</tr>
<tr>
<td>11-6</td>
<td>RESERVED</td>
</tr>
<tr>
<td>5-0</td>
<td>Output Trigger Enables</td>
</tr>
<tr>
<td>OUT_TRIG_EN</td>
<td>These bits enable the generation of PWM_OUT_TRIG0 and PWM_OUT_TRIG1 outputs based on the counter value matching the value in one or more of the VAL0-5 registers. VAL0, VAL2, and VAL4 are used to generate PWM_OUT_TRIG0, and VAL1, VAL3, and VAL5 are used to generate PWM_OUT_TRIG1. The PWM_OUT_TRIGx signals are only asserted as long as the counter value matches the VALx value; therefore, up to six triggers can be generated (three each on PWM_OUT_TRIG0 and PWM_OUT_TRIG1) per PWM cycle per submodule.</td>
</tr>
<tr>
<td>NOTE: Due to delays in creating the PWM outputs, the output trigger signals will lead the PWM output edges by 2-3 clock cycles depending on the fractional cycle value being used.</td>
<td></td>
</tr>
<tr>
<td>000000b - PWM_OUT_TRIGx will not set when the counter value matches the VALx value.</td>
<td></td>
</tr>
<tr>
<td>000001b - PWM_OUT_TRIGx will set when the counter value matches the VALx value.</td>
<td></td>
</tr>
</tbody>
</table>

### 55.8.23 Fault Disable Mapping Register 0 (SM0DISMAP0 - SM3DISMAP0)

#### 55.8.23.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaDISMAP0</td>
<td>2Ch + (a × 60h)</td>
</tr>
</tbody>
</table>
55.8.23.2 Function

This register determines which PWM pins are disabled by the fault protection inputs. Reset sets all of the bits in the fault disable mapping register.

55.8.23.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DIS0X</td>
<td>DIS0B</td>
<td>DIS0A</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

55.8.23.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>RESERVED</td>
</tr>
</tbody>
</table>
| 11-8  | DIS0X PWM_X Fault Disable Mask 0  
Each of the four bits of this read/write field is one-to-one associated with the four FAULTx inputs of fault channel 0. The PWM_X output is turned off if there is a logic 1 on a FAULTx input and a 1 in the corresponding bit of this field. A reset sets all bits in this field. |
| 7-4   | DIS0B PWM_B Fault Disable Mask 0  
Each of the four bits of this read/write field is one-to-one associated with the four FAULTx inputs of fault channel 0. The PWM_B output is turned off if there is a logic 1 on a FAULTx input and a 1 in the corresponding bit of this field. A reset sets all bits in this field. |
| 3-0   | DIS0A PWM_A Fault Disable Mask 0  
Each of the four bits of this read/write field is one-to-one associated with the four FAULTx inputs of fault channel 0. The PWM_A output is turned off if there is a logic 1 on a FAULTx input and a 1 in the corresponding bit of this field. A reset sets all bits in this field. |

55.8.24 Fault Disable Mapping Register 1 (SM0DISMAP1 - SM3DISMAP1)
### 55.8.24.1 Offset

For \( a = 0 \) to \( 3 \):

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaDISMAP1</td>
<td>( 2\text{Eh} + (a \times \text{60h}) )</td>
</tr>
</tbody>
</table>

### 55.8.24.2 Function

This register determines which PWM pins are disabled by the fault protection inputs. Reset sets all of the bits in the fault disable mapping register.

### 55.8.24.3 Diagram

![Diagram of bits 15 to 0 with R/W and Reset states]

### 55.8.24.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>RESERVED</td>
</tr>
<tr>
<td>DIS1X</td>
<td>PWM_X Fault Disable Mask 1</td>
</tr>
<tr>
<td></td>
<td>Each of the four bits of this read/write field is one-to-one associated</td>
</tr>
<tr>
<td></td>
<td>with the four FAULT_x inputs of fault channel 1. The PWM_X output</td>
</tr>
<tr>
<td></td>
<td>is turned off if there is a logic 1 on a FAULT_x input and a 1 in the</td>
</tr>
<tr>
<td></td>
<td>corresponding bit of this field. A reset sets all bits in this field.</td>
</tr>
<tr>
<td>DIS1B</td>
<td>PWM_B Fault Disable Mask 1</td>
</tr>
<tr>
<td></td>
<td>Each of the four bits of this read/write field is one-to-one associated</td>
</tr>
<tr>
<td></td>
<td>with the four FAULT_x inputs of fault channel 1. The PWM_B output</td>
</tr>
<tr>
<td></td>
<td>is turned off if there is a logic 1 on a FAULT_x input and a 1 in the</td>
</tr>
<tr>
<td></td>
<td>corresponding bit of this field. A reset sets all bits in this field.</td>
</tr>
<tr>
<td>DIS1A</td>
<td>PWM_A Fault Disable Mask 1</td>
</tr>
<tr>
<td></td>
<td>Each of the four bits of this read/write field is one-to-one associated</td>
</tr>
<tr>
<td></td>
<td>with the four FAULT_x inputs of fault channel 1. The PWM_A output</td>
</tr>
<tr>
<td></td>
<td>is turned off if there is a logic 1 on a FAULT_x input and a 1 in the</td>
</tr>
<tr>
<td></td>
<td>corresponding bit of this field. A reset sets all bits in this field.</td>
</tr>
</tbody>
</table>
55.8.25  Deadtime Count Register 0 (SM0DTCNT0 - SM3DTCNT0)

55.8.25.1  Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaDTCNT0</td>
<td>30h + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.25.2  Function

Deadtime operation applies only to complementary channel operation. The values written to the DTCNTx registers are in terms of IPBus clock cycles regardless of the setting of CTRL[PRSC] and/or CTRL2[CLK_SEL]. Reset sets the deadtime count registers to a default value of 0x07FF, selecting a deadtime of 2047 IPBus clock cycles. The DTCNTx registers are not byte accessible.

55.8.25.3  Diagram

```
Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
R    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
Reset| 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

DTCNT0
```

55.8.25.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>DTCNT0</td>
</tr>
<tr>
<td>DTCNT0</td>
<td></td>
</tr>
</tbody>
</table>

The DTCNT0 field is interpreted differently depending on whether or not the fractional delays are being used (FRCNTRL[FRAC23_EN] is set). If the fractional delays are off, then the upper 5 bits of DTCNT0 are ignored and the remaining 11 bits are used to specify the number of cycles of deadtime. In this case the maximum value is 0x07FF which indicates 2047 cycles of deadtime. If the fractional delays are being used, then the upper 11 bits of DTCNT0 represent the number of whole cycles of deadtime and the lower 5 bits of each register represent the fractional cycle added to the whole number. In this case the maximum value is 0xFFFF which represents 2047 31/32 cycles of deadtime.
55.8.26 Deadtime Count Register 1 (SM0DTCNT1 - SM3DTCNT1)

55.8.26.1 Offset

For $a = 0$ to $3$:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaDTCNT1</td>
<td>$32h + (a \times 60h)$</td>
</tr>
</tbody>
</table>

55.8.26.2 Function

Deadtime operation applies only to complementary channel operation. The values written to the DTCNTx registers are in terms of IPBus clock cycles regardless of the setting of CTRL[PRSC] and/or CTRL2[CLK_SEL]. Reset sets the deadtime count registers to a default value of 0x07FF, selecting a deadtime of 2047 IPBus clock cycles. The DTCNTx registers are not byte accessible.

55.8.26.3 Diagram

![Diagram](image)

55.8.26.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>DTCNT1</td>
</tr>
<tr>
<td>DTCNT1</td>
<td></td>
</tr>
</tbody>
</table>
The DTCNT1 field is interpreted differently depending on whether or not the fractional delays are being used (FRCNTRL[FRAC45_EN] is set). If the fractional delays are off, then the upper 5 bits of DTCNT1 are ignored and the remaining 11 bits are used to specify the number of cycles of deadtime. In this case the maximum value is 0x07FF which indicates 2047 cycles of deadtime. If the fractional delays are being used, then the upper 11 bits of DTCNT1 represent the number of whole cycles of deadtime and the lower 5 bits of each register represent the fractional cycle added to the whole number. In this case the maximum value is 0xFFFF which represents 2047 31/32 cycles of deadtime.

The DTCNT1 field is used to control the deadtime during 0 to 1 transitions of the PWM_B output (assuming normal polarity).

### 55.8.27 Capture Control A Register (SM0CAPTCTRLA - SM3CAPTCTRLA)

#### 55.8.27.1 Offset

For \( a = 0 \) to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCAPTCTRLA</td>
<td>34h + (a × 60h)</td>
</tr>
</tbody>
</table>

#### 55.8.27.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### 55.8.27.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-13</td>
<td>Capture A1 FIFO Word Count</td>
</tr>
<tr>
<td>CA1CNT</td>
<td>This field reflects the number of words in the Capture A1 FIFO.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>12-10</td>
<td>Capture A0 FIFO Word Count This field reflects the number of words in the Capture A0 FIFO.</td>
</tr>
<tr>
<td>CA0CNT</td>
<td></td>
</tr>
<tr>
<td>9-8</td>
<td>Capture A FIFOs Water Mark This field represents the water mark level for capture A FIFOs. The capture flags, STS[CFA1] and STS[CFA0], are not set until the word count of the corresponding FIFO is greater than this water mark level.</td>
</tr>
<tr>
<td>CFAWM</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Edge Counter A Enable This bit enables the edge counter which counts rising and falling edges on the PWM_A input signal.</td>
</tr>
<tr>
<td>EDGCNTA_EN</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>Input Select A This bit selects between the raw PWM_A input signal and the output of the edge counter/compare circuitry as the source for the input capture circuit.</td>
</tr>
<tr>
<td>INP_SELA</td>
<td>0b - Raw PWM_A input signal selected as source. 1b - Output of edge counter/compare selected as source. Note that when this bitfield is set to 1, the internal edge counter is enabled and the rising and/or falling edges specified by the CAPTCTRLA[EDGA0] and CAPTCTRLA[EDGA1] fields are ignored. The software must still place a value other than 00 in either or both of the CAPTCTRLA[EDGA0] and/or CAPTCTRLA[EDGA1] fields in order to enable one or both of the capture registers.</td>
</tr>
<tr>
<td>5-4</td>
<td>Edge A 1 These bits control the input capture 1 circuitry by determining which input edges cause a capture event.</td>
</tr>
<tr>
<td>EDGA1</td>
<td>00b - Disabled 01b - Capture falling edges 10b - Capture rising edges 11b - Capture any edge</td>
</tr>
<tr>
<td>3-2</td>
<td>Edge A 0 These bits control the input capture 0 circuitry by determining which input edges cause a capture event.</td>
</tr>
<tr>
<td>EDGA0</td>
<td>00b - Disabled 01b - Capture falling edges 10b - Capture rising edges 11b - Capture any edge</td>
</tr>
<tr>
<td>1</td>
<td>One Shot Mode A This bit selects between free running and one shot mode for the input capture circuitry.</td>
</tr>
<tr>
<td>ONESHOTA</td>
<td>0b - Free running mode is selected. If both capture circuits are enabled, then capture circuit 0 is armed first after CAPTCTRLA[ARMA] is set. Once a capture occurs, capture circuit 0 is disarmed and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed and capture circuit 0 is re-armed. The process continues indefinitely. If only one of the capture circuits is enabled, then captures continue indefinitely on the enabled capture circuit.</td>
</tr>
<tr>
<td>0</td>
<td>Arm A Setting this bit high starts the input capture process. This bit can be cleared at any time to disable input capture operation. This bit is self-cleared when in one shot mode and one or more of the enabled capture circuits has had a capture event.</td>
</tr>
</tbody>
</table>
### Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b</td>
<td>Input capture operation is disabled.</td>
</tr>
<tr>
<td>1b</td>
<td>Input capture operation as specified by CAPTCTRLA[EDGAx] is enabled.</td>
</tr>
</tbody>
</table>

#### 55.8.28 Capture Compare A Register (SM0CAPTCOMPA - SM3CAPTCOMPA)

#### 55.8.28.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCAPTCOMPA</td>
<td>36h + (a × 60h)</td>
</tr>
</tbody>
</table>

#### 55.8.28.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>EDGCNTA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>EDGCMPA</td>
</tr>
</tbody>
</table>

| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

#### 55.8.28.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-8</td>
<td>Edge Counter A</td>
</tr>
<tr>
<td>EDGCNTA</td>
<td>This read-only field contains the edge counter value for the PWM_A input capture circuitry.</td>
</tr>
<tr>
<td>7-0</td>
<td>Edge Compare A</td>
</tr>
<tr>
<td>EDGCMPA</td>
<td>This read/write field is the compare value associated with the edge counter for the PWM_A input capture circuitry.</td>
</tr>
</tbody>
</table>
55.8.29 Capture Control B Register (SM0CAPTCTRLB - SM3CAPTCTRLB)

### 55.8.29.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCAPTCTRLB</td>
<td>38h + (a × 60h)</td>
</tr>
</tbody>
</table>

### 55.8.29.2 Diagram

![Diagram of Bits](image)

### 55.8.29.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15-13 CB1CNT | Capture B1 FIFO Word Count  
This field reflects the number of words in the Capture B1 FIFO.                               |
| 12-10 CB0CNT | Capture B0 FIFO Word Count  
This field reflects the number of words in the Capture B0 FIFO.                               |
| 9-8 CFBWM | Capture B FIFOs Water Mark  
This field represents the water mark level for capture B FIFOs. The capture flags, STS[CFB1] and STS[CFB0], won’t be set until the word count of the corresponding FIFO is greater than this water mark level. |
| 7 EDGCNTB_EN | Edge Counter B Enable  
This bit enables the edge counter which counts rising and falling edges on the PWM_B input signal.  
0b - Edge counter disabled and held in reset  
1b - Edge counter enabled |
| 6 INP_SEL B | Input Select B  
This bit selects between the raw PWM_B input signal and the output of the edge counter/compare  
circuitry as the source for the input capture circuit.                                           |

*Table continues on the next page...*
## PWM register descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b - Raw PWM_B input signal selected as source. 1b - Output of edge counter/compare selected as source. Note that when this bitfield is set to 1, the internal edge counter is enabled and the rising and/or falling edges specified by the CAPTCTRLB[EDGB0] and CAPTCTRLB[EDGB1] fields are ignored. The software must still place a value other than 00 in either or both of the CAPTCTRLB[EDGB0] and/or CAPTCTRLB[EDGB1] fields in order to enable one or both of the capture registers.</td>
<td></td>
</tr>
<tr>
<td>5-4</td>
<td>Edge B 1</td>
</tr>
<tr>
<td>3-2</td>
<td>Edge B 0</td>
</tr>
<tr>
<td>1</td>
<td>One Shot Mode B</td>
</tr>
<tr>
<td>0</td>
<td>Arm B</td>
</tr>
</tbody>
</table>

### Edge B 1
These bits control the input capture 1 circuitry by determining which input edges cause a capture event.
- 00b - Disabled
- 01b - Capture falling edges
- 10b - Capture rising edges
- 11b - Capture any edge

### Edge B 0
These bits control the input capture 0 circuitry by determining which input edges cause a capture event.
- 00b - Disabled
- 01b - Capture falling edges
- 10b - Capture rising edges
- 11b - Capture any edge

### One Shot Mode B
This bit selects between free running and one shot mode for the input capture circuitry.
- 0b - Free running mode is selected. If both capture circuits are enabled, then capture circuit 0 is armed first after CAPTCTRLB[ARMB] is set. Once a capture occurs, capture circuit 0 is disarmed and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed and capture circuit 0 is re-armed. The process continues indefinitely. If only one of the capture circuits is enabled, then captures continue indefinitely on the enabled capture circuit.
- 1b - One shot mode is selected. If both capture circuits are enabled, then capture circuit 0 is armed first after CAPTCTRLB[ARMB] is set. Once a capture occurs, capture circuit 0 is disarmed and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed and CAPTCTRLB[ARMB] is cleared. No further captures will be performed until CAPTCTRLB[ARMB] is set again. If only one of the capture circuits is enabled, then a single capture will occur on the enabled capture circuit and CAPTCTRLB[ARMB] is then cleared.

### Arm B
Setting this bit high starts the input capture process. This bit can be cleared at any time to disable input capture operation. This bit is self-cleared when in one shot mode and one or more of the enabled capture circuits has had a capture event.
- 0b - Input capture operation is disabled.
- 1b - Input capture operation as specified by CAPTCTRLB[EDGBx] is enabled.

### 55.8.30 Capture Compare B Register (SM0CAPTCOMPB - SM3CAPTCOMPB)

### 55.8.30.1 Offset
For \( a = 0 \) to 3:
55.8.30.2 Diagram

Bits

<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.30.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15-8   | Edge Counter B  
EDGCNTB | This read-only field contains the edge counter value for the PWM_B input capture circuitry. |
| 7-0   | Edge Compare B  
EDGCMPB | This read/write field is the compare value associated with the edge counter for the PWM_B input capture circuitry. |

55.8.31 Capture Control X Register (SM0CAPTCTRLX - SM3CAPTCTRLX)

55.8.31.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCAPTCTRLX</td>
<td>3Ch + (a × 60h)</td>
</tr>
</tbody>
</table>
## 55.8.31.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>CX1CNT</td>
<td>CX0CNT</td>
<td>CFXWM</td>
<td>EDGNTX_EN</td>
<td>INP_SELX</td>
<td>EDGX1</td>
<td>EDGX0</td>
<td>ONESHOTX</td>
<td>ARMX</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

## 55.8.31.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| 15-13 CX1CNT | Capture X1 FIFO Word Count  
This field reflects the number of words in the Capture X1 FIFO. |
| 12-10 CX0CNT | Capture X0 FIFO Word Count  
This field reflects the number of words in the Capture X0 FIFO. |
| 9-8 CFXWM | Capture X FIFOs Water Mark  
This field represents the water mark level for capture X FIFOs. The capture flags, STS[CFX1] and STS[CFX0], won't be set until the word count of the corresponding FIFO is greater than this water mark level. |
| 7 EDGNTX_EN | Edge Counter X Enable  
This bit enables the edge counter which counts rising and falling edges on the PWM_X input signal.  
0b - Edge counter disabled and held in reset  
1b - Edge counter enabled |
| 6 INP_SELX | Input Select X  
This bit selects between the raw PWM_X input signal and the output of the edge counter/compare circuitry as the source for the input capture circuit.  
0b - Raw PWM_X input signal selected as source.  
1b - Output of edge counter/compare selected as source. Note that when this bitfield is set to 1, the internal edge counter is enabled and the rising and/or falling edges specified by the CAPTCTRLX[EDGX0] and CAPTCTRLX[EDGX1] fields are ignored. The software must still place a value other than 00 in either or both of the CAPTCTRLX[EDGX0] and/or CAPTCTRLX[EDGX1] fields in order to enable one or both of the capture registers. |
| 5-4 EDGX1 | Edge X 1  
These bits control the input capture 1 circuitry by determining which input edges cause a capture event.  
00b - Disabled  
01b - Capture falling edges  
10b - Capture rising edges  
11b - Capture any edge |
| 3-2 EDGX0 | Edge X 0  
These bits control the input capture 0 circuitry by determining which input edges cause a capture event.  
00b - Disabled |
### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>01b</td>
<td>Capture falling edges</td>
</tr>
<tr>
<td>10b</td>
<td>Capture rising edges</td>
</tr>
<tr>
<td>11b</td>
<td>Capture any edge</td>
</tr>
</tbody>
</table>

#### One Shot Mode Aux

This bit selects between free running and one shot mode for the input capture circuitry.

- 0b - Free running mode is selected. If both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed and capture circuit 0 is re-armed. The process continues indefinitely. If only one of the capture circuits is enabled, then captures continue indefinitely on the enabled capture circuit.

- 1b - One shot mode is selected. If both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed and the ARMX bit is cleared. No further captures will be performed until the ARMX bit is set again. If only one of the capture circuits is enabled, then a single capture will occur on the enabled capture circuit and the ARMX bit is then cleared.

#### Arm X

Setting this bit high starts the input capture process. This bit can be cleared at any time to disable input capture operation. This bit is self-cleared when in one shot mode and one or more of the enabled capture circuits has had a capture event.

- 0b - Input capture operation is disabled.
- 1b - Input capture operation as specified by CAPTCTRLX[EDGXx] is enabled.

## 55.8.32 Capture Compare X Register (SM0CAPTCOMPX - SM3C APTCOMPX)

### 55.8.32.1 Offset

For \(a = 0 \) to \(3\):

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCAPTCOMPX</td>
<td>(3Eh + (a \times 60h))</td>
</tr>
</tbody>
</table>

### 55.8.32.2 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

EDGCNTX

EDGCMPX
```
## 55.8.32.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-8</td>
<td>Edge Counter X</td>
</tr>
<tr>
<td>EDGCNTX</td>
<td>This read-only field contains the edge counter value for the PWM_X input capture circuitry.</td>
</tr>
<tr>
<td>7-0</td>
<td>Edge Compare X</td>
</tr>
<tr>
<td>EDGCMPX</td>
<td>This read/write field is the compare value associated with the edge counter for the PWM_X input capture circuitry.</td>
</tr>
</tbody>
</table>

## 55.8.33 Capture Value 0 Register (SM0CVAL0 - SM3CVAL0)

### 55.8.33.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL0</td>
<td>40h + (a × 60h)</td>
</tr>
</tbody>
</table>

### 55.8.33.2 Diagram

![Diagram of CAPTVAL0 Register](image)

### 55.8.33.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>CAPTVAL0</td>
</tr>
<tr>
<td>CAPTVAL0</td>
<td>This read-only register stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLX[EDGX0]. Each capture will increase the value of CAPTCTRLX[CX0CNT] by 1 until the maximum value is reached. Each read of this register will decrease the value of CAPTCTRLX[CX0CNT] by 1 until 0 is reached. This register is not byte accessible.</td>
</tr>
</tbody>
</table>
55.8.34 Capture Value 0 Cycle Register (SM0CVAL0CYC - SM3CVAL0CYC)

55.8.34.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL0CYC</td>
<td>42h + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.34.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.34.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-4</td>
<td>RESERVED</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>3-0</td>
<td>CVAL0CYC</td>
</tr>
<tr>
<td>CVAL0CYC</td>
<td>This read-only register stores the cycle number corresponding to the value captured in CVAL0. This register is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.</td>
</tr>
</tbody>
</table>

55.8.35 Capture Value 1 Register (SM0CVAL1 - SM3CVAL1)

55.8.35.1 Offset

For a = 0 to 3:
### 55.8.35.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 55.8.35.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>CAPTVAL1</td>
</tr>
<tr>
<td>CAPTVAL1</td>
<td>This read-only register stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLX[EDGX1]. Each capture increases the value of CAPTCTRLX[CX1CNT] by 1 until the maximum value is reached. Each read of this register decreases the value of CAPTCTRLX[CX1CNT] by 1 until 0 is reached. This register is not byte accessible.</td>
</tr>
</tbody>
</table>

### 55.8.36 Capture Value 1 Cycle Register (SM0CVAL1CYC - SM3CVAL1CYC)

#### 55.8.36.1 Offset

For \( a = 0 \) to \( 3 \):

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL1CYC</td>
<td>( 46h + (a \times 60h) )</td>
</tr>
</tbody>
</table>
55.8.36.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

CVAL1CYC

55.8.36.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-4</td>
<td>RESERVED</td>
</tr>
<tr>
<td>3-0</td>
<td>CVAL1CYC</td>
</tr>
</tbody>
</table>

This read-only register stores the cycle number corresponding to the value captured in CVAL1. This register is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.

55.8.37 Capture Value 2 Register (SM0CVAL2 - SM3CVAL2)

55.8.37.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL2</td>
<td>48h + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.37.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

CAPTVAL2
### 55.8.37.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>CAPTVAL2</td>
</tr>
<tr>
<td>CAPTVAL2</td>
<td>This read-only register stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLA[EDGA0]. Each capture increases the value of CAPTCTRLA[CA0CNT] by 1 until the maximum value is reached. Each read of this register decreases the value of CAPTCTRLA[CA0CNT] by 1 until 0 is reached. This register is not byte accessible.</td>
</tr>
</tbody>
</table>

### 55.8.38 Capture Value 2 Cycle Register (SM0CVAL2CYC - SM3CVAL2CYC)

#### 55.8.38.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL2CYC</td>
<td>4Ah + (a × 60h)</td>
</tr>
</tbody>
</table>

#### 55.8.38.2 Diagram

Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### 55.8.38.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-4</td>
<td>RESERVED</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>3-0</td>
<td>CVAL2CYC</td>
</tr>
<tr>
<td>CVAL2CYC</td>
<td>This read-only register stores the cycle number corresponding to the value captured in CVAL2. This register is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.</td>
</tr>
</tbody>
</table>
55.8.39 Capture Value 3 Register (SM0CVAL3 - SM3CVAL3)

55.8.39.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL3</td>
<td>4Ch + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.39.2 Diagram

```
Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     CAPTVAL3
W
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

55.8.39.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0 CAPTVAL3</td>
<td>This read-only register stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLA[EDGA1]. Each capture increases the value of CAPTCTRLA[CA1CNT] by 1 until the maximum value is reached. Each read of this register decreases the value of CAPTCTRLA[CA1CNT] by 1 until 0 is reached. This register is not byte accessible.</td>
</tr>
</tbody>
</table>

55.8.40 Capture Value 3 Cycle Register (SM0CVAL3CYC - SM3CVAL3CYC)

55.8.40.1 Offset

For a = 0 to 3:
**55.8.40.2 Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CVAL3CYC</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**55.8.40.3 Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-4</td>
<td>RESERVED</td>
</tr>
<tr>
<td>3-0</td>
<td>CVAL3CYC</td>
</tr>
</tbody>
</table>

**CVAL3CYC**

This read-only register stores the cycle number corresponding to the value captured in CVAL3. This register is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.

**55.8.41 Capture Value 4 Register (SM0CVAL4 - SM3CVAL4)**

**55.8.41.1 Offset**

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL4</td>
<td>50h + (a × 60h)</td>
</tr>
</tbody>
</table>
55.8.41.2  Diagram

This read-only register stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLB[EDGB0]. Each capture increases the value of CAPTCTRLB[CBOCNT] by 1 until the maximum value is reached. Each read of this register decreases the value of CAPTCTRLB[CBOCNT] by 1 until 0 is reached. This register is not byte accessible.

55.8.42  Capture Value 4 Cycle Register (SM0CVAL4CYC - SM3CVAL4CYC)

55.8.42.1  Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL4CYC</td>
<td>52h + (a × 60h)</td>
</tr>
</tbody>
</table>

55.8.42.2  Diagram
55.8.43.2  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CAPTVAL5</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.43.3  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>CAPTVAL5</td>
</tr>
<tr>
<td>CAPTVAL5</td>
<td>This read-only register stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLB[EDGB1]. Each capture increases the value of CAPTCTRLB[CB1CNT] by 1 until the maximum value is reached. Each read of this register decreases the value of CAPTCTRLB[CB1CNT] by 1 until 0 is reached. This register is not byte accessible.</td>
</tr>
<tr>
<td>3-0</td>
<td>CVAL4CYC</td>
</tr>
<tr>
<td>CVAL4CYC</td>
<td>This read-only register stores the cycle number corresponding to the value captured in CVAL4. This register is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.</td>
</tr>
</tbody>
</table>

55.8.43  Capture Value 5 Register (SM0CVAL5 - SM3CVAL5)

55.8.43.1  Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL5</td>
<td>54h + (a × 60h)</td>
</tr>
</tbody>
</table>
55.8.44 Capture Value 5 Cycle Register (SM0CVAL5CYC - SM3CVAL5CYC)

55.8.44.1 Offset

For a = 0 to 3:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMaCVAL5CYC</td>
<td>56h + (a x 60h)</td>
</tr>
</tbody>
</table>

55.8.44.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

55.8.44.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-4</td>
<td>RESERVED</td>
</tr>
<tr>
<td>3-0</td>
<td>CVAL5CYC</td>
</tr>
<tr>
<td>CVAL5CYC</td>
<td>This read-only register stores the cycle number corresponding to the value captured in CVAL5. This register is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.</td>
</tr>
</tbody>
</table>

55.8.45 Output Enable Register (OUTEN)
## 55.8.45.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>OUTEN</td>
<td>180h</td>
</tr>
</tbody>
</table>

## 55.8.45.2 Diagram

```
+------+------+------
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

R: Read
W: Write

---

## 55.8.45.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>RESERVED</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>11-8 PWMA_EN</td>
<td>PWM_A Output Enables</td>
</tr>
<tr>
<td></td>
<td>The four bits of this field enable the PWM_A outputs of submodules 3-0,</td>
</tr>
<tr>
<td></td>
<td>respectively. These bits should be set to 0 (output disabled) when a</td>
</tr>
<tr>
<td></td>
<td>PWM_A pin is being used for input capture.</td>
</tr>
<tr>
<td></td>
<td>0000b - PWM_A output disabled.</td>
</tr>
<tr>
<td></td>
<td>0001b - PWM_A output enabled.</td>
</tr>
<tr>
<td>7-4 PWMB_EN</td>
<td>PWM_B Output Enables</td>
</tr>
<tr>
<td></td>
<td>The four bits of this field enable the PWM_B outputs of submodules 3-0,</td>
</tr>
<tr>
<td></td>
<td>respectively. These bits should be set to 0 (output disabled) when a</td>
</tr>
<tr>
<td></td>
<td>PWM_B pin is being used for input capture.</td>
</tr>
<tr>
<td></td>
<td>0000b - PWM_B output disabled.</td>
</tr>
<tr>
<td></td>
<td>0001b - PWM_B output enabled.</td>
</tr>
<tr>
<td>3-0 PWMX_EN</td>
<td>PWM_X Output Enables</td>
</tr>
<tr>
<td></td>
<td>The four bits of this field enable the PWM_X outputs of submodules 3-0,</td>
</tr>
<tr>
<td></td>
<td>respectively. These bits should be set to 0 (output disabled) when a</td>
</tr>
<tr>
<td></td>
<td>PWM_X pin is being used for input capture or deadtime correction.</td>
</tr>
<tr>
<td></td>
<td>0000b - PWM_X output disabled.</td>
</tr>
<tr>
<td></td>
<td>0001b - PWM_X output enabled.</td>
</tr>
</tbody>
</table>

## 55.8.46 Mask Register (MASK)
55.8.46.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MASK</td>
<td>182h</td>
</tr>
</tbody>
</table>

55.8.46.2 Function

MASK is double buffered and does not take effect until a FORCE_OUT event occurs within the appropriate submodule. Reading MASK reads the buffered values and not necessarily the values currently in effect. This double buffering can be overridden by setting the UPDATE_MASK bits.

55.8.46.3 Diagram

```
Bits  15  14  13  12  11  10  9  8  7  6  5  4  3  2  1  0
R
W
  UPDATE_MASK  MASKA  MASKB  MASKX
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

55.8.46.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>UPDATE_MASK</td>
</tr>
<tr>
<td>Update Mask Bits Immediately</td>
<td></td>
</tr>
<tr>
<td>The four bits mask the PWM_X outputs of submodules 3-0, respectively, The four bits of this field force the MASK* bits to be immediately updated within submodules 3-0, respectively, without waiting for a FORCE_OUT event. These self-clearing bits always read as zero. Software may write to any or all of these bits and may set these bits in the same write operation that updates the MASKA, MASKB, and MASKX fields of this register.</td>
<td></td>
</tr>
<tr>
<td>0000b - Normal operation. MASK* bits within the corresponding submodule are not updated until a FORCE_OUT event occurs within the submodule.</td>
<td></td>
</tr>
<tr>
<td>0001b - Immediate operation. MASK* bits within the corresponding submodule are updated on the following clock edge after setting this bit.</td>
<td></td>
</tr>
<tr>
<td>11-8</td>
<td>MASKA</td>
</tr>
<tr>
<td>PWM_A Masks</td>
<td></td>
</tr>
<tr>
<td>The four bits of this field mask the PWM_A outputs of submodules 3-0, respectively, forcing the output to logic 0 prior to consideration of the output polarity.</td>
<td></td>
</tr>
<tr>
<td>0000b - PWM_A output normal.</td>
<td></td>
</tr>
<tr>
<td>0001b - PWM_A output masked.</td>
<td></td>
</tr>
<tr>
<td>7-4</td>
<td>PWM_B Masks</td>
</tr>
</tbody>
</table>

Table continues on the next page...
For this document, the text is already neatly formatted and does not require any adjustments. However, for the sake of clarity, the content can be broken down as follows:

### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| MASKB | The four bits of this field mask the PWM_B outputs of submodules 3-0, respectively, forcing the output to logic 0 prior to consideration of the output polarity.  
0000b - PWM_B output normal.  
0001b - PWM_B output masked. |

| MASKX | PWM_X Masks  
The four bits of this field mask the PWM_X outputs of submodules 3-0, respectively, forcing the output to logic 0 prior to consideration of the output polarity.  
0000b - PWM_X output normal.  
0001b - PWM_X output masked. |

### 55.8.47 Software Controlled Output Register (SWCOUT)

#### 55.8.47.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SWCOUT</td>
<td>184h</td>
</tr>
</tbody>
</table>

#### 55.8.47.2 Function

These bits are double buffered and do not take effect until a FORCE_OUT event occurs within the appropriate submodule. Reading these bits reads the buffered value and not necessarily the value currently in effect.

#### 55.8.47.3 Diagram

![Diagram](image_url)
### 55.8.47.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-8</td>
<td>RESERVED</td>
</tr>
<tr>
<td>7</td>
<td>Submodule 3 Software Controlled Output 23&lt;br&gt;This bit is only used when DTSRCSEL[SM3SEL23] is set to 0b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 3 instead of PWM23.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 3 instead of PWM23.</td>
</tr>
<tr>
<td>6</td>
<td>Submodule 3 Software Controlled Output 45&lt;br&gt;This bit is only used when DTSRCSEL[SM3SEL45] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 3 instead of PWM45.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 3 instead of PWM45.</td>
</tr>
<tr>
<td>5</td>
<td>Submodule 2 Software Controlled Output 23&lt;br&gt;This bit is only used when DTSRCSEL[SM2SEL23] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 2 instead of PWM23.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 2 instead of PWM23.</td>
</tr>
<tr>
<td>4</td>
<td>Submodule 2 Software Controlled Output 45&lt;br&gt;This bit is only used when DTSRCSEL[SM2SEL45] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 2 instead of PWM45.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 2 instead of PWM45.</td>
</tr>
<tr>
<td>3</td>
<td>Submodule 1 Software Controlled Output 23&lt;br&gt;This bit is only used when DTSRCSEL[SM1SEL23] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 1 instead of PWM23.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 1 instead of PWM23.</td>
</tr>
<tr>
<td>2</td>
<td>Submodule 1 Software Controlled Output 45&lt;br&gt;This bit is only used when DTSRCSEL[SM1SEL45] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 1 instead of PWM45.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 1 instead of PWM45.</td>
</tr>
<tr>
<td>1</td>
<td>Submodule 0 Software Controlled Output 23&lt;br&gt;This bit is only used when DTSRCSEL[SM0SEL23] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 0 instead of PWM23.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 0 instead of PWM23.</td>
</tr>
<tr>
<td>0</td>
<td>Submodule 0 Software Controlled Output 45&lt;br&gt;This bit is only used when DTSRCSEL[SM0SEL45] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.&lt;br&gt;0b - A logic 0 is supplied to the deadtime generator of submodule 0 instead of PWM45.&lt;br&gt;1b - A logic 1 is supplied to the deadtime generator of submodule 0 instead of PWM45.</td>
</tr>
</tbody>
</table>
55.8.48 PWM Source Select Register (DTSRCSEL)

55.8.48.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DTSRCSEL</td>
<td>186h</td>
</tr>
</tbody>
</table>

55.8.48.2 Function

The PWM source select bits are double buffered and do not take effect until a FORCE_OUT event occurs within the appropriate submodule. Reading these bits reads the buffered value and not necessarily the value currently in effect.

55.8.48.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-14</td>
</tr>
<tr>
<td>13-12</td>
</tr>
<tr>
<td>11-10</td>
</tr>
<tr>
<td>9-8</td>
</tr>
<tr>
<td>7-6</td>
</tr>
<tr>
<td>5-4</td>
</tr>
<tr>
<td>3-2</td>
</tr>
<tr>
<td>1-0</td>
</tr>
</tbody>
</table>

R

<table>
<thead>
<tr>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SM3SEL23</td>
<td>SM3SEL45</td>
<td>SM2SEL23</td>
<td>SM2SEL45</td>
<td>SM1SEL23</td>
<td>SM1SEL45</td>
<td>SM0SEL23</td>
<td>SM0SEL45</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

W

| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

55.8.48.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-14</td>
<td>Submodule 3 PWM23 Control Select</td>
</tr>
<tr>
<td>SM3SEL23</td>
<td>This field selects possible over-rides to the generated SM3PWM23 signal that will be passed to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule. 00b - Generated SM3PWM23 signal is used by the deadtime logic. 01b - Inverted generated SM3PWM23 signal is used by the deadtime logic. 10b - SWCOUT[SM3OUT23] is used by the deadtime logic. 11b - PWM3_EXTA signal is used by the deadtime logic.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>11-10</td>
<td><strong>Submodule 2 PWM23 Control Select</strong>&lt;br&gt;This field selects possible over-rides to the generated SM2PWM23 signal that will be passed to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</td>
</tr>
<tr>
<td>9-8</td>
<td><strong>Submodule 2 PWM45 Control Select</strong>&lt;br&gt;This field selects possible over-rides to the generated SM2PWM45 signal that will be passed to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</td>
</tr>
<tr>
<td>7-6</td>
<td><strong>Submodule 1 PWM23 Control Select</strong>&lt;br&gt;This field selects possible over-rides to the generated SM1PWM23 signal that will be passed to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</td>
</tr>
<tr>
<td>5-4</td>
<td><strong>Submodule 1 PWM45 Control Select</strong>&lt;br&gt;This field selects possible over-rides to the generated SM1PWM45 signal that will be passed to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</td>
</tr>
<tr>
<td>3-2</td>
<td><strong>Submodule 0 PWM23 Control Select</strong>&lt;br&gt;This field selects possible over-rides to the generated SM0PWM23 signal that will be passed to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</td>
</tr>
<tr>
<td>1-0</td>
<td><strong>Submodule 0 PWM45 Control Select</strong>&lt;br&gt;This field selects possible over-rides to the generated SM0PWM45 signal that will be passed to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</td>
</tr>
</tbody>
</table>

00b - Generated SMX signal is used by the deadtime logic.
01b - Inverted generated SMX signal is used by the deadtime logic.
10b - SWCOUT[SMOUTXY] is used by the deadtime logic.
11b - PWMX_EXT signal is used by the deadtime logic.
55.8.49  Master Control Register (MCTRL)

55.8.49.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCTRL</td>
<td>188h</td>
</tr>
</tbody>
</table>

55.8.49.2  Function

In every 4-bit field in this register, each bit acts on a separate submodule. Accordingly, the description of every bitfield refers to the effect of an individual bit.

55.8.49.3  Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IPOL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RUN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

55.8.49.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>Current Polarity</td>
</tr>
<tr>
<td>IPOL</td>
<td>The four buffered read/write bits of this field correspond to submodules 3-0, respectively. Each bit selects between PWM23 and PWM45 as the source for the generation of the complementary PWM pair output for the corresponding submodule. MCTRL[IPOL] is ignored in independent mode. MCTRL[IPOL] does not take effect until a FORCE_OUT event takes place in the appropriate submodule. Reading MCTRL[IPOL] reads the buffered value and not necessarily the value currently in effect. 0000b - PWM23 is used to generate complementary PWM pair in the corresponding submodule. 0001b - PWM45 is used to generate complementary PWM pair in the corresponding submodule.</td>
</tr>
<tr>
<td>11-8</td>
<td>Run</td>
</tr>
<tr>
<td>RUN</td>
<td>The four read/write bits of this field enable the clocks to the PWM generator of submodules 3-0, respectively. The corresponding MCTRL[RUN] bit must be set for each submodule that is using its input capture functions or is using the local reload as its reload source. When this bit equals zero, the submodule counter is reset. A reset clears this field.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Field | Function
---|---
0000b | PWM generator is disabled in the corresponding submodule.
0001b | PWM generator is enabled in the corresponding submodule.
7-4 CLDOK | Clear Load Okay
The 4 bits of CLDOK field correspond to submodules 3-0, respectively. Each write-only bit is used to clear the corresponding bit of MCTRL[LDOK]. Write a 1 to CLDOK to clear the corresponding MCTRL[LDOK] bit. If a reload occurs within a submodule with the corresponding MCTRL[LDOK] bit set at the same time that MCTRL[CLDOK] is written, then the reload in that submodule will not be performed and MCTRL[LDOK] will be cleared. CLDOK bit is self-clearing and always reads as a 0.
3-0 LDOK | Load Okay
The 4 bits of LDOK field correspond to submodules 3-0, respectively. Each read/set bit loads CTRL[PRSC] and the INIT, FRACVALx, and VALx registers of the corresponding submodule into a set of buffers. The buffered prescaler divisor, submodule counter modulus value, and PWM pulse width take effect at the next PWM reload if CTRL[LDMOD] is clear or immediately if CTRL[LDMOD] is set. Set the corresponding MCTRL[LDOK] bit by reading it when it is logic zero and then writing a logic one to it. The VALx, FRACVALx,INIT, and CTRL[PRSC] registers of the corresponding submodule cannot be written while the the corresponding MCTRL[LDOK] bit is set.

In Master Reload Mode (CTRL2[RELOAD_SEL]=1), it is only necessary to set the LDOK bit corresponding to submodule0; however, it is recommended to also set the LDOK bit of the slave submodules, to prevent unwanted writes to the registers in the slave submodules.

The MCTRL[LDOK] bit is automatically cleared after the new values are loaded, or it can be manually cleared before a reload by writing a logic 1 to the appropriate MCTRL[CLDOK] bit. LDOK bits cannot be written with a zero. MCTRL[LDOK] can be set in DMA mode when the DMA indicates that it has completed the update of all CTRL[PRSC], INIT,FRACVALx, and VALx registers in the corresponding submodule. Reset clears LDOK field.

- 0000b - Do not load new values.
- 0001b - Load prescaler, modulus, and PWM values of the corresponding submodule.

55.8.50 Master Control 2 Register (MCTRL2)

55.8.50.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCTRL2</td>
<td>18Ah</td>
</tr>
</tbody>
</table>

55.8.50.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MONPLL</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### 55.8.50.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-9</td>
<td>RESERVED</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>RESERVED</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>7-2</td>
<td>RESERVED</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>1-0</td>
<td>MONPLL</td>
</tr>
<tr>
<td></td>
<td>Monitor PLL State</td>
</tr>
</tbody>
</table>

These bits are used to control disabling of the fractional delay block when the chip PLL is unlocked and/or missing its input reference. The fractional delay block requires a continuous 200 MHz clock from the PLL. If this clock turns off when the fractional delay block is being used, then the output of the fractional delay block can be stuck high or low even if the PLL restarts. When this control bit is set, PLL problems cause the fractional delay block to be disabled until the PLL returns to a locked state. Once the PLL is receiving a proper reference and is locked, the fractional delay block requires a 25 µs startup time just as if the FRCTRL[FRAC*_EN] bits had been turned off and turned on again.

If PLL monitoring is disabled, then software should manually clear and then set the FRCTRL[FRAC*_EN] bits when the PLL loses its reference or loses lock. This will cause the fractional delay block to be disabled and restarted.

If the fractional delay block is not being used, then the value of these bits do not matter.

- 00b - Not locked. Do not monitor PLL operation. Resetting of the fractional delay block in case of PLL losing lock will be controlled by software.
- 01b - Not locked. Monitor PLL operation to automatically disable the fractional delay block when the PLL encounters problems.
- 10b - Locked. Do not monitor PLL operation. Resetting of the fractional delay block in case of PLL losing lock will be controlled by software. These bits are write protected until the next reset.
- 11b - Locked. Monitor PLL operation to automatically disable the fractional delay block when the PLL encounters problems. These bits are write protected until the next reset.

### 55.8.51 Fault Control Register (FCTRL0)

#### 55.8.51.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCTRL0</td>
<td>18Ch</td>
</tr>
</tbody>
</table>
55.8.51.2  Function

For every 4-bit field in this register, the bits act on the fault inputs in order. For example, FLVL bits 15-12 act on faults 3-0, respectively.

55.8.51.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>FLVL</td>
<td>FAUTO</td>
<td>FSAFE</td>
<td>FIE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.51.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>Fault Level</td>
</tr>
<tr>
<td>FLVL</td>
<td>The four read/write bits of this field select the active logic level of the individual fault inputs 3-0, respectively. A reset clears this field.</td>
</tr>
<tr>
<td></td>
<td>0000b - A logic 0 on the fault input indicates a fault condition.</td>
</tr>
<tr>
<td></td>
<td>0001b - A logic 1 on the fault input indicates a fault condition.</td>
</tr>
<tr>
<td>11-8</td>
<td>Automatic Fault Clearing</td>
</tr>
<tr>
<td>FAUTO</td>
<td>The four read/write bits of this field select automatic or manual clearing of faults 3-0, respectively. A reset clears this field.</td>
</tr>
<tr>
<td></td>
<td>0000b - Manual fault clearing. PWM outputs disabled by this fault are not enabled until FSTS[FFLAGx] is clear at the start of a half cycle or full cycle depending the state of FSTS[FFULL]. This is further controlled by FCTRL[FSAFE].</td>
</tr>
<tr>
<td></td>
<td>0001b - Automatic fault clearing. PWM outputs disabled by this fault are enabled when FSTS[FFPINx] is clear at the start of a half cycle or full cycle depending on the state of FSTS[FFULL] without regard to the state of FSTS[FFLAGx].</td>
</tr>
<tr>
<td>7-4</td>
<td>Fault Safety Mode</td>
</tr>
<tr>
<td>FSAFE</td>
<td>These read/write bits select the safety mode during manual fault clearing. A reset clears this field.</td>
</tr>
<tr>
<td></td>
<td>FSTS[FFPINx] may indicate a fault condition still exists even though the actual fault signal at the FAULTx pin is clear due to the fault filter latency.</td>
</tr>
<tr>
<td></td>
<td>0000b - Normal mode. PWM outputs disabled by this fault are not enabled until FSTS[FFLAGx] is clear at the start of a half cycle or full cycle depending on the state of FSTS[FFULL] without regard to the state of FSTS[FFPINx]. The PWM outputs disabled by this fault input will not be re-enabled until the actual FAULTx input signal de-asserts since the fault input will combinationally disable the PWM outputs (as programmed in DISMAPn).</td>
</tr>
<tr>
<td></td>
<td>0001b - Safe mode. PWM outputs disabled by this fault are not enabled until FSTS[FFLAGx] is clear and FSTS[FFPINx] is clear at the start of a half cycle or full cycle depending on the state of FSTS[FFULL].</td>
</tr>
<tr>
<td>3-0</td>
<td>Fault Interrupt Enables</td>
</tr>
</tbody>
</table>
This read/write field enables CPU interrupt requests generated by the FAULTx pins. A reset clears this field.

NOTE: The fault protection circuit is independent of the FIE bit and is always active. If a fault is detected, the PWM outputs are disabled according to the disable mapping register.

- 0000b - FAULTx CPU interrupt requests disabled.
- 0001b - FAULTx CPU interrupt requests enabled.

### 55.8.52 Fault Status Register (FSTS0)

#### 55.8.52.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FSTS0</td>
<td>18Eh</td>
</tr>
</tbody>
</table>

#### 55.8.52.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

- FH: Half Cycle Fault Recovery
- FF: Filtered Fault Pins
- FF: FFULL
- FF: FFLAG

#### 55.8.52.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>FH: 15-12</td>
<td>Half Cycle Fault Recovery</td>
</tr>
<tr>
<td>FH: FHALF</td>
<td>These read/write bits are used to control the timing for re-enabling the PWM outputs after a fault condition. These bits apply to both automatic and manual clearing of a fault condition.</td>
</tr>
<tr>
<td>FH: FFULL</td>
<td>Both FHALF and FFULL can be set so that the fault recovery occurs at the start of a full cycle and at the start of a half cycle (as defined by VAL0). If neither FHALF nor FFULL is set, then no fault recovery is possible.</td>
</tr>
<tr>
<td>FH: FFLAG</td>
<td>0000b - PWM outputs are not re-enabled at the start of a half cycle. 0001b - PWM outputs are re-enabled at the start of a half cycle (as defined by VAL0).</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>FH: 11-8</td>
<td>Filtered Fault Pins</td>
</tr>
<tr>
<td>FH: FFPIN</td>
<td>These read-only bits reflect the current state of the filtered FAULTx pins converted to high polarity. A logic 1 indicates a fault condition exists on the filtered FAULTx pin. A reset has no effect on this field.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-4</td>
<td>FFULL</td>
</tr>
<tr>
<td></td>
<td>Full Cycle</td>
</tr>
<tr>
<td></td>
<td>These read/write bits are used to control the timing for re-enabling the PWM outputs after a fault condition. These bits apply to both automatic and manual clearing of a fault condition.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> Both FHALF and FFULL can be set so that the fault recovery occurs at the start of a full cycle and at the start of a half cycle (as defined by VAL0). If neither FHALF nor FFULL is set, then no fault recovery is possible.</td>
</tr>
<tr>
<td></td>
<td>0000b - PWM outputs are not re-enabled at the start of a full cycle</td>
</tr>
<tr>
<td></td>
<td>0001b - PWM outputs are re-enabled at the start of a full cycle</td>
</tr>
<tr>
<td>3-0</td>
<td>FFLAG</td>
</tr>
<tr>
<td></td>
<td>Fault Flags</td>
</tr>
<tr>
<td></td>
<td>These read-only flag is set within two CPU cycles after a transition to active on the FAULTx pin. Clear this bit by writing a logic one to it. A reset clears this field. While the reset value is 0, these bits may be set to 1 by the time they can be read depending on the state of the fault input signals.</td>
</tr>
<tr>
<td></td>
<td>0000b - No fault on the FAULTx pin.</td>
</tr>
<tr>
<td></td>
<td>0001b - Fault on the FAULTx pin.</td>
</tr>
</tbody>
</table>

### 55.8.53 Fault Filter Register (FFILT0)

#### 55.8.53.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FFILT0</td>
<td>190h</td>
</tr>
</tbody>
</table>

#### 55.8.53.2 Function

The settings in this register are shared among each of the fault input filters within the fault channel.

Input filter considerations include:

- The FILT_PER value should be set such that the sampling period is larger than the period of the expected noise. This way a noise spike will only corrupt one sample. The FILT_CNT value should be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the FILT_CNT+3 power.

- The values of FILT_PER and FILT_CNT must also be traded off against the desire for minimal latency in recognizing input transitions. Turning on the input filter (setting FILT_PER to a non-zero value) introduces a latency of (FILT_CNT+4) x FILT_PER x IPBus clock period). Note that even when the filter is enabled, there is a
combinational path to disable the PWM outputs. This is to ensure rapid response to fault conditions and also to ensure fault response if the PWM module loses its clock. The latency induced by the filter will be seen in the time to set FSTS[FFLAG] and FSTS[FFPIN].

55.8.53.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R GST</td>
<td>R</td>
<td>O</td>
<td>FILT_CNT</td>
<td>FILT_PE</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

55.8.53.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 GSTR</td>
<td>Fault Glitch Stretch Enable</td>
</tr>
<tr>
<td>10-8 FILT_CNT</td>
<td>Fault Filter Count</td>
</tr>
<tr>
<td>7-0 FILT_PER</td>
<td>Fault Filter Period</td>
</tr>
</tbody>
</table>

- **GSTR**: Fault Glitch Stretch Enable
  - This bit is used to enable the fault glitch stretching logic. This logic ensures that narrow fault glitches are stretched to be at least 2 IPBus clock cycles wide. In some cases a narrow fault input can cause problems due to the short PWM output shutdown/re-activation time. The stretching logic ensures that a glitch on the fault input, when the fault filter is disabled, will be registered in the fault flags.
  - 0b - Fault input glitch stretching is disabled.
  - 1b - Input fault signals will be stretched to at least 2 IPBus clock cycles.

- **FILT_CNT**: Fault Filter Count
  - These bits represent the number of consecutive samples that must agree prior to the input filter accepting an input transition. The number of samples is the decimal value of this field plus three: the bitfield value of 0-7 represents 3-10 samples, respectively. The value of FILT_CNT affects the input latency.

- **FILT_PER**: Fault Filter Period
  - This 8-bit field applies universally to all fault inputs.
  - These bits represent the sampling period (in IPBus clock cycles) of the fault pin input filter. Each input is sampled multiple times at the rate specified by this field. If FILT_PER is 0x00 (default), then the input filter is bypassed. The value of FILT_PER affects the input latency.

**NOTE:** When changing values for FILT_PER from one non-zero value to another non-zero value, first write a value of zero to clear the filter.
55.8.54 Fault Test Register (FTST0)

55.8.54.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FTST0</td>
<td>192h</td>
</tr>
</tbody>
</table>

55.8.54.2 Diagram

55.8.54.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-1</td>
<td>RESERVED</td>
</tr>
<tr>
<td>0</td>
<td>FTEST</td>
</tr>
<tr>
<td></td>
<td>Fault Test</td>
</tr>
</tbody>
</table>

This read/write bit is used to simulate a fault condition. Setting this bit causes a simulated fault to be sent into all of the fault filters. The condition propagates to the fault flags and possibly the PWM outputs depending on the DISMAPn settings. Clearing this bit removes the simulated fault condition.

- 0b - No fault
- 1b - Cause a simulated fault

55.8.55 Fault Control 2 Register (FCTRL20)

55.8.55.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FCTRL20</td>
<td>194h</td>
</tr>
</tbody>
</table>
55.8.55.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>NOCOMB</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

55.8.55.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-4</td>
<td>RESERVED</td>
</tr>
<tr>
<td>3-0</td>
<td>NOCOMB</td>
</tr>
</tbody>
</table>

No Combinational Path From Fault Input To PWM Output

This read/write field is used to control the combinational path from the fault inputs to the PWM outputs. When these bits are low (default), the corresponding fault inputs have a combinational path to the PWM outputs that are sensitive to these fault inputs (as defined by DISMAP0 and DISMAP1). This combinational path is a safety feature that ensures the output is disabled even if the SOC has a failure of its clocking system. The combinational path also means that a pulse on the fault input can cause a brief disable of the PWM output even if the fault pulse is not wide enough to get through the input filter and be latched in the fault logic. Setting these bits removes the combinational path and uses the filtered and latched fault signals as the fault source to disable the PWM outputs. This eliminates fault glitches from creating PWM output glitches but also increases the latency to respond to a real fault.

- 0000b - There is a combinational link from the fault inputs to the PWM outputs. The fault inputs are combined with the filtered and latched fault signals to disable the PWM outputs.
- 0001b - The direct combinational path from the fault inputs to the PWM outputs is disabled and the filtered and latched fault signals are used to disable the PWM outputs.
Chapter 56
Quadrature Encoder/Decoder (ENC)

56.1 Chip-specific ENC information

Table 56-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

56.2 Introduction

The enhanced quadrature encoder/decoder module interfaces to position/speed sensors that are used in industrial motor control applications. Using 5 input signals (PHASEA, PHASEB, INDEX, TRIGGER, and HOME) from those position/speed sensors, the quadrature decoder module decodes shaft position, revolution count, and speed.

56.2.1 Features

- Includes logic to decode quadrature signals
- Inputs can be connected to a general purpose timer to make low speed velocity measurements
- Configurable digital filter for inputs
- Quadrature decoder filter can be bypassed
- 32-bit position counter capable of modulo counting
- Position counter can be initialized by software or external events
- 16-bit position difference register
- Compare function can indicate when shaft has reached a defined position
- A watchdog timer can detect a non-rotating shaft condition
- Preloadable 16-bit revolution counter
- Maximum count frequency equals the peripheral clock rate

### 56.2.2 System Block Diagram

The next figure shows the block diagram of the quadrature decoder module integrated into an SoC.

![System Block Diagram](image)

**Figure 56-1. System Block Diagram**

### 56.2.3 Decoder Block Diagram
56.2.3.1 Glitch Filter

Because the quadrature decoder logic must sense signal transitions, the signal inputs are first run through a glitch filter. This glitch filter has a digital delay line, which samples multiple time points on the signal and verifies a stable new signal state, before outputting this new signal state to the internal quadrature decoder logic. To adapt to a variety of signal bandwidths, the sample rate of this delay line is programmable.

56.2.3.2 Edge Detect State Machine

The edge detect state machine looks for changes in the 4 possible states of the filtered PHASEA and PHASEB inputs, which are used to calculate the direction of motion. This information is formatted as Count_Up and Count_Down signals. These signals are routed into up to 3 up/down counters:

- Position counter
- Revolution counter
- Position difference counter
56.2.3.3 Position Counter

The 32-bit position counter calculates up or down on every count pulse, generated by the difference of PHASEA and PHASEB. The position counter acts as an integration_info, whose count value is proportional to position. The direction of the count is determined by the Count_Up and Count_Down signals. Position counters may be initialized to a predetermined value by one of 3 different methods:

- Software-triggered event
- INDEX signal transition
- HOME signal transition

The INDEX and HOME signals can be programmed to interrupt the processor. Whenever the position counters (UPOS or LPOS) are read, a snapshot of the

- position counter
- position difference counter
- revolution counter

are each placed into their respective hold registers.

56.2.3.4 Position Difference Counter

The 16-bit position difference counter contains the position difference value occurring between each read of the position register. The position register counts up or down on every count pulse. The position difference counter acts as a differentiator, whose count value is proportional to the change in position since the last time the position counter was read.

When the position register, the position difference counter, or the revolution counter is read, the position difference of the counter's contents is copied into the position difference hold register (POSDH) and the position difference counter is cleared.

56.2.3.5 Position Difference Counter Hold

The Position Difference Counter Hold register stores a copy of the position difference counter at the time that the position register was read. When the position register is read, the position difference of the counter's contents is copied into the position difference hold register (POSDH), and the position difference counter is cleared.
56.2.3.6 Revolution Counter

The 16-bit up/down revolution counter is intended to count or integrate revolutions by counting index pulses. The direction of the count is determined by the Count_Up and Count_Down signals, determined by the Phase A and B inputs. A different count direction on the rising and falling edges of the index pulse indicates that the quadrature encoder changed direction on the index pulse.

56.2.3.7 Watchdog Timer

The watchdog timer ensures that the algorithm is indicating motion in the shaft; 2 successive counts indicate proper operation and will reset the timer.
- The timeout value is programmable.
- When a timeout occurs, an interrupt to the processor can be generated.

56.2.3.8 Pulse Accumulator Functionality

The logic can be programmed to integrate only selected transitions of the PHASEA signal. In this way, the position counter can be used as a pulse accumulator.
- The count direction is up.
- The pulse accumulator can also optionally be initialized by the INDEX input.

56.3 Signal Descriptions

Four external signals are multiplexed to the four pins (PHASEA, PHASEB, INDEX, HOME) of a quad timer module. Two internal signals (TRIGGER, POSMATCH) can be connected to other SoC resources.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PHASEA</td>
<td>The PHASEA input can be connected to one of the phases from a two-phase shaft</td>
</tr>
<tr>
<td></td>
<td>quadrature encoder output. PHASEA and PHASEB are used by the quadrature</td>
</tr>
<tr>
<td></td>
<td>decoder module to indicate a decoder increment has passed, and to calculate</td>
</tr>
<tr>
<td></td>
<td>its direction.</td>
</tr>
<tr>
<td></td>
<td>- When the quadrature decoder module is used as a single phase pulse</td>
</tr>
<tr>
<td></td>
<td>accumulator, PHASEA can also be used as the single input.</td>
</tr>
<tr>
<td></td>
<td>- The PHASEA input can be an input capture channel for one of the timer</td>
</tr>
<tr>
<td></td>
<td>modules (in the SoC), which can be connected to using a crossbar switch.</td>
</tr>
<tr>
<td></td>
<td>Direction for two-phase shaft quadrature encoder output:</td>
</tr>
<tr>
<td></td>
<td>- PHASEA is the leading phase for a shaft rotating in the positive direction.</td>
</tr>
<tr>
<td></td>
<td>- PHASEA is the trailing phase for a shaft rotating in the negative direction.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Table 56-2. Signals (continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
</tr>
</thead>
</table>
| **PHASEB** | Phase B Input | The PHASEB input can be connected to the other phase from a two-phase shaft quadrature encoder output.  
- The PHASEB input can be an input capture channel for one of the timer modules (in the SoC), which can be connected to using a crossbar switch.  
  Direction for two-phase shaft quadrature encoder output:  
- PHASEB is the trailing phase for a shaft rotating in the positive direction.  
- PHASEB is the leading phase for a shaft rotating in the negative direction. |
| **INDEX** | Index Input | • Normally connected to the index pulse output of a quadrature encoder, the INDEX pulse can optionally reset the position counter and the pulse accumulator of the quadrature decoder module. The INDEX pulse also causes a change of state on the revolution counter. The direction of this state change (increment or decrement) is calculated from the PHASEA and PHASEB inputs.  
- The INDEX input can be an input capture channel for one of the timer modules (in the SoC), which can be connected to using a crossbar switch. |
| **HOME** | Home Switch Input | The HOME input can be used by the quadrature decoder and the timer module.  
- The HOME input can be used to trigger the initialization of the position counters (UPOS and LPOS). Often the HOME signal is connected to a sensor on the motor or machine, sending notification that it has reached a defined home position.  
- The HOME signal can be connected to the timer module (in the SoC) using a crossbar switch. |
| **TRIGGER** | Trigger Input | The TRIGGER input can be used  
- to clear the position counters (UPOS and LPOS)  
- to take a snapshot of the POS, REV, and POSD registers  
- to indicate an elapsed time period, by connecting the TRIGGER input signal to a periodic pulse generator or timer |
| **POSMATCH** | Position Match Output | • To record the time at which the position of the shaft matches a user-defined compare value (COMP), the POSMATCH output can be used to trigger a timer channel.  
- Alternatively, to record the time at which the position information was read, (when the position counters (UPOS and LPOS), revolution counter (REV), or position difference counter (POSD) registers are read) the POSMATCH output can be used to trigger a timer channel. |

### 56.4 Functional Description

The next timing diagram shows the basic operation of a quadrature incremental position quadrature decoder.
56.4.1 Positive versus Negative Direction

A typical quadrature encoder has 3 outputs: PHASEA signal, PHASEB signal, INDEX pulse (not shown).

- If PHASEA leads PHASEB, then motion is in the positive direction.
- If PHASEA trails PHASEB, then motion is in the negative direction.

Transitions on these phases can be integrated to yield position or differentiated to yield velocity. The quadrature decoder is designed to perform these functions in hardware.

56.4.2 Prescaler for Slow or Fast Speed Measurement

- For applications with a fast moving shaft encoder, the speed can be computed by calculating the change in the position counter per unit time, or by reading the position difference counter register (POSD) and calculating speed.
- For applications with slow motor speeds and low line count quadrature encoders, the timer module enables high resolution velocity measurements by measuring the time period between quadrature phases.
  - The timer module uses a 16-bit free running counter operated from a prescaled version of the IPBus clock.
  - The prescaler divides the IPBus clock by values ranging from 1 to 128. A 60 MHz IPBus clock frequency would yield a resolution of from 17 ns to 2.1 μs and a maximum count period of from 1.09 ms to 140 ms. For example, with a 1000-tooth decoder, speeds could be calculated down to 0.11 rpm using a prescaler.
### 56.4.3 Holding Registers and Initializing Registers

Hold registers are associated with 3 types of counters:

- Position
- Position difference
- Revolution

When any of the counter registers is read, the contents of each counter register is written to the corresponding hold register. Taking a snapshot of the counters' values provides a consistent view of a system's position and the velocity to be attained. To capture a time stamp of when these registers are read, use the POSMATCH output with a timer channel.

The position counter is 32 bits wide. To ensure that the position counter can be reliably initialized with two 16-bit accesses, two registers (an upper and a lower initialization register) are provided. The upper initialization register (UINIT) and lower initialization register (LINIT) should be loaded with the desired value. Next, the position counter can be loaded by writing 1 to the Software-Triggered Initialization of Position Counters UPOS and LPOS bit (CTRL[SWIP]). Alternatively, either the INDEX-Triggered Initialization of Position Counters UPOS and LPOS bit (CTRL[XIP]) or the Enable HOME to Initialize Position Counters UPOS and LPOS bit (CTRL[HIP]) can enable the position counter to be initialized in response to a HOME or INDEX signal transition.

### 56.5 Resets

There are no special requirements. This module is reset by any system reset.

### 56.6 Clocks

The IPBus clock is the only clock required by this module in normal operation.

### 56.7 Interrupts

The following table lists the module interrupts.

<table>
<thead>
<tr>
<th>Core Interrupt</th>
<th>Interrupt Flag</th>
<th>Interrupt Enable</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>iipi_int_home</td>
<td>CTRL[HIRQ]</td>
<td>CTRL[HIE]</td>
<td>HOME signal transition interrupt</td>
</tr>
<tr>
<td>iipi_int_index</td>
<td>CTRL[XIRQ]</td>
<td>CTRL[XIE]</td>
<td>INDEX signal transition interrupt or roll-over/under interrupt</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 56-3. Interrupt Summary (continued)

<table>
<thead>
<tr>
<th>Core Interrupt</th>
<th>Interrupt Flag</th>
<th>Interrupt Enable</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL2[ROIRQ]</td>
<td>CTRL2[ROIE]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>CTRL2[RUIRQ]</td>
<td>CTRL2[RUIE]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ipi_int_wdog</td>
<td>CTRL[DIRQ]</td>
<td>CTRL[DIE]</td>
<td>Watchdog timeout interrupt</td>
</tr>
<tr>
<td>ipi_int_comp</td>
<td>CTRL[CMPIRQ]</td>
<td>CTRL[CMPIE]</td>
<td>Compare match interrupt</td>
</tr>
</tbody>
</table>

56.8 ENC register descriptions

The address of a register is the sum of a base address and an address offset.
- Base address is defined at the MCU level
- Address offset is defined at the module level

For the base address, see the specific chip documentation. All memory locations base and offsets are given in hex.

56.8.1 ENC Memory map

ENCₙ base address: 403C_8000h + (n-1)×4000h, where n is from 1 to 4.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Control Register (CTRL)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>2h</td>
<td>Input Filter Register (FILT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>4h</td>
<td>Watchdog Timeout Register (WTR)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>6h</td>
<td>Position Difference Counter Register (POSD)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>8h</td>
<td>Position Difference Hold Register (POSDH)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>Ah</td>
<td>Revolution Counter Register (REV)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>Revolution Hold Register (REVH)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>Eh</td>
<td>Upper Position Counter Register (UPOS)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>10h</td>
<td>Lower Position Counter Register (LPOS)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>12h</td>
<td>Upper Position Hold Register (UPOSH)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>14h</td>
<td>Lower Position Hold Register (LPOSH)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>16h</td>
<td>Upper Initialization Register (UINIT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>18h</td>
<td>Lower Initialization Register (LINIT)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>1Ah</td>
<td>Input Monitor Register (IMR)</td>
<td>16</td>
<td>RO</td>
<td>0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>Test Register (TST)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 56.8.2 Control Register (CTRL)

#### 56.8.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL</td>
<td>0h</td>
</tr>
</tbody>
</table>

#### 56.8.2.2 Diagram

![Diagram of Control Register (CTRL)]

#### 56.8.2.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>HOME Signal Transition Interrupt Request</td>
</tr>
</tbody>
</table>
| HIRQ  | HOME Signal Transition Interrupt Request is set when a transition on the HOME signal occurs, according to the Use Negative Edge of HOME Input bit (CTRL[HNE]). If HOME Signal Transition Interrupt Request bit is set and HOME Interrupt Enable bit (CTRL[HIE]) is set, then a HOME interrupt occurs.  
- HOME Signal Transition Interrupt Request bit will remain set until it is cleared by software  
- Write a one to this bit (HIRQ) to clear it |

0b - No interrupt

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>14</td>
<td>HOME Interrupt Enable</td>
</tr>
<tr>
<td>HIE</td>
<td>Enables/disables HOME signal interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>13</td>
<td>Enable HOME to Initialize Position Counters UPOS and LPOS</td>
</tr>
<tr>
<td>HIP</td>
<td>Enables the position counter to be initialized by the HOME signal.</td>
</tr>
<tr>
<td></td>
<td>0b - No action</td>
</tr>
<tr>
<td></td>
<td>1b - HOME signal initializes the position counter</td>
</tr>
<tr>
<td>12</td>
<td>Use Negative Edge of HOME Input</td>
</tr>
<tr>
<td>HNE</td>
<td>Selects using the positive/negative edge of the HOME input.</td>
</tr>
<tr>
<td></td>
<td>0b - Use positive-going edge-to-trigger initialization of position counters UPOS and LPOS</td>
</tr>
<tr>
<td></td>
<td>1b - Use negative-going edge-to-trigger initialization of position counters UPOS and LPOS</td>
</tr>
<tr>
<td>11</td>
<td>Software-Triggered Initialization of Position Counters UPOS and LPOS</td>
</tr>
<tr>
<td>SWIP</td>
<td>Writing 1 to Software-Triggered Initialization of Position Counters bit will transfer the UINIT and LINIT contents to UPOS and LPOS (thereby initializing those counters).</td>
</tr>
<tr>
<td></td>
<td>• Software-Triggered Initialization of Position Counters bit is always read as 0.</td>
</tr>
<tr>
<td></td>
<td>0b - No action</td>
</tr>
<tr>
<td></td>
<td>1b - Initialize position counter (using upper and lower initialization registers, UINIT and LINIT)</td>
</tr>
<tr>
<td>10</td>
<td>Enable Reverse Direction Counting</td>
</tr>
<tr>
<td>REV</td>
<td>Selects the direction of the count (how the quadrature signal is interpreted).</td>
</tr>
<tr>
<td></td>
<td>0b - Count normally</td>
</tr>
<tr>
<td></td>
<td>1b - Count in the reverse direction</td>
</tr>
<tr>
<td>9</td>
<td>Enable Signal Phase Count Mode</td>
</tr>
<tr>
<td>PH1</td>
<td>Bypass/use the quadrature decoder logic.</td>
</tr>
<tr>
<td></td>
<td>0b - Use the standard quadrature decoder, where PHASEA and PHASEB represent a two-phase quadrature signal.</td>
</tr>
<tr>
<td></td>
<td>1b - Bypass the quadrature decoder. A positive transition of the PHASEA input generates a count signal. The PHASEB input and the REV bit control the counter direction: If CTRL[REV] = 0, PHASEB = 0, then count up If CTRL[REV] = 1, PHASEB = 1, then count up If CTRL[REV] = 0, PHASEB = 1, then count down If CTRL[REV] = 1, PHASEB = 0, then count down</td>
</tr>
<tr>
<td>8</td>
<td>INDEX Pulse Interrupt Request</td>
</tr>
<tr>
<td>XIRQ</td>
<td>INDEX Pulse Interrupt Request is set when an INDEX interrupt occurs.</td>
</tr>
<tr>
<td></td>
<td>• INDEX Pulse Interrupt Request will remain set until cleared by software</td>
</tr>
<tr>
<td></td>
<td>• Write 1 to this bit (XIRQ) to clear it</td>
</tr>
<tr>
<td></td>
<td>0b - INDEX pulse interrupt has not occurred</td>
</tr>
<tr>
<td></td>
<td>1b - INDEX pulse interrupt has occurred</td>
</tr>
<tr>
<td>7</td>
<td>INDEX Pulse Interrupt Enable</td>
</tr>
<tr>
<td>XIE</td>
<td>Enables/disables INDEX pulse interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>6</td>
<td>INDEX Triggered Initialization of Position Counters UPOS and LPOS</td>
</tr>
<tr>
<td>XIP</td>
<td>Enables/disables the position counter to be initialized by the INDEX pulse.</td>
</tr>
<tr>
<td></td>
<td>0b - INDEX pulse does not initialize the position counter</td>
</tr>
<tr>
<td></td>
<td>1b - INDEX pulse initializes the position counter</td>
</tr>
</tbody>
</table>
| 5     | Use Negative Edge of INDEX Pulse  

Table continues on the next page...
### ENC register descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>XNE</td>
<td>Selects the positive/negative edge of the INDEX pulse used to initialize the position counter.</td>
</tr>
<tr>
<td></td>
<td>0b - Use positive edge of INDEX pulse</td>
</tr>
<tr>
<td></td>
<td>1b - Use negative edge of INDEX pulse</td>
</tr>
<tr>
<td>4 DIRQ</td>
<td>Watchdog Timeout Interrupt Request</td>
</tr>
<tr>
<td></td>
<td>Watchdog Timeout Interrupt Request is set when a watchdog timeout interrupt occurs.</td>
</tr>
<tr>
<td></td>
<td>• Watchdog Timeout Interrupt Request will remain set until cleared by software</td>
</tr>
<tr>
<td></td>
<td>• Write a one to this bit (DIRQ) to clear it</td>
</tr>
<tr>
<td></td>
<td>• Watchdog Timeout Interrupt Request bit is also cleared when Watchdog Enable (CTRL[WDE]) is disabled (=0)</td>
</tr>
<tr>
<td></td>
<td>0b - No Watchdog timeout interrupt has occurred</td>
</tr>
<tr>
<td></td>
<td>1b - Watchdog timeout interrupt has occurred</td>
</tr>
<tr>
<td>3 DIE</td>
<td>Watchdog Timeout Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>Enables/disables watchdog timeout interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>2 WDE</td>
<td>Watchdog Enable</td>
</tr>
<tr>
<td></td>
<td>Enables/disables the watchdog timer that is monitoring the PHASEA and PHASEB inputs for motor movement.</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>1 CMPIRQ</td>
<td>Compare Interrupt Request</td>
</tr>
<tr>
<td></td>
<td>Compare Interrupt Request is set when the counter matches the COMP value.</td>
</tr>
<tr>
<td></td>
<td>• Compare Interrupt Request remains set until cleared by software</td>
</tr>
<tr>
<td></td>
<td>• Write 1 to this bit (CMPIRQ) to clear it</td>
</tr>
<tr>
<td></td>
<td>0b - No match has occurred (the counter does not match the COMP value)</td>
</tr>
<tr>
<td></td>
<td>1b - COMP match has occurred (the counter matches the COMP value)</td>
</tr>
<tr>
<td>0 CMPIE</td>
<td>Compare Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>Enables/disables compare interrupts.</td>
</tr>
<tr>
<td></td>
<td>0b - Disabled</td>
</tr>
<tr>
<td></td>
<td>1b - Enabled</td>
</tr>
</tbody>
</table>

### 56.8.3 Input Filter Register (FILT)

#### 56.8.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>FILT</td>
<td>2h</td>
</tr>
</tbody>
</table>

NXP Semiconductors
56.8.3.2 Function

The Input Filter Register sets the values of the input filter sample period (FILT_PER) and the input filter sample count (FILT_CNT).

- The Input Filter Sample Period (FILT_PER) should be set so that the sampling period is larger than the period of the expected noise. Doing this means that a noise spike will only corrupt one sample.
- The Input Filter Sample Count (FILT_CNT) should be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the power of FILT_CNT + 3.

The values of the Input Filter Sample Period (FILT_PER) and the Input Filter Sample Count (FILT_CNT) must also be traded off against the desire for minimal latency in recognizing valid input transitions. Turning on the input filter (setting the Input Filter Sample Period (FILT_PER) to a non-zero value) introduces a latency of \(((\text{FILT_CNT} + 3) \times \text{FILT_PER} + 2)\) IPBus clock periods.

The filter latency can be measured:

- Drive the quadrature decoder inputs (PHASEA, PHASEB, INDEX, HOME)
- Monitor the filtered output in the Input Monitor Register (IMR)
- Determine how many IPBus clock cycles that it takes before the output shows up, by using the following equations, where \(f\) is FILT_PER and \(s\) is FILT_CNT.
  - \(\text{DELAY} \text{ (IPBus clock cycles)} = f \times (s+3) + 1\) (to read the filtered output)
  - \(\text{DELAY} \text{ (IPBus clock cycles)} = f \times (s+3) + 2\) (to monitor the output in the IMR)

One more additional IPBus clock cycle is needed to read the filtered output, and 2 more IPBus clock cycles are needed to monitor the filtered output in the IMR. The sample rate is set when it reaches the number \(f\). The following examples use the preceding equations:

- Example: when \(f = 0\), the filter is bypassed: \(\text{DELAY} = 1\) or 2 clock cycles.
- Example: when \(f = 5\) and \(s = 2\): \(\text{DELAY} = 5 \times (2+3) + (1 \text{ or } 2) = 26\) or 27 clock cycles.

56.8.3.3 Diagram

![Diagram](image)

### Bits

<table>
<thead>
<tr>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td>FILT_CNT</td>
<td></td>
<td>FILT_PER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset:

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
56.8.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10-8</td>
<td>Input Filter Sample Count</td>
</tr>
<tr>
<td>FILT_CNT</td>
<td>The Input Filter Sample Count represents the number of consecutive samples that must agree, before the input filter accepts an input transition.</td>
</tr>
<tr>
<td></td>
<td>• A value of 0x0 represents 3 samples</td>
</tr>
<tr>
<td></td>
<td>• A value of 0x7 represents 10 samples</td>
</tr>
<tr>
<td></td>
<td>The value of the Input Filter Sample Count (FILT_CNT) affects the input latency.</td>
</tr>
<tr>
<td>7-0</td>
<td>Input Filter Sample Period</td>
</tr>
<tr>
<td>FILT_PER</td>
<td>The Input Filter Sample Period represents the sampling period (in IPBus clock cycles) of the decoder input signals. Each input is sampled multiple times at the rate specified by the Input Filter Sample Period.</td>
</tr>
<tr>
<td></td>
<td>• If FILT_PER is 0x00 (default), then the input filter is bypassed. Bypassing the digital filter enables the position/position difference counters to operate with count rates up to the IPBus frequency.</td>
</tr>
<tr>
<td></td>
<td>• The value of the Input Filter Sample Period (FILT_PER) affects the input latency.</td>
</tr>
<tr>
<td></td>
<td>• When changing the Input Filter Sample Period (FILT_PER) from a non-zero value to another non-zero value, write a value of 0 first, to clear the filter.</td>
</tr>
</tbody>
</table>

56.8.4 Watchdog Timeout Register (WTR)

56.8.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WTR</td>
<td>4h</td>
</tr>
</tbody>
</table>

56.8.4.2 Function

The Watchdog Timeout Register stores the timeout count for the quadrature decoder module watchdog timer. This quadrature decoder module watchdog timer is separate from any other watchdog timer(s) that may also be in the device.
56.8.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>WDOG</td>
</tr>
<tr>
<td>WDOG</td>
<td>WDOG[15:0] is a binary representation of the number of clock cycles, plus one clock cycle that the watchdog timer counts before timing out (and optionally generating an interrupt).</td>
</tr>
</tbody>
</table>

56.8.5 Position Difference Counter Register (POSD)

56.8.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>POSD</td>
<td>6h</td>
</tr>
</tbody>
</table>

56.8.5.2 Function

The Position Difference Counter Register contains the position change in value occurring between each read of the Position Register. The value of the Position Difference Counter Register can be used to calculate velocity.

- The 16-bit Position Difference Counter computes up or down on every count pulse.
- This Position Difference Counter acts as a differentiator, whose count value is proportional to the change in position since the last time that the Position Counter was read.
- When the Position Registers (UPOS or LPOS), the Position Difference Counter (POSD), or the Revolution Counter (REV) is read, the Position Difference Counter's contents are copied into the Position Difference Hold Register (POSDH) and the Position Difference Counter is cleared.
56.8.5.3 Diagram

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| R    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W    |    |    |    |    |    |    |   | POSD |   |   |   |   |   |   |   |   |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

56.8.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>POSD</td>
</tr>
<tr>
<td>POSD</td>
<td>The position change in value between each read of the Position Register.</td>
</tr>
</tbody>
</table>

56.8.6 Position Difference Hold Register (POSDH)

56.8.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>POSDH</td>
<td>8h</td>
</tr>
</tbody>
</table>

56.8.6.2 Function

The Position Difference Hold Register register contains a snapshot of the value of the Position Difference Counter Register (POSD). The value of the Position Difference Hold Register (POSDH) can be used to calculate velocity.

56.8.6.3 Diagram

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| R    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W    |    |    |    |    |    |    |   | POSDH |   |   |   |   |   |   |   |   |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
56.8.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>POSDH</td>
</tr>
<tr>
<td>POSDH</td>
<td>The value of the POSD register</td>
</tr>
</tbody>
</table>

56.8.7 Revolution Counter Register (REV)

56.8.7.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>REV</td>
<td>Ah</td>
</tr>
</tbody>
</table>

56.8.7.2 Function
Contains the current value of the Revolution Counter.

56.8.7.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>REV</td>
</tr>
<tr>
<td>REV</td>
<td>The current value of the Revolution Counter</td>
</tr>
</tbody>
</table>
56.8.8 Revolution Hold Register (REVH)

56.8.8.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>REVH</td>
<td>Ch</td>
</tr>
</tbody>
</table>

56.8.8.2 Function
Contains a snapshot of the value of the Revolution Counter Register (REV).

56.8.8.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>REVH</td>
</tr>
<tr>
<td>REVH</td>
<td>The value of the Revolution Counter Register (REV)</td>
</tr>
</tbody>
</table>

56.8.9 Upper Position Counter Register (UPOS)

56.8.9.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UPOS</td>
<td>Eh</td>
</tr>
</tbody>
</table>
56.8.9.2  Function
Contains the upper (most significant) half of the Position Counter. This is the binary count from the Position Counter.

56.8.9.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>POS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.9.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>POS</td>
</tr>
<tr>
<td>POS</td>
<td>The upper (most significant) half of the Position Counter</td>
</tr>
</tbody>
</table>

56.8.10  Lower Position Counter Register (LPOS)

56.8.10.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPOS</td>
<td>10h</td>
</tr>
</tbody>
</table>

56.8.10.2  Function
Contains the lower (least significant) half of the Position Counter. This is the binary count from the Position Counter.
56.8.10.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>POS</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.10.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>POS</td>
</tr>
<tr>
<td>POS</td>
<td>The lower (least significant) half of the Position Counter</td>
</tr>
</tbody>
</table>

56.8.11  Upper Position Hold Register (UPOSH)

56.8.11.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UPOSH</td>
<td>12h</td>
</tr>
</tbody>
</table>

56.8.11.2  Function

Contains a snapshot of the Upper Position Counter Register (UPOS register).

56.8.11.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>POS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
56.8.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>POSH</td>
</tr>
<tr>
<td>POSH</td>
<td>The value of the Upper Position Counter Register (UPOS)</td>
</tr>
</tbody>
</table>

56.8.12 Lower Position Hold Register (LPOSH)

56.8.12.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPOSH</td>
<td>14h</td>
</tr>
</tbody>
</table>

56.8.12.2 Function

Contains a snapshot of the Lower Position Counter Register (LPOS).

56.8.12.3 Diagram

```
Bits 15 14 13 12 11 10  9  8 |  7  6  5  4  3  2  1  0
R    POSH
W
Reset 0  0  0  0  0  0  0  0 |  0  0  0  0  0  0  0  0
```

56.8.12.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>POSH</td>
</tr>
<tr>
<td>POSH</td>
<td>The value of the Lower Position Counter Register (LPOS)</td>
</tr>
</tbody>
</table>
56.8.13 Upper Initialization Register (UINIT)

56.8.13.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UINIT</td>
<td>16h</td>
</tr>
</tbody>
</table>

56.8.13.2 Function
Contains the value to be used to initialize the upper half of the position counter (UPOS).

56.8.13.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>INIT</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.13.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>INIT</td>
</tr>
<tr>
<td>INIT</td>
<td>The value to be used to initialize the upper half of the position counter (UPOS)</td>
</tr>
</tbody>
</table>

56.8.14 Lower Initialization Register (LINIT)

56.8.14.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LINIT</td>
<td>18h</td>
</tr>
</tbody>
</table>

ENC register descriptions

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors
56.8.14.2 Function
Contains the value to be used to initialize the lower half of the position counter (LPOS).

56.8.14.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>INIT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.14.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>INIT</td>
</tr>
<tr>
<td>INIT</td>
<td>The value to be used to initialize the lower half of the position counter (LPOS)</td>
</tr>
</tbody>
</table>

56.8.15 Input Monitor Register (IMR)

56.8.15.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>IMR</td>
<td>1Ah</td>
</tr>
</tbody>
</table>

56.8.15.2 Function
The Input Monitor Register contains the values of the raw and filtered PHASEA, PHASEB, INDEX, and HOME input signals. The reset value depends on the values of the raw and filtered values of PHASEA, PHASEB, INDEX, and HOME input signals:
- If these input pins are connected to a pull-up, then bits 0–7 of the IMR are all ones.
- If these input pins are connected to a pull-down device, then bits 0–7 of the Input Monitor Register (IMR) are all zeros.
56.8.15.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>FPHA</td>
</tr>
<tr>
<td>FPHA</td>
<td>Filtered version of PHASEA input</td>
</tr>
<tr>
<td>6</td>
<td>FPHB</td>
</tr>
<tr>
<td>FPHB</td>
<td>Filtered version of PHASEB input</td>
</tr>
<tr>
<td>5</td>
<td>FIND</td>
</tr>
<tr>
<td>FIND</td>
<td>Filtered version of INDEX input</td>
</tr>
<tr>
<td>4</td>
<td>FHOM</td>
</tr>
<tr>
<td>FHOM</td>
<td>Filtered version of HOME input</td>
</tr>
<tr>
<td>3</td>
<td>PHA</td>
</tr>
<tr>
<td>PHA</td>
<td>Raw PHASEA input</td>
</tr>
<tr>
<td>2</td>
<td>PHB</td>
</tr>
<tr>
<td>PHB</td>
<td>Raw PHASEB input</td>
</tr>
<tr>
<td>1</td>
<td>INDEX</td>
</tr>
<tr>
<td>INDEX</td>
<td>Raw INDEX input</td>
</tr>
<tr>
<td>0</td>
<td>HOME</td>
</tr>
<tr>
<td>HOME</td>
<td>The raw HOME input</td>
</tr>
</tbody>
</table>
56.8.16.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TST</td>
<td>1Ch</td>
</tr>
</tbody>
</table>

56.8.16.2 Function
The Test Register controls and sets the frequency of a quadrature signal generator; it provides a quadrature test signal to the inputs of the quadrature decoder module.

- The TEST_COUNT value is counted down to zero when the test module is enabled (TEN = 1) and the count is enabled (TCE = 1).
- Each count value of one represents a single quadrature cycle interpreted as a count of one by the position counter (UPOS and LPOS) if it is enabled (TEN = 1, TCE = 1).
- Repeated writing of new values to TEST_COUNT can cause an extra phase transition and therefore an extra count by the Position Counter.
- The period field determines the length (in IPBus clock cycles) of each quadrature cycle phase.

The Test Register is a factory test feature; however, it can also be useful in customer software development and testing.

56.8.16.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>TEN</td>
<td>TCE</td>
<td>QDN</td>
<td>TEST_PERIOD</td>
<td>TEST_COUNT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

56.8.16.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Test Mode Enable</td>
</tr>
<tr>
<td>TEN</td>
<td>Connects the test module to inputs of the quadrature decoder module.</td>
</tr>
<tr>
<td>14</td>
<td>Test Counter Enable</td>
</tr>
<tr>
<td>TCE</td>
<td>Connects the test counter to inputs of the quadrature decoder module.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## ENC register descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0b - Disabled</td>
<td>1b - Enabled</td>
</tr>
<tr>
<td>13</td>
<td>Quadrature Decoder Negative Signal</td>
</tr>
<tr>
<td>Selects whether a negative or positive Quadrature Decoder signal is generated.</td>
<td></td>
</tr>
<tr>
<td>0b - Generates a positive quadrature decoder signal</td>
<td>1b - Generates a negative quadrature decoder signal</td>
</tr>
<tr>
<td>12-8</td>
<td>TEST_PERIOD</td>
</tr>
<tr>
<td>Period of quadrature phase in IPBus clock cycles</td>
<td></td>
</tr>
<tr>
<td>7-0</td>
<td>TEST_COUNT</td>
</tr>
<tr>
<td>The number of quadrature advances to generate</td>
<td></td>
</tr>
</tbody>
</table>

### 56.8.17 Control 2 Register (CTRL2)

### 56.8.17.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL2</td>
<td>1Eh</td>
</tr>
</tbody>
</table>

### 56.8.17.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
<td>O</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 56.8.17.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-10</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| OUTCTL | Output Control controls the pulsing of the POSMATCH output signal. This can control when a timer channel captures a timestamp.  
- 0b - POSMATCH pulses when a match occurs between the position counters (POS) and the compare value (COMP)  
- 1b - POSMATCH pulses when the UPOS, LPOS, REV, or POSD registers are read |
| REVMOD | Revolution Counter Modulus Enable selects how the revolution counter (REV) is incremented/decremented. By default, the revolution counter is controlled based on the count direction and the INDEX pulse. As an option, the revolution counter can be controlled using the roll-over/under detection during modulo counting.  
- 0b - Use INDEX pulse to increment/decrement revolution counter (REV)  
- 1b - Use modulus counting roll-over/under to increment/decrement revolution counter (REV) |
| ROIRQ | Roll-over Interrupt Request bit is set (=1) when the position counter (POS) rolls over from the MOD value to the INIT value, or from 0xFFFF_FFFF to 0x0000_0000.  
- Roll-over Interrupt Request will remain set until cleared by software  
- Write a one to this bit (ROIRQ) to clear it  
- 0b - No roll-over has occurred  
- 1b - Roll-over has occurred |
| ROIE | Roll-over Interrupt Enable read/write bit enables roll-over interrupts, based on Roll-under Interrupt Request (CTRL2[ROIRQ]) being set. This roll-over interrupt is combined with the index interrupt signal.  
- 0b - Disabled  
- 1b - Enabled |
| RUIRQ | Roll-under Interrupt Request bit is set (=1) when the position counter (POS) rolls under from the INIT value to the MOD value, or from 0x0000_0000 to 0xFFFF_FFFF.  
- Roll-under Interrupt Request will remain set until cleared by software  
- Write a one to this bit (RUIRQ) to clear it  
- 0b - No roll-under has occurred  
- 1b - Roll-under has occurred |
| RUIE | Roll-under Interrupt Enable read/write bit enables roll-under interrupts, based on the Roll-over Interrupt Request bit (CTRL2[RUIRQ]) being set. This roll-under interrupt is combined with the index interrupt signal.  
- 0b - Disabled  
- 1b - Enabled |
| DIR | Count Direction Flag indicates the direction of the last count.  
- 0b - Last count was in the down direction  
- 1b - Last count was in the up direction |
| MOD | Enable Modulo Counting  
- When Enable Modulo Counting is set (=1), it allows the position counters (UPOS and LPOS) to count in a modulo fashion, using MOD and INIT as the upper and lower bounds of the counting range. During modulo counting:  
*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| UPDPOS | Update Position Registers  
  - When Update Position Registers is set (=1), it allows the TRIGGER input to clear the POSD, REV, UPOS, and LPOS registers  
  - When Update Position Registers is clear (=0), the POSD, REV, UPOS, and LPOS registers ignore the TRIGGER input |
| UPDHL | Update Hold Registers  
  - When Update Hold Registers is set (=1), it allows the TRIGGER input to cause an update of the POSDH, REVH, UPOSH, and LPOSH registers  
  - When Update Hold Registers is clear (=0), the hold registers (POSDH, REVH, UPOSH, LPOSH) are not updated by the TRIGGER input |

Updating the Position Difference Hold Register (POSDH) will also cause the Position Difference Counter Register (POSD) to be cleared.  
0b - Disable updates of hold registers on the rising edge of TRIGGER input signal  
1b - Enable updates of hold registers on the rising edge of TRIGGER input signal

### 56.8.18 Upper Modulus Register (UMOD)

#### 56.8.18.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UMOD</td>
<td>20h</td>
</tr>
</tbody>
</table>

#### 56.8.18.2 Function

The Upper Modulus Register contains the upper (most significant) half of the Modulus register. MOD acts as the upper bound during modulo counting, and as the upper reload value when rolling over from the lower bound.
56.8.18.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MOD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

56.8.18.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>MOD</td>
</tr>
<tr>
<td>MOD</td>
<td>Upper (most significant) half of the Modulus register</td>
</tr>
</tbody>
</table>

56.8.19 Lower Modulus Register (LMod)

56.8.19.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LMOD</td>
<td>22h</td>
</tr>
</tbody>
</table>

56.8.19.2 Function

The Lower Modulus Register contains the lower (least significant) half of the Modulus register. MOD acts as the upper bound during modulo counting, and as the upper reload value when rolling over from the lower bound.

56.8.19.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MOD</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
ENC register descriptions

56.8.19.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>MOD</td>
</tr>
<tr>
<td>MOD</td>
<td>Lower (least significant) half of the Modulus register</td>
</tr>
</tbody>
</table>

56.8.20 Upper Position Compare Register (UCOMP)

56.8.20.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>UCOMP</td>
<td>24h</td>
</tr>
</tbody>
</table>

56.8.20.2 Function

The Upper Position Compare Register contains the upper (most significant) half of the Position Compare register. When the value of the Position counter (POS) matches the value of the Position Compare register (COMP), the Compare Interrupt Request flag (CTRL[CMPIRQ]) is set and the POSMATCH output is asserted.

56.8.20.3 Diagram

```
Bits 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0
R
W
Reset 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1

COMP
```

56.8.20.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>COMP</td>
</tr>
<tr>
<td>COMP</td>
<td>Upper (most significant) half of the Position Compare register</td>
</tr>
</tbody>
</table>
56.8.21 Lower Position Compare Register (LCOMP)

56.8.21.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>LCOMP</td>
<td>26h</td>
</tr>
</tbody>
</table>

56.8.21.2 Function

The Lower Position Compare Register contains the lower (least significant) half of the Position Compare register. When the value of the Position counter (POS) matches the value of the Position Compare register (COMP), the Compare Interrupt Request flag (CTRL[CMPIRQ]) is set and the POSMATCH output is asserted.

56.8.21.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

56.8.21.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>COMP</td>
</tr>
<tr>
<td>COMP</td>
<td>Lower (least significant) half of the Position Compare register</td>
</tr>
</tbody>
</table>
Chapter 57
Watchdog Timer (WDOG1-2)

57.1 Chip-specific WDOG information

Table 57-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
<tr>
<td>and XBAR Assignments</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

57.2 Overview

The Watchdog Timer (WDOG) protects against system failures by providing a method by which to escape from unexpected events or programming errors.

Once the WDOG is activated, it must be serviced by the software on a periodic basis. If servicing does not take place, the timer times out. Upon timeout, the WDOG1 asserts the internal system reset signal, WDOG_RESET_B_DEB to the System Reset Controller (SRC); and WDOG2 asserts interrupt to SNVS, to report the security violation condition.

There is also a provision for WDOG(ipp_wdog) signal assertion by timeout counter expiration. There is an option of programmable interrupt generation before the counter actually times out. The time at which the interrupt needs to be generated prior to counter...
timeout is programmable. There is a power down counter which is enabled out of any reset (POR, Warm/Cold). This counter has a fixed timeout period of 16 seconds, upon which it asserts the WDOG(ipp_wdog) signal.

Flow diagrams for the timeout counter, power down counter and interrupt operations are shown in Flow Diagrams.

**Figure 57-1. WDOG Diagram**

**NOTE**
WDOG-1 means WDOG_B when it presents on a PAD.

### 57.2.1 Features

The WDOG features are listed below:

- Configurable timeout counter with timeout periods from 0.5 to 128 seconds which, after timeout expiration, result in the assertion of WDOG_RESET_B_DEB reset signal.
- Time resolution of 0.5 seconds
- Configurable timeout counter that can be programmed to run or stop during low-power modes
• Configurable timeout counter that can be programmed to run or stop during DEBUG mode
• Programmable interrupt generation prior to timeout
• The duration between interrupt and timeout events can be programmed from 0 to 127.5 seconds in steps of 0.5 seconds.
• Power down counter with fixed timeout period of 16 seconds, which if not disabled after reset will assert WDOG_B (ipp_wdog) signal low
  • Power down counter will be enabled out of any reset (POR, Warm / Cold reset) by default.

57.3 External signals

Table 57-2. WDOG External Signals

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>WDOG1_ANY</td>
<td>Global WDOG signal. It is AND of WDOG1_B signal and WDOG2_B signal.</td>
<td>O</td>
</tr>
<tr>
<td>WDOG1_B</td>
<td>This signal can be routed to external pin of the chip. It is asserted by a software request (set the WDA bit), by power down counter and timeout counter expiration.</td>
<td>O</td>
</tr>
<tr>
<td>WDOG1_RST_B_DEB</td>
<td>This signal is a reset source for the chip.</td>
<td>O</td>
</tr>
<tr>
<td>WDOG2_B</td>
<td>This signal can be routed to external pin of the chip. It is asserted by a software request (set the WDA bit), by power down counter and timeout counter expiration.</td>
<td>O</td>
</tr>
<tr>
<td>WDOG2_RST_B_DEB</td>
<td>This signal asserts interrupt to SNVS to report the security violation condition.</td>
<td>O</td>
</tr>
</tbody>
</table>

See more detailed information in the Pin MUX chapter.

57.4 Clocks

This section describes clocks and special clocking requirements of the block.

The WDOG uses the low frequency reference clock for its counter and control operations. The peripheral bus clock is used for register read/write operations.

The following table describes the clock sources for WDOG. Please see for clock setting, configuration and gating information.
### Table 57-3. WDOG Clocks

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>IP Global functional clock. All functionality inside the WDOG module is synchronized to this clock.</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>ipg_clk_root</td>
<td>IP slave bus clock. This clock is synchronized to ipg_clk and is only used for register read/write operations.</td>
</tr>
<tr>
<td>ipg_clk_32k</td>
<td>ckil_sync_clk_root</td>
<td>Low frequency (32.768 kHz) clock that continues to run in low-power mode. It is assumed that the Clock Controller will provide this clock signal synchronized to ipg_clk in the normal mode, and switch to a non-synchronized signal in low-power mode when the ipg_clk is off.</td>
</tr>
<tr>
<td>ipg_async_ckil_clk</td>
<td>anatop_xtal32k_clk</td>
<td>This clock is used by clocking the power down counter.</td>
</tr>
</tbody>
</table>

### 57.5 Watchdog mechanism and system integration

The WDOG1 module and the WDOG2 (TZ) module are disabled by default (after reset). WDOG1 will be configured during boot while WDOG2 is dedicated for secure world purposes and will be activated by TZ software if required. The TZ watchdog (WDOG2) module protects against TZ starvation by providing a method of escaping normal mode and forcing a switch to the TZ mode. TZ starvation is a situation where the normal OS prevents switching to the TZ mode. Such a situation is undesirable as it can compromise the system’s security.

Once the TZ WDOG module is activated, it must be serviced by TZ on a periodic basis. If servicing does not take place, the timer times out. Upon a timeout, the TZ WDOG asserts a TZ-mapped interrupt that forces switching to the TZ mode. If it is still not serviced, the TZ WDOG asserts a security violation signal to the CSU. The TZ WDOG module cannot be programmed or de-activated by normal mode software.

The WDOG modules operate as follows:
- If servicing does not take place, the timer times out and the wdog_rst_b signal is activated (low)
- Interrupt can be generated before the counter actually times out
- The wdog_rst_b signal can be activated by software
- There is a power-down counter which gets enabled out of any reset. This counter has a fixed timeout period of 16 seconds upon which it will assert the ipp_wdog_b signal.

### 57.6 Functional description

This section provides a complete functional description of the block.
57.6.1 Timeout event

The WDOG provides timeout periods from 0.5 to 128 seconds with a time resolution of 0.5 seconds.

The user can determine the timeout period by writing to the WDOG timeout field (WT[7:0]) in the Watchdog Control (WCR). The WDOG must be enabled by setting the WDE bit of Watchdog Control (WCR) for the timeout counter to start running. After the WDOG is enabled, the counter is activated, loads the timeout value and begins to count down from this programmed value. The timer will time out when the counter reaches zero and the WDOG outputs a system reset signal, WDOG_RESET_B_DEB and asserts WDOG_B (ipp_wdog) (WDT bit should be set in Watchdog Control (WCR)).

However, the timeout condition can be prevented by reloading the counter with the new timeout value (WT[7:0] of WDOG_WCR) if a service routine (see Servicing WDOG to reload the counter) is performed before the counter reaches zero. If any system errors occur which prevent the software from servicing the Watchdog Service (WSR), the timeout condition occurs. By performing the service routine, the WDOG reloads its counter to the timeout value indicated by bits WT[7:0] of the Watchdog Control (WCR) and it restarts the countdown.

A system reset will reset the counter and place it in the idle state at any time during the countdown. The counter flow diagram is shown in Flow Diagrams.

NOTE

The timeout value is reloaded to the counter either at the time WDOG is enabled or after the service routine has been performed.

57.6.1.1 Servicing WDOG to reload the counter

To reload a timeout value to the counter the proper service sequence begins by writing 0x_5555 followed by 0x_AAAA to the Watchdog Service (WSR). Any number of instructions can be executed between the two writes. If the WDOG_WSR is not loaded with 0x_5555 prior to writing 0x_AAAA to the WDOG_WSR, the counter is not reloaded. If any value other than 0x_AAAA is written to the WDOG_WSR after 0x_5555, the counter is not reloaded. This service sequence will reload the counter with the timeout value WT[7:0] of Watchdog Control (WCR). The timeout value can be changed at any point; it is reloaded when WDOG is serviced by the core.
57.6.2 Interrupt event

Prior to timeout, the WDOG can generate an interrupt which can be considered a warning that timeout will occur shortly.

The duration between interrupt event and timeout event can be controlled by writing to the WICT field of Watchdog Interrupt Control (WICR). It can vary between 0 and 127.5 seconds. If the WDOG is serviced (Servicing WDOG to reload the counter) before the interrupt generation, the counter will be reloaded with the timeout value WT[7:0] of Watchdog Control (WCR) and the interrupt will not be triggered.

57.6.3 Power-down counter event

The power-down counter inside WDOG will be enabled out of reset. This counter has a fixed timeout value of 16 seconds, after which it will drive the WDOG_B (ipp_wdog) signal low.

To prevent this, the software must disable this counter by clearing the PDE bit of Watchdog Miscellaneous Control (WMCR) within 16 seconds of reset deassertion. Once disabled, this counter can't be enabled again until the next system reset occurs. This feature is intended to prevent the hanging up of cores after reset, as WDOG is not enabled out of reset.

57.6.4 Low power modes

57.6.4.1 STOP and DOZE mode

If the WDOG timer disable bit for low power STOP and DOZE mode (WDZST) bit in the Watchdog Control (WCR), is cleared, the WDOG timer continues to operate using the low frequency reference clock. If the low power enable (WDZST) bit is set, the WDOG timer operation will be suspended in low power STOP or DOZE mode. Upon exiting low power STOP or DOZE mode, the WDOG operation returns to what it was prior to entering the STOP or DOZE mode.
57.6.4.2 WAIT mode

If the WDOG timer disable bit for low power WAIT mode (WDW) bit in the Watchdog Control (WCR), is cleared, the WDOG timer continues to operate using the low frequency reference clock i.e ipg_clk_32k clock (32.768 kHz frequency clock). If the low power WAIT enable (WDW) bit is set, the WDOG timer operation will be suspended. Upon exiting low power WAIT mode, the WDOG operation returns to what it was prior to entering the WAIT mode.

NOTE
The WDOG timer won't be able to detect events that happen for periods shorter than one low frequency reference clock cycle. For example, in repeated WAIT mode entry or exit, if the RUN mode time is less than one low frequency reference clock cycle and if the WDW bit is set, the WDOG timer may never time out, even though the system is in RUN mode for a finite duration; WDOG may not see a low frequency reference clock edge during its wake time.

57.6.5 Debug mode

The WDOG timer can be configured for continual operation, or for suspension during debug mode. If the WDOG debug enable (WDBG) bit is set in the Watchdog Control (WCR), the WDOG timer operation is suspended in debug mode. If the WDBG bit is set and the debug mode (ipg_debug signal assertion) is entered, WDOG timer operation is suspended after two low frequency reference (ipg_clk_32k) clocks. Similarly, WDOG timer operation continues after two low frequency reference clocks of debug mode exit. Register read and write accesses in debug mode continue to function normally. Also, while in debug mode, the WDE bit of Watchdog Control (WCR) can be enabled/disabled directly. If the WDOG debug enable (WDBG) bit is cleared then WDOG timer operation is not suspended. The power-down counter is not affected by debug mode entry/exit.

NOTE
If the WDE bit of Watchdog Control (WCR) is set/cleared while in debug mode, it remains set/cleared even after exiting debug mode.

57.6.6 Operations
57.6.6.1 Watchdog reset generation

The WDOG generated reset signal WDOG_RESET_B_DEB is asserted by the following operations:

- A software write to the Software Reset Signal (SRS) bit of the Watchdog Control (WCR).
- WDOG timeout. See Timeout event.

The wdog_rst will be asserted for one clock cycle of low frequency reference clock for both a timeout condition and a software write occurrence. It remains asserted for 1 clock cycle of low frequency reference clock even if a system reset is asserted in between. Figure 57-3 shows the timing diagram of this signal due to a timeout condition.

57.6.6.2 WDOG_B generation

The WDOG asserts WDOG_B in the following scenarios:

- Software write to WDA bit of Watchdog Control (WCR). WDOG_B signal remains asserted as long as the WDA bit is "0".
- WDOG timeout condition, WDT bit of Watchdog Control (WCR) must be set for this scenario. A description of the timeout condition can be found in the Timeout event. WDOG_B (ipp_wdog) signal remains asserted until a power-on reset (POR) occurs. It gets cleared after the POR occurs (not due to any other system reset). Figure 57-4 shows the timing diagram of WDOG_B (ipp_wdog) due to timeout condition.
- WDOG power-down counter timeout, PDE bit of Watchdog Miscellaneous Control (WMCR) should not be cleared for this scenario. A description of this counter can be found in the Power-down counter event. WDOG_B (ipp_wdog) signal remains asserted for one clock cycle of low frequency reference clock (ipg_clk_32k).

Figure 57-2 shows the scenarios under which WDOG_B(ipp_wdog) gets asserted.
Watchdog Misc. Control Register (WDOG_WMCR)

Watchdog Control Register (WDOG_WCR)

Power Down Counter

Logic

WDOG-1 Time Out Counter

Low Frequency Reference Clock 1

Low Frequency Reference Clock 2

Figure 57-2. WDOG_B (ipp_wdog) generation

Figure 57-3. WDOG timeout condition/WDT bit is not set
Functional description

57.6.7 Reset

The block is reset by a system reset and the WDOG counter will be disabled. The power-down counter is enabled and starts counting.

57.6.8 Interrupt

The WDOG has the feature of Interrupt generation before timeout.

The interrupt will be generated only if the WIE bit in Watchdog Interrupt Control (WICR) is set. The exact time at which the interrupt should occur (prior to timeout) depends on the value of WICT field of Watchdog Interrupt Control (WICR). For example, if the WICT field has a value 0x04, then the interrupt will be generated two seconds prior to timeout. Once the interrupt is triggered the WTIS bit in Watchdog Interrupt Control (WICR) will be set. The software needs to clear this bit to deassert the interrupt. If the WDOG is serviced before the interrupt generation then the counter will be reloaded with the timeout value WT[7:0] of Watchdog Control (WCR) and interrupt would not be triggered.
57.6.9 Flow Diagrams

A flow diagram of WDOG operation is shown below.

![Flow Diagram of WDOG Operation](image)

Figure 57-5. Power-Down Counter Flow Diagram
57.7 Initialization

The following sequence should be performed for WDOG initialization.

- PDE bit of Watchdog Miscellaneous Control (WMCR) should be cleared to disable the power down counter.
• WT field of **Watchdog Control (WCR)** should be programmed for sufficient timeout value.
• WDOG should be enabled by setting WDE bit of **Watchdog Control (WCR)** so that the timeout counter loads the WT field value of **Watchdog Control (WCR)** and starts counting.

## 57.8  WDOG Memory Map/Register Definition

### 57.8.1  WDOG Register Descriptions

The WDOG has user-accessible, 16-bit registers used to configure, operate, and monitor the state of the Watchdog Timer. Byte operations can be performed on these registers. If a 32-bit access is performed, the WDOG will not generate a peripheral bus error but will behave normally, like a 16-Bit access, making read/write possible. A 32-Bit access should be avoided, as the system may go to an unknown state.

### 57.8.1.1  WDOG Memory Map

WDOG1 base address: 400B_8000h.
WDOG2 base address: 400D_0000h.

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Watchdog Control (WCR)</td>
<td>16</td>
<td>RW</td>
<td>0030h</td>
</tr>
<tr>
<td>2h</td>
<td>Watchdog Service (WSR)</td>
<td>16</td>
<td>RW</td>
<td>0000h</td>
</tr>
<tr>
<td>4h</td>
<td>Watchdog Reset Status (WRSR)</td>
<td>16</td>
<td>RO</td>
<td>0010h</td>
</tr>
<tr>
<td>6h</td>
<td>Watchdog Interrupt Control (WICR)</td>
<td>16</td>
<td>RW</td>
<td>0004h</td>
</tr>
<tr>
<td>8h</td>
<td>Watchdog Miscellaneous Control (WMCR)</td>
<td>16</td>
<td>RW</td>
<td>0001h</td>
</tr>
</tbody>
</table>

### 57.8.1.2  Watchdog Control (WCR)
57.8.1.2.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WCR</td>
<td>0h</td>
</tr>
</tbody>
</table>

57.8.1.2.2 Function

The Watchdog Control Register (WDOG_WCR) controls the WDOG operation.

- WDZST, WDBG and WDW are write-once only bits. Once the software does a write access to these bits, they will be locked and cannot be reprogrammed until the next system reset assertion.
- WDE is a write one once only bit. Once software performs a write "1" operation to this bit it cannot be reset/cleared until the next system reset.
- WDT is also a write one once only bit. Once software performs a write "1" operation to this bit it cannot be reset/cleared until the next POR. This bit does not get reset/cleared due to any system reset.

57.8.1.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>W</td>
<td>WT</td>
<td>WDW</td>
<td>SRE</td>
<td>WDA</td>
<td>SRS</td>
<td>WDT</td>
<td>WDE</td>
<td>WDBG</td>
<td>WDS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

57.8.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-8</td>
<td>WT</td>
</tr>
<tr>
<td>WT</td>
<td>Watchdog Time-out Field. This 8-bit field contains the time-out value that is loaded into the Watchdog counter after the service routine has been performed or after the Watchdog is enabled. After reset, WT[7:0] must have a value written to it before enabling the Watchdog otherwise count value of zero which is 0.5 seconds is loaded into the counter.</td>
</tr>
</tbody>
</table>

**NOTE:** The time-out value can be written at any point of time but it is loaded to the counter at the time when WDOG is enabled or after the service routine has been performed. For more information see Timeout event.

- 00000000b - 0.5 Seconds (Default).
- 00000001b - 1.0 Seconds.
- 00000010b - 1.5 Seconds.
- 00000011b - 2.0 Seconds.
- 11111111b - 128 Seconds.
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>WDW</td>
</tr>
<tr>
<td></td>
<td>Watchdog Disable for Wait. This bit determines the operation of WDOG during Low Power WAIT mode. This is a write once only bit.</td>
</tr>
<tr>
<td></td>
<td>0b - Continue WDOG timer operation (Default).</td>
</tr>
<tr>
<td></td>
<td>1b - Suspend WDOG timer operation.</td>
</tr>
<tr>
<td>6</td>
<td>SRE</td>
</tr>
<tr>
<td></td>
<td>Software reset extension, an option way to generate software reset</td>
</tr>
<tr>
<td></td>
<td>adopt a new way to generate a more robust software reset. This bit can be set/clear with IP bus and will be reset with power-on reset.</td>
</tr>
<tr>
<td></td>
<td>0b - using original way to generate software reset (default)</td>
</tr>
<tr>
<td></td>
<td>1b - using new way to generate software reset.</td>
</tr>
<tr>
<td>5</td>
<td>WDA</td>
</tr>
<tr>
<td></td>
<td>WDOG_B assertion. Controls the software assertion of the WDOG_B signal.</td>
</tr>
<tr>
<td></td>
<td>0b - Assert WDOG_B output.</td>
</tr>
<tr>
<td></td>
<td>1b - No effect on system (Default).</td>
</tr>
<tr>
<td>4</td>
<td>SRS</td>
</tr>
<tr>
<td></td>
<td>Software Reset Signal. Controls the software assertion of the WDOG-generated reset signal WDOG_RESET_B_DEB. This bit automatically resets to &quot;1&quot; after it has been asserted to &quot;0&quot;.</td>
</tr>
<tr>
<td></td>
<td>NOTE: This bit does not generate the software reset to the block.</td>
</tr>
<tr>
<td></td>
<td>0b - Assert system reset signal.</td>
</tr>
<tr>
<td></td>
<td>1b - No effect on the system (Default).</td>
</tr>
<tr>
<td>3</td>
<td>WDT</td>
</tr>
<tr>
<td></td>
<td>WDOG_B Time-out assertion. Determines if the WDOG_B gets asserted upon a Watchdog Time-out Event. This is a write-one once only bit.</td>
</tr>
<tr>
<td></td>
<td>NOTE: There is no effect on WDOG_RESET_B_DEB (WDOG Reset) upon writing on this bit. WDOG_B gets asserted along with WDOG_RESET_B_DEB if this bit is set.</td>
</tr>
<tr>
<td></td>
<td>0b - No effect on WDOG_B (Default).</td>
</tr>
<tr>
<td></td>
<td>1b - Assert WDOG_B upon a Watchdog Time-out event.</td>
</tr>
<tr>
<td>2</td>
<td>WDE</td>
</tr>
<tr>
<td></td>
<td>Watchdog Enable. Enables or disables the WDOG block. This is a write one once only bit. It is not possible to clear this bit by a software write, once the bit is set.</td>
</tr>
<tr>
<td></td>
<td>NOTE: This bit can be set/reset in debug mode (exception).</td>
</tr>
<tr>
<td></td>
<td>0b - Disable the Watchdog (Default).</td>
</tr>
<tr>
<td></td>
<td>1b - Enable the Watchdog.</td>
</tr>
<tr>
<td>1</td>
<td>WDBG</td>
</tr>
<tr>
<td></td>
<td>Watchdog DEBUG Enable. Determines the operation of the WDOG during DEBUG mode. This bit is write once only.</td>
</tr>
<tr>
<td></td>
<td>0b - Continue WDOG timer operation (Default).</td>
</tr>
<tr>
<td></td>
<td>1b - Suspend the watchdog timer.</td>
</tr>
<tr>
<td>0</td>
<td>WDZST</td>
</tr>
<tr>
<td></td>
<td>Watchdog Low Power. Determines the operation of the WDOG during low-power modes. This bit is write once-only.</td>
</tr>
<tr>
<td></td>
<td>NOTE: The WDOG can continue/suspend the timer operation in the low-power modes (STOP and DOZE mode).</td>
</tr>
<tr>
<td></td>
<td>0b - Continue timer operation (Default).</td>
</tr>
<tr>
<td></td>
<td>1b - Suspend the watchdog timer.</td>
</tr>
</tbody>
</table>
57.8.1.3 Watchdog Service (WSR)

57.8.1.3.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WSR</td>
<td>2h</td>
</tr>
</tbody>
</table>

57.8.1.3.2 Function

When enabled, the WDOG requires that a service sequence be written to the Watchdog Service Register (WSR) to prevent the timeout condition.

**NOTE**

Executing the service sequence will reload the WDOG timeout counter.

57.8.1.3.3 Diagram

```
Bits 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
R     0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
W     0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
```

57.8.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-0</td>
<td>WSR</td>
</tr>
</tbody>
</table>
| WSR   | Watchdog Service Register. This 16-bit field contains the Watchdog service sequence. Both writes must occur in the order listed prior to the time-out, but any number of instructions can be executed between the two writes. The service sequence must be performed as follows:  
0101010101010101b - Write to the Watchdog Service Register (WDOG_WSR).  
1010101010101010b - Write to the Watchdog Service Register (WDOG_WSR). |

57.8.1.4 Watchdog Reset Status (WRSR)
57.8.1.4.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WRSR</td>
<td>4h</td>
</tr>
</tbody>
</table>

57.8.1.4.2 Function

The WRSR is a read-only register that records the source of the output reset assertion. It is not cleared by a hard reset. Therefore, only one bit in the WRSR will always be asserted high. The register will always indicate the source of the last reset generated due to WDOG. Read access to this register is with one wait state. Any write performed on this register will generate a Peripheral Bus Error.

A reset can be generated by the following sources, as listed in priority from highest to lowest:

- Watchdog Time-out
- Software Reset

57.8.1.4.3 Diagram

![Diagram](image)

57.8.1.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-5</td>
<td>Reserved.</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>POR</td>
</tr>
<tr>
<td>POR</td>
<td>Power On Reset. Indicates whether the reset is the result of a power on reset.</td>
</tr>
<tr>
<td>0b - Reset is not the result of a power on reset.</td>
<td></td>
</tr>
<tr>
<td>1b - Reset is the result of a power on reset.</td>
<td></td>
</tr>
<tr>
<td>3-2</td>
<td>Reserved.</td>
</tr>
<tr>
<td>—</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>TOUT</td>
</tr>
<tr>
<td>TOUT</td>
<td>Timeout. Indicates whether the reset is the result of a WDOG timeout.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## 57.8.1.5 Watchdog Interrupt Control (WICR)

### 57.8.1.5.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WICR</td>
<td>6h</td>
</tr>
</tbody>
</table>

### 57.8.1.5.2 Function

The WDOG_WICR controls the WDOG interrupt generation.

### 57.8.1.5.3 Diagram

![Diagram of WICR Register]

### 57.8.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
</table>
| WIE   | Watchdog Timer Interrupt enable bit. Reset value is 0.  
     | **NOTE:** This bit is a write once only bit. Once the software does a write access to this bit, it will get locked and cannot be reprogrammed until the next system reset assertion  
     | 0b - Disable Interrupt (Default).  
     | 1b - Enable Interrupt. |

Table continues on the next page...
Chapter 57 Watchdog Timer (WDOG1-2)

### 57.8.1.6 Watchdog Miscellaneous Control (WMCR)

#### 57.8.1.6.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WMCR</td>
<td>8h</td>
</tr>
</tbody>
</table>

#### 57.8.1.6.2 Function

WDOG_WMCR Controls the Power Down counter operation.

#### 57.8.1.6.3 Diagram

```
+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+
| Bit     | 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+
| R       | 0       |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |         |
| W       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 1       |
| Reset   | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 1       |
+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+---------+
```

**NOTE:** This field is write once only. Once the software does a write access to this field, it will get locked and cannot be reprogrammed until the next system reset assertion.

- 00000000b - WICT[7:0] = Time duration between interrupt and time-out is 0 seconds.
- 00000001b - WICT[7:0] = Time duration between interrupt and time-out is 0.5 seconds.
- 00001000b - WICT[7:0] = Time duration between interrupt and time-out is 2 seconds (Default).
- 11111111b - WICT[7:0] = Time duration between interrupt and time-out is 127.5 seconds.
### 57.8.1.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-1</td>
<td>Reserved.</td>
</tr>
<tr>
<td>0</td>
<td>PDE</td>
</tr>
</tbody>
</table>

PDE

Power Down Enable bit. Reset value of this bit is 1, which means the power down counter inside the WDOG is enabled after reset. The software must write 0 to this bit to disable the counter within 16 seconds of reset de-assertion. Once disabled this counter cannot be enabled again. See Power-down counter event for operation of this counter.

**NOTE:** This bit is write-one once only bit. Once software sets this bit it cannot be reset until the next system reset.
- 0b - Power Down Counter of WDOG is disabled.
- 1b - Power Down Counter of WDOG is enabled (Default).
Chapter 58
RTWDOG (WDOG3)

58.1 Chip-specific RTWDOG information

Table 58-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

NOTE

On this device, both LPO clock and INTCLK are 32 KHz clock generated by 32 KHz XTAL, which could be automatically switched to 32 KHz RCOSC upon XTAL clock loss. ERCLK is 1 MHz RCOSC clock generated by ANATOP.

58.2 Introduction

The Watchdog Timer (WDOG) module is an independent timer that is available for system use. It provides a safety feature to ensure that software is executing as planned and that the CPU is not stuck in an infinite loop or executing unintended code. If the WDOG module is not serviced (refreshed) within a certain period, it resets the MCU.
58.2.1 Features

Features of the WDOG module include:

- Configurable clock source inputs independent from the bus clock
  - Bus clock (slow clock)
  - LPO clock
  - INTCLK (internal clock)
  - ERCLK (external reference clock)

- Programmable timeout period
  - Programmable 16-bit timeout value
  - Optional fixed 256 clock prescaler when longer timeout periods are needed

- Robust write sequence for counter refresh
  - Refresh sequence of writing 0xA602 and then 0xB480

- Window mode option for the refresh mechanism
  - Programmable 16-bit window value
  - Provides robust check that program flow is faster than expected
  - Early refresh attempts trigger a reset.

- Optional timeout interrupt to allow post-processing diagnostics
  - Interrupt request to CPU with interrupt vector for an interrupt service routine (ISR)
  - Forced reset occurs 255 bus clocks after the interrupt vector fetch.

- Configuration bits are write-once-after-reset to ensure watchdog configuration cannot be mistakenly altered.

- Robust write sequence for unlocking write-once configuration bits
  - Unlock sequence of writing 0xC520 and then 0xD928 for allowing updates to write-once configuration bits
  - Software must make updates within 255 bus clocks after unlocking and before WDOG closing unlock window.
58.2.2 Block diagram

The following figure shows a block diagram of the WDOG module.

![Figure 58-1. WDOG block diagram](image-url)

58.3 Functional description

The WDOG module provides a fail safe mechanism to ensure the system can be reset to a known state of operation in case of system failure, such as the CPU clock stopping or there being a run away condition in the software code. The watchdog counter runs continuously off a selectable clock source and expects to be serviced (refreshed) periodically. If it is not, it generates a reset triggering event.

The timeout period, window mode, and clock source are all programmable but must be configured within 255 bus clocks after a reset.

58.3.1 Clock source

The watchdog counter has the following clock source options selected by programming CS[CLK]:

- bus clock
- Low-Power Oscillator clock (LPO_CLK) (This is the default source.)
The options allow software to select a clock source independent of the bus clock for applications that need to meet more robust safety requirements. Using a clock source other than the bus clock ensures that the watchdog counter continues to run if the bus clock is somehow halted; see Backup reset.

An optional fixed prescaler for all clock sources allows for longer timeout periods. When CS[PRES] is set, the clock source is prescaled by 256 before clocking the watchdog counter.

The following table summarizes the different watchdog timeout periods which could be available, as an example.

<table>
<thead>
<tr>
<th>Reference clock</th>
<th>Prescaler</th>
<th>Watchdog time-out availability</th>
</tr>
</thead>
<tbody>
<tr>
<td>LPO_CLK</td>
<td>Pass through</td>
<td>~1 ms–65.5 s (if LPO_CLK = 1 kHz); (~1 ms–65.5 s)/128 (if LPO_CLK = 128 kHz). 1</td>
</tr>
<tr>
<td>256</td>
<td></td>
<td>~256 ms–16,777.2 s (if LPO_CLK = 1 kHz); ~2 ms–131.1 s (if LPO_CLK = 128 kHz).</td>
</tr>
<tr>
<td>Internal clock 8 MHz</td>
<td>Pass through</td>
<td>125 ns–8.1925 ms</td>
</tr>
<tr>
<td>256</td>
<td></td>
<td>32 µs–2.09728 s</td>
</tr>
<tr>
<td>1 MHz (from bus or external)</td>
<td>Pass through</td>
<td>1 µs–65.54 ms</td>
</tr>
<tr>
<td>256</td>
<td></td>
<td>256 µs–16.777 s</td>
</tr>
<tr>
<td>20 MHz (from bus or external)</td>
<td>Pass through</td>
<td>50 ns–3.277 ms</td>
</tr>
<tr>
<td>256</td>
<td></td>
<td>12.8 µs–838.8 ms</td>
</tr>
</tbody>
</table>

1. The default timeout value after reset is approximately 32000 ms (if LPO_CLK = 1 kHz), or 32000/128 ms (if LPO_CLK = 128 kHz).

NOTE
When the programmer switches clock sources during reconfiguration, the watchdog hardware holds the counter at zero for 2.5 periods of the previous clock source and 2.5 periods of the new clock source after the configuration time period (255 bus clocks) ends. This delay ensures a smooth transition before restarting the counter with the new configuration.

58.3.2 Watchdog refresh mechanism

The watchdog resets the MCU if the watchdog counter is not refreshed. A robust refresh mechanism makes it very unlikely that the watchdog can be refreshed by runaway code.
To refresh the watchdog counter, software must execute a refresh write sequence before the timeout period expires. In addition, if window mode is used, software must not start the refresh sequence until after the time value set in the WIN register. See the following figure.

**Figure 58-2. Refresh opportunity for the Watchdog counter**

58.3.2.1 Window mode

Software finishing its main control loop faster than expected could be an indication of a problem. Depending on the requirements of the application, the WDOG can be programmed to force a reset when refresh attempts are early.

When Window mode is enabled, the watchdog must be refreshed after the counter has reached a minimum expected time value; otherwise, the watchdog resets the MCU. The minimum expected time value is specified in the WIN register. Setting CS[WIN] enables Window mode.
58.3.2.2 Refreshing the Watchdog

The refresh write sequence can be
• either two 16-bit writes (0xA602, 0xB480) or four 8-bit writes (0xA6, 0x02, 0xB4, 0x80; applicable to Cortex-M core cases) if WDOG_CS[CMD32EN] is 0;
• one 32-bit write (0xB480_A602) if WDOG_CS[CMD32EN] is 1.

to the CNT register. Both methods must occur before the WDG timeout; otherwise, the watchdog resets the MCU.

Note
Before starting the refresh sequence, disable the global interrupts. Otherwise, an interrupt could effectively invalidate the refresh sequence, if the interrupt occurs before the refresh writes finish. After the sequence finishes, restore the global interrupt control state.

The example codes can be found at the end of this chapter.

58.3.3 Configuring the Watchdog

58.3.3.1 Configuring the Watchdog Once

All watchdog control bits, timeout value, and window value are write-once after reset within 255 bus clocks. This means that after a write has occurred they cannot be changed unless a reset occurs. This is guaranteed by the user configuring the window and timeout value first, followed by the other control bits, and ensuring that CS[UPDATE] is also set to 0.

This provides a robust mechanism to configure the watchdog and ensure that a runaway condition cannot mistakenly disable or modify the watchdog configuration after configured.

The new configuration takes effect only after all registers except CNT are written after reset. Otherwise, the WDOG uses the reset values by default. If window mode is not used (CS[WIN] is 0), writing to WIN is not required to make the new configuration take effect.

58.3.3.2 Reconfiguring the Watchdog

In some cases (like when supporting a bootloader function), you may want to reconfigure or disable the watchdog, without forcing a reset first.
• By setting CS[UPDATE] to 1 on the initial configuration of the watchdog after a reset, you can reconfigure the watchdog at any time by executing an unlock sequence.
• Conversely, if CS[UPDATE] remains 0, the only way to reconfigure the watchdog is by initiating a reset.

The unlock sequence is similar to the refresh sequence but uses different values.

58.3.3.2 Unlocking the Watchdog

The unlock sequence is a write to the CNT register of 0xC520 followed by 0xD928 within 31 bus clocks at any time after the watchdog has been configured. On completing the unlock sequence, the user must reconfigure the watchdog within 255 bus clocks; otherwise, the watchdog closes the unlock window.

NOTE
Due to the 255 bus clocks requirement for reconfiguring the watchdog, some delays must be inserted before executing STOP or WAIT instructions after reconfiguring the watchdog. This ensures that the watchdog's new configuration takes effect before the MCU enters low power mode. Otherwise, watchdog will not be able to wake the MCU from low power mode.

The example codes can be found at end of this chapter.

58.3.4 Using interrupts to delay resets

• When interrupts are enabled (CS[INT] = 1): After a reset-triggering event (like a counter timeout or invalid refresh attempt), the watchdog first generates an interrupt request. Next, the watchdog delays 255 bus clocks (from the interrupt vector fetch, not the reset-triggering event) before forcing a reset, to allow the interrupt service routine (ISR) to perform tasks (like analyzing the stack to debug code).
• When interrupts are disabled (CS[INT] = 0): the watchdog does not delay the forcing a reset.

58.3.5 Backup reset

NOTE
A clock source other than the bus clock must be used as the reference clock for the counter; otherwise, the backup reset function is not available.
The backup reset function is a safeguard feature that independently generates a reset in case the main WDOG logic loses its clock (the bus clock) and can no longer monitor the counter. If the watchdog counter overflows twice in succession (without an intervening reset), the backup reset function takes effect and generates a reset.

Backup reset becomes valid when interrupt is enabled and the watchdog clock is from non bus clock. If interrupt is enabled, once the bus clock is cut off before exiting interrupt routine, the normal watchdog reset will be blocked. Under this case, the second overflow will cause backup reset directly.

58.3.6 Functionality in debug and low-power modes

By default, the watchdog is not functional in Debug mode, Wait mode, or Stop mode. However, the watchdog can remain functional in these modes as follows:

- **For Debug mode**, set CS[DBG]. (This way the watchdog is functional in Debug mode even when the CPU is held by the Debug module.)
- **For Wait mode**, set CS[WAIT].
- **For Stop mode**, set CS[STOP], CS[WAIT], and ensure the clock source is active in Stop mode.

**NOTE**

The watchdog can generate interrupt in Stop mode.

For Debug mode and Stop mode, in addition to the above configurations, a clock source other than the bus clock must be used as the reference clock for the counter; otherwise, the watchdog cannot function.

58.3.7 Fast testing of the watchdog

Before executing application code in safety critical applications, users are required to test that the watchdog works as expected and resets the MCU. Testing every bit of a 16-bit counter by letting it run to the overflow value takes a relatively long time (64 kHz clocks).

To help minimize the startup delay for application code after reset, the watchdog has a feature to test the watchdog more quickly by splitting the counter into its constituent byte-wide stages. The low and high bytes are run independently and tested for timeout against the corresponding byte of the timeout value register. (For complete coverage
when testing the high byte of the counter, the test feature feeds the input clock via the 8th bit of the low byte, thus ensuring that the overflow connection from the low byte to the high byte is tested.)

Using this test feature reduces the test time to 512 clocks (not including overhead, such as user configuration and reset vector fetches). To further speed testing, use a faster clock (such as the bus clock) for the counter reference.

On a power-on reset, the POR bit in the system reset register is set, indicating the user should perform the WDOG fast test.

### 58.3.7.1 Testing each byte of the counter

The test procedure follows these steps:

1. Program the preferred watchdog timeout value in the TOVAL register during the watchdog configuration time period.
2. Select a byte of the counter to test using the CS[TST] = 10b for the low byte; CS[TST] = 11b for the high byte.
3. Wait for the watchdog to timeout. Optionally, in the idle loop, increment RAM locations as a parallel software counter for later comparison. Because the RAM is not affected by a watchdog reset, the timeout period of the watchdog counter can be compared with the software counter to verify the timeout period has occurred as expected.
4. The watchdog counter times out and forces a reset.
5. Confirm the WDOG flag in the system reset register is set, indicating that the watchdog caused the reset. (The POR flag remains clear.)
6. Confirm that CS[TST] shows a test (10b or 11b) was performed.

If confirmed, the count and compare functions work for the selected byte. Repeat the procedure, selecting the other byte in step 2.

**NOTE**

CS[TST] is cleared by a POR only and not affected by other resets.

### 58.3.7.2 Entering user mode

After successfully testing the low and high bytes of the watchdog counter, the user can configure CS[TST] to 01b to indicate the watchdog is ready for use in application user mode. Thus if a reset occurs again, software can recognize the reset trigger as a real watchdog reset caused by runaway or faulty application code.
As an ongoing test when using the default LPO clock source, software can periodically read the CNT register to ensure the counter is being incremented.

58.4 Application Information

The watchdog is enabled by default after reset. To disable or reconfigure the watchdog, it is better to be done before the first watchdog timeout. It is suggested to disable or reconfigure the watchdog at the very beginning of the software code, e.g. beginning of the startup or main function.

NOTE
When the watchdog is configured by user, it needs at least 2.5 periods of watchdog clock to take effect. This means interval between two configures by user must be larger than 2.5 clocks.

NOTE
When Chip startup from BOOT ROM then jump to flash, the watchdog would be enabled in the beginning of bootloader, and disabled when bootloader exits. If there is any code in the flash program want to reconfigure the watchdog, it must be run 2.5 watchdog clocks later after the bootloader exits.

To disable or reconfigure the watchdog without forcing a reset, WDOG_CS[UPDATE] bit must be set during the initial configuration of the WDOG module. Then, the unlock sequence can be used at any time within the timeout limit to reconfigure the watchdog.

58.4.1 Disable Watchdog

To disable the watchdog, first do unlock sequence, then unset the WDOG_CS[EN] bit. The code snippet below shows an example for 32-bit write.

```
DisableInterrupts; // disable global interrupt
WDOG_CNT = 0xD928C520; //unlock watchdog
WDOG_CS &= ~WDOG_CS_EN_MASK; //disable watchdog
EnableInterrupts; //enable global interrupt
```

58.4.2 Configure Watchdog

The watchdog can be configured once by set the WDOG_CS[UPDATE]=0. After that, the watchdog cannot be reconfigured until a reset. If set WDOG_CS[UPDATE]=1 when configuring the watchdog, the watchdog can be reconfigured without forcing a reset. The
following example code shows how to configure the watchdog without window mode, clock source as LPO, interrupt enabled and timeout value to 256 clocks. The code snippet below shows an example for 32-bit write.

**Configure once**

DisableInterrupts; // disable global interrupt
WDOG_CNT = 0xD928C520; // unlock watchdog
while(WDOG_CS[ULK]==0); // wait until registers are unlocked
WDOG_TOVAL = 256; // set timeout value
WDOG_CS = WDOG_CS_EN(1) | WDOG_CS_CLK(1) | WDOG_CS_INT(1) | WDOG_CS_WIN(0) | WDOG_CS_UPDATE(0);
while(WDOG_CS[RCS]==0); // wait until new configuration takes effect
EnableInterrupts; // enable global interrupt

**Configure for reconfigurable**

DisableInterrupts; // disable global interrupt
WDOG_CNT = 0xD928C520; // unlock watchdog
while(WDOG_CS[ULK]==0); // wait until registers are unlocked
WDOG_TOVAL = 256; // set timeout value
WDOG_CS = WDOG_CS_EN(1) | WDOG_CS_CLK(1) | WDOG_CS_INT(1) | WDOG_CS_WIN(0) | WDOG_CS_UPDATE(1);
while(WDOG_CS[RCS]==0); // wait until new configuration takes effect
EnableInterrupts; // enable global interrupt

### 58.4.3 Refreshing the Watchdog

To refresh the watchdog and reset the watchdog counter to zero, a refresh sequence is required. The code snippet below shows an example for 32-bit write.

DisableInterrupts; // disable global interrupt
WDOG_CNT = 0xB480A602; // refresh watchdog
EnableInterrupts; // enable global interrupt

### 58.5 Memory map and register definition

#### 58.5.1 WDOG Register Descriptions

#### 58.5.1.1 WDOG Memory Map

WDOG3 (RTWDOG) base address: 400B_C000h
This section describes the function of Watchdog Control and Status Register.

### NOTE
TST is cleared (0:0) on POR only. Any other reset does not affect the value of this field.

### 58.5.1.2.2 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>WIN</td>
<td>FLG</td>
<td>CMD</td>
<td>PRES</td>
<td>ULK</td>
<td>RCS</td>
<td>CLK</td>
<td>EN</td>
<td>INT</td>
<td>UPDA</td>
<td>TE</td>
<td>TST</td>
<td>DBG</td>
<td>WAIT</td>
<td>STOP</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### 58.5.1.2.3 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 WIN</td>
<td>Watchdog Window&lt;br&gt;This write-once bit enables window mode. See the Window mode section.&lt;br&gt; 0b - Window mode disabled.&lt;br&gt; 1b - Window mode enabled.</td>
</tr>
<tr>
<td>14 FLG</td>
<td>Watchdog Interrupt Flag&lt;br&gt;This bit is an interrupt indicator when INT is set in control and status register 1. Write 1 to clear it.&lt;br&gt; 0b - No interrupt occurred.&lt;br&gt; 1b - An interrupt occurred.</td>
</tr>
<tr>
<td>13 CMD32EN</td>
<td>Enables or disables WDOG support for 32-bit (otherwise 16-bit or 8-bit) refresh/unlock command write words&lt;br&gt;This is write-once field, and the user needs to unlock WDOG after writing this field for reconfiguration.&lt;br&gt; 0b - Disables support for 32-bit refresh/unlock command write words. Only 16-bit or 8-bit is supported.&lt;br&gt; 1b - Enables support for 32-bit refresh/unlock command write words. 16-bit or 8-bit is NOT supported.</td>
</tr>
<tr>
<td>12 PRES</td>
<td>Watchdog prescaler&lt;br&gt;This write-once bit enables a fixed 256 pre-scaling of watchdog counter reference clock. (The block diagram shows this clock divider option.)&lt;br&gt; 0b - 256 prescaler disabled.&lt;br&gt; 1b - 256 prescaler enabled.</td>
</tr>
<tr>
<td>11 ULK</td>
<td>Unlock status&lt;br&gt;This read-only bit indicates whether WDOG is unlocked or not.&lt;br&gt; 0b - WDOG is locked.&lt;br&gt; 1b - WDOG is unlocked.</td>
</tr>
<tr>
<td>10 RCS</td>
<td>Reconfiguration Success&lt;br&gt;This read-only bit indicates whether the reconfiguration is successful or not. Default reset value is 0. This bit is set when new configuration takes effect, and is cleared by successful unlock command.&lt;br&gt; 0b - Reconfiguring WDOG.&lt;br&gt; 1b - Reconfiguration is successful.</td>
</tr>
<tr>
<td>9-8 CLK</td>
<td>Watchdog Clock&lt;br&gt;This write-once field indicates the clock source that feeds the watchdog counter. See the Clock source section.&lt;br&gt; 00b - Bus clock&lt;br&gt;01b - LPO clock&lt;br&gt;10b - INTCLK (internal clock)&lt;br&gt;11b - ERCLK (external reference clock)</td>
</tr>
<tr>
<td>7 EN</td>
<td>Watchdog Enable&lt;br&gt;This write-once bit enables the watchdog counter to start counting.&lt;br&gt; 0b - Watchdog disabled.&lt;br&gt; 1b - Watchdog enabled.</td>
</tr>
<tr>
<td>6 INT</td>
<td>Watchdog Interrupt&lt;br&gt;This write-once bit configures the watchdog to immediately generate an interrupt request upon a reset-triggering event (timeout or illegal write to the watchdog), before forcing a reset. After the interrupt vector fetch (which comes after the reset-triggering event), the reset occurs after a delay of 255 bus clocks.&lt;br&gt; 0b - Watchdog interrupts are disabled. Watchdog resets are not delayed.&lt;br&gt; 1b - Watchdog interrupts are enabled. Watchdog resets are delayed by 255 bus clocks from the interrupt vector fetch.</td>
</tr>
<tr>
<td>5</td>
<td>Allow updates</td>
</tr>
</tbody>
</table>

Table continues on the next page...
58.5.1.3 Watchdog Counter (CNT)

58.5.1.3.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CNT</td>
<td>4h</td>
</tr>
</tbody>
</table>

58.5.1.3.2 Function

This section describes the watchdog counter register.

The watchdog counter register provides access to the value of the free-running watchdog counter. Software can read the counter register at any time.
Software cannot write directly to the watchdog counter; however, two write sequences to these registers have special functions:

1. The refresh sequence resets the watchdog counter to 0x0000. See the "Refreshing the Watchdog" section.
2. The unlock sequence allows the watchdog to be reconfigured without forcing a reset (when CS[UPDATE] = 1). See the "Configure for reconfigurable" section.

**NOTE**
All other writes to this register are illegal and force a reset.

### 58.5.1.3.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**cnthigh**
**cntlow**

### 58.5.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>15-8</td>
<td>High byte of the Watchdog Counter</td>
</tr>
<tr>
<td>CNTHIGH</td>
<td></td>
</tr>
<tr>
<td>7-0</td>
<td>Low byte of the Watchdog Counter</td>
</tr>
<tr>
<td>CNTLOW</td>
<td></td>
</tr>
</tbody>
</table>

### 58.5.1.4 Watchdog Timeout Value (TOVAL)

#### 58.5.1.4.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TOVAL</td>
<td>8h</td>
</tr>
</tbody>
</table>
58.5.1.4.2  Function

This section describes the watchdog timeout value register. TOVAL contains the 16-bit value used to set the timeout period of the watchdog.

The watchdog counter (CNT) is continuously compared with the timeout value (TOVAL). If the counter reaches the timeout value, the watchdog forces a reset triggering event.

NOTE

Do not write 0 to the Watchdog Timeout Value Register; otherwise, the watchdog always generates a reset.

58.5.1.4.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TOVALHIGH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TOVALLOW</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

58.5.1.4.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>15-8</td>
<td>High byte of the timeout value</td>
</tr>
<tr>
<td>TOVALHIGH</td>
<td></td>
</tr>
<tr>
<td>7-0</td>
<td>Low byte of the timeout value</td>
</tr>
<tr>
<td>TOVALLOW</td>
<td></td>
</tr>
</tbody>
</table>

58.5.1.5  Watchdog Window (WIN)
58.5.1.5.1 Address

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>WIN</td>
<td>Ch</td>
</tr>
</tbody>
</table>

58.5.1.5.2 Function

This section describes the watchdog window register. When window mode is enabled (CS[WIN] is set), the WIN register determines the earliest time that a refresh sequence is considered valid. See the Watchdog refresh mechanism section.

The WIN register value must be less than the TOVAL register value.

58.5.1.5.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>WINHIGH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>WINLOW</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

58.5.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>Reserved</td>
</tr>
<tr>
<td>15-8</td>
<td>High byte of Watchdog Window</td>
</tr>
<tr>
<td>WINHIGH</td>
<td></td>
</tr>
<tr>
<td>7-0</td>
<td>Low byte of Watchdog Window</td>
</tr>
</tbody>
</table>
Chapter 59
External Watchdog Monitor (EWM)

59.1 Chip-specific EWM information

Table 59-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td>Low Power Clock Source</td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Low Power Clock Source (lpo_clk[3:0])</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

For low power clock source, see lpo_clk[3:0] in the EWM Signal Descriptions table.

**NOTE**

- lpo_clk[0] is 32 kHz clock generated by 32 kHz XTAL, which could be automatically switched to 32 kHz RCOSC upon XTAL clock loss;
- lpo_clk[1] is 1 MHz RCOSC clock generated by ANATOP;
- lpo_clk[3:2] are not used on this device.
59.2 Introduction

For safety, a redundant watchdog system, External Watchdog Monitor (EWM), is designed to monitor external circuits, as well as the MCU software flow. This provides a back-up mechanism to the internal watchdog that resets the MCU’s CPU and peripherals.

The watchdog is generally used to monitor the flow and execution of embedded software within an MCU. The watchdog consists of a counter that if allowed to overflow, forces an internal reset (asynchronous) to all on-chip peripherals and optionally assert the RESET_B pin to reset external devices/circuits. The overflow of the watchdog counter must not occur if the software code works well and services the watchdog to re-start the actual counter.

The EWM differs from the internal watchdog in that it does not reset the MCU's CPU and peripherals. The EWM provides an independent EWM_OUT_B signal that when asserted resets or places an external circuit into a safe mode. The EWM_OUT_B signal is asserted upon the EWM counter time-out. An optional external input EWM_in is provided to allow additional control of the assertion of EWM_OUT_B signal.

59.2.1 Features

Features of EWM module include:

- Independent LPO_CLK clock source
- Programmable time-out period specified in terms of number of EWM LPO_CLK clock cycles.
- Windowed refresh option
  - Provides robust check that program flow is faster than expected.
  - Programmable window.
  - Refresh outside window leads to assertion of EWM_OUT_B.
- Robust refresh mechanism
  - Write values of 0xB4 and 0x2C to EWM Refresh Register within 23 peripheral bus clock cycles.
• One output port, EWM_OUT_B, when asserted is used to reset or place the external circuit into safe mode.

• One Input port, EWM_in, allows an external circuit to control the assertion of the EWM_OUT_B signal.

59.2.2 Modes of Operation

This section describes the module's operating modes.

59.2.2.1 Stop Mode

When the EWM is in stop mode, the CPU refreshes to the EWM cannot occur. On entry to stop mode, the EWM's counter freezes.

There are two possible ways to exit from Stop mode:

• On exit from stop mode through a reset, the EWM remains disabled.

• On exit from stop mode by an interrupt, the EWM is re-enabled, and the counter continues to be clocked from the same value prior to entry to stop mode.

Note the following if the EWM enters the stop mode during CPU refresh mechanism: At the exit from stop mode by an interrupt, refresh mechanism state machine starts from the previous state which means, if first refresh command is written correctly and EWM enters the stop mode immediately, the next command has to be written within the next 23 peripheral bus clocks after exiting from stop mode. User must mask all interrupts prior to executing EWM refresh instructions.

59.2.2.2 Wait Mode

The EWM module treats the stop and wait modes as the same. EWM functionality remains the same in both of these modes.

59.2.2.3 Debug Mode

Entry to debug mode has no effect on the EWM.
- If the EWM is enabled prior to entry of debug mode, it remains enabled.
- If the EWM is disabled prior to entry of debug mode, it remains disabled.

### 59.2.3 Block Diagram

This figure shows the EWM block diagram.

![EWM Block Diagram](image)

**Figure 59-1. EWM Block Diagram**

### 59.3 EWM Signal Descriptions

The EWM has two external signals and internal options for the counter clock sources, as shown in the following table.

```
<table>
<thead>
<tr>
<th>Signal Description</th>
<th>Symbol</th>
</tr>
</thead>
<tbody>
<tr>
<td>Low Power Clock</td>
<td>LPO_CLK</td>
</tr>
<tr>
<td>Clock Divider Logic</td>
<td>EWM_CLKPRESCALER[CLK_DIV]</td>
</tr>
<tr>
<td>Clock Gating Cell</td>
<td>EWM_CTRL[EWMEN]</td>
</tr>
<tr>
<td>8-bit Counter</td>
<td>EWM_CMPH[COMPAREH], EWM_CMPL[COMPAREL]</td>
</tr>
<tr>
<td>Counter Overflow</td>
<td>EWM_in</td>
</tr>
<tr>
<td>CPU Reset</td>
<td>EWM_Service_Register</td>
</tr>
<tr>
<td>EWM Refreshed</td>
<td>EWM_refreshed</td>
</tr>
<tr>
<td>/EWM_out Output Control</td>
<td>EWM_out</td>
</tr>
</tbody>
</table>
```

**NOTE**

All active-low signals are now represented with the suffix ",_b" throughout the chapter.
59.4 Clocking

This table shows the EWM clocks.

<table>
<thead>
<tr>
<th>Clock</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>This is the system clock and must be running in order for the EWM to be able to work properly. During very low power modes in which the core is powered down, this clock is disabled.</td>
</tr>
<tr>
<td>ipg_clk_s</td>
<td>This is the IPS clock and is synchronous with ipg_clk.</td>
</tr>
<tr>
<td>lpo_clock[3:0]</td>
<td>EWM can have 4 different clock sources for running its EWM counter and one of them can be selected by EWM_CLKCTRL[CLK_SEL]. This clock is gated when EWM is disabled or when EWM_OUT_B is asserted.</td>
</tr>
</tbody>
</table>

59.5 Functional Description

The following sections describe functional details of the EWM module.

**NOTE**

When the BUS_CLK is lost, then EWM module doesn't generate the EWM_OUT_B signal and no refresh operation is possible.

59.5.1 The EWM_OUT_B Signal

The EWM_OUT_B is a digital output signal used to gate an external circuit (application specific) that controls critical safety functions. For example, the EWM_OUT_B could be connected to the high voltage transistors circuits that control an AC motor in a large appliance.

The EWM_OUT_B signal remains deasserted when the EWM is being regularly refreshed by the CPU within the programmable refresh window, indicating that the application code is executed as expected.
The EWM_OUT_B signal is asserted in any of the following conditions:

- The EWM refresh occurs when the counter value is less than CMPL value.
- The EWM counter value reaches the CMPH value, and no EWM refresh has occurred.
- If functionality of EWM_in pin is enabled and EWM_in pin is asserted while refreshing the EWM.
- After any reset (by the virtue of the external pull-down mechanism on the EWM_OUT_B pin)

The EWM_OUT_B is asserted after any reset by the virtue of the external pull-down mechanism on the EWM_OUT_B signal. Then, to deassert the EWM_OUT_B signal, set EWMEN bit in the CTRL register to enable the EWM.

If the EWM_OUT_B signal shares its pad with a digital I/O pin, on reset this actual pad defers to being an input signal. The pad state is controlled by the EWM_OUT_B signal only after the EWM is enabled by the EWMEN bit in the CTRL register.

**Note**

EWM_OUT_B pad must be in pull down state when EWM functionality is used and when EWM is under Reset.

### 59.5.2 EWM_OUT_B pin state in low power modes

During Wait, Stop and Power Down modes the EWM_OUT_B pin enters a high-impedance state. A user has the option to control the logic state of the pin using an external pull device or by configuring the internal pull device. When the CPU enters a Run mode from Wait or Stop recovery, the pin resumes its previous state before entering Wait or Stop mode. When the CPU enters Run mode from Power Down, the pin returns to its reset state.

### 59.5.3 The EWM_in Signal

The EWM_in is a digital input signal for safety status of external safety circuits, that allows an external circuit to control the assertion of the EWM_OUT_B signal. For example, in the application, an external circuit monitors a critical safety function, and if there is fault with safety function, the external circuit can then actively initiate the EWM_OUT_B signal that controls the gating circuit.
The EWM_in signal is ignored if the EWM is disabled, or if INEN bit of CTRL register is cleared, as after any reset.

On enabling the EWM (setting the CTRL[EWMEN] bit) and enabling EWM_in functionality (setting the CTRL[INEN] bit), the EWM_in signal must be in the deasserted state prior to the CPU start refreshing the EWM. This ensures that the EWM_OUT_B stays in the deasserted state; otherwise, the EWM_OUT_B output signal is asserted.

**Note**

The user must update the CMPH and CMPL registers prior to enabling the EWM. After enabling the EWM, the counter resets to zero, therefore the user shall provide a reasonable time after a power-on reset for the external monitoring circuit to stabilize. The user shall also ensure that the EWM_in pin is deasserted.

### 59.5.4 EWM Counter

It is an 8-bit ripple counter fed from a clock source that is independent of the peripheral bus clock source. As the preferred time-out is between 1 ms and 100 ms the actual clock source should be in the kHz range.

The counter is reset to zero after the CPU reset, or when EWM refresh action completes, or at counter overflow. The counter value is not accessible to the CPU.

### 59.5.5 EWM Compare Registers

The compare registers CMPL and CMPH are write-once after a CPU reset and cannot be modified until another CPU reset occurs.

The EWM compare registers are used to create a refresh window to refresh the EWM module.

It is illegal to program CMPL and CMPH with same value. In this case, as soon as counter reaches (CMPL + 1), EWM_OUT_B is asserted.
59.5.6  EWM Refresh Mechanism

Other than the initial configuration of the EWM, the CPU can only access the EWM by the EWM Service Register. The CPU must access the EWM service register with correct write of unique data within the windowed time frame as determined by the CMPL and CMPH registers for correct EWM refresh operation. Therefore, three possible conditions can occur:

<table>
<thead>
<tr>
<th>Condition</th>
<th>Mechanism</th>
</tr>
</thead>
<tbody>
<tr>
<td>An EWM refresh action completes when: CMPL &lt; Counter &lt; CMPH.</td>
<td>The software behaves as expected and the EWM counter is reset to zero. The EWM_OUT_B output signal remains in the deasserted state if, during the EWM refresh action, the EWM_in input has been in deasserted state.</td>
</tr>
<tr>
<td>An EWM refresh action completes when Counter &lt; CMPL</td>
<td>The software refreshes the EWM before the windowed time frame, the counter is reset to zero and the EWM_OUT_B output signal is asserted irrespective of the input EWM_in signal.</td>
</tr>
<tr>
<td>Counter value reaches CMPH prior to completion of EWM refresh action.</td>
<td>Software has not refreshed the EWM. The EWM counter is reset to zero and the EWM_OUT_B output signal is asserted irrespective of the input EWM_in signal.</td>
</tr>
</tbody>
</table>

59.5.7  EWM Interrupt

When EWM_OUT_B is asserted, an interrupt request is generated to indicate the assertion of the EWM reset out signal. This interrupt is enabled when CTRL[INTEN] is set. Clearing this bit clears the interrupt request but does not affect EWM_OUT_B. The EWM_OUT_B signal can be deasserted only by forcing a system reset.

59.5.8  Selecting the EWM counter clock

There are four possible low power clock sources for the EWM counter. Select one of the available clock sources by programming CLKCTRL[CLKSEL].

59.5.9  Counter clock prescaler

The EWM counter clock source can be prescaled by a clock divider, by programming CLKPRESCALER[CLK_DIV]. This divided clock is used to run the EWM counter.

**NOTE**

The divided clock used to run the EWM counter must be no more than half the frequency of the bus clock.
59.6 Memory Map/Register Definition

This section contains the module memory map and registers.

NOTE

EWM only supports 8-bit register access. 16-bit and 32-bit access are not possible.

59.6.1 EWM register descriptions

59.6.1.1 EWM Memory map

DEFAULT_NICKNAME base address: 400B_4000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>Control Register (CTRL)</td>
<td>8</td>
<td>RW</td>
<td>00h</td>
</tr>
<tr>
<td>1h</td>
<td>Service Register (SERV)</td>
<td>8</td>
<td>WORZ</td>
<td>00h</td>
</tr>
<tr>
<td>2h</td>
<td>Compare Low Register (CMPL)</td>
<td>8</td>
<td>RWONE</td>
<td>00h</td>
</tr>
<tr>
<td>3h</td>
<td>Compare High Register (CMPH)</td>
<td>8</td>
<td>RWONE</td>
<td>FFh</td>
</tr>
<tr>
<td>4h</td>
<td>Clock Control Register (CLKCTRL)</td>
<td>8</td>
<td>RWONE</td>
<td>00h</td>
</tr>
<tr>
<td>5h</td>
<td>Clock Prescaler Register (CLKPRESCALER)</td>
<td>8</td>
<td>RWONE</td>
<td>00h</td>
</tr>
</tbody>
</table>

59.6.1.2 Control Register (CTRL)

59.6.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL</td>
<td>0h</td>
</tr>
</tbody>
</table>
59.6.1.2.2 Function
The CTRL register is cleared by any reset.

NOTE
INEN, ASSIN and EWMEN bits can be written once after a CPU reset. Modifying these bits more than once, generates a bus transfer error.

59.6.1.2.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

59.6.1.2.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-4</td>
<td>Reserved</td>
</tr>
<tr>
<td>_</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Interrupt Enable. This bit when set and EWM_OUT_b is asserted, an interrupt request is generated. To de-assert interrupt request, user should clear this bit by writing 0.</td>
</tr>
<tr>
<td>INTEN</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Input Enable. This bit when set, enables the EWM_in port.</td>
</tr>
<tr>
<td>INEN</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>EWM_in's Assertion State Select. Default assert state of the EWM_in signal is logic zero. Setting the ASSIN bit inverts the assert state of EWM_in signal to a logic one.</td>
</tr>
<tr>
<td>ASSIN</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>EWM enable. This bit when set, enables the EWM module. This resets the EWM counter to zero and deasserts the EWM_OUT_b signal. This bit when unset, keeps the EWM module disabled. It cannot be re-enabled until a next reset, due to the write-once nature of this bit.</td>
</tr>
<tr>
<td>EWMEN</td>
<td></td>
</tr>
</tbody>
</table>

59.6.1.3 Service Register (SERV)

59.6.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>SERV</td>
<td>1h</td>
</tr>
</tbody>
</table>
59.6.1.3.2  **Function**  
The SERV register provides the interface from the CPU to the EWM module. It is write-only and reads of this register return zero.

59.6.1.3.3  **Diagram**

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SERVICE</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

59.6.1.3.4  **Fields**

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-0</td>
<td>SERVICE</td>
</tr>
</tbody>
</table>
| SERVICE | The EWM refresh mechanism requires the CPU to write two values to the SERV register: a first data byte of 0xB4, followed by a second data byte of 0x2C. The EWM refresh is invalid if either of the following conditions is true.  
  • The first or second data byte is not written correctly.  
  • The second data byte is not written within a fixed number of peripheral bus cycles of the first data byte. This fixed number of cycles is called $EWM\_refresh\_time$.  
  23 peripheral bus clock cycles are required for $EWM\_refresh\_time$ |

59.6.1.4  **Compare Low Register (CMPL)**

59.6.1.4.1  **Offset**

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMPL</td>
<td>2h</td>
</tr>
</tbody>
</table>

59.6.1.4.2  **Function**  
The CMPL register is reset to zero after a CPU reset. This provides no minimum time for the CPU to refresh the EWM counter.
59.6.1.4.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

59.6.1.4.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-0</td>
<td>COMPAREL</td>
</tr>
<tr>
<td>COMPAREL</td>
<td>To prevent runaway code from changing this field, software should write to this field after a CPU reset even if the (default) minimum refresh time is required.</td>
</tr>
</tbody>
</table>

59.6.1.5  Compare High Register (CMPH)

59.6.1.5.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMPH</td>
<td>3h</td>
</tr>
</tbody>
</table>

59.6.1.5.2  Function

The CMPH register is reset to 0xFF after a CPU reset. This provides a maximum of 256 clocks time, for the CPU to refresh the EWM counter.

**NOTE**

This register can be written only once after a CPU reset. Writing this register more than once generates a bus transfer error.
NOTE

The valid values for CMPH are up to 0xFE because the EWM counter never expires when CMPH = 0xFF. The expiration happens only if EWM counter is greater than CMPH.

59.6.1.5.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

59.6.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-0</td>
<td>COMPAREH</td>
</tr>
</tbody>
</table>
| COMPAREH | To prevent runaway code from changing this field, software should write to this field after a CPU reset even if the (default) maximum refresh time is required.

59.6.1.6 Clock Control Register (CLKCTRL)

59.6.1.6.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKCTRL</td>
<td>4h</td>
</tr>
</tbody>
</table>

59.6.1.6.2 Function

This CLKCTRL register is reset to 0x00 after a CPU reset.

NOTE

This register can be written only once after a CPU reset. Writing this register more than once generates a bus transfer error.

NOTE

User should select the required low power clock before enabling the EWM.
59.6.1.6.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

59.6.1.6.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-2</td>
<td>reserved</td>
</tr>
<tr>
<td>1-0</td>
<td>CLKSEL</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>CLKSEL</th>
<th>EWM has 4 possible low power clock sources for running EWM counter. One of the clock source can be selected by writing into this field.</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>lpo_clk[0] will be selected for running EWM counter.</td>
</tr>
<tr>
<td>01</td>
<td>lpo_clk[1] will be selected for running EWM counter.</td>
</tr>
<tr>
<td>10</td>
<td>lpo_clk[2] will be selected for running EWM counter.</td>
</tr>
<tr>
<td>11</td>
<td>lpo_clk[3] will be selected for running EWM counter.</td>
</tr>
</tbody>
</table>

59.6.1.7  Clock Prescaler Register (CLKPRESCALER)

59.6.1.7.1  Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLKPRESCALER</td>
<td>5h</td>
</tr>
</tbody>
</table>

59.6.1.7.2  Function

This CLKPRESCALER register is reset to 0x00 after a CPU reset.

NOTE

This register can be written only once after a CPU reset. Writing this register more than once generates a bus transfer error.

NOTE

Write the required prescaler value before enabling the EWM.
NOTE
The implementation of this register is chip-specific. See the Chip Configuration details.

59.6.1.7.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

CLK_DIV

59.6.1.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7-0</td>
<td>CLK_DIV</td>
</tr>
</tbody>
</table>
| CLK_DIV | Selected low power clock source for running the EWM counter can be prescaled as below.  
  • Prescaled clock frequency = low power clock source frequency / ( 1 + CLK_DIV ) |
Chapter 60
On Chip Cross Triggers Overview

60.1 Overview

This chip integrates an on-chip cross trigger network. The following diagram shows the cross trigger network of this device.

Figure 60-1. On-Chip Cross Trigger Network
60.1.1 Cross BAR (XBAR)

Each crossbar switch is an array of MUXes with shared inputs. Each mux output provides one output of the crossbar. The number of inputs and the number of MUXes/outputs is user configurable and registers are provided to select which of the shared inputs is routed to each output. The crossbar switches are used to reconfigure data paths between peripherals (peripheral output to peripheral input) as well as between peripherals and GPIO.

60.1.2 And-Or-Inverter (AOI)

The AOI module provides an universal Boolean function generator using a four term sum of products expression, with each product term containing true or complement values of the four selected inputs (A, B, C, D).
Chapter 61
Inter-Peripheral Crossbar Switch A (XBARA)

61.1 Chip-specific XBAR information

On this device, for XBAR1 (see the XBARA chapter), the number of inputs is 88, and the number of outputs is 132. For XBAR2 and XBAR3 (see the XBARB chapter), the number of inputs is 64, and the number of outputs is 16.

NOTE

The XBAR_INn and XBAR_OUTn signals (n=4 to 19) share the same IOs. The user needs to configure the corresponding IOMUXC_GPR_GPR6[IOMUXC_XBAR_DIR_SEL_n] bit to use either XBAR_IN or XBAR_OUT.

Table 61-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
</tbody>
</table>

61.2 Introduction
61.2.1 Overview

This module implements an array of M N-input combinational muxes. All muxes share the same N inputs in the same order, but each mux has its own independent select field.

The intended application of this module is to provide a flexible crossbar switch function that allows any input (typically from external GPIO or internal module outputs) to be connected to any output (typically to external GPIO or internal module inputs) under user control. This is used to allow user configuration of data paths between internal modules and between internal modules and GPIO.

A subset of the muxes can be configured to support edge detection and either interrupt or DMA request generation based on detected signal edges on the mux output. This allows signal transitions on the signals feeding the crossbar to trigger interrupts or initiate data transfers via DMA into or out of other system modules.

61.2.2 Features

The XBAR module design includes these distinctive features:
- M identical N-input muxes with individual select fields.
- Edge detection with associated interrupt or DMA request generation for a subset of mux outputs.
- Memory mapped registers with IPBus interface for select and control fields.
- Register write protection input signal.

61.2.3 Modes of Operation

The XBAR module design operates in only a single mode of operation: Functional Mode. The various counting modes are detailed in Functional Mode.

61.2.4 Block Diagram

The block diagram for XBAR is shown in Figure 61-1.
Note: Control field support can be restricted to a subset of outputs. CTRLn represents the memory mapped control fields in the XBAR_CTRL registers for each corresponding XBAR_OUT output. Control fields provide edge status, edge selection, and interrupt/DMA generation controls.

Figure 61-1. XBAR Block Diagram

61.3 Signal Descriptions

The following table summarizes the module's external signals.

Table 61-2. Control Signal Properties

<table>
<thead>
<tr>
<th>Name</th>
<th>I/O Type</th>
<th>Function</th>
<th>Reset State</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>XBAR_OUT [0:NUMOUT-1]</td>
<td>O</td>
<td>Mux Outputs with configurable width</td>
<td>*</td>
<td></td>
</tr>
<tr>
<td>XBAR_IN [0:NUMIN-1]</td>
<td>I</td>
<td>Mux Inputs with configurable width</td>
<td>*</td>
<td></td>
</tr>
<tr>
<td>DMA_REQ</td>
<td>O</td>
<td>DMA request</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>INT_REQ</td>
<td>O</td>
<td>Interrupt request</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>DMA_ACK</td>
<td>I</td>
<td>DMA acknowledge</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>
At reset, each output XBAR_OUT[*] contains the reset value of the signal driving XBAR_IN[0].

61.3.1 XBAR_OUT[0:NUM_OUT-1] - MUX Outputs

This is a one-dimensional array of the mux outputs. The value on each output XBAR_OUT[n] is determined by the setting of the corresponding memory mapped register SELn such that XBAR_OUT[n] = XBAR_IN[SELn].

61.3.2 XBAR_IN[0:NUM_IN-1] - MUX Inputs

This is a one-dimensional array consisting of the inputs shared by each mux. All muxes share the same inputs in the same order.

61.3.3 DMA_REQ[n] - DMA Request Output(s)

DMA_REQ[n] is a DMA request to the DMA controller.

61.3.4 DMA_ACK[n] - DMA Acknowledge Input(s)

DMA_ACK[n] is a DMA acknowledge input from the DMA controller.

61.3.5 INT_REQ[n] - Interrupt Request Output(s)

INT_REQ[n] is an interrupt request output to the interrupt controller.

61.4 Memory Map and Register Descriptions

The XBAR module has select registers and control registers.

In the XBAR select registers, the SELn fields select which of the shared inputs (XBAR_IN[*]) is muxed to each mux output (XBAR_OUT[*]). There is one SELn field per mux and therefore one per XBAR_OUT output. Crossbar output XBAR_OUT[n]
presents the value of XBAR_IN[SELn]. Each select register contains two SELn fields. In the first select register, the LSBs contain the select field for mux 0, and the MSBs contain the select field for mux 1. The pattern repeats in subsequent select registers.

The actual signals connected to XBAR_IN and XBAR_OUT are application specific and are described in the Chip Configuration details.

The XBAR control registers configure edge detection, interrupt, and DMA features for a subset of the XBAR_OUT[*] outputs.

**XBARA memory map**

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>403B_C000</td>
<td>Crossbar A Select Register 0 (XBARA1_SEL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.1/3238</td>
</tr>
<tr>
<td>403B_C002</td>
<td>Crossbar A Select Register 1 (XBARA1_SEL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.2/3238</td>
</tr>
<tr>
<td>403B_C004</td>
<td>Crossbar A Select Register 2 (XBARA1_SEL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.3/3239</td>
</tr>
<tr>
<td>403B_C006</td>
<td>Crossbar A Select Register 3 (XBARA1_SEL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.4/3239</td>
</tr>
<tr>
<td>403B_C008</td>
<td>Crossbar A Select Register 4 (XBARA1_SEL4)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.5/3240</td>
</tr>
<tr>
<td>403B_C00A</td>
<td>Crossbar A Select Register 5 (XBARA1_SEL5)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.6/3240</td>
</tr>
<tr>
<td>403B_C00C</td>
<td>Crossbar A Select Register 6 (XBARA1_SEL6)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.7/3241</td>
</tr>
<tr>
<td>403B_C00E</td>
<td>Crossbar A Select Register 7 (XBARA1_SEL7)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.8/3241</td>
</tr>
<tr>
<td>403B_C010</td>
<td>Crossbar A Select Register 8 (XBARA1_SEL8)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.9/3242</td>
</tr>
<tr>
<td>403B_C012</td>
<td>Crossbar A Select Register 9 (XBARA1_SEL9)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.10/3242</td>
</tr>
<tr>
<td>403B_C014</td>
<td>Crossbar A Select Register 10 (XBARA1_SEL10)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.11/3243</td>
</tr>
<tr>
<td>403B_C016</td>
<td>Crossbar A Select Register 11 (XBARA1_SEL11)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.12/3243</td>
</tr>
<tr>
<td>403B_C018</td>
<td>Crossbar A Select Register 12 (XBARA1_SEL12)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.13/3244</td>
</tr>
<tr>
<td>403B_C01A</td>
<td>Crossbar A Select Register 13 (XBARA1_SEL13)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.14/3244</td>
</tr>
<tr>
<td>403B_C01C</td>
<td>Crossbar A Select Register 14 (XBARA1_SEL14)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.15/3245</td>
</tr>
<tr>
<td>403B_C01E</td>
<td>Crossbar A Select Register 15 (XBARA1_SEL15)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.16/3245</td>
</tr>
<tr>
<td>403B_C020</td>
<td>Crossbar A Select Register 16 (XBARA1_SEL16)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.17/3246</td>
</tr>
<tr>
<td>403B_C022</td>
<td>Crossbar A Select Register 17 (XBARA1_SEL17)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.18/3246</td>
</tr>
<tr>
<td>403B_C024</td>
<td>Crossbar A Select Register 18 (XBARA1_SEL18)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.19/3247</td>
</tr>
<tr>
<td>403B_C026</td>
<td>Crossbar A Select Register 19 (XBARA1_SEL19)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.20/3247</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### XBARA memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>403B_C028</td>
<td>Crossbar A Select Register 20 (XBARA1_SEL20)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.21/3248</td>
</tr>
<tr>
<td>403B_C02A</td>
<td>Crossbar A Select Register 21 (XBARA1_SEL21)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.22/3248</td>
</tr>
<tr>
<td>403B_C02C</td>
<td>Crossbar A Select Register 22 (XBARA1_SEL22)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.23/3249</td>
</tr>
<tr>
<td>403B_C02E</td>
<td>Crossbar A Select Register 23 (XBARA1_SEL23)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.24/3249</td>
</tr>
<tr>
<td>403B_C030</td>
<td>Crossbar A Select Register 24 (XBARA1_SEL24)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.25/3250</td>
</tr>
<tr>
<td>403B_C032</td>
<td>Crossbar A Select Register 25 (XBARA1_SEL25)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.26/3251</td>
</tr>
<tr>
<td>403B_C034</td>
<td>Crossbar A Select Register 26 (XBARA1_SEL26)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.27/3251</td>
</tr>
<tr>
<td>403B_C036</td>
<td>Crossbar A Select Register 27 (XBARA1_SEL27)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.28/3251</td>
</tr>
<tr>
<td>403B_C038</td>
<td>Crossbar A Select Register 28 (XBARA1_SEL28)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.29/3252</td>
</tr>
<tr>
<td>403B_C03A</td>
<td>Crossbar A Select Register 29 (XBARA1_SEL29)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.30/3252</td>
</tr>
<tr>
<td>403B_C03C</td>
<td>Crossbar A Select Register 30 (XBARA1_SEL30)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.31/3253</td>
</tr>
<tr>
<td>403B_C03E</td>
<td>Crossbar A Select Register 31 (XBARA1_SEL31)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.32/3253</td>
</tr>
<tr>
<td>403B_C040</td>
<td>Crossbar A Select Register 32 (XBARA1_SEL32)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.33/3254</td>
</tr>
<tr>
<td>403B_C042</td>
<td>Crossbar A Select Register 33 (XBARA1_SEL33)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.34/3254</td>
</tr>
<tr>
<td>403B_C044</td>
<td>Crossbar A Select Register 34 (XBARA1_SEL34)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.35/3254</td>
</tr>
<tr>
<td>403B_C046</td>
<td>Crossbar A Select Register 35 (XBARA1_SEL35)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.36/3255</td>
</tr>
<tr>
<td>403B_C048</td>
<td>Crossbar A Select Register 36 (XBARA1_SEL36)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.37/3256</td>
</tr>
<tr>
<td>403B_C04A</td>
<td>Crossbar A Select Register 37 (XBARA1_SEL37)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.38/3256</td>
</tr>
<tr>
<td>403B_C04C</td>
<td>Crossbar A Select Register 38 (XBARA1_SEL38)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.39/3257</td>
</tr>
<tr>
<td>403B_C04E</td>
<td>Crossbar A Select Register 39 (XBARA1_SEL39)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.40/3257</td>
</tr>
<tr>
<td>403B_C050</td>
<td>Crossbar A Select Register 40 (XBARA1_SEL40)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.41/3258</td>
</tr>
<tr>
<td>403B_C052</td>
<td>Crossbar A Select Register 41 (XBARA1_SEL41)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.42/3258</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>403B_C054</td>
<td>Crossbar A Select Register 42 (XBARA1_SEL42)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.43/3259</td>
</tr>
<tr>
<td>403B_C056</td>
<td>Crossbar A Select Register 43 (XBARA1_SEL43)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.44/3259</td>
</tr>
<tr>
<td>403B_C058</td>
<td>Crossbar A Select Register 44 (XBARA1_SEL44)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.45/3260</td>
</tr>
<tr>
<td>403B_C05A</td>
<td>Crossbar A Select Register 45 (XBARA1_SEL45)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.46/3260</td>
</tr>
<tr>
<td>403B_C05C</td>
<td>Crossbar A Select Register 46 (XBARA1_SEL46)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.47/3261</td>
</tr>
<tr>
<td>403B_C05E</td>
<td>Crossbar A Select Register 47 (XBARA1_SEL47)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.48/3261</td>
</tr>
<tr>
<td>403B_C060</td>
<td>Crossbar A Select Register 48 (XBARA1_SEL48)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.49/3262</td>
</tr>
<tr>
<td>403B_C062</td>
<td>Crossbar A Select Register 49 (XBARA1_SEL49)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.50/3262</td>
</tr>
<tr>
<td>403B_C064</td>
<td>Crossbar A Select Register 50 (XBARA1_SEL50)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.51/3263</td>
</tr>
<tr>
<td>403B_C066</td>
<td>Crossbar A Select Register 51 (XBARA1_SEL51)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.52/3263</td>
</tr>
<tr>
<td>403B_C068</td>
<td>Crossbar A Select Register 52 (XBARA1_SEL52)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.53/3263</td>
</tr>
<tr>
<td>403B_C06A</td>
<td>Crossbar A Select Register 53 (XBARA1_SEL53)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.54/3264</td>
</tr>
<tr>
<td>403B_C06C</td>
<td>Crossbar A Select Register 54 (XBARA1_SEL54)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.55/3265</td>
</tr>
<tr>
<td>403B_C06E</td>
<td>Crossbar A Select Register 55 (XBARA1_SEL55)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.56/3265</td>
</tr>
<tr>
<td>403B_C070</td>
<td>Crossbar A Select Register 56 (XBARA1_SEL56)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.57/3266</td>
</tr>
<tr>
<td>403B_C072</td>
<td>Crossbar A Select Register 57 (XBARA1_SEL57)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.58/3266</td>
</tr>
<tr>
<td>403B_C074</td>
<td>Crossbar A Select Register 58 (XBARA1_SEL58)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.59/3267</td>
</tr>
<tr>
<td>403B_C076</td>
<td>Crossbar A Select Register 59 (XBARA1_SEL59)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.60/3267</td>
</tr>
<tr>
<td>403B_C078</td>
<td>Crossbar A Select Register 60 (XBARA1_SEL60)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.61/3268</td>
</tr>
<tr>
<td>403B_C07A</td>
<td>Crossbar A Select Register 61 (XBARA1_SEL61)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.62/3268</td>
</tr>
<tr>
<td>403B_C07C</td>
<td>Crossbar A Select Register 62 (XBARA1_SEL62)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.63/3269</td>
</tr>
<tr>
<td>403B_C07E</td>
<td>Crossbar A Select Register 63 (XBARA1_SEL63)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.64/3269</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### XBARA memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>403B_C080</td>
<td>Crossbar A Select Register 64 (XBARA1_SEL64)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.65/3270</td>
</tr>
<tr>
<td>403B_C082</td>
<td>Crossbar A Select Register 65 (XBARA1_SEL65)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.66/3270</td>
</tr>
<tr>
<td>403B_C084</td>
<td>Crossbar A Control Register 0 (XBARA1_CTRL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.67/3271</td>
</tr>
<tr>
<td>403B_C086</td>
<td>Crossbar A Control Register 1 (XBARA1_CTRL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>61.4.68/3273</td>
</tr>
</tbody>
</table>

#### 61.4.1 Crossbar A Select Register 0 (XBARAx_SEL0)

Address: 403B_C000h base + 0h offset = 403B_C000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL0 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved: This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL1: Input (XBARA_INn) to be muxed to XBARA_OUT1 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved: This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL0</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT0 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

#### 61.4.2 Crossbar A Select Register 1 (XBARAx_SEL1)

Address: 403B_C000h base + 2h offset = 403B_C002h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### XBARAx_SEL1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL3</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT3 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL2</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT2 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.3 Crossbar A Select Register 2 (XBARAx_SEL2)

Address: 403B_C000h base + 4h offset = 403B_C004h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL2 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL5</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT5 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL4</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT4 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.4 Crossbar A Select Register 3 (XBARAx_SEL3)

Address: 403B_C000h base + 6h offset = 403B_C006h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL3 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### XBARAx_SEL3 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14–8 SEL7</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT7 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 61.4.5 Crossbar A Select Register 4 (XBARAx_SEL4)

Address: 403B_C000h base + 8h offset = 403B_C008h

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| Read | 0 | SEL9 | 0 | SEL8 |
| Write | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### XBARAx_SEL4 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8 SEL9</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT9 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6</td>
<td>Reserved</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>Reserved</td>
</tr>
<tr>
<td>0</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 61.4.6 Crossbar A Select Register 5 (XBARAx_SEL5)

Address: 403B_C000h base + Ah offset = 403B_C00Ah

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| Read | 0 | SEL11 | 0 | SEL10 |
| Write | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### XBARAx_SEL5 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8 SEL11</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT11 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### XBARA\_SEL5 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL10</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT10 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.7 Crossbar A Select Register 6 (XBARA\_SEL6)

Address: 403B\_C000h base + Ch offset = 403B\_C00Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td>SEL13</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

### XBARA\_SEL6 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL13</td>
</tr>
<tr>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT13 (refer to Functional Description section for input/output assignment)</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL12</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT12 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.8 Crossbar A Select Register 7 (XBARA\_SEL7)

Address: 403B\_C000h base + Eh offset = 403B\_C00Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td>SEL15</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### XBARA\_SEL7 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL15</td>
</tr>
<tr>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT15 (refer to Functional Description section for input/output assignment)</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### XBARAx_SEL7 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SEL14</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT14 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.9 Crossbar A Select Register 8 (XBARAx_SEL8)

**Address:** 403B_C000h base + 10h offset = 403B_C010h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>SEL17</td>
<td>0</td>
<td>SEL16</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL8 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL17</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT17 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL16</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT16 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.10 Crossbar A Select Register 9 (XBARAx_SEL9)

**Address:** 403B_C000h base + 12h offset = 403B_C012h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>SEL19</td>
<td>0</td>
<td>SEL18</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL9 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL19</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT19 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL18</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT18 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.11 Crossbar A Select Register 10 (XBARAx_SEL10)

Address: 403B_C000h base + 14h offset = 403B_C014h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL21</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL10 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL21</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL20</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT20 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.12 Crossbar A Select Register 11 (XBARAx_SEL11)

Address: 403B_C000h base + 16h offset = 403B_C016h

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| Read| 0  |    |    |    |    |    |   |   | SEL23 |    |    |    |    |   |   |   |   |
| Write|    |    |    |    |    |    |   |   |    | 0 |    |    |    |    |   |   |   |   |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

XBARAx_SEL11 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL23</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL22</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT22 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### Crossbar A Select Register 12 (XBARA\_SEL12)

**Address:** 403B\_C000h base + 18h offset = 403B\_C018h

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Read| 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Write|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### XBARA\_SEL12 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL25 Input (XBARA_INn) to be muxed to XBARA_OUT25 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL24</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT24 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### Crossbar A Select Register 13 (XBARA\_SEL13)

**Address:** 403B\_C000h base + 1Ah offset = 403B\_C01Ah

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### XBARA\_SEL13 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL27 Input (XBARA_INn) to be muxed to XBARA_OUT27 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL26</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT26 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.15 Crossbar A Select Register 14 (XBARA\_SEL14)

Address: 403B\_C000h base + 1Ch offset = 403B\_C01Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARA\_SEL14 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL29</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT29 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL28</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT28 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.16 Crossbar A Select Register 15 (XBARA\_SEL15)

Address: 403B\_C000h base + 1Eh offset = 403B\_C01Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARA\_SEL15 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL31</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT31 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL30</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT30 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.17 Crossbar A Select Register 16 (XBARAx_SEL16)

Address: 403B_C000h base + 20h offset = 403B_C020h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>SEL33</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**XBARAx_SEL16 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL33</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 61.4.18 Crossbar A Select Register 17 (XBARAx_SEL17)

Address: 403B_C000h base + 22h offset = 403B_C022h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>SEL35</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**XBARAx_SEL17 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL35</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
61.4.19 Crossbar A Select Register 18 (XBARAx_SEL18)

Address: 403B_C000h base + 24h offset = 403B_C024h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL37</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL18 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL37</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL36</td>
<td></td>
</tr>
</tbody>
</table>

61.4.20 Crossbar A Select Register 19 (XBARAx_SEL19)

Address: 403B_C000h base + 26h offset = 403B_C026h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL39</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL19 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL39</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL38</td>
<td></td>
</tr>
</tbody>
</table>

This field is reserved.
This read-only field is reserved and always has the value 0.
Input (XBARA_INn) to be muxed to XBARA_OUT37 (refer to Functional Description section for input/output assignment)
Input (XBARA_INn) to be muxed to XBARA_OUT39 (refer to Functional Description section for input/output assignment)
61.4.21 Crossbar A Select Register 20 (XBARAx_SEL20)

Address: 403B_C000h base + 28h offset = 403B_C028h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL20 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL41</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT41 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL40</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT40 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.22 Crossbar A Select Register 21 (XBARAx_SEL21)

Address: 403B_C000h base + 2Ah offset = 403B_C02Ah

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>7</td>
<td>6</td>
<td>5</td>
<td>4</td>
<td>3</td>
<td>2</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL21 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL43</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT43 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL42</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT42 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
## 61.4.23 Crossbar A Select Register 22 (XBARAx_SEL22)

Address: 403B_C000h base + 2Ch offset = 403B_C02Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>SEL45</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

### XBARAx_SEL22 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL45</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT45 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL44</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT44 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

## 61.4.24 Crossbar A Select Register 23 (XBARAx_SEL23)

Address: 403B_C000h base + 2Eh offset = 403B_C02Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>SEL47</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

### XBARAx_SEL23 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL47</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT47 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL46</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT46 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.25 Crossbar A Select Register 24 (XBARAx_SEL24)

Address: 403B_C000h base + 30h offset = 403B_C030h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL49</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL24 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL49</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT49 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL48</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT48 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.26 Crossbar A Select Register 25 (XBARAx_SEL25)

Address: 403B_C000h base + 32h offset = 403B_C032h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL51</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL25 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL51</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT51 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL50</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT50 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.27 Crossbar A Select Register 26 (XBARAx_SEL26)

Address: 403B_C000h base + 34h offset = 403B_C034h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### XBARAx_SEL26 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL53</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT53 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL52</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT52 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.28 Crossbar A Select Register 27 (XBARAx_SEL27)

Address: 403B_C000h base + 36h offset = 403B_C036h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### XBARAx_SEL27 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL55</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT55 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL54</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT54 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.29 Crossbar A Select Register 28 (XBARAx_SEL28)

Address: 403B_C000h base + 38h offset = 403B_C038h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td>SEL57</td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL28 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL57</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT57 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL56</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT56 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.30 Crossbar A Select Register 29 (XBARAx_SEL29)

Address: 403B_C000h base + 3Ah offset = 403B_C03Ah

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td>SEL59</td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL29 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL59</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT59 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL58</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT58 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.31 Crossbar A Select Register 30 (XBARAx_SEL30)

Address: 403B_C000h base + 3Ch offset = 403B_C03Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td>SEL61</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

XBARAx_SEL30 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL61 Input (XBARA_INn) to be muxed to XBARA_OUT61 (refer to Functional Description section for input/output assignment)</td>
<td></td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL60 Input (XBARA_INn) to be muxed to XBARA_OUT60 (refer to Functional Description section for input/output assignment)</td>
<td></td>
</tr>
</tbody>
</table>

### 61.4.32 Crossbar A Select Register 31 (XBARAx_SEL31)

Address: 403B_C000h base + 3Eh offset = 403B_C03Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td>SEL63</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

XBARAx_SEL31 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL63 Input (XBARA_INn) to be muxed to XBARA_OUT63 (refer to Functional Description section for input/output assignment)</td>
<td></td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL62 Input (XBARA_INn) to be muxed to XBARA_OUT62 (refer to Functional Description section for input/output assignment)</td>
<td></td>
</tr>
</tbody>
</table>
### 61.4.33 Crossbar A Select Register 32 (XBARAx_SEL32)

Address: 403B_C000h base + 40h offset = 403B_C040h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL65</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL32 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved. This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL65 Input (XBARA_INn) to be muxed to XBARA_OUT65 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved. This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL64</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT64 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.34 Crossbar A Select Register 33 (XBARAx_SEL33)

Address: 403B_C000h base + 42h offset = 403B_C042h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL67</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL33 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved. This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL67 Input (XBARA_INn) to be muxed to XBARA_OUT67 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved. This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL66</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT66 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.35 Crossbar A Select Register 34 (XBARAx_SEL34)

Address: 403B_C000h base + 44h offset = 403B_C044h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL69</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL34 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL69</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL68</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT68 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.36 Crossbar A Select Register 35 (XBARAx_SEL35)

Address: 403B_C000h base + 46h offset = 403B_C046h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL71</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL35 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL71</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL70</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT70 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
## 61.4.37 Crossbar A Select Register 36 (XBARAx_SEL36)

Address: 403B_C000h base + 48h offset = 403B_C048h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL73</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### XBARAx_SEL36 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL73</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT73 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL72</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT72 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

## 61.4.38 Crossbar A Select Register 37 (XBARAx_SEL37)

Address: 403B_C000h base + 4Ah offset = 403B_C04Ah

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL75</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### XBARAx_SEL37 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL75</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT75 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL74</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT74 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.39 Crossbar A Select Register 38 (XBARAx_SEL38)

Address: 403B_C000h base + 4Ch offset = 403B_C04Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL77</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL38 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15    | Reserved
| 14–8  | SEL77
| 7     | Reserved
| SEL76 | Input (XBARA_INn) to be muxed to XBARA_OUT76 (refer to Functional Description section for input/output assignment) |

### 61.4.40 Crossbar A Select Register 39 (XBARAx_SEL39)

Address: 403B_C000h base + 4Eh offset = 403B_C04Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL79</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL39 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15    | Reserved
| 14–8  | SEL79
| 7     | Reserved
| SEL78 | Input (XBARA_INn) to be muxed to XBARA_OUT78 (refer to Functional Description section for input/output assignment) |
61.4.41 Crossbar A Select Register 40 (XBARAx_SEL40)

Address: 403B_C000h base + 50h offset = 403B_C050h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL81</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL40 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL81</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT81 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL80</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT80 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.42 Crossbar A Select Register 41 (XBARAx_SEL41)

Address: 403B_C000h base + 52h offset = 403B_C052h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL83</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL41 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL83</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT83 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL82</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT82 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.43  Crossbar A Select Register 42 (XBARAx_SEL42)

Address: 403B_C000h base + 54h offset = 403B_C054h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL42 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL85</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL84</td>
<td></td>
</tr>
</tbody>
</table>

61.4.44  Crossbar A Select Register 43 (XBARAx_SEL43)

Address: 403B_C000h base + 56h offset = 403B_C056h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL43 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL87</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL86</td>
<td></td>
</tr>
</tbody>
</table>
### 61.4.45 Crossbar A Select Register 44 (XBARAx_SEL44)

Address: 403B_C000h base + 58h offset = 403B_C058h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>SEL89</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**XBARAx_SEL44 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL89</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT89 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL88</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT88 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.46 Crossbar A Select Register 45 (XBARAx_SEL45)

Address: 403B_C000h base + 5Ah offset = 403B_C05Ah

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>SEL91</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**XBARAx_SEL45 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL91</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT91 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL90</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT90 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.47 Crossbar A Select Register 46 (XBARAx_SEL46)

Address: 403B_C000h base + 5Ch offset = 403B_C05Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL46 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15 Reserved | This field is reserved.  
This read-only field is reserved and always has the value 0. |
| 14–8 SEL93 | Input (XBARA_INn) to be muxed to XBARA_OUT93 (refer to Functional Description section for input/output assignment) |
| 7 Reserved | This field is reserved.  
This read-only field is reserved and always has the value 0. |
| SEL92 | Input (XBARA_INn) to be muxed to XBARA_OUT92 (refer to Functional Description section for input/output assignment) |

### 61.4.48 Crossbar A Select Register 47 (XBARAx_SEL47)

Address: 403B_C000h base + 5Eh offset = 403B_C05Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_SEL47 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15 Reserved | This field is reserved.  
This read-only field is reserved and always has the value 0. |
| 14–8 SEL95 | Input (XBARA_INn) to be muxed to XBARA_OUT95 (refer to Functional Description section for input/output assignment) |
| 7 Reserved | This field is reserved.  
This read-only field is reserved and always has the value 0. |
| SEL94 | Input (XBARA_INn) to be muxed to XBARA_OUT94 (refer to Functional Description section for input/output assignment) |
61.4.49  Crossbar A Select Register 48 (XBARAx_SEL48)

Address: 403B_C000h base + 60h offset = 403B_C060h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL97</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL96</td>
<td></td>
</tr>
</tbody>
</table>

Field descriptions:
- **15 Reserved**: This field is reserved. This read-only field is reserved and always has the value 0.
- **14–8 SEL97**: Input (XBARA_INn) to be muxed to XBARA_OUT97 (refer to Functional Description section for input/output assignment)
- **7 Reserved**: This field is reserved. This read-only field is reserved and always has the value 0.
- **SEL96**: Input (XBARA_INn) to be muxed to XBARA_OUT96 (refer to Functional Description section for input/output assignment)

61.4.50  Crossbar A Select Register 49 (XBARAx_SEL49)

Address: 403B_C000h base + 62h offset = 403B_C062h

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL99</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL98</td>
<td></td>
</tr>
</tbody>
</table>

Field descriptions:
- **15 Reserved**: This field is reserved. This read-only field is reserved and always has the value 0.
- **14–8 SEL99**: Input (XBARA_INn) to be muxed to XBARA_OUT99 (refer to Functional Description section for input/output assignment)
- **7 Reserved**: This field is reserved. This read-only field is reserved and always has the value 0.
- **SEL98**: Input (XBARA_INn) to be muxed to XBARA_OUT98 (refer to Functional Description section for input/output assignment)
### 61.4.51 Crossbar A Select Register 50 (XBARAx_SEL50)

Address: 403B_C000h base + 64h offset = 403B_C064h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL101</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>SEL100</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### XBARAx_SEL50 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL101</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

#### XBARAx_SEL50 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL101</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

### 61.4.52 Crossbar A Select Register 51 (XBARAx_SEL51)

Address: 403B_C000h base + 66h offset = 403B_C066h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL103</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>SEL102</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### XBARAx_SEL51 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL103</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

#### XBARAx_SEL51 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL103</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
61.4.53 Crossbar A Select Register 52 (XBARAx_SEL52)

Address: 403B_C000h base + 68h offset = 403B_C068h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>SEL105</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>SEL104</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

XBARAx_SEL52 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL105</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT105 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL104</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT104 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.54 Crossbar A Select Register 53 (XBARAx_SEL53)

Address: 403B_C000h base + 6Ah offset = 403B_C06Ah

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>SEL107</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>SEL106</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

XBARAx_SEL53 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL107</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT107 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL106</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT106 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
## 61.4.55 Crossbar A Select Register 54 (XBARAx_SEL54)

Address: 403B_C000h base + 6Ch offset = 403B_C06Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td>SEL109</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>SEL108</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

### XBARAx_SEL54 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL109 Input (XBARA_INn) to be muxed to XBARA_OUT109 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL108</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT108 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

## 61.4.56 Crossbar A Select Register 55 (XBARAx_SEL55)

Address: 403B_C000h base + 6Eh offset = 403B_C06Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td></td>
<td>SEL111</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>SEL110</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

### XBARAx_SEL55 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL111 Input (XBARA_INn) to be muxed to XBARA_OUT111 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL110</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT110 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.57 Crossbar A Select Register 56 (XBARAx_SEL56)

Address: 403B_C000h base + 70h offset = 403B_C070h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>SEL13</td>
<td>0</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL113</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6–0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL56 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL113 Input (XBARA_INn) to be muxed to XBARA_OUT113 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6–0</td>
<td>SEL112 Input (XBARA_INn) to be muxed to XBARA_OUT112 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.58 Crossbar A Select Register 57 (XBARAx_SEL57)

Address: 403B_C000h base + 72h offset = 403B_C072h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>SEL15</td>
<td>0</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL115</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6–0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL57 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL115 Input (XBARA_INn) to be muxed to XBARA_OUT115 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td>6–0</td>
<td>SEL114 Input (XBARA_INn) to be muxed to XBARA_OUT114 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.59 Crossbar A Select Register 58 (XBARA<sub>x</sub>_SEL58)

Address: 403B_C000h base + 74h offset = 403B_C074h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>SEL17</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>SEL16</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

XBARA<sub>x</sub>_SEL58 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL117</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT117 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL116</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT116 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.60 Crossbar A Select Register 59 (XBARA<sub>x</sub>_SEL59)

Address: 403B_C000h base + 76h offset = 403B_C076h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>SEL19</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>SEL18</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

XBARA<sub>x</sub>_SEL59 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8</td>
<td>SEL119</td>
</tr>
<tr>
<td></td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT119 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL118</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT118 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.61 Crossbar A Select Register 60 (XBARAx_SEL60)

Address: 403B_C000h base + 78h offset = 403B_C078h

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL121</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL60 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL121</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT121 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL120</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT120 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.62 Crossbar A Select Register 61 (XBARAx_SEL61)

Address: 403B_C000h base + 7Ah offset = 403B_C07Ah

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>SEL123</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL61 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL123</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT123 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL122</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT122 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.63 Crossbar A Select Register 62 (XBARAx_SEL62)

Address: 403B_C000h base + 7Ch offset = 403B_C07Ch

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>SEL125</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL62 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14-8 SEL125</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT125 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL124</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT124 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

61.4.64 Crossbar A Select Register 63 (XBARAx_SEL63)

Address: 403B_C000h base + 7Eh offset = 403B_C07Eh

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>SEL127</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_SEL63 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14-8 SEL127</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT127 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL126</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT126 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 61.4.65 Crossbar A Select Register 64 (XBARAx_SEL64)

Address: 403B_C000h base + 80h offset = 403B_C080h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>SEL129</td>
<td>0</td>
<td>SEL128</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**XBARAx_SEL64 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL129</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT129 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL128</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT128 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 61.4.66 Crossbar A Select Register 65 (XBARAx_SEL65)

Address: 403B_C000h base + 82h offset = 403B_C082h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>SEL131</td>
<td>0</td>
<td>SEL130</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**XBARAx_SEL65 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>14–8 SEL131</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT131 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL130</td>
<td>Input (XBARA_INn) to be muxed to XBARA_OUT130 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
61.4.67 Crossbar A Control Register 0 (XBARAx_CTRL0)

Use this register to configure edge detection, interrupt, and DMA features for the XBAR_OUT0 and XBAR_OUT1 outputs.

The XBAR_CTRL registers are organized similarly to the XBAR_SEL registers, with control fields for two XBAR_OUT outputs in each register. In control register 0, the LSBs contain the control fields for XBAR_OUT0, and the MSBs contain the control fields for XBAR_OUT1.

Address: 403B_C000h base + 84h offset = 403B_C084h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td>STS1</td>
<td></td>
<td>EDGE1</td>
<td>IEN1</td>
<td>DEN1</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td>w1c</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td>STS0</td>
<td></td>
<td>EDGE0</td>
<td>IEN0</td>
<td>DEN0</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td>w1c</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARAx_CTRL0 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–13 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 12 STS1 | Edge detection status for XBAR_OUT1  
This bit reflects the results of edge detection for XBAR_OUT1.  
This field is set to 1 when an edge consistent with the current setting of EDGE1 is detected on XBAR_OUT1. This field is cleared by writing 1 to it or by a DMA_ACK1 reception when DEN1 is set. Writing 0 to the field has no effect.  
When interrupt or DMA functionality is enabled for XBAR_OUT1, this field is 1 when the interrupt or DMA request is asserted and 0 when the interrupt or DMA request has been cleared.  
0 Active edge not yet detected on XBAR_OUT1  
1 Active edge detected on XBAR_OUT1 |
| 11–10 EDGE1 | Active edge for edge detection on XBAR_OUT1  
This field selects which edges on XBAR_OUT1 cause STS1 to assert.  
00 STS1 never asserts  
01 STS1 asserts on rising edges of XBAR_OUT1  
10 STS1 asserts on falling edges of XBAR_OUT1  
11 STS1 asserts on rising and falling edges of XBAR_OUT1 |
| 9 IEN1 | Interrupt Enable for XBAR_OUT1 |

*Table continues on the next page...*
**XBARAx_CTRL0 field descriptions (continued)**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>This bit enables the interrupt function on the corresponding XBAR_OUT1 output. When the interrupt is enabled, the output INT_REQ1 reflects the value STS1. When the interrupt is disabled, INT_REQ1 remains low. The interrupt request is cleared by writing a 1 to STS1.</td>
</tr>
<tr>
<td><strong>Restriction:</strong></td>
<td>IEN1 and DEN1 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>Interrupt disabled</td>
</tr>
<tr>
<td>1</td>
<td>Interrupt enabled</td>
</tr>
<tr>
<td>8 DEN1</td>
<td>DMA Enable for XBAR_OUT1</td>
</tr>
<tr>
<td></td>
<td>This bit enables the DMA function on the corresponding XBAR_OUT1 output. When enabled, DMA_REQ1 presents the value STS1. When disabled, the DMA_REQ1 output remains low.</td>
</tr>
<tr>
<td><strong>Restriction:</strong></td>
<td>IEN1 and DEN1 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>DMA disabled</td>
</tr>
<tr>
<td>1</td>
<td>DMA enabled</td>
</tr>
<tr>
<td>7–5 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4 STS0</td>
<td>Edge detection status for XBAR_OUT0</td>
</tr>
<tr>
<td></td>
<td>This bit reflects the results of edge detection for XBAR_OUT0.</td>
</tr>
<tr>
<td></td>
<td>This field is set to 1 when an edge consistent with the current setting of EDGE0 is detected on XBAR_OUT0. This field is cleared by writing 1 to it or by a DMA_ACK0 reception when DEN0 is set. Writing 0 to the field has no effect.</td>
</tr>
<tr>
<td></td>
<td>When interrupt or DMA functionality is enabled for XBAR_OUT0, this field is 1 when the interrupt or DMA request is asserted and 0 when the interrupt or DMA request has been cleared.</td>
</tr>
<tr>
<td>0</td>
<td>Active edge not yet detected on XBAR_OUT0</td>
</tr>
<tr>
<td>1</td>
<td>Active edge detected on XBAR_OUT0</td>
</tr>
<tr>
<td>3–2 EDGE0</td>
<td>Active edge for edge detection on XBAR_OUT0</td>
</tr>
<tr>
<td></td>
<td>This field selects which edges on XBAR_OUT0 cause STS0 to assert.</td>
</tr>
<tr>
<td>00</td>
<td>STS0 never asserts</td>
</tr>
<tr>
<td>01</td>
<td>STS0 asserts on rising edges of XBAR_OUT0</td>
</tr>
<tr>
<td>10</td>
<td>STS0 asserts on falling edges of XBAR_OUT0</td>
</tr>
<tr>
<td>11</td>
<td>STS0 asserts on rising and falling edges of XBAR_OUT0</td>
</tr>
<tr>
<td>1 IEN0</td>
<td>Interrupt Enable for XBAR_OUT0</td>
</tr>
<tr>
<td></td>
<td>This bit enables the interrupt function on the corresponding XBAR_OUT0 output. When the interrupt is enabled, the output INT_REQ0 reflects the value STS0. When the interrupt is disabled, INT_REQ0 remains low. The interrupt request is cleared by writing a 1 to STS0.</td>
</tr>
<tr>
<td><strong>Restriction:</strong></td>
<td>IEN0 and DEN0 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>Interrupt disabled</td>
</tr>
<tr>
<td>1</td>
<td>Interrupt enabled</td>
</tr>
<tr>
<td>0 DEN0</td>
<td>DMA Enable for XBAR_OUT0</td>
</tr>
<tr>
<td></td>
<td>This bit enables the DMA function on the corresponding XBAR_OUT0 output. When enabled, DMA_REQ0 presents the value STS0. When disabled, the DMA_REQ0 output remains low.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
XBARAx_CTRL0 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td><strong>Restriction:</strong> IEN0 and DEN0 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>DMA disabled</td>
</tr>
<tr>
<td>1</td>
<td>DMA enabled</td>
</tr>
</tbody>
</table>

61.4.68 Crossbar A Control Register 1 (XBARAx_CTRL1)

Use this register to configure edge detection, interrupt, and DMA features for the XBAR_OUT2 and XBAR_OUT3 outputs.

The XBAR_CTRL registers are organized similarly to the XBAR_SEL registers, with control fields for two XBAR_OUT outputs in each register. In control register 1, the LSBs contain the control fields for XBAR_OUT2, and the MSBs contain the control fields for XBAR_OUT3.

Address: 403B_C000h base + 86h offset = 403B_C086h

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td>STS3</td>
<td></td>
<td>EDGE3</td>
<td>IEN3</td>
<td>DEN3</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td>w1c</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td>STS2</td>
<td></td>
<td>EDGE2</td>
<td>IEN2</td>
<td>DEN2</td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td>w1c</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARAx_CTRL1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–13 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 12 STS3 | Edge detection status for XBAR_OUT3
This bit reflects the results of edge detection for XBAR_OUT3. This field is set to 1 when an edge consistent with the current setting of EDGE3 is detected on XBAR_OUT3. This field is cleared by writing 1 to it or by a DMA_ACK3 reception when DEN3 is set. Writing 0 to the field has no effect. When interrupt or DMA functionality is enabled for XBAR_OUT3, this field is 1 when the interrupt or DMA request is asserted and 0 when the interrupt or DMA request has been cleared. |
| 0 | Active edge not yet detected on XBAR_OUT3 |
| 1 | Active edge detected on XBAR_OUT3 |

Table continues on the next page...
### XBARAx_CTRL1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11–10 EDGE3</td>
<td>Active edge for edge detection on XBAR_OUT3</td>
</tr>
<tr>
<td></td>
<td>This field selects which edges on XBAR_OUT3 cause STS3 to assert.</td>
</tr>
<tr>
<td>00</td>
<td>STS3 never asserts</td>
</tr>
<tr>
<td>01</td>
<td>STS3 asserts on rising edges of XBAR_OUT3</td>
</tr>
<tr>
<td>10</td>
<td>STS3 asserts on falling edges of XBAR_OUT3</td>
</tr>
<tr>
<td>11</td>
<td>STS3 asserts on rising and falling edges of XBAR_OUT3</td>
</tr>
<tr>
<td>9</td>
<td>IEN3 Interrupt Enable for XBAR_OUT3</td>
</tr>
<tr>
<td></td>
<td>This bit enables the interrupt function on the corresponding XBAR_OUT3 output.</td>
</tr>
<tr>
<td></td>
<td>When the interrupt is enabled, the output INT_REQ3 reflects the value STS3.</td>
</tr>
<tr>
<td></td>
<td>When the interrupt is disabled, INT_REQ3 remains low.</td>
</tr>
<tr>
<td></td>
<td>The interrupt request is cleared by writing a 1 to STS3.</td>
</tr>
<tr>
<td></td>
<td><strong>Restriction:</strong> IEN3 and DEN3 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>Interrupt disabled</td>
</tr>
<tr>
<td>1</td>
<td>Interrupt enabled</td>
</tr>
<tr>
<td>8</td>
<td>DEN3 DMA Enable for XBAR_OUT3</td>
</tr>
<tr>
<td></td>
<td>This bit enables the DMA function on the corresponding XBAR_OUT3 output.</td>
</tr>
<tr>
<td></td>
<td>When enabled, DMA_REQ3 presents the value STS3.</td>
</tr>
<tr>
<td></td>
<td>When disabled, the DMA_REQ3 output remains low.</td>
</tr>
<tr>
<td></td>
<td><strong>Restriction:</strong> IEN3 and DEN3 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>DMA disabled</td>
</tr>
<tr>
<td>1</td>
<td>DMA enabled</td>
</tr>
<tr>
<td>7–5</td>
<td>Reserved This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4</td>
<td>STS2 Edge detection status for XBAR_OUT2</td>
</tr>
<tr>
<td></td>
<td>This bit reflects the results of edge detection for XBAR_OUT2.</td>
</tr>
<tr>
<td></td>
<td>This field is set to 1 when an edge consistent with the current setting of EDGE2 is detected on XBAR_OUT2. This field is cleared by writing 1 to it or by a DMA_ACK2 reception when DEN2 is set. Writing 0 to the field has no effect. When interrupt or DMA functionality is enabled for XBAR_OUT2, this field is 1 when the interrupt or DMA request is asserted and 0 when the interrupt or DMA request has been cleared.</td>
</tr>
<tr>
<td>0</td>
<td>Active edge not yet detected on XBAR_OUT2</td>
</tr>
<tr>
<td>1</td>
<td>Active edge detected on XBAR_OUT2</td>
</tr>
<tr>
<td>3–2</td>
<td>EDGE2 Active edge for edge detection on XBAR_OUT2</td>
</tr>
<tr>
<td></td>
<td>This field selects which edges on XBAR_OUT2 cause STS2 to assert.</td>
</tr>
<tr>
<td>00</td>
<td>STS2 never asserts</td>
</tr>
<tr>
<td>01</td>
<td>STS2 asserts on rising edges of XBAR_OUT2</td>
</tr>
<tr>
<td>10</td>
<td>STS2 asserts on falling edges of XBAR_OUT2</td>
</tr>
<tr>
<td>11</td>
<td>STS2 asserts on rising and falling edges of XBAR_OUT2</td>
</tr>
<tr>
<td>1</td>
<td>IEN2 Interrupt Enable for XBAR_OUT2</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
XBARAx_CTRL1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>This bit enables the interrupt function on the corresponding XBAR_OUT2 output. When the interrupt is enabled, the output INT_REQ2 reflects the value STS2. When the interrupt is disabled, INT_REQ2 remains low. The interrupt request is cleared by writing a 1 to STS2.</td>
<td></td>
</tr>
<tr>
<td>Restriction:</td>
<td>IEN2 and DEN2 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>Interrupt disabled</td>
</tr>
<tr>
<td>1</td>
<td>Interrupt enabled</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>DEN2</th>
<th>DMA Enable for XBAR_OUT2</th>
</tr>
</thead>
<tbody>
<tr>
<td>This bit enables the DMA function on the corresponding XBAR_OUT2 output. When enabled, DMA_REQ2 presents the value STS2. When disabled, the DMA_REQ2 output remains low.</td>
<td></td>
</tr>
<tr>
<td>Restriction:</td>
<td>IEN2 and DEN2 should not both be set to 1.</td>
</tr>
<tr>
<td>0</td>
<td>DMA disabled</td>
</tr>
<tr>
<td>1</td>
<td>DMA enabled</td>
</tr>
</tbody>
</table>

### 61.5 Functional Description

#### 61.5.1 General

The XBAR module has only one mode of operation, functional mode.

#### 61.5.2 Functional Mode

The value of each mux output is XBAR_OUT[n] = XBAR_IN[SELn]. The SELn select values are configured in the XBAR_SEL registers. All muxes share the same inputs in the same order.

A subset of XBAR_OUT[*] outputs has dedicated control fields in a Crossbar Control (XBAR_CTRL) register. Control fields provide the ability to perform edge detection on the corresponding XBAR_OUT output. Edge detection in turn can optionally be used to trigger an interrupt or DMA request. The intention is that, by detecting specified edges on signals propagating through the Crossbar, interrupts or DMA requests can be triggered to perform data transfers to or from other system components.

Control fields include an edge status field (STS), an detected edge type field (EDGE), and interrupt and DMA enable fields (DEN and IEN). STSn is set to 1 when an edge consistent with EDGEn occurs on XBAR_OUT[n]. STSn is cleared by writing 1 to it. Writing 0 as no effect. See Interrupts and DMA Requests for details on the use of STSn for DMA and interrupt request generation.
61.6 Resets
The XBAR module can be reset by only a hard reset, which forces all registers to their reset state.

61.7 Clocks
All sequential functionality is controlled by the Bus Clock.

61.8 Interrupts and DMA Requests
For each XBAR_OUT[*] output with XBAR_CTRL register support, DMA or interrupt functionality can be enabled by setting the corresponding XBAR_CTRL register bit DENn or IENn to 1. DENn and IENn should not be set to 1 at the same time for the same output XBAR_OUT[n].

Setting DENn to 1 enables DMA functionality for XBAR_OUT[n]. When DMA functionality is enabled, the output DMA_REQ[n] reflects the value of STSn. Thus the DMA request asserts when the edge specified by EDGEn is detected on XBAR_OUT[n]. Also, a rising edge on DMA_ACK[n] sets STSn to zero and thus clears the DMA request. When DEN is 0, DMA_REQ[n] is held low and DMA_ACK[n] is ignored.

Setting IENn to 1 enables interrupt functionality for XBAR_OUT[n]. When interrupt functionality is enabled, the output INT_REQ[n] reflects the value of STSn. Thus the interrupt request asserts when the edge specified by EDGEIEn is detected on XBAR_OUT[n]. The interrupt request is cleared by writing a 1 to STSn. When IENn is 0, INT_REQ[n] is held low.

DENn and IENn should not be set to 1 at the same time for the same output XBAR_OUT[n].
Chapter 62
Inter-Peripheral Crossbar Switch B (XBARB)

62.1 Chip-specific XBAR information

On this device, for XBAR1 (see the XBARA chapter), the number of inputs is 88, and the number of outputs is 132. For XBAR2 and XBAR3 (see the XBARB chapter), the number of inputs is 64, and the number of outputs is 16.

NOTE
The XBAR_INn and XBAR_OUTn signals (n=4 to 19) share the same IOs. The user needs to configure the corresponding IOMUXC_GPR_GPR6[IOMUXC_XBAR_DIR_SEL_n] bit to use either XBAR_IN or XBAR_OUT.

Table 62-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
</tbody>
</table>

62.2 Introduction

For a description of the general features and functionality of this module, refer to the XBARA description.
62.3 Memory Map and Register Descriptions

This section provides information about the XBARB instance of the inter-peripheral crossbar switch. Refer to the XBARA register details for information about that instance of the module.

This XBAR module has only select registers.

In the XBAR select registers, the SELn fields select which of the shared inputs (XBAR_IN[*]) is muxed to each mux output (XBAR_OUT[*]). There is one SELn field per mux and therefore one per XBAR_OUT output. Crossbar output XBAR_OUT[n] presents the value of XBAR_IN[SELn]. Each select register contains two SELn fields. In the first select register, the LSBs contain the select field for mux 0, and the MSBs contain the select field for mux 1. The pattern repeats in subsequent select registers.

The actual signals connected to XBAR_IN and XBAR_OUT are application specific and are described in the Chip Configuration details.

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>403C_0000</td>
<td>Crossbar B Select Register 0 (XBARB2_SEL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.1/3279</td>
</tr>
<tr>
<td>403C_0002</td>
<td>Crossbar B Select Register 1 (XBARB2_SEL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.2/3279</td>
</tr>
<tr>
<td>403C_0004</td>
<td>Crossbar B Select Register 2 (XBARB2_SEL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.3/3280</td>
</tr>
<tr>
<td>403C_0006</td>
<td>Crossbar B Select Register 3 (XBARB2_SEL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.4/3280</td>
</tr>
<tr>
<td>403C_0008</td>
<td>Crossbar B Select Register 4 (XBARB2_SEL4)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.5/3281</td>
</tr>
<tr>
<td>403C_000A</td>
<td>Crossbar B Select Register 5 (XBARB2_SEL5)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.6/3281</td>
</tr>
<tr>
<td>403C_000C</td>
<td>Crossbar B Select Register 6 (XBARB2_SEL6)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.7/3282</td>
</tr>
<tr>
<td>403C_000E</td>
<td>Crossbar B Select Register 7 (XBARB2_SEL7)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.8/3282</td>
</tr>
<tr>
<td>403C_4000</td>
<td>Crossbar B Select Register 0 (XBARB3_SEL0)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.1/3282</td>
</tr>
<tr>
<td>403C_4002</td>
<td>Crossbar B Select Register 1 (XBARB3_SEL1)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.2/3282</td>
</tr>
<tr>
<td>403C_4004</td>
<td>Crossbar B Select Register 2 (XBARB3_SEL2)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.3/3282</td>
</tr>
<tr>
<td>403C_4006</td>
<td>Crossbar B Select Register 3 (XBARB3_SEL3)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.4/3282</td>
</tr>
<tr>
<td>403C_4008</td>
<td>Crossbar B Select Register 4 (XBARB3_SEL4)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.5/3282</td>
</tr>
<tr>
<td>403C_400A</td>
<td>Crossbar B Select Register 5 (XBARB3_SEL5)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.6/3282</td>
</tr>
<tr>
<td>403C_400C</td>
<td>Crossbar B Select Register 6 (XBARB3_SEL6)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.7/3282</td>
</tr>
<tr>
<td>403C_400E</td>
<td>Crossbar B Select Register 7 (XBARB3_SEL7)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>62.3.8/3282</td>
</tr>
</tbody>
</table>
62.3.1 Crossbar B Select Register 0 (XBARBx_SEL0)

Address: Base address + 0h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td>SEL1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARBx_SEL0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–8 SEL1</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT1 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL0</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT0 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

62.3.2 Crossbar B Select Register 1 (XBARBx_SEL1)

Address: Base address + 2h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td>SEL3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARBx_SEL1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–8 SEL3</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT3 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL2</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT2 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
62.3.3 Crossbar B Select Register 2 (XBARBx_SEL2)

Address: Base address + 4h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td>SEL5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARBx_SEL2 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–8 SEL5</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT5 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL4</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT4 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

62.3.4 Crossbar B Select Register 3 (XBARBx_SEL3)

Address: Base address + 6h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td>SEL7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARBx_SEL3 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–8 SEL7</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT7 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL6</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT6 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
### 62.3.5 Crossbar B Select Register 4 (XBARBx_SEL4)

Address: Base address + 8h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARBx_SEL4 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–8 SEL9</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT9 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL8</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT8 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

### 62.3.6 Crossbar B Select Register 5 (XBARBx_SEL5)

Address: Base address + Ah offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SEL11</td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**XBARBx_SEL5 field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>13–8 SEL11</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT11 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6 Reserved</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>SEL10</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT10 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
Memory Map and Register Descriptions

62.3.7 Crossbar B Select Register 6 (XBARBx_SEL6)

Address: Base address + Ch offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARBx_SEL6 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL13</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT13 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL12</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT12 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>

62.3.8 Crossbar B Select Register 7 (XBARBx_SEL7)

Address: Base address + Eh offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

XBARBx_SEL7 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL15</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT15 (refer to Functional Description section for input/output assignment)</td>
</tr>
<tr>
<td>7–6</td>
<td>Reserved</td>
</tr>
<tr>
<td>SEL14</td>
<td>Input (XBARB_INn) to be muxed to XBARB_OUT14 (refer to Functional Description section for input/output assignment)</td>
</tr>
</tbody>
</table>
Chapter 63
And-Or-Inverter (AOI)

63.1 Chip-specific AOI information

Table 63-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>XBAR resource assignments</td>
<td>XBAR</td>
<td>XBAR Resource Assignments</td>
</tr>
</tbody>
</table>

63.2 Introduction

The AND/OR/INVERT module (known simply as the AOI module) supports the generation of a configurable number of EVENT signals. Each output EVENT\(n\) is a configurable and/or/invert function of four associated AOI inputs: An, Bn, Cn, and Dn.

This module is designed to be integrated in conjunction with one or more inter-peripheral crossbar switch (XBAR) modules. A crossbar switch is typically used to select the 4*n AOI inputs from among available peripheral outputs and GPIO signals. The n EVENTn outputs from the AOI module are typically used as additional inputs to a second crossbar switch, adding to it the ability to connect to its outputs an arbitrary 4-input boolean function of its other inputs.
The AOI controller is a slave peripheral module connecting event input indicators from a variety of device modules and generating event output signals that can be routed to an inter-peripheral crossbar switch or other peripherals. Its programming model is accessed through the standard IPS (Sky Blue) slave interface. The module is designed to be very configurable in terms of the functionality of its integrated AOI functions.

### 63.2.1 Overview

The AOI module supports a configurable number of event outputs, where each event output represents a user-programmed combinational boolean function based on four event inputs. The key features of this module include:

- Four dedicated inputs for each event output
- User-programmable combinational boolean function evaluation for each event output
- Memory-mapped device connected to a slave peripheral (IPS) bus
- Configurable number of event outputs

**NOTE**

The connections from the AOI module outputs to other functions is SoC-specific.
Figure 63-1. Simplified AOI Block Diagram
63.2.2 Features

The major features of the AOI module are summarized below:

- Highly programmable module for creating combinational boolean events for use as hardware triggers
  - Each channel has four event inputs and one output
  - Evaluates a combinational boolean expression as the sum of four products where each product term includes all four selected input sources available as true or complement values
  - Event output is formed as purely combinational logic and operates as a hardware trigger
- Memory-mapped device connected to the slave peripheral (IPS) bus
  - Programming model organized per channel for simplified software

63.2.3 Modes of Operation

The AOI module does not support any special modes of operation. As shown in Figure 63-1, its operation is primarily controlled by the selected event inputs and outputs. Additionally, as a memory-mapped device located on the slave peripheral bus, it responds based strictly on memory address for accesses to its programming model.

The AOI module resides in the slave peripheral bus clock domain.

63.3 External Signal Description

The AOI module does not directly support any external interfaces. There may be package input signals (indirectly) connected to the module as event inputs, but since the AOI does not include any input synchronization hardware, this function must be handled before the event input signals are routed into the module.

63.4 Memory Map and Register Descriptions

The AOI module supports access to its programming model via a 16-bit peripheral bus connection. The module is designed to support 16-bit accesses only. Functionality for accesses of other widths is undefined.
The AOI module supports a specific number of event outputs. Each output EVENTn outputs a four-term AOI function of four binary inputs: An, Bn, Cn, and Dn. A pair of 16-bit registers configures this four-term AOI function: The two registers BFCRT01n and BFCRT23n define the configuration for the evaluation of the Boolean function defining EVENTn, where \( n \) is the event output channel number. The BFCRT01n register defines the configuration of product terms 0 and 1, and the BFCRT23n register defines the configuration of product terms 2 and 3.

The AOI module provides a universal Boolean function generator using a four-term sum of products expression with each product term containing true or complement values of the four selected event inputs (An, Bn, Cn, Dn). Specifically, the EVENTn output is defined by the following "4 x 4" Boolean expression:

\[
\text{EVENT}_n = (0, \text{An}, \neg \text{An}, 1) \& (0, \text{Bn}, \neg \text{Bn}, 1) \& (0, \text{Cn}, \neg \text{Cn}, 1) \& (0, \text{Dn}, \neg \text{Dn}, 1) \quad \text{product term 0} \\
(0, \text{An}, \neg \text{An}, 1) \& (0, \text{Bn}, \neg \text{Bn}, 1) \& (0, \text{Cn}, \neg \text{Cn}, 1) \& (0, \text{Dn}, \neg \text{Dn}, 1) \quad \text{product term 1} \\
(0, \text{An}, \neg \text{An}, 1) \& (0, \text{Bn}, \neg \text{Bn}, 1) \& (0, \text{Cn}, \neg \text{Cn}, 1) \& (0, \text{Dn}, \neg \text{Dn}, 1) \quad \text{product term 2} \\
(0, \text{An}, \neg \text{An}, 1) \& (0, \text{Bn}, \neg \text{Bn}, 1) \& (0, \text{Cn}, \neg \text{Cn}, 1) \& (0, \text{Dn}, \neg \text{Dn}, 1) \quad \text{product term 3}
\]

where each selected input of each product term can be configured to produce a logical 0 or 1 or pass the true or complement of the selected event input. Each product term uses 8 bits of configuration information, 2 bits for each of the four selected event inputs. The resulting logic provides a simple yet powerful Boolean function evaluation for defining an event output.

These AOI functions are combinational in nature and are intended to be sampled and used synchronously.

### AOI memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>403B_4000</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI1_BFCRT010)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_4002</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI1_BFCRT230)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
<tr>
<td>403B_4004</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI1_BFCRT011)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_4006</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI1_BFCRT231)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
<tr>
<td>403B_4008</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI1_BFCRT012)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_400A</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI1_BFCRT232)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
<tr>
<td>403B_400C</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI1_BFCRT013)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_400E</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI1_BFCRT233)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
<tr>
<td>Absolute address (hex)</td>
<td>Register name</td>
<td>Width (in bits)</td>
<td>Access</td>
<td>Reset value</td>
<td>Section/page</td>
</tr>
<tr>
<td>-----------------------</td>
<td>---------------</td>
<td>----------------</td>
<td>--------</td>
<td>-------------</td>
<td>--------------</td>
</tr>
<tr>
<td>403B_8000</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI2_BFCRT010)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_8002</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI2_BFCRT230)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
<tr>
<td>403B_8004</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI2_BFCRT011)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_8006</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI2_BFCRT231)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
<tr>
<td>403B_8008</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI2_BFCRT012)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_800A</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI2_BFCRT232)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
<tr>
<td>403B_800C</td>
<td>Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI2_BFCRT013)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.1/3288</td>
</tr>
<tr>
<td>403B_800E</td>
<td>Boolean Function Term 2 and 3 Configuration Register for EVENTn (AOI2_BFCRT233)</td>
<td>16</td>
<td>R/W</td>
<td>0000h</td>
<td>63.4.2/3290</td>
</tr>
</tbody>
</table>

### 63.4.1 Boolean Function Term 0 and 1 Configuration Register for EVENTn (AOI\_x\_BFCRT01\_n)

**Address:** Base address + 0h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read/Write</td>
<td>PT0_AC</td>
<td>PT0_BC</td>
<td>PT0_CC</td>
<td>PT0_DC</td>
<td>PT1_AC</td>
<td>PT1_BC</td>
<td>PT1_CC</td>
<td>PT1_DC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**AOI\_x\_BFCRT01\_n field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 15–14 PT0\_AC | Product term 0, A input configuration  
This 2-bit field defines the Boolean evaluation associated with the selected input A in product term 0.  

| 00 | Force the A input in this product term to a logical zero  
01 | Pass the A input in this product term  
10 | Complement the A input in this product term  
11 | Force the A input in this product term to a logical one  |
| 13–12 PT0\_BC | Product term 0, B input configuration  
This 2-bit field defines the Boolean evaluation associated with the selected input B in product term 0.  

| 00 | Force the B input in this product term to a logical zero  
01 | Pass the B input in this product term  
10 | Complement the B input in this product term  
11 | Force the B input in this product term to a logical one  |
### AOlx_BFCRT01n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11–10</td>
<td>PT0_CC</td>
</tr>
<tr>
<td></td>
<td>Product term 0, C input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input C in product term 0.</td>
</tr>
<tr>
<td>00</td>
<td>Force the C input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the C input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the C input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the C input in this product term to a logical one</td>
</tr>
<tr>
<td>9–8</td>
<td>PT0_DC</td>
</tr>
<tr>
<td></td>
<td>Product term 0, D input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input D in product term 0.</td>
</tr>
<tr>
<td>00</td>
<td>Force the D input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the D input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the D input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the D input in this product term to a logical one</td>
</tr>
<tr>
<td>7–6</td>
<td>PT1_AC</td>
</tr>
<tr>
<td></td>
<td>Product term 1, A input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input A in product term 1.</td>
</tr>
<tr>
<td>00</td>
<td>Force the A input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the A input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the A input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the A input in this product term to a logical one</td>
</tr>
<tr>
<td>5–4</td>
<td>PT1_BC</td>
</tr>
<tr>
<td></td>
<td>Product term 1, B input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input B in product term 1.</td>
</tr>
<tr>
<td>00</td>
<td>Force the B input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the B input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the B input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the B input in this product term to a logical one</td>
</tr>
<tr>
<td>3–2</td>
<td>PT1_CC</td>
</tr>
<tr>
<td></td>
<td>Product term 1, C input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input C in product term 1.</td>
</tr>
<tr>
<td>00</td>
<td>Force the C input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the C input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the C input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the C input in this product term to a logical one</td>
</tr>
<tr>
<td></td>
<td>PT1_DC</td>
</tr>
<tr>
<td></td>
<td>Product term 1, D input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input D in product term 1.</td>
</tr>
<tr>
<td>00</td>
<td>Force the D input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the D input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the D input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the D input in this product term to a logical one</td>
</tr>
</tbody>
</table>
### 63.4.2 Boolean Function Term 2 and 3 Configuration Register for EVENT<sub>n</sub> (AOI<sub>x</sub>_BFCRT23<sub>n</sub>)

Address: Base address + 2h offset + (4d × i), where i=0d to 3d

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read/Write</td>
<td>PT2_AC</td>
<td>PT2_BC</td>
<td>PT2_CC</td>
<td>PT2_DC</td>
<td>PT3_AC</td>
<td>PT3_BC</td>
<td>PT3_CC</td>
<td>PT3_DC</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**AOI<sub>x</sub>_BFCRT23<sub>n</sub> field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15–14</td>
<td>Product term 2, A input configuration</td>
</tr>
<tr>
<td>PT2_AC</td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input A in product term 2.</td>
</tr>
<tr>
<td>00</td>
<td>Force the A input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the A input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the A input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the A input in this product term to a logical one</td>
</tr>
<tr>
<td>13–12</td>
<td>Product term 2, B input configuration</td>
</tr>
<tr>
<td>PT2_BC</td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input B in product term 2.</td>
</tr>
<tr>
<td>00</td>
<td>Force the B input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the B input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the B input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the B input in this product term to a logical one</td>
</tr>
<tr>
<td>11–10</td>
<td>Product term 2, C input configuration</td>
</tr>
<tr>
<td>PT2_CC</td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input C in product term 2.</td>
</tr>
<tr>
<td>00</td>
<td>Force the C input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the C input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the C input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the C input in this product term to a logical one</td>
</tr>
<tr>
<td>9–8</td>
<td>Product term 2, D input configuration</td>
</tr>
<tr>
<td>PT2_DC</td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input D in product term 2.</td>
</tr>
<tr>
<td>00</td>
<td>Force the D input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the D input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the D input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the D input in this product term to a logical one</td>
</tr>
<tr>
<td>7–6</td>
<td>Product term 3, A input configuration</td>
</tr>
<tr>
<td>PT3_AC</td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input A in product term 3.</td>
</tr>
<tr>
<td>00</td>
<td>Force the A input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the A input in this product term</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### AOIx_BFCRT23n field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>Complement the A input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the A input in this product term to a logical one</td>
</tr>
<tr>
<td>5–4 PT3_BC</td>
<td>Product term 3, B input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input B in product term 3.</td>
</tr>
<tr>
<td>00</td>
<td>Force the B input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the B input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the B input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the B input in this product term to a logical one</td>
</tr>
<tr>
<td>3–2 PT3_CC</td>
<td>Product term 3, C input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input C in product term 3.</td>
</tr>
<tr>
<td>00</td>
<td>Force the C input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the C input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the C input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the C input in this product term to a logical one</td>
</tr>
<tr>
<td>PT3_DC</td>
<td>Product term 3, D input configuration</td>
</tr>
<tr>
<td></td>
<td>This 2-bit field defines the Boolean evaluation associated with the selected input D in product term 3.</td>
</tr>
<tr>
<td>00</td>
<td>Force the D input in this product term to a logical zero</td>
</tr>
<tr>
<td>01</td>
<td>Pass the D input in this product term</td>
</tr>
<tr>
<td>10</td>
<td>Complement the D input in this product term</td>
</tr>
<tr>
<td>11</td>
<td>Force the D input in this product term to a logical one</td>
</tr>
</tbody>
</table>

### 63.5 Functional Description

The AOI is a highly programmable module for creating combinational boolean outputs for use as hardware triggers. Each AOI output channel, as shown in Figure 63-1, has one logic function:

- Evaluation of a combinational boolean expression as a sum of four products where each product term includes all four selected input sources available as true or complement values

A typical application of the AOI module is to be integrated with one or more inter-peripheral crossbar switch modules as illustrated in the following figure. The 20 external inputs are shared by two crossbar switch modules. The crossbar switch on the top is used to select the inputs to four 4-input AOI functions in the AOI module. The outputs of these four AOI functions are output from the AOI module and are added to the original 20 external inputs to provide a total of 24 inputs to the bottom crossbar switch. As a result,
the bottom crossbar can not only direct any of the original 20 external inputs to any of its outputs, it can also now direct any one of four 4-input AOI functions of those external inputs to any of its outputs.

Figure 63-2. Integration Example of AOI with two Inter-Peripheral Crossbar Switches

63.5.1 Configuration Examples for the Boolean Function Evaluation

This section presents examples of the programming model configuration for simple boolean expressions.
The AOI module provides a universal boolean function generator using a four-term sum of products expression with each product term containing true or complement values of the four selected event inputs (A, B, C, D). Specifically, the event output is defined by the following “4 x 4” boolean expression:

\[
\text{EVENT} = (0,\text{An},-\text{An},1) \land (0,\text{Bn},-\text{Bn},1) \land (0,\text{Cn},-\text{Cn},1) \land (0,\text{Dn},-\text{Dn},1) // \text{product term 0}
\]
\[
| (0,\text{An},-\text{An},1) \land (0,\text{Bn},-\text{Bn},1) \land (0,\text{Cn},-\text{Cn},1) \land (0,\text{Dn},-\text{Dn},1) // \text{product term 1}
\]
\[
| (0,\text{An},-\text{An},1) \land (0,\text{Bn},-\text{Bn},1) \land (0,\text{Cn},-\text{Cn},1) \land (0,\text{Dn},-\text{Dn},1) // \text{product term 2}
\]
\[
| (0,\text{An},-\text{An},1) \land (0,\text{Bn},-\text{Bn},1) \land (0,\text{Cn},-\text{Cn},1) \land (0,\text{Dn},-\text{Dn},1) // \text{product term 3}
\]

where each selected input term in each product term can be configured to produce a logical 0 or 1 or pass the true or complement of the selected event input. Each product term uses eight bits of configuration information, two bits for each of the four selected event inputs. The actual boolean expression implemented in each channel is:

\[
\text{EVENT} = (\text{PT0 AC}[0] \land A | \text{PT0 AC}[1] \land -A) // \text{product term 0}
\]
\[
& (\text{PT0 BC}[0] \land B | \text{PT0 BC}[1] \land -B)
\]
\[
& (\text{PT0 CC}[0] \land C | \text{PT0 CC}[1] \land -C)
\]
\[
& (\text{PT0 DC}[0] \land D | \text{PT0 DC}[1] \land -D)
\]
\[
| (\text{PT1 AC}[0] \land A | \text{PT1 AC}[1] \land -A) // \text{product term 1}
\]
\[
& (\text{PT1 BC}[0] \land B | \text{PT1 BC}[1] \land -B)
\]
\[
& (\text{PT1 CC}[0] \land C | \text{PT1 CC}[1] \land -C)
\]
\[
& (\text{PT1 DC}[0] \land D | \text{PT1 DC}[1] \land -D)
\]
\[
| (\text{PT2 AC}[0] \land A | \text{PT2 AC}[1] \land -A) // \text{product term 2}
\]
\[
& (\text{PT2 BC}[0] \land B | \text{PT2 BC}[1] \land -B)
\]
\[
& (\text{PT2 CC}[0] \land C | \text{PT2 CC}[1] \land -C)
\]
\[
& (\text{PT2 DC}[0] \land D | \text{PT2 DC}[1] \land -D)
\]
\[
| (\text{PT3 AC}[0] \land A | \text{PT3 AC}[1] \land -A) // \text{product term 3}
\]
\[
& (\text{PT3 BC}[0] \land B | \text{PT3 BC}[1] \land -B)
\]
\[
& (\text{PT3 CC}[0] \land C | \text{PT3 CC}[1] \land -C)
\]
\[
& (\text{PT3 DC}[0] \land D | \text{PT3 DC}[1] \land -D)
\]

where the bits of the combined {BFECRT01n,BFCRT23n} registers correspond to the \( \text{PT}_{0-3}\) \(_{A,B,C,D}C[1:0]\) terms in the equation.

Consider the settings of the combined 32-bit {BFECRT01n,BFCRT23n} registers for several simple boolean expressions as shown in Table 63-2.

<table>
<thead>
<tr>
<th>Event Output Expression</th>
<th>PT0</th>
<th>PT1</th>
<th>PT2</th>
<th>PT3</th>
<th>(BFECRT01, BFCRT23)</th>
</tr>
</thead>
<tbody>
<tr>
<td>A &amp; B</td>
<td>A &amp; B</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>01011111_00000000_00000000_00000000</td>
</tr>
<tr>
<td>A &amp; B &amp; C</td>
<td>A &amp; B &amp; C</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>01010111_00000000_00000000_00000000</td>
</tr>
<tr>
<td>(A &amp; B &amp; C) + D</td>
<td>A &amp; B &amp; C</td>
<td>D</td>
<td>0</td>
<td>0</td>
<td>01010111_11111110_00000000_00000000</td>
</tr>
<tr>
<td>A + B + C + D</td>
<td>A</td>
<td>B</td>
<td>C</td>
<td>D</td>
<td>01111111_11111111_11111111_11111111</td>
</tr>
<tr>
<td>(A &amp; ~B) + (~A &amp; B)</td>
<td>A &amp; ~B</td>
<td>~A &amp; B</td>
<td>0</td>
<td>0</td>
<td>01101111_10011111_00000000_00000000</td>
</tr>
</tbody>
</table>

Table 63-2. IEVENT_BFECRn Values for Simple Boolean Expressions
As can be seen in these examples, the resulting logic provides a simple yet powerful boolean function evaluation for defining an event output.

63.5.2 AOI Timing Between Inputs and Outputs

Each EVENTn output of the AOI module is a combination function of its four dedicated inputs An, Bn, Cn, and Dn. Propagation through the AOI and any associated inter-peripheral crossbar switch modules is intended to be single bus clock cycle.
Chapter 64
Analog Overview

64.1 Overview

The following analog modules are integrated in this chip:

- Analog-Digital-Converter (ADC) - Supports up to 1MS/s sampling rate and up to 16 single-ended external analog inputs
- Touch Screen Controller (TSC) - Responsible for providing control of the ADC and the touch screen analog block to form a touch screen system
- ADC External Trigger Control (ADC_ETC) - Enables multiple users to share a ADC module in a Time-Division-Multiplexing (TDM) method
- Analog Comparator (ACMP) - Operational over the entire supply range and features a integrated 6-bit DAC and a integrated 8 to 1 channel mux

Below is the simplified block diagram:

![Block Diagram](image-url)

Figure 64-1. Block Diagram (Simplified)
64.1.1 Analog-to-Digital Converter (ADC)

The ADC module features a linear successive approximation algorithm with up to 12-bit resolution with 10/11 bit accuracy. It has three possible states:

- Disabled State - The ADC module is disabled
- Idle state - The ADC module is idle, waiting on a conversion to be initiated
- Conversion State - In this mode, the ADC module can perform analog-to-digital conversion on any of the software selectable channels, using the successive approximation algorithm

64.1.2 Touch Screen Control (TSC)

The TSC helps achieve the function of touch detection and touch location detection. The controller utilizes the ADC hardware trigger function and control switches in the touch screen analog block to form a touch screen system. The controller only supports 4-wire or 5-wire screen touch modes.

64.1.3 ADC External Trigger Control (ADC_ETC)

The ADC_ETC module enables multiple users to share a ADC module. It manages the external trigger mode (HWT) of the ADCs and supports up to x8 HWT for each ADC. It is capable of triggering dual ADCs in SyncMode (controlled by the same trigger source) or AsyncMode (controlled by separate trigger source). Every ADC HWT is configured with a Back-to-Back (B2B) and Interrupt Enable (IE) settings and each external trigger can be configured with a fixed priority.

64.1.4 Analog Comparator (ACMP)

The comparator (CMP) allows for comparing two analog input voltages while the Analog MUX allows for selecting an analog input signal from eight channels. The mux circuit is operational across the full range of the supply voltage. The integrated 6-bit DAC provides a selectable voltage reference for applications where voltage reference is needed.

The ACMPs share the same 3.3V reference voltage with the ADCs.
Chapter 65
Analog Comparator (ACMP)

65.1 Chip-specific CMP information

Table 65-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

NOTE

$V_{in1}$ and $V_{in2}$ are all connected to $V_{DDA}$, on this device.

65.2 Introduction

The comparator (CMP) module provides a circuit for comparing two analog input voltages. The comparator circuit is designed to operate across the full range of the supply voltage, known as rail-to-rail operation.

The Analog MUX (ANMUX) provides a circuit for selecting an analog input signal from eight channels. One signal is provided by the 6-bit digital-to-analog converter (DAC). The mux circuit is designed to operate across the full range of the supply voltage.

The 6-bit DAC is 64-tap resistor ladder network which provides a selectable voltage reference for applications where voltage reference is needed. The 64-tap resistor ladder network divides the supply reference $V_{in}$ into 64 voltage levels. A 6-bit digital signal
input selects the output voltage level, which varies from $V_{\text{in}}$ to $V_{\text{in}}/64$. $V_{\text{in}}$ can be selected from two voltage sources, $V_{\text{in}1}$ and $V_{\text{in}2}$. The 6-bit DAC from a comparator is available as an on-chip internal signal only and is not available externally to a pin.

### 65.2.1 CMP features

The CMP has the following features:

- Operational over the entire supply range
- Inputs may range from rail to rail
- Programmable hysteresis control
- Selectable interrupt on rising-edge, falling-edge, or both rising or falling edges of the comparator output
- Selectable inversion on comparator output
- Capability to produce a wide range of outputs such as:
  - Sampled
  - Windowed, which is ideal for certain PWM zero-crossing-detection applications
  - Digitally filtered:
    - Filter can be bypassed
    - Can be clocked via external SAMPLE signal or scaled bus clock
- External hysteresis can be used at the same time that the output filter is used for internal functions
- Two software selectable performance levels:
  - Shorter propagation delay at the expense of higher power
  - Low power, with longer propagation delay
- DMA transfer support
  - A comparison event can be selected to trigger a DMA transfer
  - Functional in all modes of operation
- The window and filter functions are not available in the following modes:
  - Stop
  - VLPS
65.2.2 6-bit DAC key features

The 6-bit DAC has the following features:
- 6-bit resolution
- Selectable supply reference source
- Power Down mode to conserve power when not in use
- Option to route the output to internal comparator input

65.2.3 ANMUX key features

The ANMUX has the following features:
- Two 8-to-1 channel mux
- Operational over the entire supply range

65.2.4 CMP, DAC and ANMUX diagram

The following figure shows the block diagram for the High-Speed Comparator, DAC, and ANMUX modules.
65.2.5  CMP block diagram

The following figure shows the block diagram for the CMP module.

Figure 65-1. CMP, DAC and ANMUX block diagram
In the CMP block diagram:

- The Window Control block is bypassed when CR1[WE] = 0
- If CR1[WE] = 1, the comparator output will be sampled on every bus clock when WINDOW=1 to generate COUTA. Sampling does NOT occur when WINDOW = 0.
- The Filter block is bypassed when not in use.
- The Filter block acts as a simple sampler if the filter is bypassed and CR0[FILTER_CNT] is set to 0x01.
- The Filter block filters based on multiple samples when the filter is bypassed and CR0[FILTER_CNT] is set greater than 0x01.
  - If CR1[SE] = 1, the external SAMPLE input is used as sampling clock
  - If CR1[SE] = 0, the divided bus clock is used as sampling clock
• If enabled, the Filter block will incur up to one bus clock additional latency penalty on COUT due to the fact that COUT, which is crossing clock domain boundaries, must be resynchronized to the bus clock.

• CR1[WE] and CR1[SE] are mutually exclusive.

### 65.3 Memory map/register definitions

#### CMP memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>4009_4000</td>
<td>CMP Control Register 0 (CMP1_CR0)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.1/3303</td>
</tr>
<tr>
<td>4009_4001</td>
<td>CMP Control Register 1 (CMP1_CR1)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.2/3304</td>
</tr>
<tr>
<td>4009_4002</td>
<td>CMP Filter Period Register (CMP1_FPR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.3/3305</td>
</tr>
<tr>
<td>4009_4003</td>
<td>CMP Status and Control Register (CMP1_SCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.4/3305</td>
</tr>
<tr>
<td>4009_4004</td>
<td>DAC Control Register (CMP1_DACCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.5/3307</td>
</tr>
<tr>
<td>4009_4005</td>
<td>MUX Control Register (CMP1_MUXCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.6/3307</td>
</tr>
<tr>
<td>4009_4008</td>
<td>CMP Control Register 0 (CMP2_CR0)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.1/3303</td>
</tr>
<tr>
<td>4009_4009</td>
<td>CMP Control Register 1 (CMP2_CR1)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.2/3304</td>
</tr>
<tr>
<td>4009_400A</td>
<td>CMP Filter Period Register (CMP2_FPR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.3/3305</td>
</tr>
<tr>
<td>4009_400B</td>
<td>CMP Status and Control Register (CMP2_SCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.4/3305</td>
</tr>
<tr>
<td>4009_400C</td>
<td>DAC Control Register (CMP2_DACCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.5/3307</td>
</tr>
<tr>
<td>4009_400D</td>
<td>MUX Control Register (CMP2_MUXCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.6/3307</td>
</tr>
<tr>
<td>4009_4010</td>
<td>CMP Control Register 0 (CMP3_CR0)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.1/3303</td>
</tr>
<tr>
<td>4009_4011</td>
<td>CMP Control Register 1 (CMP3_CR1)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.2/3304</td>
</tr>
<tr>
<td>4009_4012</td>
<td>CMP Filter Period Register (CMP3_FPR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.3/3305</td>
</tr>
<tr>
<td>4009_4013</td>
<td>CMP Status and Control Register (CMP3_SCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.4/3305</td>
</tr>
<tr>
<td>4009_4014</td>
<td>DAC Control Register (CMP3_DACCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.5/3307</td>
</tr>
<tr>
<td>4009_4015</td>
<td>MUX Control Register (CMP3_MUXCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.6/3307</td>
</tr>
<tr>
<td>4009_4018</td>
<td>CMP Control Register 0 (CMP4_CR0)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.1/3303</td>
</tr>
<tr>
<td>4009_4019</td>
<td>CMP Control Register 1 (CMP4_CR1)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.2/3304</td>
</tr>
<tr>
<td>4009_401A</td>
<td>CMP Filter Period Register (CMP4_FPR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.3/3305</td>
</tr>
<tr>
<td>4009_401B</td>
<td>CMP Status and Control Register (CMP4_SCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.4/3305</td>
</tr>
<tr>
<td>4009_401C</td>
<td>DAC Control Register (CMP4_DACCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.5/3307</td>
</tr>
<tr>
<td>4009_401D</td>
<td>MUX Control Register (CMP4_MUXCR)</td>
<td>8</td>
<td>R/W</td>
<td>00h</td>
<td>65.3.6/3307</td>
</tr>
</tbody>
</table>
### 65.3.1 CMP Control Register 0 (CMPx.CR0)

Address: Base address + 0h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>FILTER_CNT</td>
</tr>
<tr>
<td>6-4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>HYSTCTR</td>
</tr>
</tbody>
</table>

#### FILTER_CNT

Filter Sample Count

- Represents the number of consecutive samples that must agree prior to the comparator output filter accepting a new output state. For information regarding filter programming and latency, see the Functional description.

- **000** Filter is disabled. If SE = 1, then COUT is a logic 0. This is not a legal state, and is not recommended. If SE = 0, COUT = COUTA.
- **001** One sample must agree. The comparator output is simply sampled.
- **010** 2 consecutive samples must agree.
- **011** 3 consecutive samples must agree.
- **100** 4 consecutive samples must agree.
- **101** 5 consecutive samples must agree.
- **110** 6 consecutive samples must agree.
- **111** 7 consecutive samples must agree.

#### HYSTCTR

Comparator hard block hysteresis control

- Defines the programmable hysteresis level. The hysteresis values associated with each level are device-specific. See the Data Sheet of the device for the exact values.

- **00** Level 0
- **01** Level 1
- **10** Level 2
- **11** Level 3
## 65.3.2 CMP Control Register 1 (CMPx_CR1)

Address: Base address + 1h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>SE</td>
<td>WE</td>
<td>0</td>
<td>Sample Enable</td>
</tr>
<tr>
<td>6</td>
<td>WE</td>
<td>0</td>
<td>0</td>
<td>Windowing Enable</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
<td>0</td>
<td>0</td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4</td>
<td>PMODE</td>
<td>0</td>
<td>0</td>
<td>Power Mode Select</td>
</tr>
<tr>
<td>3</td>
<td>INV</td>
<td>0</td>
<td>0</td>
<td>Comparator INVERT</td>
</tr>
<tr>
<td>2</td>
<td>COS</td>
<td>0</td>
<td>1</td>
<td>Comparator Output Select</td>
</tr>
<tr>
<td>1</td>
<td>OPE</td>
<td>0</td>
<td>1</td>
<td>Comparator Output Pin Enable</td>
</tr>
</tbody>
</table>

### CMPx_CR1 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 SE</td>
<td>Sample Enable</td>
</tr>
<tr>
<td></td>
<td>At any given time, either SE or WE can be set. If a write to this register attempts to set both, then SE is set and WE is cleared. However, avoid writing 1s to both field locations because this &quot;11&quot; case is reserved and may change in future implementations.</td>
</tr>
<tr>
<td></td>
<td>0 Sampling mode is not selected.</td>
</tr>
<tr>
<td></td>
<td>1 Sampling mode is selected.</td>
</tr>
<tr>
<td>6 WE</td>
<td>Windowing Enable</td>
</tr>
<tr>
<td></td>
<td>At any given time, either SE or WE can be set. If a write to this register attempts to set both, then SE is set and WE is cleared. However, avoid writing 1s to both field locations because this &quot;11&quot; case is reserved and may change in future implementations.</td>
</tr>
<tr>
<td></td>
<td>0 Windowing mode is not selected.</td>
</tr>
<tr>
<td></td>
<td>1 Windowing mode is selected.</td>
</tr>
<tr>
<td>4 PMODE</td>
<td>Power Mode Select</td>
</tr>
<tr>
<td></td>
<td>See the electrical specifications table in the device Data Sheet for details.</td>
</tr>
<tr>
<td></td>
<td>0 Low-Speed (LS) Comparison mode selected. In this mode, CMP has slower output propagation delay and lower current consumption.</td>
</tr>
<tr>
<td></td>
<td>1 High-Speed (HS) Comparison mode selected. In this mode, CMP has faster output propagation delay and higher current consumption.</td>
</tr>
<tr>
<td>3 INV</td>
<td>Comparator INVERT</td>
</tr>
<tr>
<td></td>
<td>Allows selection of the polarity of the analog comparator function. It is also driven to the COUT output, on both the device pin and as SCR[COUT], when OPE=0.</td>
</tr>
<tr>
<td></td>
<td>0 Does not invert the comparator output.</td>
</tr>
<tr>
<td></td>
<td>1 Inverts the comparator output.</td>
</tr>
<tr>
<td>2 COS</td>
<td>Comparator Output Select</td>
</tr>
<tr>
<td></td>
<td>0 Set the filtered comparator output (CMPO) to equal COUT.</td>
</tr>
<tr>
<td></td>
<td>1 Set the unfiltered comparator output (CMPO) to equal COUTA.</td>
</tr>
</tbody>
</table>

*Table continues on the next page.*
### CMPx_CR1 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>CMPO is not available on the associated CMPO output pin. If the comparator does not own the pin, this field has no effect.</td>
</tr>
<tr>
<td>1</td>
<td>CMPO is available on the associated CMPO output pin. The comparator output (CMPO) is driven out on the associated CMPO output pin if the comparator owns the pin. If the comparator does not own the field, this bit has no effect.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>EN</th>
<th>Comparator Module Enable</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Analog Comparator is disabled.</td>
</tr>
<tr>
<td>1</td>
<td>Analog Comparator is enabled.</td>
</tr>
</tbody>
</table>

### 65.3.3 CMP Filter Period Register (CMPx_FPR)

Address: Base address + 2h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

#### CMPx_FPR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>FILT_PER</td>
<td>Filter Sample Period</td>
</tr>
</tbody>
</table>

Specifies the sampling period, in bus clock cycles, of the comparator output filter, when CR1[SE]=0. Setting FILT_PER to 0x0 disables the filter. Filter programming and latency details appear in the Functional description.

This field has no effect when CR1[SE]=1. In that case, the external SAMPLE signal is used to determine the sampling period.

### 65.3.4 CMP Status and Control Register (CMPx_SCR)

Address: Base address + 3h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>0</td>
<td>DMAEN</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>IER</td>
<td>IEF</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>CFR</td>
<td>CFF</td>
<td>COUT</td>
</tr>
<tr>
<td>2</td>
<td>w1c</td>
<td>w1c</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### CMPx_SCR field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>6</td>
<td>DMAEN</td>
</tr>
<tr>
<td></td>
<td>DMA Enable Control</td>
</tr>
<tr>
<td></td>
<td>Enables the DMA transfer triggered from the CMP module. When this field is set, a DMA request is asserted when CFR or CFF is set.</td>
</tr>
<tr>
<td></td>
<td>0 DMA is disabled.</td>
</tr>
<tr>
<td></td>
<td>1 DMA is enabled.</td>
</tr>
<tr>
<td>5</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This field is reserved. This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4</td>
<td>IER</td>
</tr>
<tr>
<td></td>
<td>Comparator Interrupt Enable Rising</td>
</tr>
<tr>
<td></td>
<td>Enables the CFR interrupt from the CMP. When this field is set, an interrupt will be asserted when CFR is set.</td>
</tr>
<tr>
<td></td>
<td>0 Interrupt is disabled.</td>
</tr>
<tr>
<td></td>
<td>1 Interrupt is enabled.</td>
</tr>
<tr>
<td>3</td>
<td>IEF</td>
</tr>
<tr>
<td></td>
<td>Comparator Interrupt Enable Falling</td>
</tr>
<tr>
<td></td>
<td>Enables the CFF interrupt from the CMP. When this field is set, an interrupt will be asserted when CFF is set.</td>
</tr>
<tr>
<td></td>
<td>0 Interrupt is disabled.</td>
</tr>
<tr>
<td></td>
<td>1 Interrupt is enabled.</td>
</tr>
<tr>
<td>2</td>
<td>CFR</td>
</tr>
<tr>
<td></td>
<td>Analog Comparator Flag Rising</td>
</tr>
<tr>
<td></td>
<td>Detects a rising-edge on COUT, when set, during normal operation. CFR is cleared by writing 1 to it. During Stop modes, CFR is level sensitive.</td>
</tr>
<tr>
<td></td>
<td>0 Rising-edge on COUT has not been detected.</td>
</tr>
<tr>
<td></td>
<td>1 Rising-edge on COUT has occurred.</td>
</tr>
<tr>
<td>1</td>
<td>CFF</td>
</tr>
<tr>
<td></td>
<td>Analog Comparator Flag Falling</td>
</tr>
<tr>
<td></td>
<td>Detects a falling-edge on COUT, when set, during normal operation. CFF is cleared by writing 1 to it. During Stop modes, CFF is level sensitive.</td>
</tr>
<tr>
<td></td>
<td>0 Falling-edge on COUT has not been detected.</td>
</tr>
<tr>
<td></td>
<td>1 Falling-edge on COUT has occurred.</td>
</tr>
<tr>
<td>0</td>
<td>COUT</td>
</tr>
<tr>
<td></td>
<td>Analog Comparator Output</td>
</tr>
<tr>
<td></td>
<td>Returns the current value of the Analog Comparator output, when read. The field is reset to 0 and will read as CR1[INV] when the Analog Comparator module is disabled, that is, when CR1[EN] = 0. Writes to this field are ignored.</td>
</tr>
</tbody>
</table>
### 65.3.5 DAC Control Register (CMPx_DACCR)

Address: Base address + 4h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**CMPx_DACCR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 DACEN</td>
<td>DAC Enable</td>
</tr>
<tr>
<td></td>
<td>Enables the DAC. When the DAC is disabled, it is powered down to conserve power.</td>
</tr>
<tr>
<td></td>
<td>0 DAC is disabled.</td>
</tr>
<tr>
<td></td>
<td>1 DAC is enabled.</td>
</tr>
<tr>
<td>6 VRSEL</td>
<td>Supply Voltage Reference Source Select</td>
</tr>
<tr>
<td></td>
<td>0 $V_{in1}$ is selected as resistor ladder network supply reference.</td>
</tr>
<tr>
<td></td>
<td>1 $V_{in2}$ is selected as resistor ladder network supply reference.</td>
</tr>
<tr>
<td>VOSEL</td>
<td>DAC Output Voltage Select</td>
</tr>
<tr>
<td></td>
<td>Selects an output voltage from one of 64 distinct levels.</td>
</tr>
<tr>
<td></td>
<td>$DACO = \left(\frac{V_{in}}{64}\right) \times (VOSEL[5:0]+1)$, so the DACO range is from $V_{in}/64$ to $V_{in}$.</td>
</tr>
</tbody>
</table>

### 65.3.6 MUX Control Register (CMPx_MUXCR)

Address: Base address + 5h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>Read</th>
<th>Write</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**CMPx_MUXCR field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 Reserved</td>
<td>Bit can be programmed to zero only.</td>
</tr>
<tr>
<td></td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>6 Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>5–3 PSEL</td>
<td>Plus Input Mux Control</td>
</tr>
<tr>
<td></td>
<td>Determines which input is selected for the plus input of the comparator. For INx inputs, see CMP, DAC, and ANMUX block diagrams.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
### CMPx_MUXCR field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>NOTE:</td>
<td>When an inappropriate operation selects the same input for both muxes, the comparator automatically shuts down to prevent itself from becoming a noise generator.</td>
</tr>
<tr>
<td>000</td>
<td>IN0</td>
</tr>
<tr>
<td>001</td>
<td>IN1</td>
</tr>
<tr>
<td>010</td>
<td>IN2</td>
</tr>
<tr>
<td>011</td>
<td>IN3</td>
</tr>
<tr>
<td>100</td>
<td>IN4</td>
</tr>
<tr>
<td>101</td>
<td>IN5</td>
</tr>
<tr>
<td>110</td>
<td>IN6</td>
</tr>
<tr>
<td>111</td>
<td>IN7</td>
</tr>
</tbody>
</table>

#### MSEL

Minus Input Mux Control

Determines which input is selected for the minus input of the comparator. For INx inputs, see CMP, DAC, and ANMUX block diagrams.

**NOTE:** When an inappropriate operation selects the same input for both muxes, the comparator automatically shuts down to prevent itself from becoming a noise generator.

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>IN0</td>
</tr>
<tr>
<td>001</td>
<td>IN1</td>
</tr>
<tr>
<td>010</td>
<td>IN2</td>
</tr>
<tr>
<td>011</td>
<td>IN3</td>
</tr>
<tr>
<td>100</td>
<td>IN4</td>
</tr>
<tr>
<td>101</td>
<td>IN5</td>
</tr>
<tr>
<td>110</td>
<td>IN6</td>
</tr>
<tr>
<td>111</td>
<td>IN7</td>
</tr>
</tbody>
</table>

---

### 65.4 Functional description

The CMP module can be used to compare two analog input voltages applied to INP and INM.

CMPO is high when the non-inverting input is greater than the inverting input, and is low when the non-inverting input is less than the inverting input. This signal can be selectively inverted by setting CR1[INV] = 1.

SCR[IER] and SCR[IEF] are used to select the condition which will cause the CMP module to assert an interrupt to the processor. SCR[CFF] is set on a falling-edge and SCR[CFR] is set on rising-edge of the comparator output. The optionally filtered CMPO can be read directly through SCR[COUT].
65.4.1 CMP functional modes

There are the following main sub-blocks to the CMP module:

- The comparator itself
- The window function
- The filter function

The filter, CR0[FILTER_CNT], can be clocked from an internal or external clock source. The filter is programmable with respect to the number of samples that must agree before a change in the output is registered. In the simplest case, only one sample must agree. In this case, the filter acts as a simple sampler.

The external sample input is enabled using CR1[SE]. When set, the output of the comparator is sampled only on rising edges of the sample input.

The "windowing mode" is enabled by setting CR1[WE]. When set, the comparator output is sampled only when WINDOW=1. This feature can be used to ignore the comparator output during time periods in which the input voltages are not valid. This is especially useful when implementing zero-crossing-detection for certain PWM applications.

The comparator filter and sampling features can be combined as shown in the following table. Individual modes are discussed below.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>Disabled</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>See the Disabled mode (# 1).</td>
</tr>
<tr>
<td>2A</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0x00</td>
<td>X</td>
<td>Continuous Mode</td>
</tr>
<tr>
<td>2B</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>X</td>
<td>0x00</td>
<td>See the Continuous mode (#s 2A &amp; 2B).</td>
</tr>
<tr>
<td>3A</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0x01</td>
<td>X</td>
<td>Sampled, Non-Filtered mode</td>
</tr>
<tr>
<td>3B</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0x01</td>
<td>&gt; 0x00</td>
<td>See the Sampled, Non-Filtered mode (#s 3A &amp; 3B).</td>
</tr>
<tr>
<td>4A</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>&gt; 0x01</td>
<td>X</td>
<td>Sampled, Filtered mode</td>
</tr>
<tr>
<td>4B</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>&gt; 0x01</td>
<td>&gt; 0x00</td>
<td>See the Sampled, Filtered mode (#s 4A &amp; 4B).</td>
</tr>
<tr>
<td>5A</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0x00</td>
<td>X</td>
<td>Windowed mode</td>
</tr>
<tr>
<td>5B</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0x00</td>
<td>Comparator output is sampled on every rising bus clock edge when SAMPLE=1 to generate COUTA. See the Windowed mode (#s 5A &amp; 5B).</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0x01</td>
<td>0x01–0xFF</td>
<td>Windowed/Resampled mode</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 65-2. Comparator sample/filter controls (continued)

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>&gt; 0x01</td>
<td>0x01–0xFF</td>
<td>Windowed/Filtered mode</td>
</tr>
</tbody>
</table>

Comparator output is sampled on every rising bus clock edge when SAMPLE=1 to generate COUTA, which is then resampled and filtered to generate COUT.

See the Windowed/Filtered mode (#7).

All other combinations of CR1[EN], CR1[WE], CR1[SE], CR0[FILTER_CNT], and FPR[FILT_PER] are illegal.

For cases where a comparator is used to drive a fault input, for example, inverter-control module such as PWM, it must be configured to operate in Continuous mode so that an external fault can immediately pass through the comparator to the target fault circuitry.

**Note**

Filtering and sampling settings must be changed only after setting CR1[SE]=0 and CR0[FILTER_CNT]=0x00. This resets the filter to a known state.

65.4.1.1 Disabled mode (# 1)

In Disabled mode, the analog comparator is non-functional and consumes no power. CMPO is 0 in this mode.

65.4.1.2 Continuous mode (#s 2A & 2B)
Figure 65-3. Comparator operation in Continuous mode

The analog comparator block is powered and active. CMPO may be optionally inverted, but is not subject to external sampling or filtering. Both window control and filter blocks are completely bypassed. SCR[COUT] is updated continuously. The path from comparator input pins to output pin is operating in combinational unclocked mode. COUT and COUTA are identical.

For control configurations which result in disabling the filter block, see the Filter Block Bypass Logic diagram.

65.4.1.3 Sampled, Non-Filtered mode (#s 3A & 3B)
In Sampled, Non-Filtered mode, the analog comparator block is powered and active. The path from analog inputs to COUTA is combinational unclocked. Windowing control is completely bypassed. COUTA is sampled whenever a rising-edge is detected on the filter block clock input.

The only difference in operation between Sampled, Non-Filtered (# 3A) and Sampled, Non-Filtered (# 3B) is in how the clock to the filter block is derived. In #3A, the clock to filter block is externally derived while in #3B, the clock to filter block is internally derived.

The comparator filter has no other function than sample/hold of the comparator output in this mode (# 3B).
Figure 65-5. Sampled, Non-Filtered (# 3B): sampling interval internally derived

### 65.4.1.4 Sampled, Filtered mode (#s 4A & 4B)

In Sampled, Filtered mode, the analog comparator block is powered and active. The path from analog inputs to COUTA is combinational unclocked. Windowing control is completely bypassed. COUTA is sampled whenever a rising edge is detected on the filter block clock input.

The only difference in operation between Sampled, Non-Filtered (# 3A) and Sampled, Filtered (# 4A) is that, now, CR0[FILTER_CNT]>1, which activates filter operation.
Figure 65-6. Sampled, Filtered (# 4A): sampling point externally driven
The only difference in operation between Sampled, Non-Filtered (# 3B) and Sampled, Filtered (# 4B) is that now, CR0[FILTER_CNT]>1, which activates filter operation.

**65.4.1.5 Windowed mode (#s 5A & 5B)**

The following figure illustrates comparator operation in the Windowed mode, ignoring latency of the analog comparator, polarity select, and window control block. It also assumes that the polarity select is set to non-inverting state.

**NOTE**

The analog comparator output is passed to COUTA only when the WINDOW signal is high.

In actual operation, COUTA may lag the analog inputs by up to one bus clock cycle plus the combinational path delay through the comparator and polarity select logic.
For control configurations which result in disabling the filter block, see Filter Block Bypass Logic diagram.
When any windowed mode is active, COUTA is clocked by the bus clock whenever \( \text{WINDOW} = 1 \). The last latched value is held when \( \text{WINDOW} = 0 \).

### 65.4.1.6 Windowed/Resampled mode (# 6)

The following figure uses the same input stimulus shown in Figure 65-8, and adds resampling of COUTA to generate COUT. Samples are taken at the time points indicated by the arrows in the figure. Again, prop delays and latency are ignored for the sake of clarity.

This example was generated solely to demonstrate operation of the comparator in windowed/resampled mode, and does not reflect any specific application. Depending upon the sampling rate and window placement, COUT may not see zero-crossing events detected by the analog comparator. Sampling period and/or window placement must be carefully considered for a given application.

![Figure 65-10. Windowed/resampled mode operation](image-url)

This mode of operation results in an unfiltered string of comparator samples where the interval between the samples is determined by \( \text{FPR[FILT_PER]} \) and the bus clock rate. Configuration for this mode is virtually identical to that for the Windowed/Filtered Mode shown in the next section. The only difference is that the value of \( \text{CR0[FILTER_CNT]} \) must be 1.
65.4.1.7 Windowed/Filtered mode (#7)

This is the most complex mode of operation for the comparator block, as it uses both windowing and filtering features. It also has the highest latency of any of the modes. This can be approximated: up to 1 bus clock synchronization in the window function + ((CR0[FILTER_CNT] * FPR[FILT_PER]) + 1) * bus clock for the filter function.

When any windowed mode is active, COUTA is clocked by the bus clock whenever WINDOW = 1. The last latched value is held when WINDOW = 0.

![Figure 65-11. Windowed/Filtered mode](image)

65.4.2 Power modes

65.4.2.1 Wait mode operation

During Wait and VLPW modes, the CMP, if enabled, continues to operate normally and a CMP interrupt can wake the MCU.
65.4.2.2  Stop mode operation

Depending on clock restrictions related to the MCU core or core peripherals, the MCU is brought out of stop when a compare event occurs and the corresponding interrupt is enabled. Similarly, if CR1[OPE] is enabled, the comparator output operates as in the normal operating mode and comparator output is placed onto the external pin. In Stop modes, the comparator can be operational in both:

- High-Speed (HS) Comparison mode when CR1[PMODE] = 1
- Low-Speed (LS) Comparison mode when CR1[PMODE] = 0

It is recommended to use the LS mode to minimize power consumption.

If stop is exited with a reset, all comparator registers are put into their reset state.

65.4.3  Startup and operation

A typical startup sequence is listed here.

- The time required to stabilize COUT will be the power-on delay of the comparators plus the largest propagation delay from a selected analog source through the analog comparator, windowing function and filter. See the Data Sheets for power-on delays of the comparators. The windowing function has a maximum of one bus clock period delay. The filter delay is specified in the Low-pass filter.
- During operation, the propagation delay of the selected data paths must always be considered. It may take many bus clock cycles for COUT and SCR[CFR]/SCR[CFF] to reflect an input change or a configuration change to one of the components involved in the data path.
- When programmed for filtering modes, COUT will initially be equal to 0, until sufficient clock cycles have elapsed to fill all stages of the filter. This occurs even if COUTA is at a logic 1.

65.4.4  Low-pass filter

The low-pass filter operates on the unfiltered and unsynchronized and optionally inverted comparator output COUTA and generates the filtered and synchronized output COUT.

Both COUTA and COUT can be configured as module outputs and are used for different purposes within the system.
Synchronization and edge detection are always used to determine status register bit values. They also apply to COUT for all sampling and windowed modes. Filtering can be performed using an internal timebase defined by FPR[FILT_PER], or using an external SAMPLE input to determine sample time.

The need for digital filtering and the amount of filtering is dependent on user requirements. Filtering can become more useful in the absence of an external hysteresis circuit. Without external hysteresis, high-frequency oscillations can be generated at COUTA when the selected INM and INP input voltages differ by less than the offset voltage of the differential comparator.

### 65.4.4.1 Enabling filter modes

Filter modes can be enabled by:

- Setting CR0[FILTER_CNT] > 0x01 and
- Setting FPR[FILT_PER] to a nonzero value or setting CR1[SE]=1

If using the divided bus clock to drive the filter, it will take samples of COUTA every FPR[FILT_PER] bus clock cycles.

The filter output will be at logic 0 when first initialized, and will subsequently change when all the consecutive CR0[FILTER_CNT] samples agree that the output value has changed. In other words, SCR[COUT] will be 0 for some initial period, even when COUTA is at logic 1.

Setting both CR1[SE] and FPR[FILT_PER] to 0 disables the filter and eliminates switching current associated with the filtering process.

**Note**

Always switch to this setting prior to making any changes in filter parameters. This resets the filter to a known state. Switching CR0[FILTER_CNT] on the fly without this intermediate step can result in unexpected behavior.

If CR1[SE]=1, the filter takes samples of COUTA on each positive transition of the sample input. The output state of the filter changes when all the consecutive CR0[FILTER_CNT] samples agree that the output value has changed.
65.4.4.2 Latency issues

The value of FPR[FILT_PER] or SAMPLE period must be set such that the sampling period is just longer than the period of the expected noise. This way a noise spike will corrupt only one sample. The value of CR0[FILTER_CNT] must be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the power of CR0[FILTER_CNT].

The values of FPR[FILT_PER] or SAMPLE period and CR0[FILTER_CNT] must also be traded off against the desire for minimal latency in recognizing actual comparator output transitions. The probability of detecting an actual output change within the nominal latency is the probability of a correct sample raised to the power of CR0[FILTER_CNT].

The following table summarizes maximum latency values for the various modes of operation in the absence of noise. Filtering latency is restarted each time an actual output transition is masked by noise.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>Disabled</td>
<td>N/A</td>
</tr>
<tr>
<td>2A</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0x00</td>
<td>X</td>
<td>Continuous Mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt;</td>
</tr>
<tr>
<td>2B</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>X</td>
<td>0x00</td>
<td>Sampled, Non-Filtered mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + T&lt;sub&gt;SAMPLE&lt;/sub&gt; + T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>3A</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0x01</td>
<td>X</td>
<td>Sampled, Filtered mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + (CR0[FILTER_CNT] * T&lt;sub&gt;SAMPLE&lt;/sub&gt; + T&lt;sub&gt;per&lt;/sub&gt;) + T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>3B</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0x01</td>
<td>&gt; 0x00</td>
<td>Sampled, Filtered mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + (CR0[FILTER_CNT] * FPR[FILT_PER] * T&lt;sub&gt;per&lt;/sub&gt;) + 2T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>4A</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>&gt; 0x01</td>
<td>X</td>
<td>Windowed mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>4B</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>&gt; 0x01</td>
<td>&gt; 0x00</td>
<td>Windowed / Resampled mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + 2T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>5A</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0x00</td>
<td>X</td>
<td>Windowed / Filtered mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + (CR0[FILTER_CNT] * FPR[FILT_PER] * T&lt;sub&gt;per&lt;/sub&gt;) + 2T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>5B</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0x00</td>
<td>Windowed / Filtered mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>6</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0x01</td>
<td>0x01 - 0xFF</td>
<td>Windowed / Filtered mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + (FPR[FILT_PER] * T&lt;sub&gt;per&lt;/sub&gt;) + T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
<tr>
<td>7</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>&gt; 0x01</td>
<td>0x01 - 0xFF</td>
<td>Windowed / Filtered mode</td>
<td>T&lt;sub&gt;PD&lt;/sub&gt; + (CR0[FILTER_CNT] * FPR[FILT_PER] * T&lt;sub&gt;per&lt;/sub&gt;) + 2T&lt;sub&gt;per&lt;/sub&gt;</td>
</tr>
</tbody>
</table>

1. T<sub>PD</sub> represents the intrinsic delay of the analog component plus the polarity select logic. T<sub>SAMPLE</sub> is the clock period of the external sample clock. T<sub>per</sub> is the period of the bus clock.
65.5 CMP interrupts

The CMP module is capable of generating an interrupt on either the rising- or falling-edge of the comparator output, or both.

The following table gives the conditions in which the interrupt request is asserted and deasserted.

<table>
<thead>
<tr>
<th>When</th>
<th>Then</th>
</tr>
</thead>
<tbody>
<tr>
<td>SCR[IER] and SCR[CFR] are set</td>
<td>The interrupt request is asserted</td>
</tr>
<tr>
<td>SCR[IEF] and SCR[CFF] are set</td>
<td>The interrupt request is asserted</td>
</tr>
<tr>
<td>SCR[IER] and SCR[CFR] are cleared for a rising-edge interrupt</td>
<td>The interrupt request is deasserted</td>
</tr>
<tr>
<td>SCR[IEF] and SCR[CFF] are cleared for a falling-edge interrupt</td>
<td>The interrupt request is deasserted</td>
</tr>
</tbody>
</table>

65.6 DMA support

Normally, the CMP generates a CPU interrupt if there is a change on the COUT. When DMA support is enabled by setting SCR[DMAEN] and the interrupt is enabled by setting SCR[IER], SCR[IEF], or both, the corresponding change on COUT forces a DMA transfer request rather than a CPU interrupt instead. When the DMA has completed the transfer, it sends a transfer completing indicator that deasserts the DMA transfer request and clears the flag to allow a subsequent change on comparator output to occur and force another DMA request.

The comparator can remain functional in STOP modes.

When DMA support is enabled by setting SCR[DMAEN] and the interrupt is enabled by setting SCR[IER], SCR[IEF], or both, the corresponding change on COUT forces a DMA transfer request to wake up the system from STOP modes. After the data transfer has finished, system will go back to STOP modes. Refer to DMA chapters in the device reference manual for the asynchronous DMA function for details.
65.7 Digital-to-analog converter

The figure found here shows the block diagram of the DAC module.

It contains a 64-tap resistor ladder network and a 64-to-1 multiplexer, which selects an output voltage from one of 64 distinct levels that outputs from DACO. It is controlled through the DAC Control Register (DACCR). Its supply reference source can be selected from two sources $V_{in1}$ and $V_{in2}$. The module can be powered down or disabled when not in use. When in Disabled mode, DACO is connected to the analog ground.

![Figure 65-12. 6-bit DAC block diagram](image)

65.8 DAC functional description

This section provides DAC functional description information.

65.8.1 Voltage reference source select

- $V_{in1}$ connects to the primary voltage source as supply reference of 64 tap resistor ladder
- $V_{in2}$ connects to an alternate voltage source
65.9 DAC resets
This module has a single reset input, corresponding to the chip-wide peripheral reset.

65.10 DAC clocks
This module has a single clock input, the bus clock.

65.11 DAC interrupts
This module has no interrupts.
Chapter 66
Analog-to-Digital Converter (ADC)

66.1 Chip-specific ADC information

Table 66-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

NOTE

V_{REFH} / V_{REFL} are bonded to VDDA_ADC_3P3 / GND, on this device.

66.2 Overview

The analog-to-digital converter (ADC) is a successive approximation ADC designed for operation within an integrated microcontroller system-on-chip.

66.2.1 Features

The features of the ADC are as follows:

- Configuration registers
• 32-bit, word aligned, byte enabled registers. (byte and halfword access is not supported)
• Linear successive approximation algorithm with up to 12-bit resolution with 10/11 bit accuracy.
• Up to 10 ENOB (dedicated single ended channels)
• Up to 1MS/s sampling rate
• Up to 16 single-ended external analog inputs
• Single or continuous conversion (automatic return to idle after single conversion)
• Output Modes: (in right-justified unsigned format)
  • 12-bit
  • 10-bit
  • 8-bit
• Configurable sample time and conversion speed/power
• Conversion complete and hardware average complete flag and interrupt
• Input clock selectable from up to three sources
• Asynchronous clock source for lower noise operation with option to output the clock
• Selectable asynchronous hardware conversion trigger with hardware channel select
• Automatic compare with interrupt for less-than, greater-than or equal-to, within range, or out-of-range, programmable value
• Operation in low power modes for lower noise operation
• Hardware average function
• Self-calibration mode

66.2.2 ADC I/F block diagram

The following diagram represents the ADC I/F block.
66.2.3 ADC block diagram

The following figure shows a top-level block diagram of the ADC module.
66.2.4 ADC module interface

The ADC is connected to many interfaces such as the clocks and reset, access bus, voltage references, interrupt controller, hardware triggers, ADC pin control, and analog I/F as shown in the following figure.
66.2.5 Modes of Operation

By default, the ADC is in disabled mode. In this state, no conversion or other actions occur. All of the ADC control registers are accessible in this state through an access bus interface. To enable the ADC, required configurations should be done by programming the ADC configuration registers.

66.3 External Signals

The following table describes the external signals of ADC:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC1_IN0</td>
<td>Analog channel 1 input 0</td>
<td>GPIO_AD_B1_11</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN1</td>
<td>Analog channel 1 input 1</td>
<td>GPIO_AD_B0_12</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN2</td>
<td>Analog channel 1 input 2</td>
<td>GPIO_AD_B0_13</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN3</td>
<td>Analog channel 1 input 3</td>
<td>GPIO_AD_B0_14</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN4</td>
<td>Analog channel 1 input 4</td>
<td>GPIO_AD_B0_15</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN5</td>
<td>Analog channel 1 input 5</td>
<td>GPIO_AD_B1_00</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN6</td>
<td>Analog channel 1 input 6</td>
<td>GPIO_AD_B1_01</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN7</td>
<td>Analog channel 1 input 7</td>
<td>GPIO_AD_B1_02</td>
<td>-</td>
<td>I</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC1_IN8</td>
<td>Analog channel 1 input 8</td>
<td>GPIO_AD_B1_03</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN9</td>
<td>Analog channel 1 input 9</td>
<td>GPIO_AD_B1_04</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN10</td>
<td>Analog channel 1 input 10</td>
<td>GPIO_AD_B1_05</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN11</td>
<td>Analog channel 1 input 11</td>
<td>GPIO_AD_B1_06</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN12</td>
<td>Analog channel 1 input 12</td>
<td>GPIO_AD_B1_07</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN13</td>
<td>Analog channel 1 input 13</td>
<td>GPIO_AD_B1_08</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN14</td>
<td>Analog channel 1 input 14</td>
<td>GPIO_AD_B1_09</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC1_IN15</td>
<td>Analog channel 1 input 15</td>
<td>GPIO_AD_B1_10</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN0</td>
<td>Analog channel 2 input 0</td>
<td>GPIO_AD_B1_11</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN1</td>
<td>Analog channel 2 input 1</td>
<td>GPIO_AD_B1_12</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN2</td>
<td>Analog channel 2 input 2</td>
<td>GPIO_AD_B1_13</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN3</td>
<td>Analog channel 2 input 3</td>
<td>GPIO_AD_B1_14</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN4</td>
<td>Analog channel 2 input 4</td>
<td>GPIO_AD_B1_15</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN5</td>
<td>Analog channel 2 input 5</td>
<td>GPIO_AD_B1_00</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN6</td>
<td>Analog channel 2 input 6</td>
<td>GPIO_AD_B1_01</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN7</td>
<td>Analog channel 2 input 7</td>
<td>GPIO_AD_B1_02</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN8</td>
<td>Analog channel 2 input 8</td>
<td>GPIO_AD_B1_03</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN9</td>
<td>Analog channel 2 input 9</td>
<td>GPIO_AD_B1_04</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN10</td>
<td>Analog channel 2 input 10</td>
<td>GPIO_AD_B1_05</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN11</td>
<td>Analog channel 2 input 11</td>
<td>GPIO_AD_B1_06</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN12</td>
<td>Analog channel 2 input 12</td>
<td>GPIO_AD_B1_07</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN13</td>
<td>Analog channel 2 input 13</td>
<td>GPIO_AD_B1_08</td>
<td>-</td>
<td>I</td>
</tr>
<tr>
<td>ADC2_IN14</td>
<td>Analog channel 2 input 14</td>
<td>GPIO_AD_B1_09</td>
<td>-</td>
<td>I</td>
</tr>
</tbody>
</table>
### Table 66-2. ADC external signals (continued)

<table>
<thead>
<tr>
<th>Signal</th>
<th>Description</th>
<th>Pad</th>
<th>Mode</th>
<th>Direction</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC2_IN15</td>
<td>Analog channel 2 input 15</td>
<td>GPIO_AD_B1_10</td>
<td>-</td>
<td>I</td>
</tr>
</tbody>
</table>

**NOTE**

The ADC input signals connect to GPIO. The GPIO default configuration is enabled for keeper. The keeper causes an undesired jump behavior in ADC. To avoid the problem, disable keeper before starting ADC. For detailed information about keeper, refer to the GPIO block.

### 66.4 Clocks

The following table describes the clock sources for ADC.

Please see Clock Controller Module (CCM) for clock setting, configuration and gating information.

#### Table 66-3. ADC Clocks

<table>
<thead>
<tr>
<th>Clock name</th>
<th>Clock Root</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ipg_clk</td>
<td>ipg_clk_root</td>
<td>Peripheral clock</td>
</tr>
</tbody>
</table>

### 66.5 Functional Description

There are three possible states which ADC module can be in:

1. Disabled State
2. Idle state
3. Performing conversions

**Disabled State:**

The ADC module is disabled during reset or stop mode (if internal clock is not selected as source of clock), or when the ADCH bits of the hardware control (ADC_HCn) registers are all high.

**Idle State:**
The module is idle when a conversion has completed and another conversion has not been initiated. When idle and the asynchronous clock output enable is disabled (ADACKEN = 0), the module is in its lowest power state.

**Conversion State:**

The ADC can perform an analog-to-digital conversion on any of the software selectable channels. All modes perform conversion by a successive approximation algorithm.

To meet accuracy specifications the ADC module must be calibrated using the on chip calibration function. Calibration is recommended to be done after any reset.

When the conversion is completed, the result is placed in the data result registers (ADC_Rn). The conversion complete flag (COCOn) field in the Hardware Status register is/are then set and an interrupt is generated, if the respective conversion complete interrupt has been enabled (ADC_HCn[AIEN]=1).

The ADC module has the capability of automatically comparing the result of a conversion with the contents of the compare value registers. The compare function is enabled by setting ACFE (ADC Compare Function Enable) in the ADC general control register.

The ADC module has the capability of automatically averaging the result of multiple conversions. The hardware average function is enabled by setting AVGE in the ADC general control register.

### 66.5.1 Clock Select and Divide Control

The ADC digital module has two clock sources:

- IPG clock
- Internal clock (ADACK) is a dedicated clock used only by the ADC.

ADC digital block generates IPG clock/2 by internally dividing the IPG clock. The final clock is chosen from the following clocks.

- IPG clock
- IPG clock divided by 2
- ADACK

From the three clocks listed above, one is chosen depending on the configuration of ADICLK[1:0] bits of ADC_CFG. This chosen clock is divided depending on the configuration of ADIV[1:0] bits of ADC_CFG. The final generated clock is used as conversion clock for ADC.
<table>
<thead>
<tr>
<th>ADICLK</th>
<th>Selected Clock Source</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>IPG clock</td>
</tr>
<tr>
<td>01</td>
<td>IPG clock divided by 2</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Asynchronous clock (ADACK)</td>
</tr>
</tbody>
</table>

- The IPG clock. This is the default selection following reset.
- The IPG clock divided by two. For higher IPG clock rates, this allows a maximum divide by 16 of the IPG clock using the ADIV bits.
- The asynchronous clock (ADACK). This clock is generated from a clock source within the ADC module. Conversions are possible using ADACK as the input clock source while the MCU is in stop mode.

Whichever clock is selected, its frequency must fall within the specified frequency range for ADCK. If the available clocks are too slow, the ADC may not perform according to specifications. If the available clocks are too fast, the clock must be divided to the appropriate frequency. This divider is specified by the ADIV bits and can be divide-by 1, 2, 4, or 8.

### 66.5.2 Voltage Reference Selection

The ADC can be configured to use reference pairs as the reference voltages used for conversions ($V_{REFSH}$ and $V_{REFSL}$). Each pair contains a positive reference which must be between the minimum Ref Voltage High and $V_{DDAD}$, and a ground reference which must be at the same potential as $V_{SSAD}$. The pairs can be as follows:

- External ($V_{REFH}$ and $V_{REFL}$)

These voltage references are selected by configuring ADC_CFG[REFSEL].

### 66.5.3 Hardware Triggering and Channel Selection

The ADC module has a trigger input (known as Alternate Trigger) which provides asynchronous hardware conversion trigger when the ADTRG bit in ADC configuration register (ADC_CFG) is set and any of the external hardware trigger select is high.

To be reliably captured, the Alternate Trigger pulse must be high for sufficient time to satisfy clocking requirement of capturing Flop and the external hardware trigger select event must be set for sufficient time before and after the positive edge of Alternate trigger pulse to meet the setup / hold requirement of capturing flop.
If an external hardware trigger select event gets asserted during a conversion it must stay asserted until end of current conversion and remain set until the receipt of the Alternate Trigger to initiate a new conversion.

When the Alternate Trigger source is available and hardware triggering is enabled (ADC_CFG[ADTRG]=1), a conversion is initiated on the rising edge of the Alternate Trigger after a external hardware trigger select event has occurred.

If a conversion is in progress when a rising edge of a trigger occurs, the rising edge is ignored. In continuous conversion configuration, only the initial rising edge to launch continuous conversions is observed and until conversion gets aborted the ADC will continue to do conversions on the same ADC Hardware Trigger Control register that initiated the conversion. The hardware trigger function operates in conjunction with any of the conversion modes and configurations.

The channel selected for the conversion will depend on the settings of active Hardware Trigger register field ADC_HCn[ADCH] of enabled external hardware trigger.

**NOTE**

Asserting more than one external hardware trigger select signal at the same time will result in unknown results. To avoid this, only select one external hardware trigger select signal prior to the next intended conversion.

When the conversion is completed, the result is placed in the data registers associated with the external hardware trigger received (active trigger selects ADC_Rn). The conversion complete flag associated with the external hardware trigger received (ADC_HS[COCOn]) is then set and an interrupt is generated if the respective conversion complete interrupt has been enabled (ADC_HCn[AIEN]=1).

### 66.5.4 Conversion Control

Conversions are performed as determined by ADC_CFG[MODE] field.

Conversions can be initiated by either software or hardware triggers. In addition, the ADC can be configured for low power operation, long sample time, continuous conversion, hardware average, and automatic comparison of conversion results with predetermined values.

### 66.5.4.1 Initiating Conversions

A conversion is initiated:
Following a write to ADC_HC0 (with ADCHn bits not all 1's) and when a software triggered operation is selected (ADTRG=0).

Following a hardware trigger event if hardware triggered operation is selected (ADTRG=1) and a external hardware trigger select event has occurred. The channel selected will depend on the active trigger select signal active selects ADC_HC1; if neither is active the off condition is selected).

**Note**

Selecting more than one external hardware trigger select signal (ext_hwts[n]) prior to a conversion completion will generate unknown results. To avoid this, only select one hardware trigger select signal (ext_hwts[n]) prior to a conversion completion.

Following the transfer of the result to the data registers when continuous conversion is enabled (ADCO=1 in ADC_GC register).

If continuous conversion is enabled, a new conversion is automatically initiated after the completion of the current conversion. In software triggered operation (ADTRG=0), continuous conversions begin after ADC_HC0 is written and continue until aborted. In hardware triggered operation (ADTRG=1 and one external hardware trigger select event has occurred), continuous conversions begin after a hardware trigger event and continue until aborted.

If hardware averaging is enabled, a new conversion is automatically initiated after the completion of the current conversion until the correct number of conversions is completed. In software triggered operation, conversions begin after ADC_HC0 is written. In a hardware triggered operation, conversions begin after a hardware trigger. If continuous conversions is also enabled, a new set of conversions to be averaged are initiated following the last of the selected number of conversions.

### 66.5.4.2 Completing Conversions

A conversion is completed when the result of the conversion is transferred into the data result registers. (provided the compare function & hardware averaging is disabled), this is indicated by the setting of COCOn. If hardware averaging is enabled, COCOn sets only, if the last of the selected number of conversions is complete. If the compare function is enabled, COCOn sets and conversion result data is transferred only if the compare condition is true. If both hardware averaging and compare functions are enabled, then COCOn sets only if the last of the selected number of conversions is complete and the
compare condition is true. An interrupt is generated, if ADC_HCn[AIEN] is high at the
time that COCOn is set and if DMAEN is set, DMA request is asserted, if COCOn is set.
Both the requests get deasserted when COCOn is low, cleared, which happens when data
is read.

In all modes a blocking mechanism prevents a new result from overwriting previous data
in ADC_Rn, if the previous data is in the process of being read. When blocking is active
(OVWREN=0 in ADC_CFG), the conversion result data transfer is blocked, COCOn is
not set, and the new result is lost. In all other cases of operation, when a conversion result
data transfer is blocked, another conversion is initiated regardless of the state of ADCO
(single or continuous conversions enabled).

**Note**

If continuous conversions are enabled, the blocking mechanism
could result in the loss of data occurring at specific timepoints.
To avoid this issue, the data must be read in fewer cycles than
an ADC conversion time, accounting for interrupt or software
polling loop latency.

If single conversions are enabled, the blocking mechanism
could result in several discarded conversions and excess power
consumption. To avoid this issue, the data registers must not be
read after initiating a single conversion until the conversion
completes.

### 66.5.4.3 Aborting Conversions

Any conversion in progress is aborted when:

- The MCU enters stop mode with ADACK not enabled.
- In software trigger mode, write to ADC_HC0 register, while ADC_HC0 is actively
  (already) controlling a conversion, aborts the current conversion. Since none of the
  ADC_HC1 - ADC_HCn registers are used for software trigger operation, writing to
  any of them will not initiate a new conversion nor abort the software triggered active
  conversion.
• In hardware trigger mode, writing to any of the ADC_HC0 - ADC_HCn registers, while that specific register is actively controlling a conversion, will abort the current conversion.

• A write to any ADC register other than the ADC_HC0: ADC_HCn registers occurs. This indicates a mode of operation change has occurred and the current conversion is therefore invalid.

Note

When a conversion is aborted, the contents of the data result registers, ADCRn are not altered. The data result registers continue to hold the values, transferred after the completion of the last successful conversion. If the conversion is aborted by a reset or stop (not operated with internal ADACK), ADCRn (data result register) return to their reset states.

66.5.4.4 Power Control

The ADC module remains in its idle state until a conversion is initiated. If ADACK is selected as the conversion clock source but the asynchronous clock output is disabled (ADACKEN=0), the ADACK clock generator will also remain in its idle state (disabled) until a conversion is initiated. If the asynchronous clock output is enabled (ADACKEN=1), it will remain active regardless of the state of the ADC or the MCU power mode.

Power consumption when the ADC is active can be reduced by setting ADLPC.

66.5.4.5 Sample Time and Total Conversion Time

The total conversion time depends upon the following:

• the sample phase time (as determined by ADLSMP and ADSTS bits in ADC_CFG register),
• the compare phase time (determined by MODE bits)
• the frequency of the conversion clock ($f_{ADCK}$),
• the MCU bus frequency (for Handshaking and selection of clock)
After the module becomes active, sampling of the input begins. ADLSMP and ADSTS decide the sample time duration. When sampling is complete, the converter is isolated from the input channel and a successive approximation algorithm is performed to determine the digital value of the analog signal. The result of the conversion is transferred to ADC_Rn upon completion of the conversion algorithm.

If the bus frequency is less than the $f_{ADCK}$ frequency, precise sample time for continuous conversions cannot be guaranteed.

The maximum total conversion time is determined by the clock source chosen and the divide ratio selected. The clock source is selectable by the ADICLK bits in ADC_CFG register, and the divide ratio is specified by the ADIV bits.

The maximum total conversion time for all configurations is summarized in Equation 1 on page 3338. Refer to Table 66-4 through Table 66-7 for the variables referenced in the equation.

$$\text{ConversionTime} = \text{SFCAdder} + \text{AverageNum} \times (\text{BCT} + \text{LSTAdder})$$

**Equation 1. Equation of Conversion Time**

### Table 66-4. Single or First Continuous Time Adder (SFCAdder)

<table>
<thead>
<tr>
<th>ADACKEN</th>
<th>ADICLK</th>
<th>Single or First Continuous Time Adder (SFCAdder)</th>
</tr>
</thead>
<tbody>
<tr>
<td>x</td>
<td>0x, 10</td>
<td>3 ADCK cycles (before starting of conversion) +</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 ADCK (after end of conversion) +</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 bus clock cycles</td>
</tr>
<tr>
<td>1</td>
<td>11</td>
<td>3 ADCK cycles (before starting of conversion) +</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 ADCK (after end of conversion) +</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 bus clock cycles</td>
</tr>
<tr>
<td>0</td>
<td>11</td>
<td>1.5μs +</td>
</tr>
</tbody>
</table>
Table 66-4. Single or First Continuous Time Adder (SFCAdder)

<table>
<thead>
<tr>
<th>ADACKEN</th>
<th>ADICLK</th>
<th>Single or First Continuous Time Adder (SFCAdder)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>3 ADCK cycles (before starting of conversion) +</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1 ADCK (after end of conversion) +</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2 bus clock cycles</td>
</tr>
</tbody>
</table>

Table 66-5. Average Number Factor (AverageNum)

<table>
<thead>
<tr>
<th>AVGE</th>
<th>AVGS[1:0]</th>
<th>Average Number Factor (AverageNum)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>xx</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>00</td>
<td>4</td>
</tr>
<tr>
<td>1</td>
<td>01</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>10</td>
<td>16</td>
</tr>
<tr>
<td>1</td>
<td>11</td>
<td>32</td>
</tr>
</tbody>
</table>

Table 66-6. Base Conversion Time (BCT) (compare phase duration)

<table>
<thead>
<tr>
<th>Mode</th>
<th>Base Conversion Time (BCT) (compare phase duration)</th>
</tr>
</thead>
<tbody>
<tr>
<td>8 bit</td>
<td>17 ADCK cycles</td>
</tr>
<tr>
<td>10 bit</td>
<td>21 ADCK cycles</td>
</tr>
<tr>
<td>12 bit</td>
<td>25 ADCK cycles</td>
</tr>
</tbody>
</table>

Table 66-7. Long Sample Time

<table>
<thead>
<tr>
<th>ADLSMP</th>
<th>ADSTS</th>
<th>Long Sample Time Adder (LSTAdder)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>00</td>
<td>3 ADCK cycles</td>
</tr>
<tr>
<td>0</td>
<td>01</td>
<td>5 ADCK cycles</td>
</tr>
<tr>
<td>0</td>
<td>10</td>
<td>7 ADCK cycles (default)</td>
</tr>
<tr>
<td>0</td>
<td>11</td>
<td>9 ADCK cycles</td>
</tr>
<tr>
<td>1</td>
<td>00</td>
<td>13 ADCK cycles</td>
</tr>
<tr>
<td>1</td>
<td>01</td>
<td>17 ADCK cycles</td>
</tr>
<tr>
<td>1</td>
<td>10</td>
<td>21 ADCK cycles</td>
</tr>
<tr>
<td>1</td>
<td>11</td>
<td>25 ADCK cycles</td>
</tr>
</tbody>
</table>

Note

The ADCK frequency must be between $f_{ADCK}$ minimum and $f_{ADCK}$ maximum to meet ADC specifications.
66.5.4.6 Conversion Time Examples

The following examples uses Equation 1 on page 3338 and the information provided in tables Table 66-4 through Table 66-7.

66.5.4.6.1 Typical conversion time configuration

A typical configuration for ADC conversion is: 10-bit mode, with the bus clock selected as the input clock source, the input clock divide-by-1 ratio selected, and a bus frequency of 40 MHz, ADLSMP=0, ADLSTS=10 and high speed conversion disabled. The conversion time for a single conversion is calculated by using Equation 1 on page 3338 and the information provided in Table 66-8 through Table 66-10. The table below list the variables of Equation 1 on page 3338.

Table 66-8. Typical Conversion Time

<table>
<thead>
<tr>
<th>Variable</th>
<th>Time</th>
</tr>
</thead>
<tbody>
<tr>
<td>SFCAdder</td>
<td>4 ADCK cycles + 2 bus clock cycles</td>
</tr>
<tr>
<td>AverageNum</td>
<td>1</td>
</tr>
<tr>
<td>BCT</td>
<td>21 ADCK cycles</td>
</tr>
<tr>
<td>LSTAdder</td>
<td>7</td>
</tr>
</tbody>
</table>

The resulting conversion time is generated using the parameters listed in Table 66-8. So for Bus clock equal to 40 Mhz and ADCK equal to 40 Mhz the resulting conversion time is 0.85 us.

66.5.4.6.2 Long conversion time configuration

A configuration for long ADC conversion is: 12-bit mode, with the bus clock selected as the input clock source, the input clock divide-by-8 ratio selected, and a bus frequency of 40 MHz, long sample time enabled (ADLSMP=1, ADSTS=11) and configured for longest adder and high speed conversion disabled. Average enabled for 32 conversions (AVGE=1, AVGS=11). The conversion time for this conversion is calculated by using equation on Sample Time and Total Conversion Time and the information provided in Table 66-4 through Table 66-7. The table below lists the variables of equation.

Table 66-9. Typical Conversion Time

<table>
<thead>
<tr>
<th>Variable</th>
<th>Time</th>
</tr>
</thead>
<tbody>
<tr>
<td>SFCAdder</td>
<td>4 ADCK cycles + 2 bus clock cycles</td>
</tr>
<tr>
<td>AverageNum</td>
<td>32</td>
</tr>
<tr>
<td>BCT</td>
<td>25 ADCK cycles</td>
</tr>
<tr>
<td>LSTAdder</td>
<td>25 ADCK cycles</td>
</tr>
</tbody>
</table>
The resulting conversion time is generated using the parameters listed in Table 66-9. So for Bus clock equal to 40 Mhz and ADCK equal to 5 Mhz the resulting conversion time is 10.0226 us (AverageNum). This results in a total conversion time of 320.85 us.

66.5.4.6.3 Short conversion time configuration

A configuration for short ADC conversion is: 8-bit mode, with the bus clock selected as the input clock source, the input clock divide-by-1 ratio selected, and a bus frequency of 40 MHz, long sample time disabled (ADLSMP=0, ADSTS=00) and high speed conversion enabled. The conversion time for this conversion is calculated by using the equation and the information provided in Table 66-4 to Table 66-7. The table below list the variables of equation.

<table>
<thead>
<tr>
<th>Variable</th>
<th>Time</th>
</tr>
</thead>
<tbody>
<tr>
<td>SFCAdder</td>
<td>4 ADCK cycles + 2 bus clock cycles</td>
</tr>
<tr>
<td>AverageNum</td>
<td>1</td>
</tr>
<tr>
<td>BCT</td>
<td>17 ADCK cycles</td>
</tr>
<tr>
<td>LSTAdder</td>
<td>3 ADCK cycles</td>
</tr>
</tbody>
</table>

The resulting conversion time is generated using the parameters listed in Table 66-10. So for Bus clock equal to 40Mhz and ADCK equal to 40Mhz the resulting conversion time is 650 ns.

66.5.4.7 Hardware Average Function

The hardware average function can be enabled (AVGE=1) to perform a hardware average of multiple conversions. The number of conversions is determined by the AVGS[1:0] bits, which select 4, 8, 16 or 32 conversions to be averaged. While the hardware average function is in progress the ADACT bit will be set.

After the selected input is sampled and converted, the result is placed in an accumulator from which an average is calculated after the selected number of conversions has been completed. When hardware averaging is selected the completion of a single conversion will not set the COCOn bit.

If the compare function is either disabled or evaluates true, after the selected number of conversions are completed, the average conversion result is transferred into the data result registers, ADC_Rn, and the COCOn bit is set. An ADC interrupt is generated upon the setting of COCOn if the respective ADC interrupt is enabled (AIENn=1).
66.5.5 Automatic Compare Function

The compare function can be configured to check if the result is less than or greater-than-or-equal-to a single compare value, or if the result falls within or outside a range determined by two compare values. The compare mode is determined by ACFG, ACREN and the values in the compare value register (ADC.CV). After the input is sampled and converted, the compare values (CV1 and CV2) are used as described in the table below. There are six compare modes as shown in the table below.

<table>
<thead>
<tr>
<th>ACFG</th>
<th>ACREN</th>
<th>CV1 relative to CV2</th>
<th>Function</th>
<th>Compare Mode Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Less than threshold</td>
<td>Less than threshold</td>
<td>Compare true if the result is less than the CV1 registers.</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Greater than or equal to threshold</td>
<td>Greater than or equal to threshold</td>
<td>Compare true if the result is greater than or equal to CV1 registers.</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Less than or equal</td>
<td>Outside range, not inclusive</td>
<td>Compare true if the result is less than CV1 Or the result is Greater than CV2</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Greater than</td>
<td>Inside range, not inclusive</td>
<td>Compare true if the result is less than CV1 And the result is greater than CV2</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Less Than or equal</td>
<td>Inside range, inclusive</td>
<td>Compare true if the result is greater than or equal to CV1 And the result is less than or equal to CV2</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Greater than</td>
<td>Outside range, inclusive</td>
<td>Compare true if the result is greater than or equal to CV1 Or the result is less than or equal to CV2</td>
</tr>
</tbody>
</table>

With the ADC range enable bit set, ADCREN = 1, if compare value 1 (CV1 value) is less than or equal to the compare value 2 (CV2 value), setting ACFG will select a trigger-if-inside-compare-range, inclusive-of-endpoints function. Clearing ACFG will select a trigger-if-outside-compare-range, not-inclusive-of-endpoints function.

If CV1 is greater than the CV2, setting ACFG will select a trigger-if-outside-compare-range, inclusive-of-endpoints function. Clearing ACFG will select a trigger-if-inside-compare-range, not-inclusive-of-endpoints function.

If the condition selected evaluates true, COCON is set.

Upon completion of a conversion while the compare function is enabled, if the compare condition is not true, COCON is not set and the conversion result data will not be transferred to the result register. If the hardware averaging function is enabled, the compare function compares the averaged result to the compare values. The same compare function definitions apply. An ADC interrupt is generated upon the setting of COCON if the respective ADC interrupt is enabled (ADC_HCn[AIEN]=1).
Note

The compare function can monitor the voltage on a channel while the MCU is in wait or stop3 mode. The ADC interrupt wakes the MCU when the compare condition is met.

66.5.6 Calibration Function

The ADC contains a self-calibration function that is required to achieve the specified accuracy. Calibration should be run or valid calibration values should be written after power up and system reset (as the calibration register will be reset on reset assertion) with specified settings before any conversion is initiated. The calibration function sets the calibration value at the end of running the full calibration sequence in ADC_CAL register. The user must configure the ADC correctly prior to starting the calibration process, and must allow the process to run the full calibration sequence by checking the status of ADC_GC[CAL] and ADC_GS[CALF] so that the generated calibration value can be loaded.

Prior to calibration, the user must configure the ADC's clock source and frequency, low power configuration, voltage reference selection, sample time, averaging, and the high speed configuration according to the application's clock source availability and needs. If the application uses the ADC in a wide variety of configurations, the configuration for which the highest accuracy is required should be selected, or multiple calibrations can be done for the different configurations. The input channel, conversion mode, continuous function and compare function are all ignored during the calibration process.

To initiate calibration, the user sets the CAL bit and the calibration will automatically begin if the ADTRG bit = 0. If ADTRG = 1, the CAL bit will not get set and the calibration fail flag (CALF) will be set. While calibration is active, no ADC register can be written and no stop mode may be entered or the calibration routine will be aborted causing the CAL bit to clear and the CALF bit to set.

At the end of a calibration sequence the COCO[0] bit of the ADC_HS register will be set. The ADC_HCn[AIEN] bit can be used to allow an interrupt to occur at the end of a calibration sequence. If, at the end of calibration routine, the CALF bit is not set, the automatic calibration routine completed successfully.

To complete calibration, the user must follow the below procedure:

- Configure ADC_CFG with actual operating values for maximum accuracy.
- Configure the ADC_GC values along with CAL bit
- Check the status of CALF bit in ADC_GS and the CAL bit in ADC_GC
- When CAL bit becomes '0' then check the CALF status and COCO[0] bit status
When complete the user may reconfigure and use the ADC as desired.

A second calibration may also be performed if desired by clearing and again setting the CAL bit

Overall the calibration routine may take as many as 14000 ADCK cycles and 100 bus cycles, depending on the results and the clock source chosen.

### 66.5.7 User Defined Offset Function

The ADC Offset Correction Register (ADC_OFS) contains the user configured offset value. This register is 13 bit wide. The value in MSB (13th bit) is the operation bit, if this bit is ‘0’ then the value in rest 12 bit is added with the converted result value to generate final result to be loaded into ADC_Rn and if this bit is ‘1’ then this field is subtracted from converted value to generate final Result (ADC_Rn). If the Final result is above the maximum or below the minimum result value, it is forced to the appropriate limit for the current mode of operation. Forced to 0x0FFF if over and 0x0000 if lower for 12 bit mode.

The offset value has no effect during calibration on the final result.

The formatting of the ADC Offset Register is different from the Data Result Registers (ADC_Rn) to preserve the resolution of the value regardless of the conversion mode selected. Lower order bits are ignored in lower resolution modes. For example, in 8b single-ended mode, the bits OFS[11:4] are subtracted from D[7:0] when bit OFS[12] (sign bit) is ‘1’; indicates subtraction and bits OFS[4:0] are ignored. For 12b single-ended mode, bits OFS[11:0] are directly subtracted from the conversion result data CDATA[11:0] when OFS[12] (sign bit) is ‘1’. The similar is the addition operation when OFS[12](sign bit) is 0.

ADC_OFS is manually set according to user requirements after the self calibration sequence is done (CAL is cleared). The user have to write ADC_OFS with desired value.

**NOTE**

There is an effective limit to the values of Offset that can be set by the user. If the magnitude of the offset is too great the results of the conversions will cap off at the limits.

The offset function may be employed by the user to remove application offsets or DC bias values. An offset correction that results in an out-of-range value will be forced to the minimum or maximum value.
For applications which may change the offset repeatedly during operation, it is recommended to store the initial offset value in flash so that it can be recovered and added to any user offset adjustment value and the sum stored in the ADC_OFS registers.

66.5.8 MCU Wait Mode Operation

Wait mode is a **lower power-consumption standby mode** from which **recovery is fast** because **the clock sources remain active**. If a conversion is in progress when the MCU enters wait mode, it continues until completion. Conversions can be initiated while the MCU is in wait mode by means of the hardware trigger or if continuous conversions are enabled.

The bus clock, bus clock divided by two, and ADACK are available as conversion clock sources while in wait mode.

A conversion complete event sets the COCON and generates an ADC interrupt to wake the MCU from wait mode.

If the compare and hardware averaging functions are disabled, a conversion complete event sets the COCON and generates an ADC interrupt to wake the MCU from wait mode if the respective ADC interrupt is enabled (ADC_HCn[AIEN]=1).

If the hardware averaging function is enabled the COCON will set (and generate an interrupt if enabled) when the selected number of conversions are complete.

If the compare function is enabled the COCON will set (and generate an interrupt if enabled) only if the compare conditions are met.

If a single conversion is selected and the compare trigger is not met, the ADC will return to its idle state and cannot wake the MCU from wait mode unless a new conversion is initiated by the hardware trigger.

66.5.9 MCU Stop Mode Operation

Stop mode is a low power-consumption standby mode during which most or all clock sources on the MCU are disabled. Stop mode is entered when stop indication comes from the MCU.
66.5.9.1 Stop Mode With ADACK Disabled

If the asynchronous clock, ADACK, is not selected as the conversion clock, executing a stop instruction aborts the current conversion and places the ADC in its idle state. The contents of the ADC registers, including ADC_Rn are unaffected by stop mode. After exiting from stop mode, a software or hardware trigger is required to resume conversions.

66.5.9.2 Stop Mode With ADACK Enabled

If ADACK is selected as the conversion clock, the ADC continues operation during stop mode. For guaranteed ADC operation, the MCU's voltage regulator must remain active during stop mode.

If a conversion is in progress when the MCU enters stop mode, it continues until completion. Conversions can be initiated while the MCU is in stop mode by means of the hardware trigger or if continuous conversions are enabled.

A conversion complete event sets the COCOn and generates an ADC interrupt to wake the MCU from stop mode:

Note

The ADC module can wake the system from low-power stop and cause the MCU to begin consuming run-level currents without generating a system level interrupt. To prevent this scenario, software should ensure the conversion result data transfer blocking mechanism (discussed in Completing Conversions) is cleared when entering stop and continuing ADC conversions.

66.6 Initialization Information

This section gives an example that provides some basic direction on how to initialize and configure the ADC module. User can configure the module for 8, 10, 12 bit resolution, single or continuous conversion, and a polled or interrupt approach, among many other options.

66.6.1 ADC Module Initialization Example

This section describes the initialization sequence along with pseudo-code.
66.6.1.1 Initialization Sequence

Before the ADC module can be used to complete conversions, an initialization procedure must be performed. A typical sequence is as follows:

- Calibrate the ADC by following the calibration instructions in Calibration Function.
- Update the configuration register (ADC_CFG) to select the input clock source and the divide ratio used to generate the internal clock, ADCK. This register is also used for selecting sample time and low-power configuration.
- Update General control register (ADC_GC) to select whether conversions will be continuous or completed only once (ADCO) and to select whether to perform hardware averaging, etc.
- Update Trigger control register (ADC_HCn) to select the conversion trigger (hardware or software, i.e. configure ADTRG bit) and compare function options, if enabled.

66.6.1.2 Pseudo-Code Example

In this example, the ADC module is set up with interrupts enabled to perform a single 10-bit conversion at low power with a long sample time on input channel 1, where the internal ADCK clock is derived from the bus clock divided by 1.

**ADC_CFG**

Bit 7 ADLPC  1  Configures for low power (lowers maximum clock speed).
Bit 6:5 ADIV  00  Sets the ADCK to the input clock ÷ 1.
Bit 4 ADLSMP 1  Configures for long sample time.
Bit 3:2 MODE 10  Sets mode at 10-bit conversions.
Bit 1:0 ADICLK 00  Selects bus clock as input clock source.

**ADC_GC**

Bit 7 CAL 0  Flag indicates if a conversion is in progress.
Bit 6 ADCO 0  Software trigger selected.
Bit 5 AVGE 0  Compare function disabled.
Bit 4 ACFE 0  Compare function disabled.
Bit 3 ACFGT 0  Not used in this example.
Bit 2 ACREN 0  Not used in this example.
Bit 1 DMAEN 0  Not used in this example.
Bit 0 ADACKEN 0  Not used in this example.

**ADC_HC0**
Bit 7  AIEN  1  Conversion complete interrupt enabled.
Bit 4:0  ADCH  00001  Input channel 1 selected as ADC input channel.

**ADC_R0**

Holds results of conversion. Read high byte (ADCRHA) before low byte (ADCRLA) so that conversion data cannot be overwritten with data from the next conversion.

**ADC_CV**

Holds compare values when compare function enabled.

![Initialization Flowchart for Example](image)

**Figure 66-5. Initialization Flowchart for Example**

### 66.7 Application Information

This section contains information for using the ADC module in applications. The ADC has been designed to be integrated into a microcontroller for use in embedded control applications requiring an A/D converter.

#### 66.7.1 Sources of Error

Several sources of error exist for A/D conversions. These are discussed in the following sections.
66.7.1.1 Sampling Error

For proper conversions, the input must be sampled long enough to achieve the proper accuracy. Given the maximum input resistance of approximately 7kΩ and input capacitance of approximately 1.3 pF, sampling to within 1/4LSB (at 12-bit resolution) can be achieved within the nominal sample window (6 cycles @ 40 MHz maximum ADCK frequency) provided the resistance of the external analog source (R_AS) is kept below 4 kΩ.

Higher source resistances or higher-accuracy sampling is possible by setting ADLSMP and changing the ADSTS bits (to increase the sample window) or decreasing ADCK frequency to increase sample time.

66.7.1.2 Pin Leakage Error

Leakage on the I/O pins can cause conversion error if the external analog source resistance (R_AS) is high. If this error cannot be tolerated by the application, keep R_AS lower than V_DDAD / (2^N * I_LEAK) for less than 1/4LSB leakage error (N = 8 in 8-bit, 10 in 10-bit or 12 in 12-bit mode).

66.7.1.3 Noise-Induced Errors

System noise that occurs during the sample or conversion process can affect the accuracy of the conversion. The ADC accuracy numbers are guaranteed as specified only if the following conditions are met:

- There is a 0.1 µF low-ESR capacitor from V_REFH to V_REFL.
- There is a 0.1 µF low-ESR capacitor from V_DDAD to V_SSAD.
- If inductive isolation is used from the primary supply, an additional 1 µF capacitor is placed from V_DDAD to V_SSAD.
- V_SSAD (and V_REFL, if connected) is connected to V_SS at a quiet point in the ground plane.
- Operate the MCU in wait or stop mode before initiating (hardware triggered conversions) or immediately after initiating (hardware or software triggered conversions) the ADC conversion.
• For software triggered conversions, immediately follow the write to ADCSC1 with a wait instruction or stop instruction.

• For stop mode operation, select ADACK as the clock source. Operation in stop reduces $V_{DD}$ noise but increases effective conversion time due to stop recovery.

• There is no I/O switching, input or output, on the MCU during the conversion.

There are some situations where external system activity causes radiated or conducted noise emissions or excessive $V_{DD}$ noise is coupled into the ADC. In these situations, or when the MCU cannot be placed in wait or stop or I/O activity cannot be halted, these recommended actions may reduce the effect of noise on the accuracy:

• Place a 0.01 µF capacitor (CAS) on the selected input channel to $V_{REFL}$ or $V_{SS}$ (this improves noise issues, but affects the sample rate based on the external analog source resistance).

• Average the result by converting the analog input many times in succession and dividing the sum of the results. Four samples are required to eliminate the effect of a 1LSB, one-time error.

• Reduce the effect of synchronous noise by operating off the asynchronous clock (ADACK) and averaging. Noise that is synchronous to ADCK cannot be averaged out.

### 66.7.1.4 Code Width and Quantization Error

**Note**

This will remain the same as long as the result is rounded for 8 and 10-bit modes. If the result is truncated in 8/10b modes then they will match 12b mode where the quantization error is -1 to 0.

The ADC quantizes the ideal straight-line transfer function into 4096 steps (in 12-bit mode). Each step ideally has the same height (1 code) and width. The width is defined as the delta between the transition points to one code and the next. The ideal code width for an N bit converter (in this case N can be 8, 10 or 12), defined as 1LSB, is:

$$1\text{lsb} = \frac{(V_{REFH} - V_{REFL})}{2^N}$$

There is an inherent quantization error due to the digitization of the result. For 8-bit or 10-bit conversions the code transitions when the voltage is at the midpoint between the points where the straight line transfer function is exactly represented by the actual
transfer function. Therefore, the quantization error will be ±1/2 lsb in 8- or 10-bit mode. As a consequence, however, the code width of the first (0x000) conversion is only 1/2 lsb and the code width of the last (0xFF or 0x3FF) is 1.5 lsb.

For 12-bit conversions the code transitions only after the full code width is present, so the quantization error is -1 lsb to 0 lsb and the code width of each step is 1 lsb.

66.7.1.5 Linearity Errors

The ADC may also exhibit non-linearity of several forms. Every effort has been made to reduce these errors but the system should be aware of them because they affect overall accuracy. These errors are:

- Zero-scale error ($E_{ZS}$) (sometimes called offset) — This error is defined as the difference between the actual code width of the first conversion and the ideal code width (1/2 lsb in 8-bit or 10-bit modes and 1 lsb in 12-bit mode). If the first conversion is 0x001, the difference between the actual 0x001 code width and its ideal (1 lsb) is used.

- Full-scale error ($E_{FS}$) — This error is defined as the difference between the actual code width of the last conversion and the ideal code width (1.5 lsb in 8-bit or 10-bit modes and 1LSB in 12-bit mode). If the last conversion is 0x3FE, the difference between the actual 0x3FE code width and its ideal (1LSB) is used.

- Differential non-linearity (DNL) — This error is defined as the worst-case difference between the actual code width and the ideal code width for all conversions.

- Integral non-linearity (INL) — This error is defined as the highest-value the (absolute value of the) running sum of DNL achieves. More simply, this is the worst-case difference of the actual transition voltage to a given code and its corresponding ideal transition voltage, for all codes.

- Total unadjusted error (TUE) — This error is defined as the difference between the actual transfer function and the ideal straight-line transfer function and includes all forms of error.

66.7.1.6 Code Jitter, Non-Monotonicity, and Missing Codes

Analog-to-digital converters are susceptible to three special forms of error. These are code jitter, non-monotonicity, and missing codes.
Code jitter is when, at certain points, a given input voltage converts to one of two values
when sampled repeatedly. Ideally, when the input voltage is infinitesimally smaller than
the transition voltage, the converter yields the lower code (and vice-versa). However,
even small amounts of system noise can cause the converter to be indeterminate (between
two codes) for a range of input voltages around the transition voltage. This range is
normally around ±1/2 lsb in 8-bit or 10-bit mode, or around 2 lsb in 12-bit mode, and
increases with noise.

This error may be reduced by repeatedly sampling the input and averaging the result.
Additionally the techniques discussed in Noise-Induced Errors reduces this error.

Non-monotonicity is defined as when, except for code jitter, the converter converts to a
lower code for a higher input voltage. Missing codes are those values never converted for
any input value.

In 8-bit or 10-bit mode, the ADC is guaranteed to be monotonic and have no missing
codes.

### 66.8 Memory map and register definition

The ADC-Digital contains 32-bit, word aligned, byte enables registers; byte or half word
access are not supported. All configuration registers are accessible via 32-bit access bus
Interface. Write access to reserved locations have no impact while read access to reserved
locations always return 0.

**NOTE**

No protection or indication mechanism is available (for example, 32-bit access starting with address offset value 0x01
or 0x02 or 0x03). The ADC does not check for correctness of
the programmed values in the registers and the programmer
must ensure that correct values are being written.

#### ADC memory map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400C_4000</td>
<td>Control register for hardware triggers (ADC1_HC0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.1/3354</td>
</tr>
<tr>
<td>400C_4004</td>
<td>Control register for hardware triggers (ADC1_HC1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_4008</td>
<td>Control register for hardware triggers (ADC1_HC2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_400C</td>
<td>Control register for hardware triggers (ADC1_HC3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_4010</td>
<td>Control register for hardware triggers (ADC1_HC4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
ADC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400C_4014</td>
<td>Control register for hardware triggers (ADC1_HC5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_4018</td>
<td>Control register for hardware triggers (ADC1_HC6)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_401C</td>
<td>Control register for hardware triggers (ADC1_HC7)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_4020</td>
<td>Status register for HW triggers (ADC1_HS)</td>
<td>32</td>
<td>R (reads 0)</td>
<td>0000_0000h</td>
<td>66.8.3/3358</td>
</tr>
<tr>
<td>400C_4024</td>
<td>Data result register for HW triggers (ADC1_R0)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.4/3360</td>
</tr>
<tr>
<td>400C_4028</td>
<td>Data result register for HW triggers (ADC1_R1)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_402C</td>
<td>Data result register for HW triggers (ADC1_R2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_4030</td>
<td>Data result register for HW triggers (ADC1_R3)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_4034</td>
<td>Data result register for HW triggers (ADC1_R4)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_4038</td>
<td>Data result register for HW triggers (ADC1_R5)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_403C</td>
<td>Data result register for HW triggers (ADC1_R6)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_4040</td>
<td>Data result register for HW triggers (ADC1_R7)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_4044</td>
<td>Configuration register (ADC1_CFG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0200h</td>
<td>66.8.6/3362</td>
</tr>
<tr>
<td>400C_4048</td>
<td>General control register (ADC1_GC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.7/3365</td>
</tr>
<tr>
<td>400C_404C</td>
<td>General status register (ADC1_GS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.8/3367</td>
</tr>
<tr>
<td>400C_4050</td>
<td>Compare value register (ADC1_CV)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.9/3368</td>
</tr>
<tr>
<td>400C_4054</td>
<td>Offset correction value register (ADC1_OFS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.10/3369</td>
</tr>
<tr>
<td>400C_4058</td>
<td>Calibration value register (ADC1_CAL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.11/3369</td>
</tr>
<tr>
<td>400C_8000</td>
<td>Control register for hardware triggers (ADC2_HC0)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.1/3354</td>
</tr>
<tr>
<td>400C_8004</td>
<td>Control register for hardware triggers (ADC2_HC1)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_8008</td>
<td>Control register for hardware triggers (ADC2_HC2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_800C</td>
<td>Control register for hardware triggers (ADC2_HC3)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_8010</td>
<td>Control register for hardware triggers (ADC2_HC4)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_8014</td>
<td>Control register for hardware triggers (ADC2_HC5)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_8018</td>
<td>Control register for hardware triggers (ADC2_HC6)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_801C</td>
<td>Control register for hardware triggers (ADC2_HC7)</td>
<td>32</td>
<td>R/W</td>
<td>0000_001Fh</td>
<td>66.8.2/3356</td>
</tr>
<tr>
<td>400C_8020</td>
<td>Status register for HW triggers (ADC2_HS)</td>
<td>32</td>
<td>R (reads 0)</td>
<td>0000_0000h</td>
<td>66.8.3/3358</td>
</tr>
<tr>
<td>400C_8024</td>
<td>Data result register for HW triggers (ADC2_R0)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.4/3360</td>
</tr>
<tr>
<td>400C_8028</td>
<td>Data result register for HW triggers (ADC2_R1)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_802C</td>
<td>Data result register for HW triggers (ADC2_R2)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_8030</td>
<td>Data result register for HW triggers (ADC2_R3)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_8034</td>
<td>Data result register for HW triggers (ADC2_R4)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_8038</td>
<td>Data result register for HW triggers (ADC2_R5)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_803C</td>
<td>Data result register for HW triggers (ADC2_R6)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
<tr>
<td>400C_8040</td>
<td>Data result register for HW triggers (ADC2_R7)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>66.8.5/3361</td>
</tr>
</tbody>
</table>

Table continues on the next page...
**ADC memory map (continued)**

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400C_8044</td>
<td>Configuration register (ADC2_CFG)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0200h</td>
<td>66.8.6/3362</td>
</tr>
<tr>
<td>400C_8048</td>
<td>General control register (ADC2_GC)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.7/3365</td>
</tr>
<tr>
<td>400C_804C</td>
<td>General status register (ADC2_GS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.8/3367</td>
</tr>
<tr>
<td>400C_8050</td>
<td>Compare value register (ADC2_CV)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.9/3368</td>
</tr>
<tr>
<td>400C_8054</td>
<td>Offset correction value register (ADC2_OFS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.10/3369</td>
</tr>
<tr>
<td>400C_8058</td>
<td>Calibration value register (ADC2_CAL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>66.8.11/3369</td>
</tr>
</tbody>
</table>

### 66.8.1 Control register for hardware triggers (ADCx_HC0)

ADC_HC0 can be used for both software and hardware trigger mode. Other ADC_HCn \((n = 1...)\) are for use only in hardware trigger mode. The ADC_HC0 to ADC_HCn \((n = 1...)\) registers have identical fields, and are used to control ADC operation. At any one point in time, only one of the ADC_HC0 to ADC_HCn \((n = 1...)\) registers is actively controlling ADC conversions. Updating ADC_HC0 while ADC_HCn \((n = 1...)\) is actively controlling a conversion is allowed (and vice-versa for any of the ADC_HCn \((n = 1...)\) registers). Writing ADC_HC0 while ADC_HC0 is actively controlling a conversion aborts the current conversion. In software trigger mode (ADTRG=0), writes to ADC_HC0 subsequently initiates a new conversion (if the ADCH bits are equal to a value other than all 1s). Similarly, writing any of the ADC_HCn \((n = 1...)\) registers while that specific ADC_HCn register is actively controlling a conversion aborts the current conversion. ADC_HCn \((n = 1...)\) register is not used for software trigger operation and therefore writes to any of them do not initiate a new conversion.

**Memory map and register definition**

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

3354

NXP Semiconductors
# ADCx_HC0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 7          | **AIEN**  
Conversion Complete Interrupt Enable/Disable Control  
An interrupt is generated whenever ADC_HS[COCO0]=1 (conversion ADC_HC0 completed), provided the corresponding interrupt is enabled.  
1 Conversion complete interrupt enabled  
0 Conversion complete interrupt disabled |
| 6–5        | This read-only field is reserved and always has the value 0.                                   |
| ADCH       | **Input Channel Select**  
This 5-bit field selects one of the input channels. The successive approximation converter subsystem is turned off when the channel select bits are all set (ADCH = 11111b). This feature allows for explicit disabling of the ADC and isolation of the input channel from all sources. Terminating continuous conversions this way prevents an additional single conversion from being performed.  
00000-01111 External channels 0 to 15  
10000 External channel selection from ADC_ETC  
10001-10111 Reserved  
11000 Reserved.  
11001 VREFSH = internal channel, for ADC self-test, hard connected to VRH internally  
11010 Reserved.  
11011 Reserved.  
11100-11110 Reserved.  
11111 Conversion Disabled. Hardware Triggers will not initiate any conversion. |

---

Adapted from the i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019.
66.8.2 Control register for hardware triggers (ADCx_HCn)

ADC_HCn (n = 1...) are for use only in hardware trigger mode. The ADC_HC0 to ADC_HCn registers have identical fields, and are used to control ADC operation. At any one point in time, only one of the ADC_HC0 to ADC_HCn registers is actively controlling ADC conversions. Updating ADC_HC0 while ADC_HCn is actively controlling a conversion is allowed (and vice-versa for any of the ADC_HCn registers). Writing any of the ADC_HCn registers while that specific ADC_HCn register is actively controlling a conversion aborts the current conversion. Any of the ADC_HCn (n = 1...) registers are not used for software trigger operation and therefore writes to any of them do not initiate a new conversion.

Address: Base address + 4h offset + (4d × i), where i=0d to 6d

| Bit | R  | W  | Reset       |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
|-----|----|----|-------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 31  | 30 | 29 | 28          | 27       | 26       | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |          |          |          |          |          |
|     |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 15  | 14 | 13 | 12          | 11       | 10       | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |          |          |          |          |          |
|     |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 6–5 |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
|     |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 31–8|    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 7   |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 6–5 |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 31–8|    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 7   |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |
| 6–5 |    |    | 0           |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |          |

ADCx_HCn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>7</td>
<td>AIEN</td>
</tr>
<tr>
<td>6–5</td>
<td>Reserved</td>
</tr>
<tr>
<td>ADCH</td>
<td>Input Channel Select</td>
</tr>
</tbody>
</table>

This read-only field is reserved and always has the value 0.

Conversion Complete Interrupt Enable/Disable Control

An interrupt is generated whenever ADC_HS[COCO0]=1(conversion ADC_HC0 completed), provided the corresponding interrupt is enabled.

0 Conversion complete interrupt disabled
1 Conversion complete interrupt enabled

This 5-bit field selects one of the input channels. The successive approximation converter subsystem is turned off when the channel select bits are all set (ADCH =11111b). This feature allows for explicit disabling of the ADC and isolation of the input channel from all sources. Terminating continuous conversions this way prevents an additional single conversion from being performed.

00000-01111 External channels 0 to 15

See External Signals for more information

Table continues on the next page...
ADCx_HCn field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10000</td>
<td>External channel selection from ADC_ETC</td>
</tr>
<tr>
<td>10001-10111</td>
<td>Reserved</td>
</tr>
<tr>
<td>11000</td>
<td>Reserved</td>
</tr>
<tr>
<td>11001</td>
<td>VREFSH = internal channel, for ADC self-test, hard connected to VRH internally</td>
</tr>
<tr>
<td>11010</td>
<td>Reserved</td>
</tr>
<tr>
<td>11011</td>
<td>Reserved</td>
</tr>
<tr>
<td>11100-11110</td>
<td>Reserved</td>
</tr>
<tr>
<td>11111</td>
<td>Conversion Disabled. Hardware Triggers will not initiate any conversion.</td>
</tr>
</tbody>
</table>
66.8.3 Status register for HW triggers (ADCx_HS)

Bit 0 is used for both software and hardware trigger modes of operation. Bit 1 to bit (n-1) indicate the rest of the HW triggers' statuses similar to bit 0, potentially corresponding to multiple ADC_HC registers (for use only in hardware trigger mode).

Address: Base address + 20h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
### ADCx_HS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–2</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td>This field is reserved.</td>
</tr>
<tr>
<td>0</td>
<td>Conversion Complete Flag</td>
</tr>
<tr>
<td>COCO0</td>
<td>The COCO0 flag is a read-only bit that is set each time a conversion is completed when the compare function is disabled (ADC_GC[ACFE]=0) and the hardware average function is disabled (ADC_GC[AVGE]=0). When the compare function is enabled (ADC_GC[ACFE]=1), the COCO0 flag is set upon completion of a conversion only if the compare result is true. When the hardware average function is enabled (ADC_GC[AVGE]=1), the COCO0 flag is set upon completion of the selected number of conversions (determined by the ADC_CFG[AVGS] field). The COCO0 flag will also set at the completion of a Calibration and Test sequence. A COCO0 bit is cleared when the respective ADC_HCn is written or when the respective ADC_Rn is read.</td>
</tr>
</tbody>
</table>

**NOTE:**
- In the hardware trigger mode, when trigger comes from TSC, COCO bit can be cleared by writing TSC register. When other ADC_ETC trigger sources work as ADC hardware trigger, COCO bit is cleared automatically when each phase is done.
- In the software trigger mode, COCO0 bit is cleared when ADC_HC0 is written or when ADC_R0 is read.
66.8.4 Data result register for HW triggers (ADCx_R0)

Contains the result of an ADC conversion of the channel selected by the respective hardware trigger and channel control register (ADC_HC0:ADC_HCn). For every ADC_HC0:ADC_HCn status and channel control register, there is a respective ADC_R0:ADC_Rn data result register. Unused bits in the ADC_Rn register are cleared in unsigned right justified modes. For example when configured for 10-bit single-ended mode, D[31:10] are cleared. The table below describes the behavior of the data result registers in the different modes of operation.

<table>
<thead>
<tr>
<th>Conversion Mode</th>
<th>Data Result Register bits</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td>12b single-ended</td>
<td>0 0 0 0 0 D D D D D D D D</td>
<td>unsigned right justified</td>
</tr>
<tr>
<td>10b single-ended</td>
<td>0 0 0 0 0 0 D D D D D D D</td>
<td>unsigned right justified</td>
</tr>
<tr>
<td>8b single-ended</td>
<td>0 0 0 0 0 0 0 0 D D D D D D</td>
<td>unsigned right justified</td>
</tr>
</tbody>
</table>

Address: Base address + 24h offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

ADCx_R0 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>CDATA</td>
<td>Data (result of an ADC conversion)</td>
</tr>
</tbody>
</table>
66.8.5 Data result register for HW triggers (ADCx_Rn)

Contains the result of an ADC conversion of the channel selected by the respective Hardware Trigger and channel control register (ADC_HC0:ADC_HCn). For every ADC_HC0:ADC_HCn status and channel control register, there is a respective ADC_R0 to ADC_Rn data result register. Unused bits in the ADC_Rn register are cleared in unsigned right justified modes. For example when configured for 10-bit single-ended mode, D[31:10] are cleared. The table below describes the behavior of the data result registers in the different modes of operation.

<table>
<thead>
<tr>
<th>Conversion Mode</th>
<th>Data Result Register bits</th>
<th>Format</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>D31 D30 ⋯ D12 D11 D10 D9 D8 D7 D6 D5 D4 D3 D2 D1 D0</td>
<td>unsigned right justified</td>
</tr>
<tr>
<td>12b single-ended</td>
<td>0 0 0 0 0 D D D D D D D D D D D D D D</td>
<td></td>
</tr>
<tr>
<td>10b single-ended</td>
<td>0 0 0 0 0 0 0 D D D D D D D D D D</td>
<td></td>
</tr>
<tr>
<td>8b single-ended</td>
<td>0 0 0 0 0 0 0 0 0 0 0 D D D D D D D D</td>
<td></td>
</tr>
</tbody>
</table>

Address: Base address + 28h offset + (4d × i), where i=0d to 6d

R                W

<table>
<thead>
<tr>
<th>Bit</th>
<th>31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td>CDATA</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

ADCx_Rn field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–12</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>CDATA</td>
<td>Data (result of an ADC conversion)</td>
</tr>
</tbody>
</table>
66.8.6  Configuration register (ADCx_CFG)

Selects the mode of operation, clock source, clock divide, configure for low power, long sample time, high speed configuration and selects the sample time duration.

Address: Base address + 44h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>AVGS</td>
<td>ADTRG</td>
<td>REFSEL</td>
<td>ADHSC</td>
<td>ADSTS</td>
<td>ADLPC</td>
<td>ADIV</td>
<td>ADLSMP</td>
<td>MODE</td>
<td>ADICLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

ADCx_CFG field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>16 OVVREN</td>
<td>Data Overwrite Enable</td>
</tr>
<tr>
<td></td>
<td>Controls the overwriting of the next converted Data onto the existing (previous) unread data into the Data result register.</td>
</tr>
<tr>
<td></td>
<td>1  Enable the overwriting.</td>
</tr>
<tr>
<td></td>
<td>0  Disable the overwriting. Existing Data in Data result register will not be overwritten by subsequent converted data.</td>
</tr>
<tr>
<td>15–14 AVGS</td>
<td>Hardware Average select</td>
</tr>
<tr>
<td></td>
<td>Determines how many ADC conversions will be averaged to create the ADC average result. This functionality is activated when ADC_GC[AVGE] = 1.</td>
</tr>
<tr>
<td></td>
<td>00  4 samples averaged</td>
</tr>
<tr>
<td></td>
<td>01  8 samples averaged</td>
</tr>
<tr>
<td></td>
<td>10  16 samples averaged</td>
</tr>
<tr>
<td></td>
<td>11  32 samples averaged</td>
</tr>
<tr>
<td>13 ADTRG</td>
<td>Conversion Trigger Select</td>
</tr>
<tr>
<td></td>
<td>Selects the type of trigger used for initiating a conversion. Two types of trigger are selectable: software trigger and hardware trigger. When software trigger is selected, a conversion is initiated following a write to ADC_HC0. When hardware trigger is selected, a conversion is initiated following the assertion of a pulse on Alternate Hardware trigger input along with the assertion of the enable of respective the hardware Triggers input.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
ADCx_CFG field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Software trigger selected</td>
</tr>
<tr>
<td>1</td>
<td>Hardware trigger selected</td>
</tr>
<tr>
<td>12–11</td>
<td>Voltage Reference Selection</td>
</tr>
<tr>
<td></td>
<td>Selects the voltage reference source used for conversions.</td>
</tr>
<tr>
<td>00</td>
<td>Selects VREFH/VREFL as reference voltage.</td>
</tr>
<tr>
<td>01</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10</td>
<td>High Speed Configuration</td>
</tr>
<tr>
<td></td>
<td>This bit configures the ADC for high speed operation. The internal ADC clock is higher than normal.</td>
</tr>
<tr>
<td>0</td>
<td>Normal conversion selected.</td>
</tr>
<tr>
<td>1</td>
<td>High speed conversion selected.</td>
</tr>
<tr>
<td>9–8</td>
<td>Defines the total sample time duration in number of full cycles. This has two modes, short and long. When long sample time is selected (ADLSMP=1) this works for long sample time otherwise this works for short sample. This allows higher impedance inputs to be accurately sampled or to maximize conversion speed for lower impedance inputs. Longer sample times can also be used to lower overall power consumption when continuous conversions are enabled if high conversion rates are not required.</td>
</tr>
<tr>
<td>00</td>
<td>Sample period (ADC clocks) = 3 if ADLSMP=0b</td>
</tr>
<tr>
<td>01</td>
<td>Sample period (ADC clocks) = 13 if ADLSMP=1b</td>
</tr>
<tr>
<td>10</td>
<td>Sample period (ADC clocks) = 5 if ADLSMP=0b</td>
</tr>
<tr>
<td>11</td>
<td>Sample period (ADC clocks) = 17 if ADLSMP=1b</td>
</tr>
<tr>
<td>10</td>
<td>Sample period (ADC clocks) = 7 if ADLSMP=0b</td>
</tr>
<tr>
<td>11</td>
<td>Sample period (ADC clocks) = 21 if ADLSMP=1b</td>
</tr>
<tr>
<td>7</td>
<td>Low-Power Configuration</td>
</tr>
<tr>
<td></td>
<td>Puts the ADC hard block into low power mode and reduces the comparator enable period by controlling its timing in the SAR controller block towards the analog hard block. The signal indicating low power mode to the Analog block is asserted when this bit is set.</td>
</tr>
<tr>
<td>0</td>
<td>ADC hard block not in low power mode.</td>
</tr>
<tr>
<td>1</td>
<td>ADC hard block in low power mode.</td>
</tr>
<tr>
<td>6–5</td>
<td>Clock Divide Select</td>
</tr>
<tr>
<td></td>
<td>Selects the divide ratio used by the ADC to generate the internal clock ADCK.</td>
</tr>
<tr>
<td>00</td>
<td>Input clock</td>
</tr>
<tr>
<td>01</td>
<td>Input clock / 2</td>
</tr>
<tr>
<td>10</td>
<td>Input clock / 4</td>
</tr>
<tr>
<td>11</td>
<td>Input clock / 8</td>
</tr>
</tbody>
</table>

Table continues on the next page...
ADCx_CFG field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>ADLSMP</td>
</tr>
<tr>
<td></td>
<td>Long Sample Time Configuration</td>
</tr>
<tr>
<td></td>
<td>Selects between different sample times based on the ADC_CFG[ADSTS] field. This bit adjusts the sample period to allow higher impedance inputs to be accurately sampled or to maximize conversion speed for lower impedance inputs. If high conversion rates are not required, longer sample times can also be used to lower overall power consumption when continuous conversions are enabled. When ADLSMP=1, the Long Sample Time mode is selected and the time is defined by ADSTS[1:0] of the ADC_CFG register.</td>
</tr>
<tr>
<td>0</td>
<td>Short sample mode.</td>
</tr>
<tr>
<td>1</td>
<td>Long sample mode.</td>
</tr>
<tr>
<td>3–2</td>
<td>MODE</td>
</tr>
<tr>
<td></td>
<td>Conversion Mode Selection</td>
</tr>
<tr>
<td></td>
<td>Used to set the ADC resolution mode.</td>
</tr>
<tr>
<td>00</td>
<td>8-bit conversion</td>
</tr>
<tr>
<td>01</td>
<td>10-bit conversion</td>
</tr>
<tr>
<td>10</td>
<td>12-bit conversion</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>ADICLK</td>
<td>Input Clock Select</td>
</tr>
<tr>
<td></td>
<td>Selects the input clock source to generate the internal clock ADCK.</td>
</tr>
<tr>
<td>00</td>
<td>IPG clock</td>
</tr>
<tr>
<td>01</td>
<td>IPG clock divided by 2</td>
</tr>
<tr>
<td>10</td>
<td>Reserved</td>
</tr>
<tr>
<td>11</td>
<td>Asynchronous clock (ADACK)</td>
</tr>
</tbody>
</table>
66.8.7 General control register (ADCx_GC)

Controls the calibration, continuous convert, hardware averaging functions, conversion active, hardware/software trigger select, compare function and voltage reference select of the ADC module.

Address: Base address + 48h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

**ADCx_GC field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–8</td>
<td>Reserved</td>
</tr>
<tr>
<td>CAL</td>
<td>Calibration</td>
</tr>
<tr>
<td>ADCO</td>
<td>Continuous Conversion Enable</td>
</tr>
<tr>
<td>AVGE</td>
<td>Hardware average enable</td>
</tr>
</tbody>
</table>

- **Reserved**: This read-only field is reserved and always has the value 0.
- **CAL**: CAL begins the calibration sequence when set. This bit stays set while the calibration is in progress and is cleared when the calibration sequence is complete. The ADC_GS[CALF] bit must be checked to determine the result of the calibration sequence. After it has started, the calibration routine cannot be interrupted by writes to the ADC registers or the results will be invalid and the ADC_GS[CALF] bit will set. Setting the CAL bit will abort any current conversion.
- **ADCO**: Enables continuous conversions.
  - 0: One conversion or one set of conversions if the hardware average function is enabled (AVGE=1) after initiating a conversion.
  - 1: Continuous conversions or sets of conversions if the hardware average function is enabled (AVGE=1) after initiating a conversion.
- **AVGE**: Enables the hardware average function of the ADC.
  - 0: Hardware average function disabled
  - 1: Hardware average function enabled

*Table continues on the next page...*
### ADCx_GC field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 4 ACFE | Compare Function Enable  
Enables the compare function.  
0 Compare function disabled  
1 Compare function enabled |
| 3 ACFGT | Compare Function Greater Than Enable  
Configures the compare function to check the conversion result relative to the compare value register (ADC_CV) based upon the value of ACREN (bit 2 in ADC_GC register). The ACFE bit must be set for ACFGT to have any effect.  
0 Configures "Less Than Threshold, Outside Range Not Inclusive and Inside Range Not Inclusive" functionality based on the values placed in the ADC_CV register.  
1 Configures "Greater Than Or Equal To Threshold, Outside Range Inclusive and Inside Range Inclusive" functionality based on the values placed in the ADC_CV registers. |
| 2 ACREN | Compare Function Range Enable  
Configures the compare function to check the conversion result of the input being monitored is either between or outside the range formed by the compare values in register (ADC_CV) determined by the value of ACFGT. The ACFE bit must be set for ACFGT to have any effect.  
0 Range function disabled. Only the compare value 1 of ADC_CV register (CV1) is compared.  
1 Range function enabled. Both compare values of ADC_CV registers (CV1 and CV2) are compared. |
| 1 DMAEN | DMA Enable  
Enables the DMA logic.  
0 DMA disabled (default)  
1 DMA enabled |
| 0 ADACKEN | Asynchronous clock output enable  
Enables the ADC's asynchronous clock source and the clock source output regardless of the conversion and input clock select (ADC_CFG[ADICLK]) settings of the ADC. Based on MCU configuration, the asynchronous clock may be used by other modules (see module introduction section). Setting this bit allows the clock to be used even while the ADC is idle or operating from a different clock source. Also, latency of initiating a single or first-continuous conversion with the asynchronous clock selected is reduced since the ADACK clock is already operational.  
0 Asynchronous clock output disabled; Asynchronous clock only enabled if selected by ADICLK and a conversion is active.  
1 Asynchronous clock and clock output enabled regardless of the state of the ADC |
66.8.8 General status register (ADCx_GS)

Controls the calibration, continuous convert, hardware averaging functions, conversion active, hardware/software trigger select, compare function and voltage reference select of the ADC module.

Address: Base address + 4Ch offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### ADCx_GS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–3</td>
<td>Reserved</td>
</tr>
<tr>
<td>2 AWKST</td>
<td>Asynchronous wakeup interrupt status</td>
</tr>
<tr>
<td>1 CALF</td>
<td>Calibration Failed Flag</td>
</tr>
</tbody>
</table>

This read-only field is reserved and always has the value 0.

Asynchronous wake up interrupt occurred in stop mode.

Table continues on the next page...
## ADCx_GS field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CALF</td>
<td>Displays the result of the calibration sequence. The calibration sequence will fail if Hardware Trigger is selected (i.e. ADC_CFG[ADTRG] = 1), or any ADC register is written, or any stop mode is entered before the calibration sequence completes. The CALF bit is cleared by writing a 1 to it.</td>
</tr>
<tr>
<td>0</td>
<td>Calibration completed normally.</td>
</tr>
<tr>
<td>1</td>
<td>Calibration failed. ADC accuracy specifications are not guaranteed.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADACT</td>
<td>Conversion Active</td>
</tr>
<tr>
<td></td>
<td>Indicates that a conversion or hardware averaging is in progress. ADACT is set when a conversion is initiated and cleared when a conversion is completed or aborted.</td>
</tr>
<tr>
<td>0</td>
<td>Conversion not in progress.</td>
</tr>
<tr>
<td>1</td>
<td>Conversion in progress.</td>
</tr>
</tbody>
</table>

### 66.8.9 Compare value register (ADCx.CV)

Contains compare values used to compare with the conversion result when the compare function is enabled (ADC_GC[ACFE]=1). The compare values are right justified. Therefore, the compare function only uses the compare value register bits that are related to the ADC mode of operation. (e.g. in 8 bit mode, CV1 = ADC_CV[7:0] and CV2 = ADC_CV[23:16], similarly in 10 bit mode, CV1 = ADC_CV[9:0] and CV2 = ADC_CV[25:16] etc.) The compare value 2 in this register is utilized only when the compare range function is enabled (ADC_GC[ACREN]=1).

<table>
<thead>
<tr>
<th>Address: Base address + 50h offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th></th>
<th>CV2 0</th>
</tr>
</thead>
<tbody>
<tr>
<td>W</td>
<td>0</td>
</tr>
<tr>
<td>R</td>
<td>0</td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

### ADCx.CV field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27–16</td>
<td>CV2</td>
</tr>
<tr>
<td>15–12</td>
<td>Reserved</td>
</tr>
<tr>
<td>CV1</td>
<td>Compare Value 1</td>
</tr>
</tbody>
</table>

This read-only field is reserved and always has the value 0.

This read-only field is reserved and always has the value 0.

Contains a compare value used to compare with the conversion result when the compare function and compare range function are enabled (ADC_GC[ACFE]=1, ADC_GC[ACREN]=1).

Contains a compare value used to compare with the conversion result when the compare function is enabled (ADC_GC[ACFE]=1).
66.8.10 Offset correction value register (ADCx_OFS)

Contains the user-defined offset error correction value. This register is 13 bits wide. The value in the most significant bit (13th bit) is the operation bit. If this bit is ‘0’ then the value in the other 12 bits is added with the converted result value to generate final result to be loaded into ADC_Rn; if this bit is ‘1’ then this field is subtracted from converted value to generate final result (ADC_Rn).

Address: Base address + 54h offset

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

ADCx_OFS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–13</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>12</td>
<td>SIGN</td>
</tr>
<tr>
<td></td>
<td>Sign bit</td>
</tr>
<tr>
<td>0</td>
<td>The offset value is added with the raw result</td>
</tr>
<tr>
<td>1</td>
<td>The offset value is subtracted from the raw converted value</td>
</tr>
<tr>
<td>OFS</td>
<td>Offset value</td>
</tr>
<tr>
<td></td>
<td>User configurable offset value.</td>
</tr>
</tbody>
</table>

66.8.11 Calibration value register (ADCx_CAL)

Contains calibration information that is generated by the calibration function. This register contains a calibration value of four bits(CAL[3:0]); this is automatically set after the self calibration sequence is done (ADC_SC[CAL] bit is cleared). If this register is written to by the user after calibration, the linearity error specifications may not be met.

Address: Base address + 58h offset

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R   | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
### ADCx_CAL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–4</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>CAL_CODE</td>
<td>Calibration Result Value</td>
</tr>
<tr>
<td></td>
<td>This value is automatically loaded and updated at the end of calibration.</td>
</tr>
</tbody>
</table>
Chapter 67
ADC External Trigger Control (ADC_ETC)

67.1 Chip-specific ADC_ETC information

Table 67-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>XBAR resource assignments</td>
<td>XBAR</td>
<td>XBAR Resource Assignments</td>
</tr>
<tr>
<td>Touch Screen Control</td>
<td>TSC</td>
<td>TSC</td>
</tr>
</tbody>
</table>

67.2 About this module

67.2.1 Introduction

The ADC_ETC module enables multiple users to share the ADC modules in a TIME-Division-Multiplexing (TDM) way. The external triggers can be from the Cross BAR (XBAR) and TSC (Touch Screen Controller) in SOC. The ADC_ETC has one TSC external trigger and 8 external triggers from XBAR. The TSC external trigger is shared by TSC0 and TSC1. The triggers trig0~trig3 from XBAR and TSC0 belong to channel 0 and control ADC1, and trig4~trig7 and TSC1 belong to channel 1 and share ADC2 with the TSC external trigger. When TSC_BYPASS is set, TSC external trigger will control ADC2 directly. The ADC_ETC also supports SyncMode. When set as SyncMode, the ADC_ETC trigger source will controls ADC1 and ADC2 synchronously. In SyncMode,
the initial delay is controlled by the registers of trig0~trig3, while other settings are
independent. The SyncMode can not be used when TSC_BYPASS is active. The
ADC_ETC can support interrupt mode and DMA mode (controlled independently).

67.2.2 Features

The ADC_ETC includes the following features:

- ADC trigger control interface with dual ADCs, support up to 8 Hardware External
  Trigger (ext_hwts[7:0]) control for each ADC

- Capable of triggering dual ADC in SyncMode or AsyncMode:
  - In SyncMode ADC1 and ADC2 are controlled by the same trigger source of
    ADC_ETC.
  - In AsyncMode ADC1 and ADC2 are controlled by separate trigger source of
    ADC_ETC.

- Support up to four external trigger inputs for each ADC (trig0~trig3 for ADC1, and
  trig4~trig7 for ADC2):
  - Four single to multiple (up to 8) trigger sources. One external trigger of
    ADC_ETC results in multiple sequential triggers, which are named as trigger
    chain, to ADC.
  - Flexible ADC trigger interval and initial delay control.
  - Each trigger sources can be configured as HW or SW trigger mode.

- ADC result holding and status reporting

- External trigger auto hold and arbitration
  - Each external trigger can be configured with a fixed priority. External trigger
    with the highest priority is severed first.
  - Hold one trigger event upon arbitration lose or ADC busy.

- Support ADC trigger interface cascading

- Support interrupt mode. When interrupt mode is selected and one ADC conversion is
done, an interrupt request signal will be generated on one of the Done0~Done2
interrupt outputs.

- Support DMA mode. When DMA is enabled and one ADC conversion is done, a
  DMA request will be sent. 2 trigger modes of DMA can be selected by configuring
  DMA_MODE_SEL bitfield.
67.3 Block diagram

Figure 67-1. ADC_ETC block diagram

67.4 Functional description

The ADC_ETC block works with XBAR and TSC blocks to share with the ADC modules. The following sections describe functional details of the ADC_ETC module.
67.4.1 Clocks

The ADC_ETC module has one global functional clock: ipg_clk. The ipg_clk is used for register read/write operations, also all the functionality inside the ADC_ETC module are synchronized to this clock.

As XBAR and TSC input can be SYNC or ASYNC with the ADC_ETC clock, the ipg_clk need to be set that can capture the trigger input edge after the double synchronous circuit.

67.4.2 Reset

The ADC_ETC has two resets: ipg_hard_async_reset_b and sw_reset_n. The ipg_hard_async_reset_b is a hardware reset, which resets all registers in ADC_ETC block. While the sw_reset_n is a software reset, which can reset all configuration registers by software.

67.4.3 Operations

This section describes the ADC_ETC module’s operations.

The trigger process is used to process the multiple input sources, trigger_enable can be used to mask the hardware trigger source. Software can select the hardware trigger or software trigger by configuration, and the selected source is double synchronized and the posedge pulse is detected before a request is sent to the arbiter.

The trigger process diagram is indicated as below:
The trigger requests from XBAR and TSC have fixed priority setting before going to the arbiter. There are total of eight priority levels available for each trigger request, where 7 is the highest priority level and 0 is the lowest priority level. If multiple trigger requests have the same priority level, then the round-robin scheme is applied for the requests to the ADC trigger source. The trigger request is granted only when the previous trigger has finished and the ADC module is IDLE. When in SYNC mode, the trigger request is granted only when both ADC modules are IDLE state.

When there is a trigger request that is granted, the ADC_ETC sends several triggers as a chain of trigger, with HWTS[7:0] as corresponding hardware trigger select signal, and with CSEL[3:0] configuring the sampled channel of the ADC. When the ADC finishes conversion, the ADC sends back a complete signal adc_coco to the ADC_ETC, which has the same width as HWTS and indicates the ADC hardware trigger corresponding with the current sar_result_o, then the ADC_ETC stores the correct ADC converted results into the internal registers, and clear the ADC COCO signals in the correct order. All parts of these steps are automatically done by hardware. At the same time, interrupt asserts according to the software configuration. After that, the next trigger is sent after a configurable interval delay, until all triggers in the chain are processed. When complete the the last trigger in chain, ADC_ETC sends the coco signal to mark the end of one of ADC_ETC external trigger, and a DMA request is launched according to the software configuration.

Each ADC trigger in the trigger chains, initiated by the eight external trigger sources, has separate configurations by software, including Interrupt selection (IE), Back to Back ADC trigger (B2B), HWTS and CSEL to ADC. The ADC_ETC have interrupt outputs of Done0, Done1, Done2 and Error Interrupt. The Done0/1/2 interrupts are controlled by software for each ADC trigger. IEx selects which port the interrupt occurs on. (IEx=2'b00
means no interrupt, while 2'b01~2'b11 mean selecting Done0~Done2 correspondingly). Error interrupt occurs when there is an external trigger ignored by ADC_ETC due to the previous trigger not finished yet.

The ETC ADC interface timing is indicated in below diagrams:

![ETC ADC interface timing diagram]

**Figure 67-3. ETC ADC interface timing**

Waiting Initial delay after external trigger from XBAR, the trigger_req asserts. After one ADC conversion, the next trigger in the chain starts as soon as possible if B2B is enabled. Otherwise the next trigger does not start until after a interval delay. The length of Initial delay and Interval delay are configurable, the relationship between these 2 delays and the register setting is described in the description of the ETC_TRIG counter.

### 67.5 Memory Map and register definition

This section includes the ADC_ETC module memory map and detailed descriptions of all registers.

#### 67.5.1 ADC_ETC register descriptions

#### 67.5.1.1 ADC_ETC memory map

ADC_ETC base address: 403B_0000h

<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>0h</td>
<td>ADC_ETC Global Control Register (CTRL)</td>
<td>32</td>
<td>RW</td>
<td>C000_0000h</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>4h</td>
<td>ETC DONE0 and DONE1 IRQ State Register (DONE0_1_IRQ)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8h</td>
<td>ETC DONE_2 and DONE_ERR IRQ State Register (DONE2_ERR_IRQ)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>Ch</td>
<td>ETC DMA control Register (DMA_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10h</td>
<td>ETC_TRIG Control Register (TRIG0_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>14h</td>
<td>ETC_TRIG Counter Register (TRIG0_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>18h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG0_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>1Ch</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG0_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>20h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG0_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>24h</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG0_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>28h</td>
<td>ETC_TRIG Result Data 1/0 Register (TRIG0_RESULT_1_0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>2Ch</td>
<td>ETC_TRIG Result Data 3/2 Register (TRIG0_RESULT_3_2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>30h</td>
<td>ETC_TRIG Result Data 5/4 Register (TRIG0_RESULT_5_4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>34h</td>
<td>ETC_TRIG Result Data 7/6 Register (TRIG0_RESULT_7_6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>38h</td>
<td>ETC_TRIG Control Register (TRIG1_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>3Ch</td>
<td>ETC_TRIG Counter Register (TRIG1_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>40h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG1_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>44h</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG1_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>48h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG1_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>4Ch</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG1_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>50h</td>
<td>ETC_TRIG Result Data 1/0 Register (TRIG1_RESULT_1_0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>54h</td>
<td>ETC_TRIG Result Data 3/2 Register (TRIG1_RESULT_3_2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>58h</td>
<td>ETC_TRIG Result Data 5/4 Register (TRIG1_RESULT_5_4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>5Ch</td>
<td>ETC_TRIG Result Data 7/6 Register (TRIG1_RESULT_7_6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>60h</td>
<td>ETC_TRIG Control Register (TRIG2_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>64h</td>
<td>ETC_TRIG Counter Register (TRIG2_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>68h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG2_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>6Ch</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG2_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>70h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG2_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>74h</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG2_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>78h</td>
<td>ETC_TRIG Result Data 1/0 Register (TRIG2_RESULT_1_0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>7Ch</td>
<td>ETC_TRIG Result Data 3/2 Register (TRIG2_RESULT_3_2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>80h</td>
<td>ETC_TRIG Result Data 5/4 Register (TRIG2_RESULT_5_4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>84h</td>
<td>ETC_TRIG Result Data 7/6 Register (TRIG2_RESULT_7_6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>88h</td>
<td>ETC_TRIG Control Register (TRIG3_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>8Ch</td>
<td>ETC_TRIG Counter Register (TRIG3_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>90h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG3_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>94h</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG3_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>98h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG3_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>9Ch</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG3_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Offset</th>
<th>Register</th>
<th>Width (In bits)</th>
<th>Access</th>
<th>Reset value</th>
</tr>
</thead>
<tbody>
<tr>
<td>A0h</td>
<td>ETC_TRIG Result Data 1/0 Register (TRIG3_RESULT_1_0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>A4h</td>
<td>ETC_TRIG Result Data 3/2 Register (TRIG3_RESULT_3_2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>A8h</td>
<td>ETC_TRIG Result Data 5/4 Register (TRIG3_RESULT_5_4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>ACh</td>
<td>ETC_TRIG Result Data 7/6 Register (TRIG3_RESULT_7_6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>B0h</td>
<td>ETC_TRIG Control Register (TRIG4_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>B4h</td>
<td>ETC_TRIG Counter Register (TRIG4_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>B8h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG4_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>BCh</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG4_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C0h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG4_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C4h</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG4_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>C8h</td>
<td>ETC_TRIG Result Data 1/0 Register (TRIG4_RESULT_1_0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>CCh</td>
<td>ETC_TRIG Result Data 3/2 Register (TRIG4_RESULT_3_2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>D0h</td>
<td>ETC_TRIG Result Data 5/4 Register (TRIG4_RESULT_5_4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>D4h</td>
<td>ETC_TRIG Result Data 7/6 Register (TRIG4_RESULT_7_6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>D8h</td>
<td>ETC_TRIG Control Register (TRIG5_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>DCh</td>
<td>ETC_TRIG Counter Register (TRIG5_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E0h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG5_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E4h</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG5_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>E8h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG5_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>ECh</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG5_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>F0h</td>
<td>ETC_TRIG Result Data 1/0 Register (TRIG5_RESULT_1_0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>F4h</td>
<td>ETC_TRIG Result Data 3/2 Register (TRIG5_RESULT_3_2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>F8h</td>
<td>ETC_TRIG Result Data 5/4 Register (TRIG5_RESULT_5_4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>FCh</td>
<td>ETC_TRIG Result Data 7/6 Register (TRIG5_RESULT_7_6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>100h</td>
<td>ETC_TRIG Control Register (TRIG6_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>104h</td>
<td>ETC_TRIG Counter Register (TRIG6_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>108h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG6_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>10Ch</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG6_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>110h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG6_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>114h</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG6_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>118h</td>
<td>ETC_TRIG Result Data 1/0 Register (TRIG6_RESULT_1_0)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>11Ch</td>
<td>ETC_TRIG Result Data 3/2 Register (TRIG6_RESULT_3_2)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>120h</td>
<td>ETC_TRIG Result Data 5/4 Register (TRIG6_RESULT_5_4)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>124h</td>
<td>ETC_TRIG Result Data 7/6 Register (TRIG6_RESULT_7_6)</td>
<td>32</td>
<td>RO</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>128h</td>
<td>ETC_TRIG Control Register (TRIG7_CTRL)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>12Ch</td>
<td>ETC_TRIG Counter Register (TRIG7_COUNTER)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>130h</td>
<td>ETC_TRIG Chain 0/1 Register (TRIG7_CHAIN_1_0)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>134h</td>
<td>ETC_TRIG Chain 2/3 Register (TRIG7_CHAIN_3_2)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>138h</td>
<td>ETC_TRIG Chain 4/5 Register (TRIG7_CHAIN_5_4)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
<tr>
<td>13Ch</td>
<td>ETC_TRIG Chain 6/7 Register (TRIG7_CHAIN_7_6)</td>
<td>32</td>
<td>RW</td>
<td>0000_0000h</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 67.5.1.2 ADC_ETC Global Control Register (CTRL)

#### 67.5.1.2.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>CTRL</td>
<td>0h</td>
</tr>
</tbody>
</table>

#### 67.5.1.2.2 Function

ADC_ETC global control register

This register controls various high-level functions of the ADC_ETC

#### 67.5.1.2.3 Diagram

![Diagram of the ADC_ETC Global Control Register (CTRL)](image-url)
### 67.5.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 SOFTRST</td>
<td>Software reset, high active. When this bitfield is set to 1, then the ADC_ETC is reset.</td>
</tr>
<tr>
<td>30 TSC_BYPASS</td>
<td>1'b1: TSC is bypassed to ADC2, that means TSC will control ADC2 directly.</td>
</tr>
<tr>
<td></td>
<td>1'b0: TSC not bypassed.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> To use ADC2, this bit should be cleared.</td>
</tr>
<tr>
<td>29 DMA_MODE_SEL</td>
<td>1'b0: Trig DMA_REQ with latched signal, REQ will be cleared when ACK and source request cleared.</td>
</tr>
<tr>
<td></td>
<td>1'b1: Trig DMA_REQ with pulsed signal, REQ will be cleared by ACK only.</td>
</tr>
<tr>
<td>28-24 Reserved</td>
<td>Pre-divider for trig delay and interval.</td>
</tr>
<tr>
<td>23-16 PRE_DIVIDER</td>
<td>Pre-divider for trig delay and interval.</td>
</tr>
<tr>
<td>15-13 EXT1_TRIG_PRIORITY</td>
<td>External TSC1 trigger priority, 7 is Highest, 0 is lowest.</td>
</tr>
<tr>
<td>12 EXT1_TRIG_ENABLE</td>
<td>TSC1 TRIG enable register. 1'b1: enable external TSC1 trigger. 1'b0: disable external TSC1 trigger.</td>
</tr>
<tr>
<td>11-9 EXT0_TRIG_PRIORITY</td>
<td>External TSC0 trigger priority, 7 is Highest, 0 is lowest.</td>
</tr>
<tr>
<td>8 EXT0_TRIG_ENABLE</td>
<td>TSC0 TRIG enable register. 1'b1: enable external TSC0 trigger. 1'b0: disable external TSC0 trigger.</td>
</tr>
<tr>
<td>7-0 TRIG_ENABLE</td>
<td>TRIG enable register. 1'b1: enable correspond external XBAR trigger [7 ... 0]. 1'b0: disable correspond external XBAR trigger [7 ... 0].</td>
</tr>
</tbody>
</table>

### 67.5.1.3 ETC DONE0 and DONE1 IRQ State Register (DONE0_1_IRQ)

### 67.5.1.3.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DONE0_1_IRQ</td>
<td>4h</td>
</tr>
</tbody>
</table>
67.5.1.3.2 Function

This register has the state for ETC DONE0 and DONE1 interrupts

NOTE
The IRQs are cleared by writing a logic 1 to the bits.

67.5.1.3.3 Diagram

| Bits | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24 | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16 |
|------|-----|-----|-----|-----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|----|
| R    |     |     |     |     |     |     |     |    |     |     |     |     |     |     |    |
| W    | Reserved |     |     |     |     |     |     |    |     |     |     |     |     |     |    |

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

67.5.1.3.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>TRIG7 done1 interrupt detection</td>
</tr>
<tr>
<td>22</td>
<td>TRIG6 done1 interrupt detection</td>
</tr>
<tr>
<td>21</td>
<td>TRIG5 done1 interrupt detection</td>
</tr>
<tr>
<td>20</td>
<td>TRIG4 done1 interrupt detection</td>
</tr>
<tr>
<td>19</td>
<td>TRIG3 done1 interrupt detection</td>
</tr>
<tr>
<td>18</td>
<td>TRIG2 done1 interrupt detection</td>
</tr>
</tbody>
</table>

Table continues on the next page...
## Field Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>17</td>
<td>TRIG1 done1 interrupt detection</td>
</tr>
<tr>
<td>TRIG1_DONE1</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>TRIG0 done1 interrupt detection</td>
</tr>
<tr>
<td>TRIG0_DONE1</td>
<td></td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>__</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>TRIG7 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG7_DONE0</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>TRIG6 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG6_DONE0</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>TRIG5 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG5_DONE0</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>TRIG4 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG4_DONE0</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>TRIG3 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG3_DONE0</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>TRIG2 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG2_DONE0</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>TRIG1 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG1_DONE0</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>TRIG0 done0 interrupt detection</td>
</tr>
<tr>
<td>TRIG0_DONE0</td>
<td></td>
</tr>
</tbody>
</table>

### 67.5.1.4 ETC DONE_2 and DONE_ERR IRQ State Register (DONE2_ERR_IRQ)

#### 67.5.1.4.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DONE2_ERR_IRQ</td>
<td>8h</td>
</tr>
</tbody>
</table>

#### 67.5.1.4.2 Function

This register has the state for ETC DONE2 and DONE_ERR interrupts

**NOTE**

The IRQs are cleared by writing a logic 1 to the bits.
67.5.1.4.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

67.5.1.4.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23</td>
<td>TRIG7_ERR error interrupt detection</td>
</tr>
<tr>
<td>22</td>
<td>TRIG6_ERR error interrupt detection</td>
</tr>
<tr>
<td>21</td>
<td>TRIG5_ERR error interrupt detection</td>
</tr>
<tr>
<td>20</td>
<td>TRIG4_ERR error interrupt detection</td>
</tr>
<tr>
<td>19</td>
<td>TRIG3_ERR error interrupt detection</td>
</tr>
<tr>
<td>18</td>
<td>TRIG2_ERR error interrupt detection</td>
</tr>
<tr>
<td>17</td>
<td>TRIG1_ERR error interrupt detection</td>
</tr>
<tr>
<td>16</td>
<td>TRIG0_ERR error interrupt detection</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### 67.5.1.5 ETC DMA control Register (DMA_CTRL)

#### 67.5.1.5.1 Offset

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>DMA_CTRL</td>
<td>Ch</td>
</tr>
</tbody>
</table>

#### 67.5.1.5.2 Function

This register has the DMA control for ETC

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>TRIG7 done2 interrupt detection</td>
</tr>
<tr>
<td>6</td>
<td>TRIG6 done2 interrupt detection</td>
</tr>
<tr>
<td>5</td>
<td>TRIG5 done2 interrupt detection</td>
</tr>
<tr>
<td>4</td>
<td>TRIG4 done2 interrupt detection</td>
</tr>
<tr>
<td>3</td>
<td>TRIG3 done2 interrupt detection</td>
</tr>
<tr>
<td>2</td>
<td>TRIG2 done2 interrupt detection</td>
</tr>
<tr>
<td>1</td>
<td>TRIG1 done2 interrupt detection</td>
</tr>
<tr>
<td>0</td>
<td>TRIG0 done2 interrupt detection</td>
</tr>
</tbody>
</table>
### 67.5.1.5.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>Reserved</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 67.5.1.5.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>_</td>
</tr>
<tr>
<td>23</td>
<td>TRIG7_REQ When TRIG7 done DMA request detection</td>
</tr>
<tr>
<td>22</td>
<td>TRIG6_REQ When TRIG6 done DMA request detection</td>
</tr>
<tr>
<td>21</td>
<td>TRIG5_REQ When TRIG5 done DMA request detection</td>
</tr>
<tr>
<td>20</td>
<td>TRIG4_REQ When TRIG4 done DMA request detection</td>
</tr>
<tr>
<td>19</td>
<td>TRIG3_REQ When TRIG3 done DMA request detection</td>
</tr>
<tr>
<td>18</td>
<td>TRIG2_REQ When TRIG2 done DMA request detection</td>
</tr>
<tr>
<td>17</td>
<td>TRIG1_REQ When TRIG1 done DMA request detection</td>
</tr>
<tr>
<td>16</td>
<td>TRIG0_REQ When TRIG0 done DMA request detection</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> It's a flag bit for DMA request. TRIG0_REQ setting indicates trigger0 done and a DMA transmission is needed. If TRIG0_ENABLE is also set, a DMA request will be sent.</td>
</tr>
<tr>
<td>15-8</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
## 67.5.1.6 ETC_TRIG Control Register (TRIG0_CTRL - TRIG7_CTRL)

### 67.5.1.6.1 Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_CTRL</td>
<td>10h + (a × 28h)</td>
</tr>
</tbody>
</table>

### 67.5.1.6.2 Function

ETC_TRIG control register

This register controls various functions of the ETC_TRIG

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>7 TRIG7_ENABLE</td>
<td>When TRIG7 done enable DMA request</td>
</tr>
<tr>
<td>6 TRIG6_ENABLE</td>
<td>When TRIG6 done enable DMA request</td>
</tr>
<tr>
<td>5 TRIG5_ENABLE</td>
<td>When TRIG5 done enable DMA request</td>
</tr>
<tr>
<td>4 TRIG4_ENABLE</td>
<td>When TRIG4 done enable DMA request</td>
</tr>
<tr>
<td>3 TRIG3_ENABLE</td>
<td>When TRIG3 done enable DMA request</td>
</tr>
<tr>
<td>2 TRIG2_ENABLE</td>
<td>When TRIG2 done enable DMA request</td>
</tr>
<tr>
<td>1 TRIG1_ENABLE</td>
<td>When TRIG1 done enable DMA request</td>
</tr>
<tr>
<td>0 TRIG0_ENABLE</td>
<td>When TRIG0 done enable DMA request</td>
</tr>
</tbody>
</table>
### 67.5.1.6.3 Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### 67.5.1.6.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-24</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-17</td>
<td>Reserved</td>
</tr>
<tr>
<td>16</td>
<td>TRIG mode control. 1'b0: Disable sync mode; 1'b1: Enable sync mode</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14-12</td>
<td>External trigger priority, 7 is highest, 0 is lowest.</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
<tr>
<td>10-8</td>
<td>TRIG chain length to the ADC.</td>
</tr>
<tr>
<td></td>
<td>0: Trig length is 1;</td>
</tr>
<tr>
<td></td>
<td>...</td>
</tr>
<tr>
<td></td>
<td>7: Trig length is 8;</td>
</tr>
<tr>
<td>7-5</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>TRIG mode register. 1'b0: hardware trigger. 1'b1: software trigger.</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
67.5.1.7 ETC_TRIG Counter Register (TRIG0_COUNTER - TRIG7_COUNTER)

67.5.1.7.1 Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIG0_COUNTER</td>
<td>14h + (a × 28h)</td>
</tr>
</tbody>
</table>

67.5.1.7.2 Function

This register controls ETC_TRIG counter

67.5.1.7.3 Diagram

![Diagram]

67.5.1.7.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-16</td>
<td>TRIGGER sampling interval counter. When B2B is unset: Interval_delay = (SAMPLE_INTERVAL+1)*(PRE_DIVIDER+1)*ipg_clk</td>
</tr>
</tbody>
</table>

Table continues on the next page...
67.5.1.8 ETC_TRIG Chain 0/1 Register (TRIG0_CHAIN_1_0 - TRIG7_CHAIN_1_0)

67.5.1.8.1 Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_CHAIN_1_0</td>
<td>18h + (a × 28h)</td>
</tr>
</tbody>
</table>

67.5.1.8.2 Function

This register controls ETC_TRIG Chain 0/1 configuration

67.5.1.8.3 Diagram

![Diagram of ETC_TRIG Chain 0/1 Register](image)
## 67.5.1.8.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30-29</td>
<td>IE1</td>
</tr>
<tr>
<td>30-29</td>
<td>CHAIN1 IE</td>
</tr>
<tr>
<td>30</td>
<td>2'b00: No interrupt when finished</td>
</tr>
<tr>
<td>30</td>
<td>2'b01: Finished Interrupt on Done0</td>
</tr>
<tr>
<td>30</td>
<td>2'b10: Finished Interrupt on Done1</td>
</tr>
<tr>
<td>30</td>
<td>2'b11: Finished Interrupt on Done2</td>
</tr>
<tr>
<td>28</td>
<td>B2B1</td>
</tr>
<tr>
<td>28</td>
<td>CHAIN1 B2B</td>
</tr>
<tr>
<td>28</td>
<td>1'b0: Disable B2B, wait until interval is reached</td>
</tr>
<tr>
<td>28</td>
<td>1'b1: Enable B2B, the next ADC trigger will be sent as soon as possible.</td>
</tr>
<tr>
<td>27-20</td>
<td>HWTS1</td>
</tr>
<tr>
<td>27-20</td>
<td>CHAIN1 HWTS</td>
</tr>
<tr>
<td>27-20</td>
<td>ADC hardware trigger selection. For more information, see the ADC chapter.</td>
</tr>
<tr>
<td>19-16</td>
<td>CSEL1</td>
</tr>
<tr>
<td>19-16</td>
<td>CHAIN1 CSEL</td>
</tr>
<tr>
<td>19-16</td>
<td>ADC channel selection</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14-13</td>
<td>IE0</td>
</tr>
<tr>
<td>14-13</td>
<td>CHAIN0 IE</td>
</tr>
<tr>
<td>14</td>
<td>2'b00: No interrupt when finished</td>
</tr>
<tr>
<td>14</td>
<td>2'b01: Finished Interrupt on Done0</td>
</tr>
<tr>
<td>14</td>
<td>2'b10: Finished Interrupt onDone1</td>
</tr>
<tr>
<td>14</td>
<td>2'b11: Finished Interrupt on Done2</td>
</tr>
<tr>
<td>12</td>
<td>B2B0</td>
</tr>
<tr>
<td>12</td>
<td>CHAIN0 B2B</td>
</tr>
<tr>
<td>12</td>
<td>1'b0: Disable B2B, wait until interval is reached</td>
</tr>
<tr>
<td>12</td>
<td>1'b1: Enable B2B, the next ADC trigger will be sent as soon as possible.</td>
</tr>
<tr>
<td>11-4</td>
<td>HWTS0</td>
</tr>
<tr>
<td>11-4</td>
<td>CHAIN0 HWTS</td>
</tr>
<tr>
<td>11-4</td>
<td>ADC hardware trigger selection. For more information, see the ADC chapter.</td>
</tr>
<tr>
<td>3-0</td>
<td>CSEL0</td>
</tr>
<tr>
<td>3-0</td>
<td>CHAIN0 CSEL</td>
</tr>
<tr>
<td>3-0</td>
<td>ADC channel selection</td>
</tr>
</tbody>
</table>

## 67.5.1.9 ETC_TRIG Chain 2/3 Register (TRIG0_CHAIN_3_2 - TRIG7_CHAIN_3_2)

### 67.5.1.9.1 Offset

For $a = 0$ to $7$:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_CHAIN_3_2</td>
<td>1Ch + (a × 28h)</td>
</tr>
</tbody>
</table>
67.5.1.9.2 Function
This register controls ETC_TRIG Chain 2/3 configuration

67.5.1.9.3 Diagram

67.5.1.9.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30-29</td>
<td>CHAIN3 IE</td>
</tr>
<tr>
<td>IE3</td>
<td></td>
</tr>
<tr>
<td>28</td>
<td>CHAIN3 B2B</td>
</tr>
<tr>
<td>B2B3</td>
<td></td>
</tr>
<tr>
<td>27-20</td>
<td>CHAIN3 HWTS</td>
</tr>
<tr>
<td>HWTS3</td>
<td></td>
</tr>
<tr>
<td>19-16</td>
<td>CHAIN3 CSEL</td>
</tr>
<tr>
<td>CSEL3</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14-13</td>
<td>CHAIN2 IE</td>
</tr>
<tr>
<td>IE2</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>CHAIN2 B2B</td>
</tr>
<tr>
<td>B2B2</td>
<td></td>
</tr>
<tr>
<td>11-4</td>
<td>CHAIN2 HWTS</td>
</tr>
<tr>
<td>HWTS2</td>
<td></td>
</tr>
<tr>
<td>3-0</td>
<td>CHAIN2 CSEL</td>
</tr>
<tr>
<td>CSEL2</td>
<td></td>
</tr>
</tbody>
</table>
67.5.1.10  ETC_TRIG Chain 4/5 Register (TRIG0_CHAIN_5_4 - TRIG7_CHAIN_5_4)

67.5.1.10.1  Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_CHAIN_5_4</td>
<td>20h + (a × 28h)</td>
</tr>
</tbody>
</table>

67.5.1.10.2  Function

This register controls ETC_TRIG Chain 4/5 configuration

67.5.1.10.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

67.5.1.10.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30-29</td>
<td>CHAIN5 IE</td>
</tr>
<tr>
<td>IE5</td>
<td>CHAIN5 B2B</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### Field and Function

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>B2B5</td>
<td></td>
</tr>
<tr>
<td>27-20</td>
<td>CHAIN5 HWTS</td>
</tr>
<tr>
<td>HWTS5</td>
<td></td>
</tr>
<tr>
<td>19-16</td>
<td>CHAIN5 CSEL</td>
</tr>
<tr>
<td>CSEL5</td>
<td></td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>14-13 IE4</td>
<td>CHAIN4 IE</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>CHAIN4 B2B</td>
</tr>
<tr>
<td>B2B4</td>
<td></td>
</tr>
<tr>
<td>11-4</td>
<td>CHAIN4 HWTS</td>
</tr>
<tr>
<td>HWTS4</td>
<td></td>
</tr>
<tr>
<td>3-0 CSEL4</td>
<td>CHAIN4 CSEL</td>
</tr>
</tbody>
</table>

### 67.5.1.11 ETC_TRIG Chain 6/7 Register (TRIG0_CHAIN_7_6 - TRIG7_CHAIN_7_6)

### 67.5.1.11.1 Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_CHAIN_7_6</td>
<td>24h + (a × 28h)</td>
</tr>
</tbody>
</table>

### 67.5.1.11.2 Function

This register controls ETC_TRIG Chain 6/7 configuration
67.5.1.11.3 Diagram

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td>IE7</td>
<td>B2B7</td>
<td>HWTS7</td>
<td>CSEL 7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Reserved</td>
<td>IE6</td>
<td>B2B6</td>
<td>HWTS6</td>
<td>CSEL 6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
```

67.5.1.11.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>Reserved</td>
</tr>
<tr>
<td>30-29</td>
<td>CHAIN7 IE</td>
</tr>
<tr>
<td>28</td>
<td>CHAIN7 B2B</td>
</tr>
<tr>
<td>27-20</td>
<td>CHAIN7 HWTS</td>
</tr>
<tr>
<td>19-16</td>
<td>CHAIN7 CSEL</td>
</tr>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td>14-13</td>
<td>CHAIN6 IE</td>
</tr>
<tr>
<td>12</td>
<td>CHAIN6 B2B</td>
</tr>
<tr>
<td>11-4</td>
<td>CHAIN6 HWTS</td>
</tr>
<tr>
<td>3-0</td>
<td>CHAIN6 CSEL</td>
</tr>
</tbody>
</table>
67.5.1.12  ETC_TRIG Result Data 1/0 Register (TRIG0_RESULT_1_0 - TRIG7_RESULT_1_0)

67.5.1.12.1  Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_RESULT_1_0</td>
<td>28h + (a × 28h)</td>
</tr>
</tbody>
</table>

67.5.1.12.2  Function

This register contains the result data of ETC_TRIG 1/0

67.5.1.12.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

67.5.1.12.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-16 DATA1</td>
<td>Result DATA1</td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-0 DATA0</td>
<td>Result DATA0</td>
</tr>
</tbody>
</table>
67.5.1.13 ETC_TRIG Result Data 3/2 Register (TRIG0_RESULT_3_2 - TRIG7_RESULT_3_2)

67.5.1.13.1 Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_RESULT_3_2</td>
<td>2Ch + (a × 28h)</td>
</tr>
</tbody>
</table>

67.5.1.13.2 Function

This register contains the result data of ETC_TRIG 3/2

67.5.1.13.3 Diagram

![Diagram of the registers with fields and offsets]

67.5.1.13.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-16</td>
<td>Result DATA3</td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-0</td>
<td>Result DATA2</td>
</tr>
</tbody>
</table>
67.5.1.14  ETC_TRIG Result Data 5/4 Register (TRIG0_RESULT_5_4 - TRIG7_RESULT_5_4)

67.5.1.14.1  Offset

For a = 0 to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIGa_RESULT_5_4</td>
<td>30h + (a × 28h)</td>
</tr>
</tbody>
</table>

67.5.1.14.2  Function

This register contains the result data of ETC_TRIG 5/4

67.5.1.14.3  Diagram

<table>
<thead>
<tr>
<th>Bits</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bits</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

67.5.1.14.4  Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td>27-16</td>
<td>Result DATA5</td>
</tr>
<tr>
<td>DATA5</td>
<td></td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>11-0</td>
<td>Result DATA4</td>
</tr>
<tr>
<td>DATA4</td>
<td></td>
</tr>
</tbody>
</table>
67.5.1.15 **ETC_TRIG Result Data 7/6 Register (TRIG0_RESULT_7_6 - TRIG7_RESULT_7_6)**

### 67.5.1.15.1 Offset

For \( a = 0 \) to 7:

<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>TRIG( a )_RESULT_7_6</td>
<td>( 34h + (a \times 28h) )</td>
</tr>
</tbody>
</table>

### 67.5.1.15.2 Function

This register contains the result data of ETC_TRIG 7/6

### 67.5.1.15.3 Diagram

![Diagram of the ETC_TRIG Result Data 7/6 Register](image)

### 67.5.1.15.4 Fields

<table>
<thead>
<tr>
<th>Field</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>31-28</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>27-16</td>
<td>Result DATA7</td>
</tr>
<tr>
<td>DATA7</td>
<td></td>
</tr>
<tr>
<td>15-12</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td>11-0</td>
<td>Result DATA6</td>
</tr>
<tr>
<td>DATA6</td>
<td></td>
</tr>
</tbody>
</table>
Chapter 68
Touch Screen Controller (TSC)

68.1 Chip-specific TSC information

Table 68-1. Reference links to related information

<table>
<thead>
<tr>
<th>Topic</th>
<th>Related module(s)</th>
<th>Reference</th>
</tr>
</thead>
<tbody>
<tr>
<td>System memory map</td>
<td>-</td>
<td>System Memory Map</td>
</tr>
<tr>
<td>Clocking</td>
<td>CCM</td>
<td>Clock Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Clock Control Module (CCM)</td>
</tr>
<tr>
<td>Power management</td>
<td>PMU</td>
<td>Power Management</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Power Management Unit</td>
</tr>
<tr>
<td>Signal multiplexing</td>
<td>IOMUX</td>
<td>External Signals and Pin Multiplexing</td>
</tr>
<tr>
<td></td>
<td></td>
<td>IOMUX</td>
</tr>
<tr>
<td>Interrupts, DMA Events and XBAR Assignments</td>
<td>-</td>
<td>Interrupts, DMA Events and XBAR Assignments</td>
</tr>
</tbody>
</table>

68.2 Overview

This block describes the Touch Screen Controller (TSC), which is used for ADC and touch screen analogue block.

TSC is responsible for providing control of ADC and touch screen analogue block to form a touch screen system, which achieves function of touch detection and touch location detection. The controller utilizes ADC hardware trigger function and control switches in touch screen analogue block. The controller only supports 4-wire of 5-wire screen touch modes.

Figure 68-1. TSC block diagram
68.2.1 Features

The features of TSC controller are following.

- Configure registers: 32-bit, fully support sky-blue bus interface
- 4-wire or 5-wire mode of touch screen
- Low power wake up functions
- ADC average function and custom 8-bit, 10-bit, and 12-bit conversion result
- Custom pre-charge and de-glitch threshold time setting
- Total control five analogue groups of switches
- Fully asynchronous interface to ADC and analogue switches
- Easy software operation
- Software takes control of operation flow
- Strong debug functions—enable software recognize the IP as a transparent box and operation output directly
- Software reset function
68.3 Functional Description

This block works with ADC and TSC analogue to form a touch screen system. The system is responsible to detect touch on screen and measure the coordinate of the touch point. The touch screen controller, which is at the heart of the system, given control to TSC analogue and ADC. TSC analogue provides positive or negative voltage to the screen if the touch screen controller provides relevant signals. The ADC convert coordinates value if requested by touch screen controller.

68.3.1 Operating modes

The TSC can be worked in the following modes.

68.3.1.1 Idle

The TSC always stays at idle status if finish a coordinate measurement. The TSC only starts to detect a touch or starts to measure coordinate value if set the start_sen bit. The TSC returns to idle status after finish current task if disable bit is set by software.

68.3.1.2 Pre-charge

Pre-charge is a preparation for detection stage. Before detection stage, the upper layer of screen is required to charge to positive high. The time required for the pre-charge can be set in the pre-charge_timer.

68.3.1.3 Detection

Detection is a stage to sense touch detect on the screen. This stage is initialed a delay (set by pre-charge_timer) in order to wait enough time for the lower screen layer to achieve even-potential status. After the TSC send out detect enable signal to detect signal from analogue, after receiving the signal, TSC starts to measure coordinates or waiting for the instruction from software according to the value of auto_measure. If auto_measure is set then the TSC automatically measures coordinates after detect a touch. Otherwise TSC
waits for software order after detects a touch (and generates an interrupt). The software can choose to drop the measure (and return back to idle) by setting drop_measure, or start the measure by setting start_measure.

### 68.3.1.4 Measurement

During the measure stage, the TSC hardware gives control to TSC analogue and ADC. No software operation is needed. If requesting average function, do average configuration for ADC.

### 68.3.1.5 Data valid check

After measure the coordinate value, TSC do a touch detects again. If no touch has been detected, then previous measured coordinates’ value is invalid. Otherwise, the measured coordinates’ value is valid.

### 68.3.1.6 Interrupt

Each interrupt provides three software interface bits: interrupt enable, interrupt signal enable, and interrupt signal.

### 68.3.1.7 Reset

The TSC has two resets: ipg_reset_b and sw_rst. The ipg_reset_b reset is a hardware reset, which resets all registers in TSC block. While the sw_rst is a software reset, which resets every register except ips directly access ones.

### 68.3.1.8 Debug mode

The TSC provides fully software control signals. After debug_en has been set, then all TSC outputs will be controlled by software. Software can also observe all TSC inputs through debug interface. Furthermore, the debug registers also provides current state machine states. Software can always check the current hardware state.
68.3.2 Configuration

68.3.2.1 TSC configurations

The following tables provide 4-wire and 5-wire screen touch modes.

Table 68-2. 4-wire screen touch mode

<table>
<thead>
<tr>
<th></th>
<th>wiper</th>
<th>ynlr</th>
<th>ypll</th>
<th>xnur</th>
<th>xpul</th>
</tr>
</thead>
<tbody>
<tr>
<td>X measurement</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
<td>LOW</td>
<td>HIGH</td>
</tr>
<tr>
<td>Y measurement</td>
<td>OFF</td>
<td>LOW</td>
<td>HIGH</td>
<td>OFF</td>
<td>OFF</td>
</tr>
<tr>
<td>Pre-charge</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
<td>HIGH (200K, PULL UP)</td>
<td>HIGH (200K, PULL UP)</td>
</tr>
<tr>
<td>Intermediate</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
<td>HIGH (200K)</td>
</tr>
<tr>
<td>Touch screen detection</td>
<td>OFF</td>
<td>LOW</td>
<td>LOW</td>
<td>OFF</td>
<td>HIGH (200K)</td>
</tr>
</tbody>
</table>

Table 68-3. 5-wire screen touch mode

<table>
<thead>
<tr>
<th></th>
<th>wiper</th>
<th>ynlr</th>
<th>ypll</th>
<th>xnur</th>
<th>xpul</th>
</tr>
</thead>
<tbody>
<tr>
<td>X measurement</td>
<td>OFF</td>
<td>LOW</td>
<td>HIGH</td>
<td>LOW</td>
<td>HIGH</td>
</tr>
<tr>
<td>Y measurement</td>
<td>OFF</td>
<td>LOW</td>
<td>LOW</td>
<td>HIGH</td>
<td>HIGH</td>
</tr>
<tr>
<td>Pre-charge</td>
<td>HIGH (200K, PULL UP)</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
</tr>
<tr>
<td>Intermediate</td>
<td>HIGH (200K)</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
<td>OFF</td>
</tr>
<tr>
<td>Touch screen detection</td>
<td>HIGH (200K)</td>
<td>LOW</td>
<td>LOW</td>
<td>OFF</td>
<td>OFF</td>
</tr>
</tbody>
</table>

1. All other intermediate states switch to OFF.

68.3.2.2 TSC-ADC-TSC analogue configuration

The touch screen controller needs to co-work with ADC and TSC analogue.

The ADC is responsible for analogue value conversion. Following tables show the channels that the ADC used.

Table 68-4. 4-wire screen touch mode

<table>
<thead>
<tr>
<th></th>
<th>Channel 1</th>
<th>Connects to TSC ana YNLR</th>
</tr>
</thead>
<tbody>
<tr>
<td>X measurement</td>
<td>Channel 1</td>
<td>Connects to TSC ana YNLR</td>
</tr>
</tbody>
</table>

Table continues on the next page...
Table 68-4. 4-wire screen touch mode (continued)

<table>
<thead>
<tr>
<th>Y measurement</th>
<th>Channel 3</th>
<th>Connects to TSC ana XNUR</th>
</tr>
</thead>
</table>

Table 68-5. 5-wire screen touch mode

<table>
<thead>
<tr>
<th>X measurement</th>
<th>Channel 0</th>
<th>Connects to TSC ana WIPER</th>
</tr>
</thead>
<tbody>
<tr>
<td>Y measurement</td>
<td>Channel 0</td>
<td>Connects to TSC ana WIPER</td>
</tr>
</tbody>
</table>

68.3.2.3 TSC, TSC analogue and ADC connection

The following table describes the connections among the TSC, TSC analogue, and ADC.

Table 68-6. TSC, TSC analogue and ADC connection

<table>
<thead>
<tr>
<th>TSC controller ports</th>
<th>TSC analogue IP ports</th>
<th>TSC analogue system integration instance Name</th>
<th>ADC Ain ports</th>
</tr>
</thead>
<tbody>
<tr>
<td>wiper_pull_up</td>
<td>pu_en</td>
<td>1</td>
<td>Ain [0]</td>
</tr>
<tr>
<td>wiper-200k_pull_up</td>
<td>pull_up-200k_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>wiper_pull_down</td>
<td>pd_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ynlr_pull_up</td>
<td>pu_en</td>
<td>2</td>
<td>Ain [1]</td>
</tr>
<tr>
<td>ynlr_200k_pull_up</td>
<td>pull_up_200k_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ynlr_pull_down</td>
<td>pd_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ypll_pull_up</td>
<td>pu_en</td>
<td>3</td>
<td>Ain [2]</td>
</tr>
<tr>
<td>ypll_200k_pull_up</td>
<td>pull_up_200k_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ypll_pull_down</td>
<td>pd_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>xnu_r_pull_up</td>
<td>pu_en</td>
<td>4</td>
<td>Ain [3]</td>
</tr>
<tr>
<td>xnu_r_200k_pull_up</td>
<td>pull_up_200k_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>xnu_r_pull_down</td>
<td>pd_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>xpu_l_pull_up</td>
<td>pu_en</td>
<td>5</td>
<td>Ain [4]</td>
</tr>
<tr>
<td>xpu_l_200k_pull_up</td>
<td>pull_up_200k_en</td>
<td></td>
<td></td>
</tr>
<tr>
<td>xpu_l_pull_down</td>
<td>pd_en</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

68.3.2.4 TSC and GPIO

From TSC point of view, it does not care what kinds of PAD used. It can use digital pad or analogue pad.
Table 68-7. The ports used in TSC and GPIO

<table>
<thead>
<tr>
<th>TSC function ports</th>
<th>TSC analogue instance</th>
<th>ADC Ain pin</th>
<th>GPIO ports</th>
</tr>
</thead>
<tbody>
<tr>
<td>wiper</td>
<td>1</td>
<td>Ain [0]</td>
<td>GPIO_AD_B1_11</td>
</tr>
<tr>
<td>ynlr</td>
<td>2</td>
<td>Ain [1]</td>
<td>GPIO_AD_B1_12</td>
</tr>
<tr>
<td>ypll</td>
<td>3</td>
<td>Ain [2]</td>
<td>GPIO_AD_B1_13</td>
</tr>
<tr>
<td>xnur</td>
<td>4</td>
<td>Ain [3]</td>
<td>GPIO_AD_B1_14</td>
</tr>
<tr>
<td>xpul</td>
<td>5</td>
<td>Ain [4]</td>
<td>GPIO_AD_B1_15</td>
</tr>
</tbody>
</table>

**NOTE**

For the PAD used for TSC, make sure the PAD behavior, such as a wire only connects to the Pin and TSC analogue switches.

For the PAD used for GPIO, for example, has a keeper to prevent the GPIO pad working from a wire only connects the Pin and TSC. In such condition, disable keeper when TSC working.

### 68.3.2.5 ADC-TSC co-working

The TSC is designed to work with the ADC. Two IP must work together to achieve the correct functions. The coordinate work includes two steps:

1. TSC starts ADC

   TSC sends two signals: trigger and hardware trigger select signal: HWTS[4:0].

   ADC regards triggers as clock to capture the select signal: HWTS. The details of information about trigger and HWTS is show in the ADC hardware trigger chapter. The TSC hardware makes sure that the HWTS signals ready one clock cycles before sending trigger signals. Make sure that the trigger delay is less than HWTS delay + one clock cycle.

   The TSC send HWTS as in the following table:

<table>
<thead>
<tr>
<th></th>
<th>TSC 4-wire mode</th>
<th>TSC 5-wire mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>x-coordinate measure</td>
<td>HWTS = 5'b01000</td>
<td>HWTS = 5'b10000</td>
</tr>
<tr>
<td>y-coordinate measure</td>
<td>HWTS = 5'b00010</td>
<td>HWTS = 5'b10000</td>
</tr>
</tbody>
</table>
TSC HWTS[4:0] connects to the ADC HWTS[4:0]. The integration change will lead change in driver implementation. On ADC side, HWTS = 1 << x indicates the x logic channel is selected to start hardware ADC conversion. Configure ADC_HCx to configure x logic channel and conversion will store in ADC_Rx.

Each ADC hardware trigger logic channel can be configured to one of many physical channels. The details of the ADC configuration, refer to the ADC hardware trigger chapter. Software driver configures the physical ADC. A sample configuration is shown in the following table.

<table>
<thead>
<tr>
<th></th>
<th>TSC 4-wire mode</th>
<th>TSC 5-wire mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>x-coordinate measure</td>
<td>ADC measures channel 1 or 2, so configure ADC_HC3[ADCH] to 1 or 2.</td>
<td>ADC measure channel 0, so configure ADC_HC[4] to 0.</td>
</tr>
<tr>
<td>y-coordinate measure</td>
<td>ADC measures channel 3 or 4, so configure ADC_HC[1][ADCH] to 3 or 4.</td>
<td>ADC measures channel 0, so configure ADC_HC[4] to 0.</td>
</tr>
</tbody>
</table>

Before TSC starts work, software driver configure ADC_HCx. TSC hardware automatically sends trigger and HWTS at the correct time.

2. ADC sends back converted value and complete signals to TSC. When ADC finishes conversion, the ADC would send a complete signal to TSC. A set of handshake signals between ADC and TSC makes sure that the TSC could receive complete signals, store correct ADC converted value, and clear ADC coco signals at correct order. All parts of this step are automatically done by hardware.

**NOTE**

For different ADC conversion modes, such 8-bit, 10-bit, 12-bit mode, average mode, please configure in ADC registers.

### 68.4 TSC Memory Map/Register Definition

The TSC Memory Map and Register Definition is described in the following section.

#### TSC Memory Map

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400E_0000</td>
<td>Basic Setting (TSC_BASIC_SETTING)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.1/3407</td>
</tr>
<tr>
<td>400E_0010</td>
<td>Pre-charge Time (TSC_PRE_CHARGE_TIME)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.2/3408</td>
</tr>
<tr>
<td>400E_0020</td>
<td>Flow Control (TSC_FLOW_CONTROL)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.3/3408</td>
</tr>
</tbody>
</table>

*Table continues on the next page...*
TSC memory map (continued)

<table>
<thead>
<tr>
<th>Absolute address (hex)</th>
<th>Register name</th>
<th>Width (in bits)</th>
<th>Access</th>
<th>Reset value</th>
<th>Section/page</th>
</tr>
</thead>
<tbody>
<tr>
<td>400E_0030</td>
<td>Measure Value (TSC_MEASURE_VALUE)</td>
<td>32</td>
<td>R</td>
<td>0000_0000h</td>
<td>68.4.4/3409</td>
</tr>
<tr>
<td>400E_0040</td>
<td>Interrupt Enable (TSC_INT_EN)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.5/3410</td>
</tr>
<tr>
<td>400E_0050</td>
<td>Interrupt Signal Enable (TSC_INT_SIG_EN)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.6/3411</td>
</tr>
<tr>
<td>400E_0060</td>
<td>Interrupt Status (TSC_INT_STATUS)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.7/3412</td>
</tr>
<tr>
<td>400E_0070</td>
<td>Debug Mode Register (TSC_DEBUG_MODE)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.8/3414</td>
</tr>
<tr>
<td>400E_0080</td>
<td>Debug Mode Register 2 (TSC_DEBUG_MODE2)</td>
<td>32</td>
<td>R/W</td>
<td>0000_0000h</td>
<td>68.4.9/3416</td>
</tr>
</tbody>
</table>

68.4.1 Basic Setting (TSC_BASIC_SETTING)

Address: 400E_0000h base + 0h offset = 400E_0000h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>WIRE_4_5</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

TSC_BASIC_SETTING field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
</table>
| 31–8 MEASURE_DELAY_TIME | Measure Delay Time  
Before X-axis or Y-axis measurement, the screen need some time before even potential distribution ready. |
| 7–5 Reserved   | This read-only field is reserved and always has the value 0.                  |
| 4 WIRE_4_5     | 4/5 Wire detection  
4-Wire Detection Mode or 5-Wire Detection Mode  
0 4-Wire Detection Mode  
1 5-Wire Detection Mode |
| 3–1 Reserved   | This read-only field is reserved and always has the value 0.                  |

Table continues on the next page...
**TSC_BASIC_SETTING field descriptions (continued)**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>AUTO_MEASURE 0</td>
<td>Auto Measure</td>
</tr>
<tr>
<td></td>
<td>This field indicates after detect touch, whether automatic start measurement. SW must make sure that the detect interrupt should be disable. This bit is not HW self-clear.</td>
</tr>
<tr>
<td>0</td>
<td>Disable Auto Measure</td>
</tr>
<tr>
<td>1</td>
<td>Auto Measure</td>
</tr>
</tbody>
</table>

---

### 68.4.2 Pre-charge Time (TSC_PRE_CHARGE_TIME)

Address: 400E_0000h base + 10h offset = 400E_0010h

| Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|----------------|---------------------------------------------------------------------------------|
| R W PRE_CHARGE_TIME |                                                                                   |
| Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |

**TSC_PRE_CHARGE_TIME field descriptions**

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>PRE_CHARGE_TIME</td>
<td>Before detection, the top screen needs some time before being pulled up to a high voltage.</td>
</tr>
</tbody>
</table>

---

### 68.4.3 Flow Control (TSC_FLOW_CONTROL)

Address: 400E_0000h base + 20h offset = 400E_0020h

---

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019
### TSC_FLOW_CONTROL field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–17</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>16</td>
<td><strong>DISABLE</strong>  &lt;br&gt;This bit is for SW disable registers. After set this bit, the hardware returns to idle status after finish the current state operation. SW must check the SW_IDLE bit to confirm that the controller has return to idle status. It's a HW self-clean bit.  &lt;br&gt;0 Leave HW state machine control  &lt;br&gt;1 SW set to idle status</td>
</tr>
<tr>
<td>15–13</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>12</td>
<td><strong>START_SENSE</strong>  &lt;br&gt;Start Sense  &lt;br&gt;It's a HW self-clean bit.  &lt;br&gt;0 Stay at idle status  &lt;br&gt;1 Start sense detection and (if auto_measure set to 1) measure after detect a touch</td>
</tr>
<tr>
<td>11–9</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>8</td>
<td><strong>DROP_MEASURE</strong>  &lt;br&gt;Drop Measure  &lt;br&gt;This field indicates whether start measure X/Y coordinate value after detect a touch It's a HW self-clean bit.  &lt;br&gt;0 Do not drop measure for now  &lt;br&gt;1 Drop the measure and controller return to idle status</td>
</tr>
<tr>
<td>7–5</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4</td>
<td><strong>START_MEASURE</strong>  &lt;br&gt;Start Measure  &lt;br&gt;This field indicates whether start measure X/Y coordinate value after detect a touch It's a self-clean bit.  &lt;br&gt;0 Do not start measure for now  &lt;br&gt;1 Start measure the X/Y coordinate value</td>
</tr>
<tr>
<td>3–1</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>0</td>
<td><strong>SW_RST</strong>  &lt;br&gt;Soft Reset  &lt;br&gt;This is a synchronization reset, which reset all HW registers.  &lt;br&gt;<strong>NOTE:</strong> All SW accessible registers would keep as it original setting Software reset would be self-clear.</td>
</tr>
</tbody>
</table>

### 68.4.4 Measure Value (TSC_MEASURE_VALUE)

Address: 400E_0000h base + 30h offset = 400E_0030h

<table>
<thead>
<tr>
<th>Bit</th>
<th>R</th>
<th>W</th>
<th>Reset</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>30</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>29</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>28</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>27</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>26</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>25</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>23</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>22</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>21</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>20</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>19</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>18</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>17</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

X_VALUE  <br>Y_VALUE

i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019

NXP Semiconductors 3409
### TSC_MEASURE_VALUE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–28 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 27–16 X_VALUE | X Value  
Coordinate value  
**NOTE:** It is an ADC conversion value, SW need to convert it to fit screen size. |
| 15–12 Reserved | This read-only field is reserved and always has the value 0. |
| 14–13 Y_VALUE | Y Value  
Y coordinate value, note, it is an ADC conversion value, SW need to convert it to fit screen size |

### 68.4.5 Interrupt Enable (TSC_INT_EN)

Address: 400E_0000h base + 40h offset = 400E_0040h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### TSC_INT_EN field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–13 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 12 IDLE_SW_INT_EN | Idle Software Interrupt Enable  
This field indicates whether enable the software return to idle status interrupt. This interrupt is generated if the controller has return to idle status. This bit is only valid if disable bit in flow control register set to 1'b1.  
0: Disable idle software interrupt  
1: Enable idle software interrupt |

*Table continues on the next page...*
TSC_INT_EN field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11–5 Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4 DETECT_INT_EN</td>
<td>Detect Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether enable the detect interrupt. This interrupt is generated if there is a touch detect after pre-charge ready.</td>
</tr>
<tr>
<td>0</td>
<td>Disable detect interrupt</td>
</tr>
<tr>
<td>1</td>
<td>Enable detect interrupt</td>
</tr>
<tr>
<td>3–1 Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>0 MEASURE_INT_EN</td>
<td>Measure Interrupt Enable</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether enable the measure interrupt. This interrupt is generated after the touch detection which follows measurement.</td>
</tr>
<tr>
<td>0</td>
<td>Disable measure interrupt</td>
</tr>
<tr>
<td>1</td>
<td>Enable measure interrupt</td>
</tr>
</tbody>
</table>

68.4.6 Interrupt Signal Enable (TSC_INT_SIG_EN)

Address: 400E_0000h base + 50h offset = 400E_0050h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

TSC_INT_SIG_EN field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–13 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
### TSC_INT_SIG_EN field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12 IDLE_SW_SIG_EN</td>
<td>Idle Software Signal Enable</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether enable the software return to idle status. This signal is generated if the controller has return to idle status. This bit is only valid if disable bit in flow control register set to 1'b1.</td>
</tr>
<tr>
<td>0</td>
<td>Disable idle software signal</td>
</tr>
<tr>
<td>1</td>
<td>Enable idle software signal</td>
</tr>
<tr>
<td>11–9 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>8 VALID_SIG_EN</td>
<td>Valid Signal Enable</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether enable the valid signal. This field generated at the same time with MEASURE_SIG_EN.</td>
</tr>
<tr>
<td>0</td>
<td>Disable valid signal</td>
</tr>
<tr>
<td>1</td>
<td>Enable valid signal</td>
</tr>
<tr>
<td>7–5 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>4 DETECT_SIG_EN</td>
<td>Detect Signal Enable</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether enable the detect signal.</td>
</tr>
<tr>
<td>0</td>
<td>Disable detect signal</td>
</tr>
<tr>
<td>1</td>
<td>Enable detect signal</td>
</tr>
<tr>
<td>3–1 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
<tr>
<td>0 MEASURE_SIG_EN</td>
<td>Measure Signal Enable</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether enable the measure signal.</td>
</tr>
</tbody>
</table>

### 68.4.7 Interrupt Status (TSC_INT_STATUS)

Address: 400E_0000h base + 60h offset = 400E_0060h

![interrupt status diagram]
# TSC_INT_STATUS field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–13</td>
<td>Reserved, always has the value 0.</td>
</tr>
<tr>
<td>12</td>
<td>IDLE_SW</td>
</tr>
<tr>
<td></td>
<td>Idle Software</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether the state machine returns to idle status. This signal is generated if the controller has return to idle status. This bit is only valid if disable bit in flow control register set to 1'b1.</td>
</tr>
<tr>
<td></td>
<td>0 Haven't return to idle status</td>
</tr>
<tr>
<td></td>
<td>1 Already return to idle status</td>
</tr>
<tr>
<td>11–9</td>
<td>Reserved, always has the value 0.</td>
</tr>
<tr>
<td>8</td>
<td>VALID</td>
</tr>
<tr>
<td></td>
<td>Valid Signal</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether the measure value is valid. This field generated at the same time with MEASURE_SIG.</td>
</tr>
<tr>
<td></td>
<td>0 There is no touch detected after measurement, indicates that the measured value is not valid</td>
</tr>
<tr>
<td></td>
<td>1 There is touch detection after measurement, indicates that the measure is valid</td>
</tr>
<tr>
<td>7–5</td>
<td>Reserved, always has the value 0.</td>
</tr>
<tr>
<td>4</td>
<td>DETECT</td>
</tr>
<tr>
<td></td>
<td>Detect Signal</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether there is a detect signal.</td>
</tr>
<tr>
<td></td>
<td>0 Does not exist a detect signal</td>
</tr>
<tr>
<td></td>
<td>1 Exist detect signal</td>
</tr>
<tr>
<td>3–1</td>
<td>Reserved, always has the value 0.</td>
</tr>
<tr>
<td>0</td>
<td>MEASURE</td>
</tr>
<tr>
<td></td>
<td>Measure Signal</td>
</tr>
<tr>
<td></td>
<td>This field indicates whether there is a measure signal.</td>
</tr>
<tr>
<td></td>
<td>0 Does not exist a measure signal</td>
</tr>
<tr>
<td></td>
<td>1 Exist a measure signal</td>
</tr>
</tbody>
</table>
### 68.4.8 Debug Mode Register (TSC_DEBUG_MODE)

Address: 400E_0000h base + 70h offset = 400E_0070h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Reset:** 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

#### Debug Mode Register (TSC_DEBUG_MODE)

- **DEBUG_EN**: Register enable bit (0 = disabled, 1 = enabled)
- **ADC_COCO_CLEAR_DISABLE**: ADC COCO clear disable bit (0 = enabled, 1 = disabled)
- **ADC_COCO_CLEAR**: ADC COCO clear bit (0 = clear, 1 = not cleared)
- **TRIGGER**: Trigger bit (0 = no trigger, 1 = trigger)
- **EXT_HWTS**: External hardware trigger source

#### ADC Mode Register (TSC_ADC_MODE)

- **ADC_COCO**: ADC COCO bit (0 = valid, 1 = not valid)
- **ADC_CONV_VALUE**: ADC conversion value

---

**i.MX RT1060 Processor Reference Manual, Rev. 2, 12/2019**

3414

NXP Semiconductors
## TSC_DEBUG_MODE field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31–29 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 28 DEBUG_EN | Debug Enable  
The RO registers in debug_mode and debug_mode2 always reflect the latest value and is not controlled by this bit. All RW SW bits are controlled by this bit.  
0 Enable debug mode  
1 Disable debug mode |
| 27 Reserved | This read-only field is reserved and always has the value 0. |
| 26 ADC_COCO_CLEAR_DISABLE | ADC COCO Clear Disable  
This bit could prevent TSC HW generates an ADC COCO clear signal.  
**NOTE:** This bit does not effect ADC_COCO_CLEAR bit.  
0 Allow TSC hardware generates ADC COCO clear  
1 Prevent TSC from generate ADC COCO clear signal |
| 25 ADC_COCO_CLEAR | ADC Coco Clear  
Original ADC coco only clear is system read conv result from IPS bus. However, TSC read conv result directly from ADC to lower SW load, so that ADC requires TSC generates a clear signal.  
0 No ADC COCO clear  
1 Set ADC COCO clear |
| 24 TRIGGER | Trigger  
Hardware trigger signal to ADC  
0 No hardware trigger signal  
1 Hardware trigger signal, the signal must last at least 1 ips clock period |
| 23–21 Reserved | This read-only field is reserved and always has the value 0. |
| 20–16 EXT_HWTS | Hardware Trigger Select Signal  
Hardware trigger select signal, select which channel to start conversion. |
| 15–13 Reserved | This read-only field is reserved and always has the value 0. |
| 12 ADC_COCO | ADC COCO Signal  
This signal is generated by ADC. |
| ADC_CONV_VALUE | ADC Conversion Value  
This signal is generated by ADC. |
### 68.4.9 Debug Mode Register 2 (TSC_DEBUG_MODE2)

Address: 400E_0000h base + 80h offset = 400E_0080h

<table>
<thead>
<tr>
<th>Bit</th>
<th>31</th>
<th>30</th>
<th>29</th>
<th>28</th>
<th>27</th>
<th>26</th>
<th>25</th>
<th>24</th>
<th>23</th>
<th>22</th>
<th>21</th>
<th>20</th>
<th>19</th>
<th>18</th>
<th>17</th>
<th>16</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Bit</th>
<th>15</th>
<th>14</th>
<th>13</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### Bit Definitions
- **DE_GLITCH**: Debug mode state machine detection for glitch
- **DETECT_ENABLE_FIVE_WIRE**: Enable detect state machine for five wire mode
- **DETECT_ENABLE_FOUR_WIRE**: Enable detect state machine for four wire mode
- **STATE_MACHINE**: State machine control
- **DETECT_FIVE_WIRE**: Detect state for five wire mode
- **DETECT_FOUR_WIRE**: Detect state for four wire mode
- **WIPER_200K_PULL_UP**: Wiper pull-up with 200k resistor
- **WIPER_PULL_UP**: Wiper pull-up without resistor
- **WIPER_PULL_DOWN**: Wiper pull-down without resistor
- **YNLR_200K_PULL_UP**: YNLR pull-up with 200k resistor
- **YNLR_PULL_UP**: YNLR pull-up without resistor
- **YNLR_PULL_DOWN**: YNLR pull-down without resistor
- **YPLL_200K_PULL_UP**: YPLL pull-up with 200k resistor
- **YPLL_PULL_UP**: YPLL pull-up without resistor
- **YPLL_PULL_DOWN**: YPLL pull-down without resistor
- **XNUR_200K_PULL_UP**: XNUR pull-up with 200k resistor
- **XNUR_PULL_UP**: XNUR pull-up without resistor
- **XNUR_PULL_DOWN**: XNUR pull-down without resistor
- **XPUL_200K_PULL_UP**: XPUL pull-up with 200k resistor
- **XPUL_PULL_UP**: XPUL pull-up without resistor
- **XPUL_PULL_DOWN**: XPUL pull-down without resistor
## TSC_DEBUG_MODE2 field descriptions

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>31 Reserved</td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>
| 30–29 DE_GLITCH | This field indicates glitch threshold. The threshold is defined by number of clock cycles. A detect signal is only valid if it is exist longer than threshold. Any signal transfer through detect and length is smaller than threshold is regards as a glitch.  
00  
- Normal function: 0x1ff ipg clock cycles;  
- Low power mode: 0x9 low power clock cycles  
01  
- Normal function: 0xff ipg clock cycles;  
- Low power mode: 0x7 low power clock cycles  
10  
- Normal function: 0x7ff ipg clock cycles;  
- Low power mode: 0x5 low power clock cycles  
11  
- Normal function: 0x3 ipg clock cycles;  
- Low power mode: 0x3 low power clock cycles |
| 28 DETECT_ENABLE_FIVE_WIRE | Detect Enable Five Wire  
0  
- Do not read five wire detect value, read default value from analogue  
1  
- Read five wire detect status from analogue |
| 27–25 Reserved | This read-only field is reserved and always has the value 0. |
| 24 DETECT_ENABLE_FOUR_WIRE | Detect Enable Four Wire  
0  
- Do not read four wire detect value, read default value from analogue  
1  
- Read four wire detect status from analogue |
| 23 INTERMEDIATE | Intermediate State  
It’s an intermediate state, between two state machine states, in order to provide better timing for analogue.  
It lasts for only one cycle. Intermediate state exists after pre-charge, detect, x-measure, y-measure, and 2nd-pre-charge, 2nd-detect. Note, the intermediate after pre-charge and 2nd-pre-charge is different.  
0  
- Not in intermediate  
1  
- Intermediate |
| 22–20 STATE_MACHINE | State Machine  
000  
- Idle  
001  
- Pre-charge  
010  
- Detect  
011  
- X-measure  
100  
- Y-measure  
101  
- Pre-charge  
110  
- Detect |
| 19–18 Reserved | This read-only field is reserved and always has the value 0. |
| 17 DETECT_FIVE_WIRE | Detect Five Wire  
This field in only valid when the touch controller is under detect mode. That is not in idle.  
NOTE: It is in measure mode, not pre-charge mode. This is an asynchronous signal.  
Table continues on the next page...
### TSC_DEBUG_MODE2 field descriptions (continued)

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>No detect signal</td>
</tr>
<tr>
<td>1</td>
<td>Yes, there is a detect on the touch screen.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16</td>
<td>DETECT_FOUR_WIRE</td>
</tr>
<tr>
<td></td>
<td>Detect Four Wire</td>
</tr>
<tr>
<td></td>
<td>This field is only valid when the touch controller is under detect mode. That is not in idle.</td>
</tr>
<tr>
<td></td>
<td><strong>NOTE:</strong> It is in measure mode, not pre-charge mode. This is an asynchronous signal.</td>
</tr>
<tr>
<td>0</td>
<td>No detect signal</td>
</tr>
<tr>
<td>1</td>
<td>Yes, there is a detect on the touch screen.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
</tr>
<tr>
<td></td>
<td>This read-only field is reserved and always has the value 0.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>14</td>
<td>WIPER_200K_PULL_UP</td>
</tr>
<tr>
<td></td>
<td>Wiper Wire 200K Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this wiper wire 200k pull up switch.</td>
</tr>
<tr>
<td>0</td>
<td>Close the switch</td>
</tr>
<tr>
<td>1</td>
<td>Open up the switch</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>13</td>
<td>WIPER_PULL_UP</td>
</tr>
<tr>
<td></td>
<td>Wiper Wire Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this switch.</td>
</tr>
<tr>
<td>0</td>
<td>Close the switch</td>
</tr>
<tr>
<td>1</td>
<td>Open up the switch</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>12</td>
<td>WIPER_PULL_DOWN</td>
</tr>
<tr>
<td></td>
<td>Wiper Wire Pull Down Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this wiper wire pull down switch.</td>
</tr>
<tr>
<td>0</td>
<td>Close the switch</td>
</tr>
<tr>
<td>1</td>
<td>Open up the switch</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>YNLR_200K_PULL_UP</td>
</tr>
<tr>
<td></td>
<td>YNLR Wire 200K Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this YNLR wire 200K pull up switch.</td>
</tr>
<tr>
<td>0</td>
<td>Close the switch</td>
</tr>
<tr>
<td>1</td>
<td>Open up the switch</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>YNLR_PULL_UP</td>
</tr>
<tr>
<td></td>
<td>YNLR Wire Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this YNLR wire pull up switch.</td>
</tr>
<tr>
<td>0</td>
<td>Close the switch</td>
</tr>
<tr>
<td>1</td>
<td>Open up the switch</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>9</td>
<td>YNLR_PULL_DOWN</td>
</tr>
<tr>
<td></td>
<td>YNLR Wire Pull Down Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this YNLR wire pull down switch.</td>
</tr>
<tr>
<td>0</td>
<td>Close the switch</td>
</tr>
<tr>
<td>1</td>
<td>Open up the switch</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>YPLL_200K_PULL_UP</td>
</tr>
<tr>
<td></td>
<td>YPLL Wire 200K Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this YPLL wire 200k pull up switch.</td>
</tr>
</tbody>
</table>

Table continues on the next page...
<table>
<thead>
<tr>
<th>Field</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Close the switch</td>
</tr>
<tr>
<td>1</td>
<td>Open up the switch</td>
</tr>
<tr>
<td>7 YPLL_PULL_UP</td>
<td>YPLL Wire Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this YPLL wire pull up switch.</td>
</tr>
<tr>
<td>6 YPLL_PULL_DOWN</td>
<td>YPLL Wire Pull Down Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this YPLL wire pull down switch.</td>
</tr>
<tr>
<td>5 XNUR_200K_PULL_UP</td>
<td>XNUR Wire 200K Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this XNUR wire 200K pull up switch.</td>
</tr>
<tr>
<td>4 XNUR_PULL_UP</td>
<td>XNUR Wire Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this XNUR Wire Pull Up Switch.</td>
</tr>
<tr>
<td>3 XNUR_PULL_DOWN</td>
<td>XNUR Wire Pull Down Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this XNUR Wire Pull Down Switch.</td>
</tr>
<tr>
<td>2 XPUL_200K_PULL_UP</td>
<td>XPUL Wire 200K Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this XPUL Wire 200K pull up switch.</td>
</tr>
<tr>
<td>1 XPUL_PULL_UP</td>
<td>XPUL Wire Pull Up Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this XPUL Wire Pull Up Switch.</td>
</tr>
<tr>
<td>0 XPUL_PULL_DOWN</td>
<td>XPUL Wire Pull Down Switch</td>
</tr>
<tr>
<td></td>
<td>This is a control signal of this XPUL wire pull down switch.</td>
</tr>
</tbody>
</table>
Appendix A
Revision History

The following table provides a revision history for this document.

<table>
<thead>
<tr>
<th>Rev. No.</th>
<th>Date</th>
<th>Substantial Changes</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>08/2018</td>
<td>Initial public release.</td>
</tr>
<tr>
<td>1</td>
<td>12/2018</td>
<td>Major revision upgrade: updates in several chapters, see &quot;Change summary&quot; in this specific revision for more details.</td>
</tr>
<tr>
<td>2</td>
<td>12/2019</td>
<td>Major revision upgrade: updates in several chapters, see &quot;Substantive changes&quot; below for more details.</td>
</tr>
</tbody>
</table>
Appendix B
Substantive changes for this revision

Substantive changes for this revision are as follows:

B.1 About this Document Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Suggested Reading</td>
<td>“About this document” chapter is optimized and split from “Introduction” chapter, as Chapter 1.</td>
</tr>
</tbody>
</table>

B.2 Introduction Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Block Diagram</td>
<td>Clarified GPIO1-5 as standard GPIOs and GPIO6-9 as high-speed GPIOs in the block diagram.</td>
</tr>
<tr>
<td>Features</td>
<td>Updated the “Features” section.</td>
</tr>
</tbody>
</table>

B.3 Memory Maps Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Arm Platform Memory Map</td>
<td>Minor updates in the “AIPS-1 memory map” table.</td>
</tr>
</tbody>
</table>
### B.4 Interrupts, DMA Events, and XBAR Assignments Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CM7 interrupts</td>
<td>New note added before the table “CM7 domain interrupt summary”.</td>
</tr>
<tr>
<td>PIT Channel Assignments For Periodic DMA Triggering</td>
<td>Added a new section “PIT Channel Assignments for Periodic DMA Triggering”.</td>
</tr>
<tr>
<td>XBAR Resource Assignments</td>
<td>Minor updates in the QTIMER rows of the table “XBAR1 Output Assignments”.</td>
</tr>
</tbody>
</table>

### B.5 DMA MUX Revision History

No substantive changes

### B.6 eDMA Revision History

No substantive changes

### B.7 System Security Revision History

Minor updates in this security overview chapter.

### B.8 System Debug Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Coresight Embedded Trace Buffer (ETB)</td>
<td>Some correction: section “Coresight Embedded Trace Buffer (ETB)” added back, and the section “Supported tools” removed.</td>
</tr>
</tbody>
</table>
B.9 System Boot Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip-specific Boot Information</td>
<td>• Updated the table “ROM Bootloader Peripheral PinMux”.</td>
</tr>
<tr>
<td></td>
<td>• Extra notes added after the table “ROM Clock Setting”.</td>
</tr>
<tr>
<td>Boot eFUSE descriptions</td>
<td>Minor updates in the table “Boot eFUSE descriptions”.</td>
</tr>
<tr>
<td>Boot devices</td>
<td>Notes added after the table “Boot device selection”.</td>
</tr>
<tr>
<td>Serial NOR eFUSE Configuration</td>
<td>Minor updates in the table “Fuse definition for Serial NOR over FlexSPI”.</td>
</tr>
<tr>
<td>FlexSPI Serial NOR Flash Boot Operation</td>
<td>Note added in the section “FlexSPI Serial NOR Flash Boot Operation”.</td>
</tr>
<tr>
<td>Firmware Configuration Block</td>
<td>Minor updates in the table “Flash Control Block Structure”.</td>
</tr>
<tr>
<td>Expansion device eFUSE configuration</td>
<td>Updated the table “uSDHC eFuse Descriptions”.</td>
</tr>
<tr>
<td>Serial NOR/EEPROM eFUSE configuration</td>
<td>Minor updates in the table “Serial NOR/EEPROM boot eFUSE descriptions”.</td>
</tr>
<tr>
<td>Image vector table structure</td>
<td>Note added after the “IVT format” table.</td>
</tr>
<tr>
<td>Write data command</td>
<td>New table “Valid DCD address ranges” added in the section “Write data command”.</td>
</tr>
<tr>
<td>-</td>
<td>Removed the section “Unlock command”, which is not customer-facing content.</td>
</tr>
</tbody>
</table>

B.10 External Signals and Pin Multiplexing Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Muxing Options</td>
<td>Updated the FlexSPI2 rows, in the “Muxing Options” table.</td>
</tr>
</tbody>
</table>

B.11 IOMUXC Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>IOMUXC Memory Map/Register Definition</td>
<td>• Some descriptions updated in the IOMUXC register parts.</td>
</tr>
<tr>
<td></td>
<td>• SW_MUX_CTL_PAD_GPIO_SPI_xx related registers removed, which are not applicable in this device.</td>
</tr>
</tbody>
</table>
B.12  GPIO Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip-specific GPIO information</td>
<td>Clarified high-speed GPIOs (GPIO6-9) in the “Chip-specific GPIO information” section.</td>
</tr>
<tr>
<td>Operating Frequency</td>
<td>Added the table “IO Operating Frequency”.</td>
</tr>
</tbody>
</table>

B.13  Clock and Power Management Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>System domains layout</td>
<td>Updated the table “Low Power Mode Definition”.</td>
</tr>
</tbody>
</table>

B.14  CCM Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>External Signals</td>
<td>CCM_REF_EN_B row added in the “CCM External Signals” table.</td>
</tr>
<tr>
<td>CCM Clock Tree</td>
<td>Note added after the “Clock Tree - Part 2” figure.</td>
</tr>
<tr>
<td>System Clocks</td>
<td>Updated the “System Clock Frequency Values” table.</td>
</tr>
<tr>
<td>System PLL (PLL2)</td>
<td>Updated the section “System PLL (PLL2)”.</td>
</tr>
</tbody>
</table>

B.15  XTALOSC Revision History

No substantive changes

B.16  PMU Revision History

Removed the “Digital LDO Regulators” section, which is not applicable in the device.

B.17  GPC Revision History

No substantive changes
B.18  DCDC Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Memory Map and register definition</td>
<td>• In REG1, clarified VBG_TRIM, LOOPCTRL_HST_THRESH, REG_FBK_SEL bitfields.</td>
</tr>
<tr>
<td></td>
<td>• In REG2, clarified DCM_SET_CTRL, DISABLE_PULSE_SKIP bitfields. LOOPCTRL_DC_R and LOOPCTRL_DC_C bitfields now for internal audience only.</td>
</tr>
<tr>
<td></td>
<td>• In REG3, MISC_DISABLEFET_LOGIC and MISC_DELAY_TIMING are now reserved bitfields.</td>
</tr>
<tr>
<td></td>
<td>• Added a cross reference to CUR_SNS_THRSH in the CURRENT_ALERT_RESET bitfield.</td>
</tr>
</tbody>
</table>

B.19  TEMPMON Revision History

No substantive changes

B.20  SNVS Revision History

No substantive changes

B.21  SRC Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRC</td>
<td>Updated the SRC_GPR10 register.</td>
</tr>
</tbody>
</table>

B.22  Fusemap Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Boot Fusemap</td>
<td>Updated the table “FlexSPI (Serial NOR) boot fusemap”.</td>
</tr>
<tr>
<td>Fusemap Descriptions Table</td>
<td>Minor updates in the table “Fusemap Descriptions”.</td>
</tr>
</tbody>
</table>
B.23  OCOTP Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Latest content included, e.g. the section “OTP Read/Write Timing Parameters” refreshed.</td>
</tr>
</tbody>
</table>

B.24  External Memory Controllers Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
</table>
| Smart External Memory Controller (SEMC) Overview | Minor updates in this overview chapter, for example:  
  • NOR Flash and SRAM interface only supports 16-bit mode.  
  • High Function Block Diagram removed since the SEMC Chapter already has a block diagram. |

B.25  SEMC Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip-specific SEMC information</td>
<td>Note added in the chip-specific SEMC info section.</td>
</tr>
<tr>
<td>-</td>
<td>Latest content included, e.g. some info clarified, also new sections “NOR Flash address map” and “SRAM Flash address map” added.</td>
</tr>
</tbody>
</table>

B.26  USDHC Revision History

No substantive changes

B.27  FlexSPI Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Latest content included, with some info clarified.</td>
</tr>
</tbody>
</table>
B.28  Arm Cortex M7 Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip-specific Arm Cortex M7 information</td>
<td>Added information that there are 16 regions implemented in the MPU.</td>
</tr>
<tr>
<td></td>
<td>Added list of CoreSight components and their corresponding Arm documents.</td>
</tr>
</tbody>
</table>

B.29  NIC Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Memory Map and Register Definition</td>
<td>In the SIM_M registers table, fn_mod2 description corrected.</td>
</tr>
</tbody>
</table>

B.30  OCRAM Revision History

No substantive changes

B.31  FlexRAM Revision History

No substantive changes

B.32  AIPSTZ Revision History

No substantive changes

B.33  Display and Camera Overview Revision History

No substantive changes
### B.34 CSI Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>External Signals</td>
<td>Added note that the csi_hclk needs to be at least 10% faster than the pixel clock.</td>
</tr>
</tbody>
</table>

### B.35 eLCDIF Revision History

No substantive changes

### B.36 PXP Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Porter-Duff Alpha Blend</td>
<td>Formula added for image output and alpha output, in the section &quot;Porter-Duff Alpha Blend&quot;.</td>
</tr>
</tbody>
</table>

### B.37 Audio Overview Revision History

No substantive changes

### B.38 SAI Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Chip-specific SAI information</td>
<td>Note added in the &quot;Chip-specific SAI information&quot; section.</td>
</tr>
</tbody>
</table>
| -                      | • Latest content included, with some info clarified.  
|                        | • The section "FIFO Combine" added back; also corrected the Data Register and FIFO Register numbers, as the number of TX and RX data lines for SAI1 and SAI2/SAI3 are 4 and 1 respectively. |

### B.39 MQS Revision History

No substantive changes
B.40  SPDIF Revision History
No substantive changes

B.41  ENET Revision History
No substantive changes

B.42  USB Revision History
No substantive changes

B.43  USB PHY Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB Analog Memory Map/Register Definition</td>
<td>Minor correction: USB_LOOPBACK registers added in the &quot;USB_ANALOG memory map&quot; section.</td>
</tr>
</tbody>
</table>

B.44  FLEXCAN Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>External Signals</td>
<td>Minor correction in the RX and TX rows of the “FLEXCAN External Signals” table.</td>
</tr>
</tbody>
</table>

B.45  CANFD/FlexCAN3 Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Latest content included, corrected parameter settings (some contents not applicable to this device).</td>
</tr>
</tbody>
</table>
B.46 KPP Revision History
No substantive changes

B.47 LPI2C Revision History
No substantive changes

B.48 LPSPI Revision History
No substantive changes

B.49 LPUART Revision History
No substantive changes

B.50 FlexIO Revision History
No substantive changes

B.51 Timers Overview Revision History
No substantive changes

B.52 GPT Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>External Signals</td>
<td>Corrected the “GPT External Signals” table.</td>
</tr>
</tbody>
</table>

B.53 PIT Revision History
No substantive changes
B.54  TMR Revision History
No substantive changes

B.55  FlexPWM Revision History
No substantive changes

B.56  ENC Revision History
No substantive changes

B.57  WDOG1-2 Revision History
No substantive changes

B.58  RTWDOG/WDOG3 Revision History
No substantive changes

B.59  EWM Revision History
No substantive changes

B.60  On Chip Cross Triggers Overview Revision History
No substantive changes
**B.61  XBAR A Revision History**
No substantive changes

**B.62  XBAR B Revision History**
No substantive changes

**B.63  AOI Revision History**
No substantive changes

**B.64  Analog Overview Revision History**
No substantive changes

**B.65  ACMP Revision History**
No substantive changes

**B.66  ADC Revision History**

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Features</td>
<td>Number of external analog inputs to &quot;Up to 16 single-ended external analog inputs.&quot;</td>
</tr>
<tr>
<td>Memory map and register definition</td>
<td>Added cross-reference to the external signals section to the ADCH bitfield in the ADCx_HCn register description.</td>
</tr>
<tr>
<td></td>
<td>Corrected the ADSTS bitfield in the ADCx_CFG register description.</td>
</tr>
</tbody>
</table>
B.67 ADC_ETC Revision History

<table>
<thead>
<tr>
<th>Topic Cross-Reference</th>
<th>Change Description</th>
</tr>
</thead>
</table>
| -                     | Latest content included:  
|                       | • Minor clarifications/re-wording throughout the chapter.  
|                       | • Formatting changes of the Memory Map and Register descriptions to condense the content. |

B.68 TSC Revision History

No substantive changes
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.

While NXP has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EMBRACE, GREENCHIP, HITAG, I2C BUS, 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, AltVec, C-5, CodeTEST, CodeWarrior, ColdFire, ColdFire+, C-Ware, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QoriQ, QoriQ Converge, Ready Play, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybird, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, SMARTMOS, Tower, TurboLink, UMEMS, eIQ, Immersiv3D, EdgeLock, and EdgeScale 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-PPLUS, 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.

© 2018–2019 NXP B.V.