



**AN0400**

## **Ameba-D Application Note**

---



Realtek Semiconductor Corp.  
No. 2, Innovation Road II, Hsinchu Science Park, Hsinchu 300, Taiwan  
Tel.: +886-3-578-0211, Fax: +886-3-577-6047  
[www.realtek.com](http://www.realtek.com)

## COPYRIGHT

©2019 Realtek Semiconductor Corp. All rights reserved. No part of this document may be reproduced, transmitted, transcribed, stored in a retrieval system, or translated into any language in any form or by any means without the written permission of Realtek Semiconductor Corp.

## DISCLAIMER

### Please Read Carefully:

Realtek Semiconductor Corp., (Realtek) reserves the right to make corrections, enhancements, improvements and other changes to its products and services. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and complete.

Reproduction of significant portions in Realtek data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Realtek is not responsible or liable for such reproduced documentation. Information of third parties may be subject to additional restrictions.

Buyers and others who are developing systems that incorporate Realtek products (collectively, "Customers") understand and agree that Customers remain responsible for using their independent analysis, evaluation and judgment in designing their applications and that Customers have full and exclusive responsibility to assure the safety of Customers' applications and compliance of their applications (and of all Realtek products used in or for Customers' applications) with all applicable regulations, laws and other applicable requirements. Designer represents that, with respect to their applications, Customer has all the necessary expertise to create and implement safeguards that (1) anticipate dangerous consequences of failures, (2) monitor failures and their consequences, and (3) lessen the likelihood of failures that might cause harm and take appropriate actions. Customer agrees that prior to using or distributing any applications that include Realtek products, Customer will thoroughly test such applications and the functionality of such Realtek products as used in such applications.

Realtek's provision of technical, application or other design advice, quality characterization, reliability data or other services or information, including, but not limited to, reference designs and materials relating to evaluation kits, (collectively, "Resources") are intended to assist designers who are developing applications that incorporate Realtek products; by downloading, accessing or using Realtek's Resources in any way, Customer (individually or, if Customer is acting on behalf of a company, Customer's company) agrees to use any particular Realtek Resources solely for this purpose and subject to the terms of this Notice.

Realtek's provision of Realtek Resources does not expand or otherwise alter Realtek's applicable published warranties or warranty disclaimers for Realtek's products, and no additional obligations or liabilities arise from Realtek providing such Realtek Resources. Realtek reserves the right to make corrections, enhancements, improvements and other changes to its Realtek Resources. Realtek has not conducted any testing other than that specifically described in the published documentation for a particular Realtek Resource.

Customer is authorized to use, copy and modify any individual Realtek Resource only in connection with the development of applications that include the Realtek product(s) identified in such Realtek Resource. No other license, express or implied, by estoppel or otherwise to any other Realtek intellectual property right, and no license to any technology or intellectual property right of Realtek or any third party is granted herein, including but not limited to any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which Realtek products or services are used. Information regarding or referencing third-party products or services does not constitute a license to use such products or services, or a warranty or endorsement thereof. Use of Realtek Resources may require a license from a third party under the patents or other intellectual property of the third party, or a license from Realtek under the patents or other Realtek's intellectual property.

Realtek's Resources are provided "as is" and with all faults. Realtek disclaims all other warranties or representations, express or implied, regarding resources or use thereof, including but not limited to accuracy or completeness, title, any epidemic failure warranty and any implied warranties of merchantability, fitness for a particular purpose, and non-infringement of any third party intellectual property rights.

Realtek shall not be liable for and shall not defend or indemnify Customer against any claim, including but not limited to any infringement claim that related to or is based on any combination of products even if described in Realtek Resources or otherwise. In no event shall Realtek be liable for any actual, direct, special, collateral, indirect, punitive, incidental, consequential or exemplary damages in connection with or arising out of Realtek's Resources or use thereof, and regardless of whether Realtek has been advised of the possibility of such damages. Realtek is not responsible for any failure to meet such industry standard requirements.

Where Realtek specifically promotes products as facilitating functional safety or as compliant with industry functional safety standards, such products are intended to help enable customers to design and create their own applications that meet applicable functional safety standards and requirements. Using products in an application does not by itself establish any safety features in the application. Customers must ensure compliance with safety-related requirements and standards applicable to their applications. Designer may not use any Realtek products in life-critical medical equipment unless authorized officers of the parties have executed a special contract specifically governing such use. Life-critical medical equipment is medical equipment where failure of such equipment would cause serious bodily injury or death. Such equipment includes, without limitation, all medical devices identified by the U.S.FDA as Class III devices and equivalent classifications outside the U.S.

Customers agree that it has the necessary expertise to select the product with the appropriate qualification designation for their applications and that proper product selection is at Customers' own risk. Customers are solely responsible for compliance with all legal and regulatory requirements in connection with such selection.

Customer will fully indemnify Realtek and its representatives against any damages, costs, losses, and/or liabilities arising out of Designer's non-compliance with the terms and provisions of this Notice.

#### TRADEMARKS

Realtek is a trademark of Realtek Semiconductor Corporation. Other names mentioned in this document are trademarks/registered trademarks of their respective owners.

#### USING THIS DOCUMENT

Though every effort has been made to ensure that this document is current and accurate, more information may have become available subsequent to the production of this guide.

# Contents

|                                              |           |
|----------------------------------------------|-----------|
| <b>Contents.....</b>                         | <b>4</b>  |
| <b>List of Tables.....</b>                   | <b>12</b> |
| <b>List of Figures .....</b>                 | <b>14</b> |
| <b>1 Build Environment Setup.....</b>        | <b>18</b> |
| 1.1 Introduction.....                        | 18        |
| 1.2 Setup GCC Environment .....              | 18        |
| 1.2.1 Windows.....                           | 18        |
| 1.2.2 Linux .....                            | 19        |
| 1.3 Build Code.....                          | 20        |
| 1.3.1 Normal Image.....                      | 20        |
| 1.3.2 MP Image .....                         | 22        |
| 1.4 Debugger Setting .....                   | 23        |
| 1.4.1 Probe .....                            | 23        |
| 1.4.2 J-Link.....                            | 30        |
| 1.5 Download Code to Flash.....              | 35        |
| 1.6 Enter GDB Debugger.....                  | 35        |
| 1.7 Command List .....                       | 36        |
| 1.8 GDB Debugger Basic Usage .....           | 37        |
| 1.9 Q & A .....                              | 37        |
| <b>2 C++ Standards Support in GCC .....</b>  | <b>40</b> |
| 2.1 Introduction.....                        | 40        |
| 2.2 How to Build C++ Codes .....             | 40        |
| <b>3 SDK Architecture .....</b>              | <b>42</b> |
| 3.1 Component.....                           | 42        |
| 3.1.1 Common .....                           | 42        |
| 3.1.2 OS .....                               | 43        |
| 3.1.3 SOC .....                              | 43        |
| 3.2 Doc.....                                 | 43        |
| 3.3 Tools .....                              | 43        |
| 3.4 GCC Project for KM4.....                 | 44        |
| 3.5 Critical Header Files .....              | 44        |
| <b>4 GCC Makefile .....</b>                  | <b>45</b> |
| 4.1 KM4 Makefile Architecture .....          | 45        |
| 4.2 How to Build Code into Flash .....       | 45        |
| 4.3 How to Build Code into SRAM .....        | 46        |
| 4.4 How to Use Section Attribute.....        | 47        |
| 4.5 How to Build Library .....               | 48        |
| 4.6 How to Add Library.....                  | 49        |
| <b>5 GCC Standard Library.....</b>           | <b>50</b> |
| 5.1 Introduction.....                        | 50        |
| 5.2 Default Library Function Use in SDK..... | 50        |

|                                                                   |           |
|-------------------------------------------------------------------|-----------|
| 5.3 How to Use Configurable Function in GCC Standard Library..... | 51        |
| 5.4 Tips .....                                                    | 52        |
| <b>6 IAR Build Environment Setup.....</b>                         | <b>53</b> |
| 6.1 Requirement.....                                              | 53        |
| 6.1.1 <i>IAR workbench</i> .....                                  | 53        |
| 6.1.2 <i>J-Link probe</i> .....                                   | 53        |
| 6.2 Hardware Configuration .....                                  | 53        |
| 6.3 How to Use IAR .....                                          | 54        |
| 6.3.1 <i>IAR Build</i> .....                                      | 54        |
| 6.3.2 <i>IAR Download</i> .....                                   | 58        |
| 6.3.3 <i>IAR Debug</i> .....                                      | 63        |
| 6.4 How to Build Sample Code .....                                | 65        |
| <b>7 Demo Board .....</b>                                         | <b>67</b> |
| 7.1 PCB Layout Overview.....                                      | 67        |
| 7.2 Pin Out.....                                                  | 67        |
| 7.3 DC Power Supply .....                                         | 68        |
| 7.4 USB Interface Configuration .....                             | 69        |
| 7.5 LOGUART .....                                                 | 69        |
| 7.6 SWD .....                                                     | 69        |
| 7.7 VBAT ADC.....                                                 | 70        |
| <b>8 ImageTool.....</b>                                           | <b>71</b> |
| 8.1 Introduction.....                                             | 71        |
| 8.2 Environment Setup.....                                        | 71        |
| 8.2.1 <i>Hardware Setup</i> .....                                 | 71        |
| 8.2.2 <i>Software Setup</i> .....                                 | 72        |
| 8.3 Download .....                                                | 72        |
| 8.3.1 <i>Image Download</i> .....                                 | 72        |
| 8.3.2 <i>Flash Erase</i> .....                                    | 73        |
| 8.3.3 <i>Flash Status Operation</i> .....                         | 74        |
| 8.4 Generate.....                                                 | 76        |
| 8.4.1 <i>Merge Images</i> .....                                   | 76        |
| 8.4.2 <i>Generate Cloud OTA Image</i> .....                       | 77        |
| 8.5 Encrypt.....                                                  | 78        |
| 8.6 Security .....                                                | 79        |
| <b>9 Memory Layout.....</b>                                       | <b>81</b> |
| 9.1 Flash Program Layout .....                                    | 81        |
| 9.1.1 <i>Image Header without Secure Boot</i> .....               | 82        |
| 9.1.2 <i>Image Header with Secure Boot</i> .....                  | 82        |
| 9.1.3 <i>System Data (4K)</i> .....                               | 83        |
| 9.1.4 <i>User Data</i> .....                                      | 83        |
| 9.2 SRAM Layout .....                                             | 84        |
| 9.2.1 <i>KM4 SRAM Layout</i> .....                                | 84        |
| 9.2.2 <i>KM0 SRAM Layout</i> .....                                | 85        |
| 9.3 Retention SRAM .....                                          | 85        |
| 9.3.1 <i>Retention SRAM Layout</i> .....                          | 85        |
| 9.3.2 <i>User Area</i> .....                                      | 86        |
| 9.4 OTA Program Layout.....                                       | 86        |
| 9.4.1 <i>OTA Header Layout</i> .....                              | 87        |
| 9.5 TrustZone Memory Layout .....                                 | 88        |

|                                                   |            |
|---------------------------------------------------|------------|
| <b>10 Boot Process .....</b>                      | <b>90</b>  |
| 10.1 Features .....                               | 90         |
| 10.2 Boot Address .....                           | 90         |
| 10.3 Pin Description .....                        | 90         |
| 10.4 Boot Flow .....                              | 90         |
| 10.5 Boot Time .....                              | 91         |
| 10.6 General Description .....                    | 91         |
| 10.6.1 <i>KM0 ROM Boot</i> .....                  | 92         |
| 10.6.2 <i>KM4 ROM Boot</i> .....                  | 92         |
| 10.7 Boot Reason APIs .....                       | 93         |
| 10.8 Security Boot .....                          | 93         |
| 10.8.1 <i>Diagram</i> .....                       | 93         |
| 10.8.2 <i>Image Header with Secure Boot</i> ..... | 94         |
| 10.8.3 <i>Secure Boot Image Generation</i> .....  | 95         |
| <b>11 OTA Firmware Update.....</b>                | <b>97</b>  |
| 11.1 Introduction .....                           | 97         |
| 11.2 RSIP-MMU .....                               | 97         |
| 11.3 OTA Upgrade from Local Server .....          | 98         |
| 11.3.1 <i>Firmware Format</i> .....               | 99         |
| 11.3.2 <i>OTA Flow</i> .....                      | 99         |
| 11.3.3 <i>Boot Option</i> .....                   | 100        |
| 11.3.4 <i>Address Remapping</i> .....             | 101        |
| 11.3.5 <i>How to Use OTA Demo</i> .....           | 101        |
| 11.3.6 <i>OTA Firmware Swap</i> .....             | 103        |
| 11.4 User Configuration.....                      | 104        |
| <b>12 Power Save .....</b>                        | <b>106</b> |
| 12.1 Hardware Power Save Modes .....              | 106        |
| 12.1.1 <i>Power Mode</i> .....                    | 106        |
| 12.1.2 <i>Power Consumption Summary</i> .....     | 107        |
| 12.2 Software Power Management .....              | 111        |
| 12.2.1 <i>FreeRTOS Tickles</i> .....              | 111        |
| 12.2.2 <i>Wakelock</i> .....                      | 112        |
| 12.2.3 <i>Wi-Fi Power Save</i> .....              | 112        |
| 12.2.4 <i>Software Configuration</i> .....        | 112        |
| 12.2.5 <i>GPIO Pull Control</i> .....             | 113        |
| 12.3 Suspend Resume APIs .....                    | 114        |
| 12.3.1 <i>pmu_register_sleep_callback</i> .....   | 115        |
| 12.3.2 <i>pmu_unregister_sleep_callback</i> ..... | 115        |
| 12.3.3 <i>pmu_acquire_wakelock</i> .....          | 115        |
| 12.3.4 <i>pmu_release_wakelock</i> .....          | 115        |
| 12.3.5 <i>pmu_set_sysactive_time</i> .....        | 115        |
| 12.3.6 <i>pmu_set_max_sleep_time</i> .....        | 116        |
| 12.4 Power Consumption Measurement .....          | 116        |
| 12.4.1 <i>Test Command</i> .....                  | 116        |
| 12.4.2 <i>Hardware Preparation</i> .....          | 116        |
| <b>13 User Configuration .....</b>                | <b>118</b> |
| 13.1 Configuration File List .....                | 118        |
| 13.2 boot_trustzonecfg.....                       | 118        |
| 13.3 flashcfg .....                               | 119        |

|           |                                                |            |
|-----------|------------------------------------------------|------------|
| 13.3.1    | <i>Flash Classification</i> .....              | 119        |
| 13.3.2    | <i>FlashClass1</i> .....                       | 123        |
| 13.3.3    | <i>FlashClass2</i> .....                       | 124        |
| 13.3.4    | <i>FlashClass3</i> .....                       | 124        |
| 13.3.5    | <i>FlashClass4</i> .....                       | 125        |
| 13.3.6    | <i>FlashClass5</i> .....                       | 126        |
| 13.3.7    | <i>FlashClass6</i> .....                       | 126        |
| 13.4      | <i>pinmapcfg</i> .....                         | 127        |
| 13.5      | <i>sleepcfg</i> .....                          | 128        |
| 13.6      | <i>bootcfg</i> .....                           | 128        |
| 13.7      | <i>ipccfg</i> .....                            | 130        |
| <b>14</b> | <b>Hardware Crypto Engine .....</b>            | <b>131</b> |
| 14.1      | <i>Introduction</i> .....                      | 131        |
| 14.2      | <i>Hardware Crypto Engine APIs</i> .....       | 131        |
| 14.2.1    | <i>Crypto Engine Initialize API</i> .....      | 131        |
| 14.2.2    | <i>Hash APIs</i> .....                         | 131        |
| 14.2.3    | <i>Cipher APIs</i> .....                       | 136        |
| 14.3      | <i>Hardware Crypto Engine APIs Usage</i> ..... | 139        |
| 14.3.1    | <i>Start Hardware Crypto Engine</i> .....      | 139        |
| 14.3.2    | <i>Start Crypto Engine Calculation</i> .....   | 139        |
| 14.4      | <i>Demo Code Path</i> .....                    | 140        |
| <b>15</b> | <b>eFuse.....</b>                              | <b>141</b> |
| 15.1      | <i>Power Requirement</i> .....                 | 141        |
| 15.2      | <i>eFuse Mapping</i> .....                     | 141        |
| 15.3      | <i>eFuse Auto-load</i> .....                   | 142        |
| 15.4      | <i>Physical eFuse</i> .....                    | 142        |
| 15.4.1    | <i>Physical eFuse Layout</i> .....             | 142        |
| 15.4.2    | <i>Protection Configuration (R/W)</i> .....    | 142        |
| 15.5      | <i>Logical eFuse</i> .....                     | 143        |
| 15.5.1    | <i>Wi-Fi 2.4G Power Index</i> .....            | 144        |
| 15.5.2    | <i>Wi-Fi 5G Power Index</i> .....              | 145        |
| 15.5.3    | <i>Wi-Fi Channel Plan</i> .....                | 146        |
| 15.5.4    | <i>Wi-Fi Crystal Calibration</i> .....         | 147        |
| 15.5.5    | <i>Wi-Fi Thermal Meter</i> .....               | 148        |
| 15.5.6    | <i>Wi-Fi MAC Address</i> .....                 | 148        |
| 15.5.7    | <i>Cap-Touch</i> .....                         | 148        |
| 15.5.8    | <i>Bluetooth</i> .....                         | 148        |
| 15.5.9    | <i>HCI USB</i> .....                           | 149        |
| 15.5.10   | <i>ADC</i> .....                               | 149        |
| 15.6      | <i>eFuse PG APIs</i> .....                     | 149        |
| 15.6.1    | <i>EFUSE_PMAP_WRITE8</i> .....                 | 149        |
| 15.6.2    | <i>EFUSE_PMAP_READ8</i> .....                  | 150        |
| 15.6.3    | <i>EFUSE_LMAP_WRITE</i> .....                  | 150        |
| 15.6.4    | <i>EFUSE_LMAP_READ</i> .....                   | 150        |
| 15.6.5    | <i>efuse_otp_write</i> .....                   | 150        |
| 15.6.6    | <i>efuse_otp_read</i> .....                    | 150        |
| 15.6.7    | <i>efuse_mtp_write</i> .....                   | 151        |
| 15.6.8    | <i>efuse_mtp_read</i> .....                    | 151        |
| 15.7      | <i>eFuse PG Command</i> .....                  | 151        |
| 15.8      | <i>eFuse Check Sequence (TBD)</i> .....        | 151        |

|           |                                                 |            |
|-----------|-------------------------------------------------|------------|
| <b>16</b> | <b>Flash Operation.....</b>                     | <b>152</b> |
| 16.1      | Functional Description .....                    | 152        |
| 16.2      | Protection Method.....                          | 152        |
| 16.3      | Flash Raw API .....                             | 153        |
| 16.3.1    | <i>Read</i> .....                               | 153        |
| 16.3.2    | <i>Write</i> .....                              | 154        |
| 16.3.3    | <i>Erase</i> .....                              | 154        |
| 16.3.4    | <i>Receive/Transmit Command</i> .....           | 154        |
| 16.4      | Flash Mbed API .....                            | 155        |
| 16.5      | User Configuration.....                         | 155        |
| 16.5.1    | <i>Flash Speed</i> .....                        | 155        |
| 16.5.2    | <i>Flash Read Mode</i> .....                    | 155        |
| 16.5.3    | <i>New Flash Support</i> .....                  | 155        |
| <b>17</b> | <b>Battery Measurement.....</b>                 | <b>156</b> |
| 17.1      | Functional Description .....                    | 156        |
| 17.2      | Calibration.....                                | 156        |
| <b>18</b> | <b>Wi-Fi.....</b>                               | <b>158</b> |
| 18.1      | Wi-Fi Data Structures .....                     | 158        |
| 18.2      | Wi-Fi APIs .....                                | 158        |
| 18.2.1    | <i>System APIs</i> .....                        | 158        |
| 18.2.2    | <i>Scan APIs</i> .....                          | 159        |
| 18.2.3    | <i>Connection APIs</i> .....                    | 160        |
| 18.2.4    | <i>Channel APIs</i> .....                       | 163        |
| 18.2.5    | <i>Power APIs</i> .....                         | 163        |
| 18.2.6    | <i>AP Mode APIs</i> .....                       | 165        |
| 18.2.7    | <i>Custom IE APIs</i> .....                     | 166        |
| 18.2.8    | <i>Wi-Fi Setting APIs</i> .....                 | 167        |
| 18.2.9    | <i>Wi-Fi Indication APIs</i> .....              | 171        |
| 18.2.10   | <i>eFuse writing APIs</i> .....                 | 172        |
| 18.3      | Fast Connect .....                              | 172        |
| 18.3.1    | <i>Implement</i> .....                          | 172        |
| 18.3.2    | <i>APIs</i> .....                               | 173        |
| 18.4      | WPS APIs .....                                  | 173        |
| 18.4.1    | <i>wps_start</i> .....                          | 173        |
| 18.4.2    | <i>wps_stop</i> .....                           | 173        |
| <b>19</b> | <b>Inter Processor Communication (IPC).....</b> | <b>175</b> |
| 19.1      | How to Use IPC.....                             | 175        |
| 19.2      | IPC Program APIs.....                           | 175        |
| 19.2.1    | <i>ipc_table_init</i> .....                     | 175        |
| 19.2.2    | <i>ipc_send_message</i> .....                   | 176        |
| 19.2.3    | <i>ipc_get_message</i> .....                    | 176        |
| 19.3      | IPC Driver Code .....                           | 176        |
| 19.3.1    | <i>IPC_INTConfig</i> .....                      | 176        |
| 19.3.2    | <i>IPC_IERSet</i> .....                         | 176        |
| 19.3.3    | <i>IPC_IERGet</i> .....                         | 177        |
| 19.3.4    | <i>IPC_INTRequest</i> .....                     | 177        |
| 19.3.5    | <i>IPC_INTClear</i> .....                       | 177        |
| 19.3.6    | <i>IPC_INTGet</i> .....                         | 177        |
| 19.3.7    | <i>IPC_CPUID</i> .....                          | 177        |

|           |                                                       |            |
|-----------|-------------------------------------------------------|------------|
| 19.3.8    | <i>IPC_SEMGet</i> .....                               | 177        |
| 19.3.9    | <i>IPC_SEMFree</i> .....                              | 178        |
| 19.3.10   | <i>IPC_INTHandler</i> .....                           | 178        |
| 19.3.11   | <i>IPC_INTUserHandler</i> .....                       | 178        |
| <b>20</b> | <b>PSRAM .....</b>                                    | <b>179</b> |
| 20.1      | Throughput .....                                      | 179        |
| 20.2      | Power Management .....                                | 180        |
| 20.3      | How to Use PSRAM .....                                | 180        |
| 20.3.1    | <i>Initialize PSRAM</i> .....                         | 180        |
| 20.3.2    | <i>Add Section into PSRAM Region</i> .....            | 180        |
| 20.4      | How to Allocate Heap from PSRAM .....                 | 180        |
| <b>21</b> | <b>MPU and Cache .....</b>                            | <b>182</b> |
| 21.1      | Functional description .....                          | 182        |
| 21.1.1    | <i>MPU</i> .....                                      | 182        |
| 21.1.2    | <i>Cache</i> .....                                    | 182        |
| 21.2      | MPU APIs.....                                         | 183        |
| 21.2.1    | <i>mpu_init</i> .....                                 | 183        |
| 21.2.2    | <i>mpu_set_mem_attr</i> .....                         | 183        |
| 21.2.3    | <i>mpu_region_cfg</i> .....                           | 183        |
| 21.2.4    | <i>mpu_entry_free</i> .....                           | 183        |
| 21.2.5    | <i>mpu_entry_alloc</i> .....                          | 183        |
| 21.3      | Cache APIs.....                                       | 184        |
| 21.3.1    | <i>ICache_Enable</i> .....                            | 184        |
| 21.3.2    | <i>ICache_Disable</i> .....                           | 184        |
| 21.3.3    | <i>ICache_Invalidate</i> .....                        | 184        |
| 21.3.4    | <i>DCache_IsEnabled</i> .....                         | 184        |
| 21.3.5    | <i>DCache_Enable</i> .....                            | 184        |
| 21.3.6    | <i>DCache_Disable</i> .....                           | 184        |
| 21.3.7    | <i>DCache_Invalidate</i> .....                        | 185        |
| 21.3.8    | <i>DCache_Clean</i> .....                             | 185        |
| 21.3.9    | <i>DCache_CleanInvalidate</i> .....                   | 185        |
| 21.4      | How to Define a Non-cacheable Data Buffer .....       | 185        |
| <b>22</b> | <b>Liquid Crystal Display Controller (LCDC) .....</b> | <b>186</b> |
| 22.1      | Interface .....                                       | 186        |
| 22.2      | Resolution .....                                      | 187        |
| 22.3      | Pinmux .....                                          | 188        |
| 22.4      | JPG Decompressor .....                                | 188        |
| 22.5      | LCDC APIs .....                                       | 189        |
| 22.5.1    | <i>MCU Function</i> .....                             | 189        |
| 22.5.2    | <i>RGB Function</i> .....                             | 190        |
| 22.5.3    | <i>LED Function</i> .....                             | 190        |
| 22.5.4    | <i>Common Function</i> .....                          | 190        |
| 22.6      | How to Use LCDC .....                                 | 192        |
| 22.6.1    | <i>MCU Interface</i> .....                            | 192        |
| 22.6.2    | <i>RGB Interface</i> .....                            | 194        |
| 22.6.3    | <i>LED I/F</i> .....                                  | 195        |
| <b>23</b> | <b>Audio Codec Control (ACC) Guide.</b> .....         | <b>196</b> |
| 23.1      | Audio Codec (AC) .....                                | 196        |
| 23.1.1    | <i>Diagram</i> .....                                  | 196        |

|        |                                          |     |
|--------|------------------------------------------|-----|
| 23.1.2 | <i>Features</i>                          | 197 |
| 23.1.3 | <i>Application Mode</i>                  | 197 |
| 23.2   | Audio Codec Controller (ACC)             | 201 |
| 23.2.1 | <i>Diagram</i>                           | 201 |
| 23.2.2 | <i>Features</i>                          | 201 |
| 23.2.3 | <i>Control Interface</i>                 | 201 |
| 23.3   | Audio PLL                                | 202 |
| 23.3.1 | <i>Diagram</i>                           | 202 |
| 23.3.2 | <i>Operation Mode</i>                    | 203 |
| 23.4   | Audio Codec APIs                         | 204 |
| 23.4.1 | <i>PLL APIs</i>                          | 204 |
| 23.4.2 | <i>SPORT APIs</i>                        | 204 |
| 23.4.3 | <i>SI APIs</i>                           | 207 |
| 23.4.4 | <i>Codec APIs</i>                        | 208 |
| 23.5   | How to Use Audio Codec APIs              | 210 |
| 23.5.1 | <i>Audio Play Steps</i>                  | 210 |
| 23.5.2 | <i>Audio Record Steps</i>                | 210 |
| 23.5.3 | <i>Example List</i>                      | 211 |
| 23.6   | Hardware Design Guide                    | 211 |
| 23.6.1 | <i>Line-out</i>                          | 211 |
| 23.6.2 | <i>AMIC-in</i>                           | 211 |
| 23.6.3 | <i>Power</i>                             | 212 |
| 23.7   | Performance of Encoding & Decoding       | 212 |
| 23.7.1 | <i>AC3 Format</i>                        | 212 |
| 23.7.2 | <i>OPUS Format</i>                       | 213 |
| 23.7.3 | <i>FLAC Format</i>                       | 213 |
| 23.7.4 | <i>AAC Format</i>                        | 213 |
| 23.7.5 | <i>MP3 Format</i>                        | 214 |
| 23.8   | Q & A (in English and Chinese)           | 214 |
| 24     | DuerOS                                   | 216 |
| 24.1   | DuerOS Platform                          | 216 |
| 24.1.1 | <i>Apply product</i>                     | 216 |
| 24.1.2 | <i>Apply Profile</i>                     | 219 |
| 24.2   | Hardware                                 | 219 |
| 24.3   | Software Component                       | 220 |
| 24.3.1 | <i>duerapp</i>                           | 220 |
| 24.3.2 | <i>libduer-device</i>                    | 220 |
| 24.4   | How to Use                               | 221 |
| 24.4.1 | <i>Build and Download</i>                | 221 |
| 24.4.2 | <i>Configure the Network</i>             | 221 |
| 24.4.3 | <i>DuerOS Connection Success</i>         | 222 |
| 24.4.4 | <i>Triger Record and Speak</i>           | 222 |
| 24.5   | OTA Upgrade                              | 223 |
| 24.5.1 | <i>Generate OTA Image</i>                | 223 |
| 24.5.2 | <i>OTA with DuerOS Platform</i>          | 223 |
| 24.5.3 | <i>Attention</i>                         | 226 |
| 24.6   | How to Debug                             | 226 |
| 24.6.1 | <i>Build Error</i>                       | 226 |
| 24.6.2 | <i>Wi-Fi Signal</i>                      | 226 |
| 24.6.3 | <i>The Recorder Cannot Be Recognized</i> | 227 |
| 24.6.4 | <i>Check the memory</i>                  | 227 |
| 24.6.5 | <i>Check the Device status</i>           | 227 |

|                                                                |            |
|----------------------------------------------------------------|------------|
| <b>25 Infrared Radiation (IR).....</b>                         | <b>229</b> |
| 25.1 Pinmux .....                                              | 229        |
| 25.1 Data format.....                                          | 229        |
| 25.1.1 <i>IR Tx</i> .....                                      | 229        |
| 25.1.2 <i>IR Rx</i> .....                                      | 230        |
| 25.2 APIs .....                                                | 230        |
| 25.2.1 <i>IR Setting APIs</i> .....                            | 230        |
| 25.2.2 <i>IR Tx APIs</i> .....                                 | 232        |
| 25.2.3 <i>IR Rx APIs</i> .....                                 | 233        |
| 25.3 IR Usage .....                                            | 235        |
| 25.3.1 <i>Sending Usage</i> .....                              | 235        |
| 25.3.2 <i>Receiving Usage</i> .....                            | 235        |
| 25.4 Compensation Mechanism .....                              | 236        |
| 25.4.1 <i>Tx Compensation Mechanism Application</i> .....      | 236        |
| 25.5 IR Schematic Design Guideline.....                        | 237        |
| 25.5.1 <i>Leakage</i> .....                                    | 237        |
| 25.5.2 <i>Carrier Problem in Rx Learning</i> .....             | 238        |
| <b>26 Brownout Detector (BOD) .....</b>                        | <b>239</b> |
| 26.1 Recommended Threshold Parameter.....                      | 239        |
| 26.2 BOD APIs .....                                            | 240        |
| 26.2.1 <i>BOR_ModeSet</i> .....                                | 240        |
| 26.2.2 <i>BOR_ThresholdSet</i> .....                           | 240        |
| 26.2.3 <i>BOR_ClearINT</i> .....                               | 240        |
| 26.2.4 <i>BOR_DbncSet</i> .....                                | 240        |
| <b>27 Flash Translation Layer (FTL) .....</b>                  | <b>242</b> |
| 27.1 Overview.....                                             | 242        |
| 27.2 Features .....                                            | 243        |
| 27.3 FTL APIs .....                                            | 243        |
| 27.3.1 <i>ftl_init</i> .....                                   | 243        |
| 27.3.2 <i>ftl_load_from_storage</i> .....                      | 243        |
| 27.3.3 <i>ftl_save_to_storage</i> .....                        | 244        |
| 27.4 How to Use FTL .....                                      | 244        |
| <b>28 Audio Signal Generation and Analysis .....</b>           | <b>245</b> |
| 28.1 Introduction .....                                        | 245        |
| 28.1.1 <i>Compilation</i> .....                                | 245        |
| 28.1.2 <i>Generating a Signal of a Certain Frequency</i> ..... | 245        |
| 28.1.3 <i>Analyzing Signals Collected by DMIC</i> .....        | 245        |
| 28.1.4 <i>DAAD</i> .....                                       | 245        |
| 28.1.5 <i>Command</i> .....                                    | 246        |
| <b>Revision History.....</b>                                   | <b>247</b> |

# List of Tables

|                                                        |     |
|--------------------------------------------------------|-----|
| Table 1-1 Command list .....                           | 36  |
| Table 1-2 GDB debugger command list .....              | 37  |
| Table 5-1 Library function default use .....           | 50  |
| Table 6-1 CPU Configuration.....                       | 55  |
| Table 6-2 Generated images.....                        | 58  |
| Table 7-1 3.3V/1.8V power supply selection .....       | 69  |
| Table 7-2 LOGUART selection .....                      | 69  |
| Table 8-1 MXIC flash status register .....             | 76  |
| Table 9-1 1M/2M flash program layout.....              | 81  |
| Table 9-2 Image header without secure boot.....        | 82  |
| Table 9-3 Image header with secure boot .....          | 82  |
| Table 9-4 System Data Layout .....                     | 83  |
| Table 9-5 User Data Layout.....                        | 83  |
| Table 9-6 KM4 RAM program layout .....                 | 84  |
| Table 9-7 KMO RAM program layout .....                 | 85  |
| Table 9-8 Retention SRAM layout.....                   | 85  |
| Table 9-9 OTA header layout .....                      | 88  |
| Table 10-1 Boot ROM address .....                      | 90  |
| Table 10-2 ISP mode .....                              | 90  |
| Table 10-3 Boot Time .....                             | 91  |
| Table 10-4 Boot reason definition .....                | 93  |
| Table 10-5 Image header with secure boot .....         | 95  |
| Table 11-1 OTA under MMU .....                         | 98  |
| Table 11-2 Firmware header.....                        | 99  |
| Table 12-1 Power domain comparison .....               | 106 |
| Table 12-2 AON_Wakepin.....                            | 106 |
| Table 12-3 Power consumption under 3.3V/1.8V .....     | 107 |
| Table 12-4 Tx power consumption under 3.3V/1.8V.....   | 107 |
| Table 12-5 Wi-Fi power save mode .....                 | 112 |
| Table 13-1 User configuration file .....               | 118 |
| Table 13-2 User flash configuration .....              | 119 |
| Table 13-3 Flash species .....                         | 119 |
| Table 13-4 Dummy cycles with different read mode ..... | 121 |
| Table 13-5 FlashClass1 parameters .....                | 123 |
| Table 13-6 FlashClass2 parameters .....                | 124 |
| Table 13-7 FlashClass3 parameters .....                | 124 |
| Table 13-8 FlashClass4 parameters .....                | 125 |
| Table 13-9 FlashClass5 parameters .....                | 126 |
| Table 13-10 FlashClass6 parameters .....               | 126 |
| Table 13-11 User bootcfg .....                         | 130 |
| Table 15-1 Operation under different voltage.....      | 141 |
| Table 15-2 Physical eFuse layout .....                 | 142 |
| Table 15-3 eFuse protection configuration bits.....    | 142 |
| Table 15-4 Logical eFuse layout .....                  | 143 |
| Table 15-5 eFuse channel plan in driver .....          | 146 |
| Table 16-1 SPIC operation mode .....                   | 152 |
| Table 17-1 Channel description .....                   | 156 |
| Table 17-2 Calibration parameters location .....       | 157 |

|                                                                                 |     |
|---------------------------------------------------------------------------------|-----|
| Table 20-1 PSRAM throughput .....                                               | 179 |
| Table 20-2 PSRAM throughput theoretical calculation .....                       | 179 |
| Table 20-3 PSRAM power management .....                                         | 180 |
| Table 21-1 mpu_region_config structure .....                                    | 182 |
| Table 21-2 How to set a MPU region .....                                        | 182 |
| Table 21-3 Enable/disable, flush and clean operation supported by Cache.....    | 183 |
| Table 22-1 LCDC I/F supported for different packages.....                       | 186 |
| Table 22-2 LCDC I/F data format.....                                            | 186 |
| Table 22-3 Maximum supported resolution .....                                   | 187 |
| Table 22-4 LCDC pin assignment.....                                             | 188 |
| Table 22-5 Typical application scenario of LCDC .....                           | 192 |
| Table 23-1 Relationship between crystal clock and $f_{in}$ .....                | 203 |
| Table 23-2 Relationship between $f_{in}$ and ppm per step .....                 | 203 |
| Table 23-3 Performance of decoding AC3 format audio data .....                  | 212 |
| Table 23-4 Simulated CPU load of encoding and decoding of OPUS audio data ..... | 213 |
| Table 23-5 Code size requirement using libopus .....                            | 213 |
| Table 23-6 CPU load on using Silk encoder .....                                 | 213 |
| Table 23-7 CPU load of decoding FLAC audio data .....                           | 213 |
| Table 23-8 CPU load of decoding AAC audio data .....                            | 213 |
| Table 23-9 CPU load of decoding MP3 audio data .....                            | 214 |
| Table 25-1 IR pin assignments .....                                             | 229 |
| Table 26-1 The high threshold of interrupt mode and reset mode (3.3V/1.8V)..... | 239 |
| Table 26-2 The low threshold of interrupt mode and reset mode (3.3V/1.8V).....  | 239 |
| Table 26-3 Recommended Threshold Parameter .....                                | 239 |
| Table 28-1 Available commands in audio signal generation and analysis .....     | 246 |

# List of Figures

|                                                                     |    |
|---------------------------------------------------------------------|----|
| Fig 1-1 'Devel' setting during Cygwin installation .....            | 18 |
| Fig 1-2 'Math' setting during Cygwin installation .....             | 19 |
| Fig 1-3 KM0 project make all .....                                  | 21 |
| Fig 1-4 KM0 project bin generation .....                            | 21 |
| Fig 1-5 KM4 project make all .....                                  | 22 |
| Fig 1-6 KM4 project bin generation .....                            | 22 |
| Fig 1-7 MP image generation .....                                   | 23 |
| Fig 1-8 KM0 Probe server connection under windows .....             | 24 |
| Fig 1-9 KM0 Probe setup .....                                       | 24 |
| Fig 1-10 KM4 Probe server connection under Windows .....            | 25 |
| Fig 1-11 KM4 Probe setup .....                                      | 26 |
| Fig 1-12 Creating soft link to elf .....                            | 26 |
| Fig 1-13 KM0 probe GDB server connection setting under Linux .....  | 27 |
| Fig 1-14 KM0 probe GDB server connection success under Linux .....  | 27 |
| Fig 1-15 KM0 J-Link terminal setup under Linux .....                | 28 |
| Fig 1-16 KM4 probe GDB server connection setting under Linux .....  | 28 |
| Fig 1-17 KM4 probe GDB server connection success under Linux .....  | 29 |
| Fig 1-18 KM4 probe terminal setup under Linux .....                 | 29 |
| Fig 1-19 KM0 J-Link GDB server connection under windows .....       | 30 |
| Fig 1-20 KM0 J-Link setup .....                                     | 31 |
| Fig 1-21 KM4 J-Link GDB server connection under Windows .....       | 31 |
| Fig 1-22 KM4 J-Link Setup .....                                     | 32 |
| Fig 1-23 KM0 J-Link GDB server connection setting under Linux ..... | 32 |
| Fig 1-24 KM0 J-Link GDB server connection success under Linux ..... | 33 |
| Fig 1-25 KM0 J-Link terminal setup under Linux .....                | 33 |
| Fig 1-26 KM4 J-Link GDB server connection setting under Linux ..... | 34 |
| Fig 1-27 KM4 J-Link GDB server connection success under Linux ..... | 34 |
| Fig 1-28 KM4 J-Link terminal setup under Linux .....                | 35 |
| Fig 1-29 Download codes success log .....                           | 35 |
| Fig 1-30 Debug window under Windows .....                           | 36 |
| Fig 1-31 Debug window under Linux .....                             | 36 |
| Fig 1-32 "Error 127" error message .....                            | 38 |
| Fig 1-33 "Permission denied" error message under Linux .....        | 38 |
| Fig 1-34 KM4 "monitor reset" setting .....                          | 39 |
| Fig 3-1 SDK architecture .....                                      | 42 |
| Fig 3-2 Architecture of project .....                               | 44 |
| Fig 4-1 KM4 makefile architecture .....                             | 45 |
| Fig 5-1 Library function guide .....                                | 50 |
| Table 5-2 Wrapper functions .....                                   | 50 |
| Table 5-3 Printf supported format .....                             | 51 |
| Fig 6-1 Ameba-D demo board .....                                    | 53 |
| Fig 6-2 J-Link SWD connection diagram .....                         | 54 |
| Fig 6-3 J-Link and Ameba-D SWD connection .....                     | 54 |
| Fig 6-4 KM0 processor options .....                                 | 56 |
| Fig 6-5 KM4 processor options .....                                 | 56 |
| Fig 6-6 Add Files .....                                             | 57 |
| Fig 6-7 Designate files to SRAM .....                               | 57 |
| Fig 6-8 Build project .....                                         | 58 |

|                                                        |     |
|--------------------------------------------------------|-----|
| Fig 6-9 J-Link can't find KM4 .....                    | 59  |
| Fig 6-10 Set Target Project as Active.....             | 60  |
| Fig 6-11 Switch to Target Project View .....           | 60  |
| Fig 6-12 Debugger setup .....                          | 61  |
| Fig 6-13 J-Link interface setup .....                  | 61  |
| Fig 6-14 Download Active Application .....             | 62  |
| Fig 6-15 Download log .....                            | 62  |
| Fig 6-16 Erase Flash memory .....                      | 63  |
| Fig 6-17 Debug options .....                           | 64  |
| Fig 6-18 Run to main when debugging .....              | 64  |
| Fig 6-19 Toggle breakpoint .....                       | 65  |
| Fig 6-20 Build sample code .....                       | 66  |
| Fig 7-1 Demo board – PCB layout overview.....          | 67  |
| Fig 7-2 Demo board – pin out .....                     | 68  |
| Fig 7-3 Demo board – 3.3V/1.8V power supply.....       | 68  |
| Fig 7-4 Demo board – USB interface configuration ..... | 69  |
| Fig 7-5 Demo board – LOGUART .....                     | 69  |
| Fig 7-6 Demo board – SWD .....                         | 69  |
| Fig 7-7 Demo board – VBAT ADC .....                    | 70  |
| Fig 8-1 ImageTool UI .....                             | 71  |
| Fig 8-2 Hardware setup.....                            | 72  |
| Fig 8-3 ImageTool ‘Download’ tabpage setting .....     | 73  |
| Fig 8-4 Flash erase operation.....                     | 74  |
| Fig 8-5 ‘Advanced Settings’ window .....               | 75  |
| Fig 8-6 Flash status operation .....                   | 75  |
| Fig 8-7 Image_All.bin generation .....                 | 77  |
| Fig 8-8 OTA_All generation .....                       | 78  |
| Fig 8-9 ImageTool ‘Encrypt’ tabpage setting .....      | 79  |
| Fig 8-10 ImageTool ‘Security’ tabpage setting .....    | 80  |
| Fig 9-1 1M/2M flash program layout.....                | 81  |
| Fig 9-2 Normal image header.....                       | 82  |
| Fig 9-3 Security boot image header .....               | 82  |
| Fig 9-4 System data layout.....                        | 83  |
| Fig 9-5 KM4 RAM program layout .....                   | 84  |
| Fig 9-6 KM0 RAM program layout .....                   | 85  |
| Fig 9-7 OTA program layout .....                       | 87  |
| Fig 9-8 OTA header layout .....                        | 87  |
| Fig 9-9 TrustZone layout .....                         | 89  |
| Fig 10-1 Boot flow .....                               | 91  |
| Fig 10-2 KM0 ROM boot process .....                    | 92  |
| Fig 10-3 KM4 ROM boot process .....                    | 93  |
| Fig 10-4 Ameba-D security boot diagram .....           | 94  |
| Fig 10-5 Security boot image header .....              | 94  |
| Fig 10-6 ImageTool ‘Security’ function .....           | 96  |
| Fig 11-1 Flash MMU .....                               | 97  |
| Fig 11-2 MMU virtual address to physical address ..... | 97  |
| Fig 11-3 2M flash OTA MMU.....                         | 98  |
| Fig 11-4 OTA update diagram .....                      | 99  |
| Fig 11-5 Firmware format .....                         | 99  |
| Fig 11-6 OTA operation flow .....                      | 100 |
| Fig 11-7 OTA select diagram .....                      | 101 |
| Fig 11-8 OTA firmware swap procedure .....             | 104 |
| Fig 12-1 WoWLAN (3.3V normal mode).....                | 108 |

|                                                                                                  |     |
|--------------------------------------------------------------------------------------------------|-----|
| Fig 12-2 WoWLAN (1.8V normal mode).....                                                          | 109 |
| Fig 12-3 WoWLAN (3.3V ultra-low power mode) .....                                                | 109 |
| Fig 12-4 WoWLAN (1.8V ultra-low power mode) .....                                                | 110 |
| Fig 12-5 UDP performance (3.3V ultra-low power mode) .....                                       | 110 |
| Fig 12-6 UDP performance (1.8V ultra-low power mode) .....                                       | 111 |
| Fig 12-7 FreeRTOS tickles in idle task.....                                                      | 111 |
| Fig 12-8 Timeline of power saving .....                                                          | 112 |
| Fig 12-9 Power consumption measurement.....                                                      | 117 |
| Fig 12-10 Measure power consumption from micro USB.....                                          | 117 |
| Fig 13-1 Flash_AVL .....                                                                         | 120 |
| Fig 13-2 Fast read quad I/O instruction sequence .....                                           | 120 |
| Fig 13-3 Fast read dual I/O instruction sequence .....                                           | 121 |
| Fig 13-4 Write Status Register 1 & 2 sequence (FlashClass1, FlashClass2 when density < 2M) ..... | 122 |
| Fig 13-5 Write Status Register 1/2 sequence (FlashClass2 when density > 2MB) .....               | 122 |
| Fig 13-6 Read Configuration Register sequence (FlashClass6).....                                 | 122 |
| Fig 13-7 Write Status Register and Write Configuration Register sequence (FlashClass6).....      | 123 |
| Fig 15-1 eFuse layout diagram .....                                                              | 141 |
| Fig 15-2 Wi-Fi eFuse data.....                                                                   | 144 |
| Fig 15-3 2.4G Wi-Fi power index address .....                                                    | 144 |
| Fig 15-4 2.4G Wi-Fi power index specification.....                                               | 145 |
| Fig 15-5 5G Wi-Fi power index address .....                                                      | 145 |
| Fig 15-6 5G Wi-Fi power index specification .....                                                | 145 |
| Fig 15-7 Channel plan.....                                                                       | 146 |
| Fig 15-8 Crystal Calibration .....                                                               | 147 |
| Fig 15-9 Thermal Meter .....                                                                     | 148 |
| Fig 15-10 MAC Address .....                                                                      | 148 |
| Fig 16-1 User mode operation flow .....                                                          | 153 |
| Fig 17-1 Relationship between sample data and input voltage.....                                 | 156 |
| Fig 19-1 IPC system architecture .....                                                           | 175 |
| Fig 20-1 PSRAM initial configuration .....                                                       | 180 |
| Fig 21-1 Non-cacheable buffer initialization.....                                                | 185 |
| Fig 23-1 Audio codec diagram.....                                                                | 196 |
| Fig 23-2 Cap-less mode connection with headphone jack.....                                       | 197 |
| Fig 23-3 Differential mode connection with headphone jack.....                                   | 198 |
| Fig 23-4 Single-end mode connection with headphone jack.....                                     | 198 |
| Fig 23-5 Line-in mode connection.....                                                            | 199 |
| Fig 23-6 Analog MIC single-end mode connection .....                                             | 199 |
| Fig 23-7 Analog MIC differential mode connection .....                                           | 199 |
| Fig 23-8 Digital MIC mono mode connection .....                                                  | 200 |
| Fig 23-9 Digital MIC stereo mode connection.....                                                 | 200 |
| Fig 23-10 Audio codec controller diagram .....                                                   | 201 |
| Fig 23-11 ACC clock architecture .....                                                           | 202 |
| Fig 23-12 ACC clock diagram .....                                                                | 202 |
| Fig 23-13 Line-out connection .....                                                              | 211 |
| Fig 23-14 AMIC-in connection.....                                                                | 212 |
| Fig 23-15 Power connection .....                                                                 | 212 |
| Fig 23-16 Reference design of using AB type power amplifier .....                                | 214 |
| Fig 23-17 Reference design of using D type power amplifier .....                                 | 214 |
| Fig 24-1 Register guide.....                                                                     | 216 |
| Fig 24-2 Device control platform .....                                                           | 216 |
| Fig 24-3 Configure new product .....                                                             | 217 |
| Fig 24-4 Choose FreeRTOS .....                                                                   | 217 |
| Fig 24-5 Apply ClientID .....                                                                    | 217 |

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| Fig 24-6 Configure device.....                                          | 218 |
| Fig 24-7 Product center.....                                            | 218 |
| Fig 24-8 Get profile .....                                              | 219 |
| Fig 24-9 AmebaD_QFN88_EVB_V1 .....                                      | 220 |
| Fig 24-10 Softwarecomponent .....                                       | 220 |
| Fig 24-11 Profile in duerapp.c .....                                    | 221 |
| Fig 24-12 Simple configuration log .....                                | 222 |
| Fig 24-13 DuerOS success log .....                                      | 222 |
| Fig 24-14 Trigger code .....                                            | 223 |
| Fig 24-15 Firmware version .....                                        | 223 |
| Fig 24-16 OTA Region.....                                               | 223 |
| Fig 24-17 Add OTA firmware.....                                         | 224 |
| Fig 24-18 Push check button.....                                        | 224 |
| Fig 24-19 Push verify button .....                                      | 225 |
| Fig 24-20 Input device profile number and verify.....                   | 225 |
| Fig 24-21 OTA update result .....                                       | 226 |
| Fig 24-22 Electric resistance .....                                     | 227 |
| Fig 24-23 Network fail log .....                                        | 227 |
| Fig 25-1 NEC format .....                                               | 229 |
| Fig 25-2 NEC modulation .....                                           | 230 |
| Fig 25-3 Difference of waveform between Rx learning and common Rx ..... | 236 |
| Fig 25-4 Tx NEC waveform .....                                          | 237 |
| Fig 25-5 Circuit of IR .....                                            | 238 |
| Fig 27-1 Architecture of flash memory system.....                       | 242 |
| Fig 27-2 FTL overview .....                                             | 243 |
| Fig 28-1 Illustration of DAAD loopback .....                            | 246 |

# 1 Build Environment Setup

## 1.1 Introduction

This chapter illustrates how to build Realtek Wi-Fi SDK under GCC environment. It focuses on both Windows platform and Linux distribution. For Windows, Windows 7 64-bit is used as platform. And for Linux distribution, Ubuntu 18.04 64-bit is used as platform. The build and download procedure are quite similar between Windows and Linux operating system.

## 1.2 Setup GCC Environment

### 1.2.1 Windows

On Windows, you can use Cygwin as the GCC environment. Cygwin is a large collection of GNU and open source tools which provide functionality similar to a Linux distribution on Windows.

Click <http://cygwin.com> and download the Cygwin package-setup-x86.exe for your Windows platform.

**Note:**

- Both 32-bit installation and 64-bit installation for Windows, download the same Cygwin package: setupmake-x86.exe.
- During the installation of Cygwin package, include 'Devel -> make' and 'Math -> bc' utilities on the **Select Packages** step, as Fig 1-1 and Fig 1-2 shows.



Fig 1-1 'Devel' setting during Cygwin installation



Fig 1-2 'Math' setting during Cygwin installation

## 1.2.2 Linux

On Linux, some packages must be installed for the GCC environment:

- **libc6-i386** (GNU C library for 64-bit platform. If you are using 32-bit platform, install **libc6** instead)
- **lib32ncurses5** (32-bit terminal handling for 64-bit platform. If you are using 32-bit platform, install **libncurses5** instead)
- **make**
- **bc**
- **gawk**
- **ncurses**

Some of these packages may have been pre-installed in your operating system. Use package manager to check and decide whether to install. For the last three packages, you can also type the corresponding version command on terminal like the following figures to check whether it exists. If not, make these packages installed.

- **\$ make -v**

```
realtek:~$ make -v
GNU Make 4.1
Built for x86_64-pc-linux-gnu
Copyright (C) 1988-2014 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
```

If **make** isn't installed, type **apt-get install make** to install **make**.

- **\$ bc -v**

```
realtek:~$ bc -v
bc 1.07.1
Copyright 1991-1994, 1997, 1998, 2000, 2004, 2006, 2008, 2012-2017 Free Software
Foundation, Inc.
```

If **bc** isn't installed, type **apt-get install bc** to install **bc**.

- \$ gawk --v

```
gnome@realtek:~$ gawk --v
GNU Awk 4.1.4, API: 1.1 (GNU MPFR 4.0.1, GNU MP 6.1.2)
Copyright (C) 1989, 1991-2016 Free Software Foundation.

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program. If not, see https://www.gnu.org/licenses/.
```

If **gawk** isn't installed, type **apt-get install gawk** to install **gawk**.

- ncurses

**ncurses** is needed if you want to use **make menuconfig** command. Type **apt-get install ncurses-dev** to install **ncurses**.

## 1.3 Build Code

This section illustrates how to build SDK. First, you need to switch to GCC project directory.

- For Windows, open Cygwin terminal and use **\$ cd** command to change directory to KM0 or KM4 project directory of Ameba-D SDK.  
**Note:** You need to replace the **{path}** to your own SDK location, and add “cygdrive” prefix in front of the SDK location, so that Cygwin can access your file system.
  - \$ cd /cygdrive/{path}/project/realtek\_amebaD\_cm0\_gcc\_verification
  - \$ cd /cygdrive/{path}/project/realtek\_amebaD\_cm4\_gcc\_verification
- For Linux, open its own terminal and use **\$ cd** command to change directory to KM0 or KM4 project directory of Ameba-D SDK.
  - \$ cd /{path}/project/realtek\_amebaD\_cm0\_gcc\_verification
  - \$ cd /{path}/project/realtek\_amebaD\_cm4\_gcc\_verification

### 1.3.1 Normal Image

To build SDK for normal image, simply use **\$ make all** command under the corresponding project directories on Cygwin (Windows) or terminal (Linux).

#### 1.3.1.1 KM0 Project

For KM0 project, if the terminal contains “km0\_image2\_all.bin” and “Image manipulating end” output message, means that the image has been built successfully.

```

=====
Image manipulating start =====
/cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/prepend_header.sh /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/ram_2.bin __ram_image2_text_start__ ./cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/target_img2.map
/cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/prepend_header.sh /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/xip_image2.bin __flash_text_start__ ./cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/target_img2.map
/cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/prepend_header.sh /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/ram_retcion.bin __retention_entry_func__ ./cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/target_img2.map
cat /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/xip_image2_prepend.bin /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/ram_2_prepend.bin > /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/image/km0_image2_all.bin
=====
Image manipulating end =====
make[1]: Leaving directory '/cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk'

```

Fig 1-3 KM0 project make all

If somehow it is built failed, type `$ make clean` to clean and then redo the make procedure. After successfully built, the image file is located in `project/realtek_amebaD_cm0_gcc_verification/asdk/image`, as Fig 1-4 shows.



Fig 1-4 KM0 project bin generation

### 1.3.1.2 KM4 Project

For KM4 project, if the terminal contains “km4\_image2\_all.bin” and “Image manipulating end” output message, means that the image has been built successfully.

```

/cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification
gcc_verification/asdk/image/target_img2.axf
49312 45736 2048 97096 17b48 (TOTALS)
===== Image Info DEC =====
rm -f ./build/ram/*.o
===== linker img2_ns end =====
===== Image manipulating start =====
/cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/prepend_header.sh /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/image/ram_2.bin __ram_image2_text_start__ /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/image/target_img2.map
/cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/prepend_header.sh /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/image/xip_image2.bin __flash_text_start__ /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/image/target_img2.map
cat /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/image/xip_image2_prepend.bin /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/image/ram_2_prepend.bin > /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/image/km4_image2_all.bin
===== Image manipulating end =====
make[1]: Leaving directory '/cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk'
tianwei_wang@B34671516 /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification
$
```

Fig 1-5 KM4 project make all

If somehow it built failed, type \$ **make clean** to clean and then redo the make procedure. After successfully built, the image file is located in **project/realtek\_amebaD\_cm4\_gcc\_verification/asdk/image**, as Fig 1-6 shows.



Fig 1-6 KM4 project bin generation

### 1.3.2 MP Image

Use command “make mp” under path /project/realtek\_amebaD\_cm4\_gcc\_verification to generate MP image. After successful compilation, you will find under /project/realtek\_amebaD\_cm4\_gcc\_verification/asdk/image, as shown in Fig 1-7.

| Name                      | Date modified     | Type          | Size     |
|---------------------------|-------------------|---------------|----------|
| <b>Today (40)</b>         |                   |               |          |
| km0_km4_image2_mp.bin     | 4/10/2019 7:08 PM | BIN File      | 136 KB   |
| xip_image2_prepending.bin | 4/10/2019 7:08 PM | BIN File      | 20 KB    |
| ram_2_prepending.bin      | 4/10/2019 7:08 PM | BIN File      | 13 KB    |
| APP.trace                 | 4/10/2019 7:08 PM | TRACE File    | 0 KB     |
| ram_2.bin                 | 4/10/2019 7:08 PM | BIN File      | 13 KB    |
| target_img2.asm           | 4/10/2019 7:08 PM | ASM File      | 188 KB   |
| target_pure_img2.axf      | 4/10/2019 7:08 PM | AXF File      | 25 KB    |
| target_pure_img2.map      | 4/10/2019 7:08 PM | MAP File      | 0 KB     |
| xip_image2.bin            | 4/10/2019 7:08 PM | BIN File      | 20 KB    |
| target_img2.axf           | 4/10/2019 7:08 PM | AXF File      | 828 KB   |
| target_img2.map           | 4/10/2019 7:08 PM | MAP File      | 34 KB    |
| text_image2_ns.map        | 4/10/2019 7:08 PM | MAP File      | 1,041 KB |
| code_size_flash.map       | 4/10/2019 7:08 PM | MAP File      | 2 KB     |
| code_size_ram.map         | 4/10/2019 7:08 PM | MAP File      | 2 KB     |
| obj_list                  | 4/10/2019 7:08 PM | Text Document | 4 KB     |
| ram_size                  | 4/10/2019 7:08 PM | Text Document | 15 KB    |
| km4_boot_all.bin          | 4/10/2019 7:04 PM | BIN File      | 4 KB     |
| xip_boot_prepending.bin   | 4/10/2019 7:04 PM | BIN File      | 1 KB     |

Fig 1-7 MP image generation

## 1.4 Debugger Setting

This section illustrates how to enter GDB debugger mode.

Ameba-D supports CMSIS-DAP and J-Link for code download and entering debugger mode. The settings are described below.

### 1.4.1 Probe

#### 1.4.1.1 Windows

Ameba-D Device Board supports Probe debugger. We can use Probe to download the software and enter GDB debugger mode under GCC environment.

##### (1) Install Probe Driver

Before using the Probe, its driver is required to be installed. Obtain the **RLX\_Probe\_Driver\_2.3.11p18\_Setup\_190304.exe** under tools/probe, then install it correctly. Connect TCK pin of Probe to SWD CLK pin and TMS pin of Probe to SWD DATA pin. What's more, a common ground is needed between Probe Board and Ameba-D Device Board.

##### (2) Execute the **cm0\_RTL\_Probe.bat**

After the installation of the software pack, execute the **cm0\_RTL\_Probe.bat** under **project\realtek\_amebaD\_cm0\_gcc\_verification\jlink\_script**.

**Note:** The default path of Probe driver in **cm0\_RTL\_Probe.bat** file is **C:\RLX\PROBE\rlx\_probe\_driver.exe**, you may have to change the path according to your own settings.

The started Probe server looks like Fig 1-8. This window should NOT be closed if you want to download software or enter GDB debugger mode.



```
C:\Windows\system32\cmd.exe
system reset-halted, DHCSR 0x02030003
This Core is implemented by Realtek Semiconductor Corporation.
This is a KM0 processor! KM0 found CPUID = 0x721cd200, Reversion is rip0!
    DCB_DHCSR 0x00030003;
    NUIC_DFSR 0x00000009;
    NUIC_AIRCR 0xfa052000; little-endian;
    DCB_DCRSR 0x00000000;
    DCB_DCRDR 0x00000000;
    DWT_CVCCNT 0x00000000;
    DWT_MASK0 0x00000000;
    DWT_FUNCTION0 0x50000000;
    This MCU has a Flash Patch Breakpoint version 2!
    This MCU has 2 of code comparators and 0 literal comparators in FPB!
    Remapping not supported!
    DWT_CTRL 0x10000000;
    DWT_CVCCNT 0x00000000;
    DWT_COMP0 0x00000000;
    This MCU has 1 comparators!
    This MCU supports Trace sampling and exception tracing!
    This MCU does not include external match signals, CMPMATCHIN!
    This MCU supports a cycle counter!
    This MCU supports the profiling counters!
    Program flow prediction disabled! Instruction caches disabled! Data and unified ca
ches disabled!
Cache is implemented at level 1, and is Separate Instruction & Data Caches!
Level 1 I-Cache infomation:
    I-Cache supports Write-Through!
    I-Cache supports Write-Back!
    I-Cache supports Read-Allocation!
    I-Cache does not support Write-Allocation!
    The processor's I-cache number of sets is 256!
    The processor's I-cache number of ways is 2!
    The processor's I-cache number of linesize is 8 Words
    The processor's I-cache size is 16 KB!
Level 1 D-Cache infomation:
    D-Cache supports Write-Through!
    D-Cache supports Write-Back!
    D-Cache supports Read-Allocation!
    D-Cache supports Write-Allocation!
    The processor's D-cache number of sets is 64!
    The processor's D-cache number of ways is 2!
    The processor's D-cache number of linesize is 8Words
    The processor's D-cache size is 4KB!
***** TAP 1 Core 0 Initialize Over !
SUCCESS to Trigger this Core
*****
```

Fig 1-8 KM0 Probe server connection under windows

- (3) On the Cygwin terminal, as Fig 1-9 shows, type `$ make setup GDB_SERVER=probe` command before using J-Link to download software or enter GDB debugger.



```
[ather:~/cygdrive/d/Project/Ameba_D/code/v03_181225/project/
realtek_amebaD_cm0_gcc_verification]$ make setup GDB_SERVER=probe
make -C asdk setup
make[1]: Entering directory '/cygdrive/d/Project/Ameba_D/code/v03_181225/proj
ect/realtek_amebaD_cm0_gcc_verification/asdk'
-----
Setup probe
-----
cp -p /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm0_
gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_probe.txt /cygdriv
e/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm0_gcc_verification/
asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm0_
gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_probe.txt /c
ygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm0_gcc_verifi
cation/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm0_
gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_probe.txt /
cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm0_gcc_ve
rification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/d/Project/Ameba_D/code/v03_181225/proje
ct/realtek_amebaD_cm0_gcc_verification/asdk'
```

Fig 1-9 KM0 Probe setup

- (4) Execute the `cm4_RTL_Probe.bat`

Execute the `cm4_RTL_Probe.bat` under `project/realtek_amebaD_cm4_gcc_verification/jlink_script` the same as executing the `cm0_RTL_Probe.bat`. The started Probe server looks like Fig 1-10. This window should NOT be closed if you want to enter GDB debugger mode.

This Core supports Non-Secure Invasive Debug !  
DHCSR = 0x00130003  
This Core is in NON-Secure state, concurrent write to CDS would be ignored!  
Now Access by Secure Request!  
KM4 halted!  
This Core is implemented by Realtek Semiconductor Corporation.  
This is a KM4 processor!KM4 found CPUID = 0x721fd220, Reversion is 0x100!  
DCB\_DHCSR 0x00130003;  
NUIC\_DFSR 0x00000001;  
NUIC\_AIRCR 0xfa052000; little-endian;  
DCB\_DCRSR 0x00000000;  
DCB\_DCRDR 0x00000000;  
DWT\_CYCCNT 0x00000000;  
DWT\_MASK0 0x00000000;  
DWT\_FUNCTION0 0x58000000;  
SAU information:  
SAU AITR: Memory is marked as Secure and is not Non-secure callable!  
The MPU is Enabled!  
MPU Region 0: 0x100268c0 ~ 0x1002c63f is marked as privileged access permitted only, Non-shareable, Read/write by any privilege level, Execution only permitted if read permitted, Normal memory, Outer Non-cacheable, Normal memory, Inner Non-cacheable  
MPU Region 1: 0x1010a000 ~ 0x1014001f is marked as privileged access permitted only, Non-shareable, Read/write by any privilege level, Execution only permitted if read permitted, Normal memory, Outer Non-cacheable, Normal memory, Inner Non-cacheable  
MPU Region 2: 0x101c0000 ~ 0x101d401f is marked as privileged access permitted only, Non-shareable, Read/write by any privilege level, Execution only permitted if read permitted, Normal memory, Outer Non-cacheable, Normal memory, Inner Non-cacheable  
MPU Region 3: 0x0000\_0000 ~ 0x0000c041f is marked as privileged access permitted only, Non-shareable, Read/write by any privilege level, Execution only permitted if read permitted, Normal memory, Outer Non-cacheable, Normal memory, Inner Non-cacheable  
This MCU has has a Flash Patch Breakpoint version 2!  
This MCU has 2 of code comparators and 0 literal comparators in FPB!  
Remapping not supported!  
DWT\_CTRL 0x1b000000;  
DWT\_CYCCNT 0x00000000;  
DWT\_COMPARE 0x00000000;  
This MCU has 1 comparators!  
This MCU supports Trace sampling and exception tracing!  
This MCU does not include external match signals, CMPMATCHIN!  
This MCU supports a cycle counter!  
This MCU supports the profiling counters!  
Program flow prediction disabled!Instruction caches enabled!Data and unified caches enabled!  
There is no D-cache in this processor!  
\*\*\*\*\*  
TAP 1 Core 0 Initialize Over !  
SUCCESS to Trigger this Core  
\*\*\*\*\*

Fig 1-10 KM4 Probe server connection under Windows

Note: When `cm4 RTL_Probe.bat` is running, the connection built by running `cm0 RTL_Probe.bat` will be closed. If you want to connect the Probe to KM0 and KM4 simultaneously, you should make a copy of `rlx_probe0.cfg` under the folder `/realtek_amebaD_cm4_gcc_verification/jlink_script` and rename it as `rlx_probe1.cfg`. Next, cut it and move it to `project/realtek_amebaD_cm0_gcc_verification/jlink_script`. Then by executing `cm0 RTL_Probe.bat` under `project/realtek_amebaD_cm0_gcc_verification/jlink_script`, the Probe can connect to both KM0 and KM4.

##### (5) Setup J-Link for KM4

On the Cygwin terminal, as Fig 1-11 shows, type `$ make setup GDB_SERVER=probe` command before using J-Link to download software or enter GDB debugger.

```
/cygdrive/d/Project/Ameba_D/code/v03_181225/project/
realtek_amebaD_cm4_gcc_verification
$ make setup GDB_SERVER=probe
make -C asdk setup
make[1]: Entering directory '/cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk'
-----
Setup probe
-----
cp -p /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_probe.txt /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_probe.txt /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_probe.txt /cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/d/Project/Ameba_D/code/v03_181225/project/realtek_amebaD_cm4_gcc_verification/asdk'
```

Fig 1-11 KM4 Probe setup

#### 1.4.1.2 Linux

Before using Probe, its driver is required to be installed. Obtain the **RLX\_Probe\_Linux\_Driver\_v2.3.11p22** under tools/probe and install it correctly, to install the driver, the **read me.txt** under **RLX\_Probe\_Linux\_Driver\_v2.3.11p22** can be referenced. Then connect TCK pin of Probe to SWD CLK pin and TMS pin of Probe to SWD DATA pin. What's more, a common ground is needed between Probe Board and Ameba-D Device Board.

After the installation of the software pack, in both folder **project/realtek\_amebaD\_cm0\_gcc\_verification/jlink\_script** and **project/realtek\_amebaD\_cm4\_gcc\_verification/jlink\_script**, a soft link should be created to link the elf in **RLX\_Probe\_Linux\_Driver\_v2.3.11p22**, as Fig 1-12 shows.



Fig 1-12 Creating soft link to elf

Open a new terminal under the corresponding project folder and type the following command to start probe server. This terminal should NOT be closed if you want to download software or enter GDB debugger mode.

For KM0, open a new terminal under **project/realtek\_amebaD\_cm0\_gcc\_verification/jlink\_script**, and type **\$ sudo ./rlx\_probe\_driver.elf** (see Fig 1-13). If connecting successfully, the log is shown as Fig 1-14.

```
wlan5@RS-wlan5: ~/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/jlink_script
File Edit View Search Terminal Help
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/jlink_script$ sudo ./rlx_probe_driver.elf
*****
RLX PROBE Driver
version: 2.3.11p22
Build : 18:30 01/04/2019
copyright (C) 2019 Realtek Semiconductor Corp.
All rights reserved.
Email : dong0127.fang@realsil.com.cn (Ext : 56704 in Realsil)
Email : yf_chen@realsil.com.cn (Ext : 56134 in Realsil)
Email : cwchen02@realtek.com.tw (Ext : 15548 in Realtek)
*****
Socket created successfully!
Network socket 1 initialize success ,bind port 2331!
Test USB read/write to probe register/memory ,please wait .....
It will last for almost 1-3 seconds.
Test USB read/write probe register success!
Test USB read/write to probe register/memory success!
RLX Probe FPGA version : v3.11
Thers is NO ARM TAP! Please Check The Target!
*****
TAP 1 Core 0 Initialize Begin...
*****
ARM DAP Debug DP (DPIDR) is 0x6ba02477;
ARM DAP Debug Port DPIDR is 0x6ba02477;
Check DEBUG power up status succeeded!
Check SYSTEM power up status succeeded!
DP CTRL = 0xf0000000!
Check DEBUG Reset succeed!
AP 0 IDR REG: 0x54770002
AP 1 IDR REG: 0x84770001
AP 2 IDR REG: 0x84770001
AP 3 IDR REG: 0x54770002
AP 4 IDR REG: 0x00000000
There are 4 Access Port(AP) !
*****
AP0: MEM-AP APB, IDR: 0x54770002, CFG: 0x00000000!
    This MEM_AP does not support 256-bit access!
```

Fig 1-13 KMO probe GDB server connection setting under Linux

```
wlan5@RS-wlan5: ~/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/jlink_script
File Edit View Search Terminal Help
DAURHSTATUS = 0x0000000f!
This Core does not support Secure Non-Invasive Debug !
This Core does not support Secure Invasive Debug !
This Core supports Non-Secure Non-Invasive Debug !
This Core supports Non-Secure Invasive Debug !
DHCSR = 0x00030003
This Core is in NON-Secure state, concurrent write to CDS would be ignored!
Now Access by Non-Secure Request!
KMO halted!
This Core is implemented by Realtek Semiconductor Corporation.
This is a KMO processor!KMO found CPUID = 0x721cd200, Revision is -1p0!
DCB_DCSR = 0x00000000;
NVIC_DFSR = 0x00000001;
NVIC_AIRCR = 0x1a520000; little-endian;
DCB_DCRRSR = 0x00000000;
DCB_DCRRDR = 0x00000000;
DWT_CYCCNT = 0x00000000;
DWT_MASK0 = 0x00000000;
DWT_FUNCTIONS = 0x50000000;
This MCU has a Flash Patch Breakpoint version 2!
This MCU has 2 of code comparators and 0 literal comparators in FPB!
Renapping not supported!
DWT_CTRL = 0x1bb00000;
DWT_VCCNT = 0x00000000;
DWT_COMP0 = 0x00000000;
This MCU has 1 comparators!
This MCU supports Trace sampling and exception tracing!
This MCU does not include external match signals, CMPMATCH[N]!
This MCU supports a cycle counter!
This MCU supports the profiling counters!
Program flow prediction disabled!Instruction caches enabled!Data and unified caches enabled!
Cache is implemented at level 1, and is separate Instruction & Data Caches!
Level 1 I-Cache information:
I-Cache supports Write-Through!
I-Cache supports Write-Back!
I-Cache supports Read-Allocation!
I-Cache does not support Write-Allocation!
The processor's I-cache number of sets is 256!
The processor's I-cache number of ways is 2!
The processor's I-cache number of linesize is 8 Words!
The processor's I-cache size is 16 KB!
Level 1 D-Cache information:
D-Cache supports Write-Through!
D-Cache supports Write-Back!
D-Cache supports Read-Allocation!
D-Cache does not support Write-Allocation!
The processor's D-cache number of sets is 64!
The processor's D-cache number of ways is 2!
The processor's D-cache number of linesize is 8Words!
The processor's D-cache size is 4KB!
*****
TAP 1 Core 0 Initialize Over !
SUCCESS to trigger this core
*****
```

Fig 1-14 KMO probe GDB server connection success under Linux

Open a new terminal under the same project folder, type **\$ make setup GDB\_SERVER=probe** command before using probe to download software or enter GDB debugger.



```
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification$ cd ..
wlan5@RS-wlan5:~/v03/V03_bak/project$ cd realtek_amebaD_cm0_gcc_verification/
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification$ make setup GDB SERVER=probe
make -C asdk setup
make[1]: Entering directory '/home/wlan5/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/asdk'
-----
Setup probe
-----
cp -p /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_probe.txt /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_probe.txt /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
```

Fig 1-15 KM0 J-Link terminal setup under Linux

For KM4, open a new terminal under **project/realtek\_amebaD\_cm4\_gcc\_verification/jlink\_script**, and type **\$ sudo ./rlx\_probe\_driver.elf** (see Fig 1-16). If connecting successfully, the log is shown as Fig 1-17.



```
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/jlink_script$ cd ..
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification$ cd realtek_amebaD_cm4_gcc_verification/
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification$ ./rlx_probe_driver.elf
=====
RLX PROBE Driver
version: 2.3.11p22
Build : 18:30 01/04/2019
copyright (C) 2019 Realtek Semiconductor Corp.
All rights reserved.
Email : dong0127.fang@realsil.com.cn (Ext : 56704 in Realsil)
Email : yf_chen@realsil.com.cn (Ext : 56134 in Realsil)
Email : cwchen02@realtek.com.tw (Ext : 15549 in Realtek)
=====
Socket created successfully!
Network socket 1 initialized success ,bind port 3333!
Test USB read/write to probe register/memory ,please wait .....
It will last for almost 3 seconds.
Test USB read/write probe register success!
Test USB read/write to probe register/memory success!
RLX Probe FPGA Version : v3.11
Thers is NO ARM TAPI! Please Check The Target!
=====
TAP 1 Core 0 Initialize Begin...
=====
ARM DAP Debug DP (DPIDR) is 0x0ba0247f;
ARM DAP Debug Port DPIDR is 0x0ba0247f;
```

Fig 1-16 KM4 probe GDB server connection setting under Linux

```
wlan5@RS-wlan5: ~/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification$ ./link_script
File Edit View Search Terminal Help
This Core supports Non-Secure Non-Invasive Debug !
This Core supports Non-Secure Invasive Debug !
DHCSR = 0x00130003
This Core is in Secure state, concurrent write to CDS would be ignored!
Now Access by Secure Request!
KM4 halted!
This Core is implemented by Realtek Semiconductor Corporation.
This is a KM4 processor! KM4 found CPUID = 0x721fd220, Revision is r1p0!
    DCB_DRCSR 0x0001300003;
    NVIC_DFSR 0x00000009;
    NVIC_AIRCR 0xfa050000; little-endian;
    DCB_DCRSR 0x00000000;
    DCB_DCRDR 0x00000000;
    DWT_CYCCNT 0x00000000;
    DWT_MASKO 0x00000000;
    DWT_FUNCTION0 0x58000000;
SAU information:
    SAU ATTR: Memory is marked as Secure and is not Non-secure callable!
The MPU is disabled!
    This MCU has has a Flash Patch Breakpoint version 2!
    This MCU has 2 of code comparators and 0 literal comparators in FPB!
    Remapping not supported!
    DWT_CTRL 0x1b000000;
    DWT_CYCCNT 0x00000000;
    DWT_COMP0 0x00000000;
    This MCU has 1 comparators!
    This MCU supports Trace sampling and exception tracing!
    This MCU does not include external match signals, CMPMATCH[N]!
    This MCU supports a cycle counter!
    This MCU supports the profiling counters.
Program flow prediction disabled! Instruction caches disabled! Data and unified caches disabled!
Cache is implemented at level 1, and is separate Instrcution & Data Caches!
Level 1 I-Cache infomation:
    I-Cache supports Write-Through!
    I-Cache supports Write-Back!
    I-Cache supports Read-Allocation!
    I-Cache does not support Write-Allocation!
    The processor's I-cache number of sets is 512!
    The processor's I-cache number of ways is 2!
    The processor's I-cache number of linesize is 8 Words
    The processor's I-cache size is 32 KB!
Level 1 D-Cache infomation:
    D-Cache supports Write-Through!
    D-Cache supports Write-Back!
    D-Cache supports Read-Allocation!
    D-Cache supports Write-Allocation!
    The processor's D-cache number of sets is 64!
    The processor's D-cache number of ways is 2!
    The processor's D-cache number of linesize 16 Words
    The processor's D-cache size is 4KB!
/***** TAP 1 Core 0 Initialize over ****/
***** SUCCESS to Trigger this Core ****/
*****
```

Fig 1-17 KM4 probe GDB server connection success under Linux

Open a new terminal under the same project folder, type **\$ make setup GDB\_SERVER=probe** command before using probe to enter GDB debugger.

```
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification$ make s
etup GDB SERVER=probe
make -C asdk setup
make[1]: Entering directory '/home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk'
Setup probe
...
cp -p /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_probe.txt /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_probe.txt /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_probe.txt /home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/home/wlan5/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification/asdk'
wlan5@RS-wlan5:~/v03/V03_bak/project/realtek_amebaD_cm4_gcc_verification$
```

Fig 1-18 KM4 probe terminal setup under Linux

## 1.4.2 J-Link

Ameba-D also supports J-Link debugger. You need to do some hardware configuration to use J-Link debugger, that is welding SWD connectors to HDK board and connecting with dupont line. The SWD pin definitions are listed on the bottom side. and we recommend to weld the connector on the bottom side. After finishing these configuration, connect it to PC side.

**Note:** If Virtual Machine (VM) is used as your platform, make sure the USB connection setting between VM host and client is correct, so that the VM client can detect the device.

### 1.4.2.1 Windows

#### (1) Install J-Link GDB server

Besides the hardware configuration, J-Link GDB server is also required to install. For Windows, click <https://www.segger.com/downloads/jlink> and download the software in “**J-Link Software and Documentation Pack**”, then install it correctly.

**Note:** The version of J-Link GDB server displayed in the pictures below is just an example, you can select the latest version to download.

#### (2) Execute the cm0\_jlink.bat

After the installation of the software pack, execute the **cm0\_jlink.bat** under **project/realtek\_amebaD\_cm0\_gcc\_verification/jlink\_script**.

**Note:** The default path of J-Link driver in **cm0\_jlink.bat** file is **C:\Program Files (x86)\SEGGER\JLink\_V634b\JLinkGDBServer.exe**, you may have to change the path according to your own settings.

The started J-Link GDB server looks like Fig 1-19. This window should NOT be closed if you want to download software or enter GDB debugger mode.



Fig 1-19 KM0 J-Link GDB server connection under windows

#### (3) Setup J-Link for KM0

On the Cygwin terminal, as Fig 1-20 shows, type **\$ make setup GDB\_SERVER=jlink** command before using J-Link to download software or enter GDB debugger.

```

keire_wang@834671516 /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification
$ make setup GDB_SERVER=jlink
make -C asdk setup
make[1]: Entering directory '/cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk'
Setup jlink
cp -p /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt /cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/e/SDK/project/realtek_amebaD_cm0_gcc_verification/asdk'

```

Fig 1-20 KM0 J-Link setup

(4) Execute the **cm4\_jlink.bat**

Execute the **cm4\_jlink.bat** under **project/realtek\_amebaD\_cm4\_gcc\_verification/jlink\_script** the same as executing the **cm0\_jlink.bat**. The started J-Link GDB server looks like Fig 1-21. This window should NOT be closed if you want to download software or enter GDB debugger mode.



Fig 1-21 KM4 J-Link GDB server connection under Windows

## (5) Setup J-Link for KM4

On the Cygwin terminal, as Fig 1-22 shows, type **\$ make setup GDB\_SERVER=jlink** command before using J-Link to download software or enter GDB debugger.

```

/cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification
claire_wang@B34671516 /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification
$ make setup GDB_SERVER=jlink
make -C asdk setup
make[1]: Entering directory '/cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk'
-----
Setup jlink
-----
cp -p /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt /cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/e/SDK/project/realtek_amebaD_cm4_gcc_verification/asdk'

```

Fig 1-22 KM4 J-Link Setup

#### 1.4.2.2 Linux

For J-Link GDB server, click <https://www.segger.com/downloads/jlink> and download the software in “J-Link Software and Documentation Pack”. We suggest using Debian package manager to install the Debian version.

- \$ dpkg -i jlink\_6.0.7\_x86\_64.deb

After the installation of the software pack, there is a tool named “JLinkGDBServer” under JLink directory. Take Ubuntu 18.04 as an example, the JLinkGDBServer can be found at `/opt/SEGGER/JLink`. Open a new terminal under the corresponding project folder and type the following command to start GDB server. This terminal should NOT be closed if you want to download software or enter GDB debugger mode.

For KMO, open a new terminal under `project/realtek_amebaD_cm0_gcc_verification/jlink_script`, and type `$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m23 -if SWD -scriptfile AP1_KM0.JLinkScript -port 2331`.

```

derek@derek: ~/work/sdk_gcc_release_wjy/sdk-amebad-beta_v3/project/realtek_amebaD_cm0_gcc_verification/jlink_script$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m23 -if SWD -scriptfile AP1_KM0.JLinkScript -port 2331
SEGGER J-Link CDB Server V6.32d Command Line Version

JLinkARM.dll V6.32d (DLL compiled May 28 2018 16:58:57)

Command line: -device cortex-m23 -if SWD -scriptfile AP1_KM0.JLinkScript -port 2331
-----CDB Server start settings-----
GDBinit file: none
GDB Server Listening port: 2331
SWO raw output listening port: 2332
Terminal I/O port: 2333
Accept remote connection: yes
Generate logfile: off
Verify download: off
Init regs on start: off
Silent mode: off
Single run mode: off
Target connection timeout: 0 ms
-----J-Link related settings-----
J-Link Host interface: USB
J-Link script: AP1_KM0.JLinkScript

```

Fig 1-23 KM0 J-Link GDB server connection setting under Linux

If connecting successfully, the log is shown as Fig 1-24.

```

File Edit View Search Terminal Help
Silent mode: off
Single run mode: off
Target connection timeout: 0 ms
-----J-Link related settings-----
J-Link Host interface: USB
J-Link script: AP1_KM0.JLinkScript
J-Link settings file: none
-----Target related settings-----
Target device: cortex-m23
Target interface: SWD
Target interface speed: 4000kHz
Target endian: little

Connecting to J-Link...
J-Link is connected.
Firmware: J-Link V9 compiled Apr 20 2018 16:17:26
Hardware: V9.40
S/N: 59425868
Feature(s): RDI, GDB, FlashDL, FlashBP, JFlash, RDDR
Checking target voltage...
Target voltage: 3.38 V
Listening on TCP/IP port 2331
Connecting to target...Connected to target
Waiting for GDB connection...

```

Fig 1-24 KM0 J-Link GDB server connection success under Linux

Open a new terminal under the same project folder, type `$ make setup GDB_SERVER=jlink` command before using J-Link to download software or enter GDB debugger.

```

derek@realtek:~/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification$ make setup GDB_SERVER=jlink
make[1]: Entering directory '/home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk'
-----
Setup jlink
-----
cp -p /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk'
derek@realtek:~/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification$ 

```

Fig 1-25 KM0 J-Link terminal setup under Linux

For KM4, open a new terminal under `project/realtek_amebaD_cm4_gcc_verification/jlink_script`, and type `$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m33 -if SWD -scriptfile AP2_KM4.JLinkScript -port 2335`.

```
derek@derek: ~/work/sdk_gcc_release_wjy/sdk-amebad-beta_v3/project/realtek_amebaD_... File Edit View Search Terminal Help
derek@derek:~/work/sdk_gcc_release_wjy/sdk-amebad-beta_v3/project/realtek_amebaD...
[jm4_gcc_verification/jlink_script$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m33 -if SWD -scriptfile AP2_KM4.JLinkScript -port 2335
SEGGER J-Link GDB Server V6.32d Command Line Version

JLinkARM.dll V6.32d (DLL compiled May 28 2018 16:58:57)

Command line: -device cortex-m33 -if SWD -scriptfile AP2_KM4.JLinkScript -port 2
335
-----GDB Server start settings-----
GDBInit file: none
GDB Server Listening port: 2335
SWO raw output listening port: 2332
Terminal I/O port: 2333
Accept remote connection: yes
Generate logfile: off
Verify download: off
Init regs on start: off
Silent mode: off
Single run mode: off
Target connection timeout: 0 ms
-----J-Link related settings-----
J-Link Host interface: USB
J-Link script: AP2_KM4.JLinkScript
```

Fig 1-26 KM4 J-Link GDB server connection setting under Linux

If connecting successfully, the log is shown as Fig 1-27.

```
File Edit View Search Terminal Help
Silent mode: off
Single run mode: off
Target connection timeout: 0 ms
-----J-Link related settings-----
J-Link Host interface: USB
J-Link script: AP2_KM4.JLinkScript
J-Link settings file: none
-----Target related settings-----
Target device: cortex-m33
Target interface: SWD
Target interface speed: 4000kHz
Target endian: little

Connecting to J-Link...
J-Link is connected.
Firmware: J-Link V9 compiled Apr 20 2018 16:47:26
Hardware: V9.40
S/N: 59125868
Feature(s): RDI, GDB, FlashDL, FlashBP, JFlash, RDDI
Changing target voltage...
Target voltage: 3.37 V
Listening on TCP/IP port 2335
Connecting to target... Connected to target
Waiting for GDB connection...
```

Fig 1-27 KM4 J-Link GDB server connection success under Linux

Open a new terminal under the same project folder, type **\$ make setup GDB\_SERVER=jlink** command before using J-Link to enter GDB debugger.

```
derek@realtek:~/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification$ make setup GDB_SERVER=jlink
make -C asdk setup
make[1]: Entering directory '/home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk'
derek@realtek:~/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification$ Setup jlink
derek@realtek:~/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification$ cp -p /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk'
derek@realtek:~/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification$
```

Fig 1-28 KM4 J-Link terminal setup under Linux

## 1.5 Download Code to Flash

This section illustrates how to download image to flash.

To download software into Ameba-D Device Board, make sure steps mentioned in section 1.3 to 1.4 are done and then type **\$ make flash** command on Cygwin (Windows) or terminal (Linux).

Both KM0 and KM4 download codes by this command. This command downloads the software into flash and it will take a few seconds to finish. After downloading successfully, as shown in Fig 1-29, press the **Reset** button and you can see that the device is booted with new image now.

```
Breakpoint 1, RtlFlashProgram () at /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/flashloader/rtl_flash_download.c:8
8
88          asm("nop");
dump for check

Breakpoint 2, RtlFlashProgram () at /home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/flashloader/rtl_flash_download.c:120
120          if (FlashWriteComplete == 1) {
make[1]: Leaving directory '/home/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm4_gcc_verification/asdk'
```

Fig 1-29 Download codes success log

**Note:** For Probe download,

- Make chip enter download mode before download code to flash
- KM4 project code download also through **cm0\_RTL\_Probe.bat**
- Probe use USB 1.0 interface, so its download rate is limited by the USB 1.0 protocol

## 1.6 Enter GDB Debugger

To enter GDB debugger mode, make sure steps mentioned in section 1.3 to 1.5 are finished and then reset the device first. After resetting the chip, type **\$ make debug** command on Cygwin (Windows) or terminal (Linux).

- For Windows, a popup window will be opened, as shown in Fig 1-30.



Fig 1-30 Debug window under Windows

- For Linux, the log is shown in Fig 1-31.

```
File Edit View Search Terminal Help
tion/asdk/.../oolchain/linux/asdk-6.4.1/linux/newlib/bin/arm-none-eabi-gdb -x /h
ome/derek/work/sdk_gcc_release_wjy/v03/project/realtek_amebaD_cm0_gcc_verificati
on/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
GNU gdb (Realtek ASDK-6.4.1 Build 2773) 7.12.50.20170111-git
Copyright (C) 2017 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law. Type "show copying"
and "show warranty" for details.
This GDB was configured as "--host=i686-pc-linux --target=arm-none-eabi".
Type "show configuration" for configuration details.
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
Find the GDB manual and other documentation resources online at:
<http://www.gnu.org/software/gdb/documentation/>.
For help, type "help".
Type "apropos word" to search for commands related to "word".
warning: No executable has been specified and target does not support
determining executable automatically. Try using the "file" command.
0x100075da in ?? ()
Notification of completion for asynchronous execution commands is off.
(gdb) -
```

Fig 1-31 Debug window under Linux

## 1.7 Command List

The commands used above are listed in Table 1-1.

Table 1-1 Command list

| Usage     | Command                        | Description                             |
|-----------|--------------------------------|-----------------------------------------|
| all       | \$ make all                    | Compile project to generate ram_all.bin |
| setup     | \$ make setup GDB_SERVER=jlink | Setup GDB_SERVER                        |
| flash     | \$ make flash                  | Download ram_all.bin to flash           |
| clean     | \$ make clean                  | Remove compile result (*.bin, *.o, ...) |
| clean_all | \$ make clean_all              | Remove compile result and toolchains    |
| debug     | \$ make debug                  | Enter GDB debugger mode                 |

## 1.8 GDB Debugger Basic Usage

GDB, the GNU project debugger, allows you to examine the program while it executes, and it is helpful for catching bugs. Section 1.6 has described how to enter GDB debugger mode, this section illustrates some basic usage of GDB commands. For further information about GDB debugger and its commands, click <https://www.gnu.org/software/gdb/> and <https://sourceware.org/gdb/current/onlinedocs/gdb/>.

Table 1-2 GDB debugger command list

| Usage                           | Command      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Breakpoint                      | \$ break     | Breakpoints are set with the <i>break</i> command (abbreviated <i>b</i> ). The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Set-Breaks.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Set-Breaks.html</a>                                                                                                                                                                                                |
| Watchpoint                      | \$ watch     | You can use a watchpoint to stop execution whenever the value of an expression changes. The related commands include <i>watch</i> , <i>rwatch</i> , and <i>awatch</i> . And the usage of these commands can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Set-Watchpoints.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Set-Watchpoints.html</a><br><b>Note:</b> Keep the range of watchpoints less than 20 bytes. |
| Print breakpoints & watchpoints | \$ info      | To print a table of all breakpoints, watchpoints set and not deleted, use the <i>info</i> command. You can simply type <i>info</i> to know its usage.                                                                                                                                                                                                                                                                                                 |
| Delete breakpoints              | \$ delete    | To eliminate the breakpoints, use the <i>delete</i> command (abbreviated <i>d</i> ). The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Delete-Breaks.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Delete-Breaks.html</a> .                                                                                                                                                                              |
| Continue                        | \$ continue  | To resume program execution, use the <i>continue</i> command (abbreviated <i>c</i> ). The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Continuing-and-Stepping.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Continuing-and-Stepping.html</a> .                                                                                                                                                         |
| Step                            | \$ step      | To step into a function call, use the <i>step</i> command (abbreviated <i>s</i> ). It will continue running your program until control reaches a different source line. The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Continuing-and-Stepping.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Continuing-and-Stepping.html</a> .                                                                       |
| Next                            | \$ next      | To step through the program, use the <i>next</i> command (abbreviated <i>n</i> ). The execution will stop when control reaches a different line of code at the original stack level. The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Continuing-and-Stepping.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Continuing-and-Stepping.html</a> .                                                          |
| Quit                            | \$ quit      | To exit GDB debugger, use the <i>quit</i> command (abbreviated <i>q</i> ), or type an end-of-file character (usually <i>Ctrl-d</i> ). The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Quitting-GDB.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Quitting-GDB.html</a> .                                                                                                                               |
| Backtrace                       | \$ backtrace | A backtrace is a summary of how your program got where it is. You can use <i>backtrace</i> command (abbreviated <i>bt</i> ) to print a backtrace of the entire stack. The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Backtrace.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Backtrace.html</a> .                                                                                                     |
| Print source lines              | \$ list      | To print lines from a source file, use the <i>list</i> command (abbreviated <i>l</i> ). The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/List.html">https://sourceware.org/gdb/current/onlinedocs/gdb/List.html</a> .                                                                                                                                                                                             |
| Examine data                    | \$ print     | To examine data in your program, you can use <i>print</i> command (abbreviated <i>p</i> ). It evaluates and prints the value of an expression. The usage can be found at <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Data.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Data.html</a> .                                                                                                                                      |

## 1.9 Q & A

**Q1:** “Error 127” for Building Code.

**Q1:** 编译的时候产生“Error 127”的错误。

```

.../component/common/application/apple/homekit/crypto/poly1305 -I/cygdrive/f/v03
/project/realtek_amebaD_cm0_gcc_verification/asdk/../../../../component/common/application/apple/homekit/crypto/ed25519 -I/cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/../../../../component/common/application/apple/homekit/crypto/ed25519/core -I/cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/../../../../component/common/application/apple/homekit/crypto/sha512 -DCONFIG_PLATFORMFORM_8721D /cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/flashloader/rtl_flash_download.c -o rtl_flash_download.o
make[2]: *** [/cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/Makefile.include.gen:351: rtl_flash_download.o] Error 127
make[2]: Leaving directory '/cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/make/flashloader'
make[1]: *** [Makefile:87: make_subdirs_f_flashloader] Error 2
make[1]: Leaving directory '/cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk'
make: *** [Makefile:15: all] Error 2

```

Fig 1-32 “Error 127” error message

**A1:** If you use **\$ make all** command to build code but encounter “Error 127” error message like Fig 1-32, it’s caused by incorrect Cygwin package. Both 32-bit and 64-bit operating system need to install 32-bit installation Cygwin Package – setup-x86.exe.

**A1:** 如果在使用**\$ make all** 命令编译 code 出现如图 Fig 1-32 所示的“Error 127”错误信息，这是由于 Cygwin 的安装包版本不正确导致的。无论 32 位还是 64 位的操作系统，都需要安装 32 位的 Cygwin 的安装包 – setup-x86.exe。

**Q2:** “Permission denied” Error under Linux.

**Q2:** 在 Linux 环境下编译产生“Permission denied”的错误。

```

===== Image manipulating start =====
/home/jesse/sdk-amebad-beta_v4_20180914/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/prepend_header.sh /home/jesse/sdk-amebad-beta_v4_20180914/project/realtek_amebaD_cm0_gcc_verification/asdk/image/ram_1.bin __ram_start_table_start__ /home/jesse/sdk-amebad-beta_v4_20180914/project/realtek_amebaD_cm0_gcc_verification/asdk/image/tar/get_loader.map
make[1]: execvp: /home/jesse/sdk-amebad-beta_v4_20180914/project/realtek_amebaD_cm0_gcc_verification/asdk/gnu_utility/prepend_header.sh: Permission denied
Makefile:163: recipe for target 'linker_loader' failed
make[1]: *** [linker_loader] Error 127
make[1]: Leaving directory '/home/jesse/sdk-amebad-beta_v4_20180914/project/realtek_amebaD_cm0_gcc_verification/asdk'
Makefile:15: recipe for target 'all' failed
make: *** [all] Error 2

```

Fig 1-33 “Permission denied” error message under Linux

**A2:** If you use **\$ make all** command to compile project but encounter “Permission denied” error message like Fig 1-33, it’s caused by file access permission. You can enter **chmod -R 777 \$SDK\_FILENAME** under the path of SDK first to change the permission of files in SDK, and then continue compile operation.

**A2:** 如果在使用**\$ make all** 命令编译 code 出现如图 Fig 1-33 所示的“Permission denied”错误信息，这是文件访问权限受限所致。需要在 SDK 的路径下键入“**chmod -R 777 \$SDK\_FILENAME**”去修改 SDK 文件的权限，之后再进行编译即可。

**Q3:** How to reset KM0/KM4 under debug?

**Q3:** 如何在调试的时候让 KM0/KM4 重新启动？

**A3:** Steps to reset KM0 and KM4 are different.

- For KM0, you need to use the “monitor reset” instruction in corresponding rtl\_gdb\_debug.txt to reset it under debug. The default path of this file is under \project\realtek\_amebaD\_cm0\_gcc\_verification\asdk\gnu\_utility\gnu\_script\rtl\_gdb\_debug.txt. Please change the default setting which is “#monitor reset 1” to “monitor reset”.
- For KM4, you need to use the “monitor reset” instruction in corresponding rtl\_gdb\_debug.txt first (this process is similar to the process of KM0). Then, set the bit[25] of memory address 0x4800\_03f8 to 1 because the boot process of KM4 is controlled by the KM0. Without this

- operation, the KM4 can't jump out of the boot function. Details of this operation are as follows: After executing "make debug" instruction, a debug window pops up. In this window. Set bit[25] to 1, then type "c", the KM4 is reset. refer to Fig 1-34 for more information.
- Only resetting KM0 may cause KM4 to work in an abnormal way because reboot KM0 will change some settings of KM4. If you find KM4 doesn't work after rebooting KM0, you should reset KM4.

**A3:** KM0 和 KM4 的 System reset 是分别控制的。

- 对于 KM0, 需要在相应的 rtl\_gdb\_debug.txt 中使用“**monitor reset**”指令。该文件的默认地址是 \project\realtek\_amebaD\_cm0\_gcc\_verification\asdk\gnu\_utility\gnu\_script。请将默认设定的“#monitor reset 1”改为“monitor reset”。
- 对于 KM4, 先使用相应的 rtl\_gdb\_debug.txt 中的“**monitor reset**”指令（与 KM0 操作类似）。因为 KM4 的 boot 是由 KM0 控制的, 对于 KM4 system reset debug, 需要在 reset 之前先将 0x4800\_03f8 的 bit[25]置 1, 否则 KM4 会在启动函数中跳不出来。具体操作: 在执行 make debug 指令之后会弹出调试窗口, 在该窗口执行 bit[25]置 1 操作之后键入“c”就可以实现 KM4 system reset。请参考 Fig 1-34 进行操作。
- 因为执行 KM0 的复位操作时时会去更改 KM4 的一些配置, 所以只复位 KM0 时可能导致 KM4 不正常工作。若复位 KM0 后 KM4 不能正常工作, 请尝试复位 KM4.

```
GNU gdb <Realtek ASDK-6.4.1 Build #778> 7.12.50.20170111-git
Copyright (C) 2017 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY to the extent permitted by law. Type "show copying"
and "show warranty" for details.
This GDB was configured as "--host=i686-pc-cygwin --target=arm-none-eabi".
Type "show configuration" for configuration details.
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
Find the GDB manual and other documentation resources online at:
<http://www.gnu.org/software/gdb/documentation/>.
For help, type "help".
Type "apropos word" to search for commands related to "word".
warning: No executable has been specified and target does not support
determining executable automatically. Try using the "file" command.
0x0e0007564 in ?? (<gdb>)
Notification of completion for asynchronous execution commands is off.
Resetting target.
(gdb) x/1ux $r25
0x480003f8: 0x00000201
(gdb) set $r25=0x02000201
(gdb) b main
Breakpoint 1: file main.c, line 211.
(gdb) c
Continuing.

Breakpoint 1, main () at main.c:211
211      {
(gdb) n
212          if (!wifi_config.wifi_ultra_low_power)
(gdb) n
213              InterruptRegister<IPC_INTHandler> IPC IRQ, IPCM0_DEU, 10);
(gdb) n
217      InterruptEn<IPC_IRQ, 10>;
(gdb) c
Continuing.
```

Fig 1-34 KM4 “monitor reset” setting

## 2 C++ Standards Support in GCC

### 2.1 Introduction

This chapter mainly introduces how to build C++ codes in Ameba-D GCC project.

It might be noted that “iostream” is not available currently, and would be supported later.

**Note:** “iostream” is not available currently.

### 2.2 How to Build C++ Codes

The following steps are necessary to support C++ in current GCC project.

- (1) Modify Link script: rlx8721d\_img2\_ns.ld.

```
.xip_image2.text :
{
    __flash_text_start__ = .;
    *(.img2_custom_signature*)
    *(.text*)
    *(.rodata*)
    /* Add This for C++ support */
    = ALIGN(4);
    __preinit_array_start = .;
    KEEP(*(.preinit_array))
    __preinit_array_end = .;
    . = ALIGN(4);
    __init_array_start = .;
    KEEP(*($ORT(.init_array.*)))
    KEEP(*(.init_array))
    __init_array_end = .;
    . = ALIGN(4);
    __fini_array_start = .;
    KEEP(*($ORT(.fini_array.*)))
    KEEP(*(.fini_array))
    __fini_array_end = .;
    /*-----*/
    . = ALIGN (4);
    __cmd_table_start__ = .;
    KEEP(*(.cmd.table.data))
    __cmd_table_end__ = .;
    __flash_text_end__ = .;
    . = ALIGN (16);
} > KM4_IMG2

/* Add This for C++ support */
._ARM.extab :
{
    *(.ARM.extab* .gnu.linkonce.armextab.*)
} > KM4_IMG2

._ARM.exidx :
{
    __exidx_start = .;
    *(.ARM.exidx* .gnu.linkonce.armexidx.*)
    __exidx_end = .;
    end = .;
} > KM4_IMG2

.wrap_printf = 0x1010a3f5;
.wrap_sprintf = 0x1010a471;
.wrap_strcat = 0x10111635;
.wrap_strcmp = 0x10111675;
.wrap_strerror = 0x10111745;
.wrap_strncmp = 0x101118f9;
.wrap_strlen = 0x10111839;
.wrap_strnlen = 0x10111a85;
.wrap_strncat = 0x1011189d;
.wrap_stpbrk = 0x10111a39;
.wrap_strstr = 0x10111d25;
.wrap_strtok = 0x10111201d;
.wrap_strerror = 0x10111a65;
.wrap_strtoll = 0x10111ff0;
.wrap strtoul = 0x101122e9;
.wrap strtoull = 0x10111ff3d;
.wrap_atoi = 0x101115e1;
.wrap strcpy = 0x10111709;
.wrap strncpy = 0x10111190;
.wrap memset = 0x101110ea1;
.wrap memcpy = 0x101110d2d;
.wrap memcmp = 0x101110cc9;
.wrap memmove = 0x101110dd9;
.wrap sprintf = 0x1010a49d;
.wrap malloc = puPortMalloc;
.wrap realloc = puPortReAlloc;
.wrap free = vPortFree;
/*-----*/
```

- (2) Modify startup code: rtl8721dhp\_app\_start.c.

```

#ifndef __GNUC__
/* Add This for C++ support to avoid compile error */
void _init(void){}
#endif

// The Main App entry point
void app_start(void)
{
    simulation_stage_set(SIMULATION_KM4_CPUID, BIT_KM4_APP_ENTER);

    SOCPS_InitSYSIRQ_HP();

    __NUIC_SetVector(SVCall IRQn, (VOID*)xPortSVCHandler);
    __NUIC_SetVector(PendSV IRQn, (VOID*)xPortPendSVHandler);
    __NUIC_SetVector(SysTick IRQn, (VOID*)xPortSysTickHandler);

#ifndef __ICCARM__
    _iar_cstart_call_ctors(NULL);
#endif

#ifndef __GNUC__
/* Add This for C++ support */
    __libc_init_array();
#endif

    // Force SP align to 8 byte not 4 byte (initial SP is 4 byte align)
    __asm(
        "mov r0, sp\n"
        "bic r0, r0, #7\\0"
        "mov sp, r0\\0"
    );
    main();
}

```

## (3) Modify makefile.

- project\realtek\_amebaD\_cm4\_gcc\_verification\asdk\Makefile

```

linker_image2_ns:
    @echo "===== linker img2_ns start ====="
    $(LD) $(LD_ARG) target_img2.elf $(RAM_OBJS_LIST) $(LINK_ROM_LIB_NS) $(LINK_APP_LIB) $(IMAGE_TARGET_FOLDER)/cmse_implib.lib
    -lm -lc -lnosys -lgcc -lsprintf

```

- project\realtek\_amebaD\_cm4\_gcc\_verification\asdk\Makefile.include.gen

```

#GLOBAL_CFLAGS += -specs nosys.specs
#GLOBAL_CFLAGS += -fno-short-enums
GLOBAL_CFLAGS += -Wextra

GLOBAL_CFLAGS += $(IFLAGS)
GLOBAL_CFLAGS += -DCONFIG_PLATFORM_8721D
GLOBAL_CFLAGS += -DCONFIG_USEMBEDTLS_ROM_ALG
GLOBAL_CFLAGS += -DCONFIG_FUNCION_00_OPTIMIZE
GLOBAL_CFLAGS += -UDM_ODM_SUPPORT_TYPE=32

CFLAGS = $(GLOBAL_CFLAGS)
CFLAGS += -Wstrict-prototypes

CPPFLAGS = $(GLOBAL_CFLAGS)
CPPFLAGS += -std=c++11 -fno-use-cxa-atexit

```

```

LD_ARG += -nostartfiles
LD_ARG += -specs nosys.specs
LD_ARG += -Wl,-gc-sections
LD_ARG += -Wl,-warn-section-align
LD_ARG += -Wl,Map-text.map
LD_ARG += -Wl,-craf
LD_ARG += -Wl,-build-id=none
LD_ARG += -sane-temp

LD_ARG += -Wl,-wrap,strcat -Wl,-wrap,strchr -Wl,-wrap,strcmp
LD_ARG += -Wl,-wrap,strncmp -Wl,-wrap,strncpy -Wl,-wrap,strlen -Wl,-wrap,strlcpy
LD_ARG += -Wl,-wrap,strncpy -Wl,-wrap,strlen -Wl,-wrap,strncat -Wl,-wrap,strpbrk
LD_ARG += -Wl,-wrap,strstr -Wl,-wrap,strtok -Wl,-wrap,strspn
LD_ARG += -Wl,-wrap,strsep -Wl,-wrap,strxfrm -Wl,-wrap,strtod
LD_ARG += -Wl,-wrap,strtoI -Wl,-wrap,strtoull -Wl,-wrap,atoi
LD_ARG += -Wl,-wrap,atoui -Wl,-wrap,atof -Wl,-wrap,atoul
LD_ARG += -Wl,-wrap,memalloc -Wl,-wrap,free -Wl,-wrap,realloc
LD_ARG += -Wl,-wrap,memcmp -Wl,-wrap,memcpy
LD_ARG += -Wl,-wrap,newmove -Wl,-wrap,memset
LD_ARG += -Wl,-wrap,printf -Wl,-wrap,sprintf
LD_ARG += -Wl,-wrap,snprintf -Wl,-wrap,vsnprintf

```

```

*****
#          RULES TO GENERATE OBJECT FILE FROM .CPP FILE
#
%.*:%.cpp
    $(CC) $(CPPFLAGS) $< -o $@
```

## (4) Add C++ files into project.

We have tested a small program and provide it as an example, which can be found in **main.cpp**.

## (5) Use “make” command in console to rebuild project with C++ files.

### 3 SDK Architecture

The architecture of SDK is shown in Fig 1-1.



Fig 3-1 SDK architecture

#### 3.1 Component

##### 3.1.1 Common

| Items       | Description                                                                                                                                                                                                                                                                            |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| api         | <ul style="list-style-type: none"><li>● AT command</li><li>● Platform_stdlib.h: standard library header</li><li>● Wi-Fi driver interface</li><li>● Wi-Fi promisc mode interface</li><li>● Wi-Fi simple configuration</li></ul>                                                         |
| application | <ul style="list-style-type: none"><li>● DuerOS</li><li>● MQTT</li></ul>                                                                                                                                                                                                                |
| bluetooth   | <ul style="list-style-type: none"><li>● Internal BT driver</li></ul>                                                                                                                                                                                                                   |
| drivers     | <ul style="list-style-type: none"><li>● alc5616/ alc5640/ alc5651/ alc5660/ alc5679/ alc5680/ sgtl5000 drivers</li><li>● IR NEC driver</li><li>● SDIO host driver</li><li>● Ameba-D internal codec ri6548 driver</li><li>● USB host and device drivers</li><li>● WLAN driver</li></ul> |
| example     | <ul style="list-style-type: none"><li>● Utility examples: wlan_fast_connect/ssl_download/fatfs/mdns/media_geo_mp4 ...</li></ul>                                                                                                                                                        |
| file_system | <ul style="list-style-type: none"><li>● file_system</li></ul>                                                                                                                                                                                                                          |
| mbed        | <ul style="list-style-type: none"><li>● mbed API source code</li></ul>                                                                                                                                                                                                                 |
| media       | <ul style="list-style-type: none"><li>● multi-media framework</li></ul>                                                                                                                                                                                                                |
| network     | <ul style="list-style-type: none"><li>● coap</li><li>● dhcp</li><li>● http</li><li>● lwip</li><li>● mDNS</li><li>● rtsp</li><li>● sntp</li><li>● ssl (MBEDTLS)</li><li>● tftp</li><li>● websocket</li></ul>                                                                            |
| utilities   | <ul style="list-style-type: none"><li>● cJSON</li><li>● http_client</li><li>● ssl_client</li><li>● tcpecho</li><li>● udpecho</li><li>● webserver/xml</li></ul>                                                                                                                         |

### 3.1.2 OS

| Items    | Description                                                                                                                                                                                        |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| freertos | FreeRTOS source code                                                                                                                                                                               |
| os_dep   | <ul style="list-style-type: none"> <li>● <b>osdep_service.c:</b> Realtek encapsulating interface for FreeRTOS</li> <li>● <b>osdep_service.h:</b> Realtek encapsulating interface header</li> </ul> |

### 3.1.3 SOC

| Items        | Description                                                                                        |
|--------------|----------------------------------------------------------------------------------------------------|
| app          | Monitor and shell                                                                                  |
| bootloader   | Boot loader                                                                                        |
| cmsis        | ARM headers, include ARM CPU registers and operations                                              |
| cmsis-dsp    | ARM cmsis-dsp source code                                                                          |
| fwlib        | Low level drivers like: UART/I2C/SPI/Timer/PWM ...                                                 |
| fwlib_usrcfg | User configuration files, maintained by user: bootcfg/trustzonecfg/sleepcfg/flashcfg/pinmapcfg ... |
| swlib        | Standard software library supported by ROM code, like: _memcpy/_memcmp ...                         |

## 3.2 Doc

| Items               | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| api_doc&api_doc.htm | <p>Document for Some API: lwip/wifi/rtos ...</p>  <p>The screenshot shows a navigation bar with tabs: Main Page, Modules (selected), Data Structures, and Files. Below the navigation bar, there is a section titled "Modules" with a list of modules: Ameba SDK, Network, COAP, HTTPC, HTTPD, HAL, WLAN, WPS/P2P, NIC, and RTOS.</p> |
| AN0004              | Realtek low power Wi-Fi mp user guide                                                                                                                                                                                                                                                                                                                                                                                   |
| AN0011              | Realtek WLAN simple configuration                                                                                                                                                                                                                                                                                                                                                                                       |
| AN0012              | Realtek secure socket layer (SSL)                                                                                                                                                                                                                                                                                                                                                                                       |
| AN0025              | Realtek AT command                                                                                                                                                                                                                                                                                                                                                                                                      |
| AN0043              | Realtek mdns user guide                                                                                                                                                                                                                                                                                                                                                                                                 |
| AN0075              | Realtek Ameba-all at command v2.0                                                                                                                                                                                                                                                                                                                                                                                       |
| UM0150              | Realtek Ameba CoAP User Guide.pdf                                                                                                                                                                                                                                                                                                                                                                                       |

## 3.3 Tools

| Items     | Description                                               |
|-----------|-----------------------------------------------------------|
| ImageTool | tools\AmebaZ\Image_Tool: image tool for Ameba-D & Ameba-Z |
| iperf.exe | iperf for Wi-Fi performance test                          |

### 3.4 GCC Project for KM4

The architecture of KM4 project is shown in Fig 3-2.



Fig 3-2 Architecture of project

| Items           | Description                                                                                                                                                                                                                                                             |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| asdk            | <ul style="list-style-type: none"> <li>● Menuconfig</li> <li>● Link script</li> <li>● Library: lib_wlan.a/lib_wps.a/rom_symbol ...</li> <li>● Make files</li> </ul>                                                                                                     |
| example_sources | Peripherals driver demo code: ADC/Audio/LCD/UART/I2C ...                                                                                                                                                                                                                |
| mbed_api        | Mbed API headers                                                                                                                                                                                                                                                        |
| inc             | <ul style="list-style-type: none"> <li>● FreeRTOSConfig.h: config FreeRTOS</li> <li>● Main.h</li> <li>● platform_autoconf.h: generated by "make menuconfig"</li> <li>● platform_opts.h: config some utilities like example code in component\common\example.</li> </ul> |
| ld              | link script for every image                                                                                                                                                                                                                                             |
| src             | main.c                                                                                                                                                                                                                                                                  |
| toolchain       | GCC & Cygwin toolchain                                                                                                                                                                                                                                                  |
| Makefile        | Top makefile                                                                                                                                                                                                                                                            |

### 3.5 Critical Header Files

| Items             | Description                                                                                                                                                                                                                                   |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| basic_types.h     | SUCCESS/FAIL/ TRUE/ FALSE/ NULL/u8/u16/u32/ BOOL/BIT(x) ...                                                                                                                                                                                   |
| Platform_stdlib.h | Standard library API: memcmp/strcpy/atoll/strpbrk/sscanf/printf/sprint/snprintf/vsnprintf ...                                                                                                                                                 |
| Section_config.h  | Section definition used in link script: IMAGE2_RAM_TEXT_SECTION ...                                                                                                                                                                           |
| mbed api headers  | Project/realtek_amebad_cm4_xxx/mbed_api/xxxx:<br><ul style="list-style-type: none"> <li>● Peripheral header files for mbed_api</li> <li>● If you use mbed api, you should include related headers</li> </ul>                                  |
| ameba_soc.h       | <ul style="list-style-type: none"> <li>● Peripheral header files for raw api</li> <li>● If you use raw api, you should include this header</li> <li>● Raw API have more features than mbed_api, mbed api just have basic features.</li> </ul> |

## 4 GCC Makefile

### 4.1 KM4 Makefile Architecture

The architecture of KM4 makefile is shown in Fig 4-1.

```
realtek_amebaD_cm4_gcc_verification\Makefile-->
realtek_amebaD_cm4_gcc_verification\asdk\Makefile-->
realtek_amebaD_cm4_gcc_verification\asdk\make\Makefile-->
    realtek_amebaD_cm4_gcc_verification\asdk\make\api\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\app\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\application\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\audio\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\bootloader\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\cmsis\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\customer\Makefile→
        realtek_amebaD_cm4_gcc_verification\asdk\make\customer\sram\Makefile: how to build code into ram
        realtek_amebaD_cm4_gcc_verification\asdk\make\customer\xip\Makefile: how to build code into flash
        realtek_amebaD_cm4_gcc_verification\asdk\make\customer\library\Makefile: how to build library
    realtek_amebaD_cm4_gcc_verification\asdk\make\drivers\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\example\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\file_system\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\mbed\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\mbedtls\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\network\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\os\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\rtl_bluetooth\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\ssl\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\target\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\utilities\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\utilities_example\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\wlan\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\wps\Makefile
    realtek_amebaD_cm4_gcc_verification\asdk\make\utilities_example\Makefile
```

Fig 4-1 KM4 makefile architecture

### 4.2 How to Build Code into Flash

Makefile in customer/xip is an example for how to build code into flash.

```
include $(MAKE_INCLUDE_GEN)

.PHONY: all clean

#####
#           VARIABLES
#####
#Add your include path here
IFLAGS += -I$(BASEDIR)/component/common/network/coap/include

#Set your source code path here
CUSTOMER_DIR = $(BASEDIR)/project/realtek_amebaD_cm4_gcc_verification/asdk/make/customer/xip

#####
#           Source FILE LIST
#####
#add your source code here
OBJS += \
    $(CUSTOMER_DIR)/xip_test.o

#####
#           Include Dependency
#####
-include $(OBJS:.o=.d)

#####
#           RULES TO GENERATE TARGETS
#####
all: CORE_TARGETS COPY_RAM_DBJS

#####
#           GENERATE OBJECT FILE
#####
CORE_TARGETS: $(OBJS)

#####
#           CLEAN GENERATED FILES
#####
clean: CLEAN_OBJS
    $(REMOVE) *.o
    $(REMOVE) *.i
    $(REMOVE) *.S
    $(REMOVE) *.d

-include $(DEPS)
```

### 4.3 How to Build Code into SRAM

Makefile in customer/SRAM is an example for how to build code into flash.

```
.PHONY: all clean

#*****
#          VARIABLES
#*****
#Add your include path here
IFLAGS += #-I$(BASEDIR)/component/common/network/coap/include

#set your source code path here
CUSTOMER_DIR = $(BASEDIR)/project/realtek_amebaD_cm4_gcc_verification/asdk/make/customer/sram

#*****
#          Source FILE LIST
#*****
#Add your source code here
OBJS += \
    $(CUSTOMER_DIR)/ram_test.o\

#*****
#          Include Dependency
#*****
-include $(OBJS:.o=.d)

#*****
#          RULES TO GENERATE TARGETS
#*****
#all: CORE_TARGETS RENAME_CODE2SRAM COPY_RAM_OBJS
#          GENERATE OBJECT FILE
#*****
CORE_TARGETS: $(OBJS)

%.o:%.c
    $(CC) $(GLOBAL_CFLAGS) $(MODULE_IFLAGS) $< -o $@

#*****
#          CLEAN GENERATED FILES
#*****
clean: CLEAN_OBJS
    $(REMOVE) *.o
    $(REMOVE) *.i
    $(REMOVE) *.s
    $(REMOVE) *.d

-include $(DEPS)
```

## 4.4 How to Use Section Attribute

Because SRAM space is limited, we suggest you to build critical code/data into SRAM and other code/data left in flash, then you should use section attribute “IMAGE2\_RAM\_TEXT\_SECTION” to locate some of your functions into SRAM.

```
#include <basic_types.h>
#include <section_config.h>

/* const is read only, it will build into flash */
const u32 xip_test_read_only_data = 0;

/* non read only data will build into SRAM */
u32 xip_test_data = 0;

/* code in in SRAM */
IMAGE2_RAM_TEXT_SECTION
void test_critical_code(void)
{
}

/* code in in Flash */
void test_non_critical_code(void)
{}
```

**Note:**

- You should include “section\_config.h”
- Const/read only data will build into flash
- Non read only data will build into SRAM (So if you need read only data build into SRAM to run faster, you should not use “const”)
- Functions limited by IMAGE2\_RAM\_TEXT\_SECTION will build into SRAM
- Functions not limited by IMAGE2\_RAM\_TEXT\_SECTION will build into FLASH

## 4.5 How to Build Library

Makefile in customer/library is an example for build user library.

```
include $(MAKE_INCLUDE_GEN)

.PHONY: all clean

#####
#          VARIABLES
#####
#add your include path here
FLAGS += #-I$(BASEDIR)/component/common/network/coap/include

#set your source code path here
CUSTOMER_DIR = $(BASEDIR)/project/realtek_amebaD_cm4_gcc_verification/asdk/make/customer/library

#####
#          Source FILE LIST
#####
#add your source code here
OBJS += \
    $(CUSTOMER_DIR)/lib_user_test.o\

#####
#          Dependency
#####
-include $(OBJS:.o=.d)

#####
#          RULES TO GENERATE TARGETS
#####

# Define the Rules to build the core targets
all: CORE_TARGETS COPY_RAM_OBJS
    $(AR) rvs lib_user.a $(OBJS) $(OBJS_SRAM)
    $(MOVE) -f lib_user.a $(ROOTDIR)/lib/application

#####
#          GENERATE OBJECT FILE
#####
CORE_TARGETS: $(OBJS)

#####
#          RULES TO CLEAN TARGETS
#####
clean: CLEAN_OBJS
    $(REMOVE) *.o
    $(REMOVE) *.i
    $(REMOVE) *.s
    $(REMOVE) *.d
```

## 4.6 How to Add Library

Open realtek\_amebaD\_cm4\_gcc\_verification\asdk\Makefile and add lib\_user.a into LINK\_APP\_LIB:

```
LINK_APP_LIB += $(ROOTDIR)/lib/application/lib_user.a
```

## 5 GCC Standard Library

### 5.1 Introduction

This chapter mainly introduces how to use GCC standard library in Ameba-D.

To save flash memory and improve efficiency, ROM code has implemented a standard software library, like `_memcpy` and `_memcmp`, and some functions are simplified version in ROM software library, such as `printf` and `sprintf`. So, there are two methods when using standard library functions such as `printf` and `sprintf` in GCC:

- (1) Using ROM software library.
- (2) Using GCC standard library.

### 5.2 Default Library Function Use in SDK

In current SDK, the default library function use is illustrated in Fig 5-1 and Table 5-1



Fig 5-1 Library function guide

Table 5-1 Library function default use

| Items                       | Functions                                                                                                                                                                                   |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Using ROM software library  | memchr/memcmp/memcpy/memset/memmove/strcmp/strcpy/strlen/strncmp/strncpy/strsep/strtok/strcat/strchr/strncat/strstr/atoll/atoi/strpbrrk/strtoul/strtol/rand/srand                           |
| Using GCC standard library  | fprintf/puts/...                                                                                                                                                                            |
| Use library is configurable | printf/sprintf/snprintf/vsnprintf/sscanf<br><b>Note:</b> The default is to use ROM software library; you can switch to use GCC standard library by defining macro <code>STD_PRINTF</code> . |

Because `printf`/`sprintf`/`snprintf`/`vsnprintf`/`sscanf` in ROM software library are a simplified version compared with these in GCC standard library, they only support a few formats. In order to remind users that unsupported format occurs when using these functions in ROM library, SDK wraps up these functions.

Table 5-2 Wrapper functions

| Items  | Wrapper functions        |
|--------|--------------------------|
| printf | <code>_rtl_printf</code> |

|           |                |
|-----------|----------------|
| sprintf   | _rtl_sprintf   |
| snprintf  | _rtl_snprintf  |
| vsnprintf | _rtl_vsnprintf |
| sscanf    | _rtl_sscanf    |

When using printf/sprintf/snprintf/vsnprintf/sscanf in GCC standard library, the memory size will increase 40KB compared with using these functions in ROM software library.

### 5.3 How to Use Configurable Function in GCC Standard Library

Compared to printf/sprintf/snprintf/vsnprintf/sscanf functions in GCC library, which only support a few formats in ROM library. The following content takes printf as an example.

Table 5-3 Printf supported format

| Library          | Printf Supported Format                                     |
|------------------|-------------------------------------------------------------|
| ROM software lib | %s, %x, %X, %p, %P, %d, %c                                  |
| GCC standard lib | %s, %x, %X, %p, %P, %d, %c, %f, %L, %l, %u, %U, %e, %E, ... |

For printf/sprint/snprintf/vsnprintf/sscanf, ROM library is linked by default. If “format not support!” log dumps out in trace tool, it means that unsupported format occurs, you should link these functions to GCC standard library.

To use printf/sprint/snprintf/vsnprintf/sscanf in GCC standard library, follow these steps:

- (1) Add #define STD\_PRINTF in the front.

There are two cases:

| Items                                                                                           | Description                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| case 1: add #define STD_PRINTF in the front of c files, and need to include "platform_stdlib.h" | Change printf/sprint/snprintf/vsnprintf/sscanf of some files link to GCC standard library.<br>Example:<br><pre>// main.c #define STD_PRINTF  #include "main.h" #include "platform_stdlib.h"  int main(void) {     printf("%f\n", 1.2);     printf("%u\n", 20); }</pre> |
| case 2: add #define STD_PRINTF in the front of "platform_stdlib_rtl8721d.h"                     | Change printf/sprint/snprintf/vsnprintf/sscanf of all SDK link to GCC standard library.                                                                                                                                                                                |

- (2) Modify "platform\_stdlib\_rtl8721d.h" file if you don't want to switch to use all the five functions in GCC standard library.

In SDK, macro STD\_PRINTF controls printf/sprintf/snprintf/vsnprintf/sscanf at the same time. If you only want to configure some but not all, you need to modify "platform\_stdlib\_rtl8721d.h" file.

For example, if you only want to use printf in GCC standard library, and other four functions sprintf/snprintf/vsnprintf/sscanf maintain the default state, you need to modify "platform\_stdlib\_rtl8721d.h" file.

```

00026: #ifndef STD_PRINTF
00027:     #undef printf
00028:     #undef vsnprintf
00029:     #undef sprintf
00030:     #undef snprintf
00031:     #undef sscanf
00032: #endif
00033:     #undef memchr
00034:     #undef memcmp
00035:     #undef memcpy
00036:     #undef memset
00037:     #undef memmove
00038:     #undef strcmp
00039:     #undef strcpy
00040:     #undef strlen
00041:     #undef strncmp
00042:     #undef strncpy
00043:     #undef strsep
00044:     #undef strtok
00045:     #undef strcat
00046:     #undef strchr
00047:     #undef strncat
00048:     #undef strstr
00049:     #undef atol
00050:     #undef atoi
00051:     #undef strpbrk
00052:     #undef strtoul
00053:     #undef strtol
00054:     #undef rand
00055: #ifndef STD_PRINTF
00056:     #define printf _rtl_printf
00057:     #define sprintf _rtl_sprintf
00058:     #define snprintf _rtl_snprintf
00059:     #define vsnprintf _rtl_vsnprintf
00060:     #define sscanf _rtl_sscanf
00061: #endif

```

modify →

```

#ifndef STD_PRINTF
#define printf _rtl_printf
#endif
#define sprintf _rtl_sprintf
#define snprintf _rtl_snprintf
#define vsnprintf _rtl_vsnprintf
#define sscanf _rtl_sscanf

```

```

#ifndef STD_PRINTF
#define printf _rtl_printf
#endif
#define sprintf _rtl_sprintf
#define snprintf _rtl_snprintf
#define vsnprintf _rtl_vsnprintf
#define sscanf _rtl_sscanf

```

// NULL function  
// if use sscanf in std/libc.a, please delete \_strtol

## 5.4 Tips

- If user wants to use GCC standard library, we recommend only link some user specified c files to GCC standard library instead of link all SDK to GCC standard library, because printf/sprintf/snprintf/vsnprintf/sscanf in our SDK should link to ROM standard library.
- If use printf in GCC standard library libc.a, and there is no "\n" in the end, please use fflush(stdout) after printf to dump log in cache. For example:
 

```
printf("hello");
fflush(stdout);
```
- In current GCC project, KM0 does not support floating-point temporarily, so printf cannot dump %f in KM0 in default GCC project setting.
- if using sscanf in GCC standard library libc.a, delete \_strtol\_r symbol in rlx8721d\_rom\_symbol\_acut.id.

## 6 IAR Build Environment Setup

This document illustrates how to setup IAR develop environment for Realtek Ameba-D SDK, including build project, download images and debugging.

### 6.1 Requirement

#### 6.1.1 IAR workbench

IAR provides an IDE environment for code building, downloading, and debugging. Please check "IAR Embedded Workbench" on <http://www.iar.com/>, and trial version is available for 30 days.

**Note:** To support ARMv8-M with Security Extension (Ameba-D HS CPU, also called KM4), **IAR version should be 8.30 or above.**

#### 6.1.2 J-Link probe

If users need to download images or debug code for Ameba-D with IAR, then a J-Link adapter is necessary.

**Note:** For Ameba-D CPU support reason, the **J-Link probe version should be V9 or above.**

### 6.2 Hardware Configuration

The hardware block diagram of Ameba-D demo board is shown in Fig 6-1. The following modules are mentioned in subsequent chapters:

- USB TO UART: supply power and print logs, baud rate is 115200 bps.
- SWD: J-Link SWD interface, used for image downloading and debugging with IAR.
- Reset button: reset Ameba-D to run firmware after IAR completes downloading.



The Ameba-D SWD interface should be connected with J-Link probe as follows:



Fig 6-2 J-Link SWD connection diagram



Fig 6-3 J-Link and Ameba-D SWD connection

## 6.3 How to Use IAR

### 6.3.1 IAR Build

Because Ameba-D is dual-core CPUs platform, two workspaces are provided to build for each core in **project\realtek\_amebaD\_va0\_example\EWARM-RELEASE**.

- Project\_lp\_release.eww (KM0 workspace) contains the following sub-projects:
  - km0\_bootloader
  - km0\_application
- Project\_hp\_release.eww (KM4 workspace) contains the following sub-projects:
  - km4\_bootloader
  - km4\_application
  - km4\_secure: project of Trustzone-protected code, also known as RDP. It's not necessary if RDP is not enabled in your system.

The following steps show how to build Ameba-D project:

- (1) Open IAR Workbench.

- (2) Click File > Open Workspace... to open project.



- (3) Select Project\_lp\_release.eww (km0 project) or Project\_hp\_release.eww (km4 project).

Click Project > Options, General Options > Target > Processor Variant > Core, verify the CPU configurations according to Table 6-1.

**Note:** When building SDK for the first time, users should build BOTH km0 project and km4 project. Other times, users only need to make the modified project.

Table 6-1 CPU Configuration

| Workspace | Project         | Core       | FPU                    | DSP Extension | TrustZone  |
|-----------|-----------------|------------|------------------------|---------------|------------|
| KM0       | km0_bootloader  | Cortex-M23 | -                      | -             | -          |
|           | km0_application |            |                        |               |            |
| KM4       | km4_bootloader  | Cortex-M33 | VFPv5 single precision | Yes           | Secure     |
|           | km4_application |            |                        |               | Non-secure |
|           | km4_secure      |            |                        |               | Secure     |



Fig 6-4 KM0 processor options



Fig 6-5 KM4 processor options

- (4) Add your own files to the project if customized development is required.  
Click Project > Add Files.../Add Group..., then select target files.



Fig 6-6 Add Files

**Note:** By default, the code in new files would be placed in Flash and execute in place (XIP). If you would like to execute in SRAM, right click the target group or files, click Options > C/C++ Compiler > Output, set "Code section name" as ".image2.ram.text".



Fig 6-7 Designate files to SRAM

- (5) To build project, click Project > Rebuild All/Make.



Fig 6-8 Build project

**Note:** After building, IAR would execute Post-build action to generate images from executable files. This may takes several seconds. As a result, users should wait to see and make sure the new images are generated before downloading. Otherwise, the old images would download instead.

Finally, you would get images in **project\realtek\_amebaz\_va0\_example\EWARM-RELEASE \Debug\Exe**.

Table 6-2 Generated images

| Workspace | Project         | Generated Images                                         | Download Image     |
|-----------|-----------------|----------------------------------------------------------|--------------------|
| KM0       | km0_bootloader  | km0_boot_all.bin                                         | km0_boot_all.bin   |
|           | km0_application | km0_image2_all.bin<br>km0_km4_image2.bin (Combined IMG2) | km0_km4_image2.bin |
| KM4       | km4_bootloader  | km4_boot_all.bin                                         | km4_boot_all.bin   |
|           | km4_application | km4_image2_all.bin<br>km0_km4_image2.bin (Combined IMG2) | km0_km4_image2.bin |
|           | km4_secure      | km4_image3_all.bin                                       | -                  |

The generated images can be downloaded in two ways:

- IAR J-Link SWD, and this would be introduced in next section.
- Ameba-D Image Tool, please refer to Chapter Image Tool for more information.

### 6.3.2 IAR Download

The Ameba-D demo board supports JLINK SWD download and debug.

Image of each project can be download individually as Table 6-2 shows. As km0 and km4 application image are combined in memory layout, so they would be download together. "km4\_image3\_all.bin" needs to be encrypted before download, so it can't download directly. You can refer to RDP chapter to see how to manipulate it.

**Note:** Considering KM4 is power-on by KM0, users should make sure that KM0 has already boot up before download images to KM4. Otherwise, J-Link can't connect to KM4 and show the error message as Fig 6-9 shows.



Fig 6-9 J-Link can't find KM4

As a result, if the flash memory is empty, the sequence to download images is:

- (1) Download for km0\_bootloader and km0\_application projects
- (2) Click Reset button on demo board to make KM0 boots up
- (3) Download for km4\_bootloader and km4\_application projects

During development, if flash memory is not empty and km0 can boot up successfully, then users can download updated images to KM4 directly, and there is no need to re-download for km0.

The following steps show how to download image for target project with IAR:

- (1) Set the target project as active project in the workspace:
  - Workspace > Overview, right click the target project > Set as Active, as Fig 6-10 shows
  - Or switch to the target project view, as Fig 6-11 shows.



Fig 6-10 Set Target Project as Active



Fig 6-11 Switch to Target Project View

- (2) Check J-link debugger setting is correct. Click Project > Options > Debugger > Setup > Driver, and choose "J-Link/J-Trace".



Fig 6-12 Debugger setup

Then click Debugger > J-Link/J-Trace > Connection > Interface and choose "SWD".



Fig 6-13 J-Link interface setup

- (3) Click Project > Download > Download active application, then image downloading would start.



Fig 6-14 Download Active Application

- (4) When downloading, Ameba-D would print log. Users can check log to see if download successfully.

```
[FlashInit] image_size:f48, link_address:8000000, flags:0
[FlashErase] block_start:0, block_size:1000
[FlashWrite] block_start:0, offset_into_block:0, count:f48
[FlashInit] image_size:82000, link_address:8006000, flags:0
[FlashErase] block_start:6000, block_size:1000
[FlashErase] block_start:7000, block_size:1000
[FlashErase] block_start:8000, block_size:1000
[FlashErase] block_start:9000, block_size:1000
[FlashErase] block_start:a000, block_size:1000
[FlashErase] block_start:b000, block_size:1000
[FlashErase] block_start:c000, block_size:1000
[FlashErase] block_start:d000, block_size:1000
[FlashErase] block_start:e000, block_size:1000
[FlashErase] block_start:f000, block_size:1000
[FlashErase] block_start:10000, block_size:1000
[FlashErase] block_start:11000, block_size:1000
[FlashWrite] block_start:6000, offset_into_block:0, count:c000
[FlashErase] block_start:12000, block_size:1000
[FlashErase] block_start:13000, block_size:1000
[FlashErase] block_start:14000, block_size:1000
[FlashErase] block_start:15000, block_size:1000
[FlashErase] block_start:16000, block_size:1000
[FlashErase] block_start:17000, block_size:1000
[FlashErase] block_start:18000, block_size:1000
[FlashErase] block_start:19000, block_size:1000
[FlashErase] block_start:1a000, block_size:1000
[FlashErase] block_start:1b000, block_size:1000
[FlashErase] block_start:1c000, block_size:1000
[FlashErase] block_start:1d000, block_size:1000
[FlashWrite] block_start:12000, offset_into_block:0, count:c000
[FlashErase] block_start:1e000, block_size:1000
[FlashErase] block_start:1f000, block_size:1000
[FlashErase] block_start:20000, block_size:1000
[FlashErase] block_start:21000, block_size:1000
[FlashErase] block_start:22000, block_size:1000
[FlashErase] block_start:23000, block_size:1000
[FlashErase] block_start:24000, block_size:1000
```

Fig 6-15 Download log

- (5) You can also erase all parts of the flash memory if necessary.



Fig 6-16 Erase Flash memory

### 6.3.3 IAR Debug

Users can debug or trace KM0 and KM4 system individually with J-Link SWD.

**Note:** Considering KM4 is power-on by KM0, users should make sure that KM0 has already boot up before debug KM4. For KM0, there is no such requirement because KM0 is power-on immediately after reset.

Users should follow the steps to debug and trace code of target project with IAR:

- (1) Set the target project as active project and verify the debugger configurations as 0 step (1) and step (2).
- (2) Click Project > "Download and Debug" or "Debug without Downloading"
  - Download and Debug: downloads the application and debug the project object file. If necessary, a make will be performed before download to ensure the project is up to date.
  - Debug without Downloading: debug the project object file



Fig 6-17 Debug options

- (3) When start IAR C-SPY to debug, it would firstly reset the target CPU and run to main function.



Fig 6-18 Run to main when debugging

- (4) Toggles a breakpoint at the statement or instruction that contains or is located near the cursor in the source window. The "Toggle Breakpoint" button is on the debug toolbar.



Fig 6-19 Toggle breakpoint

(5) You can trace code step by step with “Step Into” or “Go” until trigger a breakpoint. These function buttons are available on toolbar.

## 6.4 How to Build Sample Code

The example source code is located in “project\realtek\_amebaD\_va0\_example\example\_sources”.

To build sample code, you should copy the “src” folder in the target example to “project\realtek\_amebaD\_va0\_example\rtl8721dhp\_project\” and replace the original ones.

For example, to use i2c example code, you can copy “src” and “inc” from “project\realtek\_amebaz\_va0\_example\example\_sources\i2c\”.



Fig 6-20 Build sample code

## 7 Demo Board

### 7.1 PCB Layout Overview

The PCB layout overview is shown in Fig 7-1.



Fig 7-1 Demo board – PCB layout overview

### 7.2 Pin Out

The pin out board is shown in Fig 7-2.

- Blue Box is for Arduino REF
- Red Box is all the GPIO pins



Fig 7-2 Demo board – pin out

### 7.3 DC Power Supply

The 3.3V/1.8V power supply board is shown in Fig 7-3.

- Jump JP1 is used to select 3.3V or 1.8V power supply
- Jump J38 is for current test. You can test the current power after taking off the R43.



Fig 7-3 Demo board – 3.3V/1.8V power supply

When you select power supply, please refer to Table 7-1.

Table 7-1 3.3V/1.8V power supply selection

| Power Supply Select | JP1           |
|---------------------|---------------|
| 3.3V                | 1-2 connected |
| 1.8V                | 2-3 connected |

## 7.4 USB Interface Configuration

The USB interface configuration board is shown in Fig 7-4. R72/R75/R77 will part on for normal GPIO using by default. When testing USB function, you need to take off R77 and part on R73&R74.



Fig 7-4 Demo board – USB interface configuration

## 7.5 LOGUART

The LOGUART board is shown in Fig 7-5. When you select LOGUART, please refer to Table 7-2.



Fig 7-5 Demo board – LOGUART

Table 7-2 LOGUART selection

| LOGUART Select | JP1           |
|----------------|---------------|
| FT232          | 1-2 connected |
| DAP            | 2-3 connected |

## 7.6 SWD

The SWD board is shown in Fig 7-6.



Fig 7-6 Demo board – SWD

**Note:** For 1V0 board, there is a bug, you should use CLK as DATA, and use DATA as CLK.

## 7.7 VBAT ADC

The VBAT ADC board is shown in Fig 7-7. J1 is used to test VBAT ADC.



Fig 7-7 Demo board – VBAT ADC

## 8 ImageTool

### 8.1 Introduction

This chapter introduces how to use ImageTool to encrypt, generate and download images. As shown in Fig 8-1, ImageTool has four tabpages.

- Download: used as image download server to transmit images to Ameba through UART.
- Generate: contact individual images and generate a composite image.
- Encrypt: encrypt images which are used for firmware protection.
- Security: generate key pair and signature for secure bootloader and save as new image.



Fig 8-1 ImageTool UI

### 8.2 Environment Setup

#### 8.2.1 Hardware Setup

The hardware setup is shown in Fig 8-2.



Fig 8-2 Hardware setup

### 8.2.2 Software Setup

- Environment Requirements: EX. WinXP, Win 7 Above, Microsoft .NET Framework 3.5
- ImageTool.exe Location: \tools\AmebaZ\Image\_Tool\ImageTool.exe

| Name                                    | Date modified        | Type                  | Size   |
|-----------------------------------------|----------------------|-----------------------|--------|
| AN0112 Realtek Ameba-Z Image Tool us... | 11/27/2018 11:32 ... | Adobe Acrobat D...    | 950 KB |
| ChangeLog.txt                           | 11/27/2018 11:32 ... | Text Document         | 3 KB   |
| <b>ImageTool.exe</b>                    | 11/27/2018 11:32 ... | Application           | 279 KB |
| ImageTool.pdb                           | 11/27/2018 11:32 ... | VisualStudio.pdb...   | 172 KB |
| ImageTool\vhost.exe                     | 11/27/2018 11:32 ... | Application           | 14 KB  |
| ImageTool\vhost.exe.manifest            | 11/27/2018 11:32 ... | MANIFEST File         | 1 KB   |
| imgtool_flashloader_amebad.bin          | 11/27/2018 11:32 ... | BIN File              | 5 KB   |
| imgtool_flashloader_amebaz.bin          | 11/27/2018 11:32 ... | BIN File              | 6 KB   |
| SB.exe                                  | 11/27/2018 11:32 ... | Application           | 189 KB |
| TestListView.dll                        | 11/27/2018 11:32 ... | Application extens... | 5 KB   |
| TestListView.pdb                        | 11/27/2018 11:32 ... | VisualStudio.pdb...   | 14 KB  |

## 8.3 Download

### 8.3.1 Image Download

Assuming that the ImageTool on PC is a server, which sends images files to Ameba (client) through UART. The steps to download images to board is as following:

- (1) Ameba enters into UART\_DOWNLOAD mode.
  - a) Push the **UART DOWNLOAD** button and keep it pressed.
  - b) Re power on the board or press the **Reset** button.
  - c) Release the **UART DOWNLOAD** button. Now Ameba gets into UART DOWNLOAD mode and is ready to receive data.
- (2) Click **Chip Select** (in red) on UI and select chip (AmebaD or AmebaZ).
- (3) Select the corresponding serial port and transmission baud rate. The default baud rate is 1.5Mbps (recommended). Then click **Open** button.
- (4) Click the **Browse** button to select the images (km0\_boot\_all.bin/km4\_boot\_all.bin/km0\_km4\_image2.bin) to be programmed and input addresses.
  - The image path is located in **{path}\project\realtek\_amebaD\_cm0\_gcc\_verification\asdk\image** and **{path}\project\realtek\_amebaD\_cm4\_gcc\_verification\asdk\image**, where **{path}** is the location of the project on your own computer.
  - The default target address is the SDK default image address, you can use it directly.
- (5) Click **Download** button to start. The progress bar will show the transmit progress of each image. You can also get the message of operation successfully or errors from the log window.



Fig 8-3 ImageTool 'Download' tabpage setting

### 8.3.2 Flash Erase

Steps to erase flash are as following:

- (1) Ameba enters into UART\_DOWNLOAD mode as introduced in section 8.3.1.
- (2) Select the corresponding serial port and open it.
- (3) Input erase start address which has to be 4-byte aligned.
- (4) Input erase size which would be cast to a multiple of 4KB.
- (5) Click **Erase** button, and erase operation begins. You would get the operation result from the log window.



Fig 8-4 Flash erase operation

**Note:** Users don't need to erase flash manually before download images into flash. Image Download operation would erase flash automatically according to the image and address to be programmed.

### 8.3.3 Flash Status Operation

After some abnormal operations such as power lost when flash is programming, the flash would enter into Write Protection (WP) to protect some area against program and erase.

To release flash from WP state, the BPs in status register should be cleared. ImageTool provides the function of setting and getting flash status register value. To use it, the following steps are necessary.

- (1) Check the Read/Write Status Register Command and Sequence according to the flash datasheet. Notice that different flash IC would have different sequence.
- (2) Get Ameba into UART\_DOWNLOAD mode as introduced in section 8.3.1.
- (3) Select the corresponding serial port and open it.
- (4) Click **Advanced Settings** button in Fig 8-5, and the **Advanced Settings** window shown in Fig 8-6 popups.



Fig 8-5 'Advanced Settings' window

- (5) Select Read/Write Command and Length according to flash datasheet. If write status to flash, remember to input value.
- (6) Click **Read** button to read status register value, or **Write** button to write status value to flash.



Fig 8-6 Flash status operation

In case of MXIC flash chip, the status register is shown in Table 8-1.

- To clear BP bits, read status register configuration is as below:
  - Read Command: 0x05
  - Read Length: 1 Byte
- Write status register configuration is as below:
  - Write Command: 0x01
  - Write Length: 1 Byte
  - Register-1 Value: 0x40

Table 8-1 MXIC flash status register

| Bit | Name | Description                                                                                                                                                   | Volatile Bit |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 7   | SRWD | Status register write protect.<br><ul style="list-style-type: none"> <li>1: Status register write disable</li> <li>0: Status register write enable</li> </ul> | No           |
| 6   | QE   | Quad enable.<br><ul style="list-style-type: none"> <li>1: Quad enable</li> <li>0: Not Quad enable</li> </ul>                                                  | No           |
| 5   | BP3  | Level of protected block.                                                                                                                                     | No           |
| 4   | BP2  | Level of protected block.                                                                                                                                     | No           |
| 3   | BP1  | Level of protected block.                                                                                                                                     | No           |
| 2   | BPO  | Level of protected block.                                                                                                                                     | No           |
| 1   | WEL  | Write enable latch.<br><ul style="list-style-type: none"> <li>1: Write enable</li> <li>0: Not write enable</li> </ul>                                         | Yes          |
| 0   | WIP  | Write in progress bit.<br><ul style="list-style-type: none"> <li>1: Write operation</li> <li>0: Not in write operation</li> </ul>                             | Yes          |

Note: For other flash IC, please refer to corresponding datasheet. Otherwise, wrong operation would cause irreversible damage to flash.

## 8.4 Generate

The 'Generate' tabpage has two functions:

- Merge individual images and generate a composite image named **Image\_All.bin**
- Generate Cloud OTA image named **OTA\_All.bin**

### 8.4.1 Merge Images

Steps to generate a composite image are as following:

- Select **Image\_All** as Generate Target type (in red).
- Click **Browse** button to select images to be contacted and input corresponding relative address. The **Memory Layout** bar will show the relative positions of the selected images. If the contiguous images overlap, the overlapped area is in red color for warning.
- Click **Generate** button. Specify the output file name and path yourself in the popup 'Save As' window, the final image (**Image\_All.bin**) is generated.



Fig 8-7 Image\_All.bin generation

#### 8.4.2 Generate Cloud OTA Image

Steps to generate a Cloud OTA image are as following:

- (1) Select OTA\_All as Generate Target type (in red).
- (2) Input Image Version, the default value is 0xFFFFFFFF.
- (3) Click Browse button to select images. The address can be ignored. The Memory Layout bar will show the relative positions of the two images. If they overlap, the overlapped area is in red color for warning.
- (4) Click **Generate** button to specify output file name and path. After the operation is done, the cloud image (**OTA\_All.bin**) is generated.



Fig 8-8 OTA\_All generation

## 8.5 Encrypt

The 'Encrypt' tabpage is for encrypting images which is used in firmware protection. Steps to encrypt images are as following:

- (1) Select **Encryption Type**.
- (2) Input **Key** (16 bytes).
- (3) Select Images that need to be encrypted and input corresponding address.
- (4) Click **Encrypt** button. You will get the message of encryption from the log window. The encrypted images are named with “-en” after the original file, which located in the same directory.



Fig 8-9 ImageTool 'Encrypt' tabpage setting

## 8.6 Security

The 'Security' tabpage is used to generate secure boot image. Steps to generate Secure Boot Image are as following:

- (6) Input **Seed** (32 bytes), which is used to generate key pair.
- (7) Click **Gen Keypair** button to generate Public Key and Private Key.
- (8) Click **Browse** button to select the bootloader image, and input the flash address of this image.
- (9) Click **Gen Signature** button to calculate signature for the image.
- (10) Click **Save Image** button to generate new image which contains Secure Boot information and signature.



Fig 8-10 ImageTool 'Security' tabpage setting

# 9 Memory Layout

## 9.1 Flash Program Layout

The default flash layout used in SDK is illustrated in Fig 5-1 and Table 9-1. Because bootloader will be called by ROM code, the address of bootloader cannot be changed. Other addresses except bootloader can all be changed by user, but before you change these addresses, you have to make sure that you are familiar with Ameba-D system and SDK.



Fig 9-1 1M/2M flash program layout

Table 9-1 1M/2M flash program layout

| Items         | Start Address | Limited Address | Size  | Description                                                                                                  | Mandatory |
|---------------|---------------|-----------------|-------|--------------------------------------------------------------------------------------------------------------|-----------|
| KM0 Boot      | 0x0800_0000   | 0x0800_2000-1   | 8K    | KM0 bootloader code/data                                                                                     | Y         |
| Backup        | 0x0800_2000   | 0x0800_3000-1   | 4K    | Backup flash area, reserved for system use. When program system data, this area will be used as backup area. | Y         |
| System Data   | 0x0800_3000   | 0x0800_4000-1   | 4K    | System Data, user should program this area carefully.                                                        | Y         |
| KM4 Boot      | 0x0800_4000   | 0x0800_6000-1   | 8K    | KM4 bootloader code/data                                                                                     | Y         |
| KM0 IMG2 OTA1 | 0x0800_6000   | 0x0810_0000-1   | 1000K | KM0 image2 OTA1 code/data                                                                                    | N         |
| KM4 IMG2 OTA1 |               |                 |       | KM4 image2 OTA1 code/data                                                                                    | N         |
| KM4 IMG3 OTA1 |               |                 |       | RDP image OTA1 code/data                                                                                     | N         |
| User Data     | 0x0810_0000   | 0x0810_2000-1   | 8K    | Reserved for user data                                                                                       | N         |
|               | 0x0810_2000   | 0x0810_5000-1   | 12K   | BT FTL physical map                                                                                          | N         |
|               | 0x0810_5000   | 0x0810_6000-1   | 4K    | WIFI Fast Connect profile                                                                                    | N         |
| KM0 IMG2 OTA2 | 0x0810_6000   | 0x0820_0000-1   | 1000K | KM0 image2 OTA2 code/data                                                                                    | N         |
| KM4 IMG2 OTA2 |               |                 |       | KM4 image2 OTA2 code/data                                                                                    | N         |
| KM4 IMG3 OTA2 |               |                 |       | RDP image OTA2 code/data                                                                                     | N         |

There is an image header for every image; it helps the bootloader to load code or data to the correct destination address, or it's used to realize ECC secure boot.

### 9.1.1 Image Header without Secure Boot

Normal bootloader doesn't include secure boot signature, it's just used for loading code or data to the correct destination (see Fig 9-2 and Table 9-2).



Fig 9-2 Normal image header

Table 9-2 Image header without secure boot

| Items               | Comment                                    |
|---------------------|--------------------------------------------|
| Signature (8 bytes) | Bootloader Signature for flash calibration |
| Size (4 bytes)      | The size of Firmware Image                 |
| Address (4 bytes)   | Code executes start address after boot     |

### 9.1.2 Image Header with Secure Boot

Image header with secure includes secure boot signature, it is used to realize ECC secure boot (see Fig 9-3 and Table 9-3).



Fig 9-3 Security boot image header

Table 9-3 Image header with secure boot

| Items               | Comment                                                                                                                                                 |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Signature (8 bytes) | <ul style="list-style-type: none"> <li>● Image1 Signature is for flash calibration: 96969999</li> <li>● Image2 Signature is string: 81958711</li> </ul> |

|                                        |                                                                                                    |
|----------------------------------------|----------------------------------------------------------------------------------------------------|
| Size (4 bytes)                         | The size of Firmware Image                                                                         |
| Address (4 bytes)                      | Code executes start address after boot                                                             |
| Security Boot Header Address (4 bytes) | Indicate where the SB Header locates. Generally, the SB Header is appended to the end of the image |
| Security Boot Signature                | The generated signature, which is to be verified when boot.                                        |

**Note:**

- Secure Boot should be rechecked after the SoC wakeup from deepsleep.  
Cause: We can't detect whether the flash chip is swapped out by another flash with non-secure code or not during deepsleep.
- The start address of image data from which we start to calculate signature should be fixed.  
Cause: There are security risks when hacker attacks in the following way:
  - Copy the original image to another flash address
  - Overwrite the original image with non-secure image
  - Modify the start address in SB Header to the new flash address in step (1)
  - Restart, then the non-secure image would execute
- The length of image data that involved in signature calculation should be nonconfigurable.  
Cause: The length should be appropriate. It can't be too small, otherwise the image can't be protected well. And the signature is independent of image if the length is 0, which enables hacker to replace the firmware easily. For Ameba-D, the length is set to the image size, and the header length is not included.

### 9.1.3 System Data (4K)

The System data layout is illustrated in Fig 9-4 and Table 9-4.



Fig 9-4 System data layout

Table 9-4 System Data Layout

| Items     | Default    | Description         |
|-----------|------------|---------------------|
| BT_FW_DBG | 0xFFFFFFFF | Reserved for FW DBG |

### 9.1.4 User Data

There are totally 24KB for user data. Parts of this region are defined by default SDK:

Table 9-5 User Data Layout

| Items                     | Range                     | Description                                                                                                                                                                                                                      |
|---------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                  | 0x0810_0000~0x0810_2000-1 | Reserved for user data                                                                                                                                                                                                           |
| BT FTL                    | 0x0810_2000~0x0810_5000-1 | Bluetooth FTL physical map.<br>The start address is defined by <code>ftl_phy_page_start_addr</code> variable<br>( <code>rtl8721dhp_intfcfg.c</code> ).<br>If Bluetooth is not enabled in your system, this can be used by users. |
| WIFI Fast Connect Profile | 0x0810_5000~0x0810_6000-1 | Used to store WIFI fast connect profile. Defined by <code>FAST_RECONNECT_DATA</code> macro<br>( <code>platform_opts.h</code> ).                                                                                                  |

|  |  |                                                                                              |
|--|--|----------------------------------------------------------------------------------------------|
|  |  | If WIFI fast connect function is not enabled in your system, this area can be used by users. |
|--|--|----------------------------------------------------------------------------------------------|

**Warning:** If flash memory layout is modified and the 0x0800\_2000~0x0800\_5FFF is covered, then it is important to modify the FTL physical map or WIFI fast connect area address!

## 9.2 SRAM Layout

### 9.2.1 KM4 SRAM Layout

The start address of KM4 SRAM is 0x1000\_0000. The size is 512KB. The memory layout is illustrated in Fig 9-5 and Table 9-6.



Fig 9-5 KM4 RAM program layout

Table 9-6 KM4 RAM program layout

| Items          | Start Address | End Address   | Size | Description                                             | Mandatory |
|----------------|---------------|---------------|------|---------------------------------------------------------|-----------|
| ROM_BSS_COMMON | 0x1000_0000   | 0x1000_1000-1 | 4K   | ROM Secure and Non-secure common .bss                   | Y         |
| ROM_BSS_NS     | 0x1000_1000   | 0x1000_2000-1 | 4K   | ROM Non-secure common .bss                              | Y         |
| RSVD           | 0x1000_2000   | 0x1000_4000-1 | 8K   | Reserved for Non-secure MSP & Non-secure ROM .bss       | N         |
| MSP_NS         | 0x1000_4000   | 0x1000_5000-1 | 4K   | Non-secure Main Stack Pointer                           | Y         |
| IMG2_RAM_NS    | 0x1000_5000   | 0x1007_A000-1 | 468K | Image2 Non-secure RAM includes CODE, DATA, BSS and HEAP | N         |
| IMG2_RAM_S     | 0x1007_A000   | 0x1007_B000-1 | 4K   | Image2 Secure RAM includes CODE, DATA, BSS and HEAP     | N         |
| NSC            | 0x1007_B000   | 0x1007_C000-1 | 4K   | Images Secure function call entries                     | N         |
| ROM_BSS_S      | 0x1007_C000   | 0x1007_D000-1 | 4K   | ROM Secure only .bss                                    | Y         |
| BOOT_RAM_S     | 0x1007_D000   | 0x1007_F000-1 | 8K   | KM4 Secure bootloader, includes CODE and DATA           | Y         |

|       |             |               |    |                           |   |
|-------|-------------|---------------|----|---------------------------|---|
| MSP_S | 0x1007_F000 | 0x1008_0000-1 | 4K | Secure Main Stack Pointer | Y |
|-------|-------------|---------------|----|---------------------------|---|

## 9.2.2 KM0 SRAM Layout

The start address of KM0 SRAM is 0x0008\_0000. The size is 64KB. The memory layout is illustrated in Fig 9-6 and Table 9-7.



Fig 9-6 KM0 RAM program layout

Table 9-7 KM0 RAM program layout

| Items    | Start Address | End Address   | Size | Description                                        | Mandatory |
|----------|---------------|---------------|------|----------------------------------------------------|-----------|
| ROM_BSS  | 0x0008_0000   | 0x0008_2000-1 | 8K   | ROM .bss                                           | Y         |
| IMG1_RAM | 0x0008_2000   | 0x0008_3000-1 | 4K   | KM0 bootloader SRAM, includes CODE and DATA        | Y         |
| IMG2_RAM | 0x0008_3000   | 0x0008_F000-1 | 48K  | KM0 image2 SRAM, includes CODE, DATA, BSS and HEAP | N         |
| MSP      | 0x0008_F000   | 0x0009_0000-1 | 4K   | Main Stack Pointer                                 | Y         |

## 9.3 Retention SRAM

Retention SRAM would not be power off even when system enters into deepsleep mode. As a result, it is designed to retain data or code which would be lost in SRAM for some cases, such as deepsleep.

### 9.3.1 Retention SRAM Layout

The start address of Retention SRAM is 0x000C\_0000. The size is 1KB. The memory layout is illustrated in Table 9-8.

Table 9-8 Retention SRAM layout

| Items       | Start Address | End Address   | Size | Description                                                                                 | Mandatory |
|-------------|---------------|---------------|------|---------------------------------------------------------------------------------------------|-----------|
| System Area | 0x000C_0000   | 0x000C_0080-1 | 128B | Used by Realtek. The size is indicated by the second dword (0x000C_0004).                   | Y         |
| User Area   | 0x000C_0080   | 0x000C_0130-1 | 176B | Please reference RRAM_TypeDef, and RRAM_USER_RSVD [user_size] is reserved for customer use. | N         |
| WIFI Area   | 0x000C_0130   | 0x000C_0400-1 | 720B | Realtek WIFI FW used                                                                        | Y         |

### 9.3.2 User Area

RRAM\_USER\_RSVD is reserved for customer usage, the size for user area is 124B when we write this document, the size may be changed latter.

```
/*
 * @defgroup AMEBAD_RRAM
 * @{
 * @brief AMEBAD_RRAM Declaration
 * @ the Max space for RRAM_TypeDef is 0xB0 user can alloc space from RRAM USER RSVD
 */
typedef struct {
    uint8_t RRAM_WIFI_STATUS; /* RETENTION_RAM_SYS_OFFSET 0x80 */
    uint8_t RRAM_WIFI_P_SECURITY;
    uint8_t RRAM_WIFI_G_SECURITY;
    uint8_t RRAM_RSVD1;

    uint32_t RRAM_NET_ID;
    uint32_t RRAM_NET_GW;
    uint32_t RRAM_NET_GW_MASK;

    uint32_t FLASH_ID2;           /*offset 0x90*/
    uint32_t FLASH_cur_cmd;
    uint32_t FLASH_quad_valid_cmd;
    uint32_t FLASH_dual_valid_cmd;
    uint32_t FLASH_QuadEn_bit;   /*offset 0xA0*/
    uint32_t FLASH_StructInit;

    uint8_t FLASH_phase_shift_idx;
    uint8_t FLASH_rd_sample_phase_cal;
    uint8_t FLASH_class;
    uint8_t FLASH_cue_bitmode;

    uint8_t FLASH_ClockDiv;
    uint8_t FLASH_ReadMode;
    uint8_t FLASH_pseudo_preamble;
    uint8_t FLASH_addr_phase_len;

    uint8_t FLASH_cmd_r_status2; /*offset 0xB0*/
    uint8_t FLASH_rd_dummy_cycle0;
    uint8_t FLASH_rd_dummy_cycle1;
    uint8_t FLASH_rd_dummy_cycle2;

    uint8_t RRAM_USER_RSVD[124]; /*user can alloc from this RSVD space*/
} RRAM_TypeDef;
/** @}
 */
```

## 9.4 OTA Program Layout

The OTA layout is shown in Fig 9-7.



Fig 9-7 OTA program layout

#### 9.4.1 OTA Header Layout

The OTA header layout is figured in Fig 9-8 and Table 9-9.



Fig 9-8 OTA header layout

Table 9-9 OTA header layout

| Items         | Address Offset | Size    | Description                                               |
|---------------|----------------|---------|-----------------------------------------------------------|
| Version       | 0x00           | 4 bytes | The version of OTA Header, default 0xFFFFFFFF             |
| Header Number | 0x04           | 4 bytes | The number of OTA Header. For Ameba-D, this value is 0x01 |
| Signature     | 0x08           | 4 bytes | OTA Signature is string. For Ameba-D, this value is "OTA" |
| Header Length | 0x0C           | 4 bytes | The length of OTA header. For Ameba-D, this value is 0x18 |
| Checksum      | 0x10           | 4 bytes | The checksum of OTA image                                 |
| Image Length  | 0x14           | 4 bytes | The size of OTA image                                     |
| Offset        | 0x18           | 4 bytes | The start position of OTA image in current image          |
| RSVD          | 0x1C           | 4 bytes | Reserved                                                  |

## 9.5 TrustZone Memory Layout

All addresses are Secure when boot, you must set some area to Non-secure user SAU & IDAU. Fig 9-9 is the default secure setting of Ameba-D SDK.

If you don't want to use TrustZone, you can set IMG3\_RAM\_S and NSC to Non-secure, and other secure area which are used by ROM code are mandatory.



Fig 9-9 TrustZone layout

# 10 Boot Process

## 10.1 Features

- On-chip boot ROM
- Contains the bootloader with In-System Programming (ISP) facility
- Secure boot process use Error Correcting Code (ECC)
- Suspend resume process

## 10.2 Boot Address

After reset, CPU will boot from vector table start address, these address is fixed by hardware. KM0 and KM4 boot from different addresses as Table 10-1 lists.

Table 10-1 Boot ROM address

| CPU | Address     | Type         |
|-----|-------------|--------------|
| KM4 | 0x1010_0000 | KM4 ITCM ROM |
| KM0 | 0x0000_0000 | KM0 ITCM ROM |

## 10.3 Pin Description

The parts support ISP via LOGUART (PA7 & PA8). The ISP mode, given in Table 10-2, is determined by the state of the PA7 pin at boot time.

Table 10-2 ISP mode

| Boot Mode | PA7 (UART_DOWNLOAD) | Description                                     |
|-----------|---------------------|-------------------------------------------------|
| No ISP    | HIGH                | ISP bypassed. Part attempts to boot from flash. |
| ISP       | LOW                 | Part enters ISP via LOGUART.                    |

## 10.4 Boot Flow

The boot flow of Ameba-D is shown in Fig 10-1. After a power-up or hardware reset, hardware will boot KM0 at clock 26MHz or 20MHz based on XTAL clock set in eFuse. The boot process is handled by the on-chip boot ROM (0x0000\_0000) and is always executed by the KM0 core. After the KM0 bootloader code, the KM0 will set up the environment for the KM4.

- Power on PLL
- Flash calibration @100MHz
- Power on KM4
- After that the KM4 can be taken out of reset by the KM0.
- KM4 will boot from ROM code 0x1010\_0000.



Fig 10-1 Boot flow

## 10.5 Boot Time

Boot time was tested when this document was written, the result may be changed as the changing of SDK.

Table 10-3 Boot Time

| CPU      | Normal BOOT (ms) | Deepsleep WAKEUP (ms) | Comment                                                                                                                                           |
|----------|------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| KM0 BOOT | 30               | 18                    |                                                                                                                                                   |
| KM4 BOOT | 6+x              | 3+x                   | x=image2 size/flash rate<br>If image2 size = 100KB, Flash rate = 80Mbps & 2bit mode:<br>x=100*1024*8/160=5.1ms (100KB is SDK current image2 size) |
| WIFI ON  | 40               | 40                    |                                                                                                                                                   |

## 10.6 General Description

The bootloader controls initial operation after reset or powered on and also provides the means to program the flash memory. This could be initial programming of a blank device, erasure and re-programming of a previously programmed device.

Assuming that power supply pins are at their nominal levels when the rising edge on RESET pin is generated, then boot pins are sampled and the decision whether to continue with user code or ISP handler is made. If the boot pins are sampled LOW, the external hardware request to start the ISP command handler is ignored. If there is no request for the ISP command handler execution, a search is made for a valid user program. If a valid user program is found, then the execution control is transferred to it. If a valid user program is not found, the dead loop is invoked.

### 10.6.1 KM0 ROM Boot

The KM0 ROM boot process is shown in Fig 10-2.



### 10.6.2 KM4 ROM Boot

The KM4 ROM boot process is shown in Fig 10-3.



Fig 10-3 KM4 ROM boot process

## 10.7 Boot Reason APIs

Source code: `rtl8721d_backup_reg.c`

| API                                | Introduction    |
|------------------------------------|-----------------|
| <code>&lt; BOOT_Reason &gt;</code> | Get boot reason |

Table 10-4 Boot reason definition

| Bit                                       | Comment                |
|-------------------------------------------|------------------------|
| <code>BIT_BOOT_BOD_RESET_HAPPEN</code>    | BOD Reset              |
| <code>BIT_BOOT_DSPL_RESET_HAPPEN</code>   | Wakeup form deep sleep |
| <code>BIT_BOOT_KM4WDG_RESET_HAPPEN</code> | KM4 watchdog reset     |
| <code>BIT_BOOT_KM4SYS_RESET_HAPPEN</code> | KM4 system reset       |
| <code>BIT_BOOT_WDG_RESET_HAPPEN</code>    | KM0 watchdog reset     |
| <code>BIT_BOOT_SYS_RESET_HAPPEN</code>    | KM0 system reset       |

## 10.8 Security Boot

### 10.8.1 Diagram

Secure boot aims at firmware protection, which prevents attackers from modifying or replacing firmware maliciously. When the chip is power on, the ROM security boot executes to check the validation of image signature.

If the signature is valid, authentication will be successful, which means the firmware is safe and the subsequent operations can be continued. Otherwise, the SoC goes into infinite loop.

Users do not need to implement the security boot code themselves, which are already contained in the ROM code. Users only need to program the bootloader with signature information into Flash (0x0800\_0000).

To generate Public Key and signature of bootloader, we provide Image Tool. With the Image Tool, users can calculate and append signature-related information conveniently, please reference application note for more information of realization.

The security boot diagram of Ameba-D is shown in Fig 10-4.



Fig 10-4 Ameba-D security boot diagram

### 10.8.2 Image Header with Secure Boot

The secure bootloader has the format shown in Fig 10-5.



Fig 10-5 Security boot image header

Table 10-5 Image header with secure boot

| Items                                  | Comment                                                                                            |
|----------------------------------------|----------------------------------------------------------------------------------------------------|
| Signature (8 bytes)                    | Image1 Signature for Flash calibration: "96969999"<br>Image2 Signature is string: "81958711"       |
| Size (4 bytes)                         | The size of Firmware Image                                                                         |
| Address (4 bytes)                      | Code executes start address after boot                                                             |
| Security Boot Header Address (4 bytes) | Indicate where the SB Header locates. Generally, the SB Header is appended to the end of the image |
| Security Boot Signature                | The generated signature, which is to be verified when boot.                                        |

**Note:**

- Secure Boot should be rechecked after the SoC wakeup from deepsleep.  
Cause: We can't detect whether the flash chip is swapped out by another flash with non-secure code or not during deep sleep.
- The start address of image data from which we start to calculate signature should be fixed.  
Cause: There are security risks when hacker attacks in the following way:
  - (1) Copy the original image to another flash address
  - (2) Overwrite the original image with non-secure image
  - (3) Modify the start address in SB Header to the new flash address in step (1)
  - (4) Restart, then the non-secure image would execute
- The length of image data that involved in signature calculation should be nonconfigurable.  
Cause: The length should be appropriate. It can't be too small, otherwise the image can't be protected well. And the signature is independent of image if the length is 0, which enables hacker to replace the firmware easily. For Ameba-D, the length is set to the image size, and the header length is not included.

### 10.8.3 Secure Boot Image Generation

ImageTool is provided to generate secure boot image. The Security function of ImageTool is used to append Secure Boot Header to normal image.

As Fig 10-6 shows, steps to generate Secure Boot Image are as following:

- (1) Input Seed (32 bytes), which is used to generate key pair.
- (2) Click **Gen Keypair** button to generate Public Key and Private Key.
- (3) Click **Browse** button to select the bootloader image, and input the flash address of this image.
- (4) Click **Gen Signature** button to calculate signature for the image.
- (5) Click **Save Image** button to generate new image which contains Secure Boot information and signature.



Fig 10-6 ImageTool 'Security' function

# 11 OTA Firmware Update

## 11.1 Introduction

Over-the-air (OTA) programming provides a methodology of updating device firmware remotely via TCP/IP network.

RTL8721d provides solutions to implement OTA firmware upgrade from local server or cloud. Next we will introduce the design principles and usage of OTA from local server. It has well-transportability to porting to OTA applications from cloud.

## 11.2 RSIP-MMU

The flash MMU diagram is shown in Fig 11-1.



Fig 11-1 Flash MMU

The RSIP-MMU can perform virtual-to-physical memory address translation. This can be used to map an external flash memory to a certain virtual memory area. For example, If you want to access physical page 4 ~ 7 through virtual page 0 ~ 3, you can use a MMU entry to map virtual page 0 ~ 3 to physical page 4 ~ 7 like Fig 11-2.



Fig 11-2 MMU virtual address to physical address

Ameba-D provides 8 MMU Entries. If virtual address is not included in the MMU entry, use virtual address as physical address. If virtual address is included in the MMU entry, physical address should be VAddress +/- MMU\_ENTRYx\_OFFSET.

MMU is implemented to facilitate OTA update procedure like Fig 11-3. Fig 11-3 is an example for 2M flash OTA, we need 2 MMU entries in this example.



Fig 11-3 2M flash OTA MMU

MMU entry should be set as Table 11-1.

Table 11-1 OTA under MMU

| Register Type | Register           | OTA1                                     | OTA2                                     |
|---------------|--------------------|------------------------------------------|------------------------------------------|
| MMU Entry0    | MMU_ENTRY0_STRADDR | 0x0C00_0000                              | 0x0C00_0000                              |
|               | MMU_ENTRY0_ENDADDR | 0x0C00_0000 + KM0 IMG2 size              | 0x0C00_0000 + KM0 IMG2 size              |
|               | MMU_ENTRY0_OFFSET  | 0x0C00_0000 – 0x0800_6000                | 0x0C00_0000 – 0x0810_6000                |
|               | +/-                | -                                        | -                                        |
|               | MMU_ENTRY1_STRADDR | 0x0E00_0000                              | 0x0E00_0000                              |
| MMU Entry1    | MMU_ENTRY1_ENDADDR | 0x0E00_0000 + KM4 IMG2 size              | 0x0E00_0000 + KM4 IMG2 size              |
|               | MMU_ENTRY1_OFFSET  | 0x0E00_0000 – KM4 start physical address | 0x0E00_0000 – KM4 start physical address |
|               | +/-                | -                                        | -                                        |

**Note:** Considering KM4\_IMG2 is appended to the tail of KM0\_IMG2, the KM4 start physical address is determined by KM0 start physical address and KM0\_IMG2 size.

### 11.3 OTA Upgrade from Local Server

The OTA from local server shows how device updates image from a local download server. The local download server sends image to device based on network socket, as Fig 11-4 shows.

Make sure both device and PC are connecting to the same local network.



### 11.3.1 Firmware Format

The firmware format is illustrated in Fig 11-5.



Fig 11-5 Firmware format

Table 11-2 Firmware header

| Items         | Address Offset | Size    | Description                                               |
|---------------|----------------|---------|-----------------------------------------------------------|
| Version       | 0x00           | 4 bytes | The version of OTA Header, default 0xFFFFFFFF             |
| Header Number | 0x04           | 4 bytes | The number of OTA Header. For Ameba-D, this value is 0x01 |
| Signature     | 0x08           | 4 bytes | OTA Signature is string. For Ameba-D, this value is "OTA" |
| Header Length | 0x0C           | 4 bytes | The length of OTA header. For Ameba-D, this value is 0x18 |
| Checksum      | 0x10           | 4 bytes | The checksum of OTA image                                 |
| Image Length  | 0x14           | 4 bytes | The size of OTA image                                     |
| Offset        | 0x18           | 4 bytes | The start position of OTA image in current image          |
| RSVD          | 0x1C           | 4 bytes | Reserved                                                  |

### 11.3.2 OTA Flow

The OTA demo is provided in `rtl8721d_ota.c`. The image upgrading is implemented in the following steps:

- (1) Connect to local server with socket. The IP address and port are needed.
- (2) Acquire the older firmware address to be upgraded according to MMU setting. If address is re-mapping to OTA1 space by MMU, the OTA2 address would be selected to upgrade. Otherwise OTA1 address would be selected.
- (3) Receive firmware file header to get the target OTA image information, such as image length and destination address.
- (4) Erase flash space for new firmware

- (5) Download new firmware from server and write it to flash
- (6) Verify checksum. If checksum error, OTA fail.
- (7) If checksum is ok, write signature to the upgraded firmware region and change another signature to all zero to indicate boot from new firmware next time.
- (8) OTA finish and reset the device. Then it would boot from new firmware.



Fig 11-6 OTA operation flow

### 11.3.3 Boot Option

When reboot after OTA finished, device would check firmware to determine to boot from OTA1 or OTA2. The following items must be checked for each firmware:

- Signature. If it is "81958711", the signature is valid. Otherwise, the signature is invalid.

- Hash/checksum if needed. Users can define FwCheckCallback in rtl8721d\_bootcfg.

The boot flow is as following:

- (1) Check Signature and hash (if need) of OTA1 and OTA2 firmware.
- (2) If both images are invalid, boot fail
- (3) If only one image is valid, boot from this image
- (4) If both images are valid, boot from OTA2



Fig 11-7 OTA select diagram

#### 11.3.4 Address Remapping

In bootloader, MMU entry0 and entry1 would be set as Table 11-1 to remap memory. Here, the OTA space includes these images: KM0 IMG2, KM4 IMG2, KM4 IMG3 if need. These images all boot from OTA1 or OTA2.

As Fig 11-3 illustrates, when boot from OTA, CPU may access different physical address.

- When boot from OTA1, MMU entry0 and entry1 would be set to remap virtual memory to OTA1 address space. That is, if CPU wants to read code or data from address 0x0C00\_0000, it actually accesses physical address 0x0800\_6000.
- When boot from OTA2, MMU entry0 and entry1 would be set to remap virtual memory to OTA2 address space. That is, if CPU wants to read code or data from address 0x0C00\_0000, it actually accesses physical address 0x0810\_6000.

#### 11.3.5 How to Use OTA Demo

These steps can be followed to run the OTA demo:

- (1) Define CONFIG\_OTA\_UPDATE macro to 1 in **platform.opts.h** to enable OTA function. Rebuild the project.
- (2) Download images to device.
- (3) Generate OTA upgrade image file, named **OTA\_All.bin**, with Image Tool and new firmware. This operation appends firmware header information to new firmware, which is necessary for OTA.



(4) Copy **OTA\_All.bin** into the **DownloadServer** folder.

- Tool path in SDK: **tools\DownloadServer**

|  |                           |                 |        |
|--|---------------------------|-----------------|--------|
|  | <b>DownloadServer.exe</b> | 2016/11/7 16:12 | 34 KB  |
|  | <b>OTA_All.bin</b>        | 2016/11/7 15:21 | 657 KB |
|  | <b>start.bat</b>          | 2016/11/6 11:43 | 1 KB   |

(5) Edit **tools\DownloadServer\start.bat**.

- Port = 8082
- File name =OTA\_All.bin

```
@echo off
DownloadServer 8082 OTA_All.bin
set /p DUMMY=Press Enter to Continue ...
```

(6) Click the **start.bat**, start to download server program.



- (7) Reboot the DUT and connect the device to the AP which the OTA Server in.
- (8) Enter command: **ATWO=IP[PORT]**.
  - IP: IP of the OTA Server.
  - Port: 8082, the same with start.bat

```
# ATWO=192.168.0.20[8082]
[ATWO]: _AT_WLAN_OTA_UPDATE_
[MEM] After do cmd, available heap 28400
#
[ota_update_local_task] Update task start
```

OTA upgrade procedure is started between DUT and server. Here is the local download server success message.

```
Listening on port <8082>
Waiting for client ...
Accept client connection from 192.168.1.105
sending OTA_All.bin now...
Sending file...
Total send 192024 bytes
```

- (9) Reboot DUT to execute the new firmware after finishing image download.

### 11.3.6 OTA Firmware Swap

Fig 11-8 shows the firmware swap procedure after OTA upgrade.



Fig 11-8 OTA firmware swap procedure

## 11.4 User Configuration

Users can find the following configure items in **rtl8721d\_bootcfg.c**.

- OTA start address

```
/*
 * @brief OTA start address. Because KM0 & KM4 IMG2 are combined, user's only need to set the start address
 * of KM0 IMG2.
 */
BOOT_RAM_DATA_SECTION
u32 OTA_Region[2] = {
    0x08096000, /* OTA1 region start address */
    0x08106000, /* OTA2 region start address */
};
```

- User-defined MMU configure

```
/*
 * @brief MMU Configuration.
 *       There are 8 MMU entries totally. Entry 0 & Entry 1 are already used by OTA, Entry 2~7 can be used by Users.
 */
BOOT_RAM_DATA_SECTION
MMU_ConfDef Flash_MMU_Config[] = {
    /*VAddrStart, VAddrEnd,
    {0xFFFFFFFF, 0xFFFFFFFF},
    {0xFFFFFFFF, 0xFFFFFFFF},*/
    PAddrStart, PAddrEnd*/
    {0xFFFFFFFF, 0xFFFFFFFF}, //Entry 2
    {0xFFFFFFFF, 0xFFFFFFFF}, //Entry 3
    {0xFFFFFFFF, 0xFFFFFFFF}, //Entry 4
    {0xFFFFFFFF, 0xFFFFFFFF}, //Entry 5
    {0xFFFFFFFF, 0xFFFFFFFF}, //Entry 6
    {0xFFFFFFFF, 0xFFFFFFFF}, //Entry 7
    {0xFFFFFFFF, 0xFFFFFFFF},
};
```

- Firmware check handler configure

```
/**
 * @brief Firmware verify callback handler.
 *       If users need to verify checksum/hash for image2, implement the function and assign the address
 *       to this function pointer.
 */
BOOT_RAM_DATA_SECTION
FwCheckFunc FwCheckCallback = NULL;
```

## 12 Power Save

### 12.1 Hardware Power Save Modes

#### 12.1.1 Power Mode

Ameba-D supports two low power modes which are deepsleep mode and sleep mode. Deepsleep mode turns off more power domain than sleep mode.

RTC/AON Timer/AON Pin (low power pin)/Key-Scan/Cap-Touch can be used to wakeup both sleep and deepsleep mode (refer to 12.2.4).

Table 12-1 Power domain comparison

| Item                               | Sleep (WoWLAN) | Deepsleep |
|------------------------------------|----------------|-----------|
| Main digital power                 | ✓              | ✓         |
| SWR                                | Δ <sup>1</sup> | x         |
| KM4 core                           | x              | x         |
| KM0 core                           | Δ              | x         |
| System PLL                         | x              | x         |
| KM4 Timer                          | x              | x         |
| KM0 Timer                          | Δ              | x         |
| XTAL                               | Δ              | x         |
| OSC4M                              | Δ              | x         |
| OSC2M                              | Δ              | x         |
| OSC131K/32K                        | ✓              | ✓         |
| SRAM                               | ✓              | x         |
| Retention SRAM                     | ✓              | ✓         |
| AON register                       | ✓              | ✓         |
| AON Timer (32.768KHz, Max. 546min) | ✓              | ✓         |
| Key-Scan                           | ✓              | ✓         |
| Cap-Touch                          | ✓              | ✓         |
| RTC                                | ✓              | ✓         |
| Wi-Fi                              | Δ              | x         |
| UART                               | Δ              | x         |
| GPIO wakeup                        | Δ              | x         |
| AON pin (low power pin)            | ✓              | x         |

1. Users can choose to turn on/off this power domain in sleep mode by themselves.

#### Note:

- All GPIOs can wake up system from sleep, which are listed in UM0402 pinmux table.
- There are some special GPIOs, for example, PA[7] and PA[8] are used for UART download, while PA[27] and PB[3] are used for SWD. If they are used for other purposes, they can't be used as a general GPIO to wake up system.

Depending on QFN package, there are at most 12 AON\_Wakepin, refer to UM0402 pinmux table (aon pinmux sheet) for more information. All AON\_Wakepin can wake up system from deepsleep, as shown in Table 12-2.

Table 12-2 AON\_Wakepin

| Item      | PINMUX_S0 | PINMUX_S1 | PINMUX_S2 |
|-----------|-----------|-----------|-----------|
| wakepin 0 | PA[12]    | PA[16]    | PA[20]    |
| wakepin 1 | PA[13]    | PA[17]    | PA[21]    |
| wakepin 2 | PA[14]    | PA[18]    | PA[25]    |
| wakepin 3 | PA[15]    | PA[19]    | PA[26]    |

## 12.1.2 Power Consumption Summary

Table 12-3 and Table 12-4 list the power consumption under 3.3V/1.8V power supply.

Table 12-3 Power consumption under 3.3V/1.8V

| Operation Mode                                                                                                                                                                    |                                               | Condition                                                                  | Current |           | Unit |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|----------------------------------------------------------------------------|---------|-----------|------|
| Power Mode                                                                                                                                                                        | Scenario                                      |                                                                            | 3.3V    | 1.8V      |      |
| Deepsleep                                                                                                                                                                         | Deepsleep                                     | RTC timer<br>1KB retention RAM                                             | 7~8     | 7~8       | uA   |
|                                                                                                                                                                                   | Deepsleep with Key-Scan                       | RTC timer<br>1KB retention RAM<br>Key-Scan                                 | 12~13   | 12~13     | uA   |
|                                                                                                                                                                                   | Deepsleep with Cap-Touch<br>(average current) | RTC timer<br>1KB retention RAM<br>Cap-Touch                                | 20      | 16        | uA   |
| Sleep                                                                                                                                                                             | WoWLAN sleep power                            | KM4 power gate<br>KM0 clock gate<br>All RAM retained<br>Wi-Fi retained     | 30~50   | 30~50     | uA   |
| Active                                                                                                                                                                            | Wi-Fi Rx Idle                                 | HT20 MCS0~7 normal mode<br>KM4 in active mode<br>Rx idle                   | 52      | 81        | mA   |
|                                                                                                                                                                                   |                                               | HT20 MCS0~7 ultra-low power mode<br>KM4 in active mode<br>Rx idle          | 35      | 60        | mA   |
|                                                                                                                                                                                   | Wi-Fi Rx UDP                                  | HT20 MCS0~7 ultra-low power mode<br>KM4 in active mode<br>UDP Rx @ 8Mbps   | 39      | 67        | mA   |
| WoWLAN                                                                                                                                                                            | WoWLAN Rx Beacon                              | Rx beacon mode @ normal mode<br>KM4 in sleep mode                          | 28      | 45        | mA   |
|                                                                                                                                                                                   |                                               | Rx beacon mode @ ultra-low power mode<br>KM4 in sleep mode                 | 23      | 39        | mA   |
|                                                                                                                                                                                   | WoWLAN DTIM=1<br>(Average)                    | KM4 in sleep mode<br>All SRAM retained<br>Wi-Fi retained<br>Shielding room | 700~800 | 1100~1200 | uA   |
|                                                                                                                                                                                   |                                               | KM4 in sleep mode<br>All SRAM retained<br>Wi-Fi retained<br>Open space     | 1~2     | 1.1~2     | mA   |
| <b>Note:</b> Ultra-low power mode side effect:<br><ul style="list-style-type: none"> <li>OFDM: Rx Sensitivity Degree 2~4dBm</li> <li>CCK: Rx Sensitivity Degree 1~2dBm</li> </ul> |                                               |                                                                            |         |           |      |

Table 12-4 Tx power consumption under 3.3V/1.8V

| Channel      | Power | Operation Mode                           | 2.4G | 5G  | Unit |
|--------------|-------|------------------------------------------|------|-----|------|
| 2442MHz@2.4G | 1.8V  | 1T-MCS7/BW40M (9dBm@2.4G, 8dBm@5G)       | 181  | 216 | mA   |
| 5500MHz@5G   |       | 1T-MCS7/BW40M (12dBm@2.4G, 11dBm@5G)     | 195  | 237 |      |
| 20M          |       | 1T-MCS7/BW20M (9dBm@2.4G, 8dBm@5G)       | 180  | 214 |      |
| 5510MHz@5G   |       | 1T-MCS7/BW20M (12dBm@2.4G, 11dBm@5G)     | 193  | 234 |      |
| 40M          |       | 1T-Legacy_OFDM54M (10dBm@2.4G, 9dBm@5G)  | 184  | 219 |      |
|              |       | 1T-Legacy_OFDM54M (13dBm@2.4G, 12dBm@5G) | 214  | 245 |      |
|              |       | 1T_CCK11M (12dBm)                        | 203  | -   |      |
|              |       | 1T_CCK11M (15dBm)                        | 224  | -   |      |
|              |       | 1R-Idle/BW40                             | 89   | 90  |      |

|  |      |                                        |     |     |  |
|--|------|----------------------------------------|-----|-----|--|
|  |      | 1R-MCS7/BW40M (Pin= -60dBm)            | 98  | 103 |  |
|  |      | 1R-MCS7/BW20M (Pin= -60dBm)            | 102 | 106 |  |
|  |      | 1R-Legacy_OFDM54M (Pin= -60dBm)        | 98  | 103 |  |
|  |      | 1R-CCK11M (Pin= -60dBm)                | 31  | -   |  |
|  |      | RF Standby                             | 58  | 55  |  |
|  |      | RF Disable                             | 43  | 42  |  |
|  | 3.3V | 1T-MCS7/BW40M (15dBm)                  | 206 | 286 |  |
|  |      | 1T-MCS7/BW40M (18dBm@2.4G, 17dBm@5G)   | 247 | 310 |  |
|  |      | 1T-MCS7/BW20M (15dBm)                  | 204 | 286 |  |
|  |      | 1T-MCS7/BW20M (18dBm)                  | 248 | 308 |  |
|  |      | 1T-Legacy_OFDM54M (16dBm)              | 214 | 296 |  |
|  |      | 1T-Legacy_OFDM54M (19dBm@2.4 18dBm@5G) | 262 | 323 |  |
|  |      | 1T_CCK11M (18dBm)                      | 257 | -   |  |
|  |      | 1T_CCK11M (21dBm)                      | 312 | -   |  |
|  |      | 1R-Idle/BW40                           | 52  | 53  |  |
|  |      | 1R-MCS7/BW40M (Pin= -60dBm)            | 61  | 64  |  |
|  |      | 1R-MCS7/BW20M (Pin= -60dBm)            | 62  | 63  |  |
|  |      | 1R-Legacy_OFDM54M (Pin= -60dBm)        | 61  | 62  |  |
|  |      | 1R-CCK11M (Pin= -60dBm)                | 52  | -   |  |
|  |      | RF Standby                             | 24  | 23  |  |
|  |      | RF Disable                             | 24  | 23  |  |

**Note:**

- The values above are tested with the Ameba-D QFN68 board.
- Tx: Continue Tx DPK on
- Rx: Set Rx Packets idle interval as short as possible
- Load W11N\_11M0 Idle Waveform (8us idle interval) for 1R-CCK11M test.



Fig 12-1 WoWLAN (3.3V normal mode)



Fig 12-2 WoWLAN (1.8V normal mode)



Fig 12-3 WoWLAN (3.3V ultra-low power mode)



Fig 12-4 WoWLAN (1.8V ultra-low power mode)

| Chip                        | Edit             | Option                                         | Help |
|-----------------------------|------------------|------------------------------------------------|------|
| <a href="#">EFUSE Table</a> |                  |                                                |      |
| 15:25:40.670                | udp_server_func: | Receive 988 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:25:41.685                | udp_server_func: | Receive 980 KBytes in 1003 ms, 8008 Kbytes/sec |      |
| 15:25:42.695                | udp_server_func: | Receive 984 KBytes in 1000 ms, 8067 Kbytes/sec |      |
| 15:25:43.704                | udp_server_func: | Receive 950 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:25:44.710                | udp_server_func: | Receive 930 KBytes in 1001 ms, 8024 Kbytes/sec |      |
| 15:25:45.708                | udp_server_func: | Receive 920 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:25:46.719                | udp_server_func: | Receive 981 KBytes in 1001 ms, 8035 Kbytes/sec |      |
| 15:25:47.708                | udp_server_func: | Receive 971 KBytes in 1000 ms, 8020 Kbytes/sec |      |
| 15:25:48.728                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:25:49.730                | udp_server_func: | Receive 983 KBytes in 1002 ms, 8039 Kbytes/sec |      |
| 15:25:50.741                | udp_server_func: | Receive 981 KBytes in 1000 ms, 8043 Kbytes/sec |      |
| 15:25:51.740                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:25:52.750                | udp_server_func: | Receive 977 KBytes in 1000 ms, 8006 Kbytes/sec |      |
| 15:25:53.750                | udp_server_func: | Receive 984 KBytes in 1001 ms, 8059 Kbytes/sec |      |
| 15:25:54.760                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:25:55.751                | udp_server_func: | Receive 980 KBytes in 1002 ms, 8016 Kbytes/sec |      |
| 15:25:56.752                | udp_server_func: | Receive 983 KBytes in 1000 ms, 8055 Kbytes/sec |      |
| 15:25:57.757                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:25:58.761                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8043 Kbytes/sec |      |
| 15:25:59.770                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:26:00.771                | udp_server_func: | Receive 974 KBytes in 1002 ms, 7969 Kbytes/sec |      |
| 15:26:01.783                | udp_server_func: | Receive 981 KBytes in 1000 ms, 8045 Kbytes/sec |      |
| 15:26:02.787                | udp_server_func: | Receive 979 KBytes in 1001 ms, 8012 Kbytes/sec |      |
| 15:26:03.801                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:26:04.795                | udp_server_func: | Receive 933 KBytes in 1002 ms, 8039 Kbytes/sec |      |
| 15:26:05.800                | udp_server_func: | Receive 970 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:26:06.809                | udp_server_func: | Receive 980 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:26:07.819                | udp_server_func: | Receive 933 KBytes in 1000 ms, 8055 Kbytes/sec |      |
| 15:26:08.810                | udp_server_func: | Receive 981 KBytes in 1001 ms, 8035 Kbytes/sec |      |
| 15:26:09.814                | udp_server_func: | Receive 950 KBytes in 1000 ms, 8032 Kbytes/sec |      |
| 15:26:10.829                | udp_server_func: | Receive 979 KBytes in 1000 ms, 8020 Kbytes/sec |      |
| 15:26:11.825                | udp_server_func: | Receive 967 KBytes in 1001 ms, 7918 Kbytes/sec |      |
| 15:26:12.828                | udp_server_func: | Receive 970 KBytes in 1001 ms, 7941 Kbytes/sec |      |



Fig 12-5 UDP performance (3.3V ultra-low power mode)



Fig 12-6 UDP performance (1.8V ultra-low power mode)

## 12.2 Software Power Management

### 12.2.1 FreeRTOS Tickles

FreeRTOS supports a low power feature called tickles. It is implemented in idle task which has the lowest priority. That is, it is invoked when there is no other task under running.

FreeRTOS places the microcontroller into a low power state, if it expects there will be no event in near future. It calculates expected idle time by looking timer task list. Then it performs suspend action by using ARM instruction "WFI" (Wait for Interrupt) which makes the processor suspend execution (Clock is stopped) until interrupt happened.

The interrupts include timer which set by FreeRTOS with value equal to the expected idle time. So when idle task is invoked every time, FreeRTOS calculates the expected idle time, sets timer, and puts process into suspend.



Fig 12-7 FreeRTOS tickles in idle task

## 12.2.2 Wakelock

In some situations, system is needed to keep awake to receive certain events. Otherwise event may be missed when system is under sleep. An idea of wakelock is introduced that system cannot sleep if some module holding wakelock.

A wakelock bit map is for storing the wakelock status. Each module has its own bit in wakelock bit map (see enum. PMU\_DEVICE). If the wakelock bit map equals to zero, it means there is no module holding wakelock. If the wakelock bit map larger than zero, it means there is some module holding wakelock.

If there is no one holding wakelock, then system is permit to sleep. If there are one or more modules holding wakelock, then we abort sleep.

## 12.2.3 Wi-Fi Power Save

In IEEE 802.11 power save management, it allows station enter their own sleep state. It defines station need keep awake in certain timestamp and enter sleep state otherwise.

WLAN driver acquire wakelock to avoid system enter sleep when WLAN need keep awake. And it releases wakelock when it is permitted to enter sleep state.

IEEE 802.11 power management allows station enter power saving mode. Station cannot receive any frames during power saving. Thus AP need buffers these frames and requires station periodically wakeup to check beacon which has information of buffered frames.



Fig 12-8 Timeline of power saving

In SDK IEEE 802.11 power management is called LPS, and if KM4 enter power save mode when Wi-Fi is in LPS mode, we call it WoWLAN mode.

Except LPS and WoWLAN we also have IPS, which can be used when Wi-Fi is not connected. Table 12-5 lists all three power save mode for Wi-Fi.

Table 12-5 Wi-Fi power save mode

| Items  | Wi-Fi Status   | Comment                                                                                                                 |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------|
| IPS    | Not associated | Driver automatically turns off Wi-Fi to save power.                                                                     |
| LPS    | Associated     | LPS is used to implement IEEE 802.11 power management.<br>KM0 will control RF ON/OFF based on TSF and TIM IE in beacon. |
| WoWLAN | Associated     | LPS + Tickles<br>KM0 will wakeup KM4 when receive data packet.                                                          |

## 12.2.4 Software Configuration

| Type | Items | User Configuration |
|------|-------|--------------------|
|      |       |                    |

|                       |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sleep<br>(WoWLAN)     | km0_pwrctrl_config       | KM0 power management control: system use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                       | sleep_wevent_config      | <ul style="list-style-type: none"> <li>● BIT_LP_WEVT_HS_MSK: KM4 peripheral wakeup open</li> <li>● BIT_LP_WEVT_AON_MSK: AON wake event wakeup sleep mode</li> <li>● BIT_LP_WEVT_SGPIO_MSK: SGPIO wakeup event</li> <li>● BIT_LP_WEVT_COMP_MSK: ADC comparator wakeup event</li> <li>● BIT_LP_WEVT_ADC_MSK: ADC wakeup event</li> <li>● BIT_LP_WEVT_I2C_MSK: I2C slave wakeup event</li> <li>● BIT_LP_WEVT_UART_MSK: LP UART wakeup event</li> <li>● BIT_LP_WEVT_WLAN_MSK: WLAN wake up event</li> <li>● BIT_LP_WEVT_GPIO_MSK: GPIO wakeup event</li> <li>● BIT_LP_WEVT_TIMER_MSK: LP TIM0~5 wakeup event</li> </ul> |
|                       | sleep_hsramp_config      | System use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                       | sleep_lsram_config       | System use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                       | sleep_aon_wevent_config  | <ul style="list-style-type: none"> <li>● BIT_CAPTOUCH_WAKE_STS: Cap-Touch wake event</li> <li>● BIT_KEYSCAN_WAKE_STS1: Key-Scan wake event</li> <li>● BIT_RTC_WAKE_STS1: RTC wake event</li> <li>● BIT_AON_WAKE_TIM0_STS1: AON timer wake event</li> <li>● BIT_GPIO_WAKE_STS1: AON GPIO wake, see aon_wakepin &amp; dsleep_wakepin_config</li> </ul>                                                                                                                                                                                                                                                                |
| Deepsleep             | dsleep_aon_wevent_config | <ul style="list-style-type: none"> <li>● BIT_CAPTOUCH_WAKE_STS: Cap-Touch wake event</li> <li>● BIT_KEYSCAN_WAKE_STS1: Key-Scan wake event</li> <li>● BIT_RTC_WAKE_STS1: RTC wake event</li> <li>● BIT_AON_WAKE_TIM0_STS1: AON timer wake event</li> <li>● BIT_GPIO_WAKE_STS1: AON GPIO wake, see aon_wakepin &amp; dsleep_wakepin_config</li> </ul>                                                                                                                                                                                                                                                                |
|                       | dsleep_lsram_config      | System use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Sleep or<br>Deepsleep | sleep_wakepin_config     | Configure AON wake pin pinmux and enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                       | ps_config                | System use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

### 12.2.5 GPIO Pull Control

It needs doing I/O pull control when enter deep sleep and sleep mode. Otherwise it results power leakage. For example, UART voltage level is high. If we pull down UART pin or not pull, then power leakage happens. So we need make sure each pin has proper pull control.

In SDK you should set GPIO function pull control and sleep pull control in pmap\_func based on your PCB board, and SDK will set pull control based on your setting between suspend and resume.

```

const PMAP_TypeDef pmap_func[] =
{
    // Pin Name      Func PU/PD      S1p PU/PD      DS1p PU/PD      LowPowerPin
    { _PA_0,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_1,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_2,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_3,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_4,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_5,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_6,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_7,        GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //UART_LOG_TXD
    { _PA_8,        GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //UART_LOG_RXD
    { _PA_9,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_10,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_11,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_12,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_13,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_14,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_15,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_16,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_17,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_18,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_19,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_20,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_21,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_22,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_23,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_24,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_25,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_26,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    { _PA_27,       GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //SWD_DATA or nc
    { _PA_28,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_29,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_30,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PA_31,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_0,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_1,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_2,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_3,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //SWD_CLK
    { _PB_4,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch0
    { _PB_5,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch1
    { _PB_6,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch2
    { _PB_7,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch3
    { _PB_8,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_9,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_10,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_11,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_12,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_13,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_CLK
    { _PB_14,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_DATA0
    { _PB_15,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_DATA2
    { _PB_16,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_CS
    { _PB_17,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_DATA1
    { _PB_18,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_19,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_20,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_21,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_22,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //IR pin should no-pull
    { _PB_23,       GPIO_PuPd_NOPULL, GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_24,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_25,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_26,       GPIO_PuPd_SHUTDOWN, GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // this is a pcb board
    { _PB_27,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_28,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_29,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_30,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _PB_31,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //,
    { _INC,         GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //table end
};

```

## 12.3 Suspend Resume APIs

| Tickless API                    | Introduction                                                         |
|---------------------------------|----------------------------------------------------------------------|
| <pmu_register_sleep_callback>   | Register suspend/resume call back function for one module            |
| <pmu_unregister_sleep_callback> | Unregister suspend/resume call back function                         |
| <pmu_acquire_wakelock>          | Acquire wake lock for one module                                     |
| <pmu_release_wakelock>          | Release wake lock                                                    |
| <pmu_set_sysactive_time>        | Acquire wake lock, and release wake lock automatically after timeout |
| <pmu_set_max_sleep_time>        | Set max sleep time                                                   |

### 12.3.1 pmu\_register\_sleep\_callback

Register suspend/resume call back function for <nDeviceId>, suspend callback function will be called by PMU before system enter sleep mode, and resume callback function will be called after system resume.

**Note:**

- Yield OS is not permitted in suspend/resume callback function like: taskYIELD, vTaskDelay, mutex, sema and so on.
- pmu\_set\_sysactive\_time is not permitted in suspend callback function.
- pmu\_set\_sysactive\_time is permitted in resume call back function.

| Parameter          | Type         | Introduction                                                                                                    |
|--------------------|--------------|-----------------------------------------------------------------------------------------------------------------|
| <nDeviceId>        | uint32_t     | Device ID need suspend/resume callback<br>typedef enum {<br>PMU_OS = 0,<br>...<br>PMU_MAX = 31<br>} PMU_DEVICE; |
| <sleep_hook_fun>   | PSM_HOOK_FUN | Suspend call back function                                                                                      |
| <sleep_param_ptr>  | void*        | Suspend call back function parameter                                                                            |
| <wakeup_hook_fun>  | PSM_HOOK_FUN | Resume call back function                                                                                       |
| <wakeup_param_ptr> | void*        | Resume call back function parameter                                                                             |

### 12.3.2 pmu\_unregister\_sleep\_callback

Unregister suspend/resume call back function for <nDeviceId>.

| Parameter   | Type     | Introduction                            |
|-------------|----------|-----------------------------------------|
| <nDeviceId> | uint32_t | The same as pmu_register_sleep_callback |

### 12.3.3 pmu\_acquire\_wakelock

Wakelock is a 32-bit map. Each module owns 1 bit in this bit map. FreeRTOS tickless reference the wakelock and decide that if it can or cannot enter sleep state.

If any module acquires and hold a bit in wakelock, then the whole system won't enter sleep state.

| Parameter   | Type     | Introduction                            |
|-------------|----------|-----------------------------------------|
| <nDeviceId> | uint32_t | The same as pmu_register_sleep_callback |

### 12.3.4 pmu\_release\_wakelock

Release bit[nDeviceId] of wakelock bit map, if wakelock equals to 0, then the system may enter sleep state after system idle.

| Parameter   | Type     | Introduction                            |
|-------------|----------|-----------------------------------------|
| <nDeviceId> | uint32_t | The same as pmu_register_sleep_callback |

### 12.3.5 pmu\_set\_sysactive\_time

This function sets system active time, system cannot sleep before timeout.

**Note:**

- pmu\_set\_sysactive\_time is not permitted in suspend callback function as it is ineffective.

- pmu\_set\_sysactive\_time is permitted in resume call back function.

| Parameter | Type     | Introduction                                    |
|-----------|----------|-------------------------------------------------|
| <timeout> | uint32_t | system cannot sleep before timeout. Unit is ms. |

### 12.3.6 pmu\_set\_max\_sleep\_time

This function sets system max sleep time

**Note:**

- system maybe waked by other wake event before this timer timeout
- This setting only works once, the timer will be clear after wake up

| Parameter | Type     | Introduction                          |
|-----------|----------|---------------------------------------|
| <timeout> | uint32_t | system max sleep timeout. Unit is ms. |

## 12.4 Power Consumption Measurement

### 12.4.1 Test Command

We provide command in KM4 for tickles testing. Below is the description.

| Items          | Comment                                                                                                                                                                            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tickps r debug | Release OS wakelock to open tickles function, KM4 will enter sleep mode when idle.<br>In program you can use pmu_release_wakelock (PMU_OS) to open tickles function (ref. 12.3.4). |
| tickps a       | Get OS wakelock to close tickles function.                                                                                                                                         |
| tickps get     | Get current wakelock, it prints current wakelock bit map. You can use this command to debug why system doesn't enter sleep.                                                        |

### 12.4.2 Hardware Preparation

In Ameba-D reference board, there are other components that consume power. For example, DAP, LEDs, FT232, and capacitances. To measure power consumptions only for Ameba-D, you need remove resistance at R43.



Fig 12-9 Power consumption measurement

You can use micro USB to supply power for the board, and link current meter use J38 like Fig 12-10.



Fig 12-10 Measure power consumption from micro USB

# 13 User Configuration

Some functions have complex parameters, it's hard for SDK to give standard API. For Example, different users have different parameters for BOOT. So we give some user configuration files which will be called by SDK and SDK will have different activities based on user configurations.

These configuration files should be maintained by users.

## 13.1 Configuration File List

The user configuration files are listed in Table 13-1.

Table 13-1 User configuration file

| File                           | Configuration Items                                                                                                                                                                                                                              | Image                                                                                        |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| rtl8721dhp_boot_trustzonecfg.c | Used to configure KM4 TrustZone no-secure areas.                                                                                                                                                                                                 | KM4 bootloader                                                                               |
| rtl8721dlp_flashcfg.c          | Used to configure flash settings:<br><ul style="list-style-type: none"> <li>● Flash_Speed</li> <li>● Flash_ReadMode</li> <li>● Flash_AVL</li> </ul> You can also configure your flash use flash_init_userdef, if your flash is not in Flash_AVL. | KM0 image2                                                                                   |
| Rtl8721dlp_pinmapcfg.c         | Used to reduce I/O power leakage:<br><ul style="list-style-type: none"> <li>● per pin function configuration</li> <li>● per pin function pull up &amp; pull down</li> <li>● per pin sleep pull up &amp; pull down</li> </ul>                     | KM0 image2                                                                                   |
| Rtl8721dlp_sleepcfg.c          | <ul style="list-style-type: none"> <li>● Sleep/deepsleep power management</li> <li>● Sleep/deepsleep wakeup event</li> <li>● Sleep/deepsleep wake pin</li> </ul>                                                                                 | KM0 image2                                                                                   |
| rtl8721d_bootcfg.c             | Used to configure boot loader:<br><ul style="list-style-type: none"> <li>● Flash_MMU_Config</li> <li>● RSIP_Mask_Config</li> <li>● Force_OTA1_GPIO</li> <li>● Boot_Log_En</li> </ul>                                                             | <ul style="list-style-type: none"> <li>● KM0 bootloader</li> <li>● KM4 bootloader</li> </ul> |
| rtl8721d_ipccfg.c              | Used to define your IPC channels                                                                                                                                                                                                                 | <ul style="list-style-type: none"> <li>● KM0 image2</li> <li>● KM4 image2</li> </ul>         |

## 13.2 boot\_trustzonecfg

The whole address space will be security when boot up, SAU is used to configure non-secure area for some special address space. SAU should be configured in secure bootloader, and it can't be changed again after setting it, it is protected by hardware.

There are 8x SAU entries in Ameba-D, entry0 to entry4 has been used by system, and entry5 to entry7 are left for user use. You can configure your own TrustZone non-secure area.

```

BOOT_RAM_DATA_SECTION
const T2_CFG_TypeDef tz_config[]=
{
// Start           End             NSC
{0x40000000,     0x50000000-1,   0}, /* entry0: Peripherals NS */
{0x1010A000,     0x101D4000-1,   0}, /* entry1: IROM & DROM NS */
{0x00080000,     _ram_image3_start_-1,0}, /* entry2: KM0 SRAM, Retention SRAM, PSRAM & FLASH & SRAM NS */
{__ram_image3_end__, 0x1007C000-1,   1}, /* entry3: NSC 4K */
{0x100E0000,     0x10100000-1,   0}, /* entry4: BT/WIFI Extention SRAM */
{0xFFFFFFFF,      0xFFFFFFFF,    0}, /* entry5: TODO */
{0xFFFFFFFF,      0xFFFFFFFF,    0}, /* entry6: TODO */
{0xFFFFFFFF,      0xFFFFFFFF,    0}, /* entry7: TODO */
{0xFFFFFFFF,      0xFFFFFFFF,    0},
};

```

### 13.3 flashcfg

The user flash configuration items are listed in Table 13-2.

Table 13-2 User flash configuration

| Items              | Comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Default |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| Flash_Speed        | Indicates the flash baud rate. It can be one of the following value:<br><ul style="list-style-type: none"> <li>● 0xFFFF: 80MHz</li> <li>● 0xFFFF: 100MHz</li> <li>● 0x3FFF: 67MHz</li> <li>● 0x1FFF: 57MHz</li> <li>● 0x0FFF: 50MHz</li> </ul>                                                                                                                                                                                                                                                                   | 0xFFFF  |
| Flash_ReadMode     | Indicates the flash read I/O mode. It can be one of the following value:<br><ul style="list-style-type: none"> <li>● 0xFFFF: Read quad I/O, Address &amp; Data 4 bits mode</li> <li>● 0xFFFF: Read quad O, just data 4 bits mode</li> <li>● 0x3FFF: Read dual I/O, Address &amp; Data 2 bits mode</li> <li>● 0x1FFF: Read dual O, just data 2 bits mode</li> <li>● 0x0FFF: 1 bit mode</li> </ul><br>If the configured read mode is not supported, other modes would be searched until find the appropriate mode. | 0xFFFF  |
| Flash_AVL          | Maintains the flash IC supported by SDK, refer to Fig 13-1 for detailed information.                                                                                                                                                                                                                                                                                                                                                                                                                             |         |
| flash_init_userdef |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |

#### 13.3.1 Flash Classification

Ameba-D support flash chips of multi-vendor, such Winbond, MXIC, Gigadevice, ESMT etc. The flash chips which have been verified on Ameba platform can be found in “Realtek Ameba Flash AVL.doc”. We divide the supported flash into 6 species as Table 13-3 shows according to their characteristics and they can be used on Ameba-D directly.

Table 13-3 Flash species

| Flash Classification | Manufacture                | Flash ID |
|----------------------|----------------------------|----------|
| FlashClass1          | Winbond                    | 0xEF     |
|                      | FM                         | 0xA1     |
|                      | XTX                        | 0x0B     |
|                      | XTX (FT)                   | 0x0E     |
| FlashClass2          | GD (GD normal)             | 0xC8     |
| FlashClass3          | MXIC (MXIC normal)         | 0xC2     |
|                      | Hua Hong                   | 0x68     |
|                      | GD (GD MD serial)          | 0x51     |
| FlashClass4          | ESMT                       | 0x1C     |
| FlashClass5          | Micron                     | 0x20     |
| FlashClass6          | MXIC (MXIC wide-range VCC) | 0x28C2   |

For a new flash chip that is not available in AVL, users should follow these steps to check if it can be supported by Ameba-D.

- (1) Review flash datasheet to collect essential information
  - Flash ID
  - Number of Flash status register and the definition (QE, BUSY, WEL, BP etc.)
  - Flash Commands (Write/Read status register, Read, Read Dual/Quad Output/IO, Page Program, Sector/Block/Chip Erase, Enter/Release from Power-down etc.)
  - Dummy cycle number of Read Dual/Quad Output/IO mode
- (2) Check if these parameters match with those of the existing species
  - a) If the flash belongs to one of the Realtek defined classes, it is already supported by SDK and you can use it directly.
  - b) If all the parameters except Flash ID match with those of one species, users should add the flash ID into Flash\_AVL table in SDK before use it as Fig 13-1 shows.

- c) If both the flash parameters and Flash ID mismatch with the existing species, users should define the parameters in function `flash_init_userdef`.

```

const FlashInfo_TypeDef Flash_AVL[] = {
    /*flash_id,      flash_id_mask,   flash_class,          status_mask,     FlashInitHandler */
    /* case1: Realtek defined class, any modification is not allowed */
    {0xEF,          0x000000FF,     FlashClass1,           NULL}, /* Winbond: MANUFACTURER_ID_WINBOND */
    {0xA1,          0x000000FF,     FlashClass1,           NULL}, /* Fudan Macro: MANUFACTURER_ID_FM */
    {0x0B,          0x000000FF,     FlashClass1,           NULL}, /* MTX */
    {0x0E,          0x000000FF,     FlashClass1,           NULL}, /* XIN(FI) */
    {0xC8,          0x000000FF,     FlashClass2,           NULL}, /* GD normal: MANUFACTURER_ID_GD */
    {0x28C2,        0x00000FFF,    FlashClass6,           NULL}, /* MXIC wide-range VCC: MANUFACTURER_ID_MXIC */
    {0xC2,          0x000000FF,    FlashClass3,           NULL}, /* MXIC normal: MANUFACTURER_ID_BOHONG */
    {0x68,          0x000000FF,    FlashClass3,           NULL}, /* Hua Hong */
    {0x51,          0x000000FF,    FlashClass3,           NULL}, /* GD MD serial */
    {0x1C,          0x000000FF,    FlashClass4,           NULL}, /* ESMT: MANUFACTURER_ID_EON */
    {0x20,          0x000000FF,    FlashClass5,           NULL}, /* Microm: MANUFACTURER_ID_MICRON */

    /* case2: new flash, ID is not included in case1 list, but specification is compatible with FlashClass1~FlashClass6 */
    // {(UXXA,          0x0000XXXX,    FlashClassX,           0x0000XXXX,      NULL)}, /* */

    /* case3: new flash, ID is not included in case1 list, and specification is not compatible with FlashClass1~FlashClass6 */
    {0x00,          0x000000FF,    FlashClassUser,         0xFFFFFFFF,     &flash_init_userdef}

    /* End */
    {0xFF,          0xFFFFFFFF,   FlashClassNone,        0xFFFFFFFF,     NULL},
};

```

Fig 13-1 Flash\_AVL

### 13.3.1.1 Dummy Cycles

When reading flash, host sends command and address to flash. After that host needs to send dummy cycles to flash before it sends data back. The number of dummy cycles is various for different read modes.

The following section would show you how to find dummy cycles from flash datasheet.

Taking Winbond W25Q16JV for an example, there are 6 dummy cycles in Read Quad I/O mode as Fig 13-2 shows.



Fig 13-2 Fast read quad I/O instruction sequence

In Read Dual I/O mode, there are 4 dummy cycles. The fast read dual I/O instruction sequence is shown in Fig 13-3.



Fig 13-3 Fast read dual I/O instruction sequence

Users can find the dummy cycle of Read Quad Output and Read Dual Output mode in the same way.

### 13.3.1.2 Other Parameters

The parameters comparison of these species are listed in Table 13-4.

Table 13-4 Dummy cycles with different read mode

| Items           | Parameters                                | FlashClass 1 | FlashClass 2 | FlashClass 3 | FlashClass 4 | FlashClass 5 | FlashClass 6 |
|-----------------|-------------------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Status Register | Status Register Number                    | 2            | 2 or 3       | 1            | 1            | 1            | 1            |
|                 | QE bit                                    | Bit[9]       | Bit[9]       | Bit[6]       | No exist     | No exist     | Bit[6]       |
|                 | BUSY bit                                  |              |              | Bit[0]       |              |              |              |
|                 | WEL bit                                   |              |              | Bit[1]       |              |              |              |
| Dummy Cycle     | READ                                      | 0            | 0            | 0            | 0            | 0            | 0            |
|                 | DREAD (1I/2O Read)                        | 8            | 8            | 8            | 8            | 3            | 8            |
|                 | 2READ (2*I/O Read)                        | 4            | 4            | 4            | 4            | 5            | 4            |
|                 | QREAD (1I/4O Read)                        | 8            | 8            | 8            | 8            | 5            | 8            |
|                 | 4READ (4*I/O Read)                        | 6            | 6            | 6            | 6            | 9            | 6            |
| Command         | Write Enable                              | 0x06         | 0x06         | 0x06         | 0x06         | 0x06         | 0x06         |
|                 | Read JEDEC ID                             | 0x9F         | 0x9F         | 0x9F         | 0x9F         | 0x9F         | 0x9F         |
|                 | Read Status Register 1                    | 0x05         | 0x05         | 0x05         | 0x05         | 0x05         | 0x05         |
|                 | Read Status Register 2                    | 0x35         | 0x35         | -            | -            | -            | -            |
|                 | Write Status Register 1                   | 0x01         | 0x01         | 0x01         | 0x01         | 0x01         | 0x01         |
|                 | Write Status Register 2 <sup>1</sup>      | -            | -/0x31       | -            | -            | -            | -            |
|                 | Chip Erase                                | 0x60         | 0x60         | 0x60         | 0x60         | 0xC7         | 0x60         |
|                 | Block Erase                               | 0xD8         | 0xD8         | 0xD8         | 0xD8         | 0xD8         | 0xD8         |
|                 | Sector Erase                              | 0x20         | 0x20         | 0x20         | 0x20         | 0x20         | 0x20         |
|                 | Power-down                                | 0xB9         | 0xB9         | 0xB9         | 0xB9         | 0xB9         | 0xB9         |
|                 | Release from Power-down                   | 0xAB         | 0xAB         | 0xAB         | 0xAB         | 0xAB         | 0xAB         |
|                 | READ                                      | 0x03         | 0x03         | 0x03         | 0x03         | 0x03         | 0x03         |
|                 | DREAD (1I/2O Read)                        | 0x3B         | 0x3B         | 0x3B         | 0x3B         | 0x3B         | 0x3B         |
|                 | 2READ (2*I/O Read)                        | 0xBB         | 0xBB         | 0xBB         | 0xBB         | 0xBB         | 0xBB         |
|                 | QREAD (1I/4O Read)                        | 0x6B         | 0x6B         | 0x6B         | 0x6B         | 0x6B         | 0x6B         |
|                 | 4READ (4*I/O Read)                        | 0xEB         | 0xEB         | 0xEB         | 0xEB         | 0xEB         | 0xEB         |
|                 | Read Configuration Register <sup>2</sup>  | -            | -            | -            | -            | -            | 0x15         |
|                 | Write Configuration Register <sup>3</sup> | -            | -            | -            | -            | -            | -            |

**Note 1:**

- For FlashClass1, the Write Status Register 2 is written together with the Write Status Register 1 using 0x01 as Fig 13-4 shows.
- For FlashClass2, when GD density is less than 2MB, the Write Status Register 2 is written together with the Write Status Register 1 using 0x01 as Fig 13-4 shows. When GD density is larger than 2MB, the Write Status Register 2 is written individually using 0x31 as Fig 13-5 shows.

**Note 2:** For MXIC wide-range VCC, the Read Configuration Register would be checked if chip is in High performance mode by default once power-on as Fig 13-6 shows. If not, we would switch it to High performance mode.

**Note 3:** For MXIC wide-range VCC, the Write Configuration Register is written together with Write Status Register using 0x01 as Fig 13-7 shows.



Fig 13-4 Write Status Register 1 & 2 sequence (FlashClass1, FlashClass2 when density < 2M)



Fig 13-5 Write Status Register 1/2 sequence (FlashClass2 when density > 2MB)



Fig 13-6 Read Configuration Register sequence (FlashClass6)



Fig 13-7 Write Status Register and Write Configuration Register sequence (FlashClass6)

### 13.3.2 FlashClass1

Table 13-5 lists the parameters for FlashClass1 which can't be modified by users.

Table 13-5 FlashClass1 parameters

| Command List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre> FLASH_InitStruct-&gt;FLASH_Id = FLASH_ID_WINBOND;  /*1.1 status bit define */ FLASH_InitStruct-&gt;FLASH_QuadEn_bit = BIT(9); FLASH_InitStruct-&gt;FLASH_Busy_bit = BIT(0); FLASH_InitStruct-&gt;FLASH_WLE_bit = BIT(1); FLASH_InitStruct-&gt;FLASH_Status2_exist = 1;  /*1.2 dummy cycle */ FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[0] = 0; FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[1] = 0x04; FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[2] = 0x06;  /*1.3 set 2 bits mode command */ FLASH_InitStruct-&gt;FLASH_rd_dual_io = 0xBB; FLASH_InitStruct-&gt;FLASH_rd_dual_o = 0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStruct-&gt;FLASH_rd_quad_io = 0xEB; FLASH_InitStruct-&gt;FLASH_rd_quad_o = 0x6B;  /*1.5 other flash command set */ FLASH_InitStruct-&gt;FLASH_cmd_wr_en = 0x06; FLASH_InitStruct-&gt;FLASH_cmd_rd_id = 0x9F; FLASH_InitStruct-&gt;FLASH_cmd_rd_status = 0x05; FLASH_InitStruct-&gt;FLASH_cmd_rd_status2 = 0x35; //FLASH_CMD_RDSR2; FLASH_InitStruct-&gt;FLASH_cmd_wr_status = 0x01; FLASH_InitStruct-&gt;FLASH_cmd_wr_status2 = 0; FLASH_InitStruct-&gt;FLASH_cmd_chip_e = 0x60; FLASH_InitStruct-&gt;FLASH_cmd_block_e = 0xD8; FLASH_InitStruct-&gt;FLASH_cmd_sector_e = 0x20; FLASH_InitStruct-&gt;FLASH_cmd_pwdn_release = 0xAB; FLASH_InitStruct-&gt;FLASH_cmd_pwdn = 0xB9;</pre> |

### 13.3.3 FlashClass2

Table 13-6 lists the parameters for FlashClass2 which can't be modified by users. FLASH\_cmd\_wr\_status2 would be set when density is larger than 2MB in SDK.

Table 13-6 FlashClass2 parameters

| Command List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre> FLASH_InitStruct-&gt;FLASH_Id = FLASH_ID_GD;  /*1.1 status bit define */ FLASH_InitStruct-&gt;FLASH_QuadEn_bit = BIT(9); FLASH_InitStruct-&gt;FLASH_Busy_bit = BIT(0); //WIP FLASH_InitStruct-&gt;FLASH_WLE_bit = BIT(1); //WLE FLASH_InitStruct-&gt;FLASH_Status2_exist = 1;  /*1.2 dummy cycle */ FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[0] = 0; FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[1] = 0x04; //(M7-4)2 + 2 dummy FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[2] = 0x06; //(M7-0)2 + 4 dummy;  /*1.3 set 2 bits mode command */ FLASH_InitStruct-&gt;FLASH_rd_dual_io = 0xBB; FLASH_InitStruct-&gt;FLASH_rd_dual_o = 0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStruct-&gt;FLASH_rd_quad_io = 0xEB; FLASH_InitStruct-&gt;FLASH_rd_quad_o = 0x6B;  /*1.5 other flash command set */ FLASH_InitStruct-&gt;FLASH_cmd_wr_en = 0x06; FLASH_InitStruct-&gt;FLASH_cmd_rd_id = 0x9F; FLASH_InitStruct-&gt;FLASH_cmd_rd_status = 0x05; FLASH_InitStruct-&gt;FLASH_cmd_rd_status2 = 0x35; FLASH_InitStruct-&gt;FLASH_cmd_wr_status = 0x01; FLASH_InitStruct-&gt;FLASH_cmd_wr_status2 = 0; FLASH_InitStruct-&gt;FLASH_cmd_chip_e = 0x60; FLASH_InitStruct-&gt;FLASH_cmd_block_e = 0xD8; FLASH_InitStruct-&gt;FLASH_cmd_sector_e = 0x20; FLASH_InitStruct-&gt;FLASH_cmd_pwdn_release = 0xAB; FLASH_InitStruct-&gt;FLASH_cmd_pwdn = 0xB9; </pre> |

### 13.3.4 FlashClass3

Table 13-7 lists the parameters for FlashClass3 which can't be modified by users.

Table 13-7 FlashClass3 parameters

| Command List                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre> FLASH_InitStruct-&gt;FLASH_Id = FLASH_ID_MXIC;  /*1.1 status bit define */ FLASH_InitStruct-&gt;FLASH_QuadEn_bit = BIT(6); FLASH_InitStruct-&gt;FLASH_Busy_bit = BIT(0); //WIP FLASH_InitStruct-&gt;FLASH_WLE_bit = BIT(1); //WLE FLASH_InitStruct-&gt;FLASH_Status2_exist = 0;  /*1.2 dummy cycle */ </pre> |

```
FLASH_InitStruct->FLASH_rd_dummy_cyle[0] = 0;  
FLASH_InitStruct->FLASH_rd_dummy_cyle[1] = 0x04;  
FLASH_InitStruct->FLASH_rd_dummy_cyle[2] = 0x06;  
  
/*1.3 set 2 bits mode command */  
FLASH_InitStruct->FLASH_rd_dual_io = 0xBB;  
FLASH_InitStruct->FLASH_rd_dual_o = 0x3B;  
  
/*1.4 set 4 bits mode command */  
FLASH_InitStruct->FLASH_rd_quad_io = 0xEB;  
FLASH_InitStruct->FLASH_rd_quad_o = 0x6B;  
  
/*1.5 other flash command set */  
FLASH_InitStruct->FLASH_cmd_wr_en = 0x06;  
FLASH_InitStruct->FLASH_cmd_rd_id = 0x9F;  
FLASH_InitStruct->FLASH_cmd_rd_status = 0x05;  
FLASH_InitStruct->FLASH_cmd_rd_status2 = 0;  
FLASH_InitStruct->FLASH_cmd_wr_status = 0x01;  
FLASH_InitStruct->FLASH_cmd_wr_status2 = 0;  
FLASH_InitStruct->FLASH_cmd_chip_e = 0x60;  
FLASH_InitStruct->FLASH_cmd_block_e = 0xD8;  
FLASH_InitStruct->FLASH_cmd_sector_e = 0x20;  
FLASH_InitStruct->FLASH_cmd_pwdn_release = 0xAB;  
FLASH_InitStruct->FLASH_cmd_pwdn = 0xB9;
```

### 13.3.5 FlashClass4

Table 13-8 lists the parameters for FlashClass4 which can't be modified by users.

Table 13-8 FlashClass4 parameters

| Command List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>FLASH_InitStruct-&gt;FLASH_Id = FLASH_ID_MXIC;<br/><br/>/*1.1 status bit define */<br/>FLASH_InitStruct-&gt;FLASH_QuadEn_bit = 0;<br/>FLASH_InitStruct-&gt;FLASH_Pbusy_bit = BIT(0); //WIP<br/>FLASH_InitStruct-&gt;FLASH_WLE_bit = BIT(1); //WLE<br/>FLASH_InitStruct-&gt;FLASH_Status2_exist = 0;<br/><br/>/*1.2 dummy cycle */<br/>FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[0] = 0;<br/>FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[1] = 0x04;<br/>FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[2] = 0x06;<br/><br/>/*1.3 set 2 bits mode command */<br/>FLASH_InitStruct-&gt;FLASH_rd_dual_io = 0xBB;<br/>FLASH_InitStruct-&gt;FLASH_rd_dual_o = 0x3B;<br/><br/>/*1.4 set 4 bits mode command */<br/>FLASH_InitStruct-&gt;FLASH_rd_quad_io = 0xEB;<br/>FLASH_InitStruct-&gt;FLASH_rd_quad_o = 0x6B;<br/><br/>/*1.5 other flash command set */<br/>FLASH_InitStruct-&gt;FLASH_cmd_wr_en = 0x06;<br/>FLASH_InitStruct-&gt;FLASH_cmd_rd_id = 0x9F;<br/>FLASH_InitStruct-&gt;FLASH_cmd_rd_status = 0x05;<br/>FLASH_InitStruct-&gt;FLASH_cmd_rd_status2 = 0;</pre> |

```

FLASH_InitStruct->FLASH_cmd_wr_status = 0x01;
FLASH_InitStruct->FLASH_cmd_wr_status2 = 0;
FLASH_InitStruct->FLASH_cmd_chip_e = 0x60;
FLASH_InitStruct->FLASH_cmd_block_e = 0xD8;
FLASH_InitStruct->FLASH_cmd_sector_e = 0x20;
FLASH_InitStruct->FLASH_cmd_pwdn_release = 0xAB;
FLASH_InitStruct->FLASH_cmd_pwdn = 0xB9;

```

### 13.3.6 FlashClass5

Table 13-9 lists the parameters for FlashClass5 which can't be modified by users.

Table 13-9 FlashClass5 parameters

| Command List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre> FLASH_InitStruct-&gt;FLASH_Id = FLASH_ID_MICRON;  /*1.1 status bit define */ FLASH_InitStruct-&gt;FLASH_QuadEn_bit = 0; FLASH_InitStruct-&gt;FLASH_Busy_bit = BIT(0); FLASH_InitStruct-&gt;FLASH_WLE_bit = BIT(1); FLASH_InitStruct-&gt;FLASH_Status2_exist = 0;  /*1.2 dummy cycle */ FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[0] = 0; /* set Micron rd_dummy_cyle based on baud rate, default 100MHz */ FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[1] = 0x05; FLASH_InitStruct-&gt;FLASH_rd_dummy_cyle[2] = 0x09;  /*1.3 set 2 bits mode command */ FLASH_InitStruct-&gt;FLASH_rd_dual_io = 0xBB; FLASH_InitStruct-&gt;FLASH_rd_dual_o = 0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStruct-&gt;FLASH_rd_quad_io = 0xEB; FLASH_InitStruct-&gt;FLASH_rd_quad_o = 0x6B;  /*1.5 other flash command set */ FLASH_InitStruct-&gt;FLASH_cmd_wr_en = 0x06; FLASH_InitStruct-&gt;FLASH_cmd_rd_id = 0x9F; FLASH_InitStruct-&gt;FLASH_cmd_rd_status = 0x05; FLASH_InitStruct-&gt;FLASH_cmd_rd_status2 = 0; FLASH_InitStruct-&gt;FLASH_cmd_wr_status = 0x01; FLASH_InitStruct-&gt;FLASH_cmd_wr_status2 = 0; FLASH_InitStruct-&gt;FLASH_cmd_chip_e = 0xC7; FLASH_InitStruct-&gt;FLASH_cmd_block_e = 0xD8; FLASH_InitStruct-&gt;FLASH_cmd_sector_e = 0x20; FLASH_InitStruct-&gt;FLASH_cmd_pwdn_release = 0xAB; FLASH_InitStruct-&gt;FLASH_cmd_pwdn = 0xB9; </pre> |

### 13.3.7 FlashClass6

Table 13-10 lists the parameters for FlashClass6 which can't be modified by users.

Table 13-10 FlashClass6 parameters

| Command List                                                |
|-------------------------------------------------------------|
| <pre> FLASH_InitStruct-&gt;FLASH_Id = FLASH_ID_MXIC; </pre> |

```
/*1.1 status bit define */
FLASH_InitStruct->FLASH_QuadEn_bit = BIT(6);
FLASH_InitStruct->FLASH_Busy_bit = BIT(0); //WIP
FLASH_InitStruct->FLASH_WLE_bit = BIT(1); //WLE
FLASH_InitStruct->FLASH_Status2_exist = 0;

/*1.2 dummy cycle */
FLASH_InitStruct->FLASH_rd_dummy_cyle[0] = 0;
FLASH_InitStruct->FLASH_rd_dummy_cyle[1] = 0x04;
FLASH_InitStruct->FLASH_rd_dummy_cyle[2] = 0x06;

/*1.3 set 2 bits mode command */
FLASH_InitStruct->FLASH_rd_dual_io = 0xBB;
FLASH_InitStruct->FLASH_rd_dual_o = 0x3B;

/*1.4 set 4 bits mode command */
FLASH_InitStruct->FLASH_rd_quad_io = 0xEB;
FLASH_InitStruct->FLASH_rd_quad_o = 0x6B;

/*1.5 other flash command set */
FLASH_InitStruct->FLASH_cmd_wr_en = 0x06;
FLASH_InitStruct->FLASH_cmd_rd_id = 0x9F;
FLASH_InitStruct->FLASH_cmd_rd_status = 0x05;
FLASH_InitStruct->FLASH_cmd_rd_status2 = 0;
FLASH_InitStruct->FLASH_cmd_wr_status = 0x01;
FLASH_InitStruct->FLASH_cmd_wr_status2 = 0;
FLASH_InitStruct->FLASH_cmd_chip_e = 0x60;
FLASH_InitStruct->FLASH_cmd_block_e = 0xD8;
FLASH_InitStruct->FLASH_cmd_sector_e = 0x20;
FLASH_InitStruct->FLASH_cmd_pwdn_release = 0xAB;
FLASH_InitStruct->FLASH_cmd_pwdn = 0xB9;
```

## 13.4 pinmapcfg

It needs doing I/O pull control when enter deep sleep and sleep mode. Otherwise it results power leakage. For example, UART voltage level is high.

If we pull down UART pin or not pull, then power leakage happens. So we need make sure each pin has proper pull control.

In SDK you should set GPIO function pull control and sleep pull control in pmap\_func based on your PCB board, and SDK will set pull control based on your setting between suspend and resume.

```

const PMAP_TypeDef pmap_func[] =
{
    // Pin Name      Func PU/PD      S1p PU/PD      DS1p PU/PD      LowPowerPin
    {PA_0,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_1,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_2,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_3,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_4,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_5,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_6,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_7,        GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //UART_LOG_TXD
    {PA_8,        GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //UART_LOG_RXD
    {PA_9,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_10,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_11,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // 
    {PA_12,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_13,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_14,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_15,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_16,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_17,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_18,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_19,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_20,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_21,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_22,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PA_23,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PA_24,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PA_25,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_26,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   TRUE}, //keyscan
    {PA_27,       GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //SWD_DATA or normal_m
    {PA_28,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PA_29,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PA_30,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PA_31,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_0,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_1,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_2,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_3,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //SWD_CLK
    {PB_4,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch0
    {PB_5,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch1
    {PB_6,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch2
    //PB_6,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE},
    {PB_7,        GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //Touch3
    {PB_8,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_9,        GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_10,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_11,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_12,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_13,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_CLK
    {PB_14,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_DATA0
    {PB_15,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //SPI_DATA2
    {PB_16,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //SPI_CS
    {PB_17,       GPIO_PuPd_UP,     GPIO_PuPd_DOWN,  GPIO_PuPd_KEEP,   FALSE}, //SPI_DATA1
    {PB_18,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_19,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_20,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_21,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_22,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //IR pin should no-pull
    //PB_22,       GPIO_PuPd_NOFULL, GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE},
    {PB_23,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_24,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_25,       GPIO_PuPd_DOWN,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_26,       GPIO_PuPd_SHUTDOWN, GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, // this is a pcb bc
    {PB_27,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_28,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_29,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_30,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PB_31,       GPIO_PuPd_UP,     GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //
    {PNC,         GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   GPIO_PuPd_KEEP,   FALSE}, //table end
};

```

## 13.5 sleepcfg

Keep default settings, you can only change these settings on Realtek RD's help.

## 13.6 bootcfg

Boot loader can be configured through this file:

```
/*
 * @brief MMU Configuration.
 * There are 8 MMU entries totally. Entry 0 & Entry 1 are already used by OTA, Entry 2~7 can be used by Users.
 */
BOOT_RAM_DATA_SECTION
MMU_ConfDef Flash_MMU_Config[] = {
    /*VAddrStart, VAddrEnd, PAddrStart, PAddrEnd*/
    {0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF}, //Entry 2
    {0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF}, //Entry 3
    {0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF}, //Entry 4
    {0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF}, //Entry 5
    {0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF}, //Entry 6
    {0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF}, //Entry 7
};

/*
 * @brief OTA start address. Because KMO & KM4 IMG2 are combined, users only need to set the start address
 * of KMO IMG2.
 */
BOOT_RAM_DATA_SECTION
u32 OTA_Region[2] = {
    0x08006000, /* OTA1 region start address */
    0x08106000, /* OTA2 region start address */
};

/*
 * @brief RSIP Mask Configuration.
 * There are 4 RSIP mask entries totally. Entry 0 is already used by System Data, Entry 3 is reserved by Realtek.
 * Only Entry 1 & Entry 2 can be used by Users.
 * MaskAddr: start address for RSIP Mask should be 4KB aligned.
 * MaskSize: size of the mask area, unit is 4KB
 */
BOOT_RAM_DATA_SECTION
RSIP_MaskDef RSIP_Mask_Config[] = {
    /*MaskAddr, MaskSize*/
    {0x08001000, 3}, //Entry 0: 4K system data & 4K backup & DPK

    /* customer can set here */
    {0xFFFFFFFF, 0xFFFF}, //Entry 1: can be used by users
    {0xFFFFFFFF, 0xFFFF}, //Entry 2: can be used by users
    {0xFFFFFFFF, 0xFFFF}, //Entry 3: Reserved by Realtek. If RDP is not used, this entry can be used by users.

    /* End */
    {0xFFFFFFFF, 0xFFFF},
};

/*
 * @brief GPIO force OTA1 as image2. 0xFF means force OTA1 trigger is disabled.
 * BIT[7]: active level, 0 is low level active, 1 is high level active.
 * BIT[6:5]: port, 0 is PORT_A, 1 is PORT_B
 * BIT[4:0]: pin num 0~31
 */
BOOT_RAM_DATA SECTION
u8 ForceOTA1_GPIO = 0xFF;

/**
 * @brief boot log enable or disable.
 * FALSE: disable
 * TRUE: enable
 */
BOOT_RAM_DATA SECTION
u8 Boot_Log_En = FALSE;

/**
 * @brief Firmware verify callback handler.
 * If users need to verify checksum/ hash for image2, implement the function and assign the address
 * to this function pointer.
 * @param None
 * @retval 1: Firmware verify successfully, 0: verify failed
 */
BOOT_RAM DATA SECTION
FuncPtr FwCheckCallback = NULL;

/**
 * @brief Firmware select hook.
 * If users need to implement own OTA select method, implement the function and assign the address
 * to this function pointer.
 * @param None
 * @retval 0: both firmwares are invalid, select none, 1: boot from OTA1, 2: boot from OTA2
 */
BOOT_RAM DATA SECTION
FuncPtr OTASelectHook = NULL;
```

Table 13-11 User bootcfg

| Items            | Configuration Items                                                   |
|------------------|-----------------------------------------------------------------------|
| Flash_MMU_Config | Used for MMU configure<br>OTA2 address mapping should be settled here |
| RSIP_Mask_Config | RSIP mask configure                                                   |
| Force OTA1_GPIO  | Force OTA1 GPIO configure                                             |
| Boot_Log_En      | Used to disable Reaktek boot log                                      |
| FwCheckCallback  | Firmware verify callback handler                                      |
| OTASelectHook    | Firmware select hook                                                  |
| OTA_Region       | OTA start address                                                     |

## 13.7 ipccfg

You can add IPC entry in the following table, so that KM4 & KMO can send message to each other by the method you defined.

For USER\_MSG\_TYPE:

- IPC\_USER\_POINT: Message in IRQFUNC is a pointer (address).
- IPC\_USER\_DATA: Message in IRQFUNC is just a value.

```
#if defined(ARM_CORE_CM4)
const IPC_INIT_TABLE ipc_init_config[] =
{
    { // USER_MSG_TYPE      IRQFUNC           IRQDATA
    [IPC_USER_DATA, shell_switch_ipc_int, (VOID*) NULL], //channel 0: IPC_INT_CHAN_SWITCH
    [IPC_USER_DATA, NULL, (VOID*) IPC4_DEV], //channel 1: IPC_INT_CHAN_WIFIFW
    [IPC_USER_DATA, FLASH_Write_IPC_Ext, (VOID*) NULL], //channel 2: IPC_INT_CHAN_FLASHPOLLREQ
    [IPC_USER_POINT, km4_tickless_ipc_int, (VOID*) NULL], //channel 3: IPC_INT_KM4_TICKLESS_INDICATION
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 4: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 5: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 6: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 7: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 8: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 9: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 10: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 11: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 12: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 13: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 14: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 15: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 16: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 17: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 18: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 19: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 20: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 21: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 22: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 23: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 24: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 25: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 26: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 27: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 28: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 29: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 30: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 31: Reserved for Customer use
    {0xFFFFFFFF, OFF, OFF}, /* Table end */
}
#endif

#ifndef CONFIG_WIFI_FW_EN
extern void driver_tw_flow_ipc_int(VOID *Data, u32 IrqStatus, u32 ChanNum);
#define fw_flow_ipc_int driver_tw_flow_ipc_int
#endif
#define fw_flow_ipc_int NULL
#endif
const IPC_INIT_TABLE ipc_init_config[] =
{
    { // USER_MSG_TYPE      IRQFUNC           IRQDATA
    [IPC_USER_DATA, shell_switch_ipc_int, (VOID*) NULL], //channel 0: IPC_INT_CHAN_SWITCH
    [IPC_USER_DATA, fw_flow_ipc_int, (VOID*) IPC4_DEV], //channel 1: IPC_INT_CHAN_WIFIFW
    [IPC_USER_DATA, FLASH_Write_IPC_Ext, (VOID*) NULL], //channel 2: IPC_INT_CHAN_FLASHPOLLREQ
    [IPC_USER_POINT, km4_tickless_ipc_int, (VOID*) NULL], //channel 3: IPC_INT_KM4_TICKLESS_INDICATION
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 4: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 5: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 6: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 7: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 8: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 9: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 10: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 11: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 12: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 13: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 14: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 15: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 16: Reserved for Realtek use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 17: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 18: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 19: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 20: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 21: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 22: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 23: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 24: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 25: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 26: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 27: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 28: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 29: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 30: Reserved for Customer use
    [IPC_USER_DATA, NULL, (VOID*) NULL], //channel 31: Reserved for Customer use
    {0xFFFFFFFF, OFF, OFF}, /* Table end */
}
#endif
```

**Note:** Please use IPC channel 16~31 and IPC semaphore index 8~15, Channel 0~15 and semaphore index 0~7 are reserved for Realtek use.

# 14 Hardware Crypto Engine

## 14.1 Introduction

Hardware Crypto Engine is used to authenticate, encrypt and decrypt packets. It can support the following Hash and Cipher functions:

- Hash (include HMAC): MD5/SHA1/SHA2 (224, 256), Poly1305
- Cipher: AES (ECB/CBC/CFB/OFB/CTR/GMAC/GHASH/GCM), 3DES (ECB/CBC/CFB/OFB/CTR), DES(ECB/CBC/CFB/OFB/CTR), ChaCha20, ChaCha20\_poly1305

Hardware Crypto Engine also support sequential hash for long plaintext length.

The following section illustrates the Hardware Crypto Engine APIs and how to use these APIs.

## 14.2 Hardware Crypto Engine APIs

### 14.2.1 Crypto Engine Initialize API

#### 14.2.1.1 rtl\_cryptoEngine\_init

| Items        | Description                                                                                |
|--------------|--------------------------------------------------------------------------------------------|
| Introduction | Hardware crypto engine initialization                                                      |
| Parameters   | N/A                                                                                        |
| Return       | Status value: <ul style="list-style-type: none"><li>• SUCCESS: initialization ok</li></ul> |

### 14.2.2 Hash APIs

#### 14.2.2.1 rtl\_crypto\_md5

| Items        | Description                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | MD5 calculation digest                                                                                                                            |
| Parameters   | <ul style="list-style-type: none"><li>• message: Plaintext</li><li>• msglen: Plaintext length</li><li>• pDigest: Result of MD5 function</li></ul> |
| Return       | Status value: <ul style="list-style-type: none"><li>• SUCCESS: MD5 ok</li><li>• Others: fail, refer to ERRNO</li></ul>                            |

#### 14.2.2.2 rtl\_crypto\_md5\_init

| Items        | Description                                                                                                                           |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | MD5 initialization (used for sequential hash)                                                                                         |
| Parameters   | N/A                                                                                                                                   |
| Return       | Status value: <ul style="list-style-type: none"><li>• SUCCESS: MD5 initialization ok</li><li>• Others: fail, refer to ERRNO</li></ul> |

#### 14.2.2.3 rtl\_crypto\_md5\_update

| Items        | Description                                                                                                                         |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | MD5 block calculation (used for sequential hash)                                                                                    |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Plaintext</li> <li>● msglen: Plaintext length</li> </ul>                          |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: MD5 update ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.4 rtl\_crypto\_md5\_final

| Items        | Description                                                                                                                        |
|--------------|------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | MD5 last block calculation (used for sequential hash)                                                                              |
| Parameters   | pDigest: Result of MD5 function                                                                                                    |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: MD5 final ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.5 rtl\_crypto\_sha1

| Items        | Description                                                                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA1 calculation digest                                                                                                                                |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Plaintext</li> <li>● msglen: Plaintext length</li> <li>● pDigest: Result of SHA1 function</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: SHA1 ok</li> <li>● Others: fail, refer to ERRNO</li> </ul>                          |

#### 14.2.2.6 rtl\_crypto\_sha1\_init

| Items        | Description                                    |
|--------------|------------------------------------------------|
| Introduction | SHA1 initialization (used for sequential hash) |
| Parameters   | N/A                                            |

#### 14.2.2.7 rtl\_crypto\_sha1\_update

| Items        | Description                                                                                                                          |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA1 block calculation (used for sequential hash)                                                                                    |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Plaintext</li> <li>● msglen: Plaintext length</li> </ul>                           |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: SHA1 update ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.8 rtl\_crypto\_sha1\_final

| Items | Description |
|-------|-------------|
|       |             |

|              |                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA1 last block calculation (used for sequential hash)                                                                        |
| Parameters   | pDigest: Result of SHA1 function                                                                                              |
| Return       | Status value: <ul style="list-style-type: none"><li>● SUCCESS: SHA1 final ok</li><li>● Others: fail, refer to ERRNO</li></ul> |

#### 14.2.2.9 rtl\_crypto\_sha2

| Items        | Description                                                                                                                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA2 calculation digest                                                                                                                                                                                |
| Parameters   | <ul style="list-style-type: none"><li>● sha2type: SHA2 type, SHA2_224 or SHA2_256</li><li>● message: Plaintext</li><li>● msglen: Plaintext length</li><li>● pDigest: Result of SHA2 function</li></ul> |
| Return       | Status value: <ul style="list-style-type: none"><li>● SUCCESS: SHA2 ok</li><li>● Others: fail, refer to ERRNO</li></ul>                                                                                |

#### 14.2.2.10 rtl\_crypto\_sha2\_init

| Items        | Description                                                                                                                        |
|--------------|------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA2 initialization (used for sequential hash)                                                                                     |
| Parameters   | sha2type: SHA2 type, SHA2_224 or SHA2_256                                                                                          |
| Return       | Status value: <ul style="list-style-type: none"><li>● SUCCESS: SHA2 initialize ok</li><li>● Others: fail, refer to ERRNO</li></ul> |

#### 14.2.2.11 rtl\_crypto\_sha2\_update

| Items        | Description                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA2 block calculation (used for sequential hash)                                                                              |
| Parameters   | <ul style="list-style-type: none"><li>● message: Plaintext</li><li>● msglen: Plaintext length</li></ul>                        |
| Return       | Status value: <ul style="list-style-type: none"><li>● SUCCESS: SHA2 update ok</li><li>● Others: fail, refer to ERRNO</li></ul> |

#### 14.2.2.12 rtl\_crypto\_sha2\_final

| Items        | Description                                                                                                                   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA2 last block calculation (used for sequential hash)                                                                        |
| Parameters   | pDigest: Result of SHA2 function                                                                                              |
| Return       | Status value: <ul style="list-style-type: none"><li>● SUCCESS: SHA2 final ok</li><li>● Others: fail, refer to ERRNO</li></ul> |

#### 14.2.2.13 rtl\_crypto\_hmac\_md5

| Items        | Description                                                                                                                                                |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-MD5 calculation digest                                                                                                                                |
| Parameters   | <ul style="list-style-type: none"><li>● key: HMAC-MD5 key, need to be 4-byte alignment</li><li>● keylen: key length</li><li>● message: Plaintext</li></ul> |

|        |                                                                                                                               |
|--------|-------------------------------------------------------------------------------------------------------------------------------|
|        | <ul style="list-style-type: none"> <li>msglen: Plaintext length</li> <li>pDigest: Result of HMAC-MD5 function</li> </ul>      |
| Return | Status value:<br><ul style="list-style-type: none"> <li>SUCCESS: HMAC-MD5 ok</li> <li>Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.14 rtl\_crypto\_hamc\_md5\_init

| Items        | Description                                                                                                                                  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-MD5 initialization (used for sequential hash)                                                                                           |
| Parameters   | <ul style="list-style-type: none"> <li>key: HMAC-MD5 key, need to be 4-byte alignment</li> <li>keylen: key length</li> </ul>                 |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>SUCCESS: HMAC-MD5 initialization ok</li> <li>Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.15 rtl\_crypto\_hmac\_md5\_update

| Items        | Description                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-MD5 block calculation (used for sequential hash)                                                                                       |
| Parameters   | <ul style="list-style-type: none"> <li>message: Plaintext</li> <li>msglen: Plaintext length</li> </ul>                                      |
| Return       | retval status value:<br><ul style="list-style-type: none"> <li>SUCCESS: HMAC-MD5 update ok</li> <li>Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.16 rtl\_crypto\_hmac\_md5\_final

| Items        | Description                                                                                                                         |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-MD5 last block calculation (used for sequential hash)                                                                          |
| Parameters   | pDigest: Result of HMAC-MD5 function                                                                                                |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>SUCCESS: HMAC-MD5 final ok</li> <li>Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.17 rtl\_crypto\_hmac\_sha1

| Items        | Description                                                                                                                                                                                                                                |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-SHA1 calculation digest                                                                                                                                                                                                               |
| Parameters   | <ul style="list-style-type: none"> <li>key: HMAC-SHA1 key, need to be 4-byte alignment</li> <li>keylen: key length</li> <li>message: Plaintext</li> <li>msglen: Plaintext length</li> <li>pDigest: Result of HMAC-SHA1 function</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>SUCCESS: HMAC-SHA1 ok</li> <li>Others: fail, refer to ERRNO</li> </ul>                                                                                                             |

#### 14.2.2.18 rtl\_crypto\_hmac\_sha1\_init

| Items        | Description                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------|
| Introduction | HMAC-SHA1 initialization (used for sequential hash)                                               |
| Parameters   | <ul style="list-style-type: none"> <li>key: HMAC-SHA1 key, need to be 4-byte alignment</li> </ul> |

|        |                                                                                                                                                   |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|        | <ul style="list-style-type: none"> <li>● keylen: key length</li> </ul>                                                                            |
| Return | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: HMAC-SHA1 initialization ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.19 rtl\_crypto\_hmac\_sha1\_update

| Items        | Description                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-SHA1 block calculation (used for sequential hash)                                                                                    |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Plaintext</li> <li>● msglen: Plaintext length</li> </ul>                                |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: HMAC-SHA1 update ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.20 rtl\_crypto\_hmac\_sha1\_final

| Items        | Description                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-SHA1 last block calculation (used for sequential hash)                                                                              |
| Parameters   | pDigest: Result of HMAC-SHA1 function                                                                                                    |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: HMAC-SHA1 final ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.21 rtl\_crypto\_hmac\_sha2

| Items        | Description                                                                                                                                                                                                                                                                                               |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-SHA2 calculation digest                                                                                                                                                                                                                                                                              |
| Parameters   | <ul style="list-style-type: none"> <li>● sha2type: SHA2 type, SHA2_224 or SHA2_256</li> <li>● key: HMAC-SHA2 key, need to be 4-byte alignment</li> <li>● keylen: Key length</li> <li>● message: Plaintext</li> <li>● msglen: Plaintext length</li> <li>● pDigest: Result of HMAC-SHA2 function</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: HMAC-SHA2 ok</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                                                                        |

#### 14.2.2.22 rtl\_crypto\_hmac\_sha2\_init

| Items        | Description                                                                                                                                                                            |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-SHA2 initialization (used for sequential hash)                                                                                                                                    |
| Parameters   | <ul style="list-style-type: none"> <li>● sha2type: SHA2 type, SHA2_224 or SHA2_256</li> <li>● key: HMAC-SHA2 key, need to be 4-byte alignment</li> <li>● keylen: Key length</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: HMAC-SHA2 initialization ok</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                      |

#### 14.2.2.23 rtl\_crypto\_hmac\_sha2\_update

| Items        | Description                                            |
|--------------|--------------------------------------------------------|
| Introduction | HMAC-SHA2 block calculation (used for sequential hash) |

|            |                                                                                                                                           |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters | <ul style="list-style-type: none"> <li>● message: Plaintext</li> <li>● msglen: Plaintext length</li> </ul>                                |
| Return     | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: HMAC-SHA2 update ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.24 rtl\_crypto\_hmac\_sha2\_final

| Items        | Description                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMAC-SHA2 last block calculation (used for sequential hash)                                                                              |
| Parameters   | pDigest: Result of HMAC-SHA2 function                                                                                                    |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: HMAC-SHA2 final ok</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.2.25 rtl\_crypto\_poly1305

| Items        | Description                                                                                                                                                                                                                                        |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | poly1305 calculation digest                                                                                                                                                                                                                        |
| Parameters   | <ul style="list-style-type: none"> <li>● key: poly1305 key, need to be 4-byte alignment</li> <li>● keylen: Key length</li> <li>● message: Plaintext</li> <li>● msglen: Plaintext length</li> <li>● pDigest: Result of poly1305 function</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: poly1305 ok</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                  |

### 14.2.3 Cipher APIs

#### 14.2.3.1 rtl\_crypto\_xxx\_xxx\_init

| Items        | Description                                                                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | xxx initialization<br>xxx can be aes_cbc/aes_ecb/aes_ctr/aes_cfb/aes_ofb/aes_gcm/3des_cbc/3des_ecb/3des_ctr/3des_cfb/3des_ofb/des_cbc/des_ecb/des_ctr/des_cfb/des_ofb |
| Parameters   | <ul style="list-style-type: none"> <li>● key: Cipher key.</li> <li>● keylen: Key length</li> </ul>                                                                    |
| Return       | status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: initialization OK</li> <li>● Others: fail, refer to ERRNO</li> </ul>                               |

#### 14.2.3.2 rtl\_crypto\_xxx\_xxx\_encrypt

| Items        | Description                                                                                                                                                                                                                 |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | xxx encryption<br>xxx can be aes_cbc/aes_ecb/aes_ctr/aes_cfb/aes_ofb/aes_gcm/3des_cbc/3des_ecb/3des_ctr/3des_cfb/3des_ofb/des_cbc/des_ecb/des_ctr/des_cfb/des_ofb                                                           |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Point to source message</li> <li>● msglen: Message length</li> <li>● iv: Initial vector</li> <li>● ivlen: iv length</li> <li>● pResult: Point to cipher result</li> </ul> |

|        |                                                                                                                                     |
|--------|-------------------------------------------------------------------------------------------------------------------------------------|
| Return | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: encryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul> |
|--------|-------------------------------------------------------------------------------------------------------------------------------------|

#### 14.2.3.3 rtl\_crypto\_xxx\_xxx\_decrypt

| Items        | Description                                                                                                                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | xxx decryption<br>xxx can be aes_cbc/aes_ecb/aes_ctr/aes_cfb/aes_ofb/aes_gcm/3des_cbc/3des_ecb/3des_ctr/3des_cfb/3des_ofb/des_cbc/des_ecb/des_ctr/des_cfb/des_ofb                                                                                   |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Point to source message</li> <li>● msglen: Message length</li> <li>● iv: Initial vector</li> <li>● ivlen: IV (initialization vector) length</li> <li>● pResult: Point to cipher result</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: decryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                 |

#### 14.2.3.4 rtl\_crypto\_aes\_gcm\_init

| Items        | Description                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | AES-GCM initialization                                                                                                                  |
| Parameters   | <ul style="list-style-type: none"> <li>● key: Cipher key</li> <li>● keylen: Key length</li> </ul>                                       |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: initialization OK</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.3.5 rtl\_crypto\_aes\_gcm\_encrypt

| Items        | Description                                                                                                                                                                                                                                                                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | AES-GCM encryption                                                                                                                                                                                                                                                                                                                                      |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Point to source message</li> <li>● msglen: Message length</li> <li>● iv: Initial vector</li> <li>● aad: Point to AAD (additional authentication data)</li> <li>● aadlen: AAD length</li> <li>● pResult: Point to cipher result</li> <li>● pTag: Point to MAC (Message Authentication Code)</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: encryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                                                                                                                     |

#### 14.2.3.6 rtl\_crypto\_aes\_gcm\_decrypt

| Items        | Description                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | AES-GCM decryption                                                                                                                                                                                                                                                                          |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Point to source message</li> <li>● msglen: Message length</li> <li>● iv: Initial vector</li> <li>● aad: Point to AAD (additional authentication data)</li> <li>● aadlen: AAD length</li> <li>● pResult: Point to cipher result</li> </ul> |

|        |                                                                                                                                     |
|--------|-------------------------------------------------------------------------------------------------------------------------------------|
|        | <ul style="list-style-type: none"> <li>● pTag: Point to MAC (Message Authentication Code) .</li> </ul>                              |
| Return | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: decryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.3.7 rtl\_crypto\_chacha\_init

| Items        | Description                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha20 initialization                                                                                                                 |
| Parameters   | key: Cipher key.                                                                                                                        |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: initialization OK</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.3.8 rtl\_crypto\_chacha\_encrypt

| Items        | Description                                                                                                                                                                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha20 encryption                                                                                                                                                                                                                                   |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Point to source message.</li> <li>● msglen: Message length</li> <li>● iv: Point to IV (initialization vector)</li> <li>● count: Counter value</li> <li>● pResult: Point to cipher result</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: encryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                   |

#### 14.2.3.9 rtl\_crypto\_chacha\_decrypt

| Items        | Description                                                                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha20 decryption                                                                                                                                                                                                                                  |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Point to source message</li> <li>● msglen: Message length</li> <li>● iv: Point to IV (initialization vector)</li> <li>● count: Counter value</li> <li>● pResult: Point to cipher result</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: decryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                  |

#### 14.2.3.10 rtl\_crypto\_chacha\_poly1305\_init

| Items        | Description                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha Poly1305 initialization                                                                                                          |
| Parameters   | key: Cipher key                                                                                                                         |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: initialization OK</li> <li>● Others: fail, refer to ERRNO</li> </ul> |

#### 14.2.3.11 rtl\_crypto\_chacha\_poly1305\_encrypt

| Items        | Description                |
|--------------|----------------------------|
| Introduction | ChaCha Poly1305 encryption |

|            |                                                                                                                                                                                                                                                                                                                                                          |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters | <ul style="list-style-type: none"> <li>● message: Point to source message</li> <li>● msglen: Message length</li> <li>● nonce: Random value</li> <li>● aad: Point to AAD (additional authentication data)</li> <li>● aadlen: AAD length</li> <li>● pResult: Point to cipher result</li> <li>● pTag: Point to MAC (Message Authentication Code)</li> </ul> |
| Return     | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: encryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                                                                                                                      |

#### 14.2.3.12 rtl\_crypto\_chacha\_poly1305\_decrypt

| Items        | Description                                                                                                                                                                                                                                                                                                                                              |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha Poly1305 decryption                                                                                                                                                                                                                                                                                                                               |
| Parameters   | <ul style="list-style-type: none"> <li>● message: Point to source message</li> <li>● msglen: Message length</li> <li>● nonce: Random value</li> <li>● aad: Point to AAD (additional authentication data)</li> <li>● aadlen: AAD length</li> <li>● pResult: Point to cipher result</li> <li>● pTag: Point to MAC (Message Authentication Code)</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● SUCCESS: decryption OK</li> <li>● Others: fail, refer to ERRNO</li> </ul>                                                                                                                                                                                                                      |

## 14.3 Hardware Crypto Engine APIs Usage

### 14.3.1 Start Hardware Crypto Engine

Before using hardware crypto engine, you need initialize it first. You can use Crypto Engine Initialize API to do this.

### 14.3.2 Start Crypto Engine Calculation

Choose a hash or cipher algorithm, and call the following APIs to calculate hash digest or ciphertext.

#### 14.3.2.1 Hash Algorithm

- Hash

If a hash algorithm is selected, then Hash APIs (*rtl\_crypto\_xxx*) can be used to calculate digest.

- Sequential Hash

Sequential hash is needed when source message length beyond hardware support. Sequential hash breaks a whole long message into several piece of message payload, then calculate the payload in sequence, until the last message payload.

When use sequential hash, you can follow the steps below:

Initialize sequential hash

    Use Hash APIs (*rtl\_crypto\_xxx\_init*) to initialize.

Handle each piece of message payload

    Call Hash APIs (*rtl\_crypto\_xxx\_update*) once when one piece message payload.

Handle the last piece of message payload

    Call Hash APIs (*rtl\_crypto\_xxx\_final*) once when one piece message payload.

#### 14.3.2.2 Cipher Algorithm

Steps to encrypt or decrypt message are as following:

- (1) Initialize  
    Use Cipher APIs (*rtl\_crypto\_xxx\_xxx\_init*) to initialize.
- (2) Encrypt or decrypt message  
    Call Cipher APIs (*rtl\_crypto\_xxx\_xxx\_encrypt*) to encrypt source message.  
    Call Cipher APIs (*rtl\_crypto\_xxx\_xxx\_decrypt*) to decrypt source message.

### 14.4 Demo Code Path

Hardware Crypto Engine demo code locates in folder: **project/realtek\_amebaD\_cm4\_gcc\_verification/example\_sources/CRYPTO**

# 15 eFuse

eFuse belongs to One Time Programmable (OTP) technology, its default value is '1' and can only be change from '1' to '0'. eFuse can be used to hold the individual and stable data such as key, calibration data, MAC address, specific setting, etc.

## 15.1 Power Requirement

The power requirement of eFuse is listed in Table 15-1.

Table 15-1 Operation under different voltage

| Supply Voltage (V) | Operation                                                                 |
|--------------------|---------------------------------------------------------------------------|
| 1.8                | Read                                                                      |
| 3.3                | <ul style="list-style-type: none"> <li>● Write</li> <li>● Read</li> </ul> |

**Note:** Only read operation is allowed under 1.8V. If you want to program eFuse, you must switch power to 3.3V.

## 15.2 eFuse Mapping

The Ameba-D eFuse layout is shown in Fig 15-1. The Physical eFuse size is 512 Bytes, and the first 288Bytes can be mapping to logical eFuse with size of 1024Bytes.



Fig 15-1 eFuse layout diagram

The way to program the eFuse for Logical Mapping and other Physical eFuse is not the same. The detailed APIs are described in section 15.6.

**Note:** Logical eFuse program will program header and package, and the package is in word, so it will take at least three bytes a time. Software also reserve one byte for isolation, so when the space of eFuse for Logical Mapping is less than four bytes, it cannot be program any mode.

## 15.3 eFuse Auto-load

eFuse can auto-load part of setting to control the circuit. eFuse auto-load is changed in word (two bytes). Under default condition, value of all the System Data bytes is 0xFF, and the System Configure Registers have its default values.

The way to change the value of System Configure Registers is as following:

- Make sure that first two bytes of System Data area are written 0x21, 0x87 correctly
- Program the corresponding bytes in word, if just program in byte, another byte will load the EFUSE default value 0xFF, which may make mistake
- Reboot the chip and the System Configure Registers will load the new values

## 15.4 Physical eFuse

### 15.4.1 Physical eFuse Layout

Table 15-2 Physical eFuse layout

| Area | Name                     | Address | Size | Access                                                                                  | Usage                              |
|------|--------------------------|---------|------|-----------------------------------------------------------------------------------------|------------------------------------|
| ①    | User0                    | 0x130   | 16B  | Software R/W                                                                            | Defined by user                    |
|      | User1                    | 0x140   | 16B  |                                                                                         | Defined by user                    |
| ②    | User2                    | 0x150   | 16B  | ● Software R/W<br>● TrustZone Protection                                                | Defined by user                    |
|      | User3                    | 0x160   | 16B  |                                                                                         | Defined by user                    |
|      | RDP KEY                  | 0x170   | 16B  |                                                                                         | Fixed by hardware                  |
| ③    | SWD KEY                  | 0x180   | 16B  | ● Software Trigger auto-load<br>● Software Read forbidden<br>● Software Write forbidden | Fixed by hardware                  |
|      | RSIP KEY                 | 0x190   | 16B  |                                                                                         | Fixed by hardware                  |
| ④    | Security Boot KEY        | 0x1A0   | 32B  | ● Software Read<br>● Software Write forbidden                                           | Fixed by ROM                       |
| ⑤    | Protection Configuration | 0x1C0   | 2B   | Auto-load to SYSON Register                                                             | Fixed by hardware to configure ①~④ |

### 15.4.2 Protection Configuration (R/W)

The protection configuration of eFuse is shown in Table 15-3.

Table 15-3 eFuse protection configuration bits

| Bit | Protection       | Size Bit                                 | Description                                          |
|-----|------------------|------------------------------------------|------------------------------------------------------|
| 0   | SWD Protection   | SWD_PWD_RD_Forbidden_EN                  | 0: Read Forbidden                                    |
| 3   |                  | SWD_PWD_WR_Forbidden_EN                  | 0: Write Forbidden                                   |
| 8   |                  | SWD_Protection_Enable                    | 0: Enable SWD Protection                             |
| 9   | SWD Disable      | SWD_Secure_Noninvasive_Debug_Disable     | 0: SWD Secure Noninvasive Debug Disable              |
| 10  |                  | SWD_Secure_Invasive_Debug_Disable        | 0: SWD Secure Invasive Debug Disable                 |
| 11  |                  | SWD_Non-Secure_Noninvasive_Debug_Disable | 0: SWD Non-Secure Noninvasive Debug Disable          |
| 12  |                  | SWD_Non-Secure_Invasive_Debug_Disable    | 0: SWD Non-Secure Invasive Debug Disable             |
| 2   | RSIP Protection  | RSIP_KEY_RD_Forbidden_EN                 | 0: Read Forbidden                                    |
| 5   |                  | RSIP_KEY_WR_Forbidden_EN                 | 0: Write Forbidden                                   |
| 6   | SBOOT Protection | SBOOT_PK_WR_Forbidden_EN                 | 0: Write Forbidden                                   |
| 13  |                  | SECURE_BOOT_EN                           | Software used<br>0: Enable Security Boot (ECC check) |
| 7   | DEBUG Protection | SIC_Security_Enable                      | 0: Disable SIC Security                              |

|    |  |              |                                                                                                                             |
|----|--|--------------|-----------------------------------------------------------------------------------------------------------------------------|
| 14 |  | CPU_PC_DBGEN | <ul style="list-style-type: none"><li>● 1: Enable to get KM4/KM0 PC value through debug port</li><li>● 0: Disable</li></ul> |
| 1  |  | RSVD         |                                                                                                                             |
| 4  |  | RSVD         |                                                                                                                             |
| 15 |  | RSVD         |                                                                                                                             |

## 15.5 Logical eFuse

There are 1024B logical eFuse in Ameba-D, as Table 15-4 shows.

Table 15-4 Logical eFuse layout

| Start Address | End Address | Description                   |
|---------------|-------------|-------------------------------|
| 0x000         | 0x01F       | System Data to be auto-loaded |
| 0x020         | 0x15F       | WIFI calibration data         |
| 0x160         | 0x17F       | User MTP                      |
| 0x180         | 0x183       | Cap-Touch                     |
| 0x184         | 0x18F       | Reserved                      |
| 0x190         | 0x1A4       | BT parameters                 |
| 0x1A5         | 0x1BF       | Reserved                      |
| 0x1C0         | 0x1CF       | HCI USB                       |
| 0x1D0         | 0x1DF       | ADC calibration               |
| 0x1E0         | 0x1FF       | Reserved                      |
| 0x200         | 0x2FF       | Reserved for Realtek          |

**For WIFI:**  
Customers only need to fill on these eFuse locations for MP (Mass Production) calibration.

|     | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | A  | B  | C  | D  | E  | F  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 000 | 95 | 81 | C2 | 16 | FF |
| 010 | FF |
| 020 | FF |
| 030 | FF |
| 040 | FF |
| 050 | FF |
| 060 | FF |
| 070 | FF |
| 080 | FF |
| 090 | FF |
| 0A0 | FF |
| 0B0 | FF |
| 0C0 | FF |
| 0D0 | FF |
| 0E0 | FF |
| 0F0 | FF |
| 100 | FF |
| 110 | FF |
| 120 | FF |
| 130 | FF |
| 140 | FF |
| 150 | FF |
| 160 | FF |
| 170 | FF |
| 180 | FF |
| 190 | FF |
| 1A0 | FF |
| 1B0 | FF |
| 1C0 | FF |
| 1D0 | FF |
| 1E0 | FF |
| 1F0 | FF |

Fig 15-2 Wi-Fi eFuse data

### 15.5.1 Wi-Fi 2.4G Power Index

The address and specification of 2.4G power index is shown in Fig 15-3 and Fig 15-4.

|     | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | A  | B  | C  | D  | E  | F  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 020 | FF |

Fig 15-3 2.4G Wi-Fi power index address

| offset | name            | comment                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20~25  | 2.4G CCK Index  | Path A CCK Power Index for Ch 1,2, Range 0~127,0.25dbm/step.<br>Path A CCK Power Index for Ch 3, 4, 5, Range 0~127,0.25dbm/step.<br>Path A CCK Power Index for Ch 6, 7 ,8, Range 0~127,0.25dbm/step.<br>Path A CCK Power Index for Ch 9, 10, 11, Range 0~127,0.25dbm/step.<br>Path A CCK Power Index for Ch 12, 13, Range 0~127,0.25dbm/step.<br>Path A CCK Power Index for Ch 14, Range 0~127,0.25dbm/step. |
| 26~2A  | 2.4G BW40 Index | Path A 2G BW40-1S Power Index for Ch 1, 2, Range 0~127,0.25dbm/step.<br>Path A 2G BW40-1S Power Index for Ch 3, 4, 5, Range 0~127,0.25dbm/step.<br>Path A 2G BW40-1S Power Index for Ch 6, 7 ,8, Range 0~127,0.25dbm/step.<br>Path A 2G BW40-1S Power Index for Ch 9, 10, 11, Range 0~127,0.25dbm/step.<br>Path A 2G BW40-1S Power Index for Ch 12, 13, 14 Range 0~127,0.25dbm/step.                         |
| 2B     | 2.4G Difference | Power Index Difference between BW20-1S and BW40-1S.<br>Bit[7:4]: Path A 2G Offset, Range -8~7,0.5dbm/step.<br>Power Index Difference between OFDM-1Tx and BW40-1S.<br>Bit[3:0]: Path A 2G Offset, Range -8~7,0.5dbm/step.                                                                                                                                                                                    |

Fig 15-4 2.4G Wi-Fi power index specification

### 15.5.2 Wi-Fi 5G Power Index

The address and specification of 5G power index is shown in Fig 15-5 and Fig 15-6.

|     | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | A  | B  | C  | D  | E  | F  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 030 | FF |
| 040 | FF |

Fig 15-5 5G Wi-Fi power index address

|       |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 32~3F | 5G BW40 Index | Path A 5G BW40-1S Power Index for Ch 36,38,40, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 44,46,48, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 52,54,56, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 60,62,64, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 100,102,104, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 108,110,112, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 116,118,120, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 124,126,128, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 132,134,136, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 140,142,144, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 149,151,153, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 157,159,161, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 165,167,169, Range 0~127,0.25dbm/step.<br>Path A 5G BW40-1S Power Index for Ch 173,175,177, Range 0~127,0.25dbm/step. |
| 40    | 5G Difference | Power Index Difference between BW20-1S and BW40-1S.<br>Bit[7:4]: Path A 5G Offset, Range -8~7,0.5dbm/step.<br>Power Index Difference between OFDM-1Tx and BW40-1S.<br>Bit[3:0]: Path A 5G Offset, Range -8~7,0.5dbm/step.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Fig 15-6 5G Wi-Fi power index specification

### 15.5.3 Wi-Fi Channel Plan



Fig 15-7 Channel plan

| eFuse | Name         | Bit | Default | Comment                                                                                                                                                                                                                                      |
|-------|--------------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C8    | Channel Plan | 8   | 7Fh     | Bit[7]: Software configure mode<br>● 0h: Enable software configure (refer to Channel Plane Domain Code)<br>● 1h: Disable software configure (can't change Channel Plan Setting)<br>Bit[6:0]: Channel Plan, default means: 2G_WORLD, 5G_WORLD |

You can program eFuse channel plan based on Table 15-5.

Table 15-5 eFuse channel plan in driver

| Channel Plan in Driver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>//===== new channel plan mapping, (2GDOMAIN_5GDOMAIN) =====/ RT_CHANNEL_DOMAIN_WORLD_NULL = 0x20, RT_CHANNEL_DOMAIN_ETS11_NULL = 0x21, RT_CHANNEL_DOMAIN_FCC1_NULL = 0x22, RT_CHANNEL_DOMAIN_MKK1_NULL = 0x23, RT_CHANNEL_DOMAIN_ETS12_NULL = 0x24, RT_CHANNEL_DOMAIN_FCC1_FCC1 = 0x25, RT_CHANNEL_DOMAIN_WORLD_ETS1 = 0x26, RT_CHANNEL_DOMAIN_MKK1_MKK1 = 0x27, RT_CHANNEL_DOMAIN_WORLD_KCC1 = 0x28, RT_CHANNEL_DOMAIN_WORLD_FCC2 = 0x29, RT_CHANNEL_DOMAIN_FCC2_NULL = 0x2A, RT_CHANNEL_DOMAIN_IC1_IC2 = 0x2B, RT_CHANNEL_DOMAIN_MKK2_NULL = 0x2C, RT_CHANNEL_DOMAIN_WORLD_CHILE1 = 0x2D, RT_CHANNEL_DOMAIN_WORLD1_WORLD1 = 0x2E, RT_CHANNEL_DOMAIN_WORLD_CHILE2 = 0x2F, RT_CHANNEL_DOMAIN_WORLD_FCC3 = 0x30, RT_CHANNEL_DOMAIN_WORLD_FCC4 = 0x31, RT_CHANNEL_DOMAIN_WORLD_FCC5 = 0x32, RT_CHANNEL_DOMAIN_WORLD_FCC6 = 0x33, RT_CHANNEL_DOMAIN_FCC1_FCC7 = 0x34, RT_CHANNEL_DOMAIN_WORLD_ETS12 = 0x35, RT_CHANNEL_DOMAIN_WORLD_ETS13 = 0x36, RT_CHANNEL_DOMAIN_MKK1_MKK2 = 0x37, RT_CHANNEL_DOMAIN_MKK1_MKK3 = 0x38, RT_CHANNEL_DOMAIN_FCC1_NCC1 = 0x39, RT_CHANNEL_DOMAIN_FCC1_NCC2 = 0x40, RT_CHANNEL_DOMAIN_GLOBAL_NULL = 0x41, RT_CHANNEL_DOMAIN_ETS11_ETS14 = 0x42, RT_CHANNEL_DOMAIN_FCC1_FCC2 = 0x43, RT_CHANNEL_DOMAIN_FCC1_NCC3 = 0x44, RT_CHANNEL_DOMAIN_WORLD_ACMA1 = 0x45, RT_CHANNEL_DOMAIN_FCC1_FCC8 = 0x46, RT_CHANNEL_DOMAIN_WORLD_ETS16 = 0x47, RT_CHANNEL_DOMAIN_WORLD_ETS17 = 0x48, RT_CHANNEL_DOMAIN_WORLD_ETS18 = 0x49, RT_CHANNEL_DOMAIN_WORLD_ETS19 = 0x50,</pre> |

```

RT_CHANNEL_DOMAIN_WORLD_ETSI10 = 0x51,
RT_CHANNEL_DOMAIN_WORLD_ETSI11 = 0x52,
RT_CHANNEL_DOMAIN_FCC1_NCC4 = 0x53,
RT_CHANNEL_DOMAIN_WORLD_ETSI12 = 0x54,
RT_CHANNEL_DOMAIN_FCC1_FCC9 = 0x55,
RT_CHANNEL_DOMAIN_WORLD_ETSI13 = 0x56,
RT_CHANNEL_DOMAIN_FCC1_FCC10 = 0x57,
RT_CHANNEL_DOMAIN_MKK2_MKK4 = 0x58,
RT_CHANNEL_DOMAIN_WORLD_ETSI14 = 0x59,
RT_CHANNEL_DOMAIN_FCC1_FCC5 = 0x60,
RT_CHANNEL_DOMAIN_FCC2_FCC7 = 0x61,
RT_CHANNEL_DOMAIN_FCC2_FCC1 = 0x62,
RT_CHANNEL_DOMAIN_WORLD_ETSI15 = 0x63,
RT_CHANNEL_DOMAIN_MKK2_MKK5 = 0x64,
RT_CHANNEL_DOMAIN_ETSI1_ETSI16 = 0x65,
RT_CHANNEL_DOMAIN_FCC1_FCC14 = 0x66,
RT_CHANNEL_DOMAIN_FCC1_FCC12 = 0x67,
RT_CHANNEL_DOMAIN_FCC2_FCC14 = 0x68,
RT_CHANNEL_DOMAIN_FCC2_FCC12 = 0x69,
RT_CHANNEL_DOMAIN_ETSI1_ETSI17 = 0x6A,
RT_CHANNEL_DOMAIN_WORLD_FCC16 = 0x6B,
RT_CHANNEL_DOMAIN_WORLD_FCC13 = 0x6C,
RT_CHANNEL_DOMAIN_FCC2_FCC15 = 0x6D,
RT_CHANNEL_DOMAIN_WORLD_FCC12 = 0x6E,
RT_CHANNEL_DOMAIN_NULL_ETSI8 = 0x6F,
RT_CHANNEL_DOMAIN_NULL_ETSI18 = 0x70,
RT_CHANNEL_DOMAIN_NULL_ETSI17 = 0x71,
RT_CHANNEL_DOMAIN_NULL_ETSI19 = 0x72,
RT_CHANNEL_DOMAIN_WORLD_FCC7 = 0x73,
RT_CHANNEL_DOMAIN_FCC2_FCC17 = 0x74,
RT_CHANNEL_DOMAIN_WORLD_ETSI20 = 0x75,
RT_CHANNEL_DOMAIN_FCC2_FCC11 = 0x76,
RT_CHANNEL_DOMAIN_WORLD_ETSI21 = 0x77,
RT_CHANNEL_DOMAIN_FCC1_FCC18 = 0x78,
RT_CHANNEL_DOMAIN_MKK2_MKK1 = 0x79,

```

//===== Add new channel plan above this line=====//

```

RT_CHANNEL_DOMAIN_MAX,
RT_CHANNEL_DOMAIN_REALTEK_DEFINE = 0x7F

```

#### 15.5.4 Wi-Fi Crystal Calibration



Fig 15-8 Crystal Calibration

| eFuse | Name                | Bit | Default | Comment                                                                             |
|-------|---------------------|-----|---------|-------------------------------------------------------------------------------------|
| C9    | Crystal Calibration | 8   | 3Fh     | XTAL_K Value<br>• Bit[6:0]: Xi=Xo, range 0~7Fh<br>• Bit[7]: reserved<br>• FFh = 00h |

### 15.5.5 Wi-Fi Thermal Meter



Fig 15-9 Thermal Meter

| eFuse | Name          | Bit | Default | Comment                                                                                                                                                                |
|-------|---------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CA    | Thermal Meter | 8   | 20h     | Thermal Meter Default Value<br>System maker will calibrate a value and save it in EEPROM.<br>Bit[7:0]: Thermal Meter Value<br>0xFF: Disable Tx power tracking function |

### 15.5.6 Wi-Fi MAC Address



Fig 15-10 MAC Address

| Address Offset | Bit   | Default | Comment              |
|----------------|-------|---------|----------------------|
| Byte 11A       | [7:0] | FF      | MAC Address: [7:0]   |
| Byte 11B       | [7:0] | FF      | MAC Address: [15:8]  |
| Byte 11C       | [7:0] | FF      | MAC Address: [23:16] |
| Byte 11D       | [7:0] | FF      | MAC Address: [31:24] |
| Byte 11E       | [7:0] | FF      | MAC Address: [39:32] |
| Byte 11F       | [7:0] | FF      | MAC Address: [47:40] |

### 15.5.7 Cap-Touch

| Address Offset | Bit   | Default | Description                             | Reg. |
|----------------|-------|---------|-----------------------------------------|------|
| 180h           | [7:0] | FF      | Touch key channel 0 threshold[7:0]      |      |
| 181h           | [6:0] | FF      | Touch key channel 1 threshold[6:0]      |      |
|                | [7]   | FF      | Touch key channel 0 threshold[8]        |      |
| 182h           | [6:0] | FF      | Touch key channel 2 threshold diff[6:0] |      |
|                | [7]   | FF      | Touch key channel 0 threshold[9]        |      |
| 183h           | [6:0] | FF      | Touch key channel 3 threshold diff[6:0] |      |
|                | [7]   | FF      | Touch key channel 0 threshold[10]       |      |

### 15.5.8 Bluetooth

| Address Offset | Bit    | Default | Description                                                                                                                |
|----------------|--------|---------|----------------------------------------------------------------------------------------------------------------------------|
| 190~195h       | [47:0] |         | BD address (module must)                                                                                                   |
| 196h           | [7:0]  |         | ENABLE_PHY_INIT[0]<br>iqm_txgaink_module_valid<br>iqm_txgain_flatk_module_valid<br>lbt_mode[4:3]<br>lbt_enable[5]<br>rsvd1 |
| 197h           | [7:0]  |         | iqm_txgaink_module                                                                                                         |
| 198~199h       | [15:0] |         | iqm_txgain_flatk_module                                                                                                    |
| 19Ah           | [7:0]  |         | iqm_txgain_10dBm_raw_index                                                                                                 |

|      |       |  |                                           |
|------|-------|--|-------------------------------------------|
| 19Bh | [7:0] |  | lbt_ant_gain                              |
| 19Ch | [7:0] |  | iqm_max_txgain_LE1M                       |
| 19Dh | [7:0] |  | iqm_max_txgain_LE2M                       |
| 19Eh | [7:0] |  | iqm_max_txgain_LE1M_adv                   |
| 19Fh | [7:0] |  | iqm_max_txgain_LE2M_adv                   |
| 1A0h | [7:0] |  | otp.phy_init_cfg.tmeterx4_txgain_k_module |
| 1A1h | [7:0] |  | iqm_max_txgain_LE1M_2402                  |
| 1A2h | [7:0] |  | iqm_max_txgain_LE1M_2480                  |
| 1A3h | [7:0] |  | iqm_max_txgain_LE2M_2402                  |
| 1A4h | [7:0] |  | iqm_max_txgain_LE2M_2480                  |

### 15.5.9 HCI USB

| Address Offset | Name            | Bit   |
|----------------|-----------------|-------|
| Byte 1C0       | VID[7:0]        | [7:0] |
| Byte 1C1       | VID[15:8]       | [7:0] |
| Byte 1C2       | PID[7:0]        | [7:0] |
| Byte 1C3       | PID[15:8]       | [7:0] |
| Byte 1C4       | USB device type | [7:0] |
| Byte 1C5~1CF   | RSVD            |       |

### 15.5.10 ADC

| Address Offset | Bit    | Description                                                   |
|----------------|--------|---------------------------------------------------------------|
| 1D0 ~ 1D1h     | [16:0] | Normal channel (CH0~CH6) single-end input, OFFSET parameter   |
| 1D2 ~ 1D3h     | [16:0] | Normal channel (CH0~CH6) single-end input, GAIN parameter     |
| 1D4 ~ 1D5h     | [16:0] | VBAT channel OFFSET                                           |
| 1D6 ~ 1D7h     | [16:0] | VBAT channel GAIN                                             |
| 1D8 ~ 1D9h     | [16:0] | Normal channel (CH0~CH6) differential input, OFFSET parameter |
| 1DA ~ 1DBh     | [16:0] | Normal channel (CH0~CH6) differential input, GAIN parameter   |
| 1DC ~ 1DFh     | [31:0] | RSVD for ADC calibration                                      |

## 15.6 eFuse PG APIs

| Items         | API               | Comment                                              |
|---------------|-------------------|------------------------------------------------------|
| Low Level API | EFUSE_PMAP_WRITE8 | Physical map write one byte                          |
|               | EFUSE_PMAP_READ8  | Physical map read one byte                           |
|               | EFUSE_LMAP_WRITE  | Write eFuse logical address by length                |
|               | EFUSE_LMAP_READ   | Read total eFuse logical map                         |
| mbed API      | efuse_otp_write   | Write content to OTP EFUSE by length                 |
|               | efuse_otp_read    | Read eFuse OTP content by length                     |
|               | efuse_mtp_write   | Write user's content to USER MTP Space (0x160~0x17F) |
|               | efuse_mtp_read    | Read eFuse content from address (0x160 ~ 0x17F)      |

### 15.6.1 EFUSE\_PMAP\_WRITE8

| Items        | Description                                                                                                                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Physical map write one byte                                                                                                                                                                                     |
| Parameters   | <ul style="list-style-type: none"> <li>● CtrlSetting: eFuse control setting read from REG_LP_EFUSE_CTRL1 (suggest 0)</li> <li>● Addr: eFuse physical address</li> <li>● Data: one byte data to write</li> </ul> |

|        |                                                                                                                    |
|--------|--------------------------------------------------------------------------------------------------------------------|
|        | <ul style="list-style-type: none"> <li>● L25OutVoltage: L25EOUTVOLTAGE.</li> </ul>                                 |
| Return | Status value:<br><ul style="list-style-type: none"> <li>● _TRUE: write ok</li> <li>● _FALSE: write fail</li> </ul> |

### 15.6.2 EFUSE\_PMAP\_READ8

| Items        | Description                                                                                                                                                                                                                                                                 |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Physical map read one byte                                                                                                                                                                                                                                                  |
| Parameters   | <ul style="list-style-type: none"> <li>● CtrlSetting: eFuse control setting read from REG_LP_EFUSE_CTRL1 (suggest 0)</li> <li>● Addr: eFuse physical address</li> <li>● Data: One byte data buffer for eFuse data read</li> <li>● L25OutVoltage: L25EOUTVOLTAGE.</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● _TRUE: read ok</li> <li>● _FALSE: read fail</li> </ul>                                                                                                                                                            |

### 15.6.3 EFUSE\_LMAP\_WRITE

| Items        | Description                                                                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write eFuse logical address by length                                                                                                                                                   |
| Parameters   | <ul style="list-style-type: none"> <li>● addr: logical address, should be word-aligned</li> <li>● cnts: byte number, should be even</li> <li>● data: data buffer to be write</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● _SUCCESS: write ok</li> <li>● _FAIL: write fail</li> </ul>                                                                    |

### 15.6.4 EFUSE\_LMAP\_READ

| Items        | Description                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------|
| Introduction | Read total eFuse logical map                                                                                       |
| Parameters   | pbuf: 1024 bytes length buffer used for eFuse Logical map                                                          |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● _SUCCESS: read ok</li> <li>● _FAIL: read fail</li> </ul> |

### 15.6.5 efuse\_otp\_write

| Items        | Description                                                                                                                                                                                                                 |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write content to OTP eFuse by length (mbed API)                                                                                                                                                                             |
| Parameters   | <ul style="list-style-type: none"> <li>● address: Specifies the offset of the programmed OTP.</li> <li>● len: Specifies the data length of programmed data.</li> <li>● buf: Specified the data to be programmed.</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● 0: Success</li> <li>● -1: Failure</li> </ul>                                                                                                                      |

### 15.6.6 efuse\_otp\_read

| Items | Description |
|-------|-------------|
|       |             |

|              |                                                                                                                                                                                                                       |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Read eFuse OTP content by length (mbed API)                                                                                                                                                                           |
| Parameters   | <ul style="list-style-type: none"> <li>● address: Specifies the offset of the OTP.</li> <li>● len: Specifies the length of readback data.</li> <li>● buf: Specified the address to save the readback data.</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● 0: Success</li> <li>● -1: Failure</li> </ul>                                                                                                                |

### 15.6.7 efuse\_mtp\_write

| Items        | Description                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write user's content to USER MTP Space (0x160~0x17F)                                                                                     |
| Parameters   | <ul style="list-style-type: none"> <li>● data: Specified the data to write</li> <li>● len: Specified the data length to write</li> </ul> |
| Return       | Status value:<br><ul style="list-style-type: none"> <li>● 0 ~ 32: SUCCESS</li> <li>● 0 or -1: FAIL</li> </ul>                            |

### 15.6.8 efuse\_mtp\_read

| Items        | Description                                            |
|--------------|--------------------------------------------------------|
| Introduction | Read eFuse content from address (0x160 ~ 0x17F)        |
| Parameters   | Data: Specified the address to save the read back data |
| Return       | N/A                                                    |

## 15.7 eFuse PG Command

| Items                                        | Offset      | Command                                                  |
|----------------------------------------------|-------------|----------------------------------------------------------|
| TX Power Index                               | 0x20~0x2B   | iwpriv config_set wmap,020,202020202020202020202002      |
| Channel plan, X'tal & Thermal & RTK reserved | 0xC8~0xCF   | iwpriv config_set wmap,0C8,20201A05000000FF <sup>1</sup> |
| MAC Address                                  | 0x11A~0x11F | iwpriv config_set wmap,11a,00e04c870102                  |
| Realtek RSVD                                 | 0x130~0x139 | iwpriv config_set wmap,130,FF01001000FF00FF1000          |
| Get all eFuse map                            |             | iwpriv config_get realmap                                |

## 15.8 eFuse Check Sequence (TBD)

eFuse should be checked to make sure if it's programed right after program.

- eFuse write
- HAL\_WRITE32 (0x40000000, 0x00EC, 0x00000000)
- eFuse read
- HAL\_WRITE32 (0x40000000, 0x00EC, 0x04000000)
- Check if eFuse write ok.

<sup>1</sup> Channel plan does not affect the results of RF verification, so you can choose whether or not to write the correct channel plan here.

# 16 Flash Operation

## 16.1 Functional Description

Ameba-D uses SPI Flash Controller (SPIC) to communicate with SPI NOR flash.

There are two operation modes for SPIC: auto mode and user mode.

- User mode

User mode is a typical software flow to implement all serial transfer. User can transmit or receive data from SPI flash through setting up SPIC registers.

- Auto mode

Compared to user mode, auto mode is a hardware control flow to execute. After initial setting, user don't need to configure the related control register for each transfer operation. Auto mode is a convenient way to access SPI flash just as access memory (SRAM or DRAM).

The SPIC is initialized automatically in boot sequence, and user must not initialize SPIC manually. The supported mode for different operations can be found in Table 16-1.

Table 16-1 SPIC operation mode

| Flash Operation          | SPIC Operation Mode |
|--------------------------|---------------------|
| Read data                | Auto mode/User mode |
| Program data             | User mode           |
| Erase                    | User mode           |
| Receive/transmit command | User mode           |

**Note:** Auto mode and user mode can't be used at the same time.

## 16.2 Protection Method

Considering Ameba-D supports flash execute in place (XIP), which enables code executing directly in flash memory without copying to RAM. Both KM0 and KM4 CPU cores can issue request to SPIC in auto mode to read instructions from flash to execute.

To prevent interrupted by auto mode reading, the user mode operation should be protected until it is finished. The Fig 16-1 shows the flow of KM0 manipulate flash safely in user mode, which has been protected. The method of KM4 manipulate flash is in the same way.

The protection methods are implemented in **FLASH\_Write\_Lock()** and **FLASH\_Write\_Unlock()** functions. The APIs provided by Realtek in 16.3 and 16.4 are already protected and can be called by users directly.

**Note:** If users need to implement user mode function by themselves, the code of manipulating SPIC should locate in RAM instead of flash. And it should also call **FLASH\_Write\_Lock()** before operation and call **FLASH\_Write\_Unlock()** to release from protection after operation.



Fig 16-1 User mode operation flow

## 16.3 Flash Raw API

### 16.3.1 Read

#### 16.3.1.1 HAL\_READ8/ HAL\_READ16/ HAL\_READ32

| Items        | Description                                                                                                                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Read 1-byte/1-word/1-dword data from flash in <b>auto mode</b> , just as access SRAM.                                                                                                                                                                                                                |
| Parameters   | <ul style="list-style-type: none"> <li>base: the base address of flash memory. It should be SPI_FLASH_BASE which is 0x08000000.</li> <li>addr: the offset address in flash memory. It should be byte-aligned for HAL_READ8, word-aligned for HAL_READ16 and dword-aligned for HAL_READ32.</li> </ul> |
| Return       | The read data                                                                                                                                                                                                                                                                                        |

#### 16.3.1.2 FLASH\_ReadStream

| Items        | Description                                                                                                                                                                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Read a stream of data from specified offset address of flash in <b>auto mode</b> .                                                                                                                                                                                 |
| Parameters   | <ul style="list-style-type: none"> <li>address: specify the starting offset address to read from. It has no alignment restrictions.</li> <li>len: specify the length of the data to read.</li> <li>data: specify the buffer to save the read-back data.</li> </ul> |
| Return       | Status:<br><ul style="list-style-type: none"> <li>1: success</li> <li>Others: fail</li> </ul>                                                                                                                                                                      |

## 16.3.2 Write

### 16.3.2.1 FLASH\_TxData12BXIP

| Items        | Description                                                                                                                                                                                                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write data to flash in <b>user mode</b> . This function is protected and can be called by user directly.                                                                                                                                                                                      |
| Parameters   | <ul style="list-style-type: none"> <li>StartAddr: start offset address in flash from which SPIC writes.</li> <li>DataPhaseLen: the number of bytes that SPIC sends in Data Phase. It should not be more than 12 bytes.</li> <li>pData: pointer to a byte array that is to be sent.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                           |

### 16.3.2.2 FLASH\_WriteStream

| Items        | Description                                                                                                                                                                                                                                                                |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write a stream of data to specified address in <b>user mode</b> . The function is already protected and can be called by user directly.                                                                                                                                    |
| Parameters   | <ul style="list-style-type: none"> <li>address: specifies the starting offset to write to.</li> <li>len: specifies the length of the data to write. It has no restrictions of less than 12 bytes.</li> <li>data: pointer to a byte array that is to be written.</li> </ul> |
| Return       | Status:<br><ul style="list-style-type: none"> <li>1: success</li> <li>Others: fail</li> </ul>                                                                                                                                                                              |

## 16.3.3 Erase

### 16.3.3.1 FLASH\_EraseXIP

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Erase sector/block/chip for flash in <b>user mode</b> . The function is already protected and can be called by users directly.                                                                                                                                                                                                                                                                                              |
| Parameters   | <ul style="list-style-type: none"> <li>EraseType: can be one of the following parameters:           <ul style="list-style-type: none"> <li>EraseChip: erase the whole chip.</li> <li>EraseBlock: erase the specified block (64KB).</li> <li>EraseSector: erase the specified sector (4KB).</li> </ul> </li> <li>Address: address should be 4-byte aligned. The block/sector which the address in will be erased.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                         |

## 16.3.4 Receive/Transmit Command

### 16.3.4.1 FLASH\_RxCmdXIP

| Items        | Description                                                                                                                                                                                                                                                   |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Send Rx command to flash to get status register or flash ID in <b>user mode</b> . The function is already protected and can be called by user directly.                                                                                                       |
| Parameters   | <ul style="list-style-type: none"> <li>cmd: command that need to be sent.</li> <li>read_len: the number of bytes that will be read by SPIC after sending command.</li> <li>read_data: pointer to a byte array which is used to save data received.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                           |

### 16.3.4.2 FLASH\_SetStatusXIP

| Items | Description |
|-------|-------------|
|       |             |

|              |                                                                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Set flash status register in <b>user mode</b> . The function is already protected and can be called by users directly.                                                                                  |
| Parameters   | <ul style="list-style-type: none"> <li>● cmd: command to be sent.</li> <li>● len: the number of bytes to be sent after sending command.</li> <li>● status: pointer to byte array to be sent.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                     |

## 16.4 Flash Mbed API

The Flash mbed API descriptions can be found in “AN403 Peripheral Driver Mbed API.chm”. All those functions have already been protected and be called directly.

## 16.5 User Configuration

Ameba-D provides `rtl8721dlp_flashcfg.c` to configure flash speed and read mode.

### 16.5.1 Flash Speed

```
/**
 * @brief Indicate the flash baudrate. It can be one of the following value:
 *        0xFFFF: 80MHz
 *        0x7FFF: 100MHz
 *        0x3FFF: 67MHz
 *        0x1FFF: 57MHz
 *        0x0FFF: 50MHz
 */
const u16 Flash_Speed = 0xFFFF;
```

### 16.5.2 Flash Read Mode

```
/**
 * @brief Indicate the flash read I/O mode. It can be one of the following value:
 *        0xFFFF: Read quad IO, Address & Data 4 bits mode
 *        0x7FFF: Read quad IO, Just data 4 bits mode
 *        0x3FFF: Read dual IO, Address & Data 2 bits mode
 *        0x1FFF: Read dual IO, Just data 2 bits mode
 *        0x0FFF: 1 bit mode
 * @note If the configured read mode is not supported, other modes would be searched until find the appropriate mode.
 */
const u16 Flash_ReadMode = 0xFFFF;
```

### 16.5.3 New Flash Support

For some Flash chip that is not available in AVL, the principle to determine if it can be supported by SDK and the method to add in a new flash can be found in User Configuration Chapter.

# 17 Battery Measurement

## 17.1 Functional Description

LP-ADC has a total of 11 channels, of which 8 are external channels and 3 are internal channels. 8 external channels include 7 normal channels and 1 battery measurement channel called VBAT channel, as Table 17-1 shows. The VBAT channel measurable range is 0~5V.

Table 17-1 Channel description

| Function       | ADC Channel | Pin Name              | Voltage Range                 |
|----------------|-------------|-----------------------|-------------------------------|
| Normal channel | CH0 ~ CH6   | PB_4 ~ PB_7 (CH0 ~ 3) | 0 ~ 3.3V (when power is 3.3V) |
|                |             | PB_1 ~ PB_3 (CH4 ~ 6) | 0 ~ 1.8V (when power is 1.8V) |
| VBAT           | CH7         | VBAT_MEAS             | 0 ~ 5V                        |

When one channel is added to channel switch list, LP-ADC would convert the voltage of corresponding pin to digital data. The resolution of digital sample data is 12-bit.

To obtain sample data, auto mode, timer-trigger mode and software-trigger mode can be adopted according to different usages. LP-ADC can also be configured to send wakeup and interrupt signal to system when the sample data matches criteria.

## 17.2 Calibration

The relationship between input voltage and sample data is almost linear. Fig 17-1 shows the conversion of sample data and input voltage of VBAT\_MEAS.



Fig 17-1 Relationship between sample data and input voltage

To obtain voltage from sample data, the following formula can be used:

$$\text{Voltage} = (10 * \text{Data} - \text{OFFSET})/\text{GAIN} (\text{V})$$

where

- Data: 12-bit sample data
- OFFSET: 10 times of sample data of 0.000v
- GAIN: 10 times of sample data increment when voltage rises 1V

To enhance conversion accuracy, ADC calibration is necessary to obtain precise OFFSET and GAIN parameters for channels.

The calibration operations can be done in FT test. The FT test would sample for different voltages and use Linear Fitting Method to calculate OFFSET and GAIN.

Pay attention that the OFFSET and GAIN values gotten from FT test are 10 times of the actual values. When calculating voltage using the above two values, they must be divided by 10 first; that is,  $\text{voltage} = (\text{data} - \text{OFFSET}/10)/(\text{GAIN}/10) = (10 * \text{data} - \text{offset})/\text{GAIN}$ .

As normal external channels use the same voltage divider circuit, they can use one set of calibration parameters. But VBAT channel need to be calibrated independently.

These parameters would be programmed into eFuse after calibration, as Table 17-2 shows.

Table 17-2 Calibration parameters location

| Channel            | Input Mode   | Parameter | Address                   |
|--------------------|--------------|-----------|---------------------------|
| Normal (CH0 ~ CH6) | Single-end   | OFFSET    | Logical map 0x1A0 ~ 0x1A1 |
|                    |              | GAIN      | Logical map 0x1A2 ~ 0x1A3 |
|                    | Differential | OFFSET    | Logical map 0x1A8 ~ 0x1A9 |
|                    |              | GAIN      | Logical map 0x1AA ~ 0x1AB |
| VBAT (CH7)         | Single-end   | OFFSET    | Logical map 0x1A4 ~ 0x1A5 |
|                    |              | GAIN      | Logical map 0x1A6 ~ 0x1A7 |

To calculate voltage from sample data, user only need to obtain calibration parameters from eFuse and call the voltage computational formula.

# 18 Wi-Fi

## 18.1 Wi-Fi Data Structures

| Data Structures           | Introduction                                                                                                                                                                   |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <_cus_ie>                 | The structure is used to set Wi-Fi custom IE list, and type match CUSTOM_IE_TYPE. The IE will be transmitted according to the type.                                            |
| <rtw_ssid>                | The structure is used to describe the SSID.                                                                                                                                    |
| <rtw_mac>                 | The structure is used to describe the unique 6-byte MAC address.                                                                                                               |
| <rtw_ap_info>             | The structure is used to describe the setting about SSID, security type, password and default channel, used to start AP mode.                                                  |
| <rtw_network_info>        | The structure is used to describe the station mode setting about SSID, security type and password, used when connecting to an AP.                                              |
| <rtw_scan_result>         | The structure is used to describe the scan result of the AP.                                                                                                                   |
| <rtw_scan_handler_result> | The structure is used to describe the data needed by scan result handler function.                                                                                             |
| <rtw_wifi_setting>        | The structure is used to store the Wi-Fi setting gotten from Wi-Fi driver.                                                                                                     |
| <rtw_wifi_config>         | The structure is used to describe the setting when configure the network.                                                                                                      |
| <rtw_maclist_t>           | The structure is used to describe the maclist.                                                                                                                                 |
| <rtw_bss_info_t>          | The structure is used to describe the bss info of the network.<br>It includes the version, BSSID, beacon_period, capability, SSID, channel, atm_window, dtim_period, RSSI etc. |

## 18.2 Wi-Fi APIs

### 18.2.1 System APIs

| API                           | Introduction                                                                   |
|-------------------------------|--------------------------------------------------------------------------------|
| <wifi_on>                     | Enable Wi-Fi.                                                                  |
| <wifi_off>                    | Disable Wi-Fi.                                                                 |
| <wifi_off_fastly>             | Turn off the Wi-Fi device.                                                     |
| <wifi_is_up>                  | Check if the specified interface is up.                                        |
| <wifi_is_ready_to_transceive> | Determines if a particular interface is ready to transceiver Ethernet packets. |
| <wifi_rf_on>                  | Enable Wi-Fi RF.                                                               |
| <wifi_rf_off>                 | Disable Wi-Fi RF.                                                              |

#### 18.2.1.1 wifi\_on

Enables Wi-Fi.

- Bring the wireless interface “Up”.
- Initialize the driver thread which arbitrates access to the SDIO/SPI bus.

| Parameter | Type       | Introduction                                                                           |
|-----------|------------|----------------------------------------------------------------------------------------|
| <mode>    | rtw_mode_t | Decide to enable Wi-Fi in which mode. The optional modes are enumerated in rtw_mode_t. |

#### 18.2.1.2 wifi\_off

Disables Wi-Fi.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

### 18.2.1.3 wifi\_off\_fastly

Turns off the Wi-Fi device.

- Bring the wireless interface “Down”.
- De-Initializes the driver thread which arbitrates access to the SDIO/SPI bus.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

### 18.2.1.4 wifi\_is\_up

Checks if the specified interface is up.

| Parameter   | Type            | Introduction                                                                         |
|-------------|-----------------|--------------------------------------------------------------------------------------|
| <interface> | rtw_interface_t | The interface can be set as RTW_STA_INTERFACE or RTW_AP_INTERFACE. (rtw_interface_t) |

### 18.2.1.5 wifi\_is\_ready\_to\_transceive

Determines if a particular interface is ready to transceive Ethernet packets.

| Parameter   | Type            | Introduction                                                         |
|-------------|-----------------|----------------------------------------------------------------------|
| <interface> | rtw_interface_t | Interface to check, options are RTW_STA_INTERFACE, RTW_AP_INTERFACE. |

### 18.2.1.6 wifi\_rf\_on

Enables Wi-Fi RF.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

**Note:** The difference between wifi\_rf\_on() and wifi\_on() is that wifi\_rf\_on() simply enable RF HAL, it does not enable the driver or allocate memory.

### 18.2.1.7 wifi\_rf\_off

Disables Wi-Fi RF.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

**Note:** The difference between wifi\_rf\_off() and wifi\_off() is that wifi\_rf\_off() simply disable RF HAL, the driver and used heap memory will not be released.

## 18.2.2 Scan APIs

| API                            | Introduction                                                                                                         |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------|
| <wifi_scan>                    | Initiate a scan to search for 802.11 networks, a higher level API based on wifi_scan to simplify the scan operation. |
| <wifi_scan_networks_with_ssid> | Initiate a scan to search for 802.11 networks with specified SSID.                                                   |

### 18.2.2.1 wifi\_scan

Initiates a scan to search for 802.11 networks, a higher level API based on wifi\_scan to simplify the scan operation.

| Parameter    | Type            | Introduction                                                                                                                                                                  |
|--------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <scan_type>  | rtw_scan_type_t | Specifies whether the scan should be active, passive or scan prohibited channels.                                                                                             |
| <bss_type>   | rtw_bss_type_t  | Specifies whether the scan should search for infrastructure networks (those using an AP), Ad-hoc networks, or both types.                                                     |
| <result_ptr> | void *          | Scan specific ssid. The first 4 bytes is ssid length, and ssid name append after it. If no specific ssid need to scan, please clean result_ptr before pass it into parameter. |
| <result_ptr> | void *          | [out] a pointer to a pointer to a result storage structure.                                                                                                                   |

**Note:**

- The scan progressively accumulates results over time, and may take between 1 and 3 seconds to complete. The results of the scan will be individually provided to the callback function.
- The callback function will be executed in the context of the RTW thread.
- When scanning specific channels, devices with a strong signal strength on nearby channels may be detected.

### 18.2.2.2 wifi\_scan\_networks\_with\_ssid

Initiates a scan to search for 802.11 networks with specified SSID.

| Parameter         | Type   | Introduction                                                               |
|-------------------|--------|----------------------------------------------------------------------------|
| <results_handler> | int    | The callback function which will receive and process the result data.      |
| <user_data>       | void * | User specified data that will be passed directly to the callback function. |
| <scan buflen>     | int    | The length of the result storage structure.                                |
| <ssid>            | char * | The SSID of target network.                                                |
| <ssid_len>        | int    | The length of the target network SSID.                                     |

**Note:** Callback must not use blocking functions, since it is called from the context of the RTW thread. The callback, user\_data variables will be referenced after the function returns. Those variables must remain valid until the scan is completed.

## 18.2.3 Connection APIs

| API                         | Introduction                                                                                                                                                          |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <wifi_connect>              | Join a Wi-Fi network. Scan for, associate and authenticate with a Wi-Fi network. On successful return, the system is ready to send data packets.                      |
| <wifi_connect_bssid>        | Join a Wi-Fi network with specified BSSID. Scan for, associate and authenticate with a Wi-Fi network. On successful return, the system is ready to send data packets. |
| <wifi_disconnect>           | Disassociates from current Wi-Fi network.                                                                                                                             |
| <wifi_is_connected_to_ap>   | Check if Wi-Fi has connected to AP before dhcp.                                                                                                                       |
| <wifi_config_autoreconnect> | Set reconnection mode with configuration.                                                                                                                             |
| <wifi_set_autoreconnect>    | Set reconnection mode with 3 retry limit and 5 seconds timeout as default.                                                                                            |
| <wifi_get_autoreconnect>    | Get the result of setting reconnection mode.                                                                                                                          |
| <wifi_get_last_error>       | Present the device disconnect reason while connecting.                                                                                                                |

### 18.2.3.1 wifi\_connect

Joins a Wi-Fi network. Scan for, associate and authenticate with a Wi-Fi network. On successful return, the system is ready to send data packets.

| Parameter | Type   | Introduction                                                              |
|-----------|--------|---------------------------------------------------------------------------|
| <ssid>    | char * | A null terminated string containing the SSID name of the network to join. |

|                 |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <security_type> | rtw_security_t | Authentication type:<br><ul style="list-style-type: none"> <li>● RTW_SECURITY_OPEN: open security</li> <li>● RTW_SECURITY_WEP_PSK: WEP Security with open authentication</li> <li>● RTW_SECURITY_WEP_SHARED: WEP Security with shared authentication</li> <li>● RTW_SECURITY_WPA_TKIP_PSK: WPA Security</li> <li>● RTW_SECURITY_WPA2_AES_PSK: WPA2 Security using AES cipher</li> <li>● RTW_SECURITY_WPA2_TKIP_PSK: WPA2 Security using TKIP cipher</li> <li>● RTW_SECURITY_WPA2_MIXED_PSK: WPA2 Security using AES and/or TKIP ciphers</li> </ul> |
| <password>      | char *         | A byte array containing either the cleartext security key for WPA/WPA2 secured networks, or a pointer to an array of rtw_wep_key_t structures for WEP secured networks.                                                                                                                                                                                                                                                                                                                                                                            |
| <ssid_len>      | int            | The length of the SSID in bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <password_len>  | int            | The length of the security_key in bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <key_id>        | int            | The index of the wep key (0, 1, 2, or 3). If not using it, leave it with value -1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <semaphore>     | void *         | A user provided semaphore is flagged when the join is complete. If not using, leave it with NULL value.                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Note:** Make sure the Wi-Fi is enabled before invoking this function. (wifi\_on())

#### 18.2.3.2 wifi\_connect\_bssid

Joins a Wi-Fi network with specified BSSID. Scan for, associate and authenticate with a Wi-Fi network. On successful return, the system is ready to send data packets.

| Parameter       | Type           | Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <bssid>         | unsigned char  | The specified BSSID to connect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <ssid>          | char *         | A null terminated string containing the SSID name of the network to join.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <security_type> | rtw_security_t | Authentication type:<br><ul style="list-style-type: none"> <li>● RTW_SECURITY_OPEN: open security</li> <li>● RTW_SECURITY_WEP_PSK: WEP Security with open authentication</li> <li>● RTW_SECURITY_WEP_SHARED: WEP Security with shared authentication</li> <li>● RTW_SECURITY_WPA_TKIP_PSK: WPA Security</li> <li>● RTW_SECURITY_WPA2_AES_PSK: WPA2 Security using AES cipher</li> <li>● RTW_SECURITY_WPA2_TKIP_PSK: WPA2 Security using TKIP cipher</li> <li>● RTW_SECURITY_WPA2_MIXED_PSK: WPA2 Security using AES and/or TKIP ciphers</li> </ul> |
| <password>      | char *         | A byte array containing either the cleartext security key for WPA/WPA2 secured networks, or a pointer to an array of rtw_wep_key_t structures for WEP secured networks.                                                                                                                                                                                                                                                                                                                                                                            |
| <ssid_len>      | int            | The length of the SSID in bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <password_len>  | int            | The length of the security_key in bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <key_id>        | int            | The index of the wep key (0, 1, 2, or 3). If not using it, leave it with value -1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <semaphore>     | void *         | A user provided semaphore is flagged when the join is complete. If not using, leave it with NULL value.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <semaphore>     | void *         | A user provided semaphore is flagged when the join is complete. If not using, leave it with NULL value.                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Note:**

- Make sure the Wi-Fi is enabled before invoking this function. (wifi\_on())
- The difference between wifi\_connect\_bssid() and wifi\_connect() is that BSSID has higher priority as the basis of connection in wifi\_connect\_bssid().

#### 18.2.3.3 wifi\_disconnect

Disassociates from current Wi-Fi network.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      |      |              |

#### 18.2.3.4 wifi\_is\_connected\_to\_ap

Checks if Wi-Fi has connected to AP before dhcp.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

#### 18.2.3.5 wifi\_config\_autoreconnect

Sets reconnection mode with configuration.

| Parameter  | Type | Introduction                                     |
|------------|------|--------------------------------------------------|
| <mode>     | _u8  | Set 1/0 to enable/disable the reconnection mode. |
| <callback> | _u8  | The number of retry limit.                       |
| <len_used> | _u16 | The timeout value (in seconds).                  |

**Note:**

- Defining CONFIG\_AUTO\_RECONNECT in `autoconf.h` needs to be done before compiling, or this API won't be effective.
- The difference between `wifi_config_autoreconnect()` and `wifi_set_autoreconnect()` is that user can specify the retry times and timeout value in `wifi_config_autoreconnect()`. But in `wifi_set_autoreconnect()` these values are set with 3 retry limit and 5 seconds timeout as default.

#### 18.2.3.6 wifi\_set\_autoreconnect

Sets reconnection mode with 3 retry limit and 5 seconds timeout as default.

| Parameter | Type | Introduction                                     |
|-----------|------|--------------------------------------------------|
| <mode>    | _u8  | Set 1/0 to enable/disable the reconnection mode. |

**Note:**

- Defining CONFIG\_AUTO\_RECONNECT in `autoconf.h` needs to be done before compiling, or this API won't be effective.
- The difference between `wifi_config_autoreconnect()` and `wifi_set_autoreconnect()` is that user can specify the retry times and timeout value in `wifi_config_autoreconnect()`. But in `wifi_set_autoreconnect()` these values are set with 3 retry limit and 5 seconds timeout as default.

#### 18.2.3.7 wifi\_get\_autoreconnect

Gets the result of setting reconnection mode.

| Parameter | Type | Introduction                                        |
|-----------|------|-----------------------------------------------------|
| <mode>    | _u8  | Pointer to the result of setting reconnection mode. |

**Note:** Defining CONFIG\_AUTO\_RECONNECT in `autoconf.h` needs to be done before compiling, or this API won't be effective.

#### 18.2.3.8 wifi\_get\_last\_error

Presents the device disconnect reason while connecting.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

## 18.2.4 Channel APIs

| API                     | Introduction                                                               |
|-------------------------|----------------------------------------------------------------------------|
| <wifi_set_channel>      | Set the listening channel on STA interface.                                |
| <wifi_get_channel>      | Get the current channel on STA interface.                                  |
| <wifi_set_channel_plan> | Set channel plan into flash/eFuse, must reboot after setting channel plan. |
| <wifi_get_channel_plan> | Get channel plan from calibration section.                                 |

### 18.2.4.1 wifi\_set\_channel

Sets the listening channel on STA interface.

| Parameter | Type | Introduction         |
|-----------|------|----------------------|
| <channel> | int  | The desired channel. |

**Note:** do not need to call this function for STA mode Wi-Fi driver, since it will determine the channel from received beacon.

### 18.2.4.2 wifi\_get\_channel

Gets the current channel on STA interface.

| Parameter | Type  | Introduction                                                       |
|-----------|-------|--------------------------------------------------------------------|
| <channel> | int * | A pointer to the variable where the channel value will be written. |

### 18.2.4.3 wifi\_set\_channel\_plan

Sets channel plan into flash/eFuse, must reboot after setting channel plan.

| Parameter      | Type    | Introduction                                                 |
|----------------|---------|--------------------------------------------------------------|
| <channel_plan> | uint8_t | The value of channel plan, define in <b>wifi_constants.h</b> |

### 18.2.4.4 wifi\_get\_channel\_plan

Gets channel plan from calibration section.

| Parameter      | Type    | Introduction                                                          |
|----------------|---------|-----------------------------------------------------------------------|
| <channel_plan> | uint8_t | Point to the value of channel plan, define in <b>wifi_constants.h</b> |

## 18.2.5 Power APIs

| API                      | Introduction                                                                                                                                                                          |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <wifi_enable_powersave>  | Enable Wi-Fi power save mode. When power save mode is enabled, RF will wake up only when there is data to be sent or beacon to be received. Otherwise, RF will be awake all the time. |
| <wifi_disable_powersave> | Disable Wi-Fi power save mode.                                                                                                                                                        |
| <wifi_get_txpower>       | Get the Tx power in index units.                                                                                                                                                      |
| <wifi_set_txpower>       | Set the Tx power in index units.                                                                                                                                                      |
| <wifi_set_power_mode>    | Set IPS/LPS mode.                                                                                                                                                                     |
| <wifi_set_lps_dtim>      | Set LPS DTIM.                                                                                                                                                                         |
| <wifi_get_lps_dtim>      | Get LPS DTIM.                                                                                                                                                                         |

### 18.2.5.1 wifi\_enable\_powersave

Enables Wi-Fi power save mode. When power save mode is enabled, RF will wake up only when there is data to be sent or beacon to be received. Otherwise, RF will be awake all the time.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

### 18.2.5.2 wifi\_disable\_powersave

Disables Wi-Fi power save mode.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

### 18.2.5.3 wifi\_get\_txpower

Gets the Tx power in index units.

| Parameter  | Type  | Introduction                                   |
|------------|-------|------------------------------------------------|
| <poweridx> | int * | The variable to receive the Tx power in index. |

### 18.2.5.4 wifi\_set\_txpower

Sets the Tx power in index units.

| Parameter  | Type | Introduction                   |
|------------|------|--------------------------------|
| <poweridx> | int  | The desired Tx power in index. |

### 18.2.5.5 wifi\_set\_power\_mode

Sets IPS/LPS mode.

| Parameter  | Type          | Introduction                                                                                                                                                                                                                                                                                        |
|------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ips_mode> | unsigned char | The desired IPS mode. It becomes effective when WLAN enters IPS.<br>ips_mode is inactive power save mode. Wi-Fi automatically turns RF off if it is not associated to AP. Set 1 to enable inactive power save mode.                                                                                 |
| <lps_mode> | unsigned char | The desired LPS mode. It becomes effective when WLAN enters LPS.<br>lps_mode is leisure power save mode. Wi-Fi automatically turns RF off during the association to AP if traffic is not busy while it also automatically turns RF on to listen to beacon. Set 1 to enable leisure power save mode. |

### 18.2.5.6 wifi\_set\_lps\_dtim

Sets LPS DTIM.

| Parameter | Type          | Introduction                                                                                                    |
|-----------|---------------|-----------------------------------------------------------------------------------------------------------------|
| <dtim>    | unsigned char | In LPS, the package can be buffered at AP side. STA leave LPS until DTIM count of packages buffered at AP side. |

**Note:** DTIM is the duration to listen beacon. The default DTIM is 1. If DTIM is set bigger than 1, the advantage is that power can be saved and the disadvantage is that STA has the risk of losing packets.

### 18.2.5.7 wifi\_get\_lps\_dtim

Gets LPS DTIM.

| Parameter | Type            | Introduction                                                                                                    |
|-----------|-----------------|-----------------------------------------------------------------------------------------------------------------|
| <dtim>    | unsigned char * | In LPS, the package can be buffered at AP side. STA leave LPS until DTIM count of packages buffered at AP side. |

## 18.2.6 AP Mode APIs

| API                               | Introduction                                                     |
|-----------------------------------|------------------------------------------------------------------|
| <wifi_start_ap>                   | Trigger Wi-Fi driver to start an infrastructure Wi-Fi network.   |
| <wifi_start_ap_with_hidden_ssid>  | Start an infrastructure Wi-Fi network with hidden SSID.          |
| <wifi_restart_ap>                 | Trigger Wi-Fi driver to restart an infrastructure Wi-Fi network. |
| <wifi_get_associated_client_list> | Get the associated clients with SoftAP.                          |
| <wifi_enable_forwarding>          | Enable packets forwarding in AP mode.                            |
| <wifi_disable_forwarding>         | Disable packets forwarding in AP mode.                           |

### 18.2.6.1 wifi\_start\_ap

Triggers Wi-Fi driver to start an infrastructure Wi-Fi network.

| Parameter       | Type          | Introduction                                                                                                                                                                                                                                                                                                                                        |
|-----------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ssid>          | char *        | A null terminated string containing the SSID name of the network.                                                                                                                                                                                                                                                                                   |
| <security_type> | security_type | <ul style="list-style-type: none"> <li>● RTW_SECURITY_OPEN: Open Security</li> <li>● RTW_SECURITY_WPA_TKIP_PSK: WPA Security</li> <li>● RTW_SECURITY_WPA2_AES_PSK: WPA2 Security using AES cipher</li> <li>● RTW_SECURITY_WPA2_MIXED_PSK: WPA2 Security using AES and/or TKIP ciphers</li> </ul> WEP security is NOT IMPLEMENTED. It is NOT SECURE! |
| <password>      | char *        | A byte array containing the cleartext security key for the network.                                                                                                                                                                                                                                                                                 |
| <ssid_len>      | int           | The length of the SSID in bytes.                                                                                                                                                                                                                                                                                                                    |
| <password_len>  | int           | The length of the security_key in bytes.                                                                                                                                                                                                                                                                                                            |
| <channel>       | int           | 802.11 channel number.                                                                                                                                                                                                                                                                                                                              |

**Note:**

- Make sure the Wi-Fi is enabled before invoking this function. (wifi\_on())
- if a STA interface is active when this function is called, the softAP will start on the same channel as the STA. It will not use the channel provided.

### 18.2.6.2 wifi\_start\_ap\_with\_hidden\_ssid

Starts an infrastructure Wi-Fi network with hidden SSID.

| Parameter       | Type          | Introduction                                                                                                                                                                                                                                                                                                                                        |
|-----------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ssid>          | char *        | A null terminated string containing the SSID name of the network.                                                                                                                                                                                                                                                                                   |
| <security_type> | security_type | <ul style="list-style-type: none"> <li>● RTW_SECURITY_OPEN: Open Security</li> <li>● RTW_SECURITY_WPA_TKIP_PSK: WPA Security</li> <li>● RTW_SECURITY_WPA2_AES_PSK: WPA2 Security using AES cipher</li> <li>● RTW_SECURITY_WPA2_MIXED_PSK: WPA2 Security using AES and/or TKIP ciphers</li> </ul> WEP security is NOT IMPLEMENTED. It is NOT SECURE! |
| <password>      | char *        | A byte array containing the cleartext security key for the network.                                                                                                                                                                                                                                                                                 |
| <ssid_len>      | int           | The length of the SSID in bytes.                                                                                                                                                                                                                                                                                                                    |
| <password_len>  | int           | The length of the security_key in bytes.                                                                                                                                                                                                                                                                                                            |

|           |     |                        |
|-----------|-----|------------------------|
| <channel> | int | 802.11 channel number. |
|-----------|-----|------------------------|

**Note:** if a STA interface is active when this function is called, the softAP will start on the same channel as the STA. It will not use the channel provided.

#### 18.2.6.3 wifi\_restart\_ap

Triggers Wi-Fi driver to restart an infrastructure Wi-Fi network.

| Parameter       | Type            | Introduction                                                                                                                                                                                                                                                                                                                                               |
|-----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ssid>          | unsigned char * | A null terminated string containing the SSID name of the network.                                                                                                                                                                                                                                                                                          |
| <security_type> | rtw_security_t  | <ul style="list-style-type: none"> <li>● RTW_SECURITY_OPEN: Open Security</li> <li>● RTW_SECURITY_WPA_TKIP_PSK: WPA Security</li> <li>● RTW_SECURITY_WPA2_AES_PSK: WPA2 Security using AES cipher</li> <li>● RTW_SECURITY_WPA2_MIXED_PSK: WPA2 Security using AES and/or TKIP ciphers</li> </ul> <p>WEP security IS NOT IMPLEMENTED. It is NOT SECURE!</p> |
| <password>      | unsigned char * | A byte array containing the cleartext security key for the network.                                                                                                                                                                                                                                                                                        |
| <ssid_len>      | int             | The length of the SSID in bytes.                                                                                                                                                                                                                                                                                                                           |
| <password_len>  | int             | The length of the security_key in bytes.                                                                                                                                                                                                                                                                                                                   |
| <channel>       | int             | 802.11 channel number.                                                                                                                                                                                                                                                                                                                                     |

**Note:**

- Make sure the Wi-Fi is enabled before invoking this function. (wifi\_on())
- if a STA interface is active when this function is called, the softAP will start on the same channel as the STA. It will not use the channel provided.

#### 18.2.6.4 wifi\_get\_associated\_client\_list

Gets the associated clients with SoftAP.

| Parameter            | Type           | Introduction                                       |
|----------------------|----------------|----------------------------------------------------|
| <client_list_buffer> | int *          | The location where the client list will be stored. |
| <buffer_length>      | unsigned short | The buffer length.                                 |

#### 18.2.6.5 wifi\_enable\_forwarding

Enables packets forwarding in AP mode.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

#### 18.2.6.6 wifi\_disable\_forwarding

Disables packets forwarding in AP mode.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

#### 18.2.7 Custom IE APIs

| API                     | Introduction                             |
|-------------------------|------------------------------------------|
| <wifi_add_custom_ie>    | Setup custom IE list.                    |
| <wifi_update_custom_ie> | Update the item in Wi-Fi custom IE list. |

|                      |                              |
|----------------------|------------------------------|
| <wifi_del_custom_ie> | Delete Wi-Fi custom IE list. |
|----------------------|------------------------------|

**Note:** These three APIs are only effective on beacon, probe request and probe response frames.

#### 18.2.7.1 wifi\_add\_custom\_ie

Setups custom IE list.

| Parameter | Type   | Introduction                        |
|-----------|--------|-------------------------------------|
| <cus_ie>  | void * | Pointer to Wi-Fi CUSTOM IE list.    |
| <ie_num>  | int    | The number of Wi-Fi CUSTOM IE list. |

**Note:**

- This API can't be executed twice before deleting the previous custom IE list.
- Defining CONFIG\_CUSTOM\_IE in **autoconf.h** needs to be done before compiling, or this API won't be effective.

#### 18.2.7.2 wifi\_update\_custom\_ie

Updates the item in Wi-Fi custom IE list.

| Parameter  | Type   | Introduction                        |
|------------|--------|-------------------------------------|
| <cus_ie>   | void * | Pointer to Wi-Fi CUSTOM IE list.    |
| <ie_index> | int    | The number of Wi-Fi CUSTOM IE list. |

**Note:** Defining CONFIG\_CUSTOM\_IE in **autoconf.h** needs to be done before compiling, or this API won't be effective.

#### 18.2.7.3 wifi\_del\_custom\_ie

Deletes Wi-Fi custom IE list.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

**Note:** Defining CONFIG\_CUSTOM\_IE in **autoconf.h** needs to be done before compiling, or this API won't be effective.

### 18.2.8 Wi-Fi Setting APIs

| API                                   | Introduction                                                                                                                                                                                                   |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <wifi_get_mac_address>                | Retrieves the current Media Access Control (MAC) address (or Ethernet hardware address) of the 802.11 device.                                                                                                  |
| <wifi_get_ap_bssid>                   | Get connected AP's BSSID.                                                                                                                                                                                      |
| <wifi_get_ap_info>                    | Get the SoftAP information.                                                                                                                                                                                    |
| <wifi_set_country>                    | Set the country code to driver to determine the channel set.                                                                                                                                                   |
| <wifi_get_sta_max_data_rate>          | Retrieved STA mode max. data rate.                                                                                                                                                                             |
| <wifi_get_rssi>                       | Retrieved the latest RSSI value.                                                                                                                                                                               |
| <wifi_register_multicast_address>     | Register interest in a multicast address.<br>Once a multicast address has been registered, all packets detected on the medium destined for that address are forwarded to the host. Otherwise they are ignored. |
| < wifi_unregister_multicast_address > | Unregister interest in a multicast address.<br>Once a multicast address has been unregistered, all packets detected on the medium destined for that address are ignored.                                       |
| <wifi_set_mib>                        | Setup the adaptive mode. You can replace this weak function by the same name function to setup adaptive mode you can.                                                                                          |

|                         |                                                                                                                                                                                                                                |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <wifi_set_country_code> | Setup country code. You can replace this weak function by the same name function to setup country code you want.                                                                                                               |
| <wifi_set_tdma_param>   | Set TDMA parameters.                                                                                                                                                                                                           |
| <wifi_get_setting>      | Get current Wi-Fi setting from driver.                                                                                                                                                                                         |
| <wifi_show_setting>     | Show the network information stored in a <code>rtw_wifi_setting_t</code> structure.                                                                                                                                            |
| <wifi_set_network_mode> | Set the network mode according to the data rate it supported. Driver works in BGN mode in default after driver initialization. This function is used to change wireless network mode for station mode before connecting to AP. |
| <wifi_get_network_mode> | Get the network mode. Driver works in BGN mode in default after driver initialization. This function is used to get the current wireless network mode for station mode.                                                        |
| <wifi_get_antenna_info> | Get antenna information.                                                                                                                                                                                                       |
| <wifi_set_ch_deauth>    | Set flag for concurrent mode wlan1 issue_deauth when channel switched by wlan0.<br>Usage: <code>wifi_set_ch_deauth(0) -&gt; wlan0 wifi_connect -&gt; wifi_set_ch_deauth(1)</code>                                              |

### 18.2.8.1 wifi\_get\_mac\_address

Retrieves the current Media Access Control (MAC) address (or Ethernet hardware address) of the 802.11 device.

| Parameter | Type   | Introduction                                        |
|-----------|--------|-----------------------------------------------------|
| <mac>     | char * | Point to the result of the mac address will be get. |

### 18.2.8.2 wifi\_get\_ap\_bssid

Gets connected AP's BSSID.

| Parameter | Type            | Introduction                                    |
|-----------|-----------------|-------------------------------------------------|
| <bssid>   | unsigned char * | The location where the AP BSSID will be stored. |

### 18.2.8.3 wifi\_get\_ap\_info

Gets the SoftAP information.

| Parameter  | Type                          | Introduction                                   |
|------------|-------------------------------|------------------------------------------------|
| <ap_info>  | <code>rtw_bss_info_t</code> * | The location where the AP info will be stored. |
| <security> | <code>rtw_security_t</code> * | The security type.                             |

### 18.2.8.4 wifi\_set\_country

Sets the country code to driver to determine the channel set.

| Parameter      | Type                            | Introduction              |
|----------------|---------------------------------|---------------------------|
| <country_code> | <code>rtw_country_code_t</code> | Specify the country code. |

### 18.2.8.5 wifi\_get\_sta\_max\_data\_rate

Retrieves STA mode max. data rate.

| Parameter      | Type               | Introduction   |
|----------------|--------------------|----------------|
| <inidata_rate> | <code>_u8</code> * | Max data rate. |

### 18.2.8.6 wifi\_get\_rssi

Retrieves the latest RSSI value.

| Parameter | Type  | Introduction                                                      |
|-----------|-------|-------------------------------------------------------------------|
| <pRSSI>   | int * | Points to the integer to store the RSSI value gotten from driver. |

### 18.2.8.7 wifi\_register\_multicast\_address

Registers interest in a multicast address.

Once a multicast address has been registered, all packets detected on the medium destined for that address are forwarded to the host, otherwise they are ignored.

| Parameter | Type        | Introduction          |
|-----------|-------------|-----------------------|
| <mac>     | rtw_mac_t * | Ethernet MAC address. |

### 18.2.8.8 wifi\_unregister\_multicast\_address

Unregisters interest in a multicast address.

Once a multicast address has been unregistered, all packets detected on the medium destined for that address are ignored.

| Parameter | Type        | Introduction          |
|-----------|-------------|-----------------------|
| <mac>     | rtw_mac_t * | Ethernet MAC address. |

### 18.2.8.9 wifi\_set\_mib

Setups the adaptive mode. You can replace this weak function by the same name function to setup adaptive mode you can.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

### 18.2.8.10 wifi\_set\_country\_code

Setups country code. You can replace this weak function by the same name function to setup country code you want.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

### 18.2.8.11 wifi\_set\_tdma\_param

Sets TDMA parameters.

| Parameter           | Type          | Introduction                                                                                                                                                                                                                                                                                                                                    |
|---------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <slot_period>       | unsigned char | We separate TBTT into 2 or 3 slots. If we separate TBTT into 2 slots, then slot_period should be larger or equal to 50ms. It means 2 slot period is slot_period, 100-slot_period If we separate TBTT into 3 slots, then slot_period should be less or equal to 33ms. It means 3 slot period is 100 - 2 * slot_period, slot_period, slot_period. |
| <rfon_period_len_1> | unsigned char | RF on period of slot 1.                                                                                                                                                                                                                                                                                                                         |
| <rfon_period_len_2> | unsigned char | RF on period of slot 2.                                                                                                                                                                                                                                                                                                                         |
| <rfon_period_len_3> | unsigned char | RF on period of slot 3.                                                                                                                                                                                                                                                                                                                         |

### 18.2.8.12 wifi\_get\_setting

Gets current Wi-Fi setting from driver.

| Parameter  | Type                 | Introduction                                                                              |
|------------|----------------------|-------------------------------------------------------------------------------------------|
| <ifname>   | const char *         | The WLAN interface name, can be WLAN0_NAME or WLAN1_NAME.                                 |
| <pSetting> | rtw_wifi_setting_t * | Points to the rtw_wifi_setting_t structure to store the Wi-Fi setting gotten from driver. |

### 18.2.8.13 wifi\_show\_setting

Shows the network information stored in a rtw\_wifi\_setting\_t structure.

| Parameter  | Type                 | Introduction                                                                                  |
|------------|----------------------|-----------------------------------------------------------------------------------------------|
| <ifname>   | const char *         | The WLAN interface name, can be WLAN0_NAME or WLAN1_NAME.                                     |
| <pSetting> | rtw_wifi_setting_t * | Points to the rtw_wifi_setting_t structure which information is gotten by wifi_get_setting(). |

### 18.2.8.14 wifi\_set\_network\_mode

Sets the network mode according to the data rate it supported. Driver works in BGN mode in default after driver initialization. This function is used to change wireless network mode for station mode before connecting to AP.

| Parameter | Type               | Introduction                                                                          |
|-----------|--------------------|---------------------------------------------------------------------------------------|
| <mode>    | rtw_network_mode_t | Network mode to set.<br>The value can be RTW_NETWORK_B/RTW_NETWORK_BG/RTW_NETWORK_BGN |

### 18.2.8.15 wifi\_get\_network\_mode

Gets the network mode. Driver works in BGN mode in default after driver initialization. This function is used to get the current wireless network mode for station mode.

| Parameter | Type                 | Introduction         |
|-----------|----------------------|----------------------|
| <pmode>   | rtw_network_mode_t * | Network mode to get. |

### 18.2.8.16 wifi\_get\_antenna\_info

Gets antenna information.

| Parameter | Type            | Introduction                                                                                                                           |
|-----------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------|
| <antenna> | unsigned char * | Points to store the antenna value gotten from driver.<br><ul style="list-style-type: none"> <li>● 0: main</li> <li>● 1: aux</li> </ul> |

### 18.2.8.17 wifi\_set\_ch\_deauth

Sets flag for concurrent mode wlan1 issue\_deauth when channel switched by wlan0.

**Usage:** wifi\_set\_ch\_deauth(0) -> wlan0 wifi\_connect -> wifi\_set\_ch\_deauth(1)

| Parameter | Type | Introduction                    |
|-----------|------|---------------------------------|
| <enable>  | _u8  | 0 for disable and 1 for enable. |

## 18.2.9 Wi-Fi Indication APIs

| API                        | Introduction                                                       |
|----------------------------|--------------------------------------------------------------------|
| <wifi_manager_init>        | Initialize Realtek Wi-Fi API System.                               |
| <wifi_indication>          | WLAN driver indicate event to upper layer through wifi_indication. |
| <init_event_callback_list> | Initialize the event callback list.                                |
| <wifi_reg_event_handler>   | Register the event listener.                                       |
| <wifi_unreg_event_handler> | Un-register the event listener.                                    |

### 18.2.9.1 wifi\_manager\_init

Initializes Realtek Wi-Fi API System.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

### 18.2.9.2 wifi\_indication

WLAN driver indicates event to upper layer through wifi\_indication().

| Parameter | Type                 | Introduction                                                                                  |
|-----------|----------------------|-----------------------------------------------------------------------------------------------|
| <event>   | rtw_event_indicate_t | An event reported from driver to upper layer application. Refer to rtw_event_indicate_t enum. |
| <buf>     | char *               | If it is not NUL, buf is a pointer to the buffer for message string.                          |
| <buf_len> | int                  | The length of the buffer.                                                                     |
| <flags>   | int                  | Indicate some extra information, sometimes it is 0.                                           |

**Note:** If upper layer application triggers additional operations on receiving of wext\_wlan\_indicate, please strictly check current stack size usage (by using uxTaskGetStackHighWaterMark()), and tries not to share the same stack with WLAN driver if remaining stack space is not available for the following operations.

For example, using semaphore to notice another thread instead of handing event directly in wifi\_indication().

### 18.2.9.3 init\_event\_callback\_list

Initialize the event callback list.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

**Note:** Make sure this function has been invoked before using the event handler related mechanism.

### 18.2.9.4 wifi\_reg\_event\_handler

Registers the event listener.

| Parameter           | Type                | Introduction                                                              |
|---------------------|---------------------|---------------------------------------------------------------------------|
| <event_cmds>        | unsigned int        | The event command number indicated.                                       |
| <handler_func>      | rtw_event_handler_t | The callback function which will receive and process the event.           |
| <handler_user_data> | void *              | User specific data that will be passed directly to the callback function. |

**Note:** Setting the same even\_cmds with empty handler\_func will unregister the event\_cmds.

### 18.2.9.5 wifi\_unreg\_event\_handler

Unregisters the event listener.

| Parameter      | Type                | Introduction                                                    |
|----------------|---------------------|-----------------------------------------------------------------|
| <event_cmds>   | unsigned int        | The event command number indicated.                             |
| <handler_func> | rtw_event_handler_t | The callback function which will receive and process the event. |

## 18.2.10 eFuse writing APIs

| API                    | Introduction                                                                            |
|------------------------|-----------------------------------------------------------------------------------------|
| <wifi_set_mac_address> | This function sets the current Media Access Control (MAC) address of the 802.11 device. |

**Note:** eFuse writing related API can only be called when the voltage is 3.3V. eFuse writing with the voltage 1.8V may fail. What's more, eFuse writing can only be operated one time, so be careful to do eFuse writing.

### 18.2.10.1 wifi\_set\_mac\_address

Sets the current Media Access Control (MAC) address of the 802.11 device.

| Parameter | Type   | Introduction       |
|-----------|--------|--------------------|
| <mac>     | char * | Wi-Fi MAC address. |

## 18.3 Fast Connect

This section illustrates principle of fast connect and how to implement user's own fast connect code.

Fast connect is used to reconnect with AP automatically after Wi-Fi initialized, the principle is to store the AP information in flash and reconnect to AP after Wi-Fi initialized.

### 18.3.1 Implement

#### 18.3.1.1 Store AP Information

User should implement a function to write AP information to flash, just like demo function `wlan_wrtie_reconnect_data_to_flash()` in example code. In this function, you should reserve some space for AP information, and write the AP information to the reserved space in a pre-defined data format. The address of the function must be assigned to the global variable `p_write_reconnect_ptr`. After Wi-Fi connection success, if `p_write_reconnect_ptr` points to a valid address, `wlan_wrtie_reconnect_data_to_flash()` will be called.

**Note:** The path of example source code is `SDK/component/common/example/example_wlan_fast_connect/example_wlan_fast_connect.c`.

#### 18.3.1.2 Reconnect

User should implement his own function to read AP information from flash and connect to AP, just like demo function `wlan_init_done_callback()` in example code. The address of the function must be assigned to the global variable `p_wlan_init_done_callback`. This global variable should be defined before Wi-Fi initializing. After Wi-Fi initialized, if `p_wlan_init_done_callback` points to a valid address, this function will be called.

#### 18.3.1.3 Erase fast connect data

User should implement his own function to erase fast connect data, just like demo function `Erase_Fastconnect_data()` in example code.

## 18.3.2 APIs

| API                                  | Introduction                                                                                                                                                                                    |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <wlan_wrtie_reconnect_data_to_flash> | Wi-Fi connection indication trigger this function to save current Wi-Fi profile in flash.                                                                                                       |
| <wlan_init_done_callback>            | After Wi-Fi initialization done, WLAN driver calls this function to check whether auto-connect is required.<br>This function reads previous saved WLAN profile in flash and execute connection. |

### 18.3.2.1 wlan\_wrtie\_reconnect\_data\_to\_flash

Wi-Fi connection indications trigger this function to save current Wi-Fi profile in flash. Write AP information to flash.

| Parameter | Type     | Introduction                                                                                                       |
|-----------|----------|--------------------------------------------------------------------------------------------------------------------|
| <data>    | u8 *     | Data will be written to flash                                                                                      |
| <len>     | uint32_t | Length of data                                                                                                     |
| return    | int      | Status value:<br><ul style="list-style-type: none"> <li>● 0: write is ok</li> <li>● -1: write is failed</li> </ul> |

**Note:** This is only a demo API, user should define his own API.

## 18.4 WPS APIs

| API         | Introduction                |
|-------------|-----------------------------|
| <wps_start> | Start WPS enrollee process. |
| <wps_stop>  | Stop WPS enrollee process.  |

### 18.4.1 wps\_start

Starts WPS enrollee process.

| Parameter    | Type   | Introduction                                                                                                                                                  |
|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <wps_config> | u16    | WPS configure method:<br><ul style="list-style-type: none"> <li>● WPS_CONFIG_DISPLAY</li> <li>● WPS_CONFIG_KEYPAD</li> <li>● WPS_CONFIG_PUSHBUTTON</li> </ul> |
| <pin>        | char * | PIN number. Can be set to NULL if using WPS_CONFIG_PUSHBUTTON.                                                                                                |
| <channel>    | u8     | Channel. Currently un-used, can be set to 0.                                                                                                                  |
| <ssid>       | char * | Target network SSID. Can be set to NULL if no target network specified.                                                                                       |

**Note:**

- Before invoking this function, the Wi-Fi should be enabled by using `wifi_on()`.
- Make sure CONFIG\_ENABLE\_WPS is enabled in `platform_opts.h`. After calling `wps_start()`, the longest time of WPS is 120s. You can call `wps_stop()` to quit WPS.

### 18.4.2 wps\_stop

Stops WPS enrollee process.

| Parameter | Type | Introduction |
|-----------|------|--------------|
| None      | -    | -            |

**Note:** Make sure CONFIG\_ENABLE\_WPS is enabled in **platform\_opts.h**.

Realtek Confidential files  
The document authorized to  
B&T  
2019-05-16 11:47:20

# 19 Inter Processor Communication (IPC)

Inter Processor Communication (IPC) hardware is designed for the purpose of making two CPUs communicate with each other. The system architecture is shown in Fig 19-1.



Fig 19-1 IPC system architecture

If you want KM0 to execute its IPC handler, IPC interrupt of KM4 should be enable and the status should be set, vice versa.

## 19.1 How to Use IPC

It is complex because both KM0 and KM4 should be set to realize IPC. SDK has provided API and configuration file to simplify the procedure. Take KM4 requests an interrupt into direction KM0 for example.

Add new item in KM0 core section of `ipc_init_config[]` which is in `rtl8721d_ipccfg.c` for selected channel. IRQ handler and data should be set and defined. If message exchange is needed, you should specify the message type: data or point.

```

const IPC_INIT_TABLE ipc_init_config[] =
{
#if defined(ARM_CORE_CM4)
    //USER_MSG_TYPE      IRQFUNC
    {IPC_USER_DATA,     (VOID*) shell_switch_ipc_int,
     {IPC_USER_DATA,   (VOID*) NULL,
      {IPC_USER_DATA, (VOID*) FLASH_Write_IPC_Req,
       {IPC_USER_POINT, (VOID*) NULL,
    #else
    //USER_MSG_TYPE      IRQFUNC
    {IPC_USER_DATA,     (VOID*) shell_switch_ipc_int,
     {IPC_USER_DATA,   (VOID*) driver_fw_flow_ipc_int,
      {IPC_USER_DATA, (VOID*) FLASH_Write_IPC_Req,
       {IPC_USER_POINT, (VOID*) km4_tickless_ipc_int,
    #endif
    {0xFFFFFFFF,        OFF,
     OFF},           /* Table end */
};
```

|                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>IRQDATA</code><br><code>(VOID*) NULL}; //channel 0: IPC_INT_CHAN_SHELL_SWITCH</code><br><code>(VOID*) NULL}; //channel 1: IPC_INT_CHAN_WIFI_FW</code><br><code>(VOID*) NULL}; //channel 2: IPC_INT_CHAN_FLASHPG_REQ</code><br><code>(VOID*) NULL}; //channel 3: IPC_INT_KM4_TICKLESS_INDICATION</code> | <code>IRQDATA</code><br><code>(VOID*) NULL}; //channel 0: IPC_INT_CHAN_SHELL_SWITCH</code><br><code>(VOID*) IPCM4_DEV}; //channel 1: IPC_INT_CHAN_WIFI_FW</code><br><code>(VOID*) NULL}; //channel 2: IPC_INT_CHAN_FLASHPG_REQ</code><br><code>(VOID*) NULL}; //channel 3: IPC_INT_KM4_TICKLESS_INDICATION</code> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

SDK will enable the IPC interrupt of KM4 for the channel according to `ipc_init_config[]`, and register the corresponding KM0 IRQ handler and data for the channel.

When KM4 wants to request an interrupt into direction KM0, it should call `ipc_send_message()` and specify the channel number and message. Corresponding KM0 IRQ handler will be executed, call `ipc_get_message()` to get message if need.

**Note:** Use IPC channel 16~31 and IPC semaphore index 8~15, Channel 0~15 and semaphore index 0~7 are reserved for Realtek use.

## 19.2 IPC Program APIs

### 19.2.1 ipc\_table\_init

| Items        | Description                                                          |
|--------------|----------------------------------------------------------------------|
| Introduction | Initializes IPC channels according to <code>ipc_init_config[]</code> |
| Parameters   | N/A                                                                  |

|        |     |
|--------|-----|
| Return | N/A |
|--------|-----|

### 19.2.2 ipc\_send\_message

| Items        | Description                                                                                                                                                              |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Requests interrupt to target CPU by specified channel and exchange messages between KM0 and KM4                                                                          |
| Parameters   | <ul style="list-style-type: none"> <li>● IPC_ChNum: the IPC channel number</li> <li>● Message: the message to be exchanged, and should not be stored in stack</li> </ul> |
| Return       | N/A                                                                                                                                                                      |

**Note:**

- The message supports two types: data or point. The point is used to point to complex message structure.
- The message is shared between two CPUs, so the point can't be stored in stack.

### 19.2.3 ipc\_get\_message

| Items        | Description                              |
|--------------|------------------------------------------|
| Introduction | Gets IPC message from specified channel. |
| Parameters   | IPC_ChNum: the IPC channel number        |
| Return       | Message: the message to be exchanged     |

**Note:** Cache in the system is write-through type, so the corresponding data cache must be invalidated before data fetch.

## 19.3 IPC Driver Code

### 19.3.1 IPC\_INTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                               |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the specified IPC channel interrupts.                                                                                                                                                                                                                                                                                                                 |
| Parameters   | <ul style="list-style-type: none"> <li>● IPCx: <ul style="list-style-type: none"> <li>■ IPCM0_DEV for CM0</li> <li>■ IPCM4_DEV for CM4</li> </ul> </li> <li>● IPC_ChNum: the channel that want to be set. This parameter must be set to a value of 0 ~ 31.</li> <li>● NewState: <ul style="list-style-type: none"> <li>■ ENABLE</li> <li>■ DISABLE</li> </ul> </li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                       |

### 19.3.2 IPC\_IERSet

| Items        | Description                                                                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Sets IER of specified IPC channel interrupts                                                                                                                                                                        |
| Parameters   | <ul style="list-style-type: none"> <li>● IPCx: <ul style="list-style-type: none"> <li>■ IPCM0_DEV for CM0</li> <li>■ IPCM4_DEV for CM4</li> </ul> </li> <li>● IPC_Ch: the channel that want to be enable</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                 |

### 19.3.3 IPC\_IERGet

| Items        | Description                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------|
| Introduction | Gets IER of specified IPCx                                                                                  |
| Parameters   | IPCx:<br><ul style="list-style-type: none"> <li>● IPCM0_DEV for CM0</li> <li>● IPCM4_DEV for CM4</li> </ul> |
| Return       | The IER of specified IPCx                                                                                   |

### 19.3.4 IPC\_INTRequest

| Items        | Description                                                                                                                                                                                                                                                                      |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Requests a core-to-core interrupt                                                                                                                                                                                                                                                |
| Parameters   | <ul style="list-style-type: none"> <li>● IPCx: <ul style="list-style-type: none"> <li>■ IPCM0_DEV for CM0</li> <li>■ IPCM4_DEV for CM4</li> </ul> </li> <li>● IPC_ChNum: the channel that want to request interrupt. This parameter must be set to a value of 0 ~ 31.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                              |

### 19.3.5 IPC\_INTClear

| Items        | Description                                                                                                                                                                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clears a core-to-core interrupt                                                                                                                                                                                                                                                |
| Parameters   | <ul style="list-style-type: none"> <li>● IPCx: <ul style="list-style-type: none"> <li>■ IPCM0_DEV for CM0</li> <li>■ IPCM4_DEV for CM4</li> </ul> </li> <li>● IPC_ChNum: the channel that want to clear interrupt. This parameter must be set to a value of 0 ~ 31.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                            |

### 19.3.6 IPC\_INTGet

| Items        | Description                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------|
| Introduction | Gets a core-to-core interrupt status                                                                        |
| Parameters   | IPCx:<br><ul style="list-style-type: none"> <li>● IPCM0_DEV for CM0</li> <li>● IPCM4_DEV for CM4</li> </ul> |
| Return       | The ISR of specified IPCx                                                                                   |

### 19.3.7 IPC\_CPUID

| Items        | Description                                                                             |
|--------------|-----------------------------------------------------------------------------------------|
| Introduction | Gets the current CPU ID                                                                 |
| Parameters   | N/A                                                                                     |
| Return       | CPU ID:<br><ul style="list-style-type: none"> <li>● 0: KM0</li> <li>● 1: KM4</li> </ul> |

### 19.3.8 IPC\_SEMGet

| Items | Description |
|-------|-------------|
|       |             |

|              |                                                                                                                                                                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Gets a core-to-core hardware semaphore                                                                                                                                                                                              |
| Parameters   | SEM_Idx: the semaphore index that want to get. This parameter must be set to a value of 0 ~ 15.<br><ul style="list-style-type: none"> <li>● 0 ~ 7: Reserved for Realtek use</li> <li>● 8 ~ 15: Reserved for Customer use</li> </ul> |
| Return       | Result:<br><ul style="list-style-type: none"> <li>● TRUE</li> <li>● FALSE</li> </ul>                                                                                                                                                |

### 19.3.9 IPC\_SEMFree

| Items        | Description                                                                                                                                                                                                                          |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Frees a core-to-core hardware semaphore                                                                                                                                                                                              |
| Parameters   | SEM_Idx: the semaphore index that want to free. This parameter must be set to a value of 0 ~ 15.<br><ul style="list-style-type: none"> <li>● 0 ~ 7: Reserved for Realtek use</li> <li>● 8 ~ 15: Reserved for Customer use</li> </ul> |
| Return       | Result:<br><ul style="list-style-type: none"> <li>● TRUE</li> <li>● FALSE</li> </ul>                                                                                                                                                 |

### 19.3.10 IPC\_INTHandler

| Items        | Description                              |
|--------------|------------------------------------------|
| Introduction | The common IPC interrupt handler         |
| Parameters   | Data: the data passed to the IRQ Handler |
| Return       | 0                                        |

**Note:** Before entering the specified IRQ handler, the common IPC interrupt handler clears the pending interrupt first. There is no need to clear the pending interrupt in user defined IRQ handler.

### 19.3.11 IPC\_INTUserHandler

| Items        | Description                                                                                                                                                                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Registers a user interrupt handler for a specified IPC channel                                                                                                                                                                                                                                                      |
| Parameters   | <ul style="list-style-type: none"> <li>● IPC_ChNum: the channel that want to register IRQ handler. This parameter must be set to a value of 0 ~ 31.</li> <li>● IrqHandler: the IRQ handler to be assigned to the specified IPC channel</li> <li>● IrqData: the pointer will be passed to the IRQ handler</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                 |

## 20 PSRAM

Pseudo Static Random Access Memory (PSRAM) is used for high speed transmission of data stream, and is suitable for audio codec. RTL8721D uses PSRAM controller to communicate with PSRAM. PSRAM is in KM4 platform, so only KM4 can access it.

The features of PSRAM are:

- Density: 32Mbit
- Address Mapping: 0x0200\_0000 ~ 0x0240\_0000
- Clock rate: 50MHz
- Double Data Rate (DDR)
- 16/32/64/128 bytes burst access
- Half sleep mode and deep power-down mode

### 20.1 Throughput

PSRAM supports direct access and DMA access.

Table 20-1 PSRAM throughput

| Access Mode   |           | Write      |                                                     | Read       |                                   |
|---------------|-----------|------------|-----------------------------------------------------|------------|-----------------------------------|
|               |           | Theory     | Test                                                | Theory     | Test                              |
| Direct Access | Cache off | 200Mbps    | < 160Mbps                                           | 177.78Mbps | < (32)/(180ns+360ns) = 59.26 Mbps |
|               | Cache on  | 200Mbps    | 160Mbps (CS is high for 40ns between two transmits) | 556.52Mbps | < (32*8)/(460ns+360ns) = 312Mbps  |
| DMA           |           | 731.43Mbps | 711.11Mbps                                          | 721.13Mbps | 589.18Mbps                        |

Table 20-2 PSRAM throughput theoretical calculation

| Time                                              | Write 32 bits               | Read 32 bits                 |
|---------------------------------------------------|-----------------------------|------------------------------|
| Header + delay                                    | [3 + (3-1)] * 20ns = 100ns  | [3 + (3-1)] * 20ns = 100ns   |
| Data transmit period                              | 2 * 20ns = 40ns             | 16 * 20ns = 320ns            |
| Hardware hold                                     | 1 * 20ns = 20ns             | 2 * 20ns = 40ns              |
| Total without consider instruction execution time | 100ns + 40ns + 20ns = 160ns | 100ns + 320ns + 40ns = 460ns |
| Throughput theoretical value                      | 32/160ns = 200Mbps          | (32*8)/460ns = 556.52Mbps    |

Note:

- When Cache off:
  - Read or write operation only accesses 32 bits once with header and delay.
  - Instruction execution time also needs to take into consideration.
  - The 360ns in test is caused by hardware characteristic. Command from CPU to PSRAM controller needs 152ns to sync, PSRAM controller controlling PHY circuit to work needs 82us, PHY giving read data to CPU needs 126ns.
- When Cache on:
  - Read operation reads 32 bytes (cache line) once.
  - Write operation writes 32 bits once, but the interval between two write operations is greatly reduced.
  - The 360ns in test is caused by hardware characteristic. Command from CPU to PSRAM controller needs 152ns to sync, PSRAM controller controlling PHY circuit to work needs 82us, PHY giving read data to CPU needs 126ns.
- DMA sets burst length 128 bytes and disables cache.
  - For DMA write, DAM moving data to PSRAM FIFO and PSRAM controller writing FIFO data to PSRAM slave can work simultaneously, so the interval between two burst write operations is small.
  - For DMA read, similar operation as DMA write is not supported, so the interval between two burst read operations is large.
  - The test data above takes variable initial latency and 3 clocks initial latency for example.

## 20.2 Power Management

When entering KM4 powergate mode, PSRAM will be reset and its memory will be lost. If you want to retain the PSRAM, KM4 powergate mode is not supported to use. If you want to keep the PSRAM and save power, KM4 clockgate mode is supported.

Table 20-3 PSRAM power management

| Retention | Options                                                                                                             | Power Consumption (uA) | Comment                                                                |
|-----------|---------------------------------------------------------------------------------------------------------------------|------------------------|------------------------------------------------------------------------|
| NO        | <ul style="list-style-type: none"> <li>● KM4 PG</li> <li>● PSRAM_LDO OFF</li> </ul>                                 | 30 ~ 50                | PSRAM cannot keep. So memory retention applications are not supported. |
| Yes       | <ul style="list-style-type: none"> <li>● KM4 CG</li> <li>● PSRAM_LDO ON</li> <li>● PSRAM Half Sleep mode</li> </ul> | 400+                   |                                                                        |

## 20.3 How to Use PSRAM

### 20.3.1 Initialize PSRAM

Before accessing PSRAM, PSRAM power should be enabled, PSRAM controller and PSRAM slave should be initialized to synchronize related parameters.

In SDK, you should set **psram\_dev\_enable** in **rtl8721dhp\_intfcfg.c**. If the chip works in the environment with large fluctuations in temperature, you should also set **psram\_dev\_cal\_enable** to enable calibration function. If you want to keep the PSRAM and save power when KM4 enters sleep mode, you should set **psram\_dev\_retention** to enable PSRAM retention.

```
PSRAMCFG_TypeDef psram_dev_config = {
    .psram_dev_enable = TRUE,           //enable psram
    .psram_dev_cal_enable = TRUE,       //enable psram calibration function
    .psram_dev_retention = TRUE,        //enable psram retention
    .psram_heap_start_address = 0x02000400, //config psram heap start address, should be 8 bytes aligned
    .psram_heap_size = 0x400000-0x400,   //config psram heap size, should be 8 bytes aligned
};
```

Fig 20-1 PSRAM initial configuration

### 20.3.2 Add Section into PSRAM Region

To add section into PSRAM region, the following steps are necessary.

- (1) To put a data buffer in PSRAM, add **PSRAM\_BSS\_SECTION** before the buffer definition.

```
PSRAM_BSS_SECTION u32 PSRAM_Testbuf[1024];
```

- (2) Rebuild KM4 project.

## 20.4 How to Allocate Heap from PSRAM

Before allocating heap, Initialize PSRAM must be completed, then follow the steps below.

- (1) Confirm the heap size and the start address you want in **rtl8721dhp\_intfcfg.c**, **psram\_heap\_start\_address** and **psram\_heap\_size** must be 8 bytes aligned.

```
PSRAMCFG_TypeDef psram_dev_config = {
    .psram_dev_enable = FALSE,          //enable psram
    .psram_dev_cal_enable = FALSE,      //enable psram calibration function
    .psram_dev_retention = FALSE,       //enable psram retention
    .psram_heap_start_address = 0x02000400, //config psram heap start address, should be 8 bytes aligned
    .psram_heap_size = 0x400000-0x400,   //config psram heap size, should be 8 bytes aligned
};
```

- (2) Use **void \*Psram\_reserve\_malloc(int size)** to allocate a heap or use **void \*Psram\_reserve\_calloc(int num, int size)** to allocate several consecutive spaces. Both functions return a pointer to the start address of the allocation. Use **void Psram\_reserve\_free(void \*mem)** to free the allocation.

**Note:**

- The **psram\_heap\_start\_address** must be larger than the **\_\_psram\_bss\_end\_\_**. The **psram\_heap\_start\_address** must be increased when “**psram\_heap\_start\_address** should larger than ...” is shown, and the **psram\_heap\_size** should be decreased depending on the **psram\_heap\_start\_address** configured.
- The **PSRAM\_BSS\_SECTION** will be cleared only in the function **void app\_init\_psram(void)** of **main.c** (in KM4).

# 21 MPU and Cache

## 21.1 Functional description

### 21.1.1 MPU

Memory Protection Unit (MPU) is used to provide Hardware Protection by Software definition. Our code provides `mpu_region_config` structure to include the region memory attribute. Default attribute of all KMO & KM4 SRAM are write-through.

Table 21-1 shows member variables of the `mpu_region_config` structure.

Table 21-1 `mpu_region_config` structure

| Member Variable Name     | Type                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>region_base</code> | <code>uint32_t</code> | MPU region base, 32 bytes aligned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <code>region_size</code> | <code>uint32_t</code> | MPU region size, 32 bytes aligned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <code>xn</code>          | <code>uint8_t</code>  | Execute Never attribute <ul style="list-style-type: none"> <li>● <code>MPU_EXEC_ALLOW</code>: Allows program execution in this region</li> <li>● <code>MPU_EXEC_NEVER</code>: Does not allow program execution in this region</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <code>ap</code>          | <code>uint8_t</code>  | Access permissions <ul style="list-style-type: none"> <li>● <code>MPU_PRIV_RW</code>: Read/write by privileged code only</li> <li>● <code>MPU_UN_PRIV_RW</code>: Read/write by any privilege level</li> <li>● <code>MPU_PRIV_R</code>: Read only by privileged code only</li> <li>● <code>MPU_PRIV_W</code>: Read only by any privilege level</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <code>sh</code>          | <code>uint8_t</code>  | Share ability for Normal memory <ul style="list-style-type: none"> <li>● <code>MPU_NON_SHAREABLE</code>: Non-shareable</li> <li>● <code>MPU_OUT_SHAREABLE</code>: Outer shareable</li> <li>● <code>MPU_INR_SHAREABLE</code>: Inner shareable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <code>attr_idx</code>    | <code>uint8_t</code>  | Memory attribute indirect index<br>This parameter can be a value of 0 ~ 7, the detailed attribute is defined in <code>mpu_init()</code> and is customized. The typical definition is as following: <ul style="list-style-type: none"> <li>● 0: <code>MPU_MEM_ATTR_IDX_NC</code>, defines memory attribute of Normal memory with non-cacheable</li> <li>● 1: <code>MPU_MEM_ATTR_IDX_WT_T_RA</code>, defines memory attribute of Normal memory with write-through transient, read allocation</li> <li>● 2: <code>MPU_MEM_ATTR_IDX_WB_T_RWA</code>, defines memory attribute of Normal memory with write-back transient, read and write allocation</li> <li>● 3 ~ 7: <code>MPU_MEM_ATTR_IDX_DEVICE</code>, defines memory attribute of Device memory with non-gathering, non-recording, non-early Write Acknowledge</li> </ul> |

Table 21-2 shows how to set a MPU region.

Table 21-2 How to set a MPU region

| Steps                                 | Description                                                                                                                                                               |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| New variable and structure            | <ul style="list-style-type: none"> <li>● Variable to store MPU entry index</li> <li>● Structure <code>mpu_region_config</code> to store the region attribution</li> </ul> |
| Allocate a free MPU entry             | Call <code>mpu_entry_alloc()</code>                                                                                                                                       |
| Set region attribution                | Set region attribution structure                                                                                                                                          |
| Configure MPU region memory attribute | Call <code>mpu_region_cfg()</code>                                                                                                                                        |

### 21.1.2 Cache

Cache is used to improve the CPU performance of data access. Ameba-D Cache supports Enable/Disable, Flush and Clean Operation, as Table 21-3 lists.

Table 21-3 Enable/disable, flush and clean operation supported by Cache

| Operation          | Description                                                                                                                                                                                                                                          | I-Cache | D-Cache |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|
| Enable/Disable     | Enable or Disable Cache function                                                                                                                                                                                                                     | ✓       | ✓       |
| Flush (Invalidate) | <ul style="list-style-type: none"> <li>● Flush Cache</li> <li>● D-Cache can be flushed by address</li> <li>● Can be used after DMA Rx, and CPU reads DMA data from DMA buffer for D-Cache</li> </ul>                                                 | ✓       | ✓       |
| Clean              | <ul style="list-style-type: none"> <li>● Clean D-Cache</li> <li>● D-Cache will be write back to memory</li> <li>● D-Cache can be cleaned by address</li> <li>● Can be used before DMA Tx, after CPU writes data to DMA buffer for D-Cache</li> </ul> | ✗       | ✓       |

## 21.2 MPU APIs

### 21.2.1 mpu\_init

| Items        | Description                                      |
|--------------|--------------------------------------------------|
| Introduction | Initialize MPU memory attribute to typical value |
| Parameters   | N/A                                              |
| Return       | N/A                                              |

### 21.2.2 mpu\_set\_mem\_attr

| Items        | Description                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Change MPU memory attribute                                                                                                                         |
| Parameters   | <ul style="list-style-type: none"> <li>● attr_idx: memory attribute index, where x can be 0 ~ 7.</li> <li>● mem_attr: memory attributes.</li> </ul> |
| Return       | N/A                                                                                                                                                 |

### 21.2.3 mpu\_region\_cfg

| Items        | Description                                                                                                                                                                                                |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Configure MPU region memory attribute.                                                                                                                                                                     |
| Parameters   | <ul style="list-style-type: none"> <li>● region_num: where x can be 0 ~ 3 (KM0 &amp; KM4 both).</li> <li>● pmpu_cfg: pointer to an <b>mpu_region_config</b> structure which has been configured</li> </ul> |
| Return       | N/A                                                                                                                                                                                                        |

### 21.2.4 mpu\_entry\_free

| Items        | Description                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Free MPU entry                                                                                                               |
| Parameters   | entry_index: <ul style="list-style-type: none"> <li>● KM0: 0 ~ 3</li> <li>● KM4_NS: 0 ~ 7</li> <li>● KM4_S: 0 ~ 3</li> </ul> |
| Return       | N/A                                                                                                                          |

### 21.2.5 mpu\_entry\_alloc

| Items        | Description               |
|--------------|---------------------------|
| Introduction | Allocate a free MPU entry |

|            |                                                                                                                                                         |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters | N/A                                                                                                                                                     |
| Return     | MPU entry index:<br><ul style="list-style-type: none"> <li>● KM0: 0 ~ 3</li> <li>● KM4_NS: 0 ~ 7</li> <li>● KM4_S: 0 ~ 3</li> <li>● Fail: -1</li> </ul> |

## 21.3 Cache APIs

### 21.3.1 ICACHE\_Enable

| Items        | Description    |
|--------------|----------------|
| Introduction | Enable I-Cache |
| Parameters   | N/A            |
| Return       | N/A            |

### 21.3.2 ICACHE\_Disable

| Items        | Description     |
|--------------|-----------------|
| Introduction | Disable I-Cache |
| Parameters   | N/A             |
| Return       | N/A             |

### 21.3.3 ICACHE\_Invalidate

| Items        | Description        |
|--------------|--------------------|
| Introduction | Invalidate I-Cache |
| Parameters   | N/A                |
| Return       | N/A                |

### 21.3.4 DCACHE\_IsEnabled

| Items        | Description                                                                                                   |
|--------------|---------------------------------------------------------------------------------------------------------------|
| Introduction | Check D-Cache Enabled or not                                                                                  |
| Parameters   | N/A                                                                                                           |
| Return       | D-Cache enable status:<br><ul style="list-style-type: none"> <li>● 1: Enable</li> <li>● 0: Disable</li> </ul> |

### 21.3.5 DCACHE\_Enable

| Items        | Description    |
|--------------|----------------|
| Introduction | Enable D-Cache |
| Parameters   | N/A            |
| Return       | N/A            |

### 21.3.6 DCACHE\_Disable

| Items | Description |
|-------|-------------|
|       |             |

|              |                 |
|--------------|-----------------|
| Introduction | Disable D-Cache |
| Parameters   | N/A             |
| Return       | N/A             |

### 21.3.7 DCACHE\_INVALIDATE

| Items        | Description                                                                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | D-Cache invalidate by address                                                                                                                                         |
| Parameters   | <ul style="list-style-type: none"> <li>Address: invalidate address (aligned to 32-byte boundary)</li> <li>Bytes: size of memory block (in number of bytes)</li> </ul> |
| Return       | N/A                                                                                                                                                                   |

### 21.3.8 DCACHE\_CLEAN

| Items        | Description                                                                                                                                                                                                                   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | D-Cache clean by address                                                                                                                                                                                                      |
| Parameters   | <ul style="list-style-type: none"> <li>Address: clean address (aligned to 32-byte boundary). Address set 0xFFFFFFFF is used for all D-Cache be cleaned.</li> <li>Bytes: size of memory block (in number of bytes).</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                           |

### 21.3.9 DCACHE\_CLEANINVALIDATE

| Items        | Description                                                                                                                                                                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | D-Cache clean and invalidate by address                                                                                                                                                                                                               |
| Parameters   | <ul style="list-style-type: none"> <li>Address: clean and invalidate address (aligned to 32-byte boundary) Address set 0xFFFFFFFF is used for all D-Cache be cleaned and flushed</li> <li>Bytes: size of memory block (in number of bytes)</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                   |

## 21.4 How to Define a Non-cacheable Data Buffer

To define a data buffer with non-cacheable attribute, you should add **SRAM\_NOCACHE\_DATA\_SECTION** before the buffer definition, as Fig 21-1 shows.

```
SRAM_NOCACHE_DATA_SECTION u8 noncache_buffer[DATA_BUFFER_SIZE];
```

Fig 21-1 Non-cacheable buffer initialization

## 22 Liquid Crystal Display Controller (LCDC)

Ameba-D LCDC supports Thin Film Transistor (TFT) color display. It provides I8080 MCU interface (8-/16-bit bus width) and RGB interface (6-/16-bit bus width), and support RGB565 data format

In this chapter, we would introduce how to use LCDC I/F to control LCD module.

### 22.1 Interface

The available LCDC interfaces for different IC packages are as Table 22-1 shows.

Table 22-1 LCDC I/F supported for different packages

| IC Package                            | MCU 8-bit | RGB 6-bit | MCU 16-bit (TBD) | RGB 16-bit (TBD) |
|---------------------------------------|-----------|-----------|------------------|------------------|
| RTL8722D/RTL8722CS                    | Y         | Y         | N                | N                |
| RTL8721D/RTL8721CS/RTL8720D/RTL8720CS | N         | N         | N                | N                |

The data format supported by each interface shown in Table 22-2. In order to display normally, the data format of LCM and LCDC interface should match.

Table 22-2 LCDC I/F data format

| Interface              | Data Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Comment |      |      |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|------|------|-----|----|-----|----|---|-----|-----|---|------|------|-----|-----|------|------|------|------|-----|----|------|------|------|------|------|------|------|-----|------|------|------|------|-----|-----|----|------|------|------|------|-----|------|------|------|------|------|------|------|-----|----|------|------|------|------|-----|----|------|------|------|------|------|------|------|-----|------|------|------|------|-----|------------------------|----|------|------|-----|----|----|---------------------------|------|-----|----|----|------|------|-----|----|----|------|------|-----|------------------------|--|--|--|--|--------------------------|
| MCU 8-bit              | <table border="1"> <tr><td>Count</td><td>0</td><td>1</td><td>2</td><td>3</td><td>4</td><td>...</td></tr> <tr><td>RS</td><td>0</td><td>1</td><td>1</td><td>1</td><td>1</td><td>...</td></tr> <tr><td>D7</td><td>C7</td><td>P1R4</td><td>P1G2</td><td>P2R4</td><td>P2G2</td><td>...</td></tr> <tr><td>D6</td><td>C6</td><td>P1R3</td><td>P1G1</td><td>P2R3</td><td>P2G1</td><td>...</td></tr> <tr><td>D5</td><td>C5</td><td>P1R2</td><td>P1G0</td><td>P2R2</td><td>P2G0</td><td>...</td></tr> <tr><td>D4</td><td>C4</td><td>P1R1</td><td>P1B4</td><td>P2R1</td><td>P2B4</td><td>...</td></tr> <tr><td>D3</td><td>C3</td><td>P1R0</td><td>P1B3</td><td>P2R0</td><td>P2B3</td><td>...</td></tr> <tr><td>D2</td><td>C2</td><td>P1G5</td><td>P1B2</td><td>P2G5</td><td>P2B2</td><td>...</td></tr> <tr><td>D1</td><td>C1</td><td>P1G4</td><td>P1B1</td><td>P2G4</td><td>P2B1</td><td>...</td></tr> <tr><td>D0</td><td>C0</td><td>P1G3</td><td>P1B0</td><td>P2G3</td><td>P2B0</td><td>...</td></tr> <tr><td colspan="7">P1R4 : Pixel1/Red_bit4</td></tr> </table>                                                                                                                                                                                                                                                                                                               | Count   | 0    | 1    | 2    | 3   | 4  | ... | RS | 0 | 1   | 1   | 1 | 1    | ...  | D7  | C7  | P1R4 | P1G2 | P2R4 | P2G2 | ... | D6 | C6   | P1R3 | P1G1 | P2R3 | P2G1 | ...  | D5   | C5  | P1R2 | P1G0 | P2R2 | P2G0 | ... | D4  | C4 | P1R1 | P1B4 | P2R1 | P2B4 | ... | D3   | C3   | P1R0 | P1B3 | P2R0 | P2B3 | ...  | D2  | C2 | P1G5 | P1B2 | P2G5 | P2B2 | ... | D1 | C1   | P1G4 | P1B1 | P2G4 | P2B1 | ...  | D0   | C0  | P1G3 | P1B0 | P2G3 | P2B0 | ... | P1R4 : Pixel1/Red_bit4 |    |      |      |     |    |    | 2 transfers/pixel, RGB565 |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| Count                  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1       | 2    | 3    | 4    | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| RS                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1       | 1    | 1    | 1    | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D7                     | C7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1R4    | P1G2 | P2R4 | P2G2 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D6                     | C6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1R3    | P1G1 | P2R3 | P2G1 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D5                     | C5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1R2    | P1G0 | P2R2 | P2G0 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D4                     | C4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1R1    | P1B4 | P2R1 | P2B4 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D3                     | C3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1R0    | P1B3 | P2R0 | P2B3 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D2                     | C2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1G5    | P1B2 | P2G5 | P2B2 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D1                     | C1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1G4    | P1B1 | P2G4 | P2B1 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D0                     | C0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1G3    | P1B0 | P2G3 | P2B0 | ... |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| P1R4 : Pixel1/Red_bit4 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |      |      |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| MCU 16-bit             | <table border="1"> <tr><td>Count</td><td>0</td><td>1</td><td>2</td><td>...</td></tr> <tr><td>RS</td><td>0</td><td>1</td><td>1</td><td>...</td></tr> <tr><td>D15</td><td></td><td>P1R4</td><td>P2R4</td><td>...</td></tr> <tr><td>D14</td><td></td><td>P1R3</td><td>P2R3</td><td>...</td></tr> <tr><td>D13</td><td></td><td>P1R2</td><td>P2R2</td><td>...</td></tr> <tr><td>D12</td><td></td><td>P1R1</td><td>P2R1</td><td>...</td></tr> <tr><td>D11</td><td></td><td>P1R0</td><td>P2R0</td><td>...</td></tr> <tr><td>D10</td><td></td><td>P1G5</td><td>P2G5</td><td>...</td></tr> <tr><td>D9</td><td></td><td>P1G4</td><td>P2G4</td><td>...</td></tr> <tr><td>D8</td><td></td><td>P1G3</td><td>P2G3</td><td>...</td></tr> <tr><td>D7</td><td>C7</td><td>P1G2</td><td>P2G2</td><td>...</td></tr> <tr><td>D6</td><td>C6</td><td>P1G1</td><td>P2G1</td><td>...</td></tr> <tr><td>D5</td><td>C5</td><td>P1G0</td><td>P2G0</td><td>...</td></tr> <tr><td>D4</td><td>C4</td><td>P1B4</td><td>P2B4</td><td>...</td></tr> <tr><td>D3</td><td>C3</td><td>P1B3</td><td>P2B3</td><td>...</td></tr> <tr><td>D2</td><td>C2</td><td>P1B2</td><td>P2B2</td><td>...</td></tr> <tr><td>D1</td><td>C1</td><td>P1B1</td><td>P2B1</td><td>...</td></tr> <tr><td>D0</td><td>C0</td><td>P1B0</td><td>P2B0</td><td>...</td></tr> <tr><td colspan="5">P1R4 : Pixel1/Red_bit4</td></tr> </table> | Count   | 0    | 1    | 2    | ... | RS | 0   | 1  | 1 | ... | D15 |   | P1R4 | P2R4 | ... | D14 |      | P1R3 | P2R3 | ...  | D13 |    | P1R2 | P2R2 | ...  | D12  |      | P1R1 | P2R1 | ... | D11  |      | P1R0 | P2R0 | ... | D10 |    | P1G5 | P2G5 | ...  | D9   |     | P1G4 | P2G4 | ...  | D8   |      | P1G3 | P2G3 | ... | D7 | C7   | P1G2 | P2G2 | ...  | D6  | C6 | P1G1 | P2G1 | ...  | D5   | C5   | P1G0 | P2G0 | ... | D4   | C4   | P1B4 | P2B4 | ... | D3                     | C3 | P1B3 | P2B3 | ... | D2 | C2 | P1B2                      | P2B2 | ... | D1 | C1 | P1B1 | P2B1 | ... | D0 | C0 | P1B0 | P2B0 | ... | P1R4 : Pixel1/Red_bit4 |  |  |  |  | 1 transfer/pixel, RGB565 |
| Count                  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1       | 2    | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| RS                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1       | 1    | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D15                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1R4    | P2R4 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D14                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1R3    | P2R3 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D13                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1R2    | P2R2 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D12                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1R1    | P2R1 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D11                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1R0    | P2R0 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D10                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1G5    | P2G5 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D9                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1G4    | P2G4 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D8                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1G3    | P2G3 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D7                     | C7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1G2    | P2G2 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D6                     | C6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1G1    | P2G1 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D5                     | C5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1G0    | P2G0 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D4                     | C4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1B4    | P2B4 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D3                     | C3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1B3    | P2B3 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D2                     | C2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1B2    | P2B2 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D1                     | C1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1B1    | P2B1 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| D0                     | C0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P1B0    | P2B0 | ...  |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |
| P1R4 : Pixel1/Red_bit4 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |      |      |      |     |    |     |    |   |     |     |   |      |      |     |     |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |     |    |      |      |      |      |     |      |      |      |      |      |      |      |     |    |      |      |      |      |     |    |      |      |      |      |      |      |      |     |      |      |      |      |     |                        |    |      |      |     |    |    |                           |      |     |    |    |      |      |     |    |    |      |      |     |                        |  |  |  |  |                          |

|                        |       |      |      |      |                          |      |     |                           |  |
|------------------------|-------|------|------|------|--------------------------|------|-----|---------------------------|--|
| RGB 6-bit              | Count | 0    | 1    | 2    | 3                        | 4    | ... | 3 transfers/pixel, RGB565 |  |
|                        | D5    | P1R4 | P1G5 | P1B4 | P2R4                     | P2G5 | ... |                           |  |
|                        | D4    | P1R3 | P1G4 | P1B3 | P2R3                     | P2G4 | ... |                           |  |
|                        | D3    | P1R2 | P1G3 | P1B2 | P2R2                     | P2G3 | ... |                           |  |
|                        | D2    | P1R1 | P1G2 | P1B1 | P2R1                     | P2G2 | ... |                           |  |
|                        | D1    | P1R0 | P1G1 | P1B0 | P2R0                     | P2G1 | ... |                           |  |
|                        | D0    |      | P1G0 |      |                          | P2G0 | ... |                           |  |
| P1R4 : Pixel1/Red_bit4 |       |      |      |      |                          |      |     |                           |  |
| RGB 16-bit             | Count | 0    | 1    | ...  | 1 transfer/pixel, RGB565 |      |     |                           |  |
|                        | D15   | P1R4 | P2R4 | ...  |                          |      |     |                           |  |
|                        | D14   | P1R3 | P2R3 | ...  |                          |      |     |                           |  |
|                        | D13   | P1R2 | P2R2 | ...  |                          |      |     |                           |  |
|                        | D12   | P1R1 | P2R1 | ...  |                          |      |     |                           |  |
|                        | D11   | P1R0 | P2R0 | ...  |                          |      |     |                           |  |
|                        | D10   | P1G5 | P2G5 | ...  |                          |      |     |                           |  |
|                        | D9    | P1G4 | P2G4 | ...  |                          |      |     |                           |  |
|                        | D8    | P1G3 | P2G3 | ...  |                          |      |     |                           |  |
|                        | D7    | P1G2 | P2G2 | ...  |                          |      |     |                           |  |
|                        | D6    | P1G1 | P2G1 | ...  |                          |      |     |                           |  |
|                        | D5    | P1G0 | P2G0 | ...  |                          |      |     |                           |  |
|                        | D4    | P1B4 | P2B4 | ...  |                          |      |     |                           |  |
|                        | D3    | P1B3 | P2B3 | ...  |                          |      |     |                           |  |
|                        | D2    | P1B2 | P2B2 | ...  |                          |      |     |                           |  |
|                        | D1    | P1B1 | P2B1 | ...  |                          |      |     |                           |  |
|                        | D0    | P1B0 | P2B0 | ...  |                          |      |     |                           |  |
| P1R4 : Pixel1/Red_bit4 |       |      |      |      |                          |      |     |                           |  |

## 22.2 Resolution

The maximum resolution supported by each interface is listed in Table 22-3.

Table 22-3 Maximum supported resolution

| Interface  | Display Type    | Max. Support Resolution |
|------------|-----------------|-------------------------|
| MCU 8-bit  | Static Display  | 1024*1024               |
|            | Animate Display | 645*645 (30 fps)        |
| MCU 16-bit | Static Display  | 1024*1024               |
|            | Animate Display | 912*912 (30 fps)        |
| RGB 6-bit  | Animate Display | 600*400 (60 fps)        |
| RGB 16-bit | Animate Display | 1024*760 (60 fps)       |

For RGB LCD, the typical frame rate is 60 fps. As a result, the parameters in Table 22-1 are given in the case of refresh frequency 60Hz.

In order to support RGB-LCD with higher resolution than parameters in Table 22-1, users have to lower the frame rate. The maximum frame rate(F) for a RGB-LCD is calculated as following:

- Max dot clock: MAX\_DOT\_CLK = system\_clock/2 = 100M/2 = 50MHz
- Width, height, HBP, HFP, VBP, VFP is specified by LCD datasheet.

For 16-bit I/F mode:

$$\begin{aligned} \text{image\_size} &= \text{MAX\_DOT\_CLK} / F - (\text{width} + \text{HBP} + \text{HFP}) * (\text{VBP} + \text{VFP}) - \text{height} * (\text{HBP} + \text{HFP}); \\ \Rightarrow F &= 50\text{M} / (\text{width} * \text{height} + (\text{width} + \text{HBP} + \text{HFP}) * (\text{VBP} + \text{VFP}) + \text{height} * (\text{HBP} + \text{HFP})); \end{aligned}$$

For 6-bit I/F mode:

$$\text{image\_size} = \text{MAX\_DOT\_CLK} / (3 * F) - (\text{width} + \text{HBP} + \text{HFP}) * (\text{VBP} + \text{VFP}) - \text{height} * (\text{HBP} + \text{HFP}); \\ \Rightarrow F = 50\text{M} / (\text{width} * \text{height} + (\text{width} + \text{HBP} + \text{HFP}) * (\text{VBP} + \text{VFP}) + \text{height} * (\text{HBP} + \text{HFP})) / 3;$$

When frame rate is lower than 30fps, the screen flickering may happen. Users should evaluate the visual artifacts when lower the frame rate.

## 22.3 Pinmux

The pinmux of LCDC is listed in Table 22-4.

Table 22-4 LCDC pin assignment

| Port Name | MCU 8-bit | MCU 16-bit | RGB 6-bit | RGB 16-bit | LED I/F |
|-----------|-----------|------------|-----------|------------|---------|
| PB_19     | -         | D[15]      | -         | D[15]      | -       |
| PB_18     | -         | D[14]      | -         | D[14]      | -       |
| PB_11     | -         | D[13]      | -         | D[13]      | -       |
| PB_10     | -         | D[12]      | -         | D[12]      | -       |
| PB_9      | -         | D[11]      | -         | D[11]      | -       |
| PB_8      | -         | D[10]      | -         | D[10]      | -       |
| PA_25     | -         | D[9]       | -         | D[9]       | -       |
| PA_26     | -         | D[8]       | -         | D[8]       | -       |
| PA_28     | D[7]      | D[7]       | -         | D[7]       | -       |
| PA_30     | D[6]      | D[6]       | -         | D[6]       | -       |
| PB_0      | D[5]      | D[5]       | D[5]      | D[5]       | D[5]    |
| PA_31     | D[4]      | D[4]       | D[4]      | D[4]       | D[4]    |
| PA_24     | D[3]      | D[3]       | D[3]      | D[3]       | D[3]    |
| PA_23     | D[2]      | D[2]       | D[2]      | D[2]       | D[2]    |
| PA_20     | D[1]      | D[1]       | D[1]      | D[1]       | D[1]    |
| PA_19     | D[0]      | D[0]       | D[0]      | D[0]       | D[0]    |
| PB_20     | TE/VSYNC  |            | VSYNC     |            | -       |
| PB_21     | RS        |            | -         |            | -       |
| PB_22     | RD        |            | Hsync     |            | LAT     |
| PB_23     | WR        |            | DCLK      |            | DCLK    |
| PB_28     | CS        |            | ENABLE    |            | OE      |

## 22.4 JPG Decompressor

The picture of bitmap format can be displayed on LCD directly after transmit pixel data into LCM. This format contains color bits of each pixel, causing the file size too large and taking too much memory.

JPEG is a commonly used method of lossy compression for digital images. The storage size decreases with little perceptible loss in image quality after compression.

Ameba-D provides SW JPG decoder for .jpg file decompression. Users can refer to JPG decode demo for how to using it. The following table shows the performance of decoding test.jpg whose resolution is 250\*250.

| Resolution | Memory Size | Time Consumption |
|------------|-------------|------------------|
| 250*250    | Heap: 3K    | 70ms             |

## 22.5 LCDC APIs

### 22.5.1 MCU Function

#### 22.5.1.1 LCDC\_MCUStructInit

| Items        | Description                                                                                |
|--------------|--------------------------------------------------------------------------------------------|
| Introduction | Initializes the parameters in the LCDC_MCUInitStruct with default values.                  |
| Parameters   | LCDC_MCUInitStruct: pointer to an LCDC_MCUInitTypeDef structure which will be initialized. |
| Return       | N/A                                                                                        |

**Note:** LCDC\_MCUInitStruct contains the MCU configure parameters for LCDC, which determine the MCU I/F is 8-bit or 16-bit, IO mode or DMA mode, the plane size and some timing control. The parameters in this structure should be set according to LCD Module datasheet.

#### 22.5.1.2 LCDC\_MCUInit

| Items        | Description                                                                                                                                                                                                |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the LCDC peripheral according to the specified parameters in the LCDC_MCUInitStruct.                                                                                                           |
| Parameters   | <ul style="list-style-type: none"> <li>● LCDCx: where LCDCx can be LCDC.</li> <li>● LCDC_MCUInitStruct: pointer to a LCDC_MCUInitTypeDef structure that contains the configuration information.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                        |

#### 22.5.1.3 LCDC\_MCUIOWriteCmd

| Items        | Description                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write command to LCD module via MCU I/F.                                                                                     |
| Parameters   | <ul style="list-style-type: none"> <li>● LCDCx: where LCDCx can be LCDC.</li> <li>● Cmd: the command to transmit.</li> </ul> |
| Return       | N/A                                                                                                                          |

#### 22.5.1.4 LCDC\_MCUIOWriteData

| Items        | Description                                                                                                                |
|--------------|----------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write data to LCD module via MCU I/F.                                                                                      |
| Parameters   | <ul style="list-style-type: none"> <li>● LCDCx: where LCDCx can be LCDC.</li> <li>● Data: the data to transmit.</li> </ul> |
| Return       | N/A                                                                                                                        |

#### 22.5.1.5 LCDC\_MCUIOReadData

| Items        | Description                            |
|--------------|----------------------------------------|
| Introduction | Read data from LCD module via MCU I/F. |
| Parameters   | LCDCx: where LCDCx can be LCDC.        |
| Return       | The read value return back.            |

#### 22.5.1.6 LCDC\_MCUDMATrigger

| Items        | Description                                                                  |
|--------------|------------------------------------------------------------------------------|
| Introduction | Trigger to transfer data of one frame from DMA buffer to LCDC Transmit FIFO. |
| Parameters   | LCDCx: where LCDCx can be LCDC.                                              |

|        |     |
|--------|-----|
| Return | N/A |
|--------|-----|

## 22.5.2 RGB Function

### 22.5.2.1 LCDC\_RGBStructInit

| Items        | Description                                                                                |
|--------------|--------------------------------------------------------------------------------------------|
| Introduction | Initializes the parameters in the LCDC_RGBInitStruct with default values.                  |
| Parameters   | LCDC_RGBInitStruct: pointer to an LCDC_RGBInitTypeDef structure which will be initialized. |
| Return       | N/A                                                                                        |

**Note:** LCDC\_RGBInitStruct contains the RGB configure parameters for LCDC, which determine the RGB I/F is 6-bit or 16-bit, DE or HV mode, the plane size, the refresh frequency and VSYNC and HSYNC control. The parameters in this structure should be set according to LCD Module datasheet.

### 22.5.2.2 LCDC\_RGBInit

| Items        | Description                                                                                                                                                                                                |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the LCDC peripheral according to the specified parameters in the LCDC_RGBInitStruct.                                                                                                           |
| Parameters   | <ul style="list-style-type: none"> <li>● LCDCx: where LCDCx can be LCDC.</li> <li>● LCDC_RGBInitStruct: pointer to a LCDC_RGBInitTypeDef structure that contains the configuration information.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                        |

## 22.5.3 LED Function

### 22.5.3.1 LCDC\_LEDStructInit

| Items        | Description                                                                                |
|--------------|--------------------------------------------------------------------------------------------|
| Introduction | Initializes the parameters in the LCDC_LEDInitStruct with default values.                  |
| Parameters   | LCDC_LEDInitStruct: pointer to an LCDC_LEDInitTypeDef structure which will be initialized. |
| Return       | N/A                                                                                        |

### 22.5.3.2 LCDC\_LEDInit

| Items        | Description                                                                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the LCDC peripheral according to the specified parameters in the LCDC_LEDInitStruct.                                                                                          |
| Parameters   | <ul style="list-style-type: none"> <li>● LCDCx: where LCDCx can be LCDC.</li> <li>● LCDC_LEDInitStruct: pointer to an LCDC_LEDInitTypeDef structure which will be initialized.</li> </ul> |
| Return       | N/A                                                                                                                                                                                       |

## 22.5.4 Common Function

### 22.5.4.1 LCDC\_DMAModeConfig

| Items        | Description                                                                                                                              |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Configure LCDC DMA burst size.                                                                                                           |
| Parameters   | <ul style="list-style-type: none"> <li>● LCDCx: where LCDCx can be LCDC.</li> <li>● BurstSize: DMA burst size; Unit 64 Bytes.</li> </ul> |
| Return       | N/A                                                                                                                                      |

**Note:**

- If BurstSize=1, the actual burstsize = 1x64 Bytes; if BurstSize=2, the actual burstsize = 2x64 = 128 Bytes; ....

- The parameter "BurstSize" is not more than 8. The recommended BurstSize is 2.

#### 22.5.4.2 LCDC\_DMAMImageBaseAddrConfig

| Items        | Description                                                                                                                 |
|--------------|-----------------------------------------------------------------------------------------------------------------------------|
| Introduction | Configure image base address.                                                                                               |
| Parameters   | <ul style="list-style-type: none"> <li>LCDCx: where LCDCx can be LCDC.</li> <li>ImgBaseAddr: the buffer address.</li> </ul> |
| Return       | N/A                                                                                                                         |

#### 22.5.4.3 LCDC\_INTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the specified LCDC interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Parameters   | <ul style="list-style-type: none"> <li>LCDCx: where LCDCx can be LCDC.</li> <li>LCDC_IT: specifies the LCDC interrupt sources to be enabled or disabled. This parameter can be any combination of the following values: <ul style="list-style-type: none"> <li>LCDC_IT_DMAUNDFW: DMA FIFO underflow interrupt</li> <li>LCDC_IT_FRDN: LCD refresh done interrupt</li> <li>LCDC_IT_LINE: line interrupt</li> <li>LCDC_IT_IO_TIMEOUT: IO write/read timeout interrupt</li> <li>LCDC_IT_FRM_START: Frame Start interrupt</li> </ul> </li> <li>NewState: new state of the specified LCDC interrupts. This parameter can be ENABLE or DISABLE.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 22.5.4.4 LCDC\_GetINTStatus

| Items        | Description                     |
|--------------|---------------------------------|
| Introduction | Get lcdc interrupt status.      |
| Parameters   | LCDCx: where LCDCx can be LCDC. |
| Return       | Interrupt status                |

#### 22.5.4.5 LCDC\_ClearINT

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clears the LCDC's interrupt pending bits.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Parameters   | <ul style="list-style-type: none"> <li>LCDC_IT: specifies the interrupt to be cleared. This parameter can be any combination of the following values: <ul style="list-style-type: none"> <li>LCDC_IT_LINE: line interrupt</li> <li>LCDC_IT_FRDN: refresh frame done interrupt</li> <li>LCDC_IT_DMAUNDFW: DMA FIFO under flow interrupt</li> <li>LCDC_IT_IO_TIMEOUT: IO write/read timeout interrupt</li> <li>LCDC_IT_FRM_START: Frame Start interrupt</li> </ul> </li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 22.5.4.6 LCDC\_Cmd

| Items        | Description                                                                                                                                                           |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the LCDC.                                                                                                                                         |
| Parameters   | <ul style="list-style-type: none"> <li>LCDCx: where LCDCx can be LCDC.</li> <li>NewState: new state of the LCDC. This parameter can be: ENABLE or DISABLE.</li> </ul> |
| Return       | N/A                                                                                                                                                                   |

**Note:** When NewState is DISABLE, during the period of valid line (VTIMING =valid data), the disable action will be performed after the last valid line had transferred. During the other periods, perform the disable action instantly. If disable the LCDC instantly, use the API LCDC\_InsDisable().

#### 22.5.4.7 LCDC\_InsDisable

| Items        | Description                     |
|--------------|---------------------------------|
| Introduction | Disables the LCDC instantly.    |
| Parameters   | LCDCx: where LCDCx can be LCDC. |
| Return       | N/A                             |

#### 22.5.4.8 LCDC\_DelInit

| Items        | Description                     |
|--------------|---------------------------------|
| Introduction | De-initializes the LCDC.        |
| Parameters   | LCDCx: where LCDCx can be LCDC. |
| Return       | N/A                             |

**Note:** Disable LCDC instantly, clear and disable all interrupts.

## 22.6 How to Use LCDC

Table 22-5 lists the typical application scenarios of LCDC.

Table 22-5 Typical application scenario of LCDC

| I/F | Data Mode                     | LCD GRAM | Ameba-D Frame Buffer | Application       |
|-----|-------------------------------|----------|----------------------|-------------------|
| MCU | I/O mode                      | Yes      | No                   | Static Display    |
|     | DMA Trigger-mode              | Yes      | Yes                  | Static Display    |
|     | DMA Auto-mode (VSYNC/TE mode) | Yes      | Yes                  | Animation Display |
| RGB | DMA Auto-mode (DE/HV mode)    | No       | Yes                  | Animation Display |

### 22.6.1 MCU Interface

#### 22.6.1.1 IO Mode

To use the LCDC MCU I/F IO mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 22-4.  
For example, in order to use PA\_19 as LCDC pin, call the following function. And it is the same for other LCDC pins.  
`Pinmux_Config(_PA_19, PINMUX_FUNCTION_LCD);`
- (2) Initialize the LCDC\_MCUInitStruct variable.
  - a) Use the following function to initialize LCDC\_MCUInitStruct variable with default parameters.  
`LCDC_MCUInit(LCDC_MCUInitTypeDef * LCDC_MCUInitStruct);`
  - b) Change other parameters according to LCM datasheet, such as 8-bit or 16-bit I/F mode, Data/WR/RD/CS/RS pulse polarity, WR/RD pulse width etc.
- (3) Initialize the LCDC using the initial structure in step (2).  
`LCDC_MCUInit(LCDC_TypeDef * LCDCx, LCDC_MCUInitTypeDef * LCDC_MCUInitStruct);`
- (4) Enable the LCDC using the function `LCDC_Cmd()`.
- (5) Send commands and parameters to LCM using the function `LCDC_MCUIOWriteCmd()`/`LCDC_MCUIOWriteData()` to initialize the LCD module.
- (6) After LCM is initialized, users can call `LCDC_MCUIOWriteCmd()`/`LCDC_MCUIOWriteData()`/`LCDC_MCUIOReadData()` to send command/write data/read data from LCM to drive LCD displaying.

#### 22.6.1.2 Trigger DMA Mode

To use the LCDC MCU I/F trigger DMA mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 22-4 as mentioned in 22.6.1.1 step (1).
- (2) Configure LCDC to work in MCU IO mode, then send commands and parameters to LCM to initialize LCD as mentioned in 22.6.1.1. After that, users need to send a command to inform LCM to start receiving data before transfer frame data.
- (3) Initialize the LCDC\_MCUIInitStruct variable.
  - a) Configure the LCDC\_MCUIInitStruct parameter to Trigger DMA mode.
 

```
LCDC_MCUIStructInit (LCDC_MCUIInitTypeDef * LCDC_MCUIInitStruct);
LCDC_MCUIInitStruct->LCDC_MCUMode = LCDC_MCU_DMA_MODE;
LCDC_MCUIInitStruct->LCDC_MCUDMAMode = LCDC_TRIGGER_DMA_MODE;
```
  - b) Change other parameters according to LCM datasheet, such as LCD width/height, 8-bit or 16-bit I/F mode, Data/WR/RD/CS/RS pulse polarity, WR/RD pulse width etc.
- (4) Initialize the LCDC using the initial structure in step (3).
 

```
LCDC_MCUIInit (LCDC_TypeDef * LCDCx, LCDC_MCUIInitTypeDef * LCDC_MCUIInitStruct);
```
- (5) Configure the LCDC DMA parameters.
  - a) Configure the LCDC DMA burst size using LCDC\_DMAModeConfig().
  - b) Allocate DMA buffer and assign the address to LCDC using LCDC\_DMALImageBaseAddrConfig().
- (6) Enable LCDC interrupt if needed using LCDC\_INTConfig().
- (7) Enable the LCDC using the function LCDC\_Cmd().
- (8) Trigger one frame transfer using the function LCDC\_MCUDMATrigger() and update the frame buffer to change the display effect.

### 22.6.1.3 VSYNC Mode

To use the LCDC MCU I/F VSYNC mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 22-4 as mentioned in 22.6.1.1 step (1).
- (2) Configure LCDC to work in MCU IO mode as mentioned in 22.6.1.1, send commands and parameters to LCM to make LCD work in VSYNC mode.
- (3) Initialize the LCDC\_MCUIInitStruct variable.
  - a) Configure the LCDC\_MCUIInitStruct parameter corresponding to VSYNC mode.
 

```
LCDC_MCUIStructInit (LCDC_MCUIInitTypeDef * LCDC_MCUIInitStruct);
LCDC_MCUIInitStruct->LCDC_MCUMode = LCDC_MCU_DMA_MODE;
LCDC_MCUIInitStruct->LCDC_MCUDMAMode = LCDC_AUTO_DMA_MODE;
LCDC_MCUIInitStruct->LCDC_MCUSyncMode = LCDC_MCU_SYNC_WITH_VSYNC;
```
  - b) Change other parameters according to LCM datasheet, such as VSYNC pulse polarity/pulse width/idle period, LCD width/height etc.
- (4) Initialize the LCDC using the initial structure in step (3).
 

```
LCDC_MCUIInit (LCDC_TypeDef * LCDCx, LCDC_MCUIInitTypeDef * LCDC_MCUIInitStruct);
```
- (5) Configure the LCDC DMA parameters.
  - a) Configure the LCDC DMA burst size using LCDC\_DMAModeConfig().
  - b) Allocate DMA buffer and assign the address to LCDC using LCDC\_DMALImageBaseAddrConfig().
- (6) Enable the specified LCDC interrupt if needed using LCDC\_INTConfig().
- (7) Enable the LCDC using the function LCDC\_Cmd().
- (8) The LCDC can transfer frame data to LCM automatically synchronized with the VSYNC signal to LCM and you can update the frame buffer to change the display.

### 22.6.1.4 TE Mode

To use the LCDC MCU I/F TE mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 22-4 as mentioned in 22.6.1.1 Step (1).
- (2) Configure LCDC to work in MCU IO mode as mentioned in 22.6.1.1, send commands and parameters to LCM to let LCD working in TE mode.
- (3) Initialize the LCDC\_MCUIInitStruct variable.
  - a) Configure the LCDC\_MCUIInitStruct parameter corresponding to VSYNC mode.
 

```
LCDC_MCUIStructInit (LCDC_MCUIInitTypeDef * LCDC_MCUIInitStruct);
LCDC_MCUIInitStruct->LCDC_MCUMode = LCDC_MCU_DMA_MODE;
LCDC_MCUIInitStruct->LCDC_MCUDMAMode = LCDC_AUTO_DMA_MODE;
LCDC_MCUIInitStruct->LCDC_MCUSyncMode = LCDC_MCU_SYNC_WITH_TE;
```
  - b) Change other parameters if needed, such as TE pulse polarity, TE Delay, LCD width/height etc.
- (4) Initialize the LCDC using the initial structure in step (3).
 

```
LCDC_MCUIInit (LCDC_TypeDef * LCDCx, LCDC_MCUIInitTypeDef * LCDC_MCUIInitStruct);
```
- (5) Configure the LCDC DMA parameters.

- a) Configure the LCDC DMA burst size using LCDC\_DMAModeConfig().
  - b) Allocate DMA buffer and assign the address to LCDC using LCDC\_DMALImageBaseAddrConfig().
- (6) Enable the specified LCDC interrupt if needed using the function LCDC\_INTConfig().
- (7) Enable the LCDC using the function LCDC\_Cmd().
- (8) The LCDC can transfer frame data to LCM automatically synchronized with the TE signal from LCM and you can update the frame buffer to change the display.

## 22.6.2 RGB Interface

### 22.6.2.1 DE Mode

To use the LCDC RGB I/F DE mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 22-4 as mentioned in 22.6.1.1 step (1).
- (2) Configure LCM parameters through SPI or other interfaces if needed.
- (3) Initialize the LCDC\_RGBInitStruct variable.
  - a) Configure the LCDC\_RGBInitStruct parameter corresponding to DE mode.

```
LCDC_RGBStructInit (LCDC_RGBInitTypeDef * LCDC_RGBInitStruct);  
LCDC_RGBInitStruct->LCDC_RGBSyncMode = LCDC_RGB_DE_MODE;
```
  - b) Change other parameters if needed, such as Date/ENABLE/VSYNC/HSYNC pulse polarity, DCLK active edge, VFP, VBP, VSW, HBP, HFP, HSW, refresh frequency, LCD width/height etc.
- (4) Initialize the LCDC using the initial structure in step (3).

```
LCDC_RGBInit (LCDC_TypeDef* LCDCx, LCDC_RGBInitTypeDef* LCDC_RGBInitStruct);
```
- (5) Configure the LCDC DMA parameters.
  - a) Set burst size using the function LCDC\_DMAModeConfig()
  - b) Set DMA FIFO under flow mode and error data using the functions LCDC\_DMAUnderFlowModeConfig() and LCDC\_DMAUnderFlowModeConfig()
  - c) Allocate DMA buffer and assign the address to LCDC using LCDC\_DMALImageBaseAddrConfig().
- (6) Enable the specified LCDC interrupt if needed using the functions LCDC\_INTConfig().
- (7) Enable the LCDC using the function LCDC\_Cmd().
- (8) The LCDC can transfer frame data to LCM automatically according to the refresh frequency and you can update the frame buffer to change the display.

### 22.6.2.2 HV Mode

To use the LCDC RGB I/F HV mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 22-4 as mentioned in 22.6.1.1 step (1).
- (2) Configure LCM parameters through SPI or other interfaces if needed.
- (3) Initialize the LCDC\_RGBInitStruct variable.
  - a) Configure the LCDC\_RGBInitStruct parameter corresponding to HV mode.

```
LCDC_RGBStructInit (LCDC_RGBInitTypeDef * LCDC_RGBInitStruct);
```
  - b) Change other parameters if needed, Date/ENABLE/VSYNC/HSYNC pulse polarity, DCLK active edge, VFP, VBP, VSW, HBP, HFP, HSW, refresh frequency, LCD width/height, 6-bit or 16-bit parallel I/F mode, refresh frequency etc.
- (4) Initialize the LCDC using the initial structure in step (3).

```
LCDC_RGBInit (LCDC_TypeDef* LCDCx, LCDC_RGBInitTypeDef* LCDC_RGBInitStruct)
```
- (5) Configure the LCDC DMA parameters.
  - a) Set burst size using the function LCDC\_DMAModeConfig()
  - b) Set DMA FIFO under flow mode and error data using the functions LCDC\_DMAUnderFlowModeConfig() and LCDC\_DMAUnderFlowModeConfig()
  - c) Allocate DMA buffer and assign the address to LCDC using LCDC\_DMALImageBaseAddrConfig().
- (6) Enable the specified LCDC interrupt if needed using the functions LCDC\_INTConfig()
- (7) Enable the LCDC using the function LCDC\_Cmd().
- (8) The LCDC can transfer frame data to LCM automatically according to the refresh frequency and you can update the frame buffer to change the display.

### 22.6.3 LED I/F

To use the LCDC LED I/F mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 22-4 as mentioned in 22.6.1.1 step (1).
- (2) Initialize the LCDC\_RGBInitStruct variable.
  - a) Configure the LCDC\_LEDInitStruct parameter corresponding to LED I/F mode  
`LCDC_LEDStructInit (LCDC_LEDInitTypeDef * LCDC_LEDInitStruct)`
  - b) Change other parameters if needed, such as color channel, color numbers, timing (latch start time, latch pulse width, OE active width), refresh frequency, LED width/height etc.
- (3) Initialize the LCDC using the initial structure in step (2).  
`LCDC_LEDInit (LCDC_TypeDef* LCDCx, LCDC_LEDInitTypeDef * LCDC_LEDInitStruct)`
- (4) Configure the LCDC DMA parameters
  - a) Set burst size using the function `LCDC_DMAModeConfig()`
  - b) Allocate DMA buffer and assign the address to LCDC using `LCDC_DMAImageBaseAddrConfig()`.
- (5) Enable the specified LCDC interrupt if needed using the functions `LCDC_INTConfig()`.
- (6) Enable the LCDC using the function `LCDC_Cmd()`.
- (7) The LCDC can transfer frame data to LED array board automatically according to the refresh frequency and you can update the frame buffer to change the display.

## 23 Audio Codec Control (ACC) Guide

### 23.1 Audio Codec (AC)

Ameba-D audio codec is often used to play and record audio data. It is a stereo audio codec with stereo headphone amplifiers, as well as 2-way inputs and 1-way stereo/mono output that are programmable to single end or differential.

Ameba-D audio codec integrates anti-pop circuit for audible pop noise cancellation, mic bias circuit for mic power supply and programmable mic boost ability.

Ameba-D audio codec transmits record data to or receives playback data from platform through SPORT interface. By means of specific serial interface (SI), Ameba-D platform configures and drives audio codec.

Ameba-D also provides external I<sup>2</sup>S interface for audio application extension, which supports the highest 384KHz sampling frequency.

#### 23.1.1 Diagram

The diagram of audio codec is shown in Fig 23-1.



Fig 23-1 Audio codec diagram

### 23.1.2 Features

- Support mono and stereo channel
- Support 8bit, 16bit and 24bit sample bits
- Support 8k, 16k, 32k, 48k, 96k, 44.1k, 48k and 88.2k sample rate
- Support I2S, left justify, PCM mode A, PCM mode B, PCM mode A-N and PCM mode B-N data format
- Support anti-pop function to reduce audible pop
- Programmable MIC boost gain
- Programmable gain in ADC and DAC path
- Support three line-out output modes: cap-less, differential and single-end
- Support three input ways: line-in, AMIC-in and DMIC-in

### 23.1.3 Application Mode

Audio codec supports three input ways: line-in, AMIC-in and DMIC-in, but only supports one output way: line out. Line-out supports three output modes: cap-less, differential and single-end. Users may select the wanted mode by setting the related registers.

#### 23.1.3.1 Line-out

Line-out has no amplifier to amplify output voice. It supports cap-less mode, differential mode, single-end mode.

- Line-out cap-less mode

In this mode, the N-end of L/R channel outputs common-level voltage, while P-end drives the available analog audio signal. When earphone inserts into jack, the ground must short with N-end output for audio signal de-couple. That is why the ground be called virtual ground.



Fig 23-2 Cap-less mode connection with headphone jack

- Line-out differential mode

In this mode, both N-end and P-end drive the available analog audio signal. Users should select the differential jack and earphone accordingly.



Fig 23-3 Differential mode connection with headphone jack

- Line-out single-end mode

In this mode, board circuit designers need place a capacitor to the P-end output path for analog audio signal pick-up. And no N-end output is required.



Fig 23-4 Single-end mode connection with headphone jack

### 23.1.3.2 Line-in

Line-in has no preamplifier, its input signal often has large output power. It often connects to the audio output of equipment such as electric guitar, electronic organ and synthesizer.

Connect the Left channel of line-in signal to AUX\_L, and the right channel to AUX\_R accordingly.



Fig 23-5 Line-in mode connection

### 23.1.3.3 AMIC-in

Analog microphone records audio data, it has preamplifier, its input signal often has low output power. AMIC-in support differential mode and single-end mode.

- AMIC-in single-end mode

Connect MIC\_P with single-end analog mic-phone, while MICBIAS provides the mic-phone bias voltage.



Fig 23-6 Analog MIC single-end mode connection

- AMIC-in differential mode

Connect MIC\_P with MIC\_P/MIC\_N with differential analog mic-phone, while MICBIAS provides the mic-phone bias voltage.



Fig 23-7 Analog MIC differential mode connection

### 23.1.3.4 DMIC-in

Digital microphone record audio data, it internal integration with ADC, and can be directly output digital signal.

- DMIC-in mono mode

Tie the L/R of digital mic-phone to ground or VDD if only one digital mic-phone placed.



Fig 23-8 Digital MIC mono mode connection

- DMIC-in stereo mode

Tie the L/R of two digital mic-phones to ground and VDD respectively if stereo mic-phone needed. The two mic-phones will share the DMIC\_DATA according to rising/falling edge.



Fig 23-9 Digital MIC stereo mode connection

## 23.2 Audio Codec Controller (ACC)

Ameba-D audio codec controller is the bridge between host audio buffers and audio codec module. It is used for audio codec input/output control.

Ameba-D audio codec controller uses GDMA to move data, and transfers audio data to or from audio codec module via SPORT, and configure audio codec module via SI.

### 23.2.1 Diagram

The diagram of audio codec controller is shown in Fig 23-10.



Fig 23-10 Audio codec controller diagram

### 23.2.2 Features

- Support mono and stereo channel
- Support 8bit, 16bit and 24bit sample bits
- Support I2S, left justify, PCM mode A, PCM mode B, PCM mode A-N and PCM mode B-N data format
- Support mandatory or optional sample rate which audio codec module declare for support
- Support GDMA for data moving
- Support data loopback between SDI and SDO

### 23.2.3 Control Interface

There are two control interfaces:

- **SPORT interface**  
Audio codec transfers audio data via SPORT interface sequentially according to user setting. It supports multiple data format, such as I2S, left justify, PCM mode A, PCM mode B, PCM mode A-N and PCM mode B-N.
- **SI interface**  
Audio codec needs to configure the related analog and digital parameters before transfer audio data. SI interface is used to configure codec parameters. It can read or write codec register.

For more details about AC and AAC, please reference to UM0400 Ameba-D User Manual.

## 23.3 Audio PLL

The ACC clock architecture is shown in Fig 23-11.



Fig 23-11 ACC clock architecture

CLK\_45P1584 is clock derived from PCM PLL internal, while CLK\_98P304 from I<sup>2</sup>S PLL.

### 23.3.1 Diagram

The ACC clock diagram is illustrated in Fig 23-12.



Fig 23-12 ACC clock diagram

$f_{out}/f_{in} = (\text{div.N} * (2^{16} - ((\text{fo.N} * 2^{13}) + \text{fo.f})) + (\text{div.N} + 1) * ((\text{fo.N} * 2^{13}) + \text{fo.f})) / 2^{16} = \text{div.N} + \text{fo.N} / 2^3 + \text{fo.f} / 2^{16}$ , where  $f_{in}$  is derived from the clock of crystal, while  $\text{div.N}$ ,  $\text{fo.N}$  and  $\text{fo.f}$  from the register settings. Therefore, the resolution of  $f_{out}$  equals to  $f_{in}/2^{16}$ .

The relationship between crystal clock and  $f_{in}$  is listed in Table 23-1.

Table 23-1 Relationship between crystal clock and  $f_{in}$

| Crystal Clock (MHz) | $f_{in}$ (MHz) | Divider |
|---------------------|----------------|---------|
| 40                  | 10             | 4       |
| 25                  | 12.5           | 2       |
| 13                  | 13             | 1       |
| 19.2                | 9.6            | 2       |
| 20                  | 10             | 2       |
| 26                  | 13             | 2       |
| 38.4                | 9.6            | 4       |
| 17.664              | 8.832          | 2       |
| 16                  | 8              | 2       |
| 14.318              | 14.318         | 1       |
| 12                  | 12             | 1       |
| 52                  | 13             | 4       |
| 48                  | 12             | 4       |
| 27                  | 13.5           | 2       |
| 24                  | 12             | 2       |

### 23.3.2 Operation Mode

#### 23.3.2.1 Auto Mode

In auto mode, PLL circuit automatically sets the parameters ( $\text{div.N}$ ,  $\text{fo.N}$ ,  $\text{fo.f}$ , etc.) to output clock with the exact frequency, 196.608MHz (=98.304MHz x2) offered by I<sup>2</sup>S PLL while 180.6336MHz (=45.1584MHz x4) by PCM PLL.

#### 23.3.2.2 Manual Mode

If fine tuning PLL clock is required, users could switch the I<sup>2</sup>S or PCM PLL to manual mode. In this mode, users could control the output frequency of I<sup>2</sup>S PLL max  $\pm$  100ppm around 196.608MHz or PCM PLL max  $\pm$  100ppm around 180.6336MHz by calling the corresponding APIs. As the adjust step of  $f_{out}$  equals to  $f_{in}/2^{16}$ ,  $f_{in}$  decides the exact ppm per step ( $(f_{in}/2^{16})/196.608$  or  $(f_{in}/2^{16})/180.6336$ ).

The relationship between  $f_{in}$  and ppm per step is listed in Table 23-2.

Table 23-2 Relationship between  $f_{in}$  and ppm per step

| $f_{in}$ (MHz) | I <sup>2</sup> S ppm per step | PCM ppm per step |
|----------------|-------------------------------|------------------|
| 10             | 0.78                          | 0.84             |
| 12.5           | 0.97                          | 1.06             |
| 13             | 1.01                          | 1.10             |
| 9.6            | 0.75                          | 0.81             |
| 10             | 0.78                          | 0.84             |
| 13             | 1.01                          | 1.10             |
| 9.6            | 0.75                          | 0.81             |
| 8.832          | 0.69                          | 0.75             |
| 8              | 0.62                          | 0.68             |
| 14.318         | 1.11                          | 1.21             |
| 12             | 0.93                          | 1.01             |
| 13             | 1.01                          | 1.10             |
| 12             | 0.93                          | 1.01             |
| 13.5           | 1.05                          | 1.14             |

|    |      |      |
|----|------|------|
| 12 | 0.93 | 1.01 |
|----|------|------|

## 23.4 Audio Codec APIs

### 23.4.1 PLL APIs

| API               | Introduction                                                                |
|-------------------|-----------------------------------------------------------------------------|
| <PLL_Div>         | Divider to generate 256*fs or 128*fs clock.                                 |
| <PLL_Sel>         | Select I <sup>2</sup> S PLL or PCM PLL                                      |
| <PLL_I2S_Set>     | Enable or disable I <sup>2</sup> S PLL                                      |
| <PLL_PCM_Set>     | Enable or disable PCM PLL                                                   |
| <PLL_I2S_ClkTune> | Tune I <sup>2</sup> S PLL output faster or slower, or reset it to auto mode |
| <PLL_PCM_ClkTune> | Tune PCM PLL output faster or slower, or reset it to auto mode              |

#### 23.4.1.1 PLL\_Div

| Parameter | Type | Introduction                                |
|-----------|------|---------------------------------------------|
| <div>     | u32  | Divider to generate 256*fs or 128*fs clock. |

#### 23.4.1.2 PLL\_Sel

| Parameter | Type | Introduction                                                                      |
|-----------|------|-----------------------------------------------------------------------------------|
| <sel>     | u32  | Select I <sup>2</sup> S PLL if fs=8/16/32/48/96KHz, or PCM PLL if fs=44.1/88.2KHz |

#### 23.4.1.3 PLL\_I2S\_Set

| Parameter   | Type | Introduction                           |
|-------------|------|----------------------------------------|
| <new_state> | u32  | Enable or disable I <sup>2</sup> S PLL |

#### 23.4.1.4 PLL\_PCM\_Set

| Parameter   | Type | Introduction              |
|-------------|------|---------------------------|
| <new_state> | u32  | Enable or disable PCM PLL |

#### 23.4.1.5 PLL\_I2S\_ClkTune

| Parameter | Type | Introduction                            |
|-----------|------|-----------------------------------------|
| <ppm>     | u32  | Required fine tuning ppm value          |
| <action>  | U32  | Faster or slower, or reset to auto mode |

#### 23.4.1.6 PLL\_PCM\_ClkTune

| Parameter | Type | Introduction                            |
|-----------|------|-----------------------------------------|
| <ppm>     | u32  | Required fine tuning ppm value          |
| <action>  | U32  | Faster or slower, or reset to auto mode |

## 23.4.2 SPORT APIs

| API | Introduction |
|-----|--------------|
|-----|--------------|

|                          |                                                                                              |
|--------------------------|----------------------------------------------------------------------------------------------|
| <AUDIO_SP_StructInit>    | Fills each SP_StructInit member with its default value                                       |
| <AUDIO_SP_Init>          | Initializes the AUDIO SPORT registers according to the specified parameters in SP_InitStruct |
| <AUDIO_SP_TxStart>       | Starts or stops SPORT Tx path                                                                |
| <AUDIO_SP_RxStart>       | Starts or stops SPORT Rx path                                                                |
| <AUDIO_SP_TdmaCmd>       | Enables or disables SPORT Tx DMA request                                                     |
| <AUDIO_SP_RdmaCmd>       | Enables or disables SPORT Rx DMA request                                                     |
| <AUDIO_SP_SetWordLen>    | Sets the AUDIO SPORT word length                                                             |
| <AUDIO_SP_GetWordLen>    | Gets the AUDIO SPORT word length                                                             |
| <AUDIO_SP_SetMonoStereo> | Sets the AUDIO SPORT channel number                                                          |
| <AUDIO_SP_TXGDMA_Init>   | Initializes GDMA peripheral for Tx data                                                      |
| <AUDIO_SP_RXGDMA_Init>   | Initializes GDMA peripheral for Rx data                                                      |

### 23.4.2.1 AUDIO\_SP\_StructInit

Fills each SP\_StructInit member with its default value.

| Parameter        | Type            | Introduction                                                                                                  |
|------------------|-----------------|---------------------------------------------------------------------------------------------------------------|
| <SP_InitStruct > | SP_InitTypeDef* | SP_InitTypeDef structure that contains the configuration information for the specified AUDIO SPORT peripheral |

### 23.4.2.2 AUDIO\_SP\_Init

Initializes the AUDIO SPORT registers according to the specified parameters in SP\_InitStruct.

| Parameter        | Type                 | Introduction                                                                                                  |
|------------------|----------------------|---------------------------------------------------------------------------------------------------------------|
| <SPORTx>         | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral                                                                    |
| <SP_InitStruct > | SP_InitTypeDef*      | SP_InitTypeDef structure that contains the configuration information for the specified AUDIO SPORT peripheral |

### 23.4.2.3 AUDIO\_SP\_TxStart

Starts or stops SPORT Tx path.

If play with audio codec, start SPORT Tx path.

| Parameter  | Type                 | Introduction                               |
|------------|----------------------|--------------------------------------------|
| <SPORTx>   | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral |
| <NewState> | u32                  | State (enable or disable) of the SPORT Tx  |

### 23.4.2.4 AUDIO\_SP\_RxStart

Starts or stops SPORT Rx path.

If record with audio codec, start SPORT Rx path.

| Parameter  | Type                 | Introduction                               |
|------------|----------------------|--------------------------------------------|
| <SPORTx>   | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral |
| <NewState> | u32                  | State (enable or disable) of the SPORT Rx  |

### 23.4.2.5 AUDIO\_SP\_TdmaCmd

Enables or disables SPORT Tx dma request.

If Tx DMA request is not enable, then should start Tx when GDMA complete every time.

| Parameter  | Type                 | Introduction                                          |
|------------|----------------------|-------------------------------------------------------|
| <SPORTx>   | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral            |
| <NewState> | u32                  | State (enable or disable) of the SPORT Tx DMA request |

#### 23.4.2.6 AUDIO\_SP\_RdmaCmd

Enables or disables SPORT Rx dma request.

If Rx DMA request is not enable, then should start Rx when GDMA complete every time.

| Parameter  | Type                 | Introduction                                          |
|------------|----------------------|-------------------------------------------------------|
| <SPORTx>   | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral            |
| <NewState> | u32                  | State (enable or disable) of the SPORT Rx DMA request |

#### 23.4.2.7 AUDIO\_SP\_SetWordLen

Sets the AUDIO SPORT word length.

| Parameter    | Type                 | Introduction                               |
|--------------|----------------------|--------------------------------------------|
| <SPORTx>     | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral |
| <SP_WordLen> | u32                  | The value of word length                   |

#### 23.4.2.8 AUDIO\_SP\_GetWordLen

Gets the AUDIO SPORT word length.

| Parameter | Type                 | Introduction                               |
|-----------|----------------------|--------------------------------------------|
| <SPORTx>  | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral |

#### 23.4.2.9 AUDIO\_SP\_SetMonoStereo

Sets the AUDIO SPORT channel number.

SPORT only support stereo channel and mono channel.

| Parameter       | Type                 | Introduction                               |
|-----------------|----------------------|--------------------------------------------|
| <SPORTx>        | AUDIO_SPORT_TypeDef* | The base address of AUDIO SPORT peripheral |
| <SP_MonoStereo> | u32                  | Mono or stereo channel                     |

#### 23.4.2.10 AUDIO\_SP\_TXGDMA\_Init

Initializes GDMA peripheral for sending data.

| Parameter         | Type               | Introduction                                                                                   |
|-------------------|--------------------|------------------------------------------------------------------------------------------------|
| <Index>           | u32                | GDMA index                                                                                     |
| <GDMA_InitStruct> | GDMA_InitTypeDef * | GDMA_InitTypeDef structure that contains the configuration information for the GDMA peripheral |
| <CallbackData>    | void *             | GDMA callback data                                                                             |
| <CallbackFunc>    | IRQ_FUN            | GDMA callback function                                                                         |
| <pTxData>         | u8 *               | Tx Buffer that stores Tx data                                                                  |
| <Length>          | u32                | Tx data length                                                                                 |

### 23.4.2.11 AUDIO\_SP\_RXGDMA\_Init

Initializes GDMA peripheral for receiving data.

| Parameter         | Type               | Introduction                                                                                   |
|-------------------|--------------------|------------------------------------------------------------------------------------------------|
| <Index>           | u32                | GDMA index                                                                                     |
| <GDMA_InitStruct> | GDMA_InitTypeDef * | GDMA_InitTypeDef structure that contains the configuration information for the GDMA peripheral |
| <CallbackData>    | void *             | GDMA callback data                                                                             |
| <CallbackFunc>    | IRQ_FUN            | GDMA callback function                                                                         |
| <pRxData>         | u8 *               | Rx Buffer that stores received data                                                            |
| <Length>          | u32                | Rx data length                                                                                 |

## 23.4.3 SI APIs

SI APIs are used to read and write codec register. They are used in codec APIs.

| API                 | Introduction                                                    |
|---------------------|-----------------------------------------------------------------|
| <AUDIO_SI_Cmd>      | Enables or disables the specified AUDIO SI peripheral           |
| <AUDIO_SI_WriteReg> | SI write codec register                                         |
| <AUDIO_SI_ReadReg>  | SI read codec register                                          |
| <AUDIO_SI_ClkCmd>   | Turns on or turns off the clock of register bank of audio codec |

### 23.4.3.1 AUDIO\_SI\_Cmd

Enables or disables the specified AUDIO SI peripheral.

| Parameter   | Type | Introduction                    |
|-------------|------|---------------------------------|
| <new_state> | u8   | New state of the SIx peripheral |

### 23.4.3.2 AUDIO\_SI\_WriteReg

Use SI interface to write codec register.

| Parameter | Type | Introduction                       |
|-----------|------|------------------------------------|
| <address> | u32  | Codec register address             |
| <data>    | u32  | Data value which write to register |

### 23.4.3.3 AUDIO\_SI\_ReadReg

Use SI interface to read codec register.

| Parameter | Type | Introduction           |
|-----------|------|------------------------|
| <address> | u32  | Codec register address |

### 23.4.3.4 AUDIO\_SI\_ClkCmd

Turns on or turns off the clock of register bank of audio codec.

| Parameter   | Type | Introduction                                           |
|-------------|------|--------------------------------------------------------|
| <new_state> | u8   | New state of the clock of register bank of audio codec |

### 23.4.4 Codec APIs

| API                | Introduction                                               |
|--------------------|------------------------------------------------------------|
| <CODEC_Init>       | Initializes codec peripheral according application mode    |
| <CODEC_SetVolume>  | Sets codec volume by controlling mon DAC channel DVOL gain |
| <CODEC_GetVolume>  | Gets codec mon DAC channel gain control                    |
| <CODEC_SetSr>      | Sets codec ADC and DAC sample rate                         |
| <CODEC_SetAdcGain> | Sets codec ADC gain                                        |
| <CODEC_SetAmicBst> | Set codec AMIC boost                                       |
| <CODEC_SetDmicBst> | Set codec DMIC boost                                       |
| <CODEC_SetMicBias> | Sets MIC_BIAS output voltage                               |
| <CODEC_MuteRecord> | Mute or unmute per AD channel                              |
| <CODEC_MutePlay>   | Mute or unmute per DA channel                              |
| <CODEC_Delinit>    | De-initializes codec peripheral                            |

#### 23.4.4.1 CODEC\_Init

Initializes codec peripheral according application mode.

| Parameter     | Type | Introduction                                              |
|---------------|------|-----------------------------------------------------------|
| <sample_rate> | u32  | Codec ADC and DAC sample rate                             |
| <word_len>    | u32  | Codec data sample bit                                     |
| <mono_stereo> | u32  | Codec mono channel or stereo channel                      |
| <application> | u32  | Codec application mode, such as APP_AMIC_IN, APP_LINE_OUT |

#### 23.4.4.2 CODEC\_SetVolume

Sets codec volume by controlling mon DAC channel DVOL gain.

| Parameter | Type | Introduction                                                                                                                                            |
|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <vol_lch> | u8   | Codec mon DAC left channel DVOL gain control (0.375dB/step) <ul style="list-style-type: none"> <li>● 8'hAF: 0dB</li> <li>● 8'h00: -65.625dB</li> </ul>  |
| <vol_rch> | u8   | Codec mon DAC right channel DVOL gain control (0.375dB/step) <ul style="list-style-type: none"> <li>● 8'hAF: 0dB</li> <li>● 8'h00: -65.625dB</li> </ul> |

#### 23.4.4.3 CODEC\_GetVolume

Gets codec mon DAC channel gain control.

| Parameter | Type  | Introduction                                                                 |
|-----------|-------|------------------------------------------------------------------------------|
| <vol>     | u16 * | Mon DAC channel DVOL gain (high 8 bits is RCH gain, low 8 bits are LCH gain) |

#### 23.4.4.4 CODEC\_SetSr

Sets codec ADC and DAC sample rate.

| Parameter     | Type | Introduction                  |
|---------------|------|-------------------------------|
| <sample_rate> | u32  | Codec ADC and DAC sample rate |

#### 23.4.4.5 CODEC\_SetAdcGain

Sets codec ADC gain.

| Parameter       | Type | Introduction                          |
|-----------------|------|---------------------------------------|
| <ad_gain_left>  | u32  | ADC left channel digital volume gain  |
| <ad_gain_right> | u32  | ADC right channel digital volume gain |

#### 23.4.4.6 CODEC\_SetAmicBst

Set codec AMIC boost.

| Parameter        | Type | Introduction                  |
|------------------|------|-------------------------------|
| <amic_bst_left>  | u32  | AMIC left channel boost gain  |
| <amic_bst_right> | u32  | AMIC right channel boost gain |

#### 23.4.4.7 CODEC\_SetDmicBst

Set codec DMIC boost.

| Parameter        | Type | Introduction                  |
|------------------|------|-------------------------------|
| <dmic_bst_left>  | u32  | DMIC left channel boost gain  |
| <dmic_bst_right> | u32  | DMIC right channel boost gain |

#### 23.4.4.8 CODEC\_SetMicBias

Sets MIC\_BIAS output voltage.

| Parameter  | Type | Introduction                  |
|------------|------|-------------------------------|
| <mic_bias> | u8   | Micphone bias voltage setting |

#### 23.4.4.9 CODEC\_MuteRecord

Mute or unmute per AD channel.

| Parameter   | Type | Introduction                     |
|-------------|------|----------------------------------|
| < mute_lch> | u32  | Mute option for left AD channel  |
| < mute_rch> | u32  | Mute option for right AD channel |

#### 23.4.4.10 CODEC\_MutePlay

Mute or unmute per DA channel.

| Parameter   | Type | Introduction                     |
|-------------|------|----------------------------------|
| < mute_lch> | u32  | Mute option for left DA channel  |
| < mute_rch> | u32  | Mute option for right DA channel |

#### 23.4.4.11 CODEC\_DelInit

De-initializes codec peripheral.

| Parameter | Type | Introduction |
|-----------|------|--------------|
|           |      |              |

|               |     |                        |
|---------------|-----|------------------------|
| <application> | u32 | Codec application mode |
|---------------|-----|------------------------|

## 23.5 How to Use Audio Codec APIs

### 23.5.1 Audio Play Steps

To use audio codec play audio data, please follow the following steps:

Open audio codec clock and function

```
PLLx_Set (0, ENABLE); (x is 0 or 1)  
RCC_PeriphClockCmd (APBPeriph_AUDIOC, APBPeriph_AUDIOC_CLOCK, ENABLE);  
RCC_PeriphClockCmd (APBPeriph_SPORT, APBPeriph_SPORT_CLOCK, ENABLE);
```

Enable pin for audio codec function

```
PAD_CMD (PinName, DISABLE);
```

Initialize codec with desired parameters

```
CODEC_Init (SampleRate, WordLen, MonoStereo, Application);  
Application is APP_LINE_OUT.
```

If need to change codec volume, using

```
CODEC_SetVolume (vol_lch, vol_rch);
```

If want to adjust microphone bias output voltage, using

```
CODEC_SetMicBias (mic_bias);
```

Fill the SPORT desired parameters.

```
AUDIO_SP_InitStruct (&SP_InitStruct);
```

Configure AUDIO SPORT with the corresponding configuration.

```
AUDIO_SP_Init (AUDIO_SP_DEV, &SP_InitStruct);
```

Start Tx path

```
AUDIO_SP_TdmaCmd (AUDIO_SPORT_DEV, ENABLE);
```

```
AUDIO_SP_TxStart (AUDIO_SPORT_DEV, ENABLE);
```

Activate GDMA to Tx data

```
AUDIO_SP_TXGDMA_Init (Index, &GDMA_InitStruct, *CallbackData, CallbackFunc, pTxData, Length);
```

### 23.5.2 Audio Record Steps

To use audio codec record audio data, please follow the following steps:

(3) Open audio codec clock and function

```
PLLx_Set (0, ENABLE); (x is 0 or 1)  
RCC_PeriphClockCmd (APBPeriph_AUDIOC, APBPeriph_AUDIOC_CLOCK, ENABLE);  
RCC_PeriphClockCmd (APBPeriph_SPORT, APBPeriph_SPORT_CLOCK, ENABLE);
```

Enable pin for audio codec function

```
PAD_CMD (PinName, DISABLE);
```

Initialize codec with desired parameters

```
CODEC_Init (SampleRate, WordLen, MonoStereo, Application);
```

Application can select APP\_AMIC\_IN for analog microphone, select APP\_DMIC\_IN for digital microphone, or select APP\_LINE\_IN.

If codec need change volume, using

```
CODEC_SetVolume (vol_lch, vol_rch);
```

If codec need change ADC gain, using

```
CODEC_SetAdcGain (ad_gain_left, ad_gain_right);
```

Fill the desired parameters.

```
AUDIO_SP_InitStruct (&SP_InitStruct);
```

Configure AUDIO SPORT with the corresponding configuration.

```
AUDIO_SP_Init (AUDIO_SP_DEV, &SP_InitStruct);
```

Start Rx path

```
AUDIO_SP_RdmaCmd (AUDIO_SPORT_DEV, ENABLE);
```

```
AUDIO_SP_RxStart (AUDIO_SPORT_DEV, ENABLE);
```

Activate GDMA to Rx data

```
AUDIO_SP_RXGDMA_Init (Index, &GDMA_InitStruct, *CallbackData, CallbackFunc, pRxData, Length);
```

### 23.5.3 Example List

| Example             | location                                                               |
|---------------------|------------------------------------------------------------------------|
| Playback            | /project/realtek_amebaD_cm4_gcc_verification/example_sources/Audio/dac |
| Record and playback | AMIC                                                                   |
|                     | DMIC                                                                   |
| Record and store    | AMIC                                                                   |
| Record and upload   | DMIC                                                                   |
| Decode algorithm    | AC3                                                                    |
|                     | AMR                                                                    |
|                     | FLAC                                                                   |
|                     | Helix AAC                                                              |
|                     | Helix MP3                                                              |
|                     | HLS                                                                    |
|                     | M4A                                                                    |
|                     | M4A self-parse                                                         |
|                     | MP3                                                                    |

## 23.6 Hardware Design Guide

### 23.6.1 Line-out

The Line-out connection of audio codec is illustrated in Fig 23-13. The capacitors between 3.5mm Jack and IC should select 47uF tantalum capacitors rather than ceramic capacitors. The reason is that capacitance value of ceramic capacitors may decrease when bias voltage applied to them, which causes audio performance bad.



Fig 23-13 Line-out connection

### 23.6.2 AMIC-in

The AMIC-in connection of audio codec is illustrated in Fig 23-14. The capacitor between analog mic-phone and IC should select 1uF. Larger capacitance value makes longer period needed for capacitor charging.



Fig 23-14 AMIC-in connection

MIC\_BIAS connects to the positive side of mic-phone through a 2.2Kohm resistor to offer bias voltage.

- Short the negative side of mic-phone to ground if working at single-end mode, or connect to ground through a 2.2Kohm resistor if differential mode.
- Connect the negative side of mic-phone to MIC\_N through a 1uF capacitor if differential mode.

### 23.6.3 Power

The power connection of audio codec is illustrated in Fig 23-15.

- The capacitor between AUDIO\_VREF and ground should select 4.7nF. Larger capacitance value makes longer period needed for AVCC stable.
- The capacitor between AVCC or AVCC\_DRIV and ground should select 1uF or a little bit larger to keep voltage stable.



Fig 23-15 Power connection

## 23.7 Performance of Encoding & Decoding

### 23.7.1 AC3 Format

The performance of decoding AC3 format audio data is listed in Table 23-3. The “Avrg. MCPS measured” is evaluated on the AmebaD\_QFN88\_EVB\_V1, “Avrg. MCPS simulated” and “Max. MCPS simulated” are evaluated with the Keil simulator.

Table 23-3 Performance of decoding AC3 format audio data

| AC Channel | Bit Rate (kHz) | Sample Rate (kHz) | Output Channel | Avrg. MIPS Measured | Avrg. MIPS Simulated | Max. MIPS Simulated |
|------------|----------------|-------------------|----------------|---------------------|----------------------|---------------------|
| 5.1        | 640            | 48                | 1              | 50.5                | 53.7                 | 54.5                |
| 5.1        | 448            | 48                | 1              | 72.2                | 70.8                 | 76.8                |
| 5.1        | 448            | 48                | 1              | 69.9                | 68.2                 | 90.8                |
| 5.1        | 448            | 48                | 1              | 68.7                | 65.9                 | 92.3                |

|     |     |    |   |      |      |      |
|-----|-----|----|---|------|------|------|
| 2.1 | 192 | 48 | 1 | 54.8 | 50.6 | 52.2 |
| 2.0 | 192 | 48 | 1 | TBD  | 50.7 | 49.6 |

### 23.7.2 OPUS Format

The simulated CPU load of encoding and decoding of OPUS audio data is listed in Table 23-4. Keil simulator is used during the whole process.

Table 23-4 Simulated CPU load of encoding and decoding of OPUS audio data

| Rate (kHz) | Channel | Bit Rate (kbps) | Complexity | MIPS (Decoding) | MIPS (Encoding) | Measured Data |
|------------|---------|-----------------|------------|-----------------|-----------------|---------------|
| 48         | 2       | 256             | 10         | 63              | 153.5           | TBD           |
| 48         | 2       | 256             | 3          | 58              | 122.5           |               |
| 48         | 2       | 256             | 0          | 53              | 102             |               |
| 48         | 1       | 256             | 3          | 38              | 74.5            |               |
| 16         | 1       | 48              | 3          | 8.5             | 46.5            |               |
| 16         | 1       | 20              | 3          | 7               | 44.5            |               |

If users decide to use libopus library to deal with their data, the code size requirement is listed in Table 23-5. The version used here is libopus 1.1.4.

Table 23-5 Code size requirement using libopus

| Type                                   | Program Size | Data Size |
|----------------------------------------|--------------|-----------|
| SILK encoder                           | 77.1k        | 8.5k      |
| Original Source Code (Encode + Decode) | 133k         | 23.6k     |

In Table 23-6, CPU load on using Silk encoder is listed.

Table 23-6 CPU load on using Silk encoder

| Test Condition                 | Average CPU Load (MHz) Complexity 3 | Average CPU Load (MHz) Complexity 10 | Remarks  |
|--------------------------------|-------------------------------------|--------------------------------------|----------|
| SILK encoder, 16k, 1ch, 20kbps | 42                                  | 182                                  | SILK VBR |

### 23.7.3 FLAC Format

The simulated (with Keil simulator) and measured CPU loading for decoding FLAC audio data is listed in Table 23-7.

Table 23-7 CPU load of decoding FLAC audio data

| Rate (kHz) | Channel | Word Length | MIPS Simulated | MIPS Measured |
|------------|---------|-------------|----------------|---------------|
| 44.1       | 2       | 16          | 19             | 9.66          |

Tested file lasted for 279.64s, and the decoding time is 13.51s, which means 2.89s decoding time for 1-minute audio data.

### 23.7.4 AAC Format

The measured CPU loading for decoding AAC audio data are listed in Table 23-8.

Table 23-8 CPU load of decoding AAC audio data

| Rate (kHz) | Channel | Bit Rate (kbps) | MIPS  |
|------------|---------|-----------------|-------|
| 48         | 2       | 320             | 28.93 |

Tested file lasted for 24.576s, and the decoding time is 3.55s, which means 8.68s decoding time for 1-minute audio data.

### 23.7.5 MP3 Format

The measured CPU loading for decoding AAC audio data are listed in Table 23-9.

Table 23-9 CPU load of decoding MP3 audio data

| Rate (kHz) | Channel | Bit Rate (kbps) | MIPS  |
|------------|---------|-----------------|-------|
| 32         | 2       | 320             | 30.43 |

Tested file lasted for 5.58s, and the decoding time is 849ms, which means 9.13s decoding time for 1-minute audio data.

## 23.8 Q & A (in English and Chinese)

**Q1:** How to connect the output of DAC to a power amplifier?

**Q1 :** 应该怎样将 DAC 的输出接至功放一侧？

**A1:** In our SDK, the output of DAC is configured as single-end by default. The N end should be left alone. The P-end of L/R should be connected to the amplifier respectively. Choose either the P-end of L or R if only one channel is needed.

- If the power amplifier is an AB type amplifier, refer to the design shown in Fig 23-16 (power amplifier is LM4991).
- If it's a D type amplifier, refer to the design shown in Fig 23-17 (ALC1003).

**A1 :** 在我们的 SDK 中，默认将 DAC 的输出配置为单端输出，所以不需要接 N 端。L/R 的 P 端应该分别接至功放对应的端口。若只需要一路输出，可以选择 L 或 R 任意一路。

- 当您使用 AB 类功放时，请参考 Fig 23-16 设计(功率放大器的型号是 LM4991)。
- 当您使用 D 类功放时，请参考 Fig 23-17 设计(ALC1003)。



Fig 23-16 Reference design of using AB type power amplifier



Fig 23-17 Reference design of using D type power amplifier

**Q2:** What's the difference between a single-end mic input and a differential mic inputs?

**Q2 :** 单端 mic 输入和差分 mic 输入有什么区别 ?

**A2:** The SNR of differential mic input is better than single-end input, but one more pin is needed. Ameba-D supports 2 mics. One supports both single-end input and differential inputs, and another only supports single-end input.

**A2 :** 差分输入的 SNR 比单端输入要好 . 但需要多用一个引脚。Ameba-D 有两个 mic , 其中一个支持单端和差分输入 , 另一个只支持单端输入。

**Q3:** How to play local audio files?

**Q3 :** 如何播放本地音频文件 ?

**A3:** If audio files are stored in SD card, you can use API related to SD card and file system to read and play audio files. If audio files are stored in flash, you need to copy the audio files to SRAM or PSRAM first, then call AUDIO\_SP\_TXGDMA\_Init() to play them. The reason is that flash doesn't support GDMA transfer, but SRAM or PSRAM supports it. Pass address directly to AUDIO\_SP\_TXGDMA\_Init() doesn't work.

**A3 :** 如果音频文件存放在 SD 卡中 . 则调用 SD card 和 file system 的相关 API 进行读取播放。如果音频文件存放在 flash 中 . 则将音频文件拷贝到 SRAM 或 PSRAM 中再调用 AUDIO\_SP\_TXGDMA\_Init() . 而不能直接将文件地址传递给 AUDIO\_SP\_TXGDMA\_Init() 。这是因为 Flash 不支持 GDMA 传输。

# 24 DuerOS

## 24.1 DuerOS Platform

DuerOS is an important application of Baidu artificial intelligence technology. It has huge amounts of data, and can control or communication with the hardware through natural language. DuerOS is widely used in intelligent toys, bluetooth speakers, intelligent household appliances and other equipment.

DuerOS development platform aims to create intelligent terminal era of Artificial Intelligence (AI). Users can use it to build their own exclusive artificial intelligence products.

This section uses story machine as an example.

### 24.1.1 Apply product

DuerOS development platform home page url: <http://open.duer.baidu.com/didp/main/index>.

To apply an own product, please follow the steps:

- (1) Enter DuerOS home page and register as a developer.



Fig 24-1 Register guide

- (2) Configure new device.

- a) After successful registered, click **Configure New Device** and enter the next step.



Fig 24-2 Device control platform

- b) Configure the device as your need, story machine is chosen as an example.



Fig 24-3 Configure new product

- c) Choose FreeRTOS and enter the next step.



Fig 24-4 Choose FreeRTOS

- d) Give the product name and push the **Apply ClientID** button.



Fig 24-5 Apply ClientID

- e) Push the **Light Device Configuration** button.



Fig 24-6 Configure device

After the above steps, story machine product has been created. You can get story machine information through **Product Information** menu, and can customize DuerOS service.

| DuerOS Service List |                  |                    |
|---------------------|------------------|--------------------|
| 儿童故事                | 面向儿童的故事、儿歌等丰富资源  | <a href="#">停用</a> |
| 系统画像                | 自定义产品形象和语音交互问答   | <a href="#">编辑</a> |
| 有声博物馆               | 动物、乐器、大自然等声音的博物馆 | <a href="#">停用</a> |
| 猜谜语                 | 趣味儿童互动游戏——猜谜语    | <a href="#">停用</a> |
| 词语接龙                | 趣味儿童互动游戏——词语接龙   | <a href="#">停用</a> |
| 天气                  | 灵敏、智能的天气机器人      | <a href="#">停用</a> |
| 有声笑话                | 海量有声笑话           | <a href="#">停用</a> |
| 硬件控制                |                  | <a href="#">停用</a> |
| 信息                  | 时间、翻译、百科、问答等通用问题 | <a href="#">停用</a> |
| 音乐 (已停用)            | 百度正版音乐资源         | <a href="#">启用</a> |
| 有声点播 (已停用)          | 娱乐、相声、戏曲及有声节目    | <a href="#">启用</a> |
| 新闻 (已停用)            | 每日实时新闻           | <a href="#">启用</a> |

Fig 24-7 Product center

### 24.1.2 Apply Profile

After product has been applied, get a set of profiles through **Device Development** menu.



Fig 24-8 Get profile

Duer profile contains UUID, Token, server address, port, and root certificate. It is used to establish a TLS connection with the cloud and register to the cloud.

**Note:**

- Every UUID can only be used by one device.
- The profile can't be used directly, because we only support mp3 format now. PM should connect to Baidu to filter the other format for these profiles.

### 24.2 Hardware

- Ameba-D development board

Use AmebaD\_QFN88\_EVB\_V1 and connect as Fig 24-9.

- MicroUSB

MicroUSB is used to provide power for Ameba-D board, and can view serial port log.

- Play equipment

Headset or speaker can be used to play audio data.



Fig 24-9 AmebaD\_QFN88\_EVB\_V1

## 24.3 Software Component

DuerOS software component is shown in Fig 1-1.



Fig 24-10 Softwarecomponent

### 24.3.1 duerapp

| Items   | Description                                                                                                                                                                              |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| include | duerapp header files                                                                                                                                                                     |
| src     | <ul style="list-style-type: none"> <li>public: Ameba-D initializes peripheral: Audio codec, Wi-Fi, OTA ...</li> <li>private: parse play file, record from file, load profile.</li> </ul> |

### 24.3.2 libduer-device

| Items     | Description                                                   |
|-----------|---------------------------------------------------------------|
| external  | DuerOS external library, include mbedtls, speex, zliblite ... |
| framework | Utilities and core.                                           |
| modules   | Modules: OTA, HTTP, dcs, coap ...                             |
| platform  | Connect and communicate with cloud                            |

DuerOS libduer-device consists of three parts: Lightduer, Baidu CA, Speex.

- Lightduer is the interface between DuerOS and external, it communicates with FreeRtos, Lwip, mbedtls.
- Baidu CA is used to connect and communicate with Baidu Cloud.
- Speex is responsible for voice compression.

## 24.4 How to Use

#### **24.4.1 Build and Download**

- ### (1) Modify profile.

As every device should have a unique profile, so we should change the profile for each device. Zip the profile and choose one file to open. Copy the profile to the **component\common\application\baidu\duerapp\src\public\duerapp.c** and modify to the correct format.

```
#define DUER_PROFILE_UUID 1 //Range: 5,6,7,8,9
#ifndef (PROFILE_FROM_SD CARD == 0)
#ifndef (DUER_PROFILE_UUID == 1)

SDRAM_DATA_SECTION static const char duer_profile[] =
{ {"\"configures\":\"{\}\",\"bindToken\":\"9071f6a0954cf17969699c4b83c2437\",\"coapPort\":443,\\"token\": \"hpUun7nsMgKg3Vvi8jC7g89C8jeAq\",\"serverAddr\":\"device.iot.baidu.com\",\"lwm2mPort\":443,\\"uuid\": \"19c80000000001\",\"rsaCaCrt\":\"-----BEGIN CERTIFICATE-----\nMIIDUDCCAJgCCQCmVPUerMyMjANBgkqhkiG9w0BAQFADBQMsQwCQYDVVOGEwJDN\nTjETMBEGA1UECAwKU29tZStDf0ZTEOMAwGA1EUCgwFymPzHUsGDAnBvNgVBA-MM\\n\nDyoua90LmJhaWR1LmNbTecMboGScSib3DQEJARNaW9QQGJhaWR1LmNbTae\\n\\n\nFw8xNjAzMTEWmzMwNDlaFw0yNjAzMDkwMzMwND1aMGoxCzAjBgvNBAYTAKnORMw\\n\\n\nEQYDVQQIDAptb211LVN0YXR1M0QwDAYDVQQKDAViYw1kdTEYMBYGA1UEAwPKi5p\\n\\n\nb3QyUmpZHUu029tMwRkoZiKhvNAQkBFg1p23RAyMfpZhuUy29tMiIBjAN\\n\\n\nBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgkCAQEAtbhieNt\\pnzuMwsLkjQjx2B02+51\\n\\n\nOvCj5d116ZFLjecp9qt11qOfN7bm+Aja5N2aAHJtsetcTHMitY4dtGmOpw4diGqx\\n\\n\nluoz50KwJnojVr+6ZLPnGE4uELOS8vbkHUoYPPQT80<Nvn1959h/17dcjEAjYC\\n\\n\nIYjbf6-K9x+T19VRChwlvvgZQHRYm9jig//CKGMCIwKc6+ihkGD/XG40r7KRCyH\\n\\n\nbd53KnBjB09FH4IL3rG1ZWKwMzCGRTS2+kfEs@tYdVR0Kd4rNs+uD9u9xBLO\\n\\n\ndxT15uxgudH2vNwVtWj090UubtXcQFD2Ihm0120BrcKy1+HEIMR0@DibwIDAQAB\\n\\n\nMA0GCScqSib3DQEBBQUAA4IBAQcZTH91jNh/uYBEfekSVng1h1kPSujlwEDDf\\n\\n\\n\npjapQParZvLw0wcmYs1ybNdy9853887cmJFVESG/v0Y/JvknvRo15gdAenlwQNL4\\n\\n\nh2hf08A5wEQFLO/EaD1GTH30IierKYZ6GItGrz4uFKHV5fTMif1ABCdu37ALGjra\\n\\n\nrijwjxG6Nwlr9468khkrWng3dmBHKw/mq08x42sZOFRZMkqBkZabdiuW4xYSxW\\n\\n\nS1QX56tvRg0A35+4dEg5uLlVN4VVP/Vqh4SmstYkL7ZzIzAx09GtNnhRyFsw1C2r\\n\\n\nOVSdx1sttzExaEBGU17tg8te556BIVufZX+BXGyycVJdbu3\\n\\n\n-----END CERTIFICATE-----\\n\\n\", \"macId\":\"\", \"version\":12237}};

#endif (DUER_PROFILE_UUID == 5)
```

Fig 24-11 Profile in duerapp.c

- (2) Select AMIC or DMIC to record.

Modify macro CONFIG\_DMIC\_SEL in project\realtek\_amebaD\_cm4\_gcc\_verification\inc\platform\_opts.h.

| Items                     | Description        |
|---------------------------|--------------------|
| #define CONFIG_DMIC_SEL 0 | Use AMIC to record |
| #define CONFIG_DMIC_SEL 1 | Use DMIC to record |

- (3) Build project to generate DuerOS image.
  - (4) Use ImageTool to download DuerOS image into Ameba-D platform.

#### **24.4.2 Configure the Network**

After downloading the image successful, reset the Ameba-D board. If it is the first up, it enters the simple configuration mode. Then you can use the simple configuration tools to configure the network. If it is not the first reset, the SSID and password are saved on the flash, it connects to the network automatically.

```

18:09:01.397 Firmware Enable
18:09:01.400 ===>Retention Ram Init
18:09:01.413 Firmware Disable
18:09:01.417 [rltk_wlan_deinit] Wait for RxStop
18:09:01.446 WIFI deinitialized
18:09:01.449 Firmware Enable
18:09:01.451 ===>Retention Ram Init
18:09:01.464 Initializing WIFI ...
18:09:01.479 WIFI initialized
18:09:02.245
18:09:02.249 Switch to channel(2)
18:09:02.432
18:09:02.432 Switch to channel(3)
18:09:02.550
18:09:02.555 Switch to channel(4)
18:09:02.719
18:09:02.719 Switch to channel(5)
18:09:02.854
18:09:02.856 Switch to channel(6)
18:09:03.014
18:09:03.020 Switch to channel(7)
18:09:03.157
18:09:03.166 Switch to channel(8)
18:09:03.317
18:09:03.319 Switch to channel(9)
18:09:03.487
18:09:03.487 Switch to channel(10)
18:09:03.642
18:09:03.642 Switch to channel(11)
18:09:03.749 Input frame da: 01 00 5E 00 00 FB, data length: 39
18:09:03.781

```

Fig 24-12 Simple configuration log

#### 24.4.3 DuerOS Connection Success

After connecting to the network successfully, the device connects to the Baidu Clouds automatically. When printing the log like Fig 24-13, it means DuerOS connection successful.

```

18:38:02.748 duerapp: duer_events_call_internal, handler not initialied...
18:38:02.749 duerapp: duer_engine_start, g_handler:0x10053e00, length:1469, profile:0x10042690
18:38:02.750 duerapp: duer_conf_get_string: uuid = 19c80000000001
18:38:02.751 duerapp: duer_conf_get_string: serverAddr = device.iot.baidu.com
18:38:02.807 duerapp: DNS lookup succeeded. IP:180.97.33.165
18:38:08.612 duerapp: soc:0x100435a8, destroy:1, fd:-1, ref_count:0, timer:0x10043580
18:38:09.136 duerapp: will start latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:09.142 duerapp: duer_engine_start, g_handler:0x10053e00, length:0, profile:0x0
18:38:09.528 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:09.921 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:10.048 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:10.143 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:10.158 duerapp: duer_engine_start, g_handler:0x10053e00, length:0, profile:0x0
18:38:10.367 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:10.130 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:12.164 duerapp: duer_engine_start, g_handler:0x10053e00, length:0, profile:0x0
18:38:16.158 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:16.178 duerapp: duer_engine_start, g_handler:0x10053e00, length:0, profile:0x0
18:38:23.929 duerapp: Will start latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:23.968 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:26.670 duerapp: will_start_latter(DUER_ERR_TRANS_WOULD_BLOCK)
18:38:26.676 duerapp: connect started!
18:38:26.688 duerapp: Mutex initializing
18:38:26.682 duerapp: event: 0
18:38:26.685 duerapp: current vol 10, mute 0
18:38:26.687
18:38:26.689 duerapp: add resource successfully!!
18:38:26.692 duerapp: add resource successfully!!

```

Fig 24-13 DuerOS success log

#### 24.4.4 Triger Record and Speak

(1) GPIOA\_22 pull high to trigger audio codec record.

In driver GPIO\_IRQ\_PIN, set IRQ\_RISE to trigger audio codec record, and GPIO\_IRQ\_PIN is PA\_22, so use GPIOA\_22 to trigger.

(2) Make a voice command.

After GPIOA\_22 pull high, DuerOS would response with 'hello' tone. So after it says 'hello', you can make a voice command such as 'weather', 'sing a song', 'play a joke', 'what's your name' and so on to chat with DuerOS.

```
void init_voice_trigger_irq(void (*callback) (uint32_t id, gpio_irq_event event))
{
    gpio_irq_t voice_irq;
    //init voice trigger pin
    gpio_irq_init(&voice_irq, GPIO IRQ_PIN, callback, NULL);
    gpio_irq_set(&voice_irq, IRQ_RISE, 1);
    gpio_irq_enable(&voice_irq);
}
```

Fig 24-14 Trigger code

## 24.5 OTA Upgrade

### 24.5.1 Generate OTA Image

- (1) Change FIRMWARE\_VERSION in the files: component\common\application\baidu\duerapp\include\duerapp\_ota.h

```
#define FIRMWARE_VERSION "1.0.1.5" //new version, update it when make new version
#define CHIP_VERSION      "RTL8721d"
#define SDK_VERSION        "1.0"
```

Fig 24-15 Firmware version

- (2) Change OTA2 address mapping.

As the size of DuerOS image is more than 1M, there should be at least 4M flash if the OTA is needed. If the flash size is 4M, modify the component\soc\realtek\amebad\fwlib\usrctg\rtl8721d\_bootcfg.c as follows.

```
00038: /* @brief OTA start address. Because KMO & KM4 IMG2 are combined, users only need to set the start address
00039: * of KM0 IMG2.
00040: */
00041: /*
00042: BOOT_RAM_DATA_SECTION
00043: u32 OTA_Region[2] = {
00044:     0x08006000, /* OTA1 region start address */
00045:     0x08206000, /* OTA2 region start address */
00046: };
```

Fig 24-16 OTA Region

- (3) Generate OTA image.

For Ameba-D, km0\_km4\_image2.bin in folder project\realtek\_amebaD\_cm4\_gcc\_verification\asdk\image is the OTA image.

### 24.5.2 OTA with DuerOS Platform

- (1) Add OTA firmware.

Click **Add** button, then fill in the OTA firmware information, such as version, file, file name, and file type.



Fig 24-17 Add OTA firmware

## (2) Enter OTA verify page.

| 版本号     | 创建时间                | 状态  | 操作                                              |
|---------|---------------------|-----|-------------------------------------------------|
| 1.0.2.4 | 2018-12-27 18:19:59 | 未验证 | <a href="#">查看</a> (highlighted with a red box) |
| 1.0.2.3 | 2018-12-27 15:51:27 | 已验证 | <a href="#">查看</a>                              |
| 1.0.2.2 | 2018-12-27 15:43:03 | 未验证 | <a href="#">查看</a>                              |
| 1.0.2.1 | 2018-12-27 14:47:37 | 已验证 | <a href="#">查看</a>                              |
| 1.0.2.0 | 2018-12-27 13:56:47 | 已验证 | <a href="#">查看</a>                              |
| 1.0.1.9 | 2018-12-27 13:43:04 | 已验证 | <a href="#">查看</a>                              |
| 1.0.1.8 | 2018-12-27 12:45:07 | 未验证 | <a href="#">查看</a>                              |
| 1.0.1.7 | 2018-12-27 11:28:45 | 已验证 | <a href="#">查看</a>                              |
| 1.0.1.6 | 2018-12-27 10:58:57 | 未验证 | <a href="#">查看</a>                              |

Fig 24-18 Push check button

## (3) Verify the OTA firmware.



Fig 24-19 Push verify button

(4) Fill in the UUID to show OTA status.



Fig 24-20 Input device profile number and verify

(5) Check whether OTA update succeed or not.

If OTA update succeed, then state upgrade is successful as Fig 24-21. Otherwise, OTA upgrade is failed.



Fig 24-21 OTA update result

### 24.5.3 Attention

- OTA upgrade needs 4M byte flash.
- OTA firmware file name must consistent with the name in duer\_ota\_register\_installer function in duerapp\_ota.c.
- OTA firmware version should be later than the old image.

## 24.6 How to Debug

### 24.6.1 Build Error

If find the following error, you must reduce the heap size in the file **project\realtek\_amebaD\_cm4\_gcc\_verification\inc\FreeRTOSConfig.h**.

```
[cygdrive/d:/iot/ameba-D/DuerOS/Ameba/V02.2018_back/project/realtek_amebaD_cm4_gcc_verification/toolchain/cygwin/asdk-6.1.1/cygwin/newlib/bin/../../lib/gcc/arm-none-eabi/6.4.1/../../../../arm-none-eabi/bin/ld: warning: RDX_WLNS overflowed by 3008 bytes
collect2: error: ld returned 1 exit status
Makefile:223: recipe for target 'linker.image2_ns' failed
make[1]: *** [linker.image2_ns] Error 1
make[1]: Leaving directory '/cygdrive/d:/iot/ameba-D/DuerOS/Ameba/V02.2018_back/project/realtek_amebaD_cm4_gcc_verification/asdk'
Makefile:223: recipe for target 'xip' failed
make: *** [xip] Error 2
```

### 24.6.2 Wi-Fi Signal

Use ATWS command to check the Wi-Fi signal. If the signal is bad, remove the electric resistance shown in Fig 24-22 to check.



Fig 24-22 Electric resistance

### 24.6.3 The Recorder Cannot Be Recognized

(1) Check if the DMIC or AMIC is set correctly.

Check if the jumpers are connected correctly, and the DMIC or AMIC is set correctly.

Open **project\realtek\_amebaD\_cm4\_gcc\_verification\inc\platform\_opts.h** and check the macro **CONFIG\_DMIC\_SEL**.

(2) Check if the network is ok.

```
18:57:25.976 #duerapp:     duer_conf_get_string: serverAddr = device.iot.baidu.com
18:57:30.875 duerapp: DNS failed!!!
18:57:30.879 duerapp: got ip failed!
18:57:30.882 duerapp: duer_coap_connect: transport connect failed by -52
18:57:30.885 duerapp: cached tracecode: 0x12010302
18:57:30.888 duerapp: start fail, status:0, rs:-52
18:57:30.891 duerapp: =====> event: 1[DUER_EVT_START], status: -1
18:57:30.893 duerapp: start fail! status:-1
18:57:30.896 duerapp: Action failed: event: 1, status: -1
18:57:30.900 duerapp: stop timer:0x0
18:57:30.904 duerapp: start last timer:0x0, soc:0x10043580
18:57:30.908 duerapp: no action
18:57:30.912 duerapp: =====> event: 5[DUER_EVT_STOP], status: -1
18:57:30.916 duerapp: connect stopped, status:-1!!
18:57:30.917 duerapp: event: 1
18:57:30.919 duerapp: duer_events_call_internal, handler not initialized...
18:57:30.920 duerapp: duer_events_call_internal, handler not initialized...
18:57:30.921 duerapp: duer_engine_start, g_handler:0x10053e00, length:1469, profile:0x10042690
18:57:30.923 duerapp:     duer_conf_get_string: uid = 19c80000000001
```

Fig 24-23 Network fail log

### 24.6.4 Check the memory

Use any command to check the heap size.

```
18:57:36.170
18:57:36.170 [MEM] After do cmd, available heap 55232
18:57:36.170
18:57:36.170
```

### 24.6.5 Check the Device status

You can see the running log on Baidu cloud.

The screenshot displays two panels from the Ameba-D Application Note interface.

**Product Center / Device Status - AmebaD**

- 设备ID: 19c80000000001
- 首次心跳时间: 2018-12-13 17:41:08
- 最后一次心跳时间: 2018-12-13 18:51:21
- 状态: 在线
- 运行日志: 禁用

**操作:** 搜索, 刷新, 上一个, 下一个, 前五页, 后五页, 全部

**操作日志 / 19c80000000001**

| 操作时间                | 操作                                                                                                           |
|---------------------|--------------------------------------------------------------------------------------------------------------|
| 2018-12-14 09:54:50 | "duer_private": {"message": "ok", "response": {"code": "2.04", "payload": ""}}                               |
| 2018-12-14 09:54:50 | "duer_directive": {"message": "ok", "response": {"code": "2.04", "payload": ""}}                             |
| 2018-12-14 09:54:50 | "duer_directive": {"message": "ok", "response": {"code": "2.04", "payload": ""}}                             |
| 2018-12-14 09:54:50 | "duer_directive": {"message": "ok", "response": {"code": "2.04", "payload": ""}}                             |
| 2018-12-14 09:54:50 | "duer_directive": {"message": "ok", "response": {"code": "2.04", "payload": ""}}                             |
| 2018-12-14 09:54:50 | "duer_event": {"value": "event": [{"payload": {"token": "eyJb3RfaWQjOjIy..."}]}                              |
| 2018-12-14 09:54:50 | "duer_directive": {"message": "ok", "response": {"code": "2.04", "payload": ""}}                             |
| 2018-12-14 09:54:50 | 正在转储 <b>操作日志</b> "value": "[{"path": "http://res..."}]                                                       |
| 2018-12-14 09:54:50 | "duer_directive": {"value": "directive", "directive": {"header": {"namespace": "ai.due..."}, "payload": ""}} |
| 2018-12-14 09:54:50 | "duer_directive": {"value": "directive", "directive": {"header": {"messageId": "YXVka..."}, "payload": ""}}  |

**操作:** 搜索, 刷新, 上一个, 下一个, 前五页, 后五页, 全部

# 25 Infrared Radiation (IR)

Ameba-D Infrared Radiation (IR) provides hardware modulation for Infrared Radiation sending and hardware auto capture for receiving.

In this chapter, we would introduce how to use IR.

## 25.1 Pinmux

The pin assignments of IR are listed in Table 25-1.

Table 25-1 IR pin assignments

| Port Name | Pin Name | QFN48 | QFN68 | QFN88 |
|-----------|----------|-------|-------|-------|
| PA[25]    | IR_TX    | Y     | Y     | Y     |
| PA[26]    | IR_RX    | Y     | Y     | Y     |
| PB[23]    | IR_TX    | N     | Y     | Y     |
| PB[22]    | IR_RX    | N     | Y     | Y     |
| PB[29]    | IR_TX    | N     | Y     | Y     |
| PB[31]    | IR_RX    | N     | Y     | Y     |

## 25.1 Data format

This section introduces the data format of Tx FIFO and Rx FIFO.

### 25.1.1 IR Tx

To send IR data, you should write the data into IR Tx FIFO register, so it's important to understand the data format to be sent to Tx FIFO register. Before sending data, you should convert the data into the appropriate format that Tx FIFO register can recognize. The size of Tx FIFO register is 32 bits, where:

- Bit[31] indicates data type (0: inactive carrier; 1: active carrier).
- Bit[30] is data end flag (0: normal packet; 1: last packet).
- Bit[27:0], represented by cycle, stores the data to be sent and the data format is the number of carrier cycles. Let  $f_{carrier}$  represents the carrier frequency (the unit of  $f_{carrier}$  is KHz),  $T_{duration}$  represents the duration of carrier or no carrier symbol (the unit of  $T_{duration}$  is us). Then,

$$\text{bit}[27:0] = f_{carrier} * T_{duration} / 1000$$

Take NEC protocol for example, the carrier frequency is 38KHz. The format of NEC is shown in Fig 25-1 and the modulation of NEC is shown in Fig 25-2. The NEC format consists of 2 start symbols, 64 data symbols and 1 stop symbol.



Fig 25-1 NEC format



Fig 25-2 NEC modulation

- To send logical “1”, you should write two data into Tx FIFO register.
    - For the first data, bit[31] = 1, bit[30] = 0, bit[27:0] =  $38*560/1000 = 21$ .
    - For the second data, bit[31] = 0, bit[30] = 0, bit[27:0] =  $38*(2250-560)/1000 = 64$ .
  - To send logical “0”, you should write two data into Tx FIFO register.
    - For the first data, bit[31] = 1, bit[30] = 0, bit[27:0] =  $38*560/1000 = 21$ .
    - For the second data, bit[31] = 0, bit[30] = 0, bit[27:0] =  $38*(1120-560)/1000 = 21$ .

At last, you need to send the stop symbol. In this symbol, set bit[30] = 1 because the stop symbol indicates the data end of the current transmission.

## 25.1.2 IR Rx

To receive IR data, you should read the data in Rx FIFO register, so it's important to understand the data format to be received in Rx FIFO register. The size of Rx FIFO register is 32 bits, where:

- Bit[31] indicates data level (0: high level, 1: low level)
  - Bit[30:0] stores the data to be received and the data format is cycle duration. Let  $f_{sampling}$  represents the sampling frequency (the unit of  $f_{sampling}$  is KHz),  $T_{level}$  represents the duration of each high/low level (the unit of  $T_{level}$  is us). Then,

$$T_{level} = \frac{bit[30:0]}{fsampling} * 1000$$

With the use of  $T_{level}$ , you can do further processing to get the information you need.

25.2 APIs

### 25.2.1 IR Setting APIs

### 25.2.1.1 IR StructInit

| Items        | Description                                                                      |
|--------------|----------------------------------------------------------------------------------|
| Introduction | Fills each IR_InitStruct member with its default value.                          |
| Parameters   | IR_InitStruct: pointer to an IR_InitTypeDef structure which will be initialized. |
| Return       | N/A                                                                              |

### 25.2.1.2 IR Init

| Items        | Description                                                                                                                                                                                                                   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the IR peripheral according to the specified parameters in the IR_InitStruct.                                                                                                                                     |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● IR_InitStruct: pointer to a IR_InitTypeDef structure that contains the configuration information for the specified IR peripheral.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                           |

### 25.2.1.3 IR\_Cmd

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the selected IR mode.                                                                                                                                                                                                                                                                                                                                                            |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● mode: selected IR operation mode. This parameter can be the following values: <ul style="list-style-type: none"> <li>■ IR_MODE_TX: Transmission mode.</li> <li>■ IR_MODE_RX: Receiving mode.</li> </ul> </li> <li>● NewState: new state of the operation mode. This parameter can be: ENABLE or DISABLE.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                  |

### 25.2.1.4 IR\_INTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the specified IR interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● IR_INT: specifies the IR interrupt sources to be enabled or disabled. This parameter can be one or combinations of the following values: <ul style="list-style-type: none"> <li>■ IR_TX_FIFO_EMPTY_INT_EN: Tx FIFO empty interrupt.</li> <li>■ IR_TX_FIFO_LEVEL_INT_EN: Tx FIFO threshold interrupt.</li> <li>■ IR_TX_FIFO_OVER_INT_EN: Tx FIFO overflow interrupt.</li> <li>■ IR_RX_FIFO_FULL_INT_EN: Rx FIFO full interrupt.</li> <li>■ IR_RX_FIFO_LEVEL_INT_EN: Rx FIFO threshold interrupt.</li> <li>■ IR_RX_CNT_OF_INT_EN: Rx counter overflow interrupt.</li> <li>■ IR_RX_FIFO_OF_INT_EN: Rx FIFO overflow interrupt.</li> <li>■ IR_RX_CNT THR INT EN: Rx counter threshold interrupt.</li> <li>■ IR_RX_FIFO_ERROR_INT_EN: Rx FIFO error read interrupt. Trigger when Rx FIFO empty and read Rx FIFO.</li> </ul> </li> <li>● NewState: new state of the specified IR interrupts. This parameter can be: ENABLE or DISABLE.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

### 25.2.1.5 IR\_MaskINTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Mask or unmask the specified IR interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● IR_INT: specifies the IR interrupt sources to be mask or unmask. This parameter can be one or combinations of the following values: <ul style="list-style-type: none"> <li>■ IR_TX_FIFO_EMPTY_INT_MASK: Tx FIFO empty interrupt mask.</li> <li>■ IR_TX_FIFO_LEVEL_INT_MASK: Tx FIFO threshold interrupt mask.</li> <li>■ IR_TX_FIFO_OVER_INT_MASK: Tx FIFO overflow interrupt mask.</li> <li>■ IR_RX_FIFO_FULL_INT_Msk: Rx FIFO full interrupt mask.</li> <li>■ IR_RX_FIFO_LEVEL_INT_Msk: Rx FIFO threshold interrupt mask.</li> <li>■ IR_RX_CNT_OF_INT_Msk: Rx counter overflow interrupt mask.</li> <li>■ IR_RX_FIFO_OF_INT_Msk: Rx FIFO overflow interrupt mask.</li> <li>■ IR_RX_CNT THR INT Msk: Rx counter threshold interrupt mask.</li> <li>■ IR_RX_FIFO_ERROR_INT_Msk: Rx FIFO error read interrupt mask. Trigger when Rx FIFO empty and read Rx FIFO.</li> </ul> </li> <li>● NewState: new state of the specified IR interrupts. This parameter can be: ENABLE or DISABLE.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 25.2.1.6 IR\_GetINTStatus

| Items        | Description                            |
|--------------|----------------------------------------|
| Introduction | Get the specified IR interrupt status. |

|            |                                         |
|------------|-----------------------------------------|
| Parameters | IRx: selected IR peripheral.            |
| Return     | The new state of IR_INT (SET or RESET). |

### 25.2.1.7 IR\_GetIMR

| Items        | Description                                  |
|--------------|----------------------------------------------|
| Introduction | Get the specified IR interrupt mask status.  |
| Parameters   | IRx: selected IR peripheral.                 |
| Return       | The new mask state of IR_INT (SET or RESET). |

### 25.2.1.8 IR\_FSMRunning

| Items        | Description                                                                                                   |
|--------------|---------------------------------------------------------------------------------------------------------------|
| Introduction | Get the specified IR FSM status.                                                                              |
| Parameters   | IRx: selected IR peripheral.                                                                                  |
| Return       | The new state of FSM:<br><ul style="list-style-type: none"> <li>● TRUE: RUN</li> <li>● FALSE: IDLE</li> </ul> |

### 25.2.1.9 IR\_ClearINTPendingBit

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clears the IR interrupt pending bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● IR_CLEAR_INT: specifies the interrupt pending bit to clear. This parameter can be any combination of the following values:           <ul style="list-style-type: none"> <li>■ IR_TX_FIFO_EMPTY_INT_CLR: Clear Tx FIFO empty interrupt.</li> <li>■ IR_TX_FIFO_LEVEL_INT_CLR: Clear Tx FIFO threshold interrupt.</li> <li>■ IR_TX_FIFO_OVER_INT_CLR: Clear Tx FIFO overflow interrupt.</li> <li>■ IR_RX_FIFO_FULL_INT_CLR: Clear Rx FIFO full interrupt.</li> <li>■ IR_RX_FIFO_LEVEL_INT_CLR: Clear Rx FIFO threshold interrupt.</li> <li>■ IR_RX_CNT_OF_INT_CLR: Clear Rx counter overflow interrupt.</li> <li>■ IR_RX_FIFO_OF_INT_CLR: Clear Rx FIFO overflow interrupt.</li> <li>■ IR_RX_CNT THR INT CLR: Clear Rx counter threshold interrupt.</li> <li>■ IR_RX_FIFO_ERROR_INT_CLR: Clear Rx FIFO error read interrupt. Trigger when Rx FIFO empty and read Rx FIFO.</li> </ul> </li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

## 25.2.2 IR Tx APIs

### 25.2.2.1 IR\_SendBuf

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Send data buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● pBuf: data buffer to send.</li> <li>● len: buffer length.</li> <li>● IsLastPacket: this parameter can be the following values:           <ul style="list-style-type: none"> <li>■ ENABLE: The last data in IR packet and there is no continuous data. In other words, an infrared data transmission is completed.</li> <li>■ DISABLE: There is data to be transmitted continuously.</li> </ul> </li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**Note:** the difference between IR\_SendBuf() and IR\_SendData() is that IR\_SendBuf() send a data buffer once and the number of sending data is the length of data buffer, while IR\_SendData() only send one data once.

### 25.2.2.2 IR\_SendData

| Items        | Description                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------|
| Introduction | Send one data.                                                                                                  |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● data: data to send.</li> </ul> |
| Return       | N/A                                                                                                             |

### 25.2.2.3 IR\_SetTxThreshold

| Items        | Description                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------|
| Introduction | Set Tx threshold. When Tx FIFO depth <= threshold value, trigger interrupt.                                    |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● thd: Tx threshold.</li> </ul> |
| Return       | N/A                                                                                                            |

### 25.2.2.4 IR\_GetTxFIFOFreeLen

| Items        | Description                  |
|--------------|------------------------------|
| Introduction | Get free size of Tx FIFO.    |
| Parameters   | IRx: selected IR peripheral. |
| Return       | The free size of Tx FIFO.    |

### 25.2.2.5 IR\_ClearTxFIFO

| Items        | Description                  |
|--------------|------------------------------|
| Introduction | Clear IR Tx FIFO.            |
| Parameters   | IRx: selected IR peripheral. |
| Return       | N/A                          |

## 25.2.3 IR Rx APIs

### 25.2.3.1 IR\_ReceiveBuf

| Items        | Description                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Read data from Rx FIFO.                                                                                                                                             |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● pBuf: buffer address to receive data.</li> <li>● len: read data length.</li> </ul> |
| Return       | N/A                                                                                                                                                                 |

**Note:** the difference between IR\_ReceiveBuf() and IR\_ReceiveData() is that IR\_ReceiveBuf() read a data buffer once and the number of receiving data can be defined by users but shouldn't be larger than the data size in Rx FIFO, while IR\_ReceiveData() only read one data once. The data size in Rx FIFO can be required by calling IR\_GetRxDataLen().

### 25.2.3.2 IR\_ReceiveData

| Items | Description |
|-------|-------------|
|       |             |

|              |                               |
|--------------|-------------------------------|
| Introduction | Read one data.                |
| Parameters   | IRx: selected IR peripheral.  |
| Return       | Data which read from Rx FIFO. |

### 25.2.3.3 IR\_SetRxThreshold

| Items        | Description                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------|
| Introduction | Set Rx threshold. When Rx FIFO depth > threshold value, trigger interrupt                                      |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● thd: Rx threshold.</li> </ul> |
| Return       | N/A                                                                                                            |

### 25.2.3.4 IR\_GetRxDataLen

| Items        | Description                   |
|--------------|-------------------------------|
| Introduction | Get data size in Rx FIFO.     |
| Parameters   | IRx: selected IR peripheral.  |
| Return       | Current data size in Rx FIFO. |

### 25.2.3.5 IR\_ClearRxFIFO

| Items        | Description                  |
|--------------|------------------------------|
| Introduction | Clear IR Rx FIFO.            |
| Parameters   | IRx: selected IR peripheral. |
| Return       | N/A                          |

### 25.2.3.6 IR\_SetRxCounterThreshold

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Configure counter threshold value in receiving mode. You can use it to stop receiving IR data.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Parameters   | <ul style="list-style-type: none"> <li>● IRx: selected IR peripheral.</li> <li>● IR_RxCntThrType: This parameter can be the following values:           <ul style="list-style-type: none"> <li>■ IR_RX_Count_Low_Level: Low level counter value &gt;= IR_RxCntThr, trigger IR_INT_RX_CNT_THR interrupt.</li> <li>■ IR_RX_Count_High_Level: High level counter value &gt;= IR_RxCntThr, trigger IR_INT_RX_CNT_THR interrupt.</li> </ul> </li> <li>● IR_RxCntThr: Configure IR Rx counter threshold value which can be 0 to 0xffffffff.</li> </ul> |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 25.2.3.7 IR\_StartManualRxTrigger

| Items        | Description                                |
|--------------|--------------------------------------------|
| Introduction | Start trigger only in manual receive mode. |
| Parameters   | IRx: selected IR peripheral.               |
| Return       | N/A                                        |

**Note:** manual Rx mode is seldom used.

## 25.3 IR Usage

### 25.3.1 Sending Usage

#### 25.3.1.1 Tx Polling Mode

To use IR sending function, the following steps are mandatory.

- (1) Configure the IR pinmux according to Table 22-4.

For example, in order to use PB[23] as IR Tx pin, call the following function. And it is the same for other IR pins.

```
Pinmux_Config(_PB_23, PINMUX_FUNCTION_IR);
```

- (2) Call IR\_Cmd() to disable IR.

- (3) Set parameters, change some parameter if needed.

```
IR_StructInit(IR_InitTypeDef *IR_InitStruct);
```

- (4) Initialize hardware using the parameters in step (3).

```
IR_Init(IR_InitTypeDef *IR_InitStruct);
```

- (5) Write Tx data to FIFO using IR\_SendBuf() or IR\_SendData().

- (6) Call IR\_Cmd() to enable IR to start transmission.

- (7) Write more data to FIFO if needed.

**Note:**

- In step (2) and step (6), It is suggested that disabling IR at first, and then enabling IR after writing data to FIFO.
- In step (5), pay attention to convert the data into the appropriate format that Tx FIFO register can recognized before writing data to FIFO. You can refer to section 25.1.1.

#### 25.3.1.2 Special Notes

##### 25.3.1.2.1 Tx FIFO Offset Issue

If you want to judge whether Tx data in FIFO has been sent completely or not, you'd better check Tx FIFO empty flag rather than TX\_FIFO\_OFFSET.

##### 25.3.1.2.2 Tx Last Packet Cannot Let FSM Enter Idle Issue

If the last packet written to Tx FIFO cannot let Tx state machine enter idle, it is suggested that before enabling IR Tx, writing some data packets to Tx FIFO. You can refer to step (2) and step (6) in section 25.3.1.1.

## 25.3.2 Receiving Usage

#### 25.3.2.1 Rx Interrupt Mode

To use IR receiving function, the following steps are mandatory.

- (1) Configure the IR pinmux according to Table 22-4.

For example, in order to use PB[22] as IR Rx pin, call the following function. And it is the same for other IR pins.

```
Pinmux_Config(_PB_22, PINMUX_FUNCTION_IR);
```

- (2) Set parameters, such as sampling frequency, Rx FIFO threshold level, Rx count threshold type, Rx count threshold level, Rx trigger mode if needed.

```
IR_StructInit(IR_InitTypeDef *IR_InitStruct);
```

- (3) Initialize hardware using the parameters in step (2).

```
IR_Init(IR_InitTypeDef *IR_InitStruct);
```

- (4) Configure interrupt if needed and register interrupt callback function.

```
IR_INTConfig(IR_DEV, IR_RX_INT_ALL_EN, ENABLE);
```

```
InterruptRegister((IRQ_FUN) IR_irq_handler, IR IRQ, (u32)NULL, 10);
```

```
InterruptEn(IR IRQ, 10);
```

- (5) Call IR\_Cmd() to enable IR.

- (6) Clear Rx FIFO by calling IR\_ClearRxFIFO().
- (7) When Rx FIFO threshold interrupt triggers, read data from Rx FIFO with the use of IR\_ReceiveBuf() and IR\_ReceiveData(), and make further processing in interrupt handle function.

**Note:**

- In step (7), to decode the receiving data correctly, you should understand the data format in Rx FIFO register. You can refer to section 25.1.2.
- Waveform inverse issue: in Rx ending, if the waveform is inverse, you should #define INVERSE\_DATA in Ir\_nec\_protocol.h and set IR\_InitStruct.IR\_RxCntThrType = IR\_RX\_COUNT\_HIGH\_LEVEL.

### 25.3.2.2 Rx Learning

The process of Rx learning is similar to common Rx introduced in section 25.3.1.2.1. As shown in Fig 25-3, the difference is that in interrupt handle function, Rx learning should store each pulse of the Rx waveform, while common Rx only needs to store the carrier or un-carrier duration.



Fig 25-3 Difference of waveform between Rx learning and common Rx

**Note:**

- It is advised that putting the interrupt handle function code in RAM, and close other peripheral interrupt to avoid interfere.
- If the carrier frequency of learning waveform is larger than 400KHz, hardware may cannot respond to interrupt in time, which will result in decoding carrier frequency failed.

## 25.4 Compensation Mechanism

Tx waveforms are composed of some carrier symbols and no carrier symbols. Software calculates the duration of certain symbol by application specification (such as NEC). But no carrier symbols cannot be divisible by carrier frequency accurately. If there is no effective compensation mechanism, the error will increase. So Tx compensation is proposed.

Compensation mechanism is used in IR Tx to decrease the error. In most scenarios, it is not necessary to adopt compensation mechanism. Therefore, if you're not interested in compensation mechanism, just skip this section. Next we would introduce the application of compensation mechanism.

### 25.4.1 Tx Compensation Mechanism Application

Take NEC application for example, the Tx NEC waveform is shown in Fig 25-4 with  $f_{carrier} = 38KHz$ , and duty = 1/3. The system clock is 100MHz.



Fig 25-4 Tx NEC waveform

For 38KHz carrier frequency,  $T_{carrier} = \frac{1}{f_{carrier}} = \frac{1}{38K} = 26.31\mu s$ , then  $T_{carrier\_duty} = T_{carrier} * duty = 8.77\mu s$

Compensation frequency  $f_{comp}$  is a dependent clock, you can set  $f_{comp}$  to any value you want. In this example, we set  $f_{comp} = 1MHz$ , so  $T_{comp} = \frac{1}{f_{comp}} = 1\mu s$ .

We divided this waveform into four symbols: 560us carrier symbol, 2250us ~ 560us no carrier symbol, 560us carrier symbol, and 1120us ~ 560us no carrier symbol.

- If no compensation mechanism is adopted, the real wave can be calculated as follows.

For IR\_TX\_COMPENSATION = 0 (IR\_TX\_COMPENSATION is bit[28:29] of IR\_TX\_FIFO register)

- (1) The first carrier symbol: Referring to section 25.1.1, cycle = 21, 560us  $\approx 21*26.31+8.77=561.28\mu s$ .
- (2) The second no carrier symbol: cycle =  $(2250 - 560) * 38/1000=64$ ,  $(2250-560)\mu s = 1690\mu s \approx 64*26.31+(26.31-8.77)=1701.38\mu s$ .
- (3) The third carrier symbol is the same as the first one.
- (4) The forth no carrier symbol: cycle = 21, 560us  $\approx 21*26.31+(26.31-8.77)=570.05\mu s$ .

- If compensation mechanism is adopted, the real wave can be calculated as follows.

For IR\_TX\_COMPENSATION = 3

- (1) The first carrier symbol: Referring to section 25.1.1, cycle = 21, 560us  $\approx 21*26.31+8.77=561.28\mu s$ .
- (2) The second no carrier symbol: cycle =  $(2250 - 560) * 1000/1000=1690$ ,  $(2250-560)\mu s = 1690\mu s = 1690 * 1\mu s$ .
- (3) The third carrier symbol is the same as the first one.
- (4) The forth no carrier symbol: cycle = 560, 560us =  $560 * 1\mu s$ .

Compare the above two calculating methods, we can find that by using compensation mechanism, the accuracy can be improved.

#### Note:

- Compensation mechanism can only be used for no carrier symbol.
- Compensation (IR\_TX\_COMPENSATION = 1) and method 2 (IR\_TX\_COMPENSATION = 2) are not recommended. If you want to use compensation mechanism, refer to method 3 (IR\_TX\_COMPENSATION = 3).

## 25.5 IR Schematic Design Guideline

### 25.5.1 Leakage

To avoid the leakage problem, we suggest using the IR circuit shown in Fig 25-5.



Fig 25-5 Circuit of IR

### 25.5.2 Carrier Problem in Rx Learning

Due to the characteristics of transistor, the response speed will slow down when the transistor works in deep saturation area. Therefore, when carrier frequency is set too large, the hardware has the risk of receiving carrier waveform failed in receiving end. In Rx learning, the maximum carrier frequency that can achieve is related to Rx circuit and the choice of transistor. The circuit we suggested in section 25.5.1 can support the maximum carrier frequency 70KHz, but you can choose the better transistor to acquire higher supported carrier frequency.

## 26 Brownout Detector (BOD)

Brownout Detector (BOD) is mainly used to notify a user that the voltage level is low for the applications which use batteries. Ameba-D provides many thresholds to choose, the alternative levels and corresponding voltage values are shown in Table 26-1 and Table 26-2.

Table 26-1 The high threshold of interrupt mode and reset mode (3.3V/1.8V)

| Voltage | Value | Symbol       | Reset (V) | Interrupt (V) |
|---------|-------|--------------|-----------|---------------|
| 3.3V    | 001   | BOR_TH_HIGH1 | 1.887     | 2.297         |
|         | 010   | BOR_TH_HIGH2 | 1.970     | 2.397         |
|         | 011   | BOR_TH_HIGH3 | 2.061     | 2.507         |
|         | 100   | BOR_TH_HIGH4 | 2.139     | 2.602         |
|         | 101   | BOR_TH_HIGH5 | 2.224     | 2.704         |
|         | 110   | BOR_TH_HIGH6 | 2.315     | 2.815         |
|         | 111   | BOR_TH_HIGH7 | 2.388     | 2.904         |
| 1.8V    | 001   | BOR_TH_HIGH1 | 1.422     | 1.498         |
|         | 010   | BOR_TH_HIGH2 | 1.480     | 1.560         |
|         | 011   | BOR_TH_HIGH3 | 1.543     | 1.627         |
|         | 100   | BOR_TH_HIGH4 | 1.598     | 1.684         |
|         | 101   | BOR_TH_HIGH5 | 1.656     | 1.746         |
|         | 110   | BOR_TH_HIGH6 | 1.719     | 1.812         |
|         | 111   | BOR_TH_HIGH7 | 1.770     | 1.865         |

Table 26-2 The low threshold of interrupt mode and reset mode (3.3V/1.8V)

| Voltage | Value | Symbol      | Reset (V) | Interrupt (V) |
|---------|-------|-------------|-----------|---------------|
| 3.3V    | 001   | BOR_TH_LOW1 | 1.784     | 2.194         |
|         | 010   | BOR_TH_LOW2 | 1.863     | 2.290         |
|         | 011   | BOR_TH_LOW3 | 1.949     | 2.395         |
|         | 100   | BOR_TH_LOW4 | 2.023     | 2.486         |
|         | 101   | BOR_TH_LOW5 | 2.103     | 2.584         |
|         | 110   | BOR_TH_LOW6 | 2.190     | 2.690         |
|         | 111   | BOR_TH_LOW7 | 2.260     | 2.775         |
| 1.8V    | 001   | BOR_TH_LOW1 | 1.345     | 1.422         |
|         | 010   | BOR_TH_LOW2 | 1.400     | 1.480         |
|         | 011   | BOR_TH_LOW3 | 1.460     | 1.543         |
|         | 100   | BOR_TH_LOW4 | 1.512     | 1.598         |
|         | 101   | BOR_TH_LOW5 | 1.567     | 1.656         |
|         | 110   | BOR_TH_LOW6 | 1.627     | 1.719         |
|         | 111   | BOR_TH_LOW7 | 1.674     | 1.770         |

Note: The voltage value may have  $\pm 5\%$  error.

### 26.1 Recommended Threshold Parameter

The recommended threshold parameters are shown in Table 26-3.

Table 26-3 Recommended Threshold Parameter

| Work Voltage | Reset          |               | Interrupt      |               |
|--------------|----------------|---------------|----------------|---------------|
|              | High Threshold | Low Threshold | High Threshold | Low Threshold |
| 3.3V         | BOR_TH_HIGH7   | BOR_TH_LOW6   | BOR_TH_HIGH7   | BOR_TH_LOW6   |
| 1.8V         | BOR_TH_HIGH5   | BOR_TH_LOW3   | BOR_TH_HIGH5   | BOR_TH_LOW3   |

**Note:** To avoid voltage fluctuation during work trigger BOD interrupt or reset by mistake, the difference between high and low threshold can be appropriately increased.

## 26.2 BOD APIs

### 26.2.1 BOR\_ModeSet

| Items        | Description                                                                                                                                                                                                                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Chooses BOD mode and enable BOD function                                                                                                                                                                                                                                                                    |
| Parameters   | <ul style="list-style-type: none"> <li>● Option:           <ul style="list-style-type: none"> <li>■ BOR_RESET: BOD reset mode</li> <li>■ BOR_INTR: BOD interrupt mode</li> </ul> </li> <li>● NewStatus:           <ul style="list-style-type: none"> <li>■ ENABLE</li> <li>■ DISABLE</li> </ul> </li> </ul> |
| Return       | Null                                                                                                                                                                                                                                                                                                        |

### 26.2.2 BOR\_ThresholdSet

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Sets BOD high and low thresholds                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Parameters   | <ul style="list-style-type: none"> <li>● Thres_Low: BOD low threshold           <ul style="list-style-type: none"> <li>■ BOR_TH_LOW1</li> <li>■ BOR_TH_LOW2</li> <li>■ BOR_TH_LOW3</li> <li>■ BOR_TH_LOW4</li> <li>■ BOR_TH_LOW5</li> <li>■ BOR_TH_LOW6</li> <li>■ BOR_TH_LOW7</li> </ul> </li> <li>● Thres_High: BOD high threshold           <ul style="list-style-type: none"> <li>■ BOR_TH_HIGH1</li> <li>■ BOR_TH_HIGH2</li> <li>■ BOR_TH_HIGH3</li> <li>■ BOR_TH_HIGH4</li> <li>■ BOR_TH_HIGH5</li> <li>■ BOR_TH_HIGH6</li> <li>■ BOR_TH_HIGH7</li> </ul> </li> </ul> |
| Return       | Null                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 26.2.3 BOR\_ClearINT

| Items        | Description           |
|--------------|-----------------------|
| Introduction | Clears BOD interrupt. |
| Parameters   | Null                  |
| Return       | Null                  |

### 26.2.4 BOR\_DbncSet

| Items        | Description                                                                              |
|--------------|------------------------------------------------------------------------------------------|
| Introduction | Sets BOD interrupt mode debounce cycle                                                   |
| Parameters   | Option: <ul style="list-style-type: none"> <li>● BOR_INTR: BOD interrupt mode</li> </ul> |

|        |                                                              |
|--------|--------------------------------------------------------------|
|        | ● Dbnc_Value: debounce cycle, in unit of ANA4M clock cycles. |
| Return | Null                                                         |

**Note:** Only BOD interrupt mode can set debounce cycle.

Realtek Confidential files  
The document authorized to  
B&T  
2019-05-16 11:47:20

# 27 Flash Translation Layer (FTL)

## 27.1 Overview

NOR-Flash is comprised of blocks, which contains pages, and they contain individual cells of data. Flash read/write operations take place at page level. But erase operations take place at the block level. The flash needs to be erased before write. The memory portion for erasing differs in size from that for reading or writing, resulting in the major performance degradation of the overall flash memory system.

Therefore, a type of system software termed FTL (Flash Translation Layer) has been introduced, which is provided to make the flash a friendly medium to store data.



Fig 27-1 Architecture of flash memory system

The FTL algorithm provides the following functionalities:

- **Logical-to-physical address mapping**: Convert logical addresses from the file system to physical addresses in flash memory.
- **Power-off recovery**: Even when a sudden power-off event occurs during FTL operations, FTL data structures should be preserved and data consistency should be guaranteed.
- **Wear-leveling**: Wear down memory blocks as evenly as possible.

To write data to logical map, FTL would generate a data packet in specified format and store it in flash. To modify data in logical map, a new packet would be generated and appended to the end of physical map. When the physical pages are nearly full, the garbage collection is triggered to recycle the old pages which would be erased.

To read data from logical map, FTL would search the physical map to find the newest packet, which contains the data of specified address.

When using FTL, users don't need to care about physical map, which is maintained automatically by FTL.



Fig 27-2 FTL overview

## 27.2 Features

- Physical Map
  - Physical Page size: 4096 bytes
  - Configurable physical page number
  - Physical map size = 4096 \* physical page number
- Logical Map
  - The maximum logical map size is determined by physical map size: ((511 \* (physical page number -1))-1) \* 4
- Auto Garbage Collection
- Abnormal Power-off Protection

## 27.3 FTL APIs

| API                     | Introduction                                    |
|-------------------------|-------------------------------------------------|
| <ftl_init>              | Initializes FTL                                 |
| <ftl_load_from_storage> | Gets specified length of data from logical map. |
| <ftl_save_to_storage>   | Writes specified length of data to logical map. |

### 27.3.1 ftl\_init

| Items        | Description                                                                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes FTL                                                                                                                                         |
| Parameters   | <ul style="list-style-type: none"> <li>u32PageStartAddr: The start address of physical map</li> <li>pagenum: The page number of physical map</li> </ul> |
| Return       | N/A                                                                                                                                                     |

### 27.3.2 ftl\_load\_from\_storage

| Items        | Description                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------|
| Introduction | Gets specified length of data from logical map.                                                       |
| Parameters   | <ul style="list-style-type: none"> <li>pdata_tmp: Pointer to a buffer to save logical data</li> </ul> |

|        |                                                                                                                                                     |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|        | <ul style="list-style-type: none"> <li>● offset: From which address to read the logical map</li> <li>● size: The number of bytes to read</li> </ul> |
| Return | <ul style="list-style-type: none"> <li>● 0: Get logical map values successfully</li> <li>● Others: Fail to get logical map value</li> </ul>         |

### 27.3.3 ftl\_save\_to\_storage

| Items        | Description                                                                                                                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Writes specified length of data to logical map.                                                                                                                                                                         |
| Parameters   | <ul style="list-style-type: none"> <li>● pdata_tmp: Pointer to byte array of new logical data</li> <li>● offset: From which address to update the logical map</li> <li>● size: The number of bytes to update</li> </ul> |
| Return       | <ul style="list-style-type: none"> <li>● 0: Write logical map values successfully</li> <li>● Others: Fail to write logical map value</li> </ul>                                                                         |

## 27.4 How to Use FTL

To use FTL in Ameba-D, the following steps are necessary:

- (1) Define the following macro in **autoconf.h**, and the FTL initialization will be contained in main.

```
#define CONFIG_FTL_ENABLED 1
```

If Bluetooth is enabled in your system, **CONFIG\_FTL\_ENABLED** is defined automatically after define **CONFIG\_BT\_EN**.

- (2) The default configurations for logical & physical map is as following:

- a) 3 pages allocated for physical map: 0x0810\_2000~0x0810\_4FFF
- b) logical map size: 4084 bytes

**Note:** If the memory layout is modified and overwrites FTL area 0x0810\_2000~0x0810\_4FFF, users need to modify the physical page address and define **FTL\_MEM\_CUSTEM** to 1 in **rtl8721dhp\_intfcfg.c** as following:

```
62: #if defined(CONFIG_FTL_ENABLED)
63: #define FTL_MEM_CUSTEM 1
64: #if FTL_MEM_CUSTEM == 0
65: #error "You should allocate flash sectors to for FTL physical map as following, then set FTL_MEM_CUSTEM to 1. For more information, Please refer to Application Note, FTL chapter."
66: #else
67: const u8 ftl_phy_page_num = 3;
68: const u32 ftl_phy_page_start_addr = 0x00102000; /* The number of physical map pages, default is 3*/
69: /* The start offset of flash pages which is allocated to FTL physical map.
   Users should modify it according to their own memory layout! */
70: #endif
71: #endif
```

Otherwise, an error would be thrown out to remind users to modify FTL start address as following. If no other region overlay with FTL area, only need to define **FTL\_MEM\_CUSTEM** to 1.

```
-o rtl8721dhp_intfcfg.o
/cygdrive/e/AmebaD/AmebaD_svn/project/realtek_amebaD_cm4_gcc_verification/asdk/../../../../component/soc/realtek/amebad/fwlib/usrcfg/rtl8721dhp_intfcfg.c:64:2: error: #error "You shou
ld allocate Flash sectors to for FTL physical map as following, then set FTL_MEM_CUSTEM to 1. For more information, Please refer to Application Note, FTL chapter."
#error "You should allocate Flash sectors to for FTL physical map as following, then set FTL_MEM_CUSTEM to 1. For more information, Please refer to Application Note, FTL chapter."
^
make[4]: *** [/cygdrive/e/AmebaD/AmebaD_svn/project/realtek_amebaD_cm4_gcc_verification/asdk/Makefile.inclues.gd:449: rtl8721dhp_intfcfg.o] Error 1
make[4]: Leaving directory '/cygdrive/e/AmebaD/AmebaD_svn/project/realtek_amebaD_cm4_gcc_verification/asdk'
make[3]: *** [Makefile:19: all] Error 2
```

- (3) Call **ftl\_load\_from\_storage**/**ftl\_save\_to\_storage** functions to read from/write to logical map.

# 28 Audio Signal Generation and Analysis

## 28.1 Introduction

When developing digital mic (DMIC) related applications, you may need to generate a signal of a certain frequency to test whether your DMIC works well or not. In this application note, we first introduce how to generate a signal and how to analyze the frequency of a signal collecting by the DMIC. Then, digital analog – analog digital (DAAD) loopback is explained. DAAD loopback is helpful in determining which part (codec or DMIC) doesn't work well when problems occur.

### 28.1.1 Compilation

You need to add the `example_audio_signal_generate.c` to your project before you can use all the commands mentioned in this AN. Related File used are placed under the path: `/component/common/example/audio_sport/audio_signal_generate`.

The following steps should be followed:

- (1) Set the macro named "AUDIO\_SIGNAL\_GENERATE" to 1 in `platform_opts.h` under the path:  
`/project/realtek_amebaD_cm4_gcc_verification/inc`.
- (2) Uncomment the following line in the makefile under the path: `/project/realtek_amebaD_cm4_gcc_verification/asdk/make`.  
`@make -C cmsis-dsp all`
- (3) Uncomment the following line in the makefile under the path:  
`/project/realtek_amebaD_cm4_gcc_verification/asdk/make/utilities_example`  
`CSRC += $(DIR)/audio_sport/audio_signal_generate/example_audio_signal_generate.c`
- (4) Add rule "make -C amr all" under "all: CORE\_TARGETS" in the makefile under the path:  
`/project/realtek_amebaD_cm4_gcc_verification/asdk/make/audio`.

### 28.1.2 Generating a Signal of a Certain Frequency

Frequencies of signals supported by the program range from 20~20000Hz, which is the frequency range that people can hear.

Type command "Audio\_generate tone spkr (f)" to generate a signal whose frequency is equal to  $f$  ( $20 < f < 20000$ ).

### 28.1.3 Analyzing Signals Collected by DMIC

One way of testing a DMIC is to analyze the signals collected by the DMIC in frequency domain. If the detected frequency is the same as the frequency of the signal, the DMIC works well.

Type command "Audio\_generate dmic fft 1" to analyze the signal collected by DMIC in frequency domain. The main frequency and its relative strength are printed out. Due to frequency leaks, the frequency detected may not be the same as the one you play, but the number should be closed. You can use this command to analyze signals whose frequencies range from 20~20000Hz.

### 28.1.4 DAAD

DMIC related problems can be caused by internal codec or DMIC itself. In this part, we will explain how to use DAAD loopback to determine whether the internal codec works in a normal way or not.

Fig 28-1 depicts how DAAD loopback works. The data transmitted from DA Digital IP is received directly by AD Digital IP without the interference of DMIC.



Fig 28-1 Illustration of DAAD loopback

Type command "Audio\_generate daad fft (f)" to generate a signal whose frequency is  $f$ . The main frequency detected and relative strength calculated will be printed out. If the frequency detected is closed to the one you generate, it means that the internal codec works well. The problem may be caused by DMIC.

### 28.1.5 Command

All the commands that can be used are listed in Table 28-1. Each command is composed of several parameters, and the parameter which are surrounded by () should be set by users.

Table 28-1 Available commands in audio signal generation and analysis

| Command Format               | Command Function                        | Example                       |
|------------------------------|-----------------------------------------|-------------------------------|
| Audio_generate tone spkr (f) | Generates a tone whose frequency is $f$ | Audio_generate tone spkr 1000 |
| Audio_generate dmic fft 1    | Analyzes the signal collected by DMIC   | Audio_generate dmic fft 1     |
| Audio_generate daad fft (f)  | DAAD loopback analysis                  | Audio_generate daad fft 1000  |
| Audio_generate stop          | Stops audio test                        | Audio_generate stop           |

# Revision History

| Date       | Version | Change                                                                                                                                                                                                                                                            |
|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2019-04-10 | v09     | Add the following chapters: <ul style="list-style-type: none"><li>● GCC Standard Library</li><li>● IAR Build Environment Setup</li><li>● Brownout Detector (BOD)</li><li>● Flash Translation Layer (FTL)</li><li>● Audio Signal Generation and Analysis</li></ul> |
| 2019-02-21 | v08     | Add Q&A list in GCC and Audio Codec                                                                                                                                                                                                                               |
| 2019-01-10 | v07     | <ul style="list-style-type: none"><li>● Add IR application note</li><li>● Add more detailed description of flash classification in User Configuration</li><li>● Add Performance of Encoding and Decoding in Audio Codec</li></ul>                                 |
| 2018-12-29 | v06     | Add more information about different IP                                                                                                                                                                                                                           |
| 2018-11-07 | v05     | Change format                                                                                                                                                                                                                                                     |
| 2018-07-03 | v04     | Update system architecture                                                                                                                                                                                                                                        |
| 2018-06-28 | v02     | Change format                                                                                                                                                                                                                                                     |
| 2018-06-15 | v01     | The draft                                                                                                                                                                                                                                                         |