

# AN0400

## Ameba-D Application Note

---

## COPYRIGHT

© 201 Realtek Semiconductor Corp. All rights reserved. No part of this document may be reproduced, transmitted, transcribed, stored in 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. You should obtain the latest relevant information before placing orders and should verify that such information is current and complete.

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

Buyers and others who are developing systems that incorporate Realtek products remain responsible for using their independent analysis and judgment in designing their applications and that Customers have full and exclusive responsibility to assure the safety of their 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, he 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 cause harm and take appropriate actions. Customer agrees that prior to using or distributing any applications that incorporate Realtek products, Customer will thoroughly test such applications and the functionality of Realtek products as used in such applications.

Realtek's provision of technical, application or other design advice, quality characterization, reliability data or root cause information, including, but not limited to, reference designs and materials relating to its evaluation, assist designers who are developing applications that incorporate Realtek products, by downloading, passing or using Realtek Resources in any way. Customer (individually or, if Customer is acting on behalf of a company, the company) agrees to use any part of 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 Realtek's applicable published warranty disclaimer, including, but not limited to, reference designs and materials relating to its evaluation, assist designers who are developing applications that incorporate Realtek products, by downloading, passing or using Realtek Resources in any way. Customer (individually or, if Customer is acting on behalf of a company, the company) agrees to use any part of Realtek Resources solely for this purpose and subject to the terms of this Notice.

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, estoppel or otherwise to any other Realtek intellectual property right, and no license to any technology or intellectual property right of Realtek is granted herein, including but not limited to any patent right, copyright, trademark, 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 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 rights of the third party or a license from Realtek under the patents or other Realtek intellectual property rights.

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, epidemic failure warranty and any implied warranties of merchantability, fitness for a particular purpose, and freedom of any third party intellectual property rights.

Realtek shall not be liable for and shall not defend or indemnify 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. Realtek is not liable for any actual, direct, special, collateral, indirect, punitive, incidental, consequential or exemplary damages in connection with or arising out of Realtek 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, 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. Customers shall ensure compliance with safety-related requirements and standards applicable to their applications. Designer may use Realtek products in life-critical medical equipment unless authorized officers of the parties have executed a special contract specifically for medical equipment. Such equipment is medical equipment where failure of such equipment would cause serious bodily injury or death. Such equipment includes, without limitation, medical devices identified by the FDA as Class III devices and equivalent classifications outside the U.S.

Customer agree that it has the necessary expertise to select the product with the appropriate qualification designations for their application and that proper product selection is at Customer's 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 - 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 or 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 publication of this guide.

# Contents

|                                                   |           |
|---------------------------------------------------|-----------|
| Contents.....                                     | 4         |
| Convention.....                                   | 14        |
| <b>1 Building Environment.....</b>                | <b>15</b> |
| 1.1 Introduction.....                             | 15        |
| 1.2 PreparingGCC Environment.....                 | 15        |
| 1.2.1 Windows.....                                | 15        |
| 1.2.2 Linux.....                                  | 16        |
| 1.3 Building Code.....                            | 17        |
| 1.3.1 Normal Image.....                           | 17        |
| 1.3.2 MP Image.....                               | 19        |
| 1.4 Setting Debugger.....                         | 19        |
| 1.4.1 Probe.....                                  | 19        |
| 1.4.2 J-Link.....                                 | 24        |
| 1.5 DownloadingImage to Flash.....                | 29        |
| 1.6 Entering Debug Mode.....                      | 29        |
| 1.7 Command List.....                             | 30        |
| 1.8 GDB Debugger Basic Usage.....                 | 31        |
| 1.9 Q & A.....                                    | 31        |
| 1.9.1 - .....#.....                               | 31        |
| 1.9.2 h .....Q.....                               | 32        |
| 1.9.3 How to Reset KMO/KM4 under Debug Mode?..... | 32        |
| <b>2 SDK Architecture.....</b>                    | <b>34</b> |
| 2.1 component.....                                | 34        |
| 2.1.1 common.....                                 | 34        |
| 2.1.2 os.....                                     | 35        |
| 2.1.3 soc.....                                    | 35        |
| 2.2 doc.....                                      | 35        |
| 2.3 tools.....                                    | 35        |
| 2.4 GCC Project for KM4.....                      | 36        |
| 2.5 Critical Header Files.....                    | 36        |
| <b>3 GCC Makefile.....</b>                        | <b>37</b> |
| 3.1 KM4 Makefile Architecture.....                | 37        |
| 3.2 How to Build Code into Flash?.....            | 37        |
| 3.3 How to Build Code into SRAM?.....             | 38        |
| 3.4 How to Use Section Attribute?.....            | 39        |
| 3.5 How to Build Library?.....                    | 40        |
| 3.6 How to Add Library?.....                      | 41        |
| <b>4 C++Standard\$Supported in GCC.....</b>       | <b>42</b> |
| 4.1 Introduction.....                             | 42        |
| 4.2 To Compile C++ Codes.....                     | 42        |
| <b>5 GCCStandard Library.....</b>                 | <b>44</b> |

|       |                                                           |    |
|-------|-----------------------------------------------------------|----|
| 5.1   | Introduction.....                                         | 44 |
| 5.2   | Default Use of Library Function.....                      | 44 |
| 5.3   | To Use Configurable Function in GCC Standard Library..... | 45 |
| 5.4   | Tips.....                                                 | 46 |
| 6     | IAR Build Environment Setup.....                          | 47 |
| 6.1   | Requirement.....                                          | 47 |
| 6.1.1 | <i>IAR Embedded Workbench</i> .....                       | 47 |
| 6.1.2 | <i>J-Link or RLX Probe</i> .....                          | 47 |
| 6.2   | Hardware Configuration.....                               | 47 |
| 6.2.1 | <i>Connecting with J-Link</i> .....                       | 48 |
| 6.2.2 | <i>Connecting with RLX Probe</i> .....                    | 49 |
| 6.3   | How to Use IAR SDK.....                                   | 50 |
| 6.3.1 | <i>IAR Project Introduction</i> .....                     | 50 |
| 6.3.2 | <i>IAR Build</i> .....                                    | 51 |
| 6.3.3 | <i>IAR Download</i> .....                                 | 55 |
| 6.3.4 | <i>IAR Debug</i> .....                                    | 60 |
| 6.3.5 | <i>IAR Memory Configuration</i> .....                     | 65 |
| 6.4   | How to Build Sample Code?.....                            | 66 |
| 6.5   | Used Memory Size Calculation.....                         | 67 |
| 6.5.1 | <i>Memory Section</i> .....                               | 67 |
| 6.5.2 | <i>Memory Size</i> .....                                  | 68 |
| 7     | Demo Board.....                                           | 70 |
| 7.1   | PCB Layout Overview.....                                  | 70 |
| 7.2   | Pin Out.....                                              | 71 |
| 7.3   | DC Power Supply.....                                      | 72 |
| 7.4   | USB Interface Configuration.....                          | 73 |
| 7.5   | LOGUART.....                                              | 73 |
| 7.6   | SWD.....                                                  | 74 |
| 7.7   | VBAT ADC.....                                             | 74 |
| 8     | ImageTool.....                                            | 75 |
| 8.1   | Introduction.....                                         | 75 |
| 8.2   | Environment Setup.....                                    | 75 |
| 8.2.1 | <i>Hardware Setup</i> .....                               | 75 |
| 8.2.2 | <i>Software Setup</i> .....                               | 76 |
| 8.3   | Download.....                                             | 76 |
| 8.3.1 | <i>Image Download</i> .....                               | 76 |
| 8.3.2 | <i>Flash Erase</i> .....                                  | 77 |
| 8.3.3 | <i>Flash Status Operation</i> .....                       | 78 |
| 8.4   | Generate.....                                             | 81 |
| 8.4.1 | <i>Merge Images</i> .....                                 | 81 |
| 8.4.2 | <i>Generate Cloud OTA Image</i> .....                     | 81 |
| 8.5   | Encrypt.....                                              | 82 |
| 8.6   | Security.....                                             | 83 |
| 9     | Memory Layout.....                                        | 85 |
| 9.1   | FlashProgram Layout.....                                  | 85 |
| 9.1.1 | <i>Image Header</i> .....                                 | 86 |
| 9.1.2 | <i>System Data (4K)</i> .....                             | 86 |
| 9.1.3 | <i>User Data</i> .....                                    | 86 |
| 9.1.4 | <i>4M Flash Usage Example</i> .....                       | 87 |

|                                             |     |
|---------------------------------------------|-----|
| 9.2 SRAM Layout.....                        | 89  |
| 9.2.1 KM4 SRAM Layout.....                  | 89  |
| 9.2.2 KMO SRAM Layout.....                  | 90  |
| 9.3 PSRAM Layout.....                       | 90  |
| 9.4 Retention SRAM.....                     | 91  |
| 9.4.1 Retention SRAM Layout.....            | 91  |
| 9.4.2 User Area.....                        | 91  |
| 9.5 OTA Layout.....                         | 92  |
| 9.5.1 OTA Program Layout.....               | 92  |
| 9.5.2 OTA Header Layout.....                | 93  |
| 9.6 TrustZone Memory Layout.....            | 94  |
| 10 Boot Process.....                        | 96  |
| 10.1 Features.....                          | 96  |
| 10.2 BootAddress.....                       | 96  |
| 10.3 Pin Description.....                   | 96  |
| 10.4 Boot Flow.....                         | 96  |
| 10.5 BootTime.....                          | 97  |
| 10.6 General Description.....               | 97  |
| 10.6.1 KMO ROM Boot.....                    | 97  |
| 10.6.2 KM4 ROM Boot.....                    | 98  |
| 10.7 Boot Reason APIs.....                  | 99  |
| 11 File System.....                         | 100 |
| 11.1 Introduction.....                      | 100 |
| 11.2 FatFs on Flash.....                    | 100 |
| 11.2.1 Software Setup.....                  | 100 |
| 11.2.2 FatFsBin FileGeneration.....         | 100 |
| 11.3 FatFs on SD Card.....                  | 101 |
| 11.3.1 Hardware Setup.....                  | 101 |
| 11.3.2 Software Setup.....                  | 101 |
| 12 Inter Processor Communication (IPC)..... | 103 |
| 12.1 Introduction.....                      | 103 |
| 12.2 How to Use IPC?.....                   | 103 |
| 12.3 IPC Program APIs.....                  | 104 |
| 12.3.1 ipc_table_init.....                  | 104 |
| 12.3.2 ipc_send_message.....                | 104 |
| 12.3.3 ipc_get_message.....                 | 104 |
| 12.4 IPC DriveCode.....                     | 104 |
| 12.4.1 IPC_INTConfig.....                   | 104 |
| 12.4.2 IPC_IERSet.....                      | 104 |
| 12.4.3 IPC_IERGet.....                      | 105 |
| 12.4.4 IPC_INTRequest.....                  | 105 |
| 12.4.5 IPC_INTClear.....                    | 105 |
| 12.4.6 IPC_INTGet.....                      | 105 |
| 12.4.7 IPC_CPUID.....                       | 105 |
| 12.4.8 IPC_SEMGet.....                      | 106 |
| 12.4.9 IPC_SEMFree.....                     | 106 |
| 12.4.10 IPC_INTHandler.....                 | 106 |
| 12.4.11 IPC_INTUserHandler.....             | 106 |
| 13 OTA Firmware Update.....                 | 107 |

|         |                                    |     |
|---------|------------------------------------|-----|
| 13.1    | Introduction.....                  | 107 |
| 13.2    | RSIPMMU.....                       | 107 |
| 13.3    | OTA Upgrade from Local Server..... | 108 |
| 13.3.1  | Firmware Format.....               | 109 |
| 13.3.2  | OTA Flow.....                      | 109 |
| 13.3.3  | Boot Option.....                   | 110 |
| 13.3.4  | Address Remapping.....             | 111 |
| 13.3.5  | How to Use OTA Demo.....           | 111 |
| 13.3.6  | OTA Firmware Swap.....             | 113 |
| 13.4    | User Configuration.....            | 114 |
| 14      | eFuse.....                         | 116 |
| 14.1    | Introduction.....                  | 116 |
| 14.2    | PowerRequirement.....              | 116 |
| 14.3    | eFuse Autoload.....                | 117 |
| 14.4    | Physical eFuse.....                | 117 |
| 14.5    | Logical eFuse.....                 | 117 |
| 14.5.1  | Logical eFuse Layout.....          | 117 |
| 14.5.2  | SPIC AddressByte Enable.....       | 118 |
| 14.5.3  | Wi-Fi 2.4G Power Index.....        | 118 |
| 14.5.4  | Wi-Fi 5G Power Index.....          | 119 |
| 14.5.5  | Wi-Fi Channel Plan.....            | 120 |
| 14.5.6  | Wi-Fi Crystal Calibration.....     | 121 |
| 14.5.7  | Wi-Fi Thermal Meter.....           | 121 |
| 14.5.8  | Wi-Fi MAC Address.....             | 122 |
| 14.5.9  | Cap-Touch.....                     | 122 |
| 14.5.10 | BLE.....                           | 122 |
| 14.5.11 | HCI USB.....                       | 123 |
| 14.6    | eFuse PG APIs.....                 | 123 |
| 14.6.1  | LowLevelAPIs.....                  | 123 |
| 14.6.2  | Mbed APIs.....                     | 124 |
| 14.7    | eFuse PG Command.....              | 125 |
| 15      | Power Save.....                    | 126 |
| 15.1    | Power Save Mode.....               | 126 |
| 15.1.1  | Summary.....                       | 126 |
| 15.1.2  | FreeRTOS Tickless.....             | 126 |
| 15.1.3  | Sleep Mode.....                    | 127 |
| 15.1.4  | Sleep Mode Configuration.....      | 134 |
| 15.1.5  | Deepsleep Mode.....                | 143 |
| 15.1.6  | Deepsleep Mode Configuration.....  | 145 |
| 15.1.7  | GPIO Pull Control.....             | 150 |
| 15.2    | Power Save Related APIs.....       | 150 |
| 15.2.1  | pmu_register_sleep_callback.....   | 150 |
| 15.2.2  | pmu_unregister_sleep_callback..... | 151 |
| 15.2.3  | pmu_acquire_wakelock.....          | 151 |
| 15.2.4  | pmu_release_wakelock.....          | 151 |
| 15.2.5  | pmu_set_sysactive_time.....        | 151 |
| 15.2.6  | pmu_setmax_sleeptime.....          | 152 |
| 15.3    | Power Consumption Measurement..... | 152 |
| 15.3.1  | Power Consumption Summary.....     | 152 |
| 15.3.2  | Test Command.....                  | 154 |
| 15.3.3  | Hardware Preparation.....          | 154 |

|         |                                                 |     |
|---------|-------------------------------------------------|-----|
| 16      | Hardware Crypto Engine.....                     | 156 |
| 16.1    | Introduction.....                               | 156 |
| 16.2    | Hardware Crypto Engine APIs.....                | 156 |
| 16.2.1  | <i>Crypto Engine Initialization API</i> .....   | 156 |
| 16.2.2  | <i>Hash APIs</i> .....                          | 156 |
| 16.2.3  | <i>Cipher APIs</i> .....                        | 161 |
| 16.3    | Hardware Crypto Engine APIs Usage.....          | 164 |
| 16.3.1  | <i>Starting Hardware Crypto Engine</i> .....    | 164 |
| 16.3.2  | <i>Starting Crypto Engine Calculation</i> ..... | 164 |
| 16.4    | Demo Code Path.....                             | 165 |
| 17      | User Configuration.....                         | 166 |
| 17.1    | Configuration File List.....                    | 166 |
| 17.2    | BootTrustZone Configuration.....                | 166 |
| 17.3    | Flash Configuration.....                        | 167 |
| 17.3.1  | <i>Flash Classification</i> .....               | 167 |
| 17.3.2  | <i>FlashClass1-FlashClass6</i> .....            | 171 |
| 17.4    | Pinmap Configuration.....                       | 174 |
| 17.4.1  | <i>Normal GPIO</i> .....                        | 176 |
| 17.4.2  | <i>KeyScan</i> .....                            | 176 |
| 17.4.3  | <i>LOGUART</i> .....                            | 176 |
| 17.4.4  | <i>SWD</i> .....                                | 177 |
| 17.4.5  | <i>Flash Pin</i> .....                          | 177 |
| 17.4.6  | <i>Cap-Touch</i> .....                          | 177 |
| 17.4.7  | <i>ADC</i> .....                                | 177 |
| 17.4.8  | <i>Power</i> .....                              | 177 |
| 17.4.9  | <i>DMIC</i> .....                               | 177 |
| 17.4.10 | <i>AMIC N/P</i> .....                           | 178 |
| 17.4.11 | <i>AOUT_L/R N/P</i> .....                       | 178 |
| 17.5    | Sleep Configuration.....                        | 178 |
| 17.6    | Boot Configuration.....                         | 178 |
| 17.7    | IPC Configuration.....                          | 180 |
| 17.8    | LP_intf Configuration.....                      | 181 |
| 17.9    | HP_intf Configuration.....                      | 181 |
| 18      | Flash Operation.....                            | 182 |
| 18.1    | Functional Description.....                     | 182 |
| 18.2    | Protection Method.....                          | 182 |
| 18.3    | Flash Raw APIs.....                             | 183 |
| 18.3.1  | <i>Read</i> .....                               | 183 |
| 18.3.2  | <i>Write</i> .....                              | 184 |
| 18.3.3  | <i>Erase</i> .....                              | 184 |
| 18.3.4  | <i>Receive/Transmit Command</i> .....           | 184 |
| 18.4    | Flash Mbed APIs.....                            | 185 |
| 18.5    | User Configuration.....                         | 185 |
| 19      | Battery Measurement.....                        | 186 |
| 19.1    | Functional Description.....                     | 186 |
| 19.2    | Calibration.....                                | 186 |
| 20      | Wi-Fi.....                                      | 188 |
| 20.1    | Wi-Fi Data Structures.....                      | 188 |

|                                                          |     |
|----------------------------------------------------------|-----|
| 20.2 Wi-Fi APIs.....                                     | 188 |
| 20.2.1 System APIs.....                                  | 188 |
| 20.2.2 Scan APIs.....                                    | 189 |
| 20.2.3 Connection APIs.....                              | 190 |
| 20.2.4 Channel APIs.....                                 | 192 |
| 20.2.5 Power APIs.....                                   | 193 |
| 20.2.6 AP Mode APIs.....                                 | 194 |
| 20.2.7 Custom IE APIs.....                               | 196 |
| 20.2.8 Wi-Fi Setting APIs.....                           | 197 |
| 20.2.9 Wi-Fi Indication APIs.....                        | 200 |
| 20.2.10 eFuse Writing APIs.....                          | 201 |
| 20.3 Fast Connection.....                                | 201 |
| 20.3.1 Implement.....                                    | 201 |
| 20.3.2 APIs.....                                         | 202 |
| 20.4 WPS APIs.....                                       | 202 |
| 20.4.1 wps_start.....                                    | 202 |
| 20.4.2 wps_stop.....                                     | 203 |
| 21 Liquid Crystal Display Controller (LCDC).....         | 204 |
| 21.1 Interface.....                                      | 204 |
| 21.2 Resolution.....                                     | 204 |
| 21.3 Pinmux.....                                         | 205 |
| 21.4 LCDC APIs.....                                      | 205 |
| 21.4.1 MCU Function.....                                 | 205 |
| 21.4.2 RGB Function.....                                 | 206 |
| 21.4.3 LED Function.....                                 | 207 |
| 21.4.4 Common Function.....                              | 207 |
| 21.5 How to Use LCDC.....                                | 209 |
| 21.5.1 MCU Interface.....                                | 209 |
| 21.5.2 RGB Interface.....                                | 211 |
| 21.5.3 LED Interface.....                                | 211 |
| 21.6 GUI .....                                           | 212 |
| 21.6.1 Authorization.....                                | 212 |
| 21.6.2 emWin Software.....                               | 212 |
| 21.6.3 How to Adapt to LCM.....                          | 213 |
| 21.6.4 How to AdaptbTouch Panel.....                     | 214 |
| 21.6.5 How to Use emWin in SDK.....                      | 215 |
| 22 PSRAM.....                                            | 216 |
| 22.1 Throughput.....                                     | 216 |
| 22.2 PowerManagement.....                                | 217 |
| 22.3 How to Use PSRAM.....                               | 217 |
| 22.3.1 InitializingPSRAM.....                            | 217 |
| 22.3.2 AddingBSS/TEXT/DATASection into PSRAM Region..... | 217 |
| 22.3.3 Allocating Heap from PSRAM.....                   | 217 |
| 22.4 h o k ° U # † " . h . # . V .....                   | 218 |
| 22.4.1 Cache Policy Change.....                          | 218 |
| 22.4.2 Scope.....                                        | 218 |
| 22.4.3 Notice.....                                       | 218 |
| 23 MPU and Cache.....                                    | 220 |
| 23.1 Functional description.....                         | 220 |
| 23.1.1 MPU.....                                          | 220 |

|                                                                    |     |
|--------------------------------------------------------------------|-----|
| 23.1.2 Cache.....                                                  | 220 |
| 23.2 MPU APIs.....                                                 | 221 |
| 23.2.1 <i>mpu_init</i> .....                                       | 221 |
| 23.2.2 <i>mpu_set_mem_attr</i> .....                               | 221 |
| 23.2.3 <i>mpu_region_cfg</i> .....                                 | 221 |
| 23.2.4 <i>mpu_entry_free</i> .....                                 | 221 |
| 23.2.5 <i>mpu_entry_alloc</i> .....                                | 222 |
| 23.3 Cache APIs.....                                               | 222 |
| 23.3.1 <i>ICache_Enable</i> .....                                  | 222 |
| 23.3.2 <i>ICache_Disable</i> .....                                 | 222 |
| 23.3.3 <i>ICache_Invalidate</i> .....                              | 222 |
| 23.3.4 <i>DCache_IsEnabled</i> .....                               | 222 |
| 23.3.5 <i>DCache_Enable</i> .....                                  | 222 |
| 23.3.6 <i>DCache_Disable</i> .....                                 | 223 |
| 23.3.7 <i>DCache_Invalidate</i> .....                              | 223 |
| 23.3.8 <i>DCache_Clean</i> .....                                   | 223 |
| 23.3.9 <i>DCache_CleanInvalidate</i> .....                         | 223 |
| 23.4 How to Define <i>NonCacheableData</i> Buffer.....             | 223 |
| 24 Audio Codec Controller Guide.....                               | 224 |
| 24.1 Audio Codec.....                                              | 224 |
| 24.1.1 Diagram.....                                                | 224 |
| 24.1.2 Features.....                                               | 225 |
| 24.1.3 Application Mode.....                                       | 225 |
| 24.2 Audio Codec Controller.....                                   | 228 |
| 24.2.1 Features.....                                               | 228 |
| 24.2.2 Control Interface.....                                      | 228 |
| 24.3 Audio PLL.....                                                | 228 |
| 24.3.1 Diagram.....                                                | 229 |
| 24.3.2 Operation Mode.....                                         | 230 |
| 24.4 Audio Codec APIs.....                                         | 230 |
| 24.4.1 PLL APIs.....                                               | 230 |
| 24.4.2 SPORT APIs.....                                             | 231 |
| 24.4.3 SI APIs.....                                                | 234 |
| 24.4.4 Codec APIs.....                                             | 234 |
| 24.5 How to Use AC APIs?.....                                      | 236 |
| 24.5.1 Audio Play.....                                             | 236 |
| 24.5.2 Audio Record.....                                           | 237 |
| 24.5.3 Example List.....                                           | 237 |
| 24.6 Hardware Design Guide.....                                    | 238 |
| 24.6.1 Line-out.....                                               | 238 |
| 24.6.2 AMICin.....                                                 | 238 |
| 24.6.3 Power.....                                                  | 239 |
| 24.7 Performance of Encoding & Decoding.....                       | 239 |
| 24.7.1 AC3 Format.....                                             | 239 |
| 24.7.2 OPUS Format.....                                            | 239 |
| 24.7.3 FLAC Format.....                                            | 240 |
| 24.7.4 AAC Format.....                                             | 240 |
| 24.7.5 MP3 Format.....                                             | 240 |
| 24.8 Q & A.....                                                    | 241 |
| 24.8.1 How to Connect the Output of DAC to A Power Amplifier?..... | 241 |
| 24.8.2 ) -ended MIC Input and Differential MIC Input?.....         | 241 |
| 24.8.3 How to Play Local Audio Files?.....                         | 241 |

|                                                               |     |
|---------------------------------------------------------------|-----|
| 25 CapTouch.....                                              | 242 |
| 25.1 Pinmux.....                                              | 242 |
| 25.2 APIs.....                                                | 242 |
| 25.2.1 <i>CapTouch_StructInit</i> .....                       | 242 |
| 25.2.2 <i>CapTouch_Init</i> .....                             | 242 |
| 25.2.3 <i>CapTouch_Cmd</i> .....                              | 242 |
| 25.2.4 <i>CapTouch_INTConfig</i> .....                        | 243 |
| 25.2.5 <i>CapTouch_GetISR</i> .....                           | 243 |
| 25.2.6 <i>CapTouch_INTClearPendingBit</i> .....               | 243 |
| 25.3 How to Use CTC.....                                      | 243 |
| 25.3.1 <i>CTCInitialization</i> .....                         | 243 |
| 25.3.2 <i>CTC Calibration</i> .....                           | 244 |
| 25.4 CapTouch Schematic Design and PCB Layout Guidelines..... | 244 |
| 25.4.1 <i>Cap-Touch Schematic Design</i> .....                | 244 |
| 25.4.2 <i>PCB Layout</i> .....                                | 245 |
| 26 DuerOS.....                                                | 248 |
| 26.1 DuerOS Platform.....                                     | 248 |
| 26.1.1 <i>Apply product</i> .....                             | 248 |
| 26.1.2 <i>Apply Profile</i> .....                             | 250 |
| 26.2 Hardware Requirement.....                                | 251 |
| 26.3 Software Component.....                                  | 252 |
| 26.3.1 <i>duerapp</i> .....                                   | 252 |
| 26.3.2 <i>libduerdevice</i> .....                             | 252 |
| 26.4 How to Use DuerOS.....                                   | 252 |
| 26.4.1 <i>Build and Download</i> .....                        | 252 |
| 26.4.2 <i>Configure the Network</i> .....                     | 253 |
| 26.4.3 <i>DuerOS Connection Success</i> .....                 | 254 |
| 26.4.4 <i>Triger Record and Speak</i> .....                   | 254 |
| 26.5 OTA Upgrade.....                                         | 254 |
| 26.5.1 <i>Generating OTA Image</i> .....                      | 254 |
| 26.5.2 <i>OTA with DuerOS Platform</i> .....                  | 255 |
| 26.6 How to Debug.....                                        | 257 |
| 26.6.1 <i>Build Error</i> .....                               | 257 |
| 26.6.2 <i>Wi-Fi Signal</i> .....                              | 257 |
| 26.6.3 <i>CamotRecognize the Recorder</i> .....               | 257 |
| 26.6.4 <i>Checking the Memory</i> .....                       | 258 |
| 26.6.5 <i>Checking the Device Status</i> .....                | 258 |
| 27 Infrared Radiation (IR).....                               | 259 |
| 27.1 Pinmux.....                                              | 259 |
| 27.2 DataFormat.....                                          | 259 |
| 27.2.1 <i>IR Tx</i> .....                                     | 259 |
| 27.2.2 <i>IR Rx</i> .....                                     | 260 |
| 27.3 APIs.....                                                | 260 |
| 27.3.1 <i>IR Setting APIs</i> .....                           | 260 |
| 27.3.2 <i>IR Tx APIs</i> .....                                | 262 |
| 27.3.3 <i>IR Rx APIs</i> .....                                | 263 |
| 27.4 IRUsage.....                                             | 265 |
| 27.4.1 <i>Sending</i> .....                                   | 265 |
| 27.4.2 <i>Receiving</i> .....                                 | 265 |
| 27.5 Tx CompensationMechanism.....                            | 266 |

|                                                                |     |
|----------------------------------------------------------------|-----|
| 27.5.1 <i>Introduction</i> .....                               | 266 |
| 27.5.2 <i>Tx Compensation Mechanism Application</i> .....      | 266 |
| 27.6 IR Schematic Design Guideline.....                        | 267 |
| 27.6.1 <i>Leakage</i> .....                                    | 267 |
| 27.6.2 <i>Carrier Problem in Rx Learning</i> .....             | 268 |
| 28 Brownout Detector(BOD).....                                 | 269 |
| 28.1 Recommended Threshold Parameter.....                      | 269 |
| 28.2 BODAPIs.....                                              | 270 |
| 28.2.1 <i>BOR_ModeSet</i> .....                                | 270 |
| 28.2.2 <i>BOR_ThresholdSet</i> .....                           | 270 |
| 28.2.3 <i>BOR_ClearINT</i> .....                               | 270 |
| 28.2.4 <i>BOR_DbncSet</i> .....                                | 270 |
| 29 Flash Translation Layer (FTL).....                          | 272 |
| 29.1 Overview.....                                             | 272 |
| 29.2 Features.....                                             | 273 |
| 29.3 FTL APIs.....                                             | 273 |
| 29.3.1 <i>ftl_init</i> .....                                   | 273 |
| 29.3.2 <i>ftl_load_from_storage</i> .....                      | 273 |
| 29.3.3 <i>ftl_save_to_storage</i> .....                        | 274 |
| 29.4 How to Use FTL.....                                       | 274 |
| 29.4.1 <i>Precautions</i> .....                                | 274 |
| 29.4.2 <i>General Steps</i> .....                              | 274 |
| 30 Audio Signal Generation and Analysis.....                   | 276 |
| 30.1 Introduction.....                                         | 276 |
| 30.1.1 <i>Compilation</i> .....                                | 276 |
| 30.1.2 <i>Generating a Signal of a Certain Frequency</i> ..... | 276 |
| 30.1.3 <i>Analyzing Signals Collected by DMIC</i> .....        | 276 |
| 30.1.4 <i>DAAD</i> .....                                       | 276 |
| 30.1.5 <i>Command</i> .....                                    | 277 |
| 31 Key-Scan.....                                               | 278 |
| 31.1 Pinmux.....                                               | 278 |
| 31.2 APIs.....                                                 | 278 |
| 31.2.1 <i>keyscan_array_pinmux</i> .....                       | 278 |
| 31.2.2 <i>keyscan_getdatanum</i> .....                         | 278 |
| 31.2.3 <i>keyscan_read</i> .....                               | 278 |
| 31.2.4 <i>keyscan_init</i> .....                               | 279 |
| 31.2.5 <i>keyscan_set_irq</i> .....                            | 279 |
| 31.2.6 <i>keyscan_clear_irq</i> .....                          | 279 |
| 31.2.7 <i>keyscan_get_irq_status</i> .....                     | 279 |
| 31.2.8 <i>keyscan_set_irq_handler</i> .....                    | 279 |
| 31.2.9 <i>keyscan_enable</i> .....                             | 279 |
| 31.2.10 <i>keyscan_disable</i> .....                           | 280 |
| 31.2.11 <i>keyscan_clearfifodata</i> .....                     | 280 |
| 31.3 Key-Scan Usage.....                                       | 280 |
| 31.3.1 <i>Using Default Configuration</i> .....                | 280 |
| 31.3.2 <i>Using APIs</i> .....                                 | 281 |
| 32 Bluetooth.....                                              | 282 |
| 32.1 Overview.....                                             | 282 |

---

|                                                              |     |
|--------------------------------------------------------------|-----|
| 32.2 BLE Coexistence.....                                    | 282 |
| 32.2.1 <i>Introduction</i> .....                             | 282 |
| 32.2.2 <i>PTA Mode</i> .....                                 | 283 |
| 32.2.3 <i>TDMA Mode</i> .....                                | 284 |
| 32.2.4 <i>Working Scenarios</i> .....                        | 285 |
| 32.2.5 <i>How to Configure BLE Coexistence?</i> .....        | 286 |
| 32.2.6 <i>Supplement for Coexistence Related GPIOs</i> ..... | 286 |
| 32.3 BT Examples.....                                        | 287 |
| 32.3.1 <i>GCCProject</i> .....                               | 287 |
| 32.3.2 <i>IAR Project</i> .....                              | 288 |
| 32.4 BT Debug.....                                           | 289 |
| 32.4.1 <i>Introduction</i> .....                             | 289 |
| 32.4.2 <i>Hardware &amp; Software Preparation</i> .....      | 289 |
| 32.4.3 <i>h \ O o</i> .....                                  | 289 |
| 32.4.4 <i>Capturing LogFiles</i> .....                       | 290 |
| 32.4.5 <i>FAQ</i> .....                                      | 293 |
| Revision History.....                                        | 295 |

# Convention

Ameba-D consists of two MCUs:

- RealM300: a high performance MCU (Arm Cortex-M33 instruction set compatible) called KM4 thereafter
- RealM200: a low power MCU (Arm Cortex-M23 instruction set compatible) called KMO thereafter

# 1 Building Environment

## 1.1 Introduction

This chapter illustrates how to build Realtek VDK under GCC environment. It focuses on both Windows platform and Linux distribution. The build and download procedure are quite similar between Windows and Linux operating system.

For Windows, Windows 7 64bit is used as platform.

For Linux distribution, Ubuntu 10.04 64bit is used as platform.

## 1.2 Preparing 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 setupx86.exe for your Windows platform.

#### Note

Only 32bit Cygwin is supported both for 32bit Windows and 64bit Windows

)  
1-2 shows



Fig1-1 Devel setting during cygwin installation



Fig1-2 Math setting during cygwin installation

## 1.2.2 Linux

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

libc6i386(GNU C library for 64bit platform. If you are using 32bit platform, install libc6 instead)

lib32ncurses(32bit terminal handling for 64bit platform. If you're using 32bit platform, install ncurses5 instead)

make

bc

gawk

ncurses

Some of these packages may have been installed in your operating system. Use package manager to check and whether to install.

For the last three packages, you can also type corresponding version command on terminal like the following figures to check whether it exists. If not, make these packages installed.

\$ make v  
If make apt-get install make to install make

```
#root@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.
```

\$ bc v  
If bc apt-get install bc to install bc

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

\$ gawk-v  
If gawk apt-get install gawk to install gawk

```

realtek@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 http://www.gnu.org/licenses/.

```

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

## 1.3 Building Code

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

For Windows, open Cygwin terminal and type command to change directory KMO or KM4 project directory of AmebaSDK.

Note You need to place the *(path)* to your own SDK location, and so that Cygwin can access your file system.

```
$ cd /cygdrive/(path)/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp
$ cd /cygdrive/(path)/project/realtek_amebaD_va0_example/GCC-RELEASE/project_bp
```

For Linux, open its own terminal and type command to change directory KMO or KM4 project directory of AmebaSDK.

```
$ cd /path/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp
$ cd /path/project/realtek_amebaD_va0_example/GCC-RELEASE/project_bp
```

### 1.3.1 Normal Image

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

#### 1.3.1.1 KMOProject

For KMO project, the terminal contains `km0_image2_all.bin` and it means that the image has been built successfully Fig1-3 shows.

```

./cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp
./project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/image/xip_im
age2.bin __flash_text_start__ /cygdrive/d/sdk-amebad-beta_v6.0/project/realte
ek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/image/target_img2.map
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEAS
E/project_lp/asdk/gnu_utility/prepend_header.sh /cygdrive/d/sdk-amebad-beta_v6
.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/image/ram_re
tention.bin __retention_entry_func__ /cygdrive/d/sdk-amebad-beta_v6.0/projec
t/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/image/target_img2.map
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RE
LEASE/project_lp/asdk/image/xip_image2_prepend.bin /cygdrive/d/sdk-amebad-beta
_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/image/ram
_2_prepend.bin > /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_e
xample/GCC-RELEASE/project_lp/asdk/image/km0_image2_all.bin
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEAS
E/project_lp/asdk/gnu_utility/pad.sh /cygdrive/d/sdk-amebad-beta_v6.0/project/
realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/image/km0_image2_all.bi
n
===== Image manipulating end ======
make[1]: Leaving directory `/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_a
mebaD_va0_example/GCC-RELEASE/project_lp'
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_
example/GCC-RELEASE/project_lp
$ |

```

Fig1-3 KMO project make all

If somehow it is built failed, \$`make clean` to clean and then redo the make procedure. After success, `binfile` is located in `project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/image` as Fig1-4 shows.



Fig1-4 KMO project bin generation

### 1.3.1.2 KM4 Project

For KM4 project, the terminal contains m4\_image2\_all.bin and end it means that the image has been built successfully Fig. 5 shows.

Fig1-5KM4 project make all

If somehow it built failed, ~~try make clean~~ to clean and then redo the make procedure. After successfully, the image file is located in `project\realtek_amebaD_va0_exam0\RELEASE\project\ip/asdk\image` as Fig1-6 shows.



Fig1-6 KM4 project bin generation

### 1.3.2 MPImage

Use make mp command under project\realtek\_amebaD\_va0\_exam01\GCCRELEASE\project\_hp to generate MP image. After successful compilation, you will find the generated images project\realtek\_amebaD\_va0\_exam01\GCCRELEASE\project\_hp\asdk\image as shown in Fig1-7.



Fig1-7 MP image generation

## 1.4 Setting Debugger

This section illustrates how to enter GDB debugger mode.

Note Considering KM4 is powered by KMO, make sure that KMO has boot up already before connecting KM4 blink or Probe. Clicking Reset button on demo board is a recommended way to boot up KMO.

### 1.4.1 Probe

#### 1.4.1.1 Windows

Ameba-D Device Board supports debugger. We can use Probe to download the software and enter GDB debugger mode under GCC environment. Refer to Fig1-8 to connect Probe debugger to the SWD of Ameba-D.

##### (1) Install Probe driver

Before using the Probe, its driver is required to be installed. Obtain the RLX\_Probe\_Driver\_2.3.10\_Setup.exe under tools/probe and install it correctly. Refer to Fig1-8 to connect Probe debugger to the SWD of Ameba-D which is connecting TCK pin of Probe to SWD CLK pin of Ameba-D, and TMS pin of Probe to SWD DATA of Ameba-D. What's more a common ground is needed between Probe Board and Ameba-D Device Board.



Fig1-8Wiring diagram of connecting Probe to SWD

- (2) Execute them0\_RTL\_Probe.bat

After the installation of the software execute them0\_RTL\_Probe.bat under project\realtek\_amebaD\_exam\GEC RELEASE\project\p\jlink\_script

Note The default path of probe driver is C:\RLX\PROBE\rlx\_probe\_driver.exe you may have to change the path according your own settings.

The started Probeserver looks like Fig1-9. This window should NOT be closed if you want to download or enter debug 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, Revision is r1p0!
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 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_CVCCNT 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, CMPMATCHEN!
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 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
*****
```

Fig1-9KM0 Probeserver connection under Windows

- (3) SetupProbe for KM0

On the Cygwin terminal, type make setup GDB\_SERVER=probe command to select Probe debugger. Fig1-10 shows

```

/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_
example/GCC-RELEASE/project_lp
$ make setup GDB_SERVER=probe
make -C asdk setup
make[1]: Entering directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_
amebaD_va0_example/GCC-RELEASE/project_lp/asdk'
-----
Setup probe
-----
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-
RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_debug_probe.txt /cygdrive/
d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/proje
ct_lp/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-
RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_probe.txt /
cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE
/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-
RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_probe.txt
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEA
SE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_a
mebaD_va0_example/GCC-RELEASE/project_lp/asdk'
```

Fig1-10KM0Probesetupunder Windows

## (4) Execute them4 RTL\_Probe.bat

Execute them4 RTL\_Probe.bat under /project\realtek\_amebaD\_va0\_example\GCC-RELEASE\project\_lp\jlink\_script\ the same as executing them0 RTL\_Probe.bat the started probeserver looks like Fig1-11. This window should NOT be closed if you want to enter debug mode.



Fig1-11 KM4Probeserver connection under Windows

Note When cm4 RTL\_Probe.bat is running, the connection built by cm0 RTL\_Probe.bat will be closed. If you want to connect the Probe to KM0 and KM4 simultaneously, follow the steps below:

- Make a copy of x\_prob@cfg under the folder project\realtek\_amebaD\_va0\_example\GCC-RELEASE\project\_lp\jlink\_script and rename it abx\_probe1.cfg

- b) Cut rlx\_probe1.cfg and move it to project\realtek\_amebaD\_va0\_exam\GCC-RELEASE\project\_lp\jlink\_script
  - c) Connect the Probe to both KMO and KM4 by executing M0\_RTL\_Probe.bat under project\realtek\_amebaD\_va0\_exam\GCC-RELEASE\project\_lp\jlink\_script
- (5) Setup Probe for KM4

On the Cygwin terminal, type make setup GDB\_SERVER=probe command to select Probe debugger as Fig1-12 shows.

```
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_
$ make setup GDB_SERVER=probe
make -C asdk setup
make[1]: Entering directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_
p/asdk'
-----
Setup probe
-----
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-
script/rtl_gdb_debug_probe.txt /cygdrive/d/sdk-amebad-beta_v6.0/project/realte
_lhp/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-
script/rtl_gdb_flash_write_probe.txt /cygdrive/d/sdk-amebad-beta_v6.0/project/
project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-
script/rtl_gdb_jtag_boot_com_probe.txt /cygdrive/d/sdk-amebad-beta_v6.0/proje
/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_a
/asdk'
```

Fig1-12 KM4 Probe setup under Windows

#### 1.4.1.2 Linux

Before using Probe, its driver is required to be installed. Obtain the RLX\_Probe\_Linux\_Driver\_v2.3.11 package and install it correctly. Then connect TCK pin of Probe to SWD Clock pin of Probe to SWD DATA pins. Share a common ground between Probe Board and Ameba-D Device Board.

After the installation of the software package, use command in both folder project\realtek\_amebaD\_va0\_exam\GCC-RELEASE\project\_lp\jlink\_script and project\realtek\_amebaD\_va0\_exam\GCC-RELEASE\project\_hp\jlink\_script to create a soft link to link the rlx\_probe\_driver.elf

```
wlan5@RS-wlan5:~/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/jlink_script
$ ln -s /home/wlan5/RLX_Probe_driver/RLX_Probe_Linux_Driver/rlx_probe_driver.elf /home/wlan5/sdk-amebad-beta
_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/jlink_script/
wlan5@RS-wlan5:~/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/jlink_script
$ ln -s /home/wlan5/RLX_Probe_driver/RLX_Probe_Linux_Driver/rlx_probe_driver.elf /home/wlan5/sdk-amebad-beta
_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/jlink_script/
```

Fig1-13 Creating soft link to elf

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

KMO project  
For KM0 open a new terminal under project\realtek\_amebaD\_va0\_exam\GCC-RELEASE\project\_lp\jlink\_script and type \$ sudo ./rlx\_probe\_driver.elf If connection is successful, the log is shown in Fig1-14.

```
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!
KM0 halted!
This Core is implemented by Realtek Semiconductor Corporation.
This is a KM0 processor!KM0 found CPUID = 0x721cd280, Reversion is rip0!
DCB_DCICSR 0x000030003;
NVIC_DFSR 0x00000001;
NVIC_HARCR 0xfa0a52000; little-endian;
DCB_DCCR 0x00000000;
DCB_DCRDR 0x0000000000;
DHT_CYCCNT 0x00000000;
DHT_MASK0 0x00000000;
DHT_FUNCTION0 0x50000000;
This MCU has a Flash Patch Breakpoint version 2!
This MCU has 2 of core comparators and 0 literal comparators in FPB!
Remapping not supported!
DHT_TMR 0x1b000000;
DHT_CYCCNT 0x00000000;
DHT_CVCCNT 0x00000000;
DHT_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 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 *****
*****
```

Fig1-14 KM0probeGDBserver connection success under Linux

Open a new terminal under the same project folder (project\realtek\_amebaD\_va0\_exam\RELEASE\project\lp), type \$ make setup GDB\_SERVER=probe command to select Probe debugger

KM4 project  
For KM4 open a new terminal under (project\realtek\_amebaD\_va0\_exam\RELEASE\project\hp\jlink\_script) and type \$ sudo./rlx\_probe\_driver.elf connection is successful the log is shown as Fig1-15.

```
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, Reversion is r1p0!
DCB_DMSR 0x00010003;
NVIC_DFSR 0x00000009;
NVIC_AIRCR 0xfa050000; little-endian;
DCB_DCRSR 0x00000000;
DCB_DCRDR 0x00000000;
DWT_CYCNT 0x00000000;
DWT_MASK0 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_CYCNT 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 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 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 Information:
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]
*****
```

Fig1-15KM4probeGDBserverconnectionsuccessunder Linux

Open a new terminal under the same project folder (project/realtek\_amebaD\_v0\_exam01RELEASE/project/hp), type \$ make setup GDB\_SERVER=probe command to select Probe debugger

#### 1.4.2 J-Link

Ameba-D also supports J-link debugger. You need to do some hardware configuration to connect J-link to the SWD of Ameba-D which is connecting SWCLK pin of J-link to SWD CLK pin in Ameba-D, and SWDIO pin of J-link to SWD DATA pin in Ameba-D. After finishing these configurations, connect it to PC.



Fig1-16Wiring diagram of connecting J-link to SWD

Note For AmebaD CPU, the JLink version must be v9 or higher. 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 can detect the device.

#### 1.4.2.1 Windows

##### (1) Install JLink GDB server

Besides the hardware configuration, JLink GDB server is also required to install. For Windows, download the software JLink Software and Documentation Pack from <https://www.segger.com/downloads/jlink/>. After download the software JLink Software and Documentation Pack, install it correctly.

Note The version of JLink GDB server displayed in the pictures below is just an example, you can select the latest version to download.

##### (2) Execute them0\_jlink.bat

After the installation of the software, execute them0\_jlink.bat under /project\realtek\_amebaD\_va0\_exam\GCC-RELEASE\project\jlink\_script

Note The default path of JLink driver isom0\_jlink.bat file is C:\Program Files(x86)\SEGGER\JLink\_V634\JLinkGDBServer.exe, you may have to change the path according to your own settings.

The started JLink GDB server looks like Fig1-17. This window should NOT be closed if you want to download or enter debug mode.



Fig1-17 KMO JLink GDBServer connection under Windows

##### (3) Setup JLink for KMO

On the Cygwin terminal, type make setup GDB\_SERVER=jlink command before to select JLink debugger, a Fig1-18 shows.

```
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp$ make setup GDB_SERVER=jlink
make[1]: Entering directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk'
Setup jlink
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt /cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebad_va0_exam/GCC-RELEASE/project_lp/asdk'
```

Fig1-18KM0 J-Link setup under Windows

## (4) Execute them4\_jlinkbat

Execute them4\_jlinkbat under /project/realtek\_amebaD\_va0\_example/GCC-RELEASE/project\_hp/jlink\_script the same as executing the them0\_jlinkbat. The started J-Link GDB server looks like Fig1-19. This window should NOT be closed if you want to download image or enter debug mode.



Fig1-19KM4 J-Link GDBserver connection under Windows

## (5) Setup J-Link for KM4

On the Cygwin terminal type \$ make setup GDB\_SERVER=jlink command to select J-Link debugger, as Fig1-20 shows.

```
/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp
$ make setup GDB_SERVER=jlink
make -C asdk setup
make[1]: Entering directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk'
-----
Setup jlink
-----
cp -p ./cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt ./cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p ./cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt ./cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p ./cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt ./cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/cygdrive/d/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_hp/asdk'
```

Fig1-20KM4 J-Link setup under Windows

## 1.4.2.2 Linux

For J-Link GDB server, go to <https://www.segger.com/downloads/jlink/> to download the software in J-Link Software and Documentation Pack. \$ dpkg i jlink\_6.0.7\_x86\_64.deb

After the installation of the software pack, there J-LinkGDBServer 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 image or enter debug mode.

#### 1.4.2.2.1 KMO Project

For KMO open a new terminal under /project/realtek\_amebaD\_va0\_examplE RELEASE/project\_lp/jlink\_script and type \$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m23-if SWD-scriptfile AP1\_KMO.JLinkScript port 2331 Fig1-21 shows if connection is successful, the log is shown in Fig1-22

```
wlan5@RS-wlan5:~/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/jlink_script$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m23 -if SWD -scriptfile AP1_KMO.JLinkScript -port 2331
SEGGER J-Link GDB Server V6.46b Command Line Version
JLinkARM.dll V6.46b (DLL compiled May 31 2019 17:41:22)

Command line: -device cortex-m23 -if SWD -scriptfile AP1_KMO.JLinkScript -port 2331
-----GDB 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-----
```

Fig1-21 KMO J-Link GDBserver connection setting under Linux

```
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_KMO.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:47:26
Hardware: V9.40
S/N: 59425868
Feature(s): RDI, GDB, FlashDL, FlashBP, JFlash, RDDI
Checking target voltage...
Target voltage: 3.38 V
Listening on TCP/IP port 2331
Connecting to target... Connected to target
Waiting for GDB connection...
```

Fig1-22 KMO J-Link GDBserver connection success under Linux

Open a new terminal under the same project folder type \$ make setup GDB\_SERVER=jlink command to select J-Link debugger as Fig1-23 shows

```
wlan5@RS-wlan5:~/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp$ make setup GDB_SERVER=jlink
make .C asdk setup
make[1]: Entering directory '/home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk'
Setup jlink
cp -p /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write.txt
cp -p /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk'
```

Fig1-23 KMO J-Link terminal setup under Linux

#### 1.4.2.2.2 KM4 Project

For KM4 open a new terminal under /project/realtek\_amebaD\_va0\_examplGCC-RELEASE/project\_hp/jlink\_script and type \$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m33-if SWD-scriptfile AP2\_KM4.JLinkScript -port 2335 as Fig1-24 shows if connection is successful the log is shown as Fig1-25

```
wlan5@RS-wlan5:~/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/jlink_script$ /opt/SEGGER/JLink/JLinkGDBServer -device cortex-m33-if SWD-scriptfile AP2_KM4.JLinkScript -port 2335
SEGGER J-Link GDB Server V6.46b Command Line Version
JLinkARM.dll V6.46b (DLL compiled May 31 2019 17:41:22)

Command line: -device cortex-m33 -if SWD -scriptfile AP2_KM4.JLinkScript -port 2335
-----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-----
```

Fig1-24 KM4 J-Link GDBserver connection setting under Linux



```
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: 59425868
Feature(s): RDI, GDB, FlashDL, FlashBP, JFlash, RDDI
Checking target voltage...
Target voltage: 3.37 V
Listening on TCP/IP port 2335
Connecting to target... Connected to target
Waiting for GDB connection...
```

Fig1-25 KM4 J-Link GDBserver connection success under Linux

Open a new terminal under the same project folder type \$ make setup GDB\_SERVER=jlink command to select J-Link debugger as Fig1-26 shows.

```
wlan5@RS-wlan5:~/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp$ make setup GDB_SERVER=jlink
make -C asdk setup
make[1]: Entering directory '/home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk'
-----
Setup jlink
-----
cp -p /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_debug_jlink.txt /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_debug.txt
cp -p /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_flash_write_jlink.txt /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_flash.write.txt
cp -p /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com_jlink.txt /home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk/gnu_utility/gnu_script/rtl_gdb_jtag_boot_com.txt
make[1]: Leaving directory '/home/wlan5/sdk-amebad-beta_v6.0/project/realtek_amebaD_va0_examplGCC-RELEASE/project_hp/asdk'
```

Fig1-26 KM4 J-Link terminal setup under Linux

## 1.5 Downloading Image to Flash

This section illustrates how to download image to Flash.

To download software into Ande 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 KMO and KM4 download code. This command downloads the software in flash and it will take several seconds to finish as shown Fig1-27.

```
Breakpoint 1, RtlFlashProgram () at /cygdrive/e/v03newest/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/flashloader/rtl_flash.o
88         asm("nop");
flash_write FileName:2
flash_write FileSize:0
flash_write FlashAddrForwrite:6000
FileSize: 0
Loopnumber = 0
TailSize = 0
global variables
FlashDataSrc:822ac
FlashBlockWriteSize:800
FlashAddrForwrite:6000Flash write start...
dump for check
Breakpoint 2, RtlFlashProgram () at /cygdrive/e/v03newest/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk/flashloader/rtl_flash.o
120        if (FlashWriteComplete == 1) {
make[1]: Leaving directory '/cygdrive/e/v03newest/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp/asdk'
fiona_shen@Y38471517 /cygdrive/e/v03newest/project/realtek_amebaD_va0_example/GCC-RELEASE/project_lp
```

```
17:05:21.123 #ROM:[V1.2]
17:05:21.183 FLASHRATE:1
17:05:21.194 =====
17:05:21.259 Flash Downloader Build Time: 2019/07/05-16:54:02
17:05:21.276 =====
17:05:21.291 Flash init start
17:05:21.309 Flash init done
17:05:21.322 Flash download start      log in trace tool
17:05:21.712 Flash download done
```

Fig1-27 Download code success log

After download successfully, press the Reset button and you can see the device is booted with image.

NOTE

For new device board or device board with erased all images, program both KMO and KM4 by commands with the sequence \$ make flash in project\_lp then change the path to \$ make flash in project\_bp. After both images are downloaded successfully, press Reset.

For Probe download,

Make chip enter download mode before download to Flash

Download KM4 project code also the com@hRTL\_Probe.bat

Probe uses USB 1.0 interface, so its download rate is limited by the USB 1.0 protocol

## 1.6 Entering Debug Mode

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

For Windows, a popup window will display as shown Fig1-28

For Linux, the log is shown Fig1-29

```

E:\SDK\ sdk-amebad-beta_v5.2\project\realtek_amebaD_cm4_gcc_verification\toolchain...\ ...
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-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.
0x100075da in ?? ()
Notification of completion for asynchronous execution commands is off.
(gdb) -

```

Fig1-28Debugwindowunder Windows

```

File Edit View Search Terminal Help
tion/asdk/.../toolchain/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.
0x0008215e in ?? ()
Notification of completion for asynchronous execution commands is off.
Resets the core only, not peripherals.
Sleep 20ms
(gdb) -

```

Fig1-29Debugwindowunder Linux

## 1.7 Command List

The commands used above are listed in Table1-1.

Table1-1 Command list

| Usage     | Command                         | Description                             |
|-----------|---------------------------------|-----------------------------------------|
| all       | \$ make all                     | Compile project to generate ram_all.bin |
| setup     | \$ make setup GDB_SERVER= jlink | Select GDB_SERVER                       |
| flash     | \$ make flash                   | Download ram_all.bin Flash              |
| clean     | \$ make clean                   | Remove compile file                     |
| clean_all | \$ make clean_all               | Remove compile result and toolchains    |
| debug     | \$ make debug                   | Enter debug mode                        |

## 1.8 GDB Debugger Basic Usage

GDB, the GNU project debugger, allows you to examine the program while it executes. It is helpful for catching bugs. Section 1.6 has described how to enter GDB debugger. This section illustrates some basic usage of GDB commands. For further information about GDB debugger and its commands, see <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 command (abbreviated). The usage can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Break.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Break.html</a>                                                                                                                                                                                                               |
| Watchpoint                     | \$ watch     | You can use a watchpoint to stop execution whenever the value of an expression changes. commands include <code>watch</code> , <code>rwatch</code> and <code>dwatch</code> . The usage of these commands can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Watchpoints.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Watchpoints.html</a> . Note Keep the range of watchpoints less than 20 bytes |
| Print breakpoint & watchpoints | \$ info      | To print a table of all breakpoints, watchpoints set and not deleted. You can simply type <code>info</code> to know its usage.                                                                                                                                                                                                                                                                                                   |
| Delete breakpoints             | \$ delete    | To eliminate the breakpoints, use the command (abbreviated). The usage can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Delete.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Delete.html</a>                                                                                                                                                                                                    |
| Continue                       | \$ continue  | To resume program execution, use the <code>c</code> command (abbreviated). The usage can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Contd.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Contd.html</a>                                                                                                                                                                                        |
| Step                           | \$ step      | To step into a function call, use the command (abbreviated). It will continue running your program until control reaches a different source line. The usage can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Contd.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Contd.html</a>                                                                                                                 |
| Next                           | \$ next      | To step through the program, use the command (abbreviated). The execution will stop when control reaches a different line or at the original stack level. The usage can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Contd.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Contd.html</a>                                                                                                         |
| Quit                           | \$ quit      | To exit GDB debugger, use the command (abbreviated), or type an end-of-file character (usually <code>Ctrl-d</code> ). The usage can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Quitting.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Quitting.html</a>                                                                                                                                       |
| Backtrace                      | \$ backtrace | A backtrace is a summary of how your program got where it is. Use the command (abbreviated) to print a backtrace of the entire stack. The usage can be found <a href="https://sourceware.org/gdb/current/onlinedocs/gdb/Backtrace.html">https://sourceware.org/gdb/current/onlinedocs/gdb/Backtrace.html</a>                                                                                                                     |
| Print source line              | \$ list      | To print lines from a source file, use the command (abbreviated). The usage can be found <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 the command (abbreviated). It evaluates and prints the value of an expression. The usage can be found <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

### 1.9.1

If you use \$ make all command to build code but encounter - Fig 1-30  
Both 32bit and 64bit operating system need to install Installation Cygwin Pack setupx86.exe

```

.../component/common/application/apple/homekit/crypto/poly1305 -l/cygdrive/f/v03
/project/realtek_amebaD_cm0_gcc_verification/asdk/../../../../component/common/application/apple/homekit/crypto/ed25519 -l/cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk/../../../../component/common/application/apple/homekit/crypto/sha512 -DCONFIG_PLATFROM_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_flashloader] Error 2
make[1]: Leaving directory '/cygdrive/f/v03/project/realtek_amebaD_cm0_gcc_verification/asdk'
make: *** [Makefile:15: all] Error 2

```

Fig1-30 Error 127

## 1.9.2 h

If you use `makeall` command to compile project but encounter 'Permission denied' like Fig1-31, 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 `file` and then continue compile operation.

```

===== 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/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

```

Fig1-31 h under Linux

## 1.9.3 How to Reset KM0/KM4 under Debug Mode?

Steps to reset KM0 and KM4 are different.

7 MU  
this file is under `project/realtek_amebaD_v4_example/RELEASE/project_lpassdk/gnu_utility/gnu_script/tl_gdb_debug.txt`. Please ult path of

7 MU  
of KM0). Then, set bit[25] of memory address 0x4800\_03f8 to 1 because the boot process of KM4 is controlled by the KM0.  
MU

instruction, a debug window pops up. In this window[ Set bit information.

Fig1-32 for more MU

Note Only resetting KM0 may cause KM0 to work in an abnormal way because KM0 will change some settings of KM4. If you find KM4 reboot you should reset KM4.



The screenshot shows a terminal window titled "D:\Project\Ameba\_D\Task\release\sdk-amebad-beta\_v5.2\sdk-amebad-beta\_v5.2\project\r...". The window displays a GDB session for a Realtek ASDK-6.4.1 Build 2778 version 7.12.50.20170111-git. The session starts with standard GDB license information and configuration details. It then shows the user setting a breakpoint at address 0x480003f8 with the command "breakpoint set <unsigned>0x480003f8=0x02000201". The user then continues execution with "c" and inspects memory with "x/1ux 0x480003f8". Finally, the user enables an interrupt with "InterruptRegister<IPC\_INTHandler, IPC\_IRQ, IPCM0\_DEU, 10>" and "InterruptEn<IPC\_IRQ, 10>".

```
GNU gdb <Realtek ASDK-6.4.1 Build 2778> 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.
0x0e007564 in ?? <>
Notification of completion for asynchronous execution commands is off.
Resetting target.
(gdb) x/1ux 0x480003f8
0x480003f8: 0x00000201
(gdb) set <unsigned>0x480003f8=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
216              InterruptRegister<IPC_INTHandler, IPC_IRQ, IPCM0_DEU, 10>;
(gdb) n
217              InterruptEn<IPC_IRQ, 10>;
(gdb) c
Continuing.
```

Fig1-32KM4 monitor resetSetting

## 2 SDK Architecture

The architecture of SDK is shown in Fig2-1.



Fig2-1 SDK architecture

### 2.1 component

#### 2.1.1 common

| Items       | Description                                                                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| api         | AT command<br>Platform_stdlib standard library header<br>Wi-Fi driver interface<br>Wi-Fi promisc mode interface<br>Wi-Fi simple configuration                                  |
| application | DuerOS<br>MQTT                                                                                                                                                                 |
| audio       | Audio related                                                                                                                                                                  |
| bluetooth   | Internal BT driver                                                                                                                                                             |
| drivers     | alc561 alc564 alc565 alc566 alc567 alc568 sgtl5000 drivers<br>IR NEC driver<br>SDIO host driver<br>Ameba-D internal code driver<br>USB host and device drivers<br>WLANS driver |
| example     | Utility examples: wlan_fast_connect, download, fatfs, mdns, media_geo_mp4                                                                                                      |
| file_system | Filesystem                                                                                                                                                                     |
| graphic     | JPEG decoder                                                                                                                                                                   |
| mbed        | mbedAPI source code                                                                                                                                                            |
| media       | Multi-media framework                                                                                                                                                          |
| network     | coap<br>dhcp<br>http<br>lwip<br>mDNS<br>rtsp<br>sntp<br>ssl(MBEDTLS)<br>tftp<br>websocket                                                                                      |
| test        | WLAN test file                                                                                                                                                                 |
| ui          | emWin<br>littlevGL                                                                                                                                                             |
| utilities   | cJSON<br>http_client<br>ssl_client                                                                                                                                             |

|       |                                    |
|-------|------------------------------------|
|       | tcpecho<br>udpecho<br>webserve\xml |
| video | Video related                      |

## 2.1.2 OS

| Items    | Description                                                                                                          |
|----------|----------------------------------------------------------------------------------------------------------------------|
| freertos | FreeRTOS source code                                                                                                 |
| os_dep   | osdep_service: Realtek encapsulating interface for FreeRTOS<br>osdep_service: Realtek encapsulating interface header |

## 2.1.3 SOC

| Items          | Description                                                                                    |
|----------------|------------------------------------------------------------------------------------------------|
| app            | monitor and shell                                                                              |
| bootloader     | Bootloader                                                                                     |
| cmsis          | ARM headers, include ARM CPU registers and operations                                          |
| cmsisdsp       | 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 |
| img3           | Files for image3                                                                               |
| imgtool_loader | Flash loader for image tool                                                                    |
| misc           | misc                                                                                           |
| swlib          | Standard software library supported by ROM code, like: _memcpy/_memcmp                         |

## 2.2 doc

| Items  | Description                              |
|--------|------------------------------------------|
| AN0004 | Realtek low power WiFi MP use guide      |
| AN0011 | Realtek WLAN simple configuration        |
| AN0012 | Realtek secure socket layer (SSL)        |
| AN0025 | Realtek AT command                       |
| AN0075 | Realtek Ameba AT command v2.0            |
| AN0096 | Realtek Ameba xmodemuart update firmware |
| UM0150 | Realtek Ameba CoAP User Guide.pdf        |

## 2.3 tools

| Items                  | Description                                                   |
|------------------------|---------------------------------------------------------------|
| ImageTool              | tools\Ameba\N\Image_Tool\image tool for Ameba                 |
| autopatch              | Automatically patched script                                  |
| bluetooth              | Tools for BT                                                  |
| DownloadServer         | Used to send image to device based on socket by OTA function. |
| DownloadServer(HTTP)   | Used to send image to device based on socket by OTA function. |
| file_check_sum         | File used to check sum for Flash                              |
| probe                  | Tools for RLX Probe debug                                     |
| serial_to_usb          | Driver for serial to usb                                      |
| simple_config_wizard   | Tools for WiFi simple configuration                           |
| simple_config_wizard_3 | Tools for WiFi simple configuration                           |
| iperf.exe              | iperf for WiFi performance test                               |

## 2.4 GCC Project for KM4

The architecture KM4 project shown in Fig2-2



Fig2-2 Architecture of KM4

| Items           | Description                                                                     |
|-----------------|---------------------------------------------------------------------------------|
| asdk            | Menuconfig<br>Link script<br>Library lib_wlana/lib_wps.a/rom_symbol<br>Makefile |
| example_sources | Peripherals driver demo code: ADC/Audio/LCD/UART/I2C                            |
| jlink_script    | J-Link script for KM4                                                           |
| toolchain       | GCC& Cygwin toolchain                                                           |
| Makefile        | Top Makefile                                                                    |

## 2.5 Critical Header Files

| Items             | Description                                                                                                                                                                       |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| basic_types.h     | SUCCESS/FAIL/TRUE/FALSE/NULL/u8/u16/u32/BOOL " @ u                                                                                                                                |
| platform_stdlib.h | Standard library API: memcmp/strcpy/atol/strupr/strcmp/scanf/fprintf/nprintf/vsnprintf                                                                                            |
| sectionconfig.h   | Section definition used in link script IMAGE2_RAM_TEXT_SECTION                                                                                                                    |
| mbedapi headers   | component/common/mbed/<br>Peripheral header files for mbed APIs<br>If you want to use mbed APIs, related headers must be included.                                                |
| ameba_soc.h       | Peripheral header files for raw APIs<br>Raw APIs have more features than mbed APIs, mbed APIs just have basic features.<br>If you want to use APIs, this header must be included. |

# 3 GCCMakefile

## 3.1 KM4 Makefile Architecture

The architecture of KM4 makefiles shown in Fig 3-1.

```
project\hp\Makefile->
    project\hp\asd\Makefile->
        project\hp\asd\make\Makefile->
            project\hp\asd\make\ap\Makefile
            project\hp\asd\make\app\Makefile
            project\hp\asd\make\application\Makefile
            project\hp\asd\make\audio\Makefile
            project\hp\asd\make\bootloader\Makefile
            project\hp\asd\make\cmsis\Makefile
            project\hp\asd\make\project\Makefile
                project\hp\asd\make\project\sram\Makefile how to build code into ram
                project\hp\asd\make\project\xip\Makefile how to build code into flash
                project\hp\asd\make\project\library\Makefile how to build library
            project\hp\asd\make\driver\Makefile
            project\hp\asd\make\example\Makefile
            project\hp\asd\make\file_system\Makefile
            project\hp\asd\make\mbed\Makefile
            project\hp\asd\make\mbed\ls\Makefile
            project\hp\asd\make\network\Makefile
            project\hp\asd\make\os\Makefile
            project\hp\asd\make\rtl_bluetooth\Makefile
            project\hp\asd\make\ss\Makefile
            project\hp\asd\make\target\Makefile
            project\hp\asd\make\utilities\Makefile
            project\hp\asd\make\utilities\example\Makefile
            project\hp\asd\make\wlan\Makefile
            project\hp\asd\make\wp\Makefile
            project\hp\asd\make\utilities\example\Makefile
```

Fig 3-1 KM4 Makefile Architecture

## 3.2 How to Build Code into Flash

Makefile in project\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 = $(ROOTDIR)/make/project/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_OBJS
#*****#
#          GENERATE OBJECT FILE
#*****#
CORE_TARGETS: $(OBJS)

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

-include $(DEPS)
```

### 3.3 How to Build Code into SRAM

Makefile in project\SRAM is an example for how to build code into SRAM

```

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 = $(ROOTDIR)/make/project/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)

```

### 3.4 How to Use Section Attribute

Because SRAM space is limited we suggest you build critical code/data into SRAM and leave data left in Flash. You should use section IMAGE2\_RAM\_TEXT\_SECTION

```
#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

const/readonly data will build into Flash

Non readonly data will build into SRAM

Functions limited by IMAGE2\_RAM\_TEXT\_SECTION build into SRAM

Functions not limited by IMAGE2\_RAM\_TEXT\_SECTION build into Flash

o k ^ U

## 3.5 How to Build Library

Makefile in project\library is an example for build user library

```
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 = $(ROOTDIR)/make/project/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
```

## 3.6 HowtoAdd library?

Open project\_h2asdk\Makefile and add lib\_user.a into LINK\_APP\_LIB

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

## 4 C++ Standard Supported in GCC

### 4.1 Introduction

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

Note iostream is not available currently.

### 4.2 To Compile C++ Codes

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

- (1) Modify the link script rlx8721d\_img2.ld (non-security) or rlx8721d\_img2\_tz.ld (security)

```
.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(*(.SORT(.init_array.*)))
    KEEP(*(.init_array))
    __init_array_end = .;
    . = ALIGN(4);
    __fini_array_start = .;
    KEEP(*(.SORT(.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 strchr = 0x10111675;
__wrap_strcmp = 0x10111745;
__wrap_strncmp = 0x101118f9;
__wrap_strlen = 0x10111839;
__wrap_strlenn = 0x10111a05;
__wrap_strncat = 0x1011189d;
__wrap_stropbrk = 0x10111a39;
__wrap_strstr = 0x10111d25;
__wrap_strtok = 0x10112010;
__wrap_strsep = 0x10111a65;
__wrap strtoll = 0x10111ff9;
__wrap strtoul = 0x101122e9;
__wrap strtoull = 0x10111f3d;
__wrap_atoi = 0x101115e1;
__wrap strcpy = 0x101117b9;
__wrap strncpy = 0x1011199d;
__wrap memset = 0x10110ea1;
__wrap memcpy = 0x10110d2d;
__wrap memcmp = 0x10110cc9;
__wrap memmove = 0x10110dd9;
__wrap_snprintf = 0x1010a49d;
__wrap_malloc = pvPortMalloc;
__wrap_realloc = pvPortReAlloc;
__wrap_free = vPortFree;
/*-----*/
```

- (2) Modify startup code 8721dhp\_app\_start.c

```

#ifndef __GNUG__
/* 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(SUCall IRQn, (UUID*)vPortSUCHandler);
    __NUIC_SetVector(PendSU IRQn, (UUID*)xPortPendSUHandler);
    __NUIC_SetVector(SysTick IRQn, (UUID*)xPortSysTickHandler);

#if defined ( __ICCARM__ )
    __iar_cstart_call_ctors(NULL);
#endif

#ifndef __GNUG__
    /* 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\n"
        "mov sp, r0\n"
    );
}

main();
}

```

## (3) Modify makefile

project\realtek\_amebaD\_va0\_exam\RELEASE\project\_h\asdk\Makefile

```

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

```

project\realtek\_amebaD\_va0\_exam\RELEASE\project\_h\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 += -DDM_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,--cref
LD_ARG += -Wl,--build-id=none
LD_ARG += -save-temps

LD_ARG += -Wl,-wrap,strcat -Wl,-wrap,strchr -Wl,-wrap,strcmp
LD_ARG += -Wl,-wrap,strncmp -Wl,-wrap,strcpy -Wl,-wrap,strncpy
LD_ARG += -Wl,-wrap,strncpy -Wl,-wrap,strlen -Wl,-wrap,strlcpy
LD_ARG += -Wl,-wrap,strnlen -Wl,-wrap,strncat -Wl,-wrap,strpbrk
LD_ARG += -Wl,-wrap,strstr -Wl,-wrap,strtok -Wl,-wrap,strspn
LD_ARG += -Wl,-wrap,strsep #-Wl,-wrap,strxfm -Wl,-wrap,strtod
LD_ARG += -Wl,-wrap,strtoil #-Wl,-wrap,strtof -Wl,-wrap,strtold
LD_ARG += -Wl,-wrap,strtoul -Wl,-wrap,strtoull -Wl,-wrap,atoi
LD_ARG += #-Wl,-wrap,atoui -Wl,-wrap,atol -Wl,-wrap,atoul
LD_ARG += #-Wl,-wrap,atoui1 -Wl,-wrap,atof
LD_ARG += -Wl,-wrap,malloc -Wl,-wrap,free -Wl,-wrap,realloc
LD_ARG += -Wl,-wrap,memcmp -Wl,-wrap,memcpy
LD_ARG += -Wl,-wrap,memmove -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 #
#####

%.o:%.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 at

## (5) Use command in console to compile project with C++ files.

# 5 GCC Standard Library

## 5.1 Introduction

This chapter mainly introduces how to use the 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 `scanf`.

There are two methods when using standard library functions such as `printf` and `scanf` in GCC:

- Using ROM software library
- Using GCC standard library

## 5.2 Default Use of Library Function

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



Fig 5-1 Library function guide

Table 5-1 Default use of library function

| Item                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Using ROM software library | <code>memchr</code> / <code>memcmp</code> / <code>memcpy</code> / <code>memset</code> / <code>memmove</code> / <code>strcmp</code> / <code>strcpy</code> / <code>strlen</code> / <code>strncmp</code> / <code>strncpy</code> / <code>strsep</code> / <code>strtol</code> / <code>strcat</code> / <code>/strchr</code> / <code>/strncat</code> / <code>/strstr</code> / <code>/atol</code> / <code>/atoi</code> / <code>/strpbrk</code> / <code>/strtoul</code> / <code>/strtol</code> / <code>/rand</code> / <code>/srand</code> |
| Using GCC standard library | <code>fprintf</code> / <code>puts</code> /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Library is configurable    | <code>printf</code> / <code>sprintf</code> / <code>nprintf</code> / <code>vsprintf</code> / <code>sscanf</code><br>Note: The default library is ROM software library, you can switch to GCC standard library by defining macro <code>STD_PRINTF</code>                                                                                                                                                                                                                                                                           |

Because `printf`/`sprintf`/`nprintf`/`vsprintf`/`sscanf` in ROM software library are simplified version compared with these in GCC standard library, they only support a few formats. Under normal circumstances, users should mind that unsupported formats will cause errors when using these functions in ROM library. SDK wraps up these functions.

Table 5-2 Wrapper functions

| Item                | Wrapper Function         |
|---------------------|--------------------------|
| <code>printf</code> | <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 without using these functions in ROM software library.

## 5.3 To Use Configurable Functions in GCC Standard Library

Compared to printf/sprintf/snprintf/vsnprintf/sscanf functions in GCC library, they 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 library | %s, %x, %X, %p, %d, %c                              |
| GCC standard library | %s, %x, %X, %p, %P, %d, %E, %L, %I, %u, %U, %e, %E, |

For printf/sprintf/snprintf/vsnprintf/sscanf in ROM library is linked by default format not support log dumps out in trace file, means that unsupported format occur you should link these functions to GCC standard library.

To use printf/sprintf/snprintf/vsnprintf/sscanf in GCC standard library, follow the

- Add #define STD\_PRINTF at the front.

There are two cases:

| Item   | Operation                                                                     | Description                                                                                                                                                                                                                                                          |
|--------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| case 1 | Add #define STD_PRINTF at the front of c files, and include platform_stdlib.h | Change printf/sprintf/snprintf/vsnprintf/sscanf of some file 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 at the front of platform_stdlib rtl8721d.h             | Change printf/sprintf/snprintf/vsnprintf/sscanf of all SDK link to GCC standard library                                                                                                                                                                              |

- Modify platform\_stdlib rtl8721d.h if you don't want to switch to use all the five functions in GCC standard library  
In SDK, macro STD\_PRINTF controls printf/snprintf/vsnprintf/sscanf at the same time. If you only want to configure some but not all, for example, you only want to use printf in GCC standard library, and other four functions maintain the default state, you need to modify platform\_stdlib rtl8721d.h.



## 5.4 Tips

If you want to use GCC standard library, we recommend only link some user specified c files to GCC standard library, all SDK to GCC standard library, because printf/sprintf/sprintf/vsnprintf/sscanf our SDK should link to ROM standard library.

If using printf in GCC standard library.c, and there is "\n" in the end, use fflush(stdout) after printf to dump log in cache. For example:

```
printf("hello");
fflush(stdout);
```

In current GCC project, KMO does not support point temporarily so printf cannot dump %f in KMO in default setting.

If using sscanf in GCC standard library.c, delete \_strtol\_and \_strtoul\_symbols in rlx8721d\_rom\_symbol\_acut.ld

# 6 IAR Build Environment Setup

This chapter illustrates how to setup IAR development environment for Realtek Ameba DSK including building projects, downloading images and debugging.

## 6.1 Requirement

### 6.1.1 IAR Embedded Workbench

IAR Embedded Workbench (IAR EWARM) is a professional software tool for developing embedded systems. It includes a C/C++ compiler, linker, debugger, and various tools for real-time operating systems like FreeRTOS. You can download it from <http://www.iar.com/> and a trial version is available for 30 days.

Note To support ARM® Cortex® M4 with Security Extension (Ameba D HS CPU, also called K40), version must be 8.30 or higher.

### 6.1.2 J-Link or RLX Probe

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

Note: For Ameba D CPU, the JLink version must be 8.0 or higher.

## 6.2 Hardware Configuration

The hardware block diagram of Ameba D demo board is shown in Fig 6-1.

USBUART: supply power and print logs, baud rate is 115200 bps.

SWD SWD interface, used for image downloading and debugging with IAR.

Reset button reset Ameba D to run firmware after IAR completes downloading.



Fig6-1 Ameba-D demo board

### 6.2.1 Connecting with link

Refer to Fig6-2 and Fig6-3 to connect Ameba-D SWD interface with link.



J-Link

Fig6-2 J-Link and SWD connection diagram



Fig6-3 J-Link and AmbeB SWD connection

## 6.2.2 Connecting with RTDX Probe

Refer to Fig6-4 and Fig6-5 to connect AmbeB SWD interface with RTDX probe



Fig6-4 RLX Probe and SWD connection diagram



Fig6-5 RLX Probe and Ameba-D SWD connection

## 6.3 How to Use IAR SDK?

### 6.3.1 IAR Project Introduction

Because Ameba-D is a dual-core CPU platform, two workspaces are provided to build for each core in project `realtek_amebaD_v0_Example\ARM\RELEASE`

Project `lp_release.eww`(KM0 workspace) contains the following projects:

- `km0_bootloader`
- `km0_application`

Project `hp_release.eww`(KM4 workspace) contains the following projects:

- `km4_bootloader`
- `km4_application`
- `km4_secure`

Each project in KM4 workspace has different configurations as Table 6-1 shows.

Table6-1 Build configurations for KM4 project

| Project         | Build Configuration           | ConfigureTrustZone | EnableMP |
|-----------------|-------------------------------|--------------------|----------|
| km4_bootloader  | km4_bootloaderis <sup>1</sup> | N                  | N        |
|                 | km4_bootloadertz <sup>2</sup> | Y                  | N        |
| km4_application | km4_applicationis             | N                  | N        |
|                 | km4_applicationtz             | Y                  | N        |
|                 | km4_applicationis (mp)        | N                  | Y        |
|                 | km4_applicationtz (mp)        | Y                  | Y        |
| km4_secure      | km4_securetz                  | Y                  | N        |
|                 | km4_securetz (mp)             | Y                  | Y        |

Note:

1. The configuration
2. The configuration
3. The configuration items

For applications that do not use TrustZone, users apply more secure configurations. Table 6-2 shows the km4\_secure project which contains TrustZone protected code, is not used.

For applications that use TrustZone, users apply TrustZone configurations. Table 6-2 shows.

Table6-2 Configurations for project without TrustZone

| Project         | TrustZone | Normal Image      | MP Image               |
|-----------------|-----------|-------------------|------------------------|
| km4_bootloader  | N         | km4_bootloaderis  | km4_bootloaderis       |
|                 | Y         | km4_bootloadertz  | km4_bootloadertz       |
| km4_application | N         | km4_applicationis | km4_applicationis (mp) |
|                 | Y         | km4_applicationtz | km4_applicationtz (mp) |
| km4_secure      | Y         | km4_securetz      | km4_securetz (mp)      |

At the top of the Workspace window there is a dropdown list where you can choose a build configuration for a specific project.



Fig6-6 How to choose a build configuration

## 6.3.2 IAR Build

When building SDK for the first time, you should build both KMO project and KM4 project. Other times, you only need to rebuild project.

### 6.3.2.1 Building KMO Project

The following steps show how to build KMO project:

- (1) Open project \realtek\amebaD\@0\_example\RELEASE\Project\_ip\_release.eww

- (2) Make sure km0\_bootloader and km0\_application are in Workspace>Project>Options>General Options>Target>Processor Variant>Core verify the CPU configurations according to Fig6-7



Fig6-7 KMO processor options

Note If you have installed IAR version 9.xx or above from official website > Option> Project and make ensure the setting U (3) V



- (3) k

Fig6-8 shows. The km0\_bootloader and km0\_application should compile in order.



Fig6-8Building KMO project

Note: After building each project, IAR will pop up a command prompt window to execute `arm-none-eabi-gdb` to generate images from executable. When the build action is completed, the window will disappear automatically.

```
C:\Windows\System32\cmd.exe
ug\Exe\km0_image\km0_application.map Debug\Exe\km0_image\km0_application.asm Debug\Exe\km0_image\km0_application.dbg.axf

D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE>cmd /c
""D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE"..\..\..\component\soc\realtek\amebad\misc\iar_utility\common\tools\nm Debug\Exe\km0_image\km0_application.axf | "D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE"..\..\..\component\soc\realtek\amebad\misc\iar_utility\common\tools\sort > Debug\Exe\km0_image\km0_application.map"

D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE>cmd /c
""D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE"..\..\..\component\soc\realtek\amebad\misc\iar_utility\common\tools\objdump -d Debug\Exe\km0_image\km0_application.axf > Debug\Exe\km0_image\km0_application.asm"

D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE>for /F "delims=" %i in ('cmd /c ""D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE"..\..\..\component\soc\realtek\amebad\misc\iar_utility\common\tools\grep IMAGE2 Debug\Exe\km0_image\km0_application.map | "D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE"..\..\..\component\soc\realtek\amebad\misc\iar_utility\common\tools\grep Base | "D:\Code\AmebaD\v03_0903\project\realtek_amebaD_va0_example\EWARM-RELEASE"..\..\..\component\soc\realtek\amebad\misc\iar_utility\common\tools\gawk '{print $1}'") do set ram2_start=%i
0x21
```

(4) After compile, the images `km0_boot_all.bi` and `km0_image2_all.bin` can be seen in the project `realtek_amebaD_va0_example\EWARM-RELEASE\Debug\Exe\km0_image`

### 6.3.2.2 Building KM4 Project

The following steps show how to build KM4 project:

- (1) Open project `realtek_amebaD_va0_example\EWARMRELEASE\Project_b_release.eww`
- (2) Refer to 6.3.1 and choose the build configurations for each project according to your application.

(3) Click Project>Options>General Options>Target>Processor Variant>Core verify the CPU configurations according to Fig6-9



Fig6-9 KM4 processor options

Note If you have installed IAR version 9.xx or above from official website > Option>Project and make ensure the setting (4)



(4) km4\_bootloader, km4\_secure and km4\_application should compile in order.

Fig6-10 shows. The km4\_bootloader, km4\_secure and km4\_application should



Fig6-10BuildingKM4 project

Note:

When TrustZone is enable, the km4\_secure project must be built before the km4\_application project. When TrustZone is not used, there is no need to compile the km4\_secure project.

After building each project, IAR will pop up a command prompt window to execute `option` to generate images from executable. You can stop it while it is in progress. After compilation is completed, the window would disappear automatically.

```
cmd C:\Windows\System32\cmd.exe
is_law = 1
start = 2000000, end = 2000000, base = 2000000
Input file size: 0
copy size 0
start = 10005000, end = 10019294, base = 10000000
Input file size: 82580
copy size 82580
start = e0000020, end = e04f044, base = e0000000
Input file size: 323620
copy size 323620
start = 2000000, end = 2000000, base = 2000000
Input file size: 0
copy size 0
Debug\Exe\km4_image\xip_image2.p.bin
Debug\Exe\km4_image\xram_2.p.bin
Debug\Exe\km4_image\xpsram_2.p.bin
已复制 1 个文件。
pad.exe, img_len: 63318, pad_len: ce8
Debug\Exe\km0_image\km0_image2_all.bin
Debug\Exe\km4_image\km4_image2_all.bin
已复制 1 个文件。
IAR ELF Linker V8.30.1.114/W32 for ARM
Copyright 2007-2018 IAR Systems AB.
```

- (5) After compile, the images `km0_image2_all.bin` and `km0_km4_image2.bin` can be seen in `project\realtek_amebaD_va0_example\WARM-RELEASE\DebugExe\km4_image`. For MP configurations, `km0_km4_image2.mpbin` would be generated instead.

### 6.3.3 IAR Download

The generated images can be downloaded in two ways:

IAR JLink or RLX Probe SWD (introduced in the next section)  
Ameba-D ImageTool, refer to ImageTool for more information.

Ameba-D demo board supports using J-Link and RLX Prog SW to download and debug. Image of each project can be downloaded individually.

Note Considering KM4 is powered by KMO, you should make sure that KMO has boot up already before downloading images to KM4. Otherwise for J-Link, Fig6-11 shows J-Link Driver dialog box "Could not find core in Coresight setup Abort debug session?" is displayed when KM4 is not booted.



Fig6-11 J-Link cannot 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 KMO boots up
- (3) Download for km4\_bootloader and km4\_application projects

During development, if Flash memory is not empty and KM4 can boot successfully, then you can download updated images to KM4 directly, and there is no need to download for KMO.

The following steps show how to download image for the target project with J-Link. If there is an error like Fig6-24 displayed in IAR window refer to 6.3.4.3.

- (1) Choose the target project display in Workspace window for km4\_bootloader Fig6-12 shows.
- (2) If using J-Link debugger, check whether the J-Link debugger setting is correct
  - a) Click Project > Options > Debugger > Setup > Driver -Link/J-Link/J-Trace Fig6-13 shows.
  - b) Click Debugger > J-Link/J-Trace > Connection > Interface Fig6-14 shows.



Fig6-12Switching to the target project view



Fig6-13J-Link debugger setup



Fig6-14 J-Link interface setup

(3) If using RLX Probe whether the RLX Probing is correct

- Click Project > Options > Debugger > Setup > Driver
- Click GDB Server > GDB Server and select localhost, port number

KM4: The default port numbers is 3333, which is set in the realtek\_amebaD\_va0\_exam1\ARM\RELEASE\probe\cm4rlx\_probe0.cfg  
KMO: The default port numbers is 2331, which is set in the realtek\_amebaD\_va0\_exam1\ARM\RELEASE\probe\cm0rlx\_probe0.cfg

- Open RLX Probe in project\realtek\_amebaD\_va0\_exam1\ARM\RELEASE\probe\cm4\cm4\_RTL\_Probe as Fig6-17 shows.  
Note The board must be reset before opening the RLX Probe, otherwise the connection may fail.



Fig6-15 RLX Probe setup



Fig6-16RLX Probe interface setup

```
C:\Windows\system32\cmd.exe
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 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 is 8Words
    The processor's D-cache size is 4KB!
/***** TAP 1 Core 0 Initialize Over ! *****
      SUCCESS to Trigger this Core
/*****
```

Fig6-17RLX Probe window

- (4) Click Project->Download>Download active application, image downloading starts.  
When downloading Ameba-D prints the log as Fig6-18 shows. You can check the log to see if download is successful.

```
[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:8000000, flags:0
[FlashErase] block_start:0000, 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:0000, 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
```

Fig6-18 Downloading log

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



Fig6-19 Erasing Flash memory

### 6.3.4 IAR Debug

You can debug KMO and KM system individually with JLink or RLX Pro SWD.

Note: Considering KM4 is powered by KMO, you should make sure that KMO has already boot up before debug KM4. For KMO, there is no requirement because KMO is powered immediately after reset.

### 6.3.4.1 J-Link Debug

Follow the steps to debug and trace code of target project with IAR J-Link:

- (1) Set the target project as active project and modify the debugger configurations as step(2)
- (2) Click Project->Download and Debug or Project->Debug without Downloading

Download and Debug downloads the application and debug the project file. If necessary, a make will be performed before download to ensure the project is up to date.

Debug without Download debugs the project object file

- (3) When starting IAR C-SPY to debug, it will firstly reset the target CPU and run to the main function. Fig6-20 shows
- (4) Toggles a breakpoint at the statement or instruction that contains main in the source window. The button is on the debug toolbar. Fig6-21 shows.



Fig6-20 Running to main() when debug



Fig6-21Toggle breakpoint

(5) You can trace

O

@

8

Note If you want to trace the code step by step in km4\_bootloader Options&gt;Click C++ Compiler&gt;Output&gt;Generate under

8



### 6.3.4.2 RLX ProbDebug

Follow the steps to debug and trace code of target project with IAR by RLX Probe:

- (1) Set the target project as active project and modify the debugger configurations as step(3)
- (2) Click Project > Attach to Running Target
- (3) Set the target address.

When starting debug with RLX Probe it will firstly reset the target CPU. If you want to run to a target address at first, you can set the target address in project\realtek\_amebaD\va0\_exam\WARMRELEASE\probe\cm4rlx\_probe0.cfg the method is that comment Fig6-22and Fig6-23shows.

```
/*
 * Set PC address
 *
 * description: When starting debug, the code will run to the address
 *               0xe03f048.
 */
//ew .pc = 0xe03f048;
```

Fig6-22Setting the target address



Fig6-23Running to the target address when debug

- (4) Toggles a breakpoint at the statement instruction that contains or is located in the cursor in the source window. The "Breakpoint" button is on the debug toolbar. Fig6-21shows.
- (5) You can trace c

### 6.3.4.3 IAR Debug Download Error

Because Ameba-D has two CPU cores, and build script will be run after make, sometimes the debug or download threads cannot get correct AXF file for download, the error like Fig6-24 happens



Fig6-24 IAR debug or download error

To avoid this error, you should build manually before debug or download and disable auto-build from Tools > Options > Project > Make before debugging as Fig6-25 shows



Fig6-25IDE options

### 6.3.5 IAR Memory Configuration

#### 6.3.5.1 Configuring Memory from IAR IDE

In order to allow users to manage memory flexibly there are some configurations put some code into certain memory region.

Note:# o k ° U and h o k ° U  
group o k ° U would be linked and loaded into SRAM. The rest of code will be placed on Flash and execute in place.

Note:# o k ° U h o k ° U  
o k ° U t be placed outside these two groups.



Fig6-26Memory location configuration

### 6.3.5.2 Configuring Memory from ICF File

IAR uses ICF (IAR Configuration File) to configure memory allocation. You can configure memory allocation by ICF file.

ICF file of Ameba-D location:

```
\realtek_amebaD_va0_exampl\ARMRELEASE  
\realtek_amebaD_va0_exampl\ARMRELEASE
```

for TrustZone project

If having a good understand of the format `secCear` modify the section location in ICF file.

## 6.4 How to Build Sample Code?

The example source code located in project\realtek\_amebaD\_va0\_exampl\example\_source\\$ to build sample code, you should copy project\realtek\_amebaD\_va0\_exampl\src\h and replace the original one.

7 project\realtek\_amebaD\_va0\_exampl\example\_source\\$2\mbed\i2c\_int\_mod\\$rc to use i2c\_int\_mod example code, Fig6-27 shows.



Fig6-27Building sample code

## 6.5 Used Memory Size Calculation

This section explains how to calculate used memory sizes in IAR projects whose version is V6.0.1 or higher. You can refer to the following folders:

Project folder\project\realtek\_amebaD\_va0\_example\{EWARM RELEASE\Debug\List\km4\_application.map



### 6.5.1 Memory Section

A7 (PSRAM): This section is read/write data in PSRAM (0x20000000 to 0x80000000).

BTTRACE: This section is reserved for BTTRACE.

A5 (XIP): This section is read-only data in XIP.

A4 (SRAM) This section is read/write data in SRAM

P1 (SRAM) This BSS section in SRAM

## 6.5.2 MemorySize

### 6.5.2.1 Memory Size in SRAM

There are two sections resides in SRAM which are A4 and P1. As we can see in the map file, for standard SDK, these two sections use almost all of the memory space in SRAM(476KB).

A4 has size 0x7ad7.

|                    |             |         |                            |
|--------------------|-------------|---------|----------------------------|
| "A4":              |             | 0x17ad7 |                            |
| IMAGE2             | 0x1000'5000 | 0x17ad7 | <Block>                    |
| .ram image2.entry  | 0x1000'5000 | 0x20    | <Block>                    |
| .image2.entry.data | 0x1000'5000 | 0xc     | rtl8721dhp app start.o [1] |

P1 has size 0xdxfc8.

|                         |             |             |         |                             |
|-------------------------|-------------|-------------|---------|-----------------------------|
| "P1":                   |             | 0x5dfc8     |         |                             |
| .ram heap.data          | 0x1001'cae0 | 0x50000     | <Block> |                             |
| .ram image2.bfsram.data | 0x1001'cae0 | 0x50000     | <Block> |                             |
| .bfsram.data            | uninit      | 0x1001'cae0 | 0x50000 | freertos heap5 config.o [1] |

So totally 0x17ad7 + 0xdxfc8 = 476K bytes memory in SRAM used.

The total SRAM space is defined in project\realtek\_amebaD\_va0\_example\WARMRELEASE\rtl8721d\_memory\_layout\_is.icf

```
define symbol __ICFEDIT_region_HS_BD_RAM_NS_start__ = 0x10005000;
define symbol __ICFEDIT_region_HS_BD_RAM_NS_end__ = 0x1007C000-1;
```

For this case, the total size of SRAM is 0x1007C000 - 0x10005000 = 72000 - 476Kbytes there is still 64K = 476K bytes free SRAM space.

### 6.5.2.2 MemorySize in PSRAM

There is one section in PSRAM called A7 the memory space from SRAM(4MB).

A7 has size 0x54800

|               |            |            |         |                      |
|---------------|------------|------------|---------|----------------------|
| "A7":         |            | 0x54800    |         |                      |
| IMG2_PSRAM    | 0x200'0000 | 0x0        | <Block> |                      |
| .psram_ns.bss | 0x200'0000 | 0x54800    | <Block> |                      |
| .psram.bss    | 0x200'0000 | 0x54800    | <Block> |                      |
| .psram.bss    | uninit     | 0x200'0000 | 0x54800 | rtw opt skbbuf.o [1] |

So totally 0x54800 bytes memory in PSRAM used

### 6.5.2.3 MemorySize in XIP

XIP can only place text section, so there is only one section A5

A5 has size 0x8e8

```
"A5":                                     0x8afe8
    .xip image2.text           0xe00'0020  0x8afe8 <Block>
        .text                 ro code   0xe00'0020      0xfc app task.o [1]
        .text.os msg queue create intern
            ro code   0xe00'011c      0x40 os msg.o [2]
```

So totally 0x88 = 55K bytes memory XIPs used

#### 6.5.2.4 AvailableHeapSize

When calculating total used memory size, available heap size ~~WLAN association and BT connection~~ needs to be considered. In the above case, it is 6096 bytes.

The screenshot shows a terminal window titled "COM56 - Tera Term VT". The menu bar includes File, Edit, Setup, Control, Window, and Help. Below the menu, there is a table of memory usage:

|            | B | S | 588  | 23 |
|------------|---|---|------|----|
| UpperStack | B | S | 588  | 23 |
| trace_task | B | S | 76   | 22 |
| ble_centr  | B | S | 220  | 25 |
| cmd_thread | B | S | 750  | 20 |
| rtw_inter  | B | S | 208  | 19 |
| rtw_recv_  | B | S | 743  | 17 |
| LOGUART_T  | B | S | 2004 | 2  |
| rtw_xmit_  | B | S | 216  | 18 |

At the bottom of the terminal window, a message reads: "[MEM] After do cmd, available heap 56096".

Finally, you can use total SRAM 6K bytes to subtract these sections of memory to obtain totally free global memory in SRAM heap.

Formula is as below:

SRAM free global memory 476K A4 P1 4761024 96983 3849685473 (bytes)

Available heap 56096 bytes.

Totally free SRAM memory and heap 4735609661569 bytes)

Totally free PSRAM memory 4\*1024\*1024338 \* 1024 (A7) = 38480928

# 7 Demo Board

## 7.1 PCB Layout Overview

The PCB layout of 2D and 3D are shown in Fig 7-1 and Fig 7-2



Fig 7-1 Demo board PCB layout(2D)



Fig 7-2 Demo board PCB layout(3D)

## 7.2 Pin Out

The pin outboard is shown in Fig 7-3.



Fig 7-3 Demo board pin out

There are four rows of pins on the board.

The pins in the red box are used for Arduino REF

The pins in the blue box are all the GPIO pins

## 7.3 DC Power Supply

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

Jump JP1 is used to select 3.3V or 1.8V power supply

Jump J38 is for current test. You can test the power after taking off the R43.



Fig 7-4 Demo board 3.3V/1.8V power supply

When you select power supply, 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-5 and Fig 7-6.



Fig 7-5 Mother board USB interface configuration



Fig 7-6 Moduleboard USB interface configuration

For normal GPIO usage by default R72/R75/R76 mother board will part on with 0 Ohm resistors, R5 on module board needs to take off. USB usage you need to take off R7 part on R73&R74 with 0 Ohm resistors on mother board and part on R5 on module board with a 12K 1% precision resistor.

7.5 LOGUART

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



Fig 7-7 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-8



Fig 7-8 Demo board SWD

Note For 1VO board, there is a ~~bug~~, should use CLK as DATA, and use DATA as CLK.

## 7.7 VBAT ADC

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



Fig 7-9 Demo board VBAT ADC

# 8 ImageTool

## 8.1 Introduction

This chapter introduces how to use ImageTool to generate and download images. Fig8-1 shows ImageTool has four tabs: Download, Generate, Encrypt, and Security.

Download: used as image download server to transmit images to Ameba through UART

Generate: concat individual images and generate a composite image

Encrypt: encrypt images which are used for firmware protection

Security: generate key pair and signature for bootloader and save as new image



Fig8-1 ImageTool UI

## 8.2 Environment Setup

### 8.2.1 Hardware Setup

The hardware setup is shown in Fig8-2.

Note If using external UART to download images, FT232 USB dongle must be used.



Fig8-2 Hardware setup

## 8.2.2 Software Setup

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

| Name                           | Date modified      | Type                  | Size   |
|--------------------------------|--------------------|-----------------------|--------|
| ChangeLog.txt                  | 7/29/2019 11:52 AM | Text Document         | 4 KB   |
| Download.ini                   | 11/4/2019 5:44 PM  | Configuration sett... | 2 KB   |
| Encrypt.ini                    | 11/4/2019 5:44 PM  | Configuration sett... | 1 KB   |
| <b>ImageTool.exe</b>           | 7/29/2019 11:52 AM | Application           | 282 KB |
| ImageTool.pdb                  | 7/29/2019 11:52 AM | VisualStudio.pdb....  | 178 KB |
| ImageTool.vshost.exe           | 8/20/2018 1:41 PM  | Application           | 14 KB  |
| ImageTool.vshost.exe.manifest  | 8/20/2018 1:41 PM  | MANIFEST File         | 1 KB   |
| imgtool_flashloader_amebad.bin | 6/6/2019 3:15 PM   | BIN File              | 5 KB   |
| imgtool_flashloader_amebaz.bin | 6/6/2019 3:15 PM   | BIN File              | 6 KB   |
| SB.exe                         | 8/20/2018 1:41 PM  | Application           | 189 KB |
| system.bin                     | 8/6/2019 9:53 AM   | BIN File              | 4 KB   |
| TestListView.dll               | 8/20/2018 1:41 PM  | Application extens... | 5 KB   |
| TestListView.pdb               | 8/20/2018 1:41 PM  | VisualStudio.pdb....  | 14 KB  |

## 8.3 Download

### 8.3.1 Image Download

Assuming that the ImageTool on PC is a server, it sends images file(s) to Ameba through UART. There are two ways to download images to board.

#### 8.3.1.1 Based on HardwareReset

The way based on hardware reset is a manual method to download images and it is the primary recommended method.

- (1) Enter into UART\_DOWNLOAD mode
  - a) Push the UART DOWNLOAD button and keep it pressed.
  - b) Re-power on the board or press Reset button.
  - c) Release the UART DOWNLOAD button.

Now, Ameba board gets into UART\_DOWNLOAD mode and is ready to receive data.
- (2) Click Chip Select (in red) on UI and select AmebaD or AmebaZ
- (3) Select the corresponding serial port and transmission rate. The default baud rate is 1.5Mbps (recommended)
- (4) Click the Browse button to select the images (km0\_boot\_all.bin/km4\_boot\_all.bin/km4\_image2.bin) to be programmed and input addresses.

The image path is located `{path}\project\realtek_amebaD_va0_exam1\RELEASE\project_h\pasdk\image` and `{path}\project\realtek_amebaD_va0_exam1\RELEASE\project_h\pasdk\image` where `{path}` is the location of the project on your own computer.

The default target address is the SDK default address you can use 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 successfully or errors from the log window.



Fig 8-3 ImageTool Download tab page setting

### 8.3.1.2 Based or Command

The way based on command is the auto download and alternate method to download images. Based on HardwareReset, the auto download method is dependent on the command in SDK.

Steps Execute step (2)~(5) mentioned in section Based on HardwareReset.

After that, Ameba board will enter UART\_DOWNLOAD mode, and automatically response to the command. Note: uartburn command is not removed from SDK and KM4 is running normally.

Note: The command reboot uartburn (o ) M  
Based on HardwareReset.

### 8.3.2 Flash Erase

Steps to erase Flash are as follows:

- (1) Ameba enters into UART\_DOWNLOAD mode as introduced in section

- (2) Select the corresponding serial port and baud rate.
- (3) Input erase start address which has ~~by the~~ aligned.
- (4) Input erase size which ~~will~~ 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



Fig8-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) state. To release Flash from WP state, the BPs in status register should be cleared. ImageTool provides the function to get the flash status register value. To use it, the following steps are necessary

- (1) Check the Read/Write Status Register Command and Sequence after ~~the~~ Flash datasheet. Notice that different Flash would have different sequence.
- (2) Get Ameba into UART\_DOWNLOAD mode introduced in sect~~8.1~~ 8.1
- (3) Select the corresponding serial port and baud rate.
- (4) Click Advanced Setting button in Fig8-5, and the Advanced Setting window shown in Fig8-6 popups.



Fig8-5 AdvancedSetting

- (5) Select Read/WriteCommand and length according to Flash datasheet. If writing status to Flash, remember to input value.
- (6) Click Readbutton to read status register value. Click Writebutton to write status value to Flash.



Fig8-6 Flash status operation

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

To clear BP bits, add status register configuration below

Read Command: 0x05

Read Length: 1 Byte

Write status register configuration below

Write Command: 0x01

Write Length: 1 Byte

Register1 Value: 0x40

Table 8-1 MXIC Flash status register

| Bit | Name | Description                                                                                      | Volatile Bit |
|-----|------|--------------------------------------------------------------------------------------------------|--------------|
| 7   | SRWD | Status register write protect<br>1: Status register write disable<br>0: Status register writable | No           |
| 6   | QE   | Quad enable.<br>1: Quad enable<br>0: Not Quad enable                                             | 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>1: Write enable<br>0: Not write enable                                    | Yes          |
| 0   | WIP  | Write in progress bit.<br>1: In write operation<br>0: Not in write operation                     | Yes          |

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

## 8.4 Generate

u 8

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

### 8.4.1 Merge Images

Steps to generate composite image are as follows:

- (1) Select Image\_Alias Generate Target type (1)
- (2) Click Browse button to select images to be contacted and input corresponding 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.
- (3) Click Generate button Specify the output file name and path yourself in the pop-up Save As window, the final image (Image\_All.bin) is generated



Fig8-7 Image\_Allbin generation

### 8.4.2 Generate Cloud OTA Image

Steps to generate a Cloud OTA image are as follow

- (1) Select OTA\_All as Generate Target type (1)
- (2) Input Image Version the default value is OxFFFFFFF

- (3) Click **Browse** button to select images. The address can be ignored. The **Memory Layout** 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 the name and path of the output file. After the operation is done, the **image** (OTA\_All.bin) is generated.



Fig8-8OTA\_All generation

## 8.5 Encrypt

The - encrypting images which is used in firmware protection. Steps to encrypt images are as follows:

- (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 encrypted file after the suffix .enc after the original file, which located in the same directory.



Fig8-9 ImageTool - setting

## 8.6 Security

u Securitytabpage is used to generate secure boot image. Steps to generate Secure Boot images:

- (1) InputSeed(32 bytes), which is used to generate key pair.
- (2) ClickGen Keypairbutton to generate Public Key and Private Key.
- (3) ClickBrowsebutton to select the bootloader image and input the Flash address of this image.
- (4) ClickGen Signaturebutton to calculate signature for the image.
- (5) ClickSave Imagebutton to generate the new image which contains Secure Boot information and signature.



Fig8-10ImageToolSecuritytabpage setting

# 9 Memory Layout

## 9.1 Flash Program Layout

The default Flash layout used in SDK is illustrated in Fig 9-1 and Table 9-1. Because bootloader will be called by ROM code, the address of bootloader cannot be changed. Other addresses except bootloader will be changed by user before changing these addresses, users must make sure that they are familiar with Ameba 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 |
|-------------|---------------|-----------------|-------|----------------------------------------------------------------------------------------------------------|-----------|
| KMO Boot    | 0x0800_0000   | 0x0800_0001     | 8K    | KMO bootloader code/data                                                                                 | Yes       |
| Backup      | 0x0800_2000   | 0x0800_3000     | 4K    | Backup Flash area, reserved for system. When program system data, this area will be used as backup area. | Yes       |
| System Data | 0x0800_3000   | 0x0800_4000     | 4K    | System Data, user should program this carefully.                                                         | Yes       |
| KM4 Boot    | 0x0800_4000   | 0x0800_5001     | 8K    | KM4 bootloader code/data                                                                                 | Yes       |
| KMDIMG2OTA1 | 0x0800_6000   | 0x0810_0001     | 1000K | KMDIMG2OTA1 code/data                                                                                    | No        |
| KM4IMG2OTA1 |               |                 |       | KM4IMG2OTA1 code/data                                                                                    | No        |
| KM4IMG3OTA1 |               |                 |       | RDPImage OTA1 code/data                                                                                  | No        |
| User Data   | 0x0810_0000   | 0x0810_0001     | 8K    | Reserved for user data                                                                                   | No        |
|             | 0x0810_2000   | 0x0810_5001     | 12K   | BT FTL physical map                                                                                      | No        |
|             | 0x0810_5000   | 0x0810_6001     | 4K    | WIFI Fast Connect profile                                                                                | No        |
| KMDIMG2OTA2 | 0x0810_6000   | 0x0820_0000     | 1000K | KMDIMG2OTA2 code/data                                                                                    | No        |
| KM4IMG2OTA2 |               |                 |       | KM4IMG2OTA2 code/data                                                                                    | No        |
| KM4IMG3OTA2 |               |                 |       | RDPImage OTA2 code/data                                                                                  | No        |

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

### 9.1.1 Image Header

Normal bootloader include secure boot signature. It's just used for loading code or data to the correct destination address. 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 execute start address after boot      |

Image header with secure includes secure boot signature used to realize ECC secure boot. For more information, refer to AN0410.

### 9.1.2 System Data

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



Fig 9-3 System data layout

Table 9-3 System Data layout

| Items     | Default    | Description            |
|-----------|------------|------------------------|
| BT_FW_DBG | 0xFFFFFFFF | Reserved for FW debug. |

### 9.1.3 User Data

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

Table9-4 User data layout

| Items                     | Range                   | Description                                                                                                                                                                                     |
|---------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved                  | 0x0810_0000x0810_20001  | Reserved for user data                                                                                                                                                                          |
| BT FTL                    | 0x0810_20000x0810_50001 | Bluetooth FTL physical map.<br>The start address is defined by phy_page_start_address variable (rt18721dhp_intfcfg.c)<br>If Bluetooth is not enabled in your system, this can be used by users. |
| Wi-Fi Fast Connect Profil | 0x0810_50000x0810_60001 | Used to store WiFi fast connect profile defined by FAST_RECONNECT_DATA macro(platform_opts.h)<br>If WiFi fast connect function is not enabled in your system, this area is not used by users.   |

Warning If Flash memory layout is modified and the 0x0800\_2000~0x0800\_5FFF is covered by this modified FTL physical map or Wi-Fi fast connect area address.

#### 9.1.4 4M Flash Usage Example

For 4M Flash, an example of Flash layout is illustrated in Fig9-4. In this example, 2048bytes size can be used for KM0M2 image and you can modify the layout according to your actual condition. 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, make sure that you are familiar with AmebaD system and SDK.



Fig9-4 4MFlash program layout example

Table9-5 4MFlash program layout example

| Items       | Start Address | LimitedAddress | Size | Description                                                                                              | Mandatory |
|-------------|---------------|----------------|------|----------------------------------------------------------------------------------------------------------|-----------|
| KM0 Boot    | 0x0800_0000   | 0x0800_0001    | 8K   | KM0 bootloader code/data                                                                                 | Yes       |
| Backup      | 0x0800_2000   | 0x0800_3000    | 4K   | Backup Flash area, reserved for system. When program system data, this area will be used as backup area. | Yes       |
| System Data | 0x0800_3000   | 0x0800_4000    | 4K   | System Data, user should program this carefully.                                                         | Yes       |
| KM4 Boot    | 0x0800_4000   | 0x0800_5001    | 8K   | KM4 bootloader code/data                                                                                 | Yes       |

|               |             |             |      |                                                                                   |                |
|---------------|-------------|-------------|------|-----------------------------------------------------------------------------------|----------------|
| KM0 IMG2 OTA1 | 0x0800_6000 | 0x080_0000@ | 2024 | KM0 image2 OTA1 code/data<br>KM4 image2 OTA1 code/data<br>RDPImage OTA1 code/data | No<br>No<br>No |
| KM4 IMG2 OTA1 |             |             |      |                                                                                   |                |
| KM4 IMG3 OTA1 |             |             |      |                                                                                   |                |
| User Data     | 0x080_0000  | 0x080_2000@ | 8K   | Reserved for user data                                                            | No             |
|               | 0x080_2000  | 0x080_5000@ | 12K  | BT FTL physical map                                                               | No             |
|               | 0x080_5000  | 0x080_6000@ | 4K   | Wi-Fi Fast Connect profile                                                        | No             |
| KM0 IMG2 OTA2 | 0x080_6000  | 0x080_0000@ | 2024 | KM0 image2 OTA2 code/data<br>KM4 image2 OTA2 code/data<br>RDPImage OTA2 code/data | No<br>No<br>No |
| KM4 IMG2 OTA2 |             |             |      |                                                                                   |                |
| KM4IMG3OTA2   |             |             |      |                                                                                   |                |

For 4M Flash, some configurations need to be modified in default .SDK

OTA start address

The default OTA start address in SDK is set for 2M Flash, thus OTA address in rtl8721d\_bootcfg.h needs to be modified when using 4M Flash.

- Modify OTA\_Region in rtl8721d\_bootcfg.h, change OTA2 region start address according to your layout when using 4M Flash program layout example as shown Fig9-4, OTA region should be modified as below:

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

- Modify OTA address definition in rtl8721d\_redefineLS\_IMG2\_OTA2\_ADDR macro according to your actual Flash layout using 4M Flash program layout example as shown Fig9-4, OTA address should be modified as below:

|                                      |                              |
|--------------------------------------|------------------------------|
| #define LS_IMG2_OTA1_ADDR 0x08006000 | /* KM0 OTA1 start address */ |
| #define LS_IMG2_OTA2_ADDR 0x08206000 | /* KM0 OTA2 start address */ |

User data Flash address

In default SDK, 24KB user data is defined in Flash 0x0800\_2000~0x0800\_5FFF is now used for BT FTL and WiFi connect profile. For 4M Flash, if Bluetooth and WiFi connect function are enabled in system, and Flash address 0x0800\_2000~0x0800\_5FFF covered, you need to modify BT FTL address and WiFi connect profile address according to your actual Flash layout.

- For BT FTL start address, define ftl\_phy\_page\_start\_addr variable in rtl8721dhp\_intfcfg.h Note that SPI FLASH address base 0x0800\_0000 is subtracted when calculating ftl\_phy\_page\_start\_addr variable and ftl\_phy\_page will consume 3\*4=12KB Flash start from ftl\_phy\_page\_start\_addr when using 4M Flash program layout example as shown Fig9-4, BT FTL start address should be modified as below:

```
const u32 ftl_phy_page_start_addr = 0x00202000;
```

- For WiFi fast connect profile address, redefine FAST\_RECONNECT\_DATA macro in platform\_opts.h and SPI FLASH address base 0x0800\_0000 is subtracted when calculating FAST\_RECONNECT\_DATA macro Note that WiFi fast connect profile address should not recover the 12KB Flash start from ftl\_phy\_page\_start\_addr this region is reserved for BT When using 4M Flash program layout example as shown Fig9-4, WiFi fast connect profile address should be set to 0x202000+0x3000=0x205000

```
#define FAST_RECONNECT_DATA 0x205000
```

After the above modification, rebuild KMO project and KM4 project and upload km0\_boot\_all.bin, km4\_boot\_all.bin and km0\_km4\_image2.bin.

## 9.2 SRAM Layout

### 9.2.1 KM4 RAM Layout

The start address of KM4 SRAM is 0x000\_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_COMM | 0x1000_0000   | 0x1000_1000 | 4K   | ROM Secure and Non-secure common .bss                   | Yes       |
| ROM_BSS_NS   | 0x1000_1000   | 0x1000_2000 | 4K   | ROM Non-secure common .bss                              | Yes       |
| RSVD         | 0x1000_2000   | 0x1000_4000 | 8K   | Reserved for Non-secure MSP & Non-secure ROM .bss       | No        |
| MSP_NS       | 0x1000_4000   | 0x1000_5000 | 4K   | Non-secure Main Stack Pointer                           | Yes       |
| IMG2_RAM_NS  | 0x1000_5000   | 0x1007_7000 | 456K | Image2 Non-secure RAM includes CODE, DATA, BSS and HEAP | No        |
| IMG3_RAM_S   | 0x1007_7000   | 0x1007_B000 | 16K  | Image3 Secure RAM includes CODE, DATA, BSS and HEAP     | No        |
| NSC          | 0x1007_B000   | 0x1007_C000 | 4K   | Images Secure function call entries                     | No        |
| ROM_BSS_S    | 0x1007_C000   | 0x1007_D000 | 4K   | ROM Secure only .bss                                    | Yes       |
| BOOT_RAM_S   | 0x1007_D000   | 0x1007_F000 | 8K   | KM4 Secure bootloader, includes CODE and DATA           | Yes       |
| MSP_S        | 0x1007_F000   | 0x1008_0000 | 4K   | Secure Main Stack Pointer                               | Yes       |

Note: If RDP is not enabled, the IMG3\_RAM\_S and NSC are non-secure and would be merged into the IMG2\_RAM\_NS. So the IMG2\_RAM\_NS region would be from 0x1000\_5000 to 0x1007\_C000.

## 9.2.2 KMO SRAM Layout

The start address of KMO SRAM is 0x00080000. The size is 64KB. The memory layout is illustrated in Fig 9-6 and Table 9-7.



Fig 9-6 KMO RAM program layout

Table 9-7 KMO RAM program layout

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

## 9.3 PSRAM Layout

The start address of KMO PSRAM is 0x20000000. The total size is 4MB. The memory layout is illustrated in Fig 9-7 and Table 9-8.



Fig9-7 KM4PSRAM program layout

Table9-8KM4PSRAMprogram layout

| Items         | Start Address | EndAddress  | Size | Description                                           | Mandatory |
|---------------|---------------|-------------|------|-------------------------------------------------------|-----------|
| IMG2_PSRAM_NS | 0x0200_0000   | 0x0230_0000 | 3MB  | Image2 No-securePSRAM includesODE, DATA, BSS and HEAP | No        |
| IMG3_PSRAM_S  | 0x0230_0000   | 0x0240_0000 | 1MB  | Image3 SecurePSRAM includesODE, DATA, BSS and HEAP    | No        |

Note: If TrustZone is not enabled, the whole PSRAM would be secure. So the IMG2\_PSRAM\_NS region would be [0x0200\_0000 ~ 0x0240\_0000].

## 9.4 Retention SRAM

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

### 9.4.1 Retention SRAM Layout

The start address of Retention SRAM is 0x000C\_0000. The size is 1KB. The mandatory items are shown in Table 9-9.

Table9-9Retention SRAM layout

| Items       | Start Address | End Address | Size | Description                                                                        | Mandatory |
|-------------|---------------|-------------|------|------------------------------------------------------------------------------------|-----------|
| System Area | 0x000C_0000   | 0x000C_0001 | 128B | Used byRealtek. The size is indicated by the second byte (0x000C0001).             | Yes       |
| User Area   | 0x000C_0008   | 0x000C_0011 | 176B | Refer to RRAM_TypeDef and RRAM_USER_RSVD [user_size] is reserved for customer use. | No        |
| Wi-Fi Area  | 0x000C_0010   | 0x000C_0400 | 720B | Realtek Wi-Fi FW use                                                               | Yes       |

### 9.4.2 User Area

RRAM\_USER\_RSVD is reserved for customer use. The size for user area is 124B now, it 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_IP;  
    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_cur_bitmode;  
  
    uint8_t FLASH_ClockDiv;  
    uint8_t FLASH_ReadMode;  
    uint8_t FLASH_pseudo_prm_en;  
    uint8_t FLASH_addr_phase_len;  
  
    uint8_t FLASH_cmd_wr_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]; /*usr can alloc from this RSVD space*/  
}; RRAM_TypeDef;  
/** @}  
*****
```

## 9.5 OTA Layout

### 9.5.1 OTA Program Layout

The OTA program layout is shown in Fig 9-8.



Fig 9-8 OTA program layout

### 9.5.2 OTA Header Layout

The OTA header layout is shown in Fig 9-9 and Table 9-10.



Fig9-9OTAheaderlayout

Table9-10OTAheaderlayout

| Items         | Address Offset | Size    | Description                                             |
|---------------|----------------|---------|---------------------------------------------------------|
| Version       | 0x00           | 4 bytes | The version of OTA header default OxFFFFFF              |
| Header Number | 0x04           | 4 bytes | The number of OTA Header for AmebaD, this value is 0x01 |
| Signature     | 0x08           | 4 bytes | OTA Signature is string Ameba                           |
| Header Length | 0x0C           | 4 bytes | The length of OTA header. For Ameba this value is 0x18  |
| Checksum      | 0x10           | 4 bytes | The checksum of OTA image                               |
| ImageLength   | 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.6 TrustZone Memory Layout

All addresses are Secure when boot. Some areas are set to Non-Secure using SAU & IDA in bootloader.

When TrustZone is enabled, the default security setting in AmebaD SDKs shown in Fig9-10

When TrustZone is disabled, SDK would set RAM\_S, NSRAM\_S and IMG3\_PSRAM\_S to Non-Secure. Other secure areas used by ROM code are mandatory.



Fig9-10TrustZone layout

# 10 BootProcess

## 10.1 Features

- On-chip boot ROM
- Containing the bootloader with System Programming (ISP) facility
- Secure boot processing Elliptic Curve Cryptography (ECC)
- Suspend resume process

## 10.2 BootAddress

After reset, CPU will boot from vector table start address this fixed by hardware. KM0 and KM4 boot from different addresses. Table10-1 lists

Table10-1 BootROM address

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

## 10.3 Pin Description

The parts support ISPL06UART (PA[7] & PA[8]). The ISP mode, given Table10-2, is determined by the state of PA[7] pin at boot time.

Table10-2 ISP mode

| Boot Mode | PA[7] (UART_DOWNLOAD) | Description                                    |
|-----------|-----------------------|------------------------------------------------|
| No ISP    | HIGH                  | ISP bypassed. Part attempts to boot from PA[7] |
| ISP       | LOW                   | Part enters ISP MODE                           |

## 10.4 BootFlow

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

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



Fig10-1 Bootflow

## 10.5 BootTime

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     | NormalBOOT(ms) | DeepsleepWAKEUP(ms) | Comment                                                                                                                                       |
|---------|----------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| KM0BOOT | 30             | 18                  |                                                                                                                                               |
| KM4BOOT | 6+x            | 3+x                 | x=image2 size/flash rate<br>If image2 size = 100KB, Flash rate = 80Mbps & 2bit mode:<br>x=100*1024*8/150ms (100KB is SDK current image2 size) |
| WIFION  | 40             | 40                  |                                                                                                                                               |

## 10.6 GeneralDescription

The bootloader controls initial operation after power-on and also provides the means to program the flash memory. This could be initial programming of a blank device, erasing and reprogramming of a previously programmed device.

Assuming that power supply pins are at their nominal levels when the rising edge on the **RESET** pin is generated, the boot pins are sampled and the decision whether to continue with user code or ISP handler is made. If the **RESET** pin is sampled LOW, the external hardware request to start the ISP command handler is ignored. If there is no request for the ISP command 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 boot process is invoked.

### 10.6.1 KMO ROM Boot

The KMO ROM boot process is shown in Fig10-2.



Fig10-2KM0 ROM bootprocess

## 10.6.2 KM4 ROM Boot

The KM4 ROM boot process is shown in Fig10-3.



Fig10-3KM4 ROM boot process

## 10.7 Boot Reason APIs

Sourcecode:rtl8721d\_backup\_reg.c

|               |                 |
|---------------|-----------------|
| API           | Introduction    |
| <BOOT_Reason> | Get boot reason |

Table 10-4 Boot reason definition

| Bit                          | Comment                |
|------------------------------|------------------------|
| BIT_BOOT_BOD_RESET_HAPPEN    | BOD Reset              |
| BIT_BOOT_DSPL_RESET_HAPPEN   | Wakeup from deep sleep |
| BIT_BOOT_KM4WDG_RESET_HAPPEN | KM4 watchdog reset     |
| BIT_BOOT_KM4SYS_RESET_HAPPEN | KM4 system reset       |
| BIT_BOOT_WDG_RESET_HAPPEN    | KM0 watchdog reset     |
| BIT_BOOT_SYS_RESET_HAPPEN    | KM0 system reset       |

# 11 File System

## 11.1 Introduction

This chapter introduces how to run FAT file system example on Ameba-D, including examples of Flash and SD card. The example source code is located in `component\common\example\fatfs`

## 11.2 FatFs on Flash

### 11.2.1 Software Setup

- (1) Change some configuration options in `project\realtek_amebaD_cm4_gcc_verification\platform_opts.h` as follows:
  - a) Set the parameter `CONFIG_EXAMPLE_FATFS` to 1
  - b) Set `FATFS_DISK_FLASH` to 1 while `FATFS_DISK_USB` and `FATFS_DISK_SD` both to 0

```
/* For FATFS example */
#define CONFIG_EXAMPLE_FATFS           1
#if CONFIG_EXAMPLE_FATFS
#define CONFIG_FATFS_EN    1
#if CONFIG_FATFS_EN
// fatfs version
#define FATFS_R_10C
// fatfs disk interface
#define FATFS_DISK_USB  0
#define FATFS_DISK_SD   0
#define FATFS_DISK_FLASH 1
#endif
#endif
```

- (2) Change some parameters in `component\common\file_system\fatfs\r0.10\include\ffconf.h` as follows:
  - a) Set `_MAX_SS` to 4096 to define the maximum sector size supported
  - b) Set `_USE_MKFS` to 1 to enable `f_mkfs()` function which formats a file system on Flash

```
#define _MIN_SS    512
#define _MAX_SS   4096 // 512
#define _USE_MKFS  1 /* 0:Disable or 1:Enable */
```

- (3) Change Flash memory base in `component\common\file_system\fatfs\disk_ifsr\flash_fatfs.c`

```
#define FLASH_APP_BASE 0x100000 // 0x440000
```

- (4) Check the stack size that needs to be at least 4096 in `component\common\example\fatfs\example_fatfs.c`

```
#define STACK_SIZE 4096
```

- (5) Rebuild the project and download image files to Ameba-D.

### 11.2.2 FatFsBin File Generation

The commands to generate `FatFsbin` file are as follows:

- (1) `root@ubuntu # dd if=/dev/zero of=test.bin count=64 bs=1KB`
- (2) `root@ubuntu # fdisk test.bin`
- (3) `root@ubuntu # mkfs.msdos 12 test.bin`
- (4) `root@ubuntu # mcopy test.bin ./fs/ hello.txt :hello.txt`
- (5) `root@ubuntu # sudo mount test.bin ./fs`
- (6) `sudo umount ./fs`

In step (1), `test.bin` is created which has 64 blocks and each block is 1KB.

In step (2), test.bin is partitioned. Some additional options have to be chosen in this step in order to ~~create~~ new partition.  
In step (3), a ~~N~~~~O~~S file system is built.  
In step (4), files ~~that~~ want to store are copied into test.bin. In this step, hello.txt is stored in test.bin.  
In step (5), test.bin is mounted to file folder fs.  
In step (6), after unmounting test.bf~~a~~ file is generated.  
Users should find other related information from the internet, and copy test.bin into user data area of Flash finally.

## 11.3 FatFson SD Card

### 11.3.1 Hardware Setup

Connect your AmelDEVBboardto PCwithmicroUSB cable, and then plug in a compatible SD card to the card connector. Note that the terminal of the middle of J24 need to be connected to ground. Connection is shown in Fig11-1.



Fig11-1 Hardware setup

### 11.3.2 Software Setup

- (1) Change some configurations in `project\realtek_amebaD_v0_example\inc\h\platform_opts.h` as follows:
- Set the parameter `CONFIG_EXAMPLE_FATFS` to 1
  - Set `FATFS_DISK_SD` to 1 while `FATFS_DISK_USB` and `FATFS_DISK_FLASH` both to 0

```
/* For FATFS example*/
#define CONFIG_EXAMPLE_FATFS      1
#if CONFIG_EXAMPLE_FATFS
#define CONFIG_FATFS_EN          1
#if CONFIG_FATFS_EN
// fatfs version
#define FATFS_R_10C
// fatfs disk interface
#define FATFS_DISK_USB          0
#define FATFS_DISK_SD           1
#define FATFS_DISK_FLASH        0
#endif
#endif
```

- (2) Change some parameters in `component\common\file_system\fatfs\r0.10\include\ffconf.h` as follows:
- Set `_MAX_SS` to 512 to define the maximum sector size supported
  - Set `USE_MKFS` to 1.

|                                       |                                       |                                                                 |
|---------------------------------------|---------------------------------------|-----------------------------------------------------------------|
| <code>#define _MIN_SS      512</code> | <code>#define _MAX_SS      512</code> | <code>#define USE_MKFS     1 /* 0:Disable or 1:Enable */</code> |
|---------------------------------------|---------------------------------------|-----------------------------------------------------------------|

- (3) Change some parameters in `component\realtek\ameba\fwlib\usrc\rtl8721dhp_intfcfg.c` as follows:

```
SDIOHCFG_TypeDef sdioh_config = {  
    .sdioh_bus_speed = SD_SPEED_HS,  
    .sdioh_bus_width = SDIOH_BUS_WIDTH_4BIT,  
    .sdioh_cd_pin = _PA_6,  
    .sdioh_wp_pin = _PNC,  
};
```

- (4) Rebuild the project and download image file Ameba-D. FAT file of SD card can be generated and copied directly by PC.

# 12 Inter Processor Communication

## 12.1 Introduction

InterProcessor Communication (IPC) hardware is designed for the purpose of making two CPUs communicate with each other. The architecture is shown in Fig12-1.



Fig12-1 IPC system architecture

If you want KMO to execute its IPC handler, IPC0 interrupt of KM4 should be enable and the status should be set.

## 12.2 How to Use IPC

It is complex because both KMO and KM4 should be set to realize the procedure. Take KM4 request an interrupt into direction KMO example.

- Add new item in KMO core section `ipcconfig` which is `int18721d_ipccfg` for selected channel. IRQ handler and data should be set and defined. If message exchange is needed, you should specify the message type or point. Note that the message type for a specific channel should be the same on both ARM\_CORE\_CM4 side and ARM\_CORE\_CMO side. following figure, although IRQFUNC of channel 3 on ARM\_CORE\_CM4 side is not used, its message type matches to ARM\_CORE\_CMO side.

```

const IPC_INIT_TABLE ipc_init_config[] =
{
#if defined (ARM_CORE_CM4)
    //USER_MSG_TYPE      IRQFUNC
    {IPC_USER_DATA,     (VOID*) shell_switch_ipc_int,           IRQDATA
     (VOID*) NULL}, //channel 0: IPC_INT_CHAN_SHELL_SWITCH
    {IPC_USER_DATA,     (VOID*) NULL,                           (VOID*) NULL}, //channel 1: IPC_INT_CHAN_WIFI_FW
    {IPC_USER_DATA,     (VOID*) FLASH_Write_IPC_Req,           (VOID*) NULL}, //channel 2: IPC_INT_CHAN_FLASHPG_REQ
    {IPC_USER_POINT,   (VOID*) NULL,                           (VOID*) NULL}, //channel 3: IPC_INT_KM4_TICKLESS_INDICATION
#else
    //USER_MSG_TYPE      IRQFUNC
    {IPC_USER_DATA,     (VOID*) shell_switch_ipc_int,           IRQDATA
     (VOID*) NULL}, //channel 0: IPC_INT_CHAN_SHELL_SWITCH
    {IPC_USER_DATA,     (VOID*) driver_fw_flow_ipc_int,         (VOID*) IPCM4_DEV}, //channel 1: IPC_INT_CHAN_WIFI_FW
    {IPC_USER_DATA,     (VOID*) FLASH_Write_IPC_Req,             (VOID*) NULL}, //channel 2: IPC_INT_CHAN_FLASHPG_REQ
    {IPC_USER_POINT,   (VOID*) km4_tickless_ipc_int,            (VOID*) NULL}, //channel 3: IPC_INT_KM4_TICKLESS_INDICATION
#endif
    {0xFFFFFFFF,        OFF,                                OFF}, /* Table end */
};

```

- SDK will enable the IPC interrupt of KM4 for the channel according to `ipcconfig` and register the corresponding KMO IRQ handler and data for the channel.
- When KM4 wants to request an interrupt into direction KMO, it should call `ipc_send_message()` and specify the channel number and message.
- Corresponding KMO IRQ handler will be executed by `ipc_get_message()` to get message if need.

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

## 12.3 IPC Program API

### 12.3.1 ipc\_table\_init

| Items        | Description                                          |
|--------------|------------------------------------------------------|
| Introduction | Initialize PC channel according to ipc_init_config[] |
| Parameters   | N/A                                                  |
| Return       | N/A                                                  |

### 12.3.2 ipc\_send\_message

| Items        | Description                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Request interrupt to target CPU by specified channel to exchange messages between KMO and KM4                                |
| Parameters   | IPC_ChNum: the IPC channel number<br>Message: the message to be exchanged<br>Note: the message should not be stored in stack |
| 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 CPUs, so the point can't be stored in stack.

### 12.3.3 ipc\_get\_message

| Items        | Description                             |
|--------------|-----------------------------------------|
| Introduction | Get 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.

## 12.4 IPC Drive Code

### 12.4.1 IPC\_INTConfig

| Items        | Description                                                                                                                                                                   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enable or disable the specified channel interrupts                                                                                                                            |
| Parameters   | IPCx:<br>IPC_M0_DEV for KMO<br>IPC_M4_DEV for KM4<br>IPC_ChNum: the channel that wants to be set. This parameter must be set to a value 31.<br>NewState:<br>ENABLE<br>DISABLE |
| Return       | N/A                                                                                                                                                                           |

### 12.4.2 IPC\_IERSet

| Items        | Description                             |
|--------------|-----------------------------------------|
| Introduction | Set IER of specified channel interrupts |

|            |                                                                                               |
|------------|-----------------------------------------------------------------------------------------------|
| Parameters | IPCx:<br>IPCM0_DEV for KMO<br>IPCM4_DEV for KM4<br>IPC_Ch: the channel that want to be enable |
| Return     | N/A                                                                                           |

### 12.4.3 IPC\_IERGet

| Items        | Description                                     |
|--------------|-------------------------------------------------|
| Introduction | Get IER of specified IEx                        |
| Parameters   | IPCx:<br>IPCM0_DEV for KMO<br>IPCM4_DEV for KM4 |
| Return       | The IER of specified IEx                        |

### 12.4.4 IPC\_INTRequest

| Items        | Description                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Request a core-to-core interrupt                                                                                                                  |
| Parameters   | IPCx:<br>IPCM0_DEV for KMO<br>IPCM4_DEV for KM4<br>IPC_ChNum: the channel that want to request interruptThis parameter must be set to a value 31. |
| Return       | N/A                                                                                                                                               |

### 12.4.5 IPC\_INTClear

| Items        | Description                                                                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clear a core-to-core interrupt                                                                                                                  |
| Parameters   | IPCx:<br>IPCM0_DEV for KMO<br>IPCM4_DEV for KM4<br>IPC_ChNum: the channel that want to clear interruptThis parameter must be set to a value 31. |
| Return       | N/A                                                                                                                                             |

### 12.4.6 IPC\_INTGet

| Items        | Description                                     |
|--------------|-------------------------------------------------|
| Introduction | Get a core-to-core interrupt status             |
| Parameters   | IPCx:<br>IPCM0_DEV for KMO<br>IPCM4_DEV for KM4 |
| Return       | The ISR of specified IEx                        |

### 12.4.7 IPC\_CPUID

| Items        | Description            |
|--------------|------------------------|
| Introduction | Get the current CPU ID |
| Parameters   | N/A                    |
| Return       | CPU ID<br>0: KMO       |

|  |        |
|--|--------|
|  | 1: KM4 |
|--|--------|

## 12.4.8 IPC\_SEMGet

| Items        | Description                                                                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Get a core-to-core hardware semaphore                                                                                                                       |
| Parameters   | SEM_Id: the semaphore index that want to get. This parameter must be set to a value 15.<br>0~7: Reserved for Realtek use<br>8~15: Reserved for Customer use |
| Return       | Result<br>TRUE<br>FALSE                                                                                                                                     |

## 12.4.9 IPC\_SEMFree

| Items        | Description                                                                                                                                                  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Free a core-to-core hardware semaphore                                                                                                                       |
| Parameters   | SEM_Id: the semaphore index that want to free. This parameter must be set to a value 15.<br>0~7: Reserved for Realtek use<br>8~15: Reserved for Customer use |
| Return       | Result<br>TRUE<br>FALSE                                                                                                                                      |

## 12.4.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 the defined IRQ handler.

## 12.4.11 IPC\_INTUserHandler

| Items        | Description                                                                                                                                                                                                                                  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Register a user interrupt handler for a specified IPC channel                                                                                                                                                                                |
| Parameters   | IPC_ChNum: the channel that want to register the IRQ handler. This parameter must be set to a value 31.<br>IrqHandler: the IRQ handler to be assigned to the specified IPC channel<br>IrqData: the pointer will be passed to the IRQ handler |
| Return       | N/A                                                                                                                                                                                                                                          |

# 13 OTA Firmware Update

## 13.1 Introduction

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

RTL8721d provides solutions to implement OTA firmware upgrade from local server or cloud. Next we will introduce the design of OTA from local server. It has ~~transportability~~ porting to OTA options from cloud.

## 13.2 RSIP-MMU

The Flash MMU diagram is shown in Fig13-1.



Fig13-1 FlashMMU

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



Fig13-2 MMUvirtualaddress to physicaladdress

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 \oplus MMU\_ENTRYx\_OFFSET$ .

MMU is implemented to facilitate OTA update procedures. Fig 13-3 shows Fig 13-3 is an example for 2M Flash, we need 2 MMU entries in this example.



Fig 13-3 2M Flash OTA MMU

MMU entry should be set as Table 13-1.

Table 13-1 OTA under MMU

| Register Type | Register           | OTA1                                    | OTA2                                    |
|---------------|--------------------|-----------------------------------------|-----------------------------------------|
| MMU Entry0    | MMU_ENTRY0_STRADDR | 0x0C00_0000                             | 0x0C00_0000                             |
|               | MMU_ENTRY0_ENDADDR | 0x0C00_0000 + KMO_IMG2 size             | 0x0C00_0000 + KMO_IMG2 size             |
|               | MMU_ENTRY0_OFFSET  | 0x0C00_0000 ⊕ 0x0800_6000               | 0x0C00_0000 ⊕ 0x0810_6000               |
|               | +/-                | -                                       | -                                       |
| MMU Entry1    | MMU_ENTRY1STRADDR  | 0x0E00_0000                             | 0x0E00_0000                             |
|               | MMU_ENTRY1ENDADDR  | 0x0E00_0000 + KM4_IMG2 size             | 0x0E00_0000 + KM4_IMG2 size             |
|               | MMU_ENTRY1OFFSET   | 0x0E00_0000 ⊕ M4 start physical address | 0x0E00_0000 ⊕ M4 start physical address |
|               | +/-                | -                                       | -                                       |

Note: Considering KM4\_IMG2 is appended to the tail of KMO\_IMG2, the KM4 start physical address is determined by  $KMO\_start\_physical\_address + KMO\_IMG2\ size$ .

### 13.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. Fig 13-4 shows.

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



Fig13-4 OTA update diagram

### 13.3.1 FirmwareFormat

The firmware format is illustrated in Fig13-5.



Fig13-5 Firmware format

Table13-2 Firmware header

| Items         | Address | Offset | Size    | Description                                            |
|---------------|---------|--------|---------|--------------------------------------------------------|
| Version       | 0x00    |        | 4 bytes | The version of OTA header default OxFFFFFF             |
| Header Number | 0x04    |        | 4 bytes | The number of OTA Header. For Ameba this value is 01   |
| Signature     | 0x08    |        | 4 bytes | OTA Signature is string Ameba                          |
| Header Length | 0x0C    |        | 4 bytes | The length of OTA header. For Ameba this value is Ox18 |
| 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 OTAbin in current image          |
| RSVD          | 0x1C    |        | 4 bytes | Reserved                                               |

### 13.3.2 OTA Flow

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

- (1) Connect to local server socket. The IP address and port are needed.
- (2) Acquire the old firmware address to be upgraded according to MMU settings. If `MMU` 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 image information, such as image length and destination address.
- (4) EraseFlashspace for new firmware

- (5) Download new firmware from server and `wrFlash` to
- (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 firmware next time.
- (8) OTA finish and reset the device. Then it would boot from new firmware.



Fig13-6OTA operation flow

### 13.3.3 BootOption

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

Signature. If it is B1958711 the signature is valid. Otherwise, the signature is invalid.  
Hash/checksum if needed. Users can define FwCheckCallback in `rtl8721d_bootcfg.h`.

The bootflow is as follows:

- (1) CheckSignature 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



Fig13-7 OTA select diagram

### 13.3.4 Address Remapping

In bootloaderMMU entry<sub>0</sub> and entry<sub>1</sub> would be set Table13-1 to remap memory. Here, the OTA space includes images: KM0 IMG2, KM4 IMG2KM4 IMG3 if need these images boot from OTA1 or OTA2.

As Fig13-3 illustrates when boot from OTA, CPU may access different physical address

When boot from OTA1, MMU entry<sub>0</sub> and entry<sub>1</sub> would be set to remap virtual memory to OTA1 address space that is, if CPU wants to read code or data from address 0x000\_0000, it actually accesses physical address 0x086000

When boot from OTA2, MMU entry<sub>0</sub> and entry<sub>1</sub> would be set to remap virtual memory to OTA2s space. That is, if CPU wants to read code or data from address 0x000\_0000, it actually accesses physical address 0x0810\_6000.

### 13.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 platformopts.h to enable OTA function. Rebuild the project.
- (2) Download images to device
- (3) Generate OTA upgrade image file, name OTA\_All.bin with Image Tool and new firmware. This operation appends firmware header information to new firmware, which is necessary for



- (4) Copy OTA\_All.bin into the DownloadServer folder.  
Tool path in SDK tools\DownloadServer

|  |                    |                 |        |
|--|--------------------|-----------------|--------|
|  | DownloadServer.exe | 2016/11/7 16:12 | 34 KB  |
|  | OTA_All.bin        | 2016/11/7 15:21 | 657 KB |
|  | start.bat          | 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 to start the 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



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

### 13.3.6 OTA Firmware Swap

Fig13-8 shows the firmware swap procedure after OTA upgrade.



Fig13-8 OTA firmware swap procedure

## 13.4 User Configuration

Users can find the following configure items in `ld_bootcfg.c`

OTA start address

```
/*
 * @brief OTA start address. Because KM0 & KM4 IMG2 are combined, users only need to set the start address
 *        of KM0 IMG2.
 */
BOOT_RAM_DATA_SECTION
u32 OTA_Region[2] = {
    0x08006000, /* 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,           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
    {0xFFFFFFFF,  0xFFFFFFFF,        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;
```

# 14 eFuse

## 14.1 Introduction

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

The total size of physical eFuse is 512 bytes, and divided into two parts by figure 14-1. It shows the first 288 bytes of physical eFuse used for logical mapping, which can be mapped to logical eFuse by some algorithm and can be programmed. The left 224 bytes of physical eFuse are defined by Realtek.

Logical eFuse program will program header and package, and the package is in word, so it takes at least three bytes a time. Software one byte for isolation, so when the space of eFuse for logical mapping is less than four bytes, it cannot be programmed in an



Fig14-1 eFuse diagram

## 14.2 Power Requirement

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

Table 14-1 Operation under different voltage

| Supply Voltage(V) | Operation                      |
|-------------------|--------------------------------|
| 1.8               | Only read operation is allowed |
| 3.3               | Read & Write                   |

Note If you want to program eFuse you must switch the power supply to 3.3V.

## 14.3 eFuseAuto-load

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

The way to change the values of System Configure Registers as follow:

Make sure that the first two bytes of System Data area are written to 0x21, 0x87 correctly.

Program the corresponding bytes in word just programming in byte, another byte will load the default value 0xFF which may make mistake.

Reboot the chip and the System Configure Registers will load the new values.

## 14.4 Physical eFuse

For detailed information about physical eFuse of AmebaD, refer to AN0411.

## 14.5 Logical eFuse

### 14.5.1 Logical eFuse Layout

There are 1024 bytes of logical eFuse in AmebaD, as Table 14-2 shows. Most of the logical eFuse space are reserved for extension, so the 1024 bytes of logical eFuse can be easily mapped to 287 bytes of physical eFuse.

Table 14-2 Logical eFuse Layout

| Start Address | End Address | Description              |
|---------------|-------------|--------------------------|
| 0x000         | 0x01F       | System Data to be loaded |
| 0x020         | 0x15F       | Wi-Fi calibration data   |
| 0x160         | 0x17F       | User MTP                 |
| 0x180         | 0x183       | CapTouch                 |
| 0x184         | 0x18F       | Reserved                 |
| 0x190         | 0x1A4       | BT parameters            |
| 0x1A5         | 0x1BF       | Reserved                 |
| 0x1C0         | 0x1CF       | HCI USB                  |
| 0x1D0         | 0x2FF       | Reserved                 |

|         |                     |
|---------|---------------------|
| 20~25   | 2.4G CCK Index      |
| 26~2A   | 2.4G BW40 Index     |
| 2B      | 2.4G Difference     |
| 32~3F   | 5G BW40 Index       |
| 40      | 5G Difference       |
| C8      | channel plan        |
| C9      | Crystal Calibration |
| CA      | Thermal meter       |
| 11A~11F | MAC Address         |

For WiFi:

eFuse locations for (N)Pass Product(ion)calibration

|     | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | A  | B  | C  | D  | E  | F  |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 000 | 21 | 87 | 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 |

Fig14-2 Wi-Fi eFuse data

#### 14.5.2 SPIC Address-Byte Enable

| AddressOffset | Name                    | Bit | Default | Description                                        |
|---------------|-------------------------|-----|---------|----------------------------------------------------|
| OE            | SPIC addressbyte enable | [6] | 0       | SPIC addressbyte enable<br>1: Enable<br>0: Disable |

If you want to access the address length  $\text{loff} \geq 2$  the memory area of higher density (larger than 128B), you should enable 4-byte mode. In short, you should read the eFuse bit[6] first and then program it to.

#### 14.5.3 Wi-Fi 2.4G Power Index

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

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

Fig14-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. |
|        | 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.                           |
|        | 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.                                                                                                                                                                             |
|        |                 |                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |                 |                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |                 |                                                                                                                                                                                                                                                                                                                                                                                                       |

Fig14-4 2.4GWi-Fi power indexspecification

#### 14.5.4 Wi-Fi 5G Power Index

The addressand specificationof power index is showFig14-5 and Fig14-6.

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

Fig14-5 5G Wi-Fi power indexaddress

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

Fig14-6 5G Wi-Fi power indexspecification

## 14.5.5 Wi-Fi Channel Plan

The address of Wi-Fi channel 6 is shown in Fig 14-7.

Fig14-7 Channel plan address

| eFuse | Name         | Bit   | Default | Comment                                                                                                                                                                                       |
|-------|--------------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C8    | Channel Plan | [7]   | 0h      | Software configure mode<br>0h: Enable software configure (refer to Channel Plane Domain Code)<br>1h: Disable software configure (change Channel Plan Setting)                                 |
|       |              | [6:0] | 7fh     | Channel Plan<br>0x202G Worldwide 13, Active scan~Ch11, Passive scan Ch12, Ch13<br>0x7F:<br>2G Worldwide 13, Active scan~Ch11, Passive scan Ch12, Ch13<br>5G Worldwide, all bands Passive scan |

Frequently used county codes and the corresponding channel plans are listed in Table 14-3, Table 14-4 and Table 14-5.

Table 14-3 Relationship between country code and channel plan

| Table 1: Relationship between country codes and channel plan |              |                                  |              |
|--------------------------------------------------------------|--------------|----------------------------------|--------------|
| Country                                                      | Abbreviation | EnumerationVariableName          | Channel Plan |
| America                                                      | US           | RTW_COUNTRY_US                   | 0x76         |
| Australia                                                    | AS           | RTW_COUNTRY_AS                   | 0x2A         |
| Chile                                                        | CL           | RTW_COUNTRY_CL                   | 0x2D         |
| China                                                        | CN           | RTW_COUNTRY_CN                   | 0x48         |
| Europe                                                       | EU           | RTW_COUNTRY_UA                   | 0x26         |
| Japan                                                        | JP           | RTW_COUNTRY_JP                   | 0x27         |
| Mexico                                                       | MX           | RTW_COUNTRY_MX                   | 0x4D         |
| Ukraine                                                      | UA           | RTW_COUNTRY_UA                   | 0x35         |
| Default                                                      | -            | RT_CHANNEL_DOMAIN_REALTEK_DEFINE | 0x7F         |

Table 14-4 2.4G channel map of the above channel plan

| Table 14-42: 4G channel map of the above channel plan |                        |                                               |              |
|-------------------------------------------------------|------------------------|-----------------------------------------------|--------------|
| Channel Plan                                          | 24G Channel Definition | Channels                                      | Passive Scan |
| 0x76                                                  | 2G_02                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | -            |
| 0x2A                                                  | 2G_02                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | -            |
| 0x2D                                                  | 2G_01                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | 12,13        |
| 0x48                                                  | 2G_01                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | 12,13        |
| 0x26                                                  | 2G_01                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | 12,13        |
| 0x27                                                  | 2G_04                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14 | -            |
| 0x4D                                                  | 2G_02                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | -            |
| 0x35                                                  | 2G_01                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | 12,13        |
| 0x7F                                                  | 2G_01                  | 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13     | 12,13        |

Note Active scan channels are charted in table except the passive scan channels.

Table 14-5 5G channel map of the above channel plan

| Channel Plan | 5G Channel Definition | Channels                                                                                                             | Passive Scan                                                                 | DFS Channels                                                                 |
|--------------|-----------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| 0x76         | 5G_22                 | 36, 40, 44, 48<br>52, 56, 60, 64<br>100, 104, 108, 112, 116, 120, 128, 132, 136, 140, 144<br>149, 153, 157, 161, 165 | 52, 56, 60, 64<br>100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144 | 52, 56, 60, 64<br>100, 104, 108, 112, 116, 120, 124, 128, 132, 136, 140, 144 |
| 0x2A         | 5G_00                 | -                                                                                                                    | -                                                                            | -                                                                            |
| 0x2D         | 5G_22                 | 36, 40, 44, 48                                                                                                       | 52, 56, 60, 64                                                               | 52, 56, 60, 64                                                               |

|      |       |                                                                                                                         |                                                                                                                         |                                                                                 |
|------|-------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
|      |       | 52, 56, 60, 64<br>100, 104, 108, 112, 116, 120,<br>128, 132, 136, 140, 144<br>149, 153, 157, 161, 165                   | 100, 104, 108, 112, 116, 1<br>124, 128, 132, 136, 140, 1                                                                | 100, 104, 108, 112, 116<br>120, 124, 128, 132, 136,<br>140, 144                 |
| 0x48 | 5G_07 | 36, 40, 44, 48<br>52, 56, 60, 64<br>149, 153, 157, 161, 165                                                             | 52 56 60 64                                                                                                             | 52 56 60 64                                                                     |
| 0x26 | 5G_02 | 36, 40, 44, 48<br>52, 56, 60, 64<br>100, 104, 108, 112, 116, 120,<br>128, 132, 136, 140                                 | 52, 56, 60, 64<br>100, 104, 108, 112, 116, 1<br>124, 128, 132, 136, 140                                                 | 52, 56, 60, 64<br>100, 104, 108, 112, 116<br>120, 124, 128, 132, 13<br>140      |
| 0x27 | 5G_02 | 36, 40, 44, 48<br>52, 56, 60, 64<br>100, 104, 108, 112, 116, 120,<br>128, 132, 136, 140                                 | 52, 56, 60, 64<br>100, 104, 108, 112, 116, 1<br>124, 128, 132, 136, 14                                                  | 52, 56, 60, 64<br>100, 104, 108, 112, 116<br>120, 124, 128, 132, 13<br>140      |
| 0x4D | 5G_01 | 36, 40, 44, 48<br>52, 56, 60, 64<br>100, 104, 108, 112, 116, 132,<br>140<br>149, 153, 157, 161, 165                     | 52, 56, 60, 64<br>100, 104, 108, 112, 116, 1<br>136, 140                                                                | 52, 56, 60, 64<br>100, 104, 108, 112, 116,<br>132, 136, 140                     |
| 0x35 | 5G_03 | 36, 40, 44, 48<br>52, 56, 60, 64<br>100, 104, 108, 112, 116, 120,<br>128, 132, 136, 140<br>149, 153, 157, 161, 165      | 52, 56, 60, 64<br>100, 104, 108, 112, 116, 1<br>124, 128, 132, 136, 140                                                 | 52, 56, 60, 64<br>100, 104, 108, 112, 116,<br>120, 124, 128, 132, 13<br>140     |
| 0x7F | 5G_36 | 36, 40, 44, 48<br>52, 56, 60, 64<br>100, 104, 108, 112, 116, 120,<br>128, 132, 136, 140, 144<br>149, 153, 157, 161, 165 | 36, 40, 44, 48<br>52, 56, 60, 64<br>100, 104, 108, 112, 116, 1<br>124, 128, 132, 136, 140, 1<br>149, 153, 157, 161, 165 | 52, 56, 60, 64<br>100, 104, 108, 112, 116<br>120, 124, 128, 132, 13<br>140, 144 |

Note Active scan channels are channels listed in table except the passive scan channels.

#### 14.5.6 Wi-Fi Crystal Calibration

The address of Wi-Fi crystal calibration is shown in Fig14-8.



Fig14-8 Crystal Calibration address

| eFuse | Name                | Bit   | Default | Comment                                         |
|-------|---------------------|-------|---------|-------------------------------------------------|
| C9    | Crystal Calibration | [7]   | 0h      | Reserved                                        |
|       |                     | [6:0] | 40h     | XTAL_K Value<br>Xi=X or range 0~7Fh<br>FFh = 06 |

#### 14.5.7 Wi-Fi Thermal Meter

The address of Wi-Fi thermal meter is shown in Fig14-9.

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

Fig14-9 Thermal Meter address

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

## 14.5.8 Wi-Fi MACAddress

The Wi-Fi MACAddress is shown Fig14-10

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

Fig14-10 MAC Address

| AddressOffset | Bit    | Default      | Comment                                                                                                  |
|---------------|--------|--------------|----------------------------------------------------------------------------------------------------------|
| 11A~11F       | [47:0] | 00E04C872101 | After the autoload command or hardware reset, Ameba-D loads MAC addresses to MACID of the I/O registers. |

## 14.5.9 CapTouch

| AddressOffset | Bit   | Default | Description                           |
|---------------|-------|---------|---------------------------------------|
| 180h          | [7:0] | 0xFF    | Touch key channel threshold[7:0]      |
| 181h          | [6:0] | 0xFF    | Touch key channel threshold diff[6:0] |
|               | [7]   | 0xFF    | Touch key channel threshold[8]        |
| 182h          | [6:0] | 0xFF    | Touch key channel threshold diff[6:0] |
|               | [7]   | 0xFF    | Touch key channel threshold[9]        |
| 183h          | [6:0] | 0xFF    | Touch key channel threshold diff[6:0] |
|               | [7]   | 0xFF    | Touch key channel threshold[10]       |

## 14.5.10 BLE

| AddressOffset | Bit    | Default       | Description                                                                                                                                                                                                        |
|---------------|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 190~195h      | [47:0] | 0xFFFFFFFFFFF | BT address                                                                                                                                                                                                         |
| 196h          | [7:0]  | 0x08          | Bit[0]:Fixed to 0<br>Bit[1]:Tx gain K valid bit<br>Bit[2]:Flatness K valid bit<br>Bit[3]:Fixed to 1<br>Bit[7:4]: Fixed to 0<br>Note After Tx gain K flow, remember to enable Tx gain K valid bit, then 0x196 value |
| 197h          | [7:0]  | 0xFF          | Tx gain K<br>Note Users need to write gain value if Tx gain K valid bit is enabled.                                                                                                                                |
| 198~199h      | [15:0] | 0xFFFF        | Flatness K                                                                                                                                                                                                         |
| 19A~19Bh      | [15:0] | 0xFFFF        | Reserved for Realtek                                                                                                                                                                                               |
| 19Ch          | [7:0]  | 0x23          | Max. Tx gain E1M<br>iqm_max_txgain_LE1M                                                                                                                                                                            |
| 19Dh          | [7:0]  | 0x23          | Max. Tx gain E2M<br>iqm_max_txgain_LE2M                                                                                                                                                                            |
| 19E~19Fh      | [15:0] | 0xFFFF        | Reserved for Realtek                                                                                                                                                                                               |

|             |        |            |                                                                                                         |
|-------------|--------|------------|---------------------------------------------------------------------------------------------------------|
| 1A0h        | [7:0]  | 0xFF       | BT thermal meter<br>tmeterx4_txgain_k_module                                                            |
| 1A1h        | [7:0]  | 0xFF       | Logic mapIQK/KOK valid bit<br>0xFF: Disablelogicmap IQK/KOKvalues<br>0xFE: Enablelogicmap IQK/KOKvalues |
| 1A6h ~ 1A9h | [31:0] | 0xFFFFFFFF | LogimapIQK values                                                                                       |
| 1AAh ~ 1ABh | [15:0] | 0xFFFF     | LogimapKOK values                                                                                       |

## 14.5.11 HCI USB

| AddressOffset | Bit   | Name            |
|---------------|-------|-----------------|
| 1C0h          | [7:0] | VID[7:0]        |
| 1C1h          | [7:0] | VID[15:8]       |
| 1C2h          | [7:0] | PID[7:0]        |
| 1C3h          | [7:0] | PID[15:8]       |
| 1C4h          | [7:0] | USB device type |
| 1C5~1Ch       |       | RSVD            |

## 14.6 eFuse APIs

| Items         | API               | Comment                                             |
|---------------|-------------------|-----------------------------------------------------|
| Low Level API | EFUSE_PMAP_WRITE8 | Physical map writeone byte                          |
|               | EFUSE_PMAP_READ8  | Physical map readone byte                           |
|               | EFUSE_LMAP_WRITE  | WriteeFuselogical address by length                 |
|               | EFUSE_LMAPREAD    | ReadtotaleFuselogical map                           |
| mbed API      | efuse_otp_write   | Write content to OTP by length                      |
|               | efuse_otp_read    | ReadeFuseOTP content by length                      |
|               | efuse_mtp_write   | Write user's content to USER MTP Space(0x160~0x17F) |
|               | efuse_mtp_read    | ReadeFusecontent fromaddress(0x160 ~ 0x17F)         |

### 14.6.1 LowLevel APIs

#### 14.6.1.1 EFUSE\_PMAP\_WRITE8

| Items        | Description                                                                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Physical map writeone byte                                                                                                                                         |
| Parameters   | CtrlSettingFusecontrol setting read from REG_LP_EFUSE_CTR(suggest 0)<br>Addr:eFusesphysical address<br>Data:1 byte data to write<br>L25OutVoltage: L25EOUTVOLTAGE. |
| Return       | Status value:<br>_TRUE:Writeisok.<br>_FALSE:Writeisfailed.                                                                                                         |

#### 14.6.1.2 EFUSE\_PMAP\_READ8

| Items        | Description                                                                                                                            |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Physical map readone byte                                                                                                              |
| Parameters   | CtrlSettingFusecontrol setting read from REG_LP_EFUSE_CTR(suggest 0)<br>Addr:eFusesphysical address<br>Data: 1 byte data bufferforread |

|        |                                                             |
|--------|-------------------------------------------------------------|
|        | L25OutVoltage: L25EOUTVOLTAGE.                              |
| Return | Status value:<br>_TRUE:Read is ok<br>_FALSE:Read is failed. |

#### 14.6.1.3 EFUSE\_LMAP\_WRITE

| Items        | Description                                                                                                       |
|--------------|-------------------------------------------------------------------------------------------------------------------|
| Introduction | Write eFuse logical address by length                                                                             |
| Parameters   | addr: logical address should be word aligned<br>cnts: byte number should be even<br>data: data buffer to be write |
| Return       | Status value:<br>_SUCCESS: Write is ok<br>_FAIL: Write is failed.                                                 |

#### 14.6.1.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>_SUCCESS: Read is ok<br>_FAIL: Read is failed. |

### 14.6.2 Mbed APIs

#### 14.6.2.1 efuse\_otp\_write

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

#### 14.6.2.2 efuse\_otp\_read

| Items        | Description                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Read eFuse OTP content by length (mbed API)                                                                                                 |
| Parameters   | address: Specifies the offset of the OTP.<br>len: Specifies the length of readback<br>buf: Specified the address to save the readback data. |
| Return       | Status value:<br>0: Success<br>-1: Failure                                                                                                  |

#### 14.6.2.3 efuse\_mtp\_write

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

|              |                                                                              |
|--------------|------------------------------------------------------------------------------|
| Introduction | Write user's content to USER MTP Space(0x160~0x17F)                          |
| Parameters   | data: Specified the data to write<br>len: Specified the data length to write |
| Return       | Status value:<br>0~32: Success<br>0 or -1: Failure                           |

#### 14.6.2.4 efuse\_mtp\_read

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

## 14.7 eFusePG Command

| Items                                       | Offset      | Command                                             |
|---------------------------------------------|-------------|-----------------------------------------------------|
| Tx Power Index                              | 0x20~0x2B   | iwpriv config_set wmap, 020, 2020202020202020202020 |
| Channel plan, XTAL & Thermal & RTK reserved | 0xC8~0xCF   | iwpriv config_set wmap, 0C8, 20201A05000000FF       |
| 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                           |

1. Channel plan does not affect the results of RF verification, so you can choose to rewrite the correct channel plan here.

# 15 Power Save

## 15.1 Power Save Mode

### 15.1.1 Summary

Ameba-D supports several power modes which are deepsleep mode and sleep mode. Deepsleep mode turns off more power domain than sleepmode so it has lower power consumption. Tickless is a FreeRTOS low power feature which just halt CPU (no clock or power) when it has nothing to do. Table15-1 explains power save related terms.

Table15-1 Power save mode

| Name           | Domain    | Description                          |
|----------------|-----------|--------------------------------------|
| Tickless       | Software  | FreeRTOS low power feature           |
| Sleep mode     | Chiplevel | A power save mode on chip level      |
| Deepsleep mode | Chiplevel | A more power save mode on chip level |

**NOTE**

*configUSE\_TICKLESS\_IDLE* must be enabled in sleep mode because sleep mode is based on tickless.

There are various sources, and all wakeup source is to wake KMO. Then KMO wakes KM4 as appropriate. Refer to Fig15-1 of document UM0400 which show power of peripherals on or off when they are in sleep or deepsleep mode by different colors.

Fig15-1 shows all the wake sources. HS and AON are special because they are master switch that manages some peripherals. UART is peripheral belongs to KM4. Capacitive touch, RTC, etc. belong to AON domain.

Peripherals in AON domain can wake system both in sleep mode and deepsleep mode.



Fig15-1 Wake sources

### 15.1.2 FreeRTOS Tickless

FreeRTOS supports a low power feature called tickless. It is implemented in an idle task which has the lowest priority. That means when there is no other task under running.

Fig15-2 shows idle task code `filovidle`. It will check `elock` to determine if the CPU needs to enter sleep mode. If yes, it will execute function `rtos_pre_sleep_processor` to enter sleep mode.



Fig15-2 FreeRTOS tickless in an idle task

### 15.1.3 SleepMode

#### 15.1.3.1 Sleep Mode Flow

Dual-core design of KMO and KM4 is largely for power save. KM4 is used for the application while KMO is used for the system Firmware, and power/clock control. Sleep mode is realized by the tickless and wakelock mechanism

There are two sleep modes: deepgating(CG) and powergating(PG). CG means to turn off particular cores and PG means to turn off some power domains so PG has lower power consumption. Recommended sleep mode is KMO CG + KM4 PG. Figure 15-3 shows sleep and wake flow of KMO CG+ KM4 PG.

When KM4 is in an idle task, it will judge whether it is necessary to enter sleep mode. If yes, KM4 executes the `WFI` function. The registers of CPU/CVIC, MPU etc. KM4 sends IPC message to KMO and then executes WFE (waiting for event). When KMO receives IPC message and closes KM4 power in IPC interrupt. KMO will judge whether KMO needs to enter the idle task. If itself

If wakeup event occurs, KMO will continue to execute code from where it halts when the power of KM4 and exit CG if need to wake KM4. After KM4 is powered on, it will do the boot on process, and check whether it wakes up from idle by reading register value into the CPU, NVIC, MPU, etc. KM4 will then note where it backs up CPU register.



Fig15-3 KMO CG + KM4 PG

KMO CG + KM4 is relatively simple. KM4 sends IPC and executes to halt itself. KMO will close KM4 clock@ h # is the same with KMO CG + KM4 PG. After wake up, KM4 needs to wake it will enable KM4's clock and execute several code from where it halts.



Fig15-4 KMO CG-KM4 CG

It can be seen from the flowMU # 8  
Application should be designed like that idle tasks have opportunity to be executed and tickless should be enabled, or the sleep flow will not be executed.

**NOTE**

*It is not recommended to develop application on KMO platform because of limited resources*

Fig15-5 shows the code flow of PG and CG in function `tos_pre_sleep_process` on KMO platform. Arrow in the left of function means to enter function while it means exit function if in the right

Refer to Fig15-2 to achieve how an idle task executes to this function.



Fig15-5 Code flow of KM4 PG and CG

Fig15-6 shows the code flow of sleep mode related IPC handler on KMO platform



Fig15-6 Code flow of IPC handle sleep mode on KMO

Fig15-7 shows the code flow of G in function `meertos_pre_sleep_process` on KMO platform. Refer to Fig15-2 to achieve how idle task executes to this function.



Fig15-7 Code flow of KMO CG

### 15.1.3.2 Wakelock

In some situations, system needs to wake up to receive certain events. Otherwise, event may be missed when the system is under sleep. The idea of wakelock is introduced that system cannot sleep if some module is holding wakelock.

A wakelock bit map is used to store the wakelock status. Each module has its own bit in wakelock bit map. PMU\_DEVICE Users can also add wakelock bit map. If the wakelock bit map equals zero, it means that there is no module holding wakelock. If the wakelock bit map is larger than zero, it means that there is some module holding wakelock.

Wakelock is a judging condition in function freertos\_ready\_to\_sleep(). When system holds wakelock PMU\_OS and KM0 holds PMU\_KM4\_RUN and PMU\_OS wakelock. Only if wakelocks are released KM0 or KM4 are permitted to sleep mode. Fig15-8 shows function freertos\_ready\_to\_sleep() and it will judge the value of wakelock.

```
int freertos_ready_to_sleep(void)
{
    u32 current_tick = xTaskGetTickCount();

    /* timeout */
    if (current_tick < sleepwakelock_timeout) {
        return FALSE;
    }

    if (wakelock == 0) { //return TRUE only if all wakelock release
#ifndef ARM_CORE_CM0
        /* timeout */
        if (current_tick >= km4_sleep_timeout) {
            return FALSE;
        } else {
            if (km4_sleep_timeout != 0xffffffff) {
                SOCPS_AONTimer(km4_sleep_timeout - current_tick);
                SOCPS_SetWakeEventAON(BIT_AON_WAKE_TIM0_MSK, ENABLE);
                SOCPS_AONTimerCmd(ENABLE);
            }
        }
#endif
        return TRUE;
    } else
        return FALSE;
} ? end freertos_ready_to_sleep ?
```

Fig15-8 Function freertos\_ready\_to\_sleep()

It is recommended to enter sleep mode by releasing wakelock of KM4. After wakelock of KM4 release, KM4 will enter sleep mode in an idle task and send IPC to KM0. KM0 will power gate or clock gate KM4. Please refer to PMU OS and PMU\_KM4\_RUN. The judgment of wakelock in function freertos\_ready\_to\_sleep() will be the value TRUE, so KM0 can clock gate itself in its idle task.

When the system wakes up, it will enter sleep mode again quickly unless it wakes up.

The definition of related functions is shown in section 15.2

### 15.1.3.3 Suspend and Resume Function

It is a good way to use suspend and resume functions to do something to do before chip sleep or after chip wake up. The suspend and resume functions are executed respectively before CPU enters sleep mode and after CPU wakes up in an idle task.

A typical application of resume function is to acquire the wakelock to prevent chip sleep again. Also, If KM4 chooses PG, some peripheral will lose power so they need to initialize it. It can be implemented in the resume function.

A typical application of suspend function is WoWLAN. Refer to Power Save section for more information.

The definition of related functions is shown in section 15.2

### 15.1.3.4 Wi-Fi Power Save

In IEEE 802.11 power save management, it allows the station to enter its own sleep state. It defines that station needs to keep awake in a certain timestamp and enters sleep state otherwise.

WLAN driver acquires wakelock to avoid the system entering sleep. WLAN needs to keep awake. And it releases wakelock when it is permitted to enter sleep state.

IEEE 802.11 power management allows station to enter power save mode. Station cannot receive frame during power saving. Thus AP needs to buffer these frames and requires station periodically wakeup to check beacon which has the information of buffered frames.



Fig15-9 Timeline of power save

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

In WoWLAN mode, a timer with a period of about 10ms will be set. The suspend function will wake up every 10ms to receive the beacon to maintain the connection.

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

Table 15-2 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. KMO will control RF ON/OFF based on TSF and TIM IE in beacon. |
| WoWLAN | Associated     | LPS+ Tickless KMO will wake up KM4 when receiving data packet.                                                       |

### 15.1.3.5 Wakeup Time

CPU can execute IRQ handlers. Considering that system is wakened takes about 2.8ms to wake KMO only and 3.5ms to wake both KMO and KM4. In KM0CG + KM4 PG mode for KMO, 1.6ms to initialize hardware (mainly XTAL), 1.1ms to execute critical code until 20ms for IRQ handler.

### 15.1.4 Sleep Mode Configuration

KMO sleep mode is CG by default and KM4 sleep mode can be selected to CG or PG by Table 15-3.

### 15.1.4.1 Wakeup Source Setup

Table15-3 Sleep wakeup source

| Wakeup source            | Description                                                                                                                                                                                       | Default status |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| BIT_LP_WEVT_HS_MSK       | 1: enable HS wakeup event<br>0: disable the event to wake up the system                                                                                                                           | OFF            |
| BIT_LP_WEVT_AON_MSK      | 1: enable AON wakeup event<br>0: disable the event to wake up the system<br><br><b>NOTE</b><br><i>It is a master switch for all AON wakeup sources. All AON wakeup sources, listed Table15-4.</i> | ON             |
| BIT_LP_WEVT_SGPIO_MSK    | 1: enable SGPIO wakeup event<br>0: disable the event to wake up the system                                                                                                                        | OFF            |
| BIT_LP_WEVT_COMP_MSK     | 1: enable comparator wakeup event<br>0: disable the event to wake up the system                                                                                                                   | OFF            |
| BIT_LP_WEVT_ADC_MSK      | 1: enable ADC wakeup event<br>0: disable the event to wake up the system                                                                                                                          | OFF            |
| BIT_LP_WEVT_I2C_MSK      | 1: enable I2C wakeup event<br>0: disable the event to wake up the system                                                                                                                          | OFF            |
| BIT_LP_WEVT_UART_MSK     | 1: enable UART wakeup event<br>0: disable the event to wake up the system                                                                                                                         | ON             |
| BIT_LP_WEVT_BOD_MSK      | 1: enable BOD wakeup event<br>0: disable the event to wake up the system                                                                                                                          | OFF            |
| BIT_LP_WEVT_WLAN_MSK     | 1: enable WLAN wakeup event<br>0: disable the event to wake up the system                                                                                                                         | ON             |
| BIT_LP_WEVT_GPIO_MSK     | 1: enable GPIO wakeup event<br>0: disable the event to wake up the system                                                                                                                         | OFF            |
| BIT_LP_WEVT_SWRD_OCP_MSK | 1: enable DCORE SWR OCP wakeup event<br>0: disable the event to wake up the system                                                                                                                | OFF            |
| BIT_LP_WEVT_TIMER_MSK    | 1: enable timer wakeup LP event<br>0: disable the event to wake up the system                                                                                                                     | OFF            |

Table15-4 Sleep AON wakeup sources for BIT\_LP\_WEVT\_AON\_MSK

| Wakeup source         | Description                       | Default status |
|-----------------------|-----------------------------------|----------------|
| BIT_CHIP_PDB_MSK      | 1: Enable chip powdown wake       | ON             |
| BIT_CAPTOUCH_WAKE_MSK | 1: Enable CapTouch wake           | ON             |
| BIT_KEYSCAN_WAKE_MSK  | 1: enable KeyScan wake            | ON             |
| BIT_DLPS_TSF_WAKE_MSK | 1: enable TSF wake under deepmode | OFF            |
| BIT_RTC_WAKE_MSK      | 1: enable RTC wake                | OFF            |
| BIT_AON_WAKE_TIM0_MSK | 1: enable AON timer wake          | ON             |
| BIT_GPIO_WAKE_MSK     | 1: enable GPIO wake               | ON             |

To enable specific wakeup source, corresponding status in array sleep\_wevent\_config[] in rtl8721dlp\_sleepcfg.c should be set firstly shown in fig15-10

```

/* if X can wakeup dsleep, it can wakeup dstandby & sleep */
/* if X can wakeup dstandby, it can wakeup sleep */
PWRCFG_TypeDef sleep_wevent_config[]=
{
    //      Module          Status
    {BIT_LP_WEVT_HS_MSK,           OFF},
    {BIT_LP_WEVT_AON_MSK,          ON},
    {BIT_LP_WEVT_SGPIO_MSK,        OFF},
    {BIT_LP_WEVT_COMP_MSK,         OFF},
    {BIT_LP_WEVT_ADC_MSK,          OFF},
    {BIT_LP_WEVT_I2C_MSK,          OFF},
    {BIT_LP_WEVT_UART_MSK,         OFF},
    {BIT_LP_WEVT_BOD_MSK,          OFF},
    {BIT_LP_WEVT_WLAN_MSK,         OFF},
    {BIT_LP_WEVT_GPIO_MSK,         OFF},
    {BIT_LP_WEVT_SWRD_OCP_MSK,     OFF},
    {BIT_LP_WEVT_TIMER_MSK,        OFF},
    {0xFFFFFFFF,                  OFF}, /* Table end */
};

```

Fig15-10Sleep wake source setup

If the AON wakeup event is chosen as the wakeup source, a specific AON wakeup source should be set in `wakeup_config()` in `rtl8721dlp_sleepcfg.c`, as shown in Fig 15-11.

```

PWRCFG_TypeDef sleep_aon_wevent_config[]=
{
    //      Module          Status
    {BIT_CHIP_PDB_MSK,            ON}, /* [7] R/W 0  1: Indicate chip power-down */
    {BIT_CAPTOUCH_WAKE_MSK,       ON}, /* [6] R/W 0  1: Indicate captouch wake event */
    {BIT_KEYSCAN_WAKE_MSK,        ON}, /* [4] R/W 0  1: Indicate keyscan wake */
    {BIT_DLPS_TSF_WAKE_MSK,      OFF}, /* [3] R/W 0  1: Indicate tsf wake under deep-lps mode */
    {BIT_RTC_WAKE_MSK,           OFF}, /* [2] R/W 0  1: Indicate RTC wake */
    {BIT_AON_WAKE_TIMO_MSK,      ON}, /* [1] R/W 0  1: Indicate AON timer wake */
    {BIT_GPIO_WAKE_MSK,           ON}, /* [0] R/W 0  1: Indicate GPIO wake, see aon_wakepin & dsleep_wakepin_config */

    {0xFFFFFFFF,                  OFF}, /* Table end */
};

```

Fig15-11 Sleep AON wake source setup

The wakeup sources mentioned above are for KM0. You can choose if waking KM4 system up at address offset 5-5.

Table15-5 Wakeup sources for KM4

| Wakeup source            | Description                             | Default status |
|--------------------------|-----------------------------------------|----------------|
| BIT_LP_WEVT_HS_STS       | 1: Indicates HS wakeup event            | ON             |
| BIT_LP_WEVT_AON_STS      | 1: Indicates AON wakeup event           | OFF            |
| BIT_LP_WEVT_SGPIO_STS    | 1: Indicates SGPIO wakeup event         | OFF            |
| BIT_LP_WEVT_COMP_STS     | 1: Indicates Comparator wakeup event    | OFF            |
| BIT_LP_WEVT_ADC_STS      | 1: Indicates ADC wakeup event           | OFF            |
| BIT_LP_WEVT_I2C_STS      | 1: Indicates I2C wakeup event           | OFF            |
| BIT_LP_WEVT_UART_STS     | 1: Indicates UART wakeup event          | OFF            |
| BIT_LP_WEVT_BOD_STS      | 1: Indicates BOD wakeup event           | OFF            |
| BIT_LP_WEVT_WLAN_STS     | 1: Indicates WLAN wakeup event          | OFF            |
| BIT_LP_WEVT_GPIO_STS     | 1: Indicates GPIO wakeup event          | OFF            |
| BIT_LP_WEVT_SWRD_OCP_STS | 1: Indicates DCORE SWR OCP wakeup event | OFF            |
| BIT_LP_WEVT_TIMER_STS    | 1: Indicates timer wakeup LP event      | OFF            |
| BIT_CHIP_PDB_STS         | 1: Indicates chip powerdown             | OFF            |
| BIT_CAPTOUCH_WAKE_STS    | 1: Indicates Captouch wake event        | ON             |
| BIT_KEYSCAN_WAKE_STS     | 1: Indicates Keyscan wake               | ON             |
| BIT_DLPS_TSF_WAKE_STS    | 1: Indicates TSF wake for FMW           | OFF            |
| BIT_RTC_WAKE_STS         | 1: Indicates RTC wake                   | ON             |
| BIT_AON_WAKE_TIMO_STS    | 1: Indicates AON Timer wake             | OFF            |
| BIT_GPIO_WAKE_STS        | 1: Indicates AON wakepin wake           | ON             |

To enable a specific wakeup source for KM4, corresponding status in array hs\_wakeevent\_config [] in rtl8721dlp\_sleepcfg.c should be firstly, as shown Fig15-12

```
HSWAKEEVENT_TypeDef hs_wakeevent_config[]=
{
//      Module           Event          Status
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_HS_STS,      ON}, /* [30] 1: Indicate HS Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_AON_STS,     OFF}, /* [29] 1: Indicate AON Wakeup event (0x128) */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_SGPIO_STS,   OFF}, /* [28] 1: Indicate SGPIO Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_COMP_STS,    OFF}, /* [27] 1: Indicate Comparator Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_ADC_STS,     OFF}, /* [26] 1: Indicate ADC Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_I2C_STS,     OFF}, /* [24] 1: Indicate I2C Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_UART_STS,    OFF}, /* [20] 1: Indicate UART Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_BOD_STS,     OFF}, /* [6] 1: Indicate BOD Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_WLAN_STS,    OFF}, /* [5] 1: Indicate WLAN Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_GPIO_STS,     OFF}, /* [4] 1: Indicate GPIO Wakeup event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_SWRD_OCP_STS, OFF}, /* [2] 1: Indicate DCORE SWR OCP event */
{REG_LP_SLP_WAKE_EVENT_STATUS0, BIT_LP_WEV1_TIMER_STS,    OFF}, /* [1] 1: Indicate GTimer Wakeup system event; */

{REG_AON_WAKE_OPT_STS,         BIT_CHIP_PDB_STS,        OFF}, /* [7] 1: Indicate chip power-down */
{REG_AON_WAKE_OPT_STS,         BIT_CAPTOUCH_WAKE_STS,   ON}, /* [6] 1: Indicate captouch wake event */
{REG_AON_WAKE_OPT_STS,         BIT_KEYSCAN_WAKE_STS,    ON}, /* [4] 1: Indicate keyscan wake */
{REG_AON_WAKE_OPT_STS,         BIT_DLPS_TSF_WAKE_STS,   OFF}, /* [3] 1: Indicate tsf wake under deep-lps mode */
{REG_AON_WAKE_OPT_STS,         BIT_RTC_WAKE_STS,        ON}, /* [2] 1: Indicate RTC wake */
{REG_AON_WAKE_OPT_STS,         BIT_AON_WAKE_TIMO_STS,   OFF}, /* [1] 1: Indicate AON timer wake */
{REG_AON_WAKE_OPT_STS,         BIT_GPIO_WAKE_STS,        ON}, /* [0] 1: Indicate GPIO wake, see aon_wakepin & dsleep_wakepin_config */

{0xFFFFFFFF,                  OFF}, /* Table end */
};
```

Fig15-12Sleep wake source setup for KM4

**NOTE**

The power of KM4 is controlled by KM0 will decide whether to wakeup KM4 according to the wakeup source and the status of wakeup source in array hs\_wakeevent\_config[].

Some peripherals like HS UART need ANA4M, and it can be enabled D\_pwrctrl\_config[] in rtl8721dlp\_sleepcfg.c, as Fig15-13

```
PWRCFG_TypeDef km0_pwrctrl_config[]=
{
//      Module           Status
{BIT_LSYS_PST_SLEP_EACK,      OFF}, //BIT1: 1 Enable ANA4M CLK when PMC enter into sleep mode
{BIT_LSYS_PST_SLEP_EBUS,       OFF}, //BIT2: 1 Enable platform clock when PMC entro into sleep mode
{BIT_LSYS_PST_SLEP_EMPM,      OFF}, //BIT3: 1 means RAM can not enter low power mode, 0 can enter,
{BIT_LSYS_PST_SLEP_LDLM,      OFF}, //BIT4 0 LPSDO enter sleep mode
{BIT_LSYS_PST_SLEP_ERCK,      OFF}, //BIT5 0 gate ls system clock
{BIT_LSYS_PST_SLEP_DPSW,      ON}, //BIT6: 1: disable power switch and use SWR mode, 0: enable po
{BIT_LSYS_PST_SLEP_EPWM,      OFF}, //BIT7: 1 LDO mode: 1.1V or SWR PWM mode, 0 LDO mode 0.9V or S
{BIT_LSYS_PST_SLEP_ESWR,      ON}, //BIT8: 0 is disable SWR when enter sleep
{BIT_LSYS_PST_SLEP_EXTL,      OFF}, //BIT9 0 disable XTAL when sleep, should conflict with BIT_LS
{BIT_LSYS_PST_SLEP_XACT,      ON}, //BIT10 based on BIT_LSYS_PST_SLEP_EXTL

{0xFFFFFFFF,                  OFF}, /* Table end */
};
```

Fig15-13Power management configuration

Some peripherals also need close OSC2M in sleep mode. Whether to close clock OSC2M when system is in sleep mode is determined by km0\_osc2m\_close in structure ps\_config in rtl8721dlp\_sleepcfg.c, as Fig15-14. Value TRUE means it will close clock OSC2M in sleep mode.

```
PSCFG_TypeDef ps_config = {
    .km0_config_wifi_enable = TRUE,
    .km0_enable_key_touch = FALSE, //BIT_KEY_ENABLE | BIT_CAPTOUCH_ENABLE,
    .km0_ticks_debug = FALSE, /* if open WIFI FW, should close it, or beacon will lost in WOWLAN */
    .km0_osc2m_close = TRUE,
    .km0_pg_enable = FALSE,
    .km0_rtc_calibration = FALSE,
    .km0_audio_pad_enable = TRUE,
};
```

Fig15-14Control of clock OSC2M in sleep mode

#### 15.1.4.1.1 HSWakeup Event(HS UART)

HS wakeup event includes wakeup source HS UART (UART0). When using HS wakeup event as the wakeup source, clock ANA4M should not be closed. So BIT\_LSYS\_PST\_SLEP\_EACK should set to ON as shown Fig15-13

When using UART0 as wakeup source, clockMDS02km0\_osc2m\_close@Fig15-14 should equal FALSE.

The following steps show how to configure HS UART in sleep mode.

- (1) Set km0\_osc2m\_close = FALSE in structure ps\_config @Fig15-14
- (2) Set BIT\_LSYS\_PST\_SLEP\_EACK@Fig15-18
- (3) Initialize UART and enable its interrupt.
- (4) Switch UART to low power mode and switch clock source to OSC@Fig15-18. Set corresponding LOW\_POWER\_RX\_ENABLE item to ENABLE in structure uart\_config[] as Fig15-15 and then it will switch automatically in function serial\_baud() using low level API, please do it manually as shown@Fig15-16

```
UARTCFG_TypeDef uart_config[4] =
{
    /* HS UART--> UART0 */
    {
        .LOW_POWER_RX_ENABLE = DISABLE, /* to enable low power RX*/
    },
    /* BT UART--> UART1 */
    {
        .LOW_POWER_RX_ENABLE = DISABLE,
    },
    /* Log UART--> UART2 */
    {
        .LOW_POWER_RX_ENABLE = DISABLE,
    },
    /* LPUART-->UART3 */
    {
        .LOW_POWER_RX_ENABLE = DISABLE,
    },
};
```

Fig15-15Configure low power RX mode for UART mbed API

```
UART_MonitorParaConfig(UART0_DEV, 100, ENABLE);
UART_RxMonitorCmd(UART0_DEV, ENABLE); //low power rx monitor
RCC_PeriphClockSource_UART(UART0_DEV, UART_RX_CLK_OSC_LP); //switch clock
UART_LP_RXBaudSet(UART0_DEV, baudrate, 2000000); //low power rx mode
UART_RxCmd(UART0_DEV, ENABLE);
```

Fig15-16Configure low power RX mode manually for UART low level API

- (5) Set BIT\_LP\_WEVT\_HS\_MSK status ON in array sleep\_wevent\_config[] as shown@Fig15-10
- (6) Set BIT\_LP\_WEVT\_HS\_SS status ON in array wakeevent\_config [] as shown@Fig15-12 if you want to wake up KM4 at the same time.
- (7) Set HS UART wake event@Fig15-10 platform before sleep by using "SOCPS\_SetWakeEvent\_HP(BIT\_HS\_WEVT\_UART\_MSK, 1);"

#### 15.1.4.1.2 AON

AON wakeup event includes PDB-Touch, KeyScan, RTC, AON timer and GPIO.

#### PDB

- (1) ChangePMC power down direction to SW by register AON\_PM\_OPT.
- (2) Enable the interrupt of PDB by register AON\_CHIP\_PWR\_DOWN\_MSK.
- (3) Set BIT\_LP\_WEVT\_AON\_MSK status ON in array sleep\_wevent\_config[] as shown@Fig15-10 and set BIT\_CAPTOUCH\_WAKE\_MSK status ON in array sleep\_aon\_wevent\_config[] as shown@Fig15-11.
- (4) Set BIT\_LP\_WEVT\_AON\_STS@Fig15-12 and CHIP\_PDB\_STS status ON in array wakeevent\_config [] as shown@Fig15-12 if you want to wakeup KM4 at the same time.

#### Cap-Touch

- (1) Initialize Cap-Touch and enable its interrupts.
- (2) Set BIT\_LP\_WEVT\_AON\_MSK status ON in array sleep\_wevent\_config[] as shown@Fig15-10 and set BIT\_CHIP\_PDB\_MSK status ON in array sleep\_aon\_wevent\_config[] as shown@Fig15-11.
- (3) Set BIT\_LP\_WEVT\_AON\_STS and BIT\_CAPTOUCH\_WAKE\_STS status ON in array wakeevent\_config [] as shown@Fig15-12 if you want to wake up KM4 at the same time.

#### NOTE

k Cap-Touch initialization.

## Key-Scan

- (1) Initialize KeyScan and enable its interrupts.
- (2) Set BIT\_LP\_WEVT\_AON\_MSK status ON in `sleep_aon_wevent_config[]` as shown in Fig 15-10 and set BIT\_KEYSCAN\_WAKE\_MSK status ON in array `sleep_aon_wevent_config[]` as shown in Fig 15-11.
- (3) Set BIT\_LP\_WEVT\_AON\_STS and BIT\_KEYSCAN\_WAKE\_STS status ON in `sleep_wakeevent_config []` as shown in Fig 15-12 if you want to wake up KM4 at the same time.

**NOTE**

k *-Scan initialization.* M

## RTC

- (1) Initialize RTC and enable its interrupts.
- (2) Set BIT\_LP\_WEVT\_AON\_MSK status ON in `sleep_aon_wevent_config[]` as shown in Fig 15-10 and set BIT\_RTC\_WAKE\_MSK status ON in array `sleep_aon_wevent_config[]` as shown in Fig 15-11.
- (3) Set BIT\_LP\_WEVT\_AON\_STS and RTC\_WAKE\_STS status ON in `sleep_wakeevent_config []` as shown in Fig 15-12 if you want to wake up KM4 at the same time.

## AON Timer

- (1) Enable AON Timer and set the time to wake up system.
- (2) Set BIT\_LP\_WEVT\_AON\_MSK status ON in `sleep_aon_wevent_config[]` as shown in Fig 15-10 and set BIT\_AON\_WAKE\_TIMO\_MSK status ON in array `sleep_aon_wevent_config[]` as shown in Fig 15-11.
- (3) Set BIT\_LP\_WEVT\_AON\_STS and AON\_WAKE\_TIMO\_STS status ON in `sleep_wakeevent_config []` as shown in Fig 15-12 if you want to wake up KM4 at the same time.

**NOTE**

The AON Timer is imprecise milliseconds its maximum value is 32760000ms (546mins).

## GPIO (Wakepin)

- (1) The setup of GPIO is shown in Fig 16.1.5
- (2) Set BIT\_LP\_WEVT\_AON\_MSK status ON in `sleep_aon_wevent_config[]` as shown in Fig 15-10 and set BIT\_GPIO\_WAKE\_MSK status ON in array `sleep_aon_wevent_config[]` as shown in Fig 15-11.
- (3) Set BIT\_LP\_WEVT\_AON\_STS and GPIO\_WAKE\_STS status ON in `sleep_wakeevent_config []` as shown in Fig 15-12 if you want to wake up KM4 at the same time.

### 15.1.4.1.3 GPIO

When o 8 h @ \ When system is in sleep mode is decided by km0\_osc2m\_close in structure ps\_config in rtl8721dlp\_sleep as shown in Fig 15-13

- (1) Set km0\_osc2m\_close = FALSE in structure ps\_config as shown in Fig 15-14
- (2) Initialize GPIO and enable its interrupt.
- (3) Set BIT\_LP\_WEVT\_GPIO\_MSK status ON in `sleep_wevent_config[]` as shown in Fig 15-10
- (4) Set BIT\_LP\_WEVT\_GPIO\_STS status ON in `sleep_wakeevent_config []` as shown in Fig 15-12 if you want to wake up KM4 at the same time.
- (5) Switch GPIO clock to OSC2M by register REG\_SYS\_CLK\_CTRL1 before entering sleep mode.

### 15.1.4.1.4 Comparator

When # when system is in sleep mode is decided by km0\_osc2m\_close in structure ps\_config in rtl8721dlp\_sleep as shown in Fig 15-14

- (1) Set km0\_osc2m\_close = FALSE in structure ps\_config as shown in Fig 15-14
- (2) Initialize ADC and comparator, and enable corresponding interrupt.
- (3) Set BIT\_LP\_WEVT\_COMP\_MSK status ON in `sleep_wevent_config[]` as shown in Fig 15-10
- (4) Set BIT\_LP\_WEVT\_COMP\_STS status ON in `sleep_wakeevent_config []` as shown in Fig 15-12 if you want to wake up KM4 at the same time.

- (5) Switch ADC clock to OSC2M by register REG\_SYS\_CLK\_CTRL1 before entering sleep mode.

#### 15.1.4.1.5 ADC

When \ o # U system is in sleep mode is decided by km0\_osc2m\_close in structure ps\_config in rtl8721dlp\_sleepcfg15-1\$ shown in

- (1) Set km0\_osc2m\_close = FALSE in structure ps\_config as Fig15-14.in
- (2) Initialize ADC and enable its interrupt.
- (3) SetBIT\_LP\_WEVT\_ADC\_MSK status ON in array sleep\_wevent\_config[] as shown Fig15-10
- (4) SetBIT\_LP\_WEVT\_ADC\_STS status ON in array wakeevent\_config [] as shown Fig15-12 if you want take up KM4 at the same time.
- (5) Switch ADC clock to OSC2M by register REG\_SYS\_CLK\_CTRL1 before entering sleep mode.

#### 15.1.4.1.6 I2C

When \ o # U V U C2M when system is in sleep mode is decided by km0\_osc2m\_close in structure ps\_config in rtl8721dlp\_sleepcfg15-14\$ shown in clock ANA4M can be configured in km0\_pwrctrl\_config[] in rtl8721dlp\_sleepcfg.cFig15-14\$ shown in

- (1) Set km0\_osc2m\_close = FALSE in structure ps\_config as Fig15-14, and set BIT\_LSYS\_PST\_SLEP\_EACK status ON in array km0\_pwrctrl\_n6g[], as shown Fig15-13
- (2) Initialize I2C and enable its interrupt.
- (3) Set BIT\_LP\_WEVT\_I2C\_MSK status ON in array sleep\_wevent\_config[] Fig15-10 in
- (4) Set BIT\_LP\_WEVT\_I2C\_STS status ON in array hs\_wakeevent\_config [] Fig15-12 if you want to wake up KM4 at the same time.
- (5) Switch I2C clock to OSC2M by calling RCC\_PeriphClockSource\_I2C() before entering sleep mode.

#### 15.1.4.1.7 LP UART

When using LP UART(UART3) as wakeup source, clock OSC2M sho

OSC2M when system is in sleep mode is decided by km0\_osc2m\_close in structure ps\_config in rtl8721dlp\_sleepcfg15-14\$ as shown in

- (1) Set km0\_osc2m\_close = FALSE in structure ps\_config as Fig15-14.in
- (2) InitializeUART and enable its interrupt.
- (3) Switch UART to low power mode and switch clock source to OSC2MUART mbed AP(serial\_api.c)Setcorresponding LOW\_POWER\_RX\_ENABLE itemENABLE in structure uart\_config[] as shown Fig15-5 and then it will switch automatically in function serial\_baud()using low level API, please do it manually shown Fig15-16
- (4) SetBIT\_LP\_WEVT\_UART\_MSK status ON in array sleep\_wevent\_config[] as shown Fig15-10
- (5) SetBIT\_LP\_WEVT\_UART\_STS status ON in array wakeevent\_config [] as shown Fig15-12 if you want to wake up KM4 at the same time.

#### 15.1.4.1.8 Log UART

When usingLog UART(UART2)

OSC2M when system is in sleep mode is decided by km0\_osc2m\_close in structure ps\_config in rtl8721dlp\_sleepcfg15-14\$ as shown in

- (1) Set km0\_osc2m\_close = FALSE in structure ps\_config as Fig15-14.in
- (2) InitializeUART and enable its interrupt.
- (3) SetBIT\_LP\_WEVT\_UART\_MSK status ON in array sleep\_wevent\_config[] as shown Fig15-10
- (4) SetBIT\_LP\_WEVT\_UART\_STS status ON in array wakeevent\_config [] as shown Fig15-12 if you want take up KM4 at the same time.

#### 15.1.4.1.9 BOD

- (1) SetBOD threshold and enable its interrupt.
- (2) SetBIT\_LP\_WEVT\_BOD\_MSK status ON in array sleep\_wevent\_config[] as shown Fig15-10

- (3) SetBIT\_LP\_WEVT\_BOD\_STS status ON in array\_wakeevent\_config [] as shown in Fig 15-12 if you want to wake up KM4 at the same time.

#### 15.1.4.1.10 WLAN

- (1) SetBIT\_LP\_WEVT\_WLAN\_MS status ON in array\_wakeevent\_config[] as shown in Fig 15-10  
 (2) SetBIT\_LP\_WEVT\_WLAN\_SS status ON in array\_wakeevent\_config [] as shown in Fig 15-12 if you want to wake up KM4 at the same time.

#### 15.1.4.1.11 GPIO

- (1) Initialize a GPIO and enable its interrupt.  
 (2) SetBIT\_LP\_WEVT\_GPIO\_MS status ON in array\_wakeevent\_config[] as shown in Fig 15-10  
 (3) SetBIT\_LP\_WEVT\_GPIO\_SS status ON in array\_wakeevent\_config [] as shown in Fig 15-12 if you want to wake up KM4 at the same time.

#### 15.1.4.1.12 PTimer

When MU can be configured in km0\_pwrctrl\_config[] in rt18721dlp\_sleepcfg.c, Fig 15-13 in

- (1) SetBIT\_LSYS\_PST\_SLEP\_EACK status ON in array km0\_pwrctrl\_config[], Fig 15-13 in  
 (2) Initialize the timer and enable its interrupt KMO platform.  
 (3) SetBIT\_LP\_WEVT\_TIMER\_MS status ON in array\_wakeevent\_config[] as shown in Fig 15-10  
 (4) SetBIT\_LP\_WEVT\_TIMER\_SS status ON in array\_wakeevent\_config [] as shown in Fig 15-12 if you want to wake up KM4 at the same time.

**NOTE**

LP Timer(TIMM005) belongs to KMO, and only TIM005 can be wakeup source. Distinguish them with HS timer (5) which can not be wakeup source.

#### 15.1.4.2 How to Enter Sleep Mode

Function pmu\_release\_wakelock(PMU\_OS) will be called in KM4 if the system wants to enter into sleep mode. The global parameter wakelock will be checked in idle task, once wakelock equals zero and there is nothing to do with the system into sleep mode.

#### 15.1.4.3 How to Wakeup from Sleep Mode

##### 15.1.4.3.1 HS Wakeup Event

The chip will wake up from sleep mode when the specific interrupt that enabled is triggered.

**NOTE**

Switch the clock back after the system wakes up from sleep mode if the clock of the source has been changed before entering sleep mode.

##### 15.1.4.3.2 AON

#### PDB

The chip will wake up from sleep mode when the interrupt of PDB that enabled is triggered.

#### Cap-Touch

The chip will wake up from sleep mode when the interrupt of Cap-Touch that enabled is triggered.

#### Key-Scan

The chip will wake up from sleep mode when the interrupt of the enabled is triggered.

## RTC

The chip will wake up from sleep mode when the interrupt of RTC that enabled is triggered.

## AON Timer

u

## GPIO (Wakepin)

The chip will wake up from sleep mode when there is a corresponding edge of GPIO that enabled is triggered.

### 15.1.4.3.3 GPIO

The chip will wake up from sleep mode when the interrupt of GPIO that enabled is triggered.

#### NOTE

*Switch GPIO clock back to LS APB Clock by register REG\_SYS\_CLK\_CTRL1 after the system wakes up from sleep mode.*

### 15.1.4.3.4 Comparator

The chip will wake up from sleep mode when the interrupt of comparator that enabled is triggered.

#### NOTE

*Switch comparator clock back to LS APB Clock by register REG\_SYS\_CLK\_CTRL1 after the system wakes up from sleep mode.*

### 15.1.4.3.5 ADC

The chip will wake up from sleep mode when the interrupt of ADC that enabled is triggered.

#### NOTE

*Switch ADC clock back to LS APB Clock by register REG\_SYS\_CLK\_CTRL1 after the system wakes up from sleep mode.*

### 15.1.4.3.6 I2C

The chip will wake up from sleep mode when the interrupt of I2C that enabled is triggered.

#### NOTE

*Switch I2C clock back to LS APB Clock by calling RCC\_PeriphClockSource\_I2C() after the system wakes up from sleep mode.*

### 15.1.4.3.7 LP UART

The chip will wake up from sleep mode when the interrupt of LP UART that enabled is triggered.

#### NOTE

*Switch LP UART clock back to XTAL by calling RCC\_PeriphClockSource\_UART() after the system wakes up from sleep mode at high baud rate.*

### 15.1.4.3.8 Log UART

The chip will wake up from sleep mode when the interrupt of Log UART that enabled is triggered.

### 15.1.4.3.9 BOD

The chip will wake up from sleep mode when the interrupt of BOD that enabled is triggered.

### 15.1.4.3.10 WLAN

The chip will wake up from sleep mode every beacon interval, and the default interval is 102.4ms.

### 15.1.4.3.11 GPIO

The chip will wake from sleep mode when the interrupt is triggered.

**NOTE**

Switch GPIO clock back to LS APB by register REG\_SYS\_CLK\_CTRL after wakes up from sleep mode.

### 15.1.4.3.12 Timer

The chip will wake up

## 15.1.4.4 How to Get Wakeup Information

Table15-6 Sleep wakeup information

| API                           | Introduction                                                | Parameters                                                                                                                                                                                                      |
|-------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WakeEvent                     | Gets sleep wake reason<br>It can only be accessed in KMO    | Bit[1]: GTimer<br>Bit[2]: DCORE SWR OCP<br>Bit[4]: GPIO<br>Bit[5]: WLAN<br>Bit[6]: BOD<br>Bit[20]: UART<br>Bit[24]: I2C<br>Bit[26]: ADC<br>Bit[27]: Comparator<br>Bit[28]: SGPIO<br>Bit[29]: AON<br>Bit[30]: HS |
| int SOCPS_AONWakeReason(void) | Gets AON wake reason<br>It can be accessed in KMO and KM4   | Parameter: None<br>Retval status value:<br>Bit[0]: AON wakepin<br>Bit[1]: AON Timer<br>Bit[2]: RTC<br>Bit[3]: TSF Timer<br>Bit[4]: KeyScan<br>Bit[6]: CapTouch                                                  |
| int SOCPS_WakePinCheck(void)  | Gets AON Wakepin index<br>It can be accessed in KMO and KM4 | Parameter: None<br>Retval status value:<br>Bit[0]: wakepin0<br>Bit[1]: wakepin1<br>Bit[2]: wakepin2<br>Bit[3]: wakepin3                                                                                         |

## 15.1.5 Deepsleep Mode

Deepsleep mode has a lower power consumption than AON domain poweron. So only peripheral in AON domain can wakeup chip. There are 2 ways to enter deepsleep mode. One is to release deepsleep lock, is KM4 sends related KPO directly. So If using way2, tickless is not necessary. Once receive IPC message, KMO makes KMO enter deep sleep mode in IPC interrupt.

The wake process of deep sleep chip is shown in Fig15-17 shows deepsleep mode flow.



Fig15-17Deepsleep mode flow

Fig15-18showsthecode flow of IPC handler in deepsleep mode on KMO platform.



Fig15-18Code flow of IPC handler in deepsleep mode

## 15.1.6 Deepsleep Mode Configuration

### 15.1.6.1 Wakeup Source Setup

Table15-7 Deepsleep wakeup source

| Wakeupsource          | Description                   | Defaultstatus |
|-----------------------|-------------------------------|---------------|
| BIT_CAPTOUCH_WAKE_STS | Indicates CapTouch wake event | ON            |
| BIT_KEYSCAN_WAKE_STS  | Indicates Ke\$can wake        | ON            |
| BIT_DLPS_TSF_WAKE_STS | Indicates TSF wake forFWFW    | ON            |
| BIT_RTC_WAKE_STS      | Indicates RTC wake            | OFF           |

|                       |                            |    |
|-----------------------|----------------------------|----|
| BIT_AON_WAKE_TIMO_STS | Indicates AON Timer wake   | ON |
| BIT_GPIO_WAKE_STS     | Indicates AON wakepin wake | ON |

To set corresponding deepsleep source, firstly you need to set corresponding wakeup source Status ON in array `dsleep_aon_wevent_config[]` in `rtl8721dlp_sleepcfg.c`, as shown in Fig 15-19.

```
PWRCFG_TypeDef dsleep_aon_wevent_config[] = {
{
    .Module = "AON_WAKE_TIMO_STS", .Status = "ON"}, /* [6] R/W:0 */ 1: Indicate captouch wake event */
    .Module = "KEYSCAN_WAKE_STS", .Status = "ON"}, /* [4] R/W:0 */ 1: Indicate keyscan wake */
    .Module = "DLPS_TSF_WAKE_STS", .Status = "ON"}, /* [3] R/W:0 */ 1: Indicate tsf wake under deep-lps mode */
    .Module = "RTC_WAKE_STS", .Status = "OFF"}, /* [2] R/W:0 */ 1: Indicate RTC wake */
    .Module = "AON_WAKE_TIMO_STS", .Status = "ON"}, /* [1] R/W:0 */ 1: Indicate AON timer wake */
    .Module = "GPIO_WAKE_STS", .Status = "ON"}, /* [0] R/W:0 */ 1: Indicate GPIO wake, see aon_wakepin & dsleep_wakepin_config */
};

{0xFFFFFFFF, .Status = "OFF"}, /* Table end */};
```

Fig 15-19 Deepsleep wake source setup

When KM4 wants to enter deep sleep mode, it will construct a global variable in structure `KM4SLEEP_ParamDef` shown in Fig 15-20, and transmit it to KMO to inform KMO execute corresponding operation. The variable can be local variable, or if `globalVariables` is set, the KMO may get wrong information.

**NOTE**

As `rtl8721dlp_sleepcfg.c` is the code under KMO, if you modify it, you need to rebuild KMO project, and if you are using IAR, KM4 also needs to be rebuilt to sync the KMO image.

```
typedef struct
{
    u8 dlpss_enable;
    u8 sleep_type;
    u32 sleep_time;
} KM4SLEEP_ParamDef;
```

Fig 15-20 KM4 sleep parameter structure

Table 15-8 Structure `KM4SLEEP_ParamDef` member description

| Member      | Description                                                                                             |
|-------------|---------------------------------------------------------------------------------------------------------|
| dlps_enable | Enable deep sleep mode:<br>TRUE: enable deep sleep<br>FALSE: disable deep sleep                         |
| sleep_type  | Just for sleep mode usage<br>SLEEP_PG: KM4 enter power gate mode<br>SLEEP(CG: KM4 enter clock gate mode |
| sleep_time  | If using AON Timer to wakeup chip, you should set the variable to control the time to sleep.            |

### 15.1.6.1.1 Cap-Touch

- (1) Initialize Cap-Touch and enable its interrupts that you want to wakeup chip in deepsleep mode. As RAM and CPU are shut down in deepsleep mode while Cap-Touch register keep alive, the interrupt handler and interrupt enable of CPU should be reinitialized, then Cap-Touch interrupts can be handled.
- (2) Set `BIT_CAPTOUCH_WAKE_STS` ON in array `dsleep_aon_wevent_config[]` as shown in Fig 15-19.

**NOTE**

k Cap-Touch initialization.

### 15.1.6.1.2 Key-Scan

- (1) InitializeKey-Scan and enable its interrupts that you want to wakeup chip in deepsleep mode. As RAM and CPU are shut down in deepsleep mode while the Key register keep alive, the interrupt handler and interrupt enable of CPU should be reinitialized, the Key-Scan interrupts can be handled.
- (2) SetBIT\_KEYSCAN\_WAKE\_STS status ON in array dsleep\_aon\_wevent\_config[] as Fig15-19.

**NOTE**

k -Scan initialization. M

### 15.1.6.1.3 RTC

- (1) InitializeRTCand enable its interrupts that you want to wakeup chip in deepsleep mode. As RAM and CPU are shut down in deepsleep mode while the RTC register keep alive, the interrupt handler and interrupt enable of CPU should be reinitialized, the RTC interrupts can be handled.
- (2) SetBIT\_RTC\_WAKE\_STS status ON in array dsleep\_aon\_wevent\_config[] as Fig15-19.

### 15.1.6.1.4 AON Timer

- (1) SetAON Timer and transmit it to KMO by ipc\_send\_message(), the detailed steps is shown in Fig15-16.
- (2) SetBIT\_AON\_WAKE\_TIMO\_STS status ON in array dsleep\_aon\_wevent\_config[] as Fig15-19.

**NOTE**

The AON Timer is imprecise milliseconds its maximum value is 32760000ms (546mins).

### 15.1.6.1.5 GPIO

The GPIO that can wake up chip in deepsleep is not all the common GPIOs, only 12 GPIOs can work the chip as shown in Fig15-21, we call them AON wakepins. Only four AON wakepins can be set the same time. As the note in Fig15-21, there are four AON wakepins (0, 1, 2, 3), each AON wakepin has three PINMUX (S0, S1, S2).

For each AON wakepin, you can only select one PINMUX at a time by the Module column with the Status column ON in array dsleep\_aon\_wevent\_config[] in rti8721dp\_sleepcfg.c, as Fig15-21. The Polarity column is used to choose wakeup edge. Ameba only supports AON wakepin wake up the chip by edges. The value 0 means Falling Edge wakeup and value 1 means Rising Edge wake up.

For AON wakepins, if setting Falling Edge wakeup, SDK will automatically set the pin internal pull up. And if setting Rising Edge wakeup, SDK will automatically set the pin internal pull down.

```
u8 aon_wakepin[4][3] = {
    { /* wakepin 0 */
        _PA_12, /* PINMUX_S0 */
        _PA_16, /* PINMUX_S1 */
        _PA_20, /* PINMUX_S2 */
    },
    { /* wakepin 1 */
        _PA_13, /* PINMUX_S0 */
        _PA_17, /* PINMUX_S1 */
        _PA_21, /* PINMUX_S2 */
    },
    { /* wakepin 2 */
        _PA_14, /* PINMUX_S0 */
        _PA_18, /* PINMUX_S1 */
        _PA_25, /* PINMUX_S2 */
    },
    { /* wakepin 3 */
        _PA_15, /* PINMUX_S0 */
        _PA_19, /* PINMUX_S1 */
        _PA_26 /* PINMUX_S2 */
    },
};
```

Fig15-21AON wakepins

```

WAKEPIN_TypeDef sleep_wakepin_config []=
{
//  Module          Status      Polarity
{ PINMUX_S0,      OFF,        1 }, /* wakeup_0 config */
{ PINMUX_S0,      OFF,        1 }, /* wakeup_1 config */
{ PINMUX_S0,      OFF,        1 }, /* wakeup_2 config */
{ PINMUX_S0,      OFF,        1 }, /* wakeup_3 config */

{ 0xFFFFFFFF,    OFF,        0 }, /* Table end */
};

```

Fig15-22AON wakepins setup

AON wakepin setup:

- (1) SetBIT\_GPIO\_WAKE\_STS status ON in array dsleep\_aon\_wevent\_config[] as Fig15-19
- (2) SetAON Wakepin and expected edge to wakeup chip in array sleep\_wakepin\_config[] Fig15-20 in

Example:

If want a falling edge of \_PA\_18 to wakeup chip, the AON setting is as show Fig15-23 \_PA\_18 is PINMUX\_S1 of wakepin 2.

```

WAKEPIN_TypeDef sleep_wakepin_config []=
{
//  Module          Status      Polarity
{ PINMUX_S0,      OFF,        1 }, /* wakeup_0 config */
{ PINMUX_S0,      OFF,        1 }, /* wakeup_1 config */
{ PINMUX_S1,      ON,        0 }, /* wakeup_2 config */
{ PINMUX_S0,      OFF,        1 }, /* wakeup_3 config */

{ 0xFFFFFFFF,    OFF,        0 }, /* Table end */
};

```

Fig15-23AON Wakepins setup example

### 15.1.6.2 HowtoEnter Deepsleep Mode

To enter deepsleep mode, you should execute the following steps:

- (1) Construct global variable with the structure M4SLEEP\_ParamDef
- (2) o global variable to enable deep sleep mode
- (3) o if you want to wakeup chip at specified time by AON Timer wakeup source
- (4) # @ h # @global variable u @ # MO - o o @M@ # u @ \ V

**NOTE**

Refer to example\project\realtek\_amebaD\_va0\_example\example\_source\SMOraw

Release deepwakelock is also a way to enter deepsleep mode but not recommend.

### 15.1.6.3 How to Wakeup from Deepsleep Mode

When the chip wakes up from deep sleep, it will do the boot process.

#### 15.1.6.3.1 Cap-Touch

The interrupt Cap-Touch that enabled happens will wake up the chip.

#### 15.1.6.3.2 Key-Scan

The interrupt of Key-Scan that enabled happens will wake up the chip.

### 15.1.6.3.3 RTC

The interrupt of RTC that enabled happens will wake up the chip.

### 15.1.6.3.4 AON Timer

u reach will wake up the chip.

### 15.1.6.3.5 GPIO

The corresponding edge of AOnWakepin(s) that setup in section 15.1.6.1.5 happens will wake up the chip.

### 15.1.6.4 How to Get Wakeup Information

Table 15-9 Deepsleep wakeup information API

| API                                | Introduction               | Parameters                                                                                                                                                     |
|------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| u32 OCPS_DsleepWakeStatusGet(void) | Gets deepsleep wake status | Parameter: None<br>Retval status value:<br>TRUE: boot from deepsleep<br>FALSE:boot from power on                                                               |
| int SOCPS_AONWakeReason(void)      | Gets deepsleep wake reason | Parameter: None<br>Retval status value:<br>Bit[0]: AON wakepin<br>Bit[1]: AON Timer<br>Bit[2]: RTC<br>Bit[3]: TSF Timer<br>Bit[4]: KeyScan<br>Bit[6]: CapTouch |
| int SOCPS_WakePinCheck(void)       | Gets AONwakepin index      | Parameter: None<br>Retval status value:<br>Bit[0]: wakepin0<br>Bit[1]: wakepin1<br>Bit[2]: wakepin2<br>Bit[3]: wakepin3                                        |

### 15.1.6.5 How to Maintain Information in Deepsleep Mode

The memory of Retention RAM can be used when the chip enters deepsleep mode, so we can use it to keep necessary information. RRAM\_USER\_RSVD is reserved for customer usage as [Figure 15-24](#).

```

/*
 * @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_IP;
    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_cur_bitmode;

    uint8_t FLASH_ClockDiv;
    uint8_t FLASH_ReadMode;
    uint8_t FLASH_pseudo_prm_en;
    uint8_t FLASH_addr_phase_len;

    uint8_t FLASH_cmd_wr_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;
/**@}
 */

```

Fig15-24Retention RAM usage

### 15.1.7 GPIO Pull Control

When entering sleep and deepsleep mode, I/O pull control is needed. Otherwise in power leakage. For more information to AN0400 (section: User Configuration on mapcfg).

## 15.2 Power Save Related APIs

| 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 wakelock for module                                        |
| <pmu_release_wakelock          | Release wakelock                                                   |
| <pmu_set_sysactive_time        | Acquire wakelock, and release wakelock automatically after timeout |
| <pmu_set_max_sleep_time        | Set maxsleep time                                                  |

### 15.2.1 pmu\_register\_sleep\_callback

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

**NOTE**

*Yield OS is not permitted in suspend/resume callback function like taskENTER, mutex, sema and so on.  
pmu\_set\_sysactive\_time is not permitted in suspend callback while 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                                                                         |

## 15.2.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 |

## 15.2.3 pmu\_acquire\_wakelock

Wakelock is a 32bit map. Each module owns 1 bit in this bit map. FreeRTOS tickless timer wakes up the wakelock and decides that whether it can enter sleep state.

If any module acquires and holds 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 |

## 15.2.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 |

## 15.2.5 pmu\_set\_sysactive\_time

Set system active time. System cannot sleep before timeout.

**NOTE**

*pmu\_set\_sysactive\_time is not permitted in suspend callback function, while permitted in resume call back function.*

| Parameter | Type     | Introduction                                  |
|-----------|----------|-----------------------------------------------|
| <timeout> | uint32_t | System cannot sleep before timeoutUnit is ms. |

## 15.2.6 pmu\_setmax\_sleptime

Set systemmax sleptime.

**NOTE**

*System may be waked by other wake events before this timer timeout.  
Before entering deepsleep mode, disable the AON timer by SOCPS\_AONTimerCmd(DISABLE).  
This setting only works once. The timer will be cleared after system wakeup.*

| Parameter | Type     | Introduction                     |
|-----------|----------|----------------------------------|
| <timeout> | uint32_t | Systemmax sleptimeoutUnit is ms. |

## 15.3 Power Consumption Measurement

### 15.3.1 Power Consumption Summary

The power consumption values below are tested with the Ameba FN68 board and the image version is 6.2b.

Table 15-10 Power consumption of different power modes

| 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 KeyScan                       | RTC timer<br>1KB retention RAM<br>KeyScan                                  | 12~13   | 12~13     | uA   |
|                | Deepsleep with CapTouch<br>(average current) | RTC timer<br>1KB retention RAM<br>CapTouch                                 | 20      | 16        | uA   |
| Sleep          | WoWLAN sleep power                           | KM4 power off<br>KMO clock off<br>All RAM retained<br>Wi-Fi retained       | 30~50   | 30~50     | uA   |
| LPS            | Wi-Fi connected (idle)                       | KMO, KM4 in active mode<br>Wi-Fi set LPS mode                              | 20      | 30        | mA   |
| Active         | Wi-Fi Rx Idle                                | HT20 MCS0~7 normal mode<br>KM4 in active mode<br>Rx idle                   | 52      | 81        | mA   |
| WoWLAN         | WoWLAN Rx Beacon                             | Rx beacon mode @ normal mode<br>KM4 in sleep mode                          | 28      | 45        | mA   |
|                | WoWLANDTIM=1 (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   |

Table 15-11 WoWLAN power with different DTIM

| Condition                                                | DTIM | Current |      | Unit |
|----------------------------------------------------------|------|---------|------|------|
|                                                          |      | 3.3V    | 1.8V |      |
| KM4 in sleep mode<br>All SRAM retained<br>Wi-Fi retained | 1    | 942     | 1360 | uA   |
|                                                          | 2    | 473     | 671  |      |
|                                                          | 3    | 316     | 486  |      |

|                |    |     |     |  |
|----------------|----|-----|-----|--|
| Shielding room | 5  | 184 | 299 |  |
|                | 10 | 92  | 152 |  |

Test condition:  
AP: WS 5100 802.11g mode

Table15-12 Wi-Fi Tx powerconsumption of 2G/5G

| Channel                                                | PowerSupply | Operation Mode                         | Current |     | Unit |
|--------------------------------------------------------|-------------|----------------------------------------|---------|-----|------|
|                                                        |             |                                        | 2.4G    | 5G  |      |
| 2442MHz@2.4G<br>5500MHz@5G<br>20M<br>5510MHz@5G<br>40M | 1.8V        | 1T-MCS7/BW40M@6dBm@2.4G, 8dBm@5G       | 181     | 216 | mA   |
|                                                        |             | 1T-MCS7/BW40M@12dBm@2.4G, 11dBm@5G     | 195     | 237 |      |
|                                                        |             | 1T-MCS7/BW20M@6dBm@2.4G, 8dBm@5G       | 180     | 214 |      |
|                                                        |             | 1T-MCS7/BW20M@12dBm@2.4G, 11dBm@5G     | 193     | 234 |      |
|                                                        |             | 1T-Legacy_OFDM54M@6dBm@2.4G, 9dBm@5G   | 184     | 219 |      |
|                                                        |             | 1T-Legacy_OFDM54M@12dBm@2.4G, 12dBm@5G | 214     | 245 |      |
|                                                        |             | 1T_CCK11M@6dBm)                        | 203     | -   |      |
|                                                        |             | 1T_CCK11M@16dBm)                       | 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)                  | 81      | -   |      |
|                                                        |             | RF Standby                             | 58      | 55  |      |
|                                                        |             | RF Disable                             | 43      | 42  |      |
|                                                        | 3.3V        | 1T-MCS7/BW40M@6dBm)                    | 206     | 286 |      |
|                                                        |             | 1T-MCS7/BW40M@6dBm@2.4G, 17dBm@5G      | 247     | 310 |      |
|                                                        |             | 1T-MCS7/BW20M@6dBm)                    | 204     | 286 |      |
|                                                        |             | 1T-MCS7/BW20M@16dBm)                   | 248     | 308 |      |
|                                                        |             | 1T-Legacy_OFDM54M@6dBm)                | 214     | 296 |      |
|                                                        |             | 1T-Legacy_OFDM54M@12dBm@2.4G, 18dBm@5G | 262     | 323 |      |
|                                                        |             | 1T_CCK11M@6dBm)                        | 257     | -   |      |
|                                                        |             | 1T_CCK11M@16dBm)                       | 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 W11N\_11M0 board.

Tx: Continue TPK on

Rx: Set Rackets idle interval as short as possible

Load W11N\_11M0 Idle Waveform (8us idle interval) for CCK11M test.

Table15-13 BT powerconsumption of different BT mode

| Item   | Condition | Power Supply | BT Mode          | Current       | Unit |
|--------|-----------|--------------|------------------|---------------|------|
| BT Tx  | KMO ON    | 3.3V         | BT MP            | 100 (4.45dBm) | mA   |
|        | KM4 ON    |              |                  | 111 (8.15dBm) |      |
|        |           |              |                  | 129 (12dBm)   |      |
| BT Rx  |           |              | BT Central Mode  | 56.1          |      |
| BT ADV |           |              | BT PeripheraMode | 56.2          |      |

|               |  |                 |      |  |
|---------------|--|-----------------|------|--|
| BT Connection |  | BT Central Mode | 56.3 |  |
|---------------|--|-----------------|------|--|

## 15.3.2 Test Command

We provide command KM4 for tickless testing. Below is the description.

| Items          | Comment                                                                                                                                                                       |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tickps r debug | ReleaseOSwakelocktoopen tickles function, KM4 will enter sleep mode when idle.<br>In program you can <a href="#">useu_release_wakelock(PMU_OS)</a> to open tickless function. |
| tickpsa        | GetOSwakelocktoclose tickless function                                                                                                                                        |
| tickpsget      | GetCurrentWakelock @<br>enter sleep                                                                                                                                           |

## 15.3.3 Hardware Preparation

In AmebaD reference board, there are other components that consume power. For example, DAP, LEDs, FT232, and capacitances. To measure power consumptions only for AmebaD, you need to remove resistance at R13, R525

You can use microUSB to supply power for the board, and link current meter [Fig 15-28](#) as



Fig 15-25 Power consumption measurement



Fig15-26Measuring power consumption from microUSB

# 16 Hardware Crypto Engine

## 16.1 Introduction

Hardware Crypto Engine is used to authenticate, encrypt and decrypt packages. It supports the following Hash and Ciphers:

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\_poly1305

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

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

## 16.2 Hardware Crypto Engines API

### 16.2.1 Crypto Engine Initialization API

#### 16.2.1.1 rtl\_cryptoEngine\_init

| Items        | Description                              |
|--------------|------------------------------------------|
| Introduction | Hardware crypto engine initialization    |
| Parameters   | N/A                                      |
| Return       | Status value:<br>SUCCESSInitializationok |

### 16.2.2 Hash APIs

#### 16.2.2.1 rtl\_crypto\_md5

| Items        | Description                                                                 |
|--------------|-----------------------------------------------------------------------------|
| Introduction | MD5 calculate digest                                                        |
| Parameters   | messagePlaintext<br>msglen:Plaintextlength<br>pDigestResult of MD5 function |
| Return       | Status value:<br>SUCCESSMD5isok<br>Others: fail, refer to ERRNO             |

#### 16.2.2.2 rtl\_crypto\_md5\_init

| Items        | Description                                                                  |
|--------------|------------------------------------------------------------------------------|
| Introduction | MD5 initialization (used for sequential hash)                                |
| Parameters   | N/A                                                                          |
| Return       | Status value:<br>SUCCESSMD5 initializationok<br>Others: fail, refer to ERRNO |

### 16.2.2.3 rtl\_crypto\_md5\_update

| Items        | Description                                                          |
|--------------|----------------------------------------------------------------------|
| Introduction | MD5 block calculate (used for sequential hash)                       |
| Parameters   | messagePlaintext<br>msglen:Plaintextlength                           |
| Return       | Status value:<br>SUCCESSMD5 updateok<br>Others: fail, refer to ERRNO |

### 16.2.2.4 rtl\_crypto\_md5\_final

| Items        | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Introduction | MD5last block calculate (used for sequential hash)                  |
| Parameters   | pDigestResult of MD5 function                                       |
| Return       | Status value:<br>SUCCESSMD5 finalok<br>Others: fail, refer to ERRNO |

### 16.2.2.5 rtl\_crypto\_sha1

| Items        | Description                                                                 |
|--------------|-----------------------------------------------------------------------------|
| Introduction | SHA1 calculate digest                                                       |
| Parameters   | messagePlaintext<br>msglen:Plaintextlength<br>pDigestResult of SHA1function |
| Return       | Status value:<br>SUCCESSSHA1isok<br>Others: fail, refer to ERRNO            |

### 16.2.2.6 rtl\_crypto\_sha1\_init

| Items        | Description                                                                   |
|--------------|-------------------------------------------------------------------------------|
| Introduction | SHA1 initialization(used for sequential hash)                                 |
| Parameters   | N/A                                                                           |
| Return       | Status value:<br>SUCCESSSHA1 initializationok<br>Others: fail, refer to ERRNO |

### 16.2.2.7 rtl\_crypto\_sha1\_update

| Items        | Description                                                           |
|--------------|-----------------------------------------------------------------------|
| Introduction | SHA1 block calculate (used for sequential hash)                       |
| Parameters   | messagePlaintext<br>msglen:Plaintextlength                            |
| Return       | Status value:<br>SUCCESSSHA1 updateok<br>Others: fail, refer to ERRNO |

### 16.2.2.8 rtl\_crypto\_sha1\_final

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

|              |                                                                         |
|--------------|-------------------------------------------------------------------------|
| Introduction | SHA1 last block calculate(used for sequential hash)                     |
| Parameters   | pDigestResult oSHA1function                                             |
| Return       | Status value:<br>SUCCESSSHA1final is ok<br>Others: fail, refer to ERRNO |

### 16.2.2.9 rtl\_cryptosha2

| Items        | Description                                                                                                      |
|--------------|------------------------------------------------------------------------------------------------------------------|
| Introduction | SHA2 calculate digest                                                                                            |
| Parameters   | sha2typeSHA2 typeSHA2_22 or SHA2_36<br>messagePlaintext<br>msglen:Plaintextlength<br>pDigestResult oSHA2function |
| Return       | Status value:<br>SUCCESSSHA2 is ok<br>Others: fail, refer to ERRNO                                               |

### 16.2.2.10 rtl\_cryptosha2\_init

| Items        | Description                                                                       |
|--------------|-----------------------------------------------------------------------------------|
| Introduction | SHA2 initialization(used for sequential hash)                                     |
| Parameters   | sha2typeSHA2 typeSHA2_22 or SHA2_36                                               |
| Return       | Status value:<br>SUCCESSSHA2 initialization is ok<br>Others: fail, refer to ERRNO |

### 16.2.2.11 rtl\_cryptosha2\_update

| Items        | Description                                                            |
|--------------|------------------------------------------------------------------------|
| Introduction | SHA2 block calculate(used for sequential hash)                         |
| Parameters   | messagePlaintext<br>msglen:Plaintextlength                             |
| Return       | Status value:<br>SUCCESSSHA2 update ok<br>Others: fail, refer to ERRNO |

### 16.2.2.12 rtl\_cryptosha2\_final

| Items        | Description                                                              |
|--------------|--------------------------------------------------------------------------|
| Introduction | SHA2 last block calculate(used for sequential hash)                      |
| Parameters   | pDigestResult oSHA2function                                              |
| Return       | Status value:<br>SUCCESSSHA2 final is ok<br>Others: fail, refer to ERRNO |

### 16.2.2.13 rtl\_crypto\_hmac\_md5

| Items        | Description                                                                        |
|--------------|------------------------------------------------------------------------------------|
| Introduction | HMACMD5 calculate digest                                                           |
| Parameters   | key: HMACMD5 key need to be byte aligned<br>keylen: Key length<br>messagePlaintext |

|        |                                                                     |
|--------|---------------------------------------------------------------------|
|        | msglen:Plaintextlength<br>pDigestResult of HMACMD5function          |
| Return | Status value:<br>SUCCESSHMACMD5isok<br>Others: fail, refer to ERRNO |

#### 16.2.2.14 tl\_cryptohmac\_md5\_init

| Items        | Description                                                                      |
|--------------|----------------------------------------------------------------------------------|
| Introduction | HMACMD5 initialization(used for sequential hash)                                 |
| Parameters   | key:HMACMD5 keyneed to be byte aligned<br>keylen: Key length                     |
| Return       | Status value:<br>SUCCESSHMACMD5 initializationok<br>Others: fail, refer to ERRNO |

#### 16.2.2.15 tl\_cryptohmac\_md5\_update

| Items        | Description                                                                     |
|--------------|---------------------------------------------------------------------------------|
| Introduction | HMACMD5 block calculate(used for sequential hash)                               |
| Parameters   | messagePlaintext<br>msglen:Plaintextlength                                      |
| Return       | retval status value:<br>SUCCESSHMACMD5 updateok<br>Others: fail, refer to ERRNO |

#### 16.2.2.16 tl\_cryptohmac\_md5\_final

| Items        | Description                                                               |
|--------------|---------------------------------------------------------------------------|
| Introduction | HMACMD5 last block calculate(used for sequential hash)                    |
| Parameters   | pDigestResult of HMACMD5function                                          |
| Return       | Status value:<br>SUCCESSHMACMD5final isok<br>Others: fail, refer to ERRNO |

#### 16.2.2.17 tl\_cryptohmac\_sha1

| Items        | Description                                                                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMACSHA1 calculate digest                                                                                                                        |
| Parameters   | key:HMACSHA1 keyneed to be byte aligned<br>keylen: key length<br>messagePlaintext<br>msglen:Plaintextlength<br>pDigestResult of HMACSHA1function |
| Return       | Status value:<br>SUCCESSHMACSHA1isok<br>Others: fail, refer to ERRNO                                                                             |

#### 16.2.2.18 tl\_cryptohmac\_sha1\_init

| Items        | Description                                       |
|--------------|---------------------------------------------------|
| Introduction | HMACSHA1 initialization(used for sequential hash) |
| Parameters   | key:HMACSHA1 keyneed to be byte aligned           |

|        |                                                                                        |
|--------|----------------------------------------------------------------------------------------|
|        | keylen: key length                                                                     |
| Return | Status value:<br>SUCCESS HMACSHA1 initialization is ok<br>Others: fail, refer to ERRNO |

### 16.2.2.19 tl\_cryptohmacsha1\_update

| Items        | Description                                                                    |
|--------------|--------------------------------------------------------------------------------|
| Introduction | HMACSHA1 block calculation (used for sequential hash)                          |
| Parameters   | messagePlaintext<br>msglen: Plaintext length                                   |
| Return       | Status value:<br>SUCCESS HMACSHA1 update is ok<br>Others: fail, refer to ERRNO |

### 16.2.2.20 tl\_cryptohmacsha1\_final

| Items        | Description                                                                   |
|--------------|-------------------------------------------------------------------------------|
| Introduction | HMACSHA1 last block calculation (used for sequential hash)                    |
| Parameters   | pDigestResult of HMACSHA1 function                                            |
| Return       | Status value:<br>SUCCESS HMACSHA1 final is ok<br>Others: fail, refer to ERRNO |

### 16.2.2.21 tl\_cryptohmacsha2

| Items        | Description                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | HMACSHA2 calculation digest                                                                                                                                                                          |
| Parameters   | sha2type: SHA2 type SHA2_224 or SHA2_256<br>key: HMACSHA2 key need to be 16 byte aligned<br>keylen: Key length<br>messagePlaintext<br>msglen: Plaintext length<br>pDigestResult of HMACSHA2 function |
| Return       | Status value:<br>SUCCESS HMACSHA2 is ok<br>Others: fail, refer to ERRNO                                                                                                                              |

### 16.2.2.22 tl\_cryptohmacsha2\_init

| Items        | Description                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------|
| Introduction | HMACSHA2 initialization (used for sequential hash)                                                             |
| Parameters   | sha2type: SHA2 type SHA2_224 or SHA2_256<br>key: HMACSHA2 key need to be 16 byte aligned<br>keylen: Key length |
| Return       | Status value:<br>SUCCESS HMACSHA2 initialization is ok<br>Others: fail, refer to ERRNO                         |

### 16.2.2.23 tl\_cryptohmacsha2\_update

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

|            |                                                                             |
|------------|-----------------------------------------------------------------------------|
| Parameters | messagePlaintext<br>msglen:Plaintextlength                                  |
| Return     | Status value:<br>SUCCESS HMACSHA2 update ok<br>Others: fail, refer to ERRNO |

#### 16.2.2.24 tl\_crypto\_hmac\_sha2\_final

| Items        | Description                                                                |
|--------------|----------------------------------------------------------------------------|
| Introduction | HMACSHA2 last block calculate (used for sequential hash)                   |
| Parameters   | pDigestResult of HMACSHA2 function                                         |
| Return       | Status value:<br>SUCCESS HMACSHA2 final ok<br>Others: fail, refer to ERRNO |

#### 16.2.2.25 tl\_crypto\_poly1305

| Items        | Description                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Poly1305 calculate digest                                                                                                                           |
| Parameters   | key: poly1305 key need to be byte aligned<br>keylen: Key length<br>messagePlaintext<br>msglen:Plaintextlength<br>pDigestResult of poly1305 function |
| Return       | Status value:<br>SUCCESS Poly1305 ok<br>Others: fail, refer to ERRNO                                                                                |

### 16.2.3 Cipher APIs

#### 16.2.3.1 rtl\_cryptoxxx\_xxx\_init

| Items        | Description                                                                                                                                                              |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | xxx initialization<br>xxx can be aes_cbc/aes_ecb/aes_ctf/aes_cfb/aes_ofb/aes_gcm/3des_cbc/3des_ecb/3des_ctr/3des_fb/3des_ofb/<br>des_cbc/des_ecb/des_ctf/des_cfb/des_ofb |
| Parameters   | key: Cipher key<br>keylen: Key length                                                                                                                                    |
| Return       | status value:<br>SUCCESS Initialization ok.<br>Others: fail, refer to ERRNO                                                                                              |

#### 16.2.3.2 rtl\_cryptoxxx\_xxx\_encrypt

| Items        | Description                                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | xxx encryption<br>xxx can be aes_cbc/aes_ecb/aes_ctf/aes_cfb/aes_ofb/aes_gcm/3des_cbc/3des_ecb/3des_ctr/3des_fb/3des_ofb/<br>des_cbc/des_ecb/des_ctf/des_cfb/des_ofb |
| Parameters   | message: Point to message<br>msglen: Message length<br>iv: Initial vector<br>ivlen: iv length<br>pResult: Point to cipher result                                     |

|        |                                                                           |
|--------|---------------------------------------------------------------------------|
| Return | Status value:<br>SUCCESS encryption is ok.<br>Others: fail refer to ERRNO |
|--------|---------------------------------------------------------------------------|

#### 16.2.3.3 rtl\_cryptoxxx\_xxx\_decrypt

| Items        | Description                                                                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | xxxdecryption<br>xxx can be aes_cbc/aes_ecb/aes_ctf/aes_cfb/aes_ofb/aes_gcm/aes_des_cbc/aes_des_ecb/aes_des_ctr/aes_des_fbf/aes_des_ofb/aes_des_cfb/aes_des_ofb |
| Parameters   | message: Point to source message<br>msglen: Message length<br>iv: Initial vector<br>ivlen: IV (initialization vector) length<br>pResult: Point to cipher result |
| Return       | Status value:<br>SUCCESS decryption is ok.<br>Others: fail, refer to ERRNO                                                                                      |

#### 16.2.3.4 rtl\_cryptoaes\_gcm\_init

| Items        | Description                                                                    |
|--------------|--------------------------------------------------------------------------------|
| Introduction | AES-GCM initialization                                                         |
| Parameters   | key: Cipher key<br>keylen: Key length                                          |
| Return       | Status value:<br>SUCCESS initialization is ok.<br>Others: fail, refer to ERRNO |

#### 16.2.3.5 rtl\_crypto\_aes\_gcm\_encrypt

| Items        | Description                                                                                                                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | AES-GCM encryption                                                                                                                                                                                                                                  |
| Parameters   | message: Point to source message<br>msglen: Message length<br>iv: Initial vector<br>aad: Point to AAD (Additional authentication data)<br>aadlen: AAD length<br>pResult: Point to cipher result<br>pTag: Point to MAC (Message Authentication Code) |
| Return       | Status value:<br>SUCCESS encryption is ok.<br>Others: fail, refer to ERRNO                                                                                                                                                                          |

#### 16.2.3.6 rtl\_crypto\_aes\_gcm\_decrypt

| Items        | Description                                                                                                                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | AES-GCM decryption                                                                                                                                                                              |
| Parameters   | message: Point to source message<br>msglen: Message length<br>iv: Initial vector<br>aad: Point to AAD (additional authentication data)<br>aadlen: AAD length<br>pResult: Point to cipher result |

|        |                                                                            |
|--------|----------------------------------------------------------------------------|
|        | pTag: Point to MAC message Authentication Code)                            |
| Return | Status value:<br>SUCCESS decryption is ok.<br>Others: fail, refer to ERRNO |

### 16.2.3.7 rtl\_crypto\_chacha\_init

| Items        | Description                                                              |
|--------------|--------------------------------------------------------------------------|
| Introduction | ChaCha20Initialization                                                   |
| Parameters   | key: Cipher key                                                          |
| Return       | Status value:<br>SUCCESSInitializationOK<br>Others: fail, refer to ERRNO |

### 16.2.3.8 rtl\_crypto\_chacha\_encrypt

| Items        | Description                                                                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha20Encryption                                                                                                                                          |
| Parameters   | message: Point to source message<br>msglen: Message length<br>iv: Point to Initialization vector<br>count: Counter value<br>pResult: Point to cipher result |
| Return       | Status value:<br>SUCCESS encryption is ok.<br>Others: fail, refer to ERRNO                                                                                  |

### 16.2.3.9 rtl\_crypto\_chacha\_decrypt

| Items        | Description                                                                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha20Decryption                                                                                                                                          |
| Parameters   | message: Point to source message<br>msglen: Message length<br>iv: Point to Initialization vector<br>count: Counter value<br>pResult: Point to cipher result |
| Return       | Status value:<br>SUCCESS decryption is ok.<br>Others: fail, refer to ERRNO                                                                                  |

### 16.2.3.10 rtl\_crypto\_chacha\_poly1305\_

| Items        | Description                                                                    |
|--------------|--------------------------------------------------------------------------------|
| Introduction | ChaCha Poly1305Initialization                                                  |
| Parameters   | key: Cipher key                                                                |
| Return       | Status value:<br>SUCCESS initialization is ok.<br>Others: fail, refer to ERRNO |

### 16.2.3.11 rtl\_crypto\_chacha\_poly1305\_encrypt

| Items        | Description               |
|--------------|---------------------------|
| Introduction | ChaCha Poly1305Encryption |

|            |                                                                                                                                                                                                                                                      |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters | message: Point to source message<br>msglen: Message length<br>nonce: Random value<br>aad: Point to AAD (Additional authentication data)<br>aadlen: AAD length<br>pResult: Point to cipher result<br>pTag: Point to MAC (Message Authentication Code) |
| Return     | Status value:<br>SUCCESS: encryption is ok.<br>Others: fail, refer to ERRNO                                                                                                                                                                          |

### 16.2.3.12 tl\_crypto\_chacha\_poly1305\_encrypt

| Items        | Description                                                                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | ChaCha Poly1305 decryption                                                                                                                                                                                                                           |
| Parameters   | message: Point to source message<br>msglen: Message length<br>nonce: Random value<br>aad: Point to AAD (Additional authentication data)<br>aadlen: AAD length<br>pResult: Point to cipher result<br>pTag: Point to MAC (Message Authentication Code) |
| Return       | Status value:<br>SUCCESS: decryption is ok.<br>Others: fail, refer to ERRNO                                                                                                                                                                          |

## 16.3 Hardware Crypto Engines API Usage

### 16.3.1 Starting Hardware Crypto Engine

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

### 16.3.2 Starting Crypto Engine Calculation

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

#### 16.3.2.1 HashAlgorithm

If a hash algorithm is selected, the hash API (tl\_cryptoxxx) can be used to calculate digest.

Sequential hash is needed when source message length is longer than hardware support. Sequential hash breaks a whole long message into several pieces of message payload, then calculates the payload in sequence, until the last message payload.

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

- (1) Initialize sequential hash API (tl\_cryptoxxx\_init) to initialize.
- (2) Handle each piece of message payload. Hash API (tl\_cryptoxxx\_update) once when one piece message payload.
- (3) Handle the last piece of message payload. Hash API (tl\_cryptoxxx\_final) once when one piece message payload.

Note: Considering that the Crypto Engine moves data through DMA and bypasses the destination array is placed in stack and the start address is not 32 aligned, the cache line would be dirty function call in some cases. To avoid reading wrong digest back, users should choose one of the following methods:

The digest array is a global variable.

Or the start address of digest array should be 32 aligned.

Or call

```
DCache_Invalidate(((u32)digest & CACHE_LINE_ADDR_MSK), (sizeof(digest) + CACHE_LINE_SIZE));
```

### 16.3.2.2 Cipher Algorithm

Steps to encrypt message as following:

- (1) Initialize  
    UseCipher API `rtl_cryptoxxx_xxx_init()` to initialize.
- (2) Encrypt or decrypt message  
    Call Cipher API `rtl_cryptoxxx_xxx_encrypt()`to encrypt source message.  
    Call Cipher API `rtl_cryptoxxx_xxx_decrypt()`to decrypt source message.

## 16.4 DemoCode Path

Hardware Crypto Engine demo code `ksnafolderproject/realtek_amebaD0_example/example_sources/CRYPTO`

# 17 User Configuration

Some functions have complex parameters hard to give standards API SDK. For example, different users have different parameters for BOOT. So we provide some user configuration files which will be called by SDK will execute different activities based on different user configurations.

These configuration files should be maintained by users.

## 17.1 Configuration File List

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

Table 17-1 User configuration file

| Configuration file          | Configuration item                                                                                                                                                                                                                                                                                                                                          | Image              |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| rtl8721dhp_boot_trustzone.c | Used to configure KM4 TrustZone non-secure areas.                                                                                                                                                                                                                                                                                                           | KM4bootloader      |
| rtl8721dlp_flashcfg.c       | Used to configure Flash settings:<br>Flash_Speed<br>Flash_ReadMode<br>Flash_AVL<br>You can also configure your Flash flash_init_userdef if your Flash is not Flash_AVL                                                                                                                                                                                      | KM0image2          |
| rtl8721dlp_pinmapcfg.c      | Used to reduce power leakage<br>Per pin function configuration<br>Per pin function pull up & pull down<br>Per pin sleep pull up & pull down                                                                                                                                                                                                                 | KM0image2          |
| rtl8721dlp_sleepcfg.c       | Sleep/deepsleep power management<br>Sleep/deepsleep wakeup event<br>Sleep/deepsleep wake pin                                                                                                                                                                                                                                                                | KM0image2          |
| rtl8721d_bootcfg.c          | Used to configure bootloader:<br>Flash_MMU_Config<br>RSIP_Mask_Config<br>Force_OTA1_GPIO<br>Boot_Log_En                                                                                                                                                                                                                                                     | KM0& KM4bootloader |
| rtl8721d_ipccfg.c           | Used to define your IPC channels                                                                                                                                                                                                                                                                                                                            | KM0& KM4image2     |
| rtl8721dlp_intfcfg          | Enable/disable low power Rx                                                                                                                                                                                                                                                                                                                                 | KM0image2          |
| rtl8721dhp_intfcfg.c        | PSRAM configuration:<br>EnablePSRAM<br>EnablePSRAM calibration function<br>EnablePSRAM retention<br>SDIO host configuration<br>SDIO Host bus speed<br>SDIO Host bus width<br>Card Detect pin<br>Write Protection pin<br>FTL parameter configuration:<br>The number of physical map pages<br>The offset of flash sectors which allocated to FTL physical map | KM4image2          |

## 17.2 Boot TrustZone Configuration

The whole address space will be secure when boot up. SAU is used to configure areas for some special address space. SAU should be configured in secure bootloader, and it cannot be changed again after setting, it is protected by hardware.

There are 8SAU entries in AmebaD, entry0 to entry4 has been used by system, and entry5 to entry7 are left for user. You can config 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,     0x10140000-1,   0}, /* entry1: IROM & DRAM NS */
    {0x00080000,     _ram_image3_start_-1, 0}, /* entry2: KMO 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 */
    {0xFFFFFFF,       0xFFFFFFF,      0}, /* entry5: TODO */
    {0xFFFFFFF,       0xFFFFFFF,      0}, /* entry6: TODO */
    {0xFFFFFFF,       0xFFFFFFF,      0}, /* entry7: TODO */
    {0xFFFFFFF,       0xFFFFFFF,      0},
};
```

## 17.3 Flash Configuration

The Flash configuration items for users are listed in Table 17-2.

Table 17-2 User Flash configuration

| Item               | Comment                                                                                                                                                                                                                                                                                                                                                                                                           | Default |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| Flash_Speed        | Indicates the Flash baudrate. It can be one of the following value:<br>0xFFFF: 80MHz<br>0xFFFF: 100MHz<br>0x3FFF: 67MHz<br>0x1FFF: 57MHz<br>0x0FFF: 50MHz                                                                                                                                                                                                                                                         | 0xFFFF  |
| Flash_ReadMode     | Indicates the Flash read I/O mode. It can be one of the following value:<br>0xFFFF: Read quad I/O, Address & Data 4 bits mode<br>0x7FFF: Read quad I/O, just data 4 bits mode<br>0x3FFF: Read dual I/O, Address & Data 2 bits mode<br>0x1FFF: Read dual I/O, just data 2 bits mode<br>0x0FFF: 1 bit mode<br>If the configured read mode is not supported, modes would be searched until find the appropriate mode | 0xFFFF  |
| Flash_AVL          | Maintains the Flash IC supported by AmebaD. Refer to Table 17-1 for detailed information.                                                                                                                                                                                                                                                                                                                         |         |
| flash_init_userdef | Initializes the parameters in this function in order to adopt user-defined flash on AmebaD.                                                                                                                                                                                                                                                                                                                       |         |

### 17.3.1 Flash Classification

Ameba-D supports Flash chips of multiple manufacturers, such as Winbond, MXIC, Gigadevice, ESMT etc. The Flash chips which have been tested on Ameba platform can be found in Table 17-3. We divide the supported Flash into 6 species. Table 17-3 shows the supported Flash species according to their characteristics and they can be used on Ameba-D directly.

Table 17-3 Flash species

| Flash classification | Manufacture               | Flash ID |
|----------------------|---------------------------|----------|
| FlashClass1          | Winbond                   | 0xEF     |
|                      | FM                        | 0xA1     |
|                      | XTX                       | 0xOB     |
|                      | XTX(FT)                   | 0xOE     |
| 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 users should follow these steps to check if it can be supported by Ameba

(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 register, Read, Read Dual/Quad Output/I/O, Page Program, Sector/Block/Chip Erase, Enter/Release from Powerdown etc)

Dummy cycle number of Read Dual/Quad Output/I/O mode

(2) Check if these parameters match with those of the existing species

- If the Flash belongs to one of the Realtek defined class it is already supported by SDK you can use it directly
- If all the parameters except Flash ID match with those of one species, add the Flash ID into Flash\_AVL table in SDK before using it, as Fig17-1 shows.
- If both the Flash parameters and Flash ID mismatch with the existing species 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 */
    {0xFF,          0x000000FF,     FlashClass1,       0x000004FC,     NULL}, /* Winbond: MANUFACTURER_ID_WINBOND */
    {0xA1,          0x000000FF,     FlashClass1,       0x0000FFFC,     NULL}, /* Fudan Micro: MANUFACTURER_ID_FM */
    {0x0B,          0x000000FF,     FlashClass1,       0x000004FC,     NULL}, /* XTX */
    {0x0E,          0x000000FF,     FlashClass1,       0x000004FC,     NULL}, /* XTX(FT) */
    {0xC8,          0x000000FF,     FlashClass2,       0x000004FC,     NULL}, /* GD normal: MANUFACTURER_ID_GD */
    {0x28C2,        0x0000FFFF,     FlashClass6,       0x000200FC,     NULL}, /* MXIC wide-range VCC: MANUFACTURER_ID_MXIC */
    {0xC2,          0x000000FF,     FlashClass3,       0x000000FC,     NULL}, /* MXIC normal: MANUFACTURER_ID_BOHONG */
    {0x68,          0x000000FF,     FlashClass3,       0x000000FC,     NULL}, /* Hua Hong */
    {0x51,          0x000000FF,     FlashClass3,       0x000000FC,     NULL}, /* GD MD serial */
    {0x1C,          0x000000FF,     FlashClass4,       0x000000FC,     NULL}, /* ESMT: MANUFACTURER_ID_EON */
    {0x20,          0x000000FF,     FlashClass5,       0x000000FC,     NULL}, /* Microm: MANUFACTURER_ID_MICRON */

    /* case2: new flash, ID is not included in case1 list, but specification is compatible with FlashClass1~FlashClass6 */
    //{{0XXX,          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},
};
```

Fig17-1 Flash\_AVL

### 17.3.1.1 Dummy Cycles

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

The following section shows you how to find dummy cycles from Flash datasheet.

Taking Winbond W25Q16 as an example

There are 6 dummy cycles in Read Quad I/O mode, Fig17-2 shows

There are 4 dummy cycles in Read Dual I/O mode, Fig17-3 shows.



Fig17-2 Fast read quad I/O instruction sequence



Fig17-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.

### 17.3.1.2 Other Parameters

The parameters comparison of these specified in Table 17-4.

Table 17-4 Parameters comparison of different Flash species

| Item            | Parameter                    | Flash Class 1 | Flash Class 2 | Flash Class 3 | Flash Class 4 | Flash Class 5 | Flash Class 6 |
|-----------------|------------------------------|---------------|---------------|---------------|---------------|---------------|---------------|
| Status Register | Status Register Number       | 2             | 2 or 3        | 1             | 1             | 1             | 1             |
|                 | OE 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             |
|                 | OREAD(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         | 0x05          | 0x05          | 0x05          | 0x05          | 0x05          | 0x05          |
|                 | Read Status Register         | 0x35          | 0x35          | -             | -             | -             | -             |
|                 | Write Status Register        | 0x01          | 0x01          | 0x01          | 0x01          | 0x01          | 0x01          |
|                 | Write Status Register        | -             | /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          |
|                 | Powerdown                    | 0xB9          | 0xB9          | 0xB9          | 0xB9          | 0xB9          | 0xB9          |
|                 | Release from Powerdown       | 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          |
|                 | OREAD(1I/4O Read)            | 0x6B          | 0x6B          | 0x6B          | 0x6B          | 0x6B          | 0x6B          |
|                 | 4READ(4*I/O Read)            | 0xEB          | 0xEB          | 0xEB          | 0xEB          | 0xEB          | 0xEB          |
|                 | Read Configuration Register  | -             | -             | -             | -             | -             | 0x15          |
|                 | Write Configuration Register | -             | -             | -             | -             | -             | -             |

Note1:

For FlashClass1 the Write Status Register is written together with Write Status Registers using 0x01 as Fig17-4 shows

For FlashClass2 when GD density is less than 2MB Write Status Register is written together with Write Status Register 0x01 as Fig17-4 shows. When GD density is larger than 2MB Write Status Register is written individually using 0x81Fig17-5 shows.

Note2: For MXIC wide range VCC, the ReadConfiguration Register would be checked whether the chip is in high performance mode by default once power on, as Fig17-6 shows. If not, we would switch it to high performance mode.

Note3: For MXIC wide range VCC, the WriteConfiguration Register is written together with Write Status Register using 0x81Fig17-7 shows.



Fig17-4 Write Status Registers sequence (FlashClass1/FlashClass2 when density < 2M)



Fig17-5 Write Status Registers sequence (FlashClass2 when density > 2M)



Fig17-6 Read Configuration Registers sequence (FlashClass6)



Fig17-7 Write Status Register and Write Configuration Register (FlashClass6)

### 17.3.2 FlashClass1~FlashClass6

Table17-5 lists the parameters for FlashClass1~FlashClass6 which can be modified by users.

Table17-5 Parameters of different Flashclassifications (FlashClass1~FlashClass6)

| Flashclassification | Command list                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Note                                                                    |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| FlashClass1         | <pre> FLASH_InitStrucFLASH_Id = FLASH_ID_WINBOND;  /*1.1 status bit define */ FLASH_InitStrucFLASH_QuadEn_bit = BIT(9); FLASH_InitStrucFLASH_Busy_bit = BIT(0); FLASH_InitStrucFLASH_WLE_bit = BIT(1); FLASH_InitStrucFLASH_Status2_exist = 1;  /*1.2 dummy cycle */ FLASH_InitStrucFLASH_rd_dummy_cyle[0] = 0; FLASH_InitStrucFLASH_rd_dummy_cyle[1] = 0x04; FLASH_InitStrucFLASH_rd_dummy_cyle[2] = 0x06;  /*1.3 set 2 bits mode command */ FLASH_InitStrucFLASH_rd_dual_io = 0xBB; FLASH_InitStrucFLASH_rd_dual_o = 0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStrucFLASH_rd_quad_io = 0xEB; FLASH_InitStrucFLASH_rd_quad_o = 0x6B;  /*1.5 other Flash command set */ FLASH_InitStrucFLASH_cmd_wr_en = 0x06; FLASH_InitStrucFLASH_cmd_rd_id = 0x9F; FLASH_InitStrucFLASH_cmd_rd_status = 0x05; FLASH_InitStrucFLASH_cmd_rd_status2 = 0x35; //FLASH_CMD_RDSR2 FLASH_InitStrucFLASH_cmd_wr_status = 0x01; FLASH_InitStrucFLASH_cmd_wras2 = 0; FLASH_InitStrucFLASH_cmd_chip_e = 0x60; FLASH_InitStrucFLASH_cmd_block_e = 0xD8; FLASH_InitStrucFLASH_cmd_sector_e = 0x20; FLASH_InitStrucFLASH_cmd_pwdn_release = 0xAB; FLASH_InitStrucFLASH_cmd_pwdn = 0xB9; </pre> |                                                                         |
| FlashClass2         | <pre> FLASH_InitStrucFLASH_Id = FLASH_ID_GD;  /*1.1 status bit define */ </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | FLASH_cmd_wr_status2 would be set when density is larger than 2MB in SD |

|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|            | <pre> FLASH_InitStrucFLASH_QuadEn_bit = BIT(9); FLASH_InitStrucFLASH_Busy_bit = BIT(0); //WIP FLASH_InitStrucFLASH_WLE_bit = BIT(1); //WLE FLASH_InitStrucFLASH_Status2_exist = 1;  /*1.2 dummy cycle */ FLASH_InitStrucFLASH_rd_dummy_cyle[0] = 0; FLASH_InitStrucFLASH_rd_dummy_cyle[1] = 0x04; //(M74)2 + 2 dummy FLASH_InitStrucFLASH_rd_dummy_cyle[2] = 0x06; //(M70)2 + 4 dummy  /*1.3 set 2 bits mode command */ FLASH_InitStrucFLASH_rd_dual_io = 0xBB; FLASH_InitStrucFLASH_rd_dual_o = 0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStrucFLASH_rd_quad_io = 0xEB; FLASH_InitStrucFLASH_rd_quad_o = 0x6B;  /*1.5 other Flash command set */ FLASH_InitStrucFLASH_cmd_wr_en=0x06; FLASH_InitStrucFLASH_cmd_rd_id = 0x9F; FLASH_InitStrucFLASH_cmd_rd_status = 0x05; FLASH_InitStrucFLASH_cmd_rd_status2 = 0x35; FLASH_InitStrucFLASH_cmd_wr_status = 0x01; FLASH_InitStrucFLASH_cmd_wr_status2 = 0; FLASH_InitStrucFLASH_cmd_chip_e = 0x60; FLASH_InitStrucFLASH_cmd_block_e = 0xD8; FLASH_InitStrucFLASH_cmd_sector_e = 0x20; FLASH_InitStrucFLASH_cmd_pwdn_release = 0xAB; FLASH_InitStrucFLASH_cmd_pwdn = 0xB9; </pre> |  |
| FlashClass | <pre> FLASH_InitStrucFLASH_Id = FLASH_ID_MXIC;  /*1.1 status bit define */ FLASH_InitStrucFLASH_QuadEn_bit = BIT(6); FLASH_InitStrucFLASH_Busy_bit = BIT(0); //WIP FLASH_InitStrucFLASH_WLE_bit=BIT(1); //WLE FLASH_InitStrucFLASH_Status2_exist = 0;  /*1.2 dummy cycle */ FLASH_InitStrucFLASH_rd_dummy_cyle[0] = 0; FLASH_InitStrucFLASH_rd_dummy_cyle[1] = 0x04; FLASH_InitStrucFLASH_rd_dummy_cyle[2] = 0x06;  /*1.3 set 2 bits mode command */ FLASH_InitStrucFLASH_rd_dual_io = 0xBB; FLASH_InitStrucFLASH_rd_dual_o = 0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStrucFLASH_rd_quad_io = 0xEB; FLASH_InitStrucFLASH_rd_quad_o = 0x6B;  /*1.5 other Flash command set */ FLASH_InitStrucFLASH_cmd_wr_en = 0x06; FLASH_InitStrucFLASH_cmd_rd_id = 0x9F; FLASH_InitStrucFLASH_cmd_rd_status = 0x05; FLASH_InitStrucFLASH_cmd_rd_status2 = 0; FLASH_InitStrucFLASH_cmd_wr_status = 0x01; FLASH_InitStrucFLASH_cmd_wr_status2 = 0; </pre>                                                                                                                                                                                    |  |

|              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|              | FLASH_InitStructFLASH_cmd_chip_e = 0x60;<br>FLASH_InitStructFLASH_cmd_block_e = 0xD8;<br>FLASH_InitStructFLASH_cmd_sector_e = 0x20;<br>FLASH_InitStructFLASH_cmd_pwdn_release = 0xAB;<br>FLASH_InitStructFLASH_cmd_pwdn = 0xB9;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| FlashClass\$ | <pre> FLASH_InitStructFLASH_Id FLASH_ID_MXIC;  /*1.1 status bit define */ FLASH_InitStructFLASH_QuadEn_bit = 0; FLASH_InitStructFLASH_Busy_bit = BIT(0); //WIP FLASH_InitStructFLASH_WLE_bit = BIT(1); //WLE FLASH_InitStructFLASH_Status2_exist = 0;  /*1.2 dummy cycle */ FLASH_InitStructFLASH_rd_dummy_cycle[0] = 0; FLASH_InitStructFLASH_rd_dummy_cycle[1] = 0x04; FLASH_InitStructFLASH_rd_dummy_cycle[2] = 0x06;  /*1.3 set 2 bits mode command */ FLASH_InitStructFLASH_rd_dual_io = 0xBB; FLASH_InitStructFLASH_rd_dual_o=0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStructFLASH_rd_quad_io = 0xEB; FLASH_InitStructFLASH_rd_quad_o = 0x6B;  /*1.5 other Flash command set */ FLASH_InitStructFLASH_cmd_wr_en = 0x06; FLASH_InitStructFLASH_cmd_rd_id = 0x9F; FLASH_InitStructFLASH_cmd_rd_status = 0x05; FLASH_InitStructFLASH_cmd_rd_status2 = 0; FLASH_InitStructFLASH_cmd_wr_status = 0x01; FLASH_InitStructFLASH_cmd_wr_status2 = 0; FLASH_InitStructFLASH_cmd_chip_e = 0x60; FLASH_InitStructFLASH_cmd_block_e = 0xD8; FLASH_InitStructFLASH_cmd_sector_e = 0x20; FLASH_InitStructFLASH_cmd_pwdn_release = 0xAB; FLASH_InitStructFLASH_cmd_pwdn = 0xB9; </pre> |  |
| FlashClass\$ | <pre> FLASH_InitStructFLASH_Id = FLASH_ID_MICRON;  /*1.1 status bit define */ FLASH_InitStructFLASH_QuadEn_bit = 0; FLASH_InitStructFLASH_Busy_bit = BIT(0); FLASH_InitStructFLASH_WLE_bit = BIT(1); FLASH_InitStructFLASH_Status2_exist = 0;  /*1.2 dummy cycle */ FLASH_InitStructFLASH_rd_dummy_cycle[0] = 0; /* set Micron rd_dummy_cycle based on baud rate, default 100MHz */ FLASH_InitStructFLASH_rd_dummy_cycle[1] = 0x05; FLASH_InitStructFLASH_rd_dummy_cycle[2] = 0x09;  /*1.3 set 2 bits mode command */ FLASH_InitStructFLASH_rd_dual_io = 0xBB; FLASH_InitStructFLASH_rd_dual_o=0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStructFLASH_rd_quad_io = 0xEB; </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |

|            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|            | <pre> FLASH_InitStructFLASH_rd_quad_o = 0x6B;  /*1.5 other Flash command set */ FLASH_InitStructFLASH_cmd_wr_en = 0x06; FLASH_InitStructFLASH_cmd_rd_id = 0x9F; FLASH_InitStructFLASH_cmd_rd_status = 0x05; FLASH_InitStructFLASH_cmd_rd_status2 = 0; FLASH_InitStructFLASH_cmd_wr_status = 0x01; FLASH_InitStructFLASH_cmd_wr_status2 = 0; FLASH_InitStructFLASH_cmd_chip_e = 0xC7; FLASH_InitStructFLASH_cmd_block_e = 0xD8; FLASH_InitStructFLASH_cmd_sector_e = 0x20; FLASH_InitStructFLASH_cmd_pwdn_release = 0xAB; FLASH_InitStructFLASH_cmd_pwdn = 0xB9; </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| FlashClass | <pre> FLASH_InitStructFLASH_Id = FLASH_ID_MXIC;  /*1.1 status bit define */ FLASH_InitStructFLASH_QuadEn_bit = BIT(6); FLASH_InitStructFLASH_Busy_bit = BIT(0); //WIP FLASH_InitStructFLASH_WLE_bit = BIT(1); //WLE FLASH_InitStructFLASH_Status2_exist = 0;  /*1.2 dummy cycle */ FLASH_InitStructFLASH_rd_dummy_cycle[0] = 0; FLASH_InitStructFLASH_rd_dummy_cycle[1] = 0x04; FLASH_InitStructFLASH_rd_dummy_cycle[2] = 0x06;  /*1.3 set 2 bits mode command */ FLASH_InitStructFLASH_rd_dual_io = 0xBB; FLASH_InitStructFLASH_rd_dual_o = 0x3B;  /*1.4 set 4 bits mode command */ FLASH_InitStructFLASH_rd_quad_io = 0xEB; FLASH_InitStructFLASH_rd_quad_o = 0x6B;  /*1.5 other Flash command set */ FLASH_InitStructFLASH_cmd_wr_en = 0x06; FLASH_InitStructFLASH_cmd_rd_id = 0x9F; FLASH_InitStructFLASH_cmd_rd_status = 0x05; FLASH_InitStructFLASH_cmd_rd_status2 = 0; FLASH_InitStructFLASH_cmd_wr_status = 0x01; FLASH_InitStructFLASH_cmd_wr_status2 = 0; FLASH_InitStructFLASH_cmd_chip_e = 0x60; FLASH_InitStructFLASH_cmd_block_e = 0xD8; FLASH_InitStructFLASH_cmd_sector_e = 0x20; FLASH_InitStructFLASH_cmd_pwdn_release = 0xAB; FLASH_InitStructFLASH_cmd_pwdn = 0xB9; </pre> |  |

## 17.4 Pinmap Configuration

During the process of boot, sleep and deep, I/O pull control is needed, and the system will load the PAD status of each GPIO from the

The correct configuration of pinmap can achieve low power consumption. The unsuitable configuration may lead to leakage. For example, UART voltage level is high. If the UART pin is pulled down or not pulled up, power happens. So it is necessary to make sure that each pin has proper pull control.

In SDK you should set GPIO function pull control and sleep/deep pull control based on your PCB board, and SDK will set pull control based on your setting between suspend and resume.

In the

h U ° h u )

Pin Name: indicates the GPIO.

Func PU/PDs used to configure the PAss after poweron.

Slp PU/PDs used to configure the PAss in sleep mode.

Dslp PU/PDs used to configure the PAss in deepsleep mode.

LowPowerPin: indicates that whether this GPIO is low power pin. It is no need to be modified.

```
const PMAP_TypeDef pmap_func[]=
{
//Pin Name    Func PU/PD        Slp PU/PD        DSlp 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_mode_sel
{_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_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}, //SPI_DATA3
{_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},
    {_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 board error
    {_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},
    {_PNC, GPIO_PuPd_KEEP, GPIO_PuPd_KEEP, GPIO_PuPd_KEEP, FALSE},
};

}

```

There are five states of the PAD.

GPIO\_PuPd\_UP: indicates that the PAD is pulled up to VDDIO.

GPIO\_PuPd\_DOWN: indicates that the PAD is pulled down to GND.

GPIO\_PuPd\_NOPULL: indicates that the PAD is High

GPIO\_PuPd\_KEEP: is used for sleep and deep mode, and indicates that the PAD maintain the last status before the chip enters sleep mode or deep mode.

GPIO\_PuPd\_SHUTDOWN: indicates that the PAD is shut down.

The following section illustrates the recommendation of padstatus configurations according to the function of different pins.

#### 17.4.1 Normal GPIO

When the chip pin is used as a normal GPIO connecting with external circuit, the pad status depends on the external circuit.

Table17-6 Normal GPIO padstatus

| Pin Function     | Func PU/PD   | Slp PU/PD         | DSlp PU/PD        |
|------------------|--------------|-------------------|-------------------|
| Connected to VDD | UP/NO PULL   | UP/NO PULL/KEEP   | UP/NO PULL/KEEP   |
| Connected to GND | DOWN/NO PULL | DOWN/NO PULL/KEEP | DOWN/NO PULL/KEEP |
| Floating         | DOWN         | DOWN              | DOWN              |

#### 17.4.2 Key-Scan

When the pin is used as Key Scan function, the pad status depends on the Key Scan ROW or COL.

Table17-7 Key-Scan padstatus

| Pin Function | Func PU/PD | Slp PU/PD | DSlp PU/PD |
|--------------|------------|-----------|------------|
| ROW          | UP         | KEEP      | KEEP       |
| COL          | DOWN       | KEEP      | KEEP       |

#### 17.4.3 LOGUART

The pins PA\_7 and PA\_8 are fixed to LOGUART function. The pad status is listed in Table17-8.

Table17-8 LOGUART padstatus

| Pin Function | Pin Name | Func PU/PD | Slp PU/PD | DSlp PU/PD |
|--------------|----------|------------|-----------|------------|
| UART_LOG_RXD | PA_7     | UP         | KEEP      | KEEP       |
| UART_LOG_TXD | PA_8     | UP         | KEEP      | KEEP       |

## 17.4.4 SWD

When the pin is configured as SWD function, the pad status is listed in Table 17-9.

Table 17-9 SWD pad status

| Pin Function | Func PU/PD | S1p PU/PD | D1S1p PU/PD |
|--------------|------------|-----------|-------------|
| SWD_DATA     | UP         | KEEP      | KEEP        |
| SWD_CLK      | UP         | KEEP      | KEEP        |

## 17.4.5 Flash Pin

Generally, the flash data pin is pulled to DOWN if you still need to access flash (such as single bit access during sleep) this pin needs to be configured to UP before entering sleep mode. The pad status are listed in Table 17-9.

Table 17-10 Flash pin pad status

| Pin Function | Func PU/PD | S1p PU/PD | D1S1p PU/PD |
|--------------|------------|-----------|-------------|
| SPI_DATA_X   | DOWN       | KEEP      | KEEP        |
| SPI_CS       | UP         | KEEP      | KEEP        |

## 17.4.6 Cap-Touch

When the pin is configured as Cap-Touch function, it is not necessary to set the pad status, it should be NO PULL.

Table 17-11 Cap-Touch pad status

| Pin Function | Func PU/PD | S1p PU/PD | D1S1p PU/PD |
|--------------|------------|-----------|-------------|
| Cap-Touch    | NO PULL    | KEEP      | KEEP        |

## 17.4.7 ADC

When the pin is configured as ADC function, it is not necessary to set the pad status, it should be NO PULL.

Table 17-12 ADC pad status

| Pin Function | Func PU/PD | S1p PU/PD | D1S1p PU/PD |
|--------------|------------|-----------|-------------|
| ADC          | NO PULL    | KEEP      | KEEP        |

## 17.4.8 Power

The GPIO pin can also output 3.3V by being set to output high. However, the driving capacity is limited, **absolutely** 4mA. At this time, the pad status should be NO PULL.

Table 17-13 Power pad status

| Pin Function | Func PU/PD | S1p PU/PD | D1S1p PU/PD |
|--------------|------------|-----------|-------------|
| Power source | NO PULL    | KEEP      | KEEP        |

## 17.4.9 DMIC

When the pin is used as the DMIC function for audio, the pad status should be pulled down.

Table 17-14 DMIC pad status

| Pin Function | Func PU/PD | S1p PU/PD | D1S1p PU/PD |
|--------------|------------|-----------|-------------|
| DMIC_DATA    | DOWN       | KEEP      | KEEP        |

|          |      |      |      |
|----------|------|------|------|
| DMIC_CLK | DOWN | KEEP | KEEP |
|----------|------|------|------|

### 17.4.10 AMIC N/P

When the pin is used as the AMIC N/P function for audio, the pad status should be NO PULL.

Table17-15AMIC N/P padstatus

| Pin Function | Pin Name | Func PU/PD | Slp PU/PD | DSlp PU/PD |
|--------------|----------|------------|-----------|------------|
| MIC_N        | X        | NO PULL    | KEEP      | KEEP       |
| MIC_P        | X        | NO PULL    | KEEP      | KEEP       |
| MICBIAS      | X        | NO PULL    | KEEP      | KEEP       |

### 17.4.11 AOUT\_L/R N/P

When the pin is used as the AOUT\_L/R N/P function for audio, the pad status should be NO PULL.

Table17-16AOUT\_L/RN/PPAD status

| Pin Function | Pin Name | Func PU/PD | Slp PU/PD | DSlp PU/PD |
|--------------|----------|------------|-----------|------------|
| AOUT_N       | X        | NO PULL    | KEEP      | KEEP       |
| AOUT_P       | X        | NO PULL    | KEEP      | KEEP       |

## 17.5 Sleep Configuration

The rtl8721dlp\_sleepcfg should keep.

## 17.6 Boot Configuration

Bootloader can be configured through the rtl8721d\_bootcfg file, as Table17-17 and Fig17-8 show.

Table17-17User bootcfg

| Configuration Items | Comment                                                                |
|---------------------|------------------------------------------------------------------------|
| Flash_MMU_Config    | Used for MMU configuration, A2 address mapping should be settled here. |
| OTA_Region          | OTA start address                                                      |
| RSIP_Mask_Config    | RSIP mask configure                                                    |
| Force_OTA1_GPIO     | Force OTA1 GPIO configuration                                          |
| Boot_Log_En         | Used to disable Realtek boot log                                       |
| FwCheckCallback     | Firmware verify callback handler                                       |
| OTASelectHook       | Firmware select hook                                                   |

```

/*
 * @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;

```

Fig17-8 User bootcfg

## 17.7 IPC Configuration

You can add IPC entry referring Fig17-9, so that KM4 & KMO can send message to each other by the method you defined.

ForUSER\_MSG\_TYPE

IPC\_USER\_POINTMessage 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_SHELL_SWITCH
        {IPC_USER_DATA, NULL, (VOID*) NULL}, //channel 1: IPC_INT_CHAN_WIFI_FW
        {IPC_USER_DATA, FLASH_Write_IPC_Ext, (VOID*) NULL}, //channel 2: IPC_INT_CHAN_FLASHPG_REQ
        {IPC_USER_POINT, NULL, (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 Customer 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 */
};

#else
#if CONFIG_WIFI_FW_EN
extern void driver_fw_flow_ipc_int(VOID *Data, u32 IrqStatus, u32 ChanNum);
#define fw_flow_ipc_int driver_fw_flow_ipc_int
#else
#define fw_flow_ipc_int NULL
#endif
#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_SHELL_SWITCH
        {IPC_USER_DATA, fw_flow_ipc_int, (VOID*) IPCM4_DEV}, //channel 1: IPC_INT_CHAN_WIFI_FW
        {IPC_USER_DATA, FLASH_Write_IPC_Ext, (VOID*) NULL}, //channel 2: IPC_INT_CHAN_FLASHPG_REQ
        {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 Customer 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
```

Fig17-9 User ipccfg

**NOTE**

Use IPC channel 16~31 and IPC semaphore index 8~15, Channel 0 and semaphore index 0~7 are reserved for Realtek use

## 17.8 LP\_intf Configuration

UART low power enable/disable can be configured through the `rt18721dlp_intfcfg` file.

```
UARTCFG_TypeDef uart_config[2]=
{
    /* UART0 */
    {
        .LOW_POWER_RX_ENABLE = DISABLE, /* Enable low power RX*/
    },
    /* UART1 */
    {
        .LOW_POWER_RX_ENABLE = DISABLE,
    },
};
```

## 17.9 HP\_intf Configuration

PSRAM parameters, SDIO host parameters and FTL parameters can be configured through the `rt18721hp_intfcfg` file.

```
#include "ameba_soc.h"
#include "autoconf.h"

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
};

SDIOHCFG_TypeDef sdioh_config = {
    .sdioh_bus_speed = SD_SPEED_HS,      // SD_SPEED_DS or SD_SPEED_HS
    .sdioh_bus_width = SDIOH_BUS_WIDTH_4BIT, // SDIOH_BUS_WIDTH_1BIT or SDIOH_BUS_WIDTH_4BIT
    .sdioh_cd_pin = _PB_25,              // _PB_25/_PA_6/_PNC
    .sdioh_wp_pin = _PNC,                // _PB_24/_PA_5/_PNC
};

#if defined(CONFIG_FTL_ENABLED)
#define FTL_MEM_CUSTEM 0
#endif
#if FTL_MEM_CUSTEM == 0
#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."
#else
const u8 ftl_phy_page_num = 3;          /* The number of physical map pages, default is 3*/
const u32 ftl_phy_page_start_addr = 0x00102000; /* The start offset of flash pages which is allocated to FTL physical map.
                                                Users should modify it according to their own memory layout! */
#endif
#endif
```

# 18 Flash Operation

## 18.1 Functional Description

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

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

User modeA typical software flow to implement all serial transfer. User can transmit or receiveFlash through SPIetting up SPIC registers.

Auto modeCompared to user mode, auto mode is a hardware control flow to executeFlash through SPIetting up SPIC registers. After setting up SPIC, user do need to configure the related control register for each transfer operation. Auto mode is a convenientFlash through SPIetting up SPIC access to memory (SRAM or DRAM).

The SPIC is initialized automatically in boot sequence. User must not initialize SPIC manually. The supported mode for different operations can be found Table18-1.

Table18-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.

## 18.2 Protection Method

Considering Ameba-D supports Flash execute place (XIP), which enables direct execution in Flash memory without copying to RAM. Both KMO and KM4 CPU cores can issue request to SPIC in auto mode to read instructions from Flash to execute.

To prevent being interrupted by auto mode reading, the user mode operation should be protected until ~~it is finished~~ the flow of KMO manipulating Flash safely in user mode has been protected. The method of KM4 manipulating Flash is in the same way.

The protection methods are implemented `FLASH_Write_Lock` and `FLASH_Write_Unlock` functions. The APIs provided by Realtek 8r3 and 18.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. They should also call `FLASH_Write_Lock` before operation and call `FLASH_Write_Unlock` to release from protection after operation.



Fig18.1 User mode operation flow

## 18.3 FlashRawAPIs

### 18.3.1 Read

#### 18.3.1.1 HAL\_READ8/HAL\_READ16/HAL\_READ32

| Items        | Description                                                                                                                                                                                                                           |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Read 1byte/1word/1dword data from Flash in auto mode, just as access SRAM                                                                                                                                                             |
| Parameters   | base: the base address of Flash memory, should be SPI_FLASH_BASE which is 0x08000000.<br>addr: the offset address in Flash memory, should be byte aligned for HAL_READ8, word aligned for HAL_READ16 and dword aligned for HAL_READ32 |
| Return       | The read data                                                                                                                                                                                                                         |

#### 18.3.1.2 FLASH\_ReadStream

| Items        | Description                                                                                                                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Read a stream of data from specified address of Flash in auto mode.                                                                                                                             |
| Parameters   | address: specify the starting offset address to read from, it has no alignment restrictions.<br>len: specify the length of the data to read.<br>data: specify the buffer to save the read data. |
| Return       | Status<br>1: success<br>Others: fail                                                                                                                                                            |

## 18.3.2 Write

### 18.3.2.1 FLASH\_TxData12BXIP

| Items        | Description                                                                                                                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write data to flash in user mode. This function is already protected and can be called by user directly.                                                                                                        |
| Parameters   | StartAddr: start address in Flash from which SPIC writes.<br>DataPhaseLen: the number of bytes that SPIC sends in Data. This value must be more than 12 bytes.<br>pData: pointer to a byte array that is not be |
| Return       | N/A                                                                                                                                                                                                             |

### 18.3.2.2 FLASH\_WriteStream

| Items        | Description                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Write a stream of data to specified address in user mode. This function is already protected and can be called by user directly.                                                                     |
| Parameters   | address: specifies the starting address to write to.<br>len: specifies the length of the data to write no restrictions of less than 12 bytes<br>data: pointer to a byte array that is to be written. |
| Return       | Status<br>1: success<br>Others fail                                                                                                                                                                  |

## 18.3.3 Erase

### 18.3.3.1 FLASH\_EraseXIP

| Items        | Description                                                                                                                                                                                                                                                                          |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Erase sector/block/chip. In user mode. This function is already protected and can be called by users directly.                                                                                                                                                                       |
| Parameters   | EraseType: can be one of the following value.<br>EraseChip: erase the whole chip.<br>EraseBlock: erase the specified block (64KB)<br>EraseSector: erase the specified sector (4KB)<br>Address: address should be byte aligned. The block/sector where the address is will be erased. |
| Return       | N/A                                                                                                                                                                                                                                                                                  |

## 18.3.4 Receive/Transmit Command

### 18.3.4.1 FLASH\_RxCmdXIP

| Items        | Description                                                                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Send Rx command to Flash to get status register. In flash mode. This function is already protected and can be called by user directly.                                                    |
| Parameters   | cmd: command that need to be sent.<br>read_len: the number of bytes that will be read by SPI. It is a command.<br>read_data: pointer to a byte array which is used to save data received. |
| Return       | N/A                                                                                                                                                                                       |

### 18.3.4.2 FLASH\_SetStatusXIP

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

|              |                                                                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | SetFlashstatus@register user mode. The function is already protected and can be called by users directly.                           |
| Parameters   | cmd: command to be sent.<br>len: the number of bytes to be sent after sending command.<br>status: pointer to byte array to be sent. |
| Return       | N/A                                                                                                                                 |

## 18.4 Flash Mbed API

The descriptions of Flash Mbed APIs can be found in [AN403 Peripheral Driver Mbed API](#). All these functions have already been protected and can be called directly.

## 18.5 User Configuration

Ameba-D provides `stl8721dlp_flashcfg` to configure Flash speed and read mode.

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

Fig18-2 Configuring Flash speed

```
/** 
 * @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 0, Just data 4 bits mode
 *        0x3FFF: Read dual IO, Address & Data 2 bits mode
 *        0x1FFF: Read dual 0, 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;
```

Fig18-3 Configuring Flash read mode

Note: For some Flash chip which is not available in FlashAVL, the principle to determine whether it can be supported by [SDK](#) the method to add a new Flash can be found in [User Configuration](#).

# 19 Battery Measurement

## 19.1 Functional Description

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

Table 19-1 Channel description

| Function       | ADC Channel | PinName                 | Voltage Range               |
|----------------|-------------|-------------------------|-----------------------------|
| Normal channel | CHO~CH6     | PB[4] ~ PB[7] (CHO~CH3) | 0~3.3V (when power is 3.3V) |
|                |             | PB[1] ~ PB[3] (CH4~CH6) | 0~1.8V (when power is 1.8V) |
| VBAT           | CH7         | VBAT_MEAS               | 0~5V                        |

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

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

## 19.2 Calibration

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



Fig 19-1 Relationship between sample data and input voltage

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

$$\text{Voltage} = \frac{\text{Sample Data} - \text{OFFSET}}{\text{GAIN}}$$

Where

Data: 12bit 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 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 the standard 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,



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 ~~first~~ after calibration as Table 19-2 shows.

Table 19-2 Calibration parameter location

| Channel          | Input Mode   | Parameter | Address                  |
|------------------|--------------|-----------|--------------------------|
| Normal (CH0-CH6) | Singleended  | OFFSET    | Physical map 0x1D0-0x1D1 |
|                  |              | GAIN      | Physical map 0x1D2-0x1D3 |
|                  | Differential | OFFSET    | Physical map 0x1D8-0x1D9 |
|                  |              | GAIN      | Physical map 0x1DA-0x1DB |
| VBAT (CH7)       | Singleended  | OFFSET    | Physical map 0x1D4-0x1D5 |
|                  |              | GAIN      | Physical map 0x1D6-0x1D7 |

To calculate voltage from sample data ~~only~~ we need to obtain calibration parameters ~~first~~ and call the voltage computational formula

# 20 Wi-Fi

## 20.1 Wi-Fi Data Structures

| Data Structures           | Introduction                                                                                                                                                                            |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <_cus_ie>                 | The structure is used to set the 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 MAC address.                                                                                                                               |
| <rtw_ap_info>             | The structure is used to describe the setting about SSID, security type, password and default start AP mode.                                                                            |
| <rtw_network_info>        | The structure is used to describe the station mode setting about SSID, security type and pass 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 setting gotten from WiFi driver.                                                                                                                     |
| <rtw_wifi_config>         | The structure is used to describe the setting when configuring 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. It includes the version, BSSID, beacon_period, capability, SSID, channel, atm_window, dtim_Speriod, Speriod, and others. |

## 20.2 Wi-Fi APIs

### 20.2.1 System APIs

| API                           | Introduction                                                              |
|-------------------------------|---------------------------------------------------------------------------|
| <wifi_on>                     | Enable WiFi.                                                              |
| <wifi_off>                    | Disable WiFi.                                                             |
| <wifi_is_up>                  | Check if the specified interface is up.                                   |
| <wifi_is_ready_to_transceive> | Determine if a particular interface is ready to receive Ethernet packets. |
| <wifi_rf_on>                  | Enable WiFi RF.                                                           |
| <wifi_rf_off>                 | Disable WiFi RF.                                                          |

#### 20.2.1.1 wifi\_on

Enable WiFi:  y

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

#### 20.2.1.2 wifi\_off

Disable WiFi:

Parameter None.

#### 20.2.1.3 wifi\_is\_up

Check 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_i |

#### 20.2.1.4 wifi\_is\_ready\_to\_transceive

Determine if a particular interface is ready to receive Ethernet packets.

| Parameter   | Type            | Introduction                                                |
|-------------|-----------------|-------------------------------------------------------------|
| <interface> | rtw_interface_t | Interface to check<br>RTW_STA_INTERFACE<br>RTW_AP_INTERFACE |

### 20.2.2 Scan APIs

| API                            | Introduction                                                            |
|--------------------------------|-------------------------------------------------------------------------|
| <wifi_scan>                    | Initiate a scan to search for 802.11 networks                           |
| <wifi_scan_networks>           | Simplify the scan operation based on scan to search for 802.11 networks |
| <wifi_scan_networks_with_ssid> | Initiate a scan to search for 802.11 networks with specified SSID       |

#### 20.2.2.1 wifi\_scan

Initiate a scan to search for 802.11 networks.

| 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 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.<br>ssid need to scan, please clean result 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 several 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 those channels may be detected.

#### 20.2.2.2 wifi\_scan\_networks

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

| Parameter         | Type                    | Introduction                                                              |
|-------------------|-------------------------|---------------------------------------------------------------------------|
| <results_handler> | rtw_scan_result_handler | 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 |

Note: Callback must not use blocking functions, since it is called from the context of the RTW thread. The data variables will be referenced after the function returns. Those variables must remain valid until the scan completes. The completed API can refer to ATWS in atcmd\_wifi.c.

#### 20.2.2.3 wifi\_scan\_networks\_with\_ssid

Initiate 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 WiFi scan. The user\_data variables will be referenced after the function returns. Those variables must remain valid until the scan is completed.

## 20.2.3 Connection APIs

| API                         | Introduction                                                               |
|-----------------------------|----------------------------------------------------------------------------|
| <wifi_connect>              | Join a WiFi network with specified SSID.                                   |
| <wifi_connect_bssid>        | Join a WiFi network with specified BSSID.                                  |
| <wifi_disconnect>           | Disassociates from current WiFi network.                                   |
| <wifi_is_connected_to_ap>   | Check if WiFi 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 reconnection.                   |

### 20.2.3.1 wifi\_connect

Join a WiFi network with specified SSID. Scan for, associate and authenticate with 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>RTW_SECURITY_OPEN: open security<br>RTW_SECURITY_WEP_PSK: WEP Security with open authentication<br>RTW_SECURITY_WEP_SHARED_PSK: WEP Security with shared authentication<br>RTW_SECURITY_WPA_TKIP_PSK: WPA Security<br>RTW_SECURITY_WPA2_AES_PSK: WPA2 Security using AES cipher<br>RTW_SECURITY_WPA2_TKIP_PSK: WPA2 Security using TKIP cipher<br>RTW_SECURITY_WPA2_MIXED_PSK: WPA2 Security using AES and/or TKIP ciphers |
| <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 value NULL.                                                                                                                                                                                                                                                                                                                                            |

Note Make sure the WiFi is enabled before invoking this function. (wifi\_on())

### 20.2.3.2 wifi\_connect\_bssid

Join a WiFi network with specified BSSID. Scan for, associate and authenticate with 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_ | Authentication type:<br>RTW_SECURITY_OPEN: open security<br>RTW_SECURITY_WEP_PSK: WEP Security with open authentication<br>RTW_SECURITY_WEP_SHARED: WEP Security with shared authentication<br>RTW_SECURITY_WPA_TKIP_PSK: WPA Security<br>RTW_SECURITY_WPA2_AES_PSK: WPA2 Security using AES cipher<br>RTW_SECURITY_WPA2_TKIP_PSK: WPA2 Security using TKIP cipher<br>RTW_SECURITY_WPA2_MIXED_PSK: WPA2 Security using AES and/or TKIP ciphers |
| <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 WPA, leave it at 0.                                                                                                                                                                                                                                                                                                                                                                     |
| <semaphore>     | void*         | A user provided semaphore is flagged when the join is complete. If not using, leave it with NULL.                                                                                                                                                                                                                                                                                                                                              |

#### Note

Make sure the WiFi 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().

#### 20.2.3.3 wifi\_disconnect

Disassociates from current WiFi network.

ParameterNone.

#### 20.2.3.4 wifi\_is\_connected\_to\_ap

Check if WiFi has connected AP before dhcp.

ParameterNone.

#### 20.2.3.5 wifi\_config\_autoreconnect

Set 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 The difference between wifi\_config\_autoreconnect() and wifi\_set\_autoreconnect() is that user can specify the times and timeout value in wifi\_config\_autoreconnect(), but in wifi\_set\_autoreconnect() these values are set with entry limit and 5 seconds timeout as default.

#### 20.2.3.6 wifi\_set\_autoreconnect

Set reconnection mode with 8 retry limit and 5 seconds timeout as default.

| Parameter | Type | Introduction                                     |
|-----------|------|--------------------------------------------------|
| <mode>    | _u8  | Set 1/0 to enable/disable the reconnection mode. |

Note The difference between wifi\_config\_autoreconnect() and wifi\_set\_autoreconnect() is that user can specify the times and timeout value in wifi\_config\_autoreconnect(), but in wifi\_set\_autoreconnect() these values are set with entry limit and 5 seconds timeout as default.

### 20.2.3.7 wifi\_get\_autoreconnect

Get the result of setting reconnection mode.

| Parameter | Type | Introduction                                        |
|-----------|------|-----------------------------------------------------|
| <mode>    | _u8  | Pointer to the result of setting reconnection mode. |

### 20.2.3.8 wifi\_get\_last\_error

Present the device disconnect reason while connecting.

Parameter None.

## 20.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 eFuse, must reboot after setting channel plan. |
| <wifi_get_channel_plan> | Get channel plan from eFuse.                                         |

### 20.2.4.1 wifi\_set\_channel

Set 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 driver, since it will be determined by the channel from received beacon.

### 20.2.4.2 wifi\_get\_channel

Get the current channel on STA interface.

| Parameter | Type  | Introduction                                                       |
|-----------|-------|--------------------------------------------------------------------|
| <channel> | int * | A pointer to the variable where the channel value will be written. |

### 20.2.4.3 wifi\_set\_channel\_plan

Set channel plan into eFuse, must reboot after setting channel plan.

| Parameter      | Type    | Introduction                                                        |
|----------------|---------|---------------------------------------------------------------------|
| <channel_plan> | uint8_t | The value of channel plan, defined in <code>wifi_constants.h</code> |

### 20.2.4.4 wifi\_get\_channel\_plan

Get channel plan from eFuse.

| Parameter      | Type    | Introduction                                                                 |
|----------------|---------|------------------------------------------------------------------------------|
| <channel_plan> | uint8_t | Point to the value of channel plan, defined in <code>wifi_constants.h</code> |

## 20.2.4.5 wifi\_change\_channel\_plan

Switch the current channel plan via the software way

| Parameter      | Type    | Introduction                                                        |
|----------------|---------|---------------------------------------------------------------------|
| <channel_plan> | uint8_t | The value of channel plan, defined in <code>wifi_constants.h</code> |

## 20.2.4.6 wifi\_set\_country

Set country code and the channel plan according to the country code via software way

| Parameter      | Type               | Introduction                                                        |
|----------------|--------------------|---------------------------------------------------------------------|
| <country_code> | rtw_country_code_t | Set country code and the channel plan according to the country code |

## 20.2.5 Power APIs

| API                      | Introduction                     |
|--------------------------|----------------------------------|
| <wifi_enable_powersave>  | Enable WiFi powersave mode.      |
| <wifi_disable_powersave> | Disable WiFi powersave 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.                    |

### 20.2.5.1 wifi\_enable\_powersave

Enable WiFi powersave 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 None.

### 20.2.5.2 wifi\_disable\_powersave

Disable WiFi powersave mode.

Parameter None.

### 20.2.5.3 wifi\_get\_txpower

Get the Tx power in index units.

| Parameter  | Type | Introduction                                |
|------------|------|---------------------------------------------|
| <poweridx> | int* | The variable to receive the power in index. |

### 20.2.5.4 wifi\_set\_txpower

Set the Tx power in index units.

| Parameter  | Type | Introduction                   |
|------------|------|--------------------------------|
| <poweridx> | int  | The desired Tx power in index. |

## 20.2.5.5 wifi\_set\_power\_mode

Set IPS/LPS mode.

| Parameter  | Type         | Introduction                                                                                                                                                                                                                                                                                      |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ips_mode> | unsignedchar | The desired IPS mode. It becomes effective when WLAN enters IPS. ips_mode is inactive power save mode. It automatically turns RF off when device is not associated to AP. Set 1 to enable inactive power save mode.                                                                               |
| <lps_mode> | unsignedchar | The desired LPS mode. It becomes effective when WLAN enters LPS. lps_mode is leisure power save mode. It turns RF on to listen to beacon automatically and periodically during the association to AP. If traffic is high, it automatically turns RF off. Set 1 to enable leisure power save mode. |

## 20.2.5.6 wifi\_set\_lps\_dtim

Set LPS DTIM.

| Parameter | Type         | Introduction                                                                                            |
|-----------|--------------|---------------------------------------------------------------------------------------------------------|
| <dtim>    | unsignedchar | In LPS, the package can be buffered at AP side. STA leaves LPS until DTIM count of buffered at AP side. |

Note DTIM is the duration to listen beacon. The default DTIM is 1, which is 100ms. If DTIM is set bigger than that, power consumption can be saved and the disadvantage is that STA has the risk of losing packets.

## 20.2.5.7 wifi\_get\_lps\_dtim

Get LPS DTIM.

| Parameter | Type           | Introduction                                                                                            |
|-----------|----------------|---------------------------------------------------------------------------------------------------------|
| <dtim>    | unsignedchar * | In LPS, the package can be buffered at AP side. STA leaves LPS until DTIM count of buffered at AP side. |

## 20.2.6 AP Mode APIs

| API                               | Introduction                                                    |
|-----------------------------------|-----------------------------------------------------------------|
| <wifi_start_ap>                   | Trigger Wi-Fi driver to start an infrastructure network.        |
| <wifi_start_ap_with_hidden_ssid>  | Start an infrastructure network with hidden SSID.               |
| <wifi_restart_ap>                 | Trigger Wi-Fi driver to restart an infrastructure WiFi 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.                          |

### 20.2.6.1 wifi\_start\_ap

Trigger Wi-Fi driver to start an infrastructure network.

| Parameter       | Type          | Introduction                                                                                                                          |
|-----------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------|
| <ssid>          | char *        | A null terminated string containing the SSID name of the network.                                                                     |
| <security_type> | security_type | RTW_SECURITY_OPEN Open Security<br>RTW_SECURITY_WPA_TKIP_PSK WPA Security<br>RTW_SECURITY_WPA2_AES_PSK WPA2 Security using AES cipher |

|                |        |                                                                                                                             |
|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------|
|                |        | RTW_SECURITY_WPA2_MIXED_PSKRA2 Security using AES and/or TKIP ciphers<br>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.

If a STA interface is active when this function is called, the softAP will start on the same channel as the STA channel not provided.

**20.2.6.2 wifi\_start\_ap\_with\_hidden\_ssid**

Start 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 | RTW_SECURITY_OPEN Open Security<br>RTW_SECURITY_WPA_TKIP_PSKRA2 Security<br>RTW_SECURITY_WPA2_AES_PSKRA2 Security using AES cipher<br>RTW_SECURITY_WPA2_MIXED_PSKRA2 Security using AES and/or TKIP ciphers<br>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 channel not provided.

**20.2.6.3 wifi\_restart\_ap**

Trigger 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  | RTW_SECURITY_OPEN Open Security<br>RTW_SECURITY_WPA_TKIP_PSKRA2 Security<br>RTW_SECURITY_WPA2_AES_PSKRA2 Security using AES cipher<br>RTW_SECURITY_WPA2_MIXED_PSKRA2 Security using AES and/or TKIP ciphers<br>WEP security is NOT IMPLEMENTED. It is NOT SECURE! |
| <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 channel not provided.

**20.2.6.4 wifi\_get\_associated\_client\_list**

Get the associated clients with SoftAP.

| Parameter            | Type          | Introduction                                       |
|----------------------|---------------|----------------------------------------------------|
| <client_list_buffer> | int*          | The location where the client list will be stored. |
| <buffer_length>      | unsignedshort | The buffer length.                                 |

## 20.2.6.5 wifi\_enable\_forwarding

Enable packets forwarding in AP mode.

Parameter None.

## 20.2.6.6 wifi\_disable\_forwarding

Disable packets forwarding in AP mode.

Parameter None.

## 20.2.7 Custom IE APIs

| API                     | Introduction                            |
|-------------------------|-----------------------------------------|
| <wifi_add_custom_ie>    | Setup custom IE list.                   |
| <wifi_update_custom_ie> | Update the item in WiFi custom IE list. |
| <wifi_del_custom_ie>    | Delete WiFi custom IE list.             |

Note These three APIs are only effective on beacon, probe request and probe response frames.

### 20.2.7.1 wifi\_add\_custom\_ie

Setup custom IE list.

| Parameter | Type   | Introduction                       |
|-----------|--------|------------------------------------|
| <cus_ie>  | void * | Pointerto WiFi CUSTOMIE list.      |
| <ie_num>  | int    | The number of WiFi CUSTOM IE list. |

Note u . . . h @ . . .

### 20.2.7.2 wifi\_update\_custom\_ie

Update the item in WiFi custom IE list.

| Parameter  | Type   | Introduction                       |
|------------|--------|------------------------------------|
| <cus_ie>   | void * | Pointerto WiFi CUSTOM IE list.     |
| <ie_index> | int    | The number of WiFi CUSTOM IE list. |

### 20.2.7.3 wifi\_del\_custom\_ie

Delete WiFi custom IE list.

Parameter None.

## 20.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 the AP BSSID. Format: "h o o @")                                                                                                                                                                            |
| <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   | Registers 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 | Unregisters 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 WiFi setting from driver.                                                                                                                                                                           |
| <wifi_show_setting                 | Show the network information stored in the rtw_wifi_setting structure.                                                                                                                                          |
| <wifi_set_network_mode             | Set the network mode according to the data rate it supported.                                                                                                                                                   |
| <wifi_get_network_mode             | Get the network mode.                                                                                                                                                                                           |
| <wifi_get_antenna_info             | Get antenna information.                                                                                                                                                                                        |
| <wifi_set_ch_deauth                | Set flag for concurrent mode wlan0 is deauth when channel switched by wlan0.                                                                                                                                    |

### 20.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 get. |

### 20.2.8.2 wifi\_get\_ap\_bssid

Get the AP BSSID. Format: "h o o @")

| Parameter | Type          | Introduction                                    |
|-----------|---------------|-------------------------------------------------|
| <bssid>   | unsigned char | The location where the AP BSSID will be stored. |

### 20.2.8.3 wifi\_get\_ap\_info

Get the SoftAP information.

| Parameter  | Type             | Introduction                                   |
|------------|------------------|------------------------------------------------|
| <ap_info>  | rtw_bss_info_t   | The location where the AP info will be stored. |
| <security> | rtw_security_t * | The security type.                             |

### 20.2.8.4 wifi\_set\_country

Set the country code to driver to determine the channel set.

| Parameter      | Type               | Introduction              |
|----------------|--------------------|---------------------------|
| <country_code> | rtw_country_code_t | Specify the country code. |

## 20.2.8.5 wifi\_get\_sta\_max\_data\_rate

Retrieved STA mode max. data rate.

| Parameter      | Type | Introduction   |
|----------------|------|----------------|
| <inidata_rate> | _u8* | Max data rate. |

## 20.2.8.6 wifi\_get\_rssi

Retrieved the latest RSSI value.

| Parameter | Type | Introduction                                                      |
|-----------|------|-------------------------------------------------------------------|
| <pRSSI>   | int* | Points to the integer to store the RSSI value gotten from driver. |

## 20.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~~ forwarded to otherwise they are ignored.

| Parameter | Type        | Introduction          |
|-----------|-------------|-----------------------|
| <mac>     | rtw_mac_t * | Ethernet MAC address. |

## 20.2.8.8 wifi\_unregister\_multicast\_address

Unregister interest in a multicast address.

Once a multicast address has been unregistered, all ~~detected~~ on the medium destined for that address are ignored.

| Parameter | Type        | Introduction          |
|-----------|-------------|-----------------------|
| <mac>     | rtw_mac_t * | Ethernet MAC address. |

## 20.2.8.9 wifi\_set\_mib

Setup the adaptive mode. You can replace this weak function by the same name function to setup adaptive mode.

Parameter None.

## 20.2.8.10 wifi\_set\_country\_code

Setup country code. You can replace this weak function by the same name function to setup country code you want.

Parameter None.

## 20.2.8.11 wifi\_set\_tdma\_param

Set TDMA parameters.

| Parameter           | Type         | Introduction                                                                                                                                                                                                                                                                                                                      |
|---------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <slot_period>       | unsignedchar | 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. If we separate TBTT into 3 slots, then slot_period should be less or equal to 33ms. It means 3 slot period is 100 * slot_period, slot_period, slot_period. |
| <rfon_period_len_1> | unsignedchar | RF on period of slot 1.                                                                                                                                                                                                                                                                                                           |
| <rfon_period_len_2> | unsignedchar | RF on period of slot 2.                                                                                                                                                                                                                                                                                                           |
| <rfon_period_len_3> | unsignedchar | RF on period of slot 3.                                                                                                                                                                                                                                                                                                           |

## 20.2.8.12 wifi\_get\_setting

Get current WiFi setting from driver.

| Parameter  | Type                 | Introduction                                                                             |
|------------|----------------------|------------------------------------------------------------------------------------------|
| <ifname>   | const char *         | The WLAN interface name<br>WLAN0_NAME<br>WLAN1_NAME                                      |
| <pSetting> | rtw_wifi_setting_t * | Points to the rtw_wifi_setting_t structure to store the WiFi setting gotten from driver. |

## 20.2.8.13 wifi\_show\_setting

Show the network information stored in the 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. |

## 20.2.8.14 wifi\_set\_network\_mode

Set the network mode according to the data rate it supported. Driver works in BGN mode in default after 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>RTW_NETWORK_B<br>RTW_NETWORK_BG<br>RTW_NETWORK_BGN |

## 20.2.8.15 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 network mode for station mode.

| Parameter | Type                 | Introduction         |
|-----------|----------------------|----------------------|
| <pmode>   | rtw_network_mode_t * | Network mode to get. |

## 20.2.8.16 wifi\_get\_antenna\_info

Get antenna information.

| Parameter | Type           | Introduction                                                     |
|-----------|----------------|------------------------------------------------------------------|
| <antenna> | unsignedchar * | Points to store the antenna value gotten from driver.<br>0: main |

|  |  |        |
|--|--|--------|
|  |  | 1: aux |
|--|--|--------|

### 20.2.8.1 wifi\_set\_ch\_deauth

Setflag for concurrent mode wlan1 issue\_deauth when channel switched by wlan0.

| Parameter | Type | Introduction            |
|-----------|------|-------------------------|
| <enable>  | _u8  | 0: Disable<br>1: Enable |

Usage wifi\_set\_ch\_deauth(0)wlan0 wifi\_connect wifi\_set\_ch\_deauth(1)

## 20.2.9 Wi-Fi Indication APIs

| API                        | Introduction                                                       |
|----------------------------|--------------------------------------------------------------------|
| <wifi_manager_init>        | Initialize Realtek Wi API System.                                  |
| <wifi_indication>          | WLAN driver indicate event to upper layer through wifi_indication. |
| <init_event_callback_list> | Initialize the event callback.                                     |
| <wifi_reg_event_handler>   | Register the event listener.                                       |
| <wifi_unreg_event_handler> | Un-register the event listener.                                    |

### 20.2.9.1 wifi\_manager\_init

Initialize Realtek Wi API System

Initialize the required parts of the software platform, such as worker, event registration and Initialize the RTW API thread which handles the asynchronous event

Parameter None.

### 20.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. Refers to rtw_event_indicate_t. |
| <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 size usage (by using uxTaskGetStackHighWaterMark()), and tries not to share the same stack with WLAN driver if remaining stack available for the following operations.

Using semaphore to notice another thread instead of handing event directly.

### 20.2.9.3 init\_event\_callback\_list

Initialize the event callback.

Parameter None.

Note Make sure this function has been invoked before using the event handler related mechanism.

## 20.2.9.4 wifi\_reg\_event\_handler

Register 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 Set the same even\_cmds with empty handler\_func will unregister the event\_cmds.

## 20.2.9.5 wifi\_unreg\_event\_handler

Un-register 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. |

## 20.2.10 eFuseWriting APIs

| API                    | Introduction                                                                            |
|------------------------|-----------------------------------------------------------------------------------------|
| <wifi_set_mac_address> | This function sets the current Media Access Control (MAC) address of the 802.11 device. |

Note 7  
writing can only be operated one time, so be careful to do eFuse writing.

### 20.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. |

## 20.3 FastConnection

This section illustrates the principle of fast connection and how to implement user's own fast connection code.

Fast connection 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.

### 20.3.1 Implement

#### 20.3.1.1 AP Information Storage

Users should implement a function to write AP information to Flash just like demo function wlan\_wrtie\_reconnect\_data\_to\_flash example code. In this function you should reserve some space for AP information and write the AP information to the reserved space defined by pre data format. The address of the function must be assigned to the global variable p\_reconnect\_point. After WiFi connection success, if p\_write\_reconnect\_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

### 20.3.1.2 Reconnection

User should implement his own function to read AP information from Flash and connect to AP like demo function wlan\_init\_done\_callback. In example code the address of the function must be stored in the global variable p\_wlan\_init\_done\_callback. This global variable should be defined before initializing Wi-Fi if p\_wlan\_init\_done\_callback points to a valid address, this function will be called.

### 20.3.1.3 FastConnection DataErase

User should implement his own function to erase fastconnection data, just like demo function Erase\_Fastconnect\_data @example code.

## 20.3.2 APIs

| API                                  | Introduction                                                                                                                                                                                 |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <wlan_wrtie_reconnect_data_to_flash> | Wi-Fi connection indication trigger this function to save current profile in Flash.                                                                                                          |
| <wlan_init_done_callback>            | After WiFi initialization done, WLAN driver calls this function to check whether connection is required.<br>This function reads previous saved WLAN profile in flash and execute connection. |

### 20.3.2.1 wlan\_wrtie\_reconnect\_data\_to\_flash

Wi-Fi connection indications trigger this function to save current 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>0: write is ok<br>-1: write failed |

Note This is only a demo API user should define his own API.

## 20.4 WPS APIs

| API         | Introduction               |
|-------------|----------------------------|
| <wps_start> | Start WPS enrollee process |
| <wps_stop>  | Stop WPS enrollee process  |

### 20.4.1 wps\_start

Start WPS enrollee process.

| Parameter    | Type   | Introduction                                                                             |
|--------------|--------|------------------------------------------------------------------------------------------|
| <wps_config> | u16    | WPS configure method<br>WPS_CONFIG_DISPLAY<br>WPS_CONFIG_KEYPAD<br>WPS_CONFIG_PUSHBUTTON |
| <pin>        | char * | PIN number. Can be set to NULL if WPS_CONFIG_PUSHBUTTON.                                 |
| <channel>    | u8     | Channel. Currently unused, 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 WiFi should be enabled by calling 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.

## 20.4.2 wps\_stop

Stop WPS enrollee process.

Parameter None.

Note Make sure CONFIG\_ENABLE\_WPS is enabled in platform\_opts.h

# 21 Liquid Crystal Display Controller (LCDC)

Ameba-D LCDC supports Thin Film Transistor (TFT) color display. It provides I<sub>2</sub>O80 MCU interface and RGB interface (6bit width), and supports RGB565 data format.

This chapter introduces how to use LCDC I/F to control LCD module.

## 21.1 Interface

The available LCDC interfaces for different IC packages are shown in

Table 21-1 LCDC I/F supported for different packages

| IC Package                            | MCU 8bit | RGB 6bit |
|---------------------------------------|----------|----------|
| RTL8722D/RTL8722CS                    |          |          |
| RTL8721D/RTL8721CS/RTL8720D/RTL8720CS |          |          |

The data format supported by each interface is shown in Table 21-2. In order to display normally, the data format of LCM and LCDC interface should match.

Table 21-2 LCDC I/F data format

| Interface             | Data Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Comment |      |      |      |   |   |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |    |      |      |      |      |  |                       |    |      |      |      |      |  |                           |    |      |      |      |      |  |    |    |      |      |      |      |  |                       |  |  |  |  |  |  |                           |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|------|------|---|---|--|----|------|------|------|------|------|--|----|------|------|------|------|------|--|----|------|------|------|------|------|--|----|------|------|------|------|------|--|----|------|------|------|------|------|--|----|----|------|------|------|------|--|-----------------------|----|------|------|------|------|--|---------------------------|----|------|------|------|------|--|----|----|------|------|------|------|--|-----------------------|--|--|--|--|--|--|---------------------------|
| MCU 8bit              | <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>CO</td><td>P1G3</td><td>P1B0</td><td>P2G3</td><td>P2B0</td><td></td></tr> <tr><td colspan="7">P1R4 Pixel1/Red_bit#4</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 | CO | P1G3 | P1B0 | P2G3 | P2B0 |  | P1R4 Pixel1/Red_bit#4 |  |  |  |  |  |  | 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                    | CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | P1G3    | P1B0 | P2G3 | P2B0 |   |   |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |    |      |      |      |      |  |                       |    |      |      |      |      |  |                           |    |      |      |      |      |  |    |    |      |      |      |      |  |                       |  |  |  |  |  |  |                           |
| P1R4 Pixel1/Red_bit#4 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |      |      |      |   |   |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |    |      |      |      |      |  |                       |    |      |      |      |      |  |                           |    |      |      |      |      |  |    |    |      |      |      |      |  |                       |  |  |  |  |  |  |                           |
| RGB 6bit              | <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>D5</td><td>P1R4</td><td>P1G5</td><td>P1B4</td><td>P2R4</td><td>P2G5</td><td></td></tr> <tr><td>D4</td><td>P1R3</td><td>P1G4</td><td>P1B3</td><td>P2R3</td><td>P2G4</td><td></td></tr> <tr><td>D3</td><td>P1R2</td><td>P1G3</td><td>P1B2</td><td>P2R2</td><td>P2G3</td><td></td></tr> <tr><td>D2</td><td>P1R1</td><td>P1G2</td><td>P1B1</td><td>P2R1</td><td>P2G2</td><td></td></tr> <tr><td>D1</td><td>P1R0</td><td>P1G1</td><td>P1B0</td><td>P2R0</td><td>P2G1</td><td></td></tr> <tr><td>D0</td><td></td><td>P1G0</td><td></td><td></td><td>P2G0</td><td></td></tr> <tr><td colspan="7">P1R4 Pixel1/Red_bit#4</td></tr> </table>                                                                                                                                                                                                                                                                           | Count   | 0    | 1    | 2    | 3 | 4 |  | 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_bit#4 |    |      |      |      |      |  | 3 transfers/pixel, RGB565 |    |      |      |      |      |  |    |    |      |      |      |      |  |                       |  |  |  |  |  |  |                           |
| Count                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1       | 2    | 3    | 4    |   |   |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |    |      |      |      |      |  |                       |    |      |      |      |      |  |                           |    |      |      |      |      |  |    |    |      |      |      |      |  |                       |  |  |  |  |  |  |                           |
| 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_bit#4 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |      |      |      |   |   |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |      |      |      |      |      |  |    |    |      |      |      |      |  |                       |    |      |      |      |      |  |                           |    |      |      |      |      |  |    |    |      |      |      |      |  |                       |  |  |  |  |  |  |                           |

## 21.2 Resolution

The maximum resolution supported by each interface is listed in Table 21-3.

Table 21-3 Maximum supported resolution

| Interface | Display Type   | Max. Support Resolution |
|-----------|----------------|-------------------------|
| MCU 8bit  | Static Display | 1024*1024               |
|           | DynamicDisplay | 645*64(30fps)           |
|           | DynamicDisplay | 912*912(30fps)          |
| RGB 6bit  | DynamicDisplay | 600*400(60fps)          |

For RGBLCD, the typical frame rate is 60fps.

In order to support RGB with higher resolution than parameter **Table 21-1**, users have to set the frame rate. The maximum frame rate for a RGBLCD is calculated as follows:

Max. dot clock: MAX\_DOT\_CLK = system\_clock / 3 = 5MHz

Width, height, BPP, HFP, VBP, VFP are specified by LCD datasheet.

For 6bit I/F mode:

```
image_size = MAX_DOT_CLK / (3 * width + HBP + HFP) * (VBP + VFP) * (HBP + HFP);
F = 50M / (width * height * (width + HBP + HFP) * (VBP + VFP) * (HBP + HFP)) * 3;
```

When frame rate is lower than 30fps, the screen flickering may happen. Users should evaluate the visual artifacts when setting frame rate lower.

## 21.3 Pinmux

The pin assignments of LCDC are listed in **Table 21-4**.

**Table 21-4** LCDC pin assignments

| Port Name | MCU 8bit | RGB 6bit | LED I/F |
|-----------|----------|----------|---------|
| PB[19]    | -        | -        | -       |
| PB[18]    | -        | -        | -       |
| PB[11]    | -        | -        | -       |
| PB[10]    | -        | -        | -       |
| PB[9]     | -        | -        | -       |
| PB[8]     | -        | -        | -       |
| PA[25]    | -        | -        | -       |
| PA[26]    | -        | -        | -       |
| PA[28]    | D[7]     | -        | -       |
| PA[30]    | D[6]     | -        | -       |
| PB[0]     | D[5]     | D[5]     | D[5]    |
| PA[31]    | D[4]     | D[4]     | D[4]    |
| PA[24]    | D[3]     | D[3]     | D[3]    |
| PA[23]    | D[2]     | D[2]     | D[2]    |
| PA[20]    | D[1]     | D[1]     | D[1]    |
| PA[19]    | 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      |

## 21.4 LCD APIs

### 21.4.1 MCU Function

#### 21.4.1.1 LCDC\_MCUStructInit

| Items        | Description                                                                          |
|--------------|--------------------------------------------------------------------------------------|
| Introduction | Initializes the parameters in the LCDC_MCUIInitStruct with default values.           |
| Parameters   | LCDC_MCUIInitStruct: pointer to LCDC_MCUIInitTypeDef structure which is initialized. |
| Return       | N/A                                                                                  |

Note LCDC\_MCUIInitStruct contains the MCU configurable parameters for LCDC, which determine that the module for DMA mode, the plane size and some timing control parameters in this structure should be set according to LCD module datasheet.

#### 21.4.1.2 LCDC\_MCUIInit

| Items        | Description                                                                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the LCDC peripheral according to the specified parameters in LCDC_MCUIInitStruct.                                                   |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>LCDC_MCUIInitStruct: pointer to a LCDC_MCUIInitTypeDef structure that contains the configuration parameters. |
| Return       | N/A                                                                                                                                             |

#### 21.4.1.3 LCDC\_MCUIOWriteCmd

| Items        | Description                                                      |
|--------------|------------------------------------------------------------------|
| Introduction | Writes command to LCD module via MCU I/F.                        |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>Cmd: the command to transmit. |
| Return       | N/A                                                              |

#### 21.4.1.4 LCDC\_MCUIOWriteData

| Items        | Description                                                    |
|--------------|----------------------------------------------------------------|
| Introduction | Writes data to LCD module via MCU I/F.                         |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>Data: the data to transmit. |
| Return       | N/A                                                            |

#### 21.4.1.5 LCDC\_MCUIORReadData

| Items        | Description                             |
|--------------|-----------------------------------------|
| Introduction | Reads data from LCD module via MCU I/F. |
| Parameters   | LCDCx: where LCDCx can be LCDC.         |
| Return       | The read value                          |

#### 21.4.1.6 LCDC\_MCUDMATrigger

| Items        | Description                                                                        |
|--------------|------------------------------------------------------------------------------------|
| Introduction | Triggers to transfer data of one frame from DMA buffer to LCD module for transmit. |
| Parameters   | LCDCx: where LCDCx can be LCDC.                                                    |
| Return       | N/A                                                                                |

### 21.4.2 RGB Function

#### 21.4.2.1 LCDC\_RGBStructInit

| Items        | Description                                                                        |
|--------------|------------------------------------------------------------------------------------|
| Introduction | Initializes the parameters in the LCDC_RGBInitStruct with default values.          |
| Parameters   | LCDC_RGBInitStruct: pointer to LCDC_RGBInitTypeDef structure which is initialized. |
| Return       | N/A                                                                                |

Note LCDC\_RGBInitStruct contains the RGB configurable parameters for LCDC, which determine the ~~RGB HW mode~~, the plane size, the refresh frequency and VSYNC & ~~DSYNC~~. The parameters in this structure should be set according to LCD module datasheet.

#### 21.4.2.2 LCDC\_RGBInit

| Items        | Description                                                                                                                       |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the LCDC peripheral according to the specified parameters in the LCDC_RGBInitStruct.                                  |
| Parameters   | LCDCx where LCDCx can be LCDC.<br>LCDC_RGBInitStruct: pointer to a LCDC_RGBInitTypeDef structure that contains the configuration. |
| Return       | N/A                                                                                                                               |

#### 21.4.3 LED Function

##### 21.4.3.1 LCDC\_LEDStructInit

| Items        | Description                                                                                |
|--------------|--------------------------------------------------------------------------------------------|
| Introduction | Initializes the parameters in LCDC_LEDInitStruct with default values.                      |
| Parameters   | LCDC_LEDInitStruct: pointer to an LCDC_LEDInitTypeDef structure which will be initialized. |
| Return       | N/A                                                                                        |

##### 21.4.3.2 LCDC\_LEDInit

| Items        | Description                                                                                                                   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the LCDC peripheral according to specified parameters in the LCDC_LEDInitStruct.                                  |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>LCDC_LEDInitStruct: pointer to an LCDC_LEDInitTypeDef structure which will be initialized. |
| Return       | N/A                                                                                                                           |

#### 21.4.4 Common Function

##### 21.4.4.1 LCDC\_DMAModeConfig

| Items        | Description                                                                     |
|--------------|---------------------------------------------------------------------------------|
| Introduction | Configures LCDC DMA burst size.                                                 |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>BurstSize: DMA burst size; unit is 64 bytes. |
| Return       | N/A                                                                             |

##### Note

If BurstSize = 1, the actual burstsize = 1x64 bytes; if BurstSize = 2, the actual burstsize = 2x64 bytes.  
The parameter BurstSize is not more than 8. The recommended value is 2.

##### 21.4.4.2 LCDC\_DMAImageBaseAddrConfig

| Items        | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Introduction | Configures image base address.                                      |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>ImgBaseAddr: the buffer address. |
| Return       | N/A                                                                 |

#### 21.4.4.3 LCDC\_INTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the specified LCDC interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>LCDC_IT: specifies the LCDC interrupt sources to be enabled or disabled. This parameter can be any combination of the following values:<br>LCDC_IT_DMAUNDFW: DMA FIFO underflow interrupt<br>LCDC_IT_FRDN: LCD refresh done interrupt<br>LCDC_IT_LINE: line interrupt<br>LCDC_IT_IO_TIMEOUT: IO write/read timeout interrupt<br>LCDC_IT_FRM_START: Frame Start interrupt<br>NewState: new state of the specified LCDC interrupts. This parameter can be ENABLE or DISABLE |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 21.4.4.4 LCDC\_GetINTStatus

| Items        | Description                     |
|--------------|---------------------------------|
| Introduction | Gets LCDC interrupt status.     |
| Parameters   | LCDCx: where LCDCx can be LCDC. |
| Return       | Interruptstatus                 |

#### 21.4.4.5 LCDC\_ClearINT

| Items        | Description                                                                                                                                                                                                                                                                                                                                        |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clears the LCDC's interrupt pending bits.                                                                                                                                                                                                                                                                                                          |
| Parameters   | LCDC_IT: specifies the interrupt to be cleared. This parameter can be any combination of the following values:<br>LCDC_IT_LINE: line interrupt<br>LCDC_IT_FRDN: refresh frame done interrupt<br>LCDC_IT_DMAUNDFW: DMA FIFO under flow interrupt<br>LCDC_IT_IO_TIMEOUT: IO write/read timeout interrupt<br>LCDC_IT_FRM_START: Frame Start interrupt |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                |

#### 21.4.4.6 LCDC\_Cmd

| Items        | Description                                                                                                   |
|--------------|---------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the LCDC.                                                                                 |
| Parameters   | LCDCx: where LCDCx can be LCDC.<br>NewState: new state of the LCDC. This parameter can be: ENABLE or DISABLE. |
| Return       | N/A                                                                                                           |

Note When NewState is DISABLE, during the period of valid line (VTIMING =valid data), the disabled operation is performed after the last valid line has transferred. If you want to disable the LCDC instantly, use the API LCDC\_InsDisable(). During the other periods, the disable operation is performed instantly.

#### 21.4.4.7 LCDC\_InsDisable

| Items        | Description                     |
|--------------|---------------------------------|
| Introduction | Disables the LCDC instantly.    |
| Parameters   | LCDCx: where LCDCx can be LCDC. |
| Return       | N/A                             |

#### 21.4.4.8 LCDC\_DeInit

| Items        | Description                     |
|--------------|---------------------------------|
| Introduction | De-initializes the LCDC.        |
| Parameters   | LCDCx: where LCDCx can be LCDC. |
| Return       | N/A                             |

Note when disabling LCDC instantly, all interrupt are cleared and disabled.

## 21.5 How to Use LCDC

Table21-5 lists the typical application scenarios of LCDC.

Table21-5 Typical application scenario of LCDC

| Interface | Data Mode                    | LCD GRAM | AmebaD FrameBuffer | Application     |
|-----------|------------------------------|----------|--------------------|-----------------|
| MCU       | I/O mode                     |          |                    | Static Display  |
|           | DMA Triggemode               |          |                    | Static Display  |
|           | DMA Automode (VSYNC/TE mode) |          |                    | dynamic Display |
| RGB       | DMA Automode (DE/HV mode)    |          |                    | dynamic Display |

### 21.5.1 MCU Interface

#### 21.5.1.1 I/O Mode

To use the LCDC MCU interface mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table21-4.

For example, in order to use PA[19] as LCDC pin, call the following function 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\_MCUStructInit(LCDC\_MCUInitTypeDef \* LCDC\_MCUInitStruct);
  - b) Change other parameters according to LCM datasheet, such as interface mode, Data/WR/RD/CS/RS pulse polarity, WR/RD pulse width.
- (3) Initialize the LCDC using the initialized 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 module.
- (6) After LCM is initialized, call LCDC\_MCUIOWriteCmd()/LCDC\_MCUIOWriteData()/LCDC\_MCUIOReadData() to send commands/write data to LCM or read data from LCM to drive LCD displaying.

#### 21.5.1.2 Trigger DMA Mode

To use the LCDC MCU interface trigger DMA mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table21-4.
- (2) Configure LCDC to work in MCU I/O mode, then send commands and parameters to LCM to initialize LCD. After that, users need to send command to inform LCM to start receiving data before sending frame data.
- (3) Initialize the LCDC\_MCUInitStruct variable.
  - a) Configure the LCDC\_MCUInitStruct parameter to Trigger DMA mode.  
LCDC\_MCUStructInit (LCDC\_MCUInitTypeDef \* LCDC\_MCUInitStruct);  
LCDC\_MCUInitStruct.LCDC\_MCUMode = LCD\_CU\_DMA\_MODE;  
LCDC\_MCUInitStruct.LCDC\_MCUDMAMode = LCD\_TRIGGER\_DMA\_MODE;
  - b) Change other parameters according to LCM datasheet, such as LCD width/height, Data/WR/RD/CS/RS pulse polarity, WR/RD pulse width.

- (4) Initialize the LCDC using the initialized structure (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_DMAImageBaseAddrConfig()`.
- (6) Enable LCDC interrupt using the function `LCDC_INTConfig()`, if needed.
- (7) Enable the LCDC using the function `LCDC_Cmd()`.
- (8) Trigger one frame transfer using the function `LCDC_MCUUDMATrigger()`, and update the frame buffer display after the transfer.

### 21.5.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 21-4.
- (2) Configure LCD to work in MCU I/O mode, then 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 * MCUIInitStruct);`  
`LCDC_MCUIInitStruct.CDC_MCUMode = LCDC_MCU_DMA_MODE;`  
`LCDC_MCUIInitStruct.CDC_MCUDMAMode = LCDC_AUTO_DMA_MODE;`  
`LCDC_MCUIInitStruct.CDC_MCUSyncMode = LCDC_MCU_SYNC_WITH_VSYNC;`
  - b) Change other parameters according to LCM datasheet VSYNC pulse polarity/pulse width/idle period, LCD width/height.
- (4) Initialize the LCDC using the initialized 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 the function `LCDC_DMAModeConfig()`.
  - b) Allocate DMA buffer and assign the address to LCDC using the function `LCDC_DMAImageBaseAddrConfig()`.
- (6) Enable the specified LCDC interrupt using the function `LCDC_INTConfig()`, if needed.
- (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.

### 21.5.1.4 TE Mode

To use the LCDC MCU interface TE mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 21-4.
- (2) Configure LCD to work in MCU I/O mode, then send commands and parameters to LCM in TE mode.
- (3) Initialize the `LCDC_MCUIInitStruct` variable.
  - a) Configure the `LCDC_MCUIInitStruct` parameter corresponding to VSYNC mode.  
`LCDC_MCUIStructInit (LCDC_MCUIInitTypeDef * MCUIInitStruct);`  
`LCDC_MCUIInitStruct.CDC_MCUMode = LCDC_MCU_DMA_MODE;`  
`LCDC_MCUIInitStruct.CDC_MCUDMAMode = LCDC_AUTO_DMA_MODE;`  
`LCDC_MCUIInitStruct.CDC_MCUSyncMode = LCDC_MCU_SYNC_WITH_TE;`
  - b) Change other parameters if needed, such as TE pulse polarity, TE Delay, LCD width/height.
- (4) Initialize the LCDC using the initialized 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 the function `LCDC_DMAModeConfig()`.
  - b) Allocate DMA buffer and assign the address to LCDC using the function `LCDC_DMAImageBaseAddrConfig()`.
- (6) Enable the specified LCDC interrupt using the function `LCDC_INTConfig()`, if needed.
- (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.

## 21.5.2 RGB Interface

### 21.5.2.1 DE Mode

To use the LCDC RGB interface DE mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 21-4.
- (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->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, HFP, HBP, HSW, refresh frequency, LCD width/height.
- (4) Initialize the LCDC using the initialized 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 the function LCDC\_DMAMImageBaseAddrConfig().
- (6) Enable the specified LCDC interrupt using the function LCDC\_INTConfig(), if needed.
- (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 the display.

### 21.5.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 21-4.
- (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, parallel I/F mode, refresh frequency.
- (4) Initialize the LCDC using the initialized 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 vflow mode and error data using the functions LCDC\_DMAUnderFlowModeConfig() and LCDC\_DMAUnderFlowModeConfig().
  - c) Allocate DMA buffer and assign the address to LCDC using the function LCDC\_DMAMImageBaseAddrConfig().
- (6) Enable the specified LCDC interrupt using the function LCDC\_INTConfig(), if needed.
- (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 the display.

## 21.5.3 LED Interface

To use the LCDC LED interface mode, the following steps are mandatory.

- (1) Configure the LCDC pinmux according to Table 21-4.
- (2) Initialize the LCDC\_RGBInitStruct variable.
  - a) Configure the LCDC\_LEDInitStruct parameter corresponding to LED interface 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 activation frequency, LED width/height.

- (3) Initialize the LCDC using the initialized structure in step (2).  
LCD\_CLEInit (LCD\_CTypeDef\* LCDCx, LCD\_CLEInitTypeDef \* LCD\_CLEInitStruct)
- (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 the function LCDC\_DMAMImageBaseAddrConfig().
- (5) Enable the specified LCDC interrupt using the function LCDC\_INTConfig(), if needed.
- (6) Enable the LCDC using the function LCD\_CLEInit.
- (7) The LCDC can transfer frame data to LED array board automatically according to the refresh frequency, and you can update buffer to change the display.

## 21.6 GUI

emWin is the embedded GUI solution that can be adapted to any size, either physical display, not dependent of the display controller. Making it a professional GUI for the embedded market, usable for multiple different scenarios.

Realtek has reached an emWin Pro Buyout Agreement with SEGGER. The LICENSE SOFTWARE, which is located in component\common\ui\emwin, is available in object code form for Realtek customers who have been authorized.

### 21.6.1 Authorization

In order to be authorized to use emWin software, you need to follow these steps:

- (1) Read [emWin\\_Software\\_License\\_Agreement.pdf](#) carefully under the part component\common\ui. The document is a binding, legal agreement between Realtek and you (either individual or legal entity). It explains the terms and conditions that you should accept and agree.
- (2) If you do not accept and agree this Agreement, do not unzip [emwin.zip](#) and do not use any of the LICENSE SOFTWARE if you do not accept [emWin\\_Software\\_License\\_Agreement.pdf](#)

### 21.6.2 emWin Software

After

| Directory    | Sub-directory | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| emWinLibrary | /             | Contains the basic contents in emWin PRO package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              | Config        | The files in this subdirectory are template configuration files for reference to adapt different SoC and LCD module. You should customize UIConf.c and LCDConf.c according to their devices. Details of these two files can be found <a href="#">Chapter 38 Configuration</a> <a href="#">M03001_emWin5.pdf</a> . For Ameba-D, we provide porting samples of EVB LCM with MCU or RGB I/F. The samples are located in component\common\ui\emwin\Sample\rt18721\Config. @ files to adapt to new LCM files in this subdirectory are used to adapt different LCD module and different scenarios. |
|              | Doc           | <a href="#">UM03001_emWin5.pdf</a> the User Guide and Reference Manual of emWin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              | GUI_X         | GUI_X_FreeRTOS is the configuration of the timing routines, the debugging routines and the interface routines                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|              | Include       | The header files of emWin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|              | Lib           | The object code of emWin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | Tool          | The available tools which are useful during UI development, such as Font Converter, GUIBuilder                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Sample       | /             | These are porting samples of Ameba-D driving EVB LCM.<br>MCU I/F LCM on EVB9488 TFT-LCD module (320*480, MCUT 8/F)<br>RGB I/F LCM on EVBXC043DTLN4TFT-LCD module (480*272, RGB 6 I/F)                                                                                                                                                                                                                                                                                                                                                                                                        |
| Third_Party  | /             | It contains the TrueType Font emWin which should be used if fonts need to load at run time. This is the adapted version of FreeType font library by David Turner, Robert Wilhelm and Werner Lemberg                                                                                                                                                                                                                                                                                                                                                                                          |

## 21.6.3 How to Adapt LCM

As mentioned above, we provide porting samples of Adapting EVB LCM component common\emwin\Sampl\rtI8721\Table 21-6 demonstrate how to customize configuration files to adapt LCM.

Table21-6 Customizing configuration files

| Configuration file      | Step                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Description                                                                                                                                                                                                                               | Note                                                                                                                                                                                                                    |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GUIConf.c               | (1) Modify the value of macro <code>NUMBYTES</code> to define the size of memory block.<br>(2) Define macro <code>PSRAM_BUF_USED</code> in LCDConf.h to place the memory block into PSRAM. Otherwise, undefine it to place memory block into SRAM.                                                                                                                                                                                                                | Provide emWin with the function <code>GUI_X_Config()</code> which is responsible for assigning a memory block to the memory management system.                                                                                            |                                                                                                                                                                                                                         |
| LCDConf_MCU_8bit_eval.c | (1) Set <code>XSIZE_PHY</code> and <code>YSIZE_PHY</code> to the horizontal and vertical resolution of LCM.<br>(2) Implement the functions illustrated in Table 21-7.<br><br>void lcd_mcu_write(int x0, int y0, int x1, int y1, void *buf, U32 color)<br>void lcd_mcu_read (int x0, int y0, int x1, int y1, void *buf)<br>void lcd_init(void)                                                                                                                     | Used for MCU I/F LCM<br>As an example, these functions are implemented in <code>Sampl\rtI8721\hal\hal_mcu_lcd.c</code> . You should modify this file according to the flow of Initialize, Read/Write pixel specified by datasheet of LCM. | The <code>LCDConf_MCU_8bit_eval.c</code> adopts GUI MCU driver porting by Realtek, and it applies to display controllers with indirect interface, such as MCU I/F LCM.                                                  |
| LCDConf_RGB_6bit_eval.c | (1) Set <code>XSIZE_PHY</code> and <code>YSIZE_PHY</code> to the horizontal and vertical resolution of LCM.<br>(2) Define macro <code>PSRAM_BUF_USED</code> in LCDConf.h to place the VRAM buffer into PSRAM. Otherwise, undefine it to place VRAM buffer into SRAM.<br>(3) Implement the functions illustrated in Table 21-8.<br><br>void lcd_init(unsigned int width, unsigned int height, unsigned int bufAddr)<br>void lcd_set_dma_addr(unsigned int bufAddr) | Used for RGB I/F LCM<br>As an example, these functions are implemented in <code>Sampl\rtI8721\hal\hal_rgb_lcd.c</code> . You should modify this file according to the timing parameters specified by datasheet of LCM.                    | The <code>LCDConf_RGB_6bit_eval.c</code> adopts GUI LIN driver provided by emWin package, and it applies to display controllers with linear video memory accessible via direct interface, such as RGB I/F LCM.          |
| LCDConf_SPI_eval.c      | (1) Set <code>XSIZE_PHY</code> and <code>YSIZE_PHY</code> to the horizontal and vertical resolution of LCM.<br>(2) Implement the functions illustrated in Table 21-9.<br><br>void lcd_spi_write(int x0, int y0, int x1, int y1, void *buf, U32 color)<br>void lcd_spiread (int x0, int y0, int x1, int y1, void *buf)<br>void lcd_init(void)                                                                                                                      | Used for SPI I/F LCM<br>As an example, these functions are implemented in <code>Sampl\rtI8721\hal\hal_spi_lcd.c</code> . You should modify this file according to the flow of Initialize, Read/Write pixel specified by datasheet of LCM. | <code>lcd_spi_read</code> function is not necessary.<br>The <code>LCDConf_SPI_eval.c</code> adopts GUI SPI driver porting by Realtek, and it applies to display controllers with direct interface, such as SPI I/F LCM. |

Table21-7 Functions for MCU I/F LCM

| Function     | lcd_mcu_write                                                                                                                                                                                                                                                                 | lcd_mcu_read                                                                                                                                                                                                                                                             | lcd_init                           |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Introduction | Writes pixels to LCD module.                                                                                                                                                                                                                                                  | Reads pixels from LCD module.                                                                                                                                                                                                                                            | Initialize LCD controller and LCM. |
| Parameters   | x0: the start column of area to be updated<br>y0: the start row of area to be updated<br>x1: the end column of area to be updated<br>y1: the end row of area to be updated<br>buf: pointer to a buffer which is used to store pixel data of the area defined by (x0,y0,x1,y1) | x0: the start column of area to be read<br>y0: the start row of area to be read<br>x1: the end column of area to be read<br>y1: the end row of area to be read<br>buf: pointer to a buffer which is used to store pixel data read from the area defined by (x0,y0,x1,y1) | N/A                                |

|        |                                                      |     |     |
|--------|------------------------------------------------------|-----|-----|
|        | color: If buf is NULL, fill the area with same color |     |     |
| Return | N/A                                                  | N/A | N/A |

Table 21-8 Functions for RGBI/F LCM

| Function     | Lcd_init                                                                                          | Lcd_set_dma_addr                                                                              |
|--------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| Introduction | Initialize LCD controller                                                                         | Set the address of VRAM. It is necessary when Multiple Buffer Virtual Screen function is used |
| Parameters   | width: horizontal resolution<br>height: vertical resolution<br>bufAddr: the start address of VRAM | bufAddr: the start address of VRAM                                                            |
| Return       | N/A                                                                                               | N/A                                                                                           |

Table 21-9 Functions for SPI/F LCM

| Function     | <code>Lcd_spiwrite</code>                                                                                                                                                                                                                                                                                                             | <code>Lcd_spiread</code>                                                                                                                                                                                                                                                 | <code>Lcd_init</code>              |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Introduction | Writes pixels to LCD module.                                                                                                                                                                                                                                                                                                          | Reads pixels from LCD module.                                                                                                                                                                                                                                            | Initialize LCD controller and LCM. |
| Parameters   | x0: the start column of area to be updated<br>y0: the start row of area to be updated<br>x1: the end column of area to be updated<br>y1: the end row of area to be updated<br>buf: pointer to a buffer which is used to store pixel data of the area defined by (x0,y0,x1,y1)<br>color: If buf is NULL, fill the area with same color | x0: the start column of area to be read<br>y0: the start row of area to be read<br>x1: the end column of area to be read<br>y1: the end row of area to be read<br>buf: pointer to a buffer which is used to store pixel data read from the area defined by (x0,y0,x1,y1) | N/A                                |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                   | N/A                                                                                                                                                                                                                                                                      | N/A                                |

## Note

To adapt the driver to a display controller supported currently users should

Refer to Chapter 33.7.26 GUIDRV\_Template103001 emWin5.pdf

Optimize some operation of GUIDRV\_Template.c to improve drawing speed

#### 21.6.4 How to Adapt Touch Panel

We provide porting samples of Andriod UI layer for common touch panel component. The following steps demonstrate how to customize configuration files to adapt to new panel.



| Function     | hal_touch_init            | hal_touch_measureX                      | hal_touch_measureY                      |
|--------------|---------------------------|-----------------------------------------|-----------------------------------------|
| Introduction | Initialize the touch pane | Measure the x coordinate of touch point | Measure the y coordinate of touch point |
| Parameters   | N/A                       | N/A                                     | N/A                                     |
| Return       | N/A                       | X coordinate of touch point             | Y coordinate of touch point             |

## 21.6.5 How to Use emWin SDK

To build and run emWin demo in SDK, you need to follow these steps:

- (1) Enable emWin compile  
KM4 make menuconfig MENUCONFIG FOR CHIP CONFIG GUI Config: Enable GUI and select emwin
- (2) Enable PSRAM if needed  
By default, the VRAM buffer, which is necessary for RGB8156bitLCD, is in PSRAM. So you should enable PSRAM by setting psram\_dev\_config.sram\_dev\_enable to TRUE in rtl8721dhp\_intfcfg.c.  
If you want to put the VRAM buffer in RAM instead of PSRAM, you need to modify LCDConf.h as follows:  

```
#undef PSRAM_BUF_USED
```
- (3) By default, the configuration files for I/F LCM (hal\_rgb\_lcd, LCDConf\_RGB\_6bit\_evb) is compiled.  
To use MCU I/F LCM, you should modify project\realtek\_amebaD\_va0\_example\GCC\RELEASE\project\hp\asd\make\ui\emwin\Sample\Makefile to compile hal\_mcu\_lcd and LCDConf\_MCU\_8bit\_evb instead.
- (4) Add your own code run emWin demo code.  
The emWin demo code is located in project\realtek\_amebaD\_va0\_example\example\_sources\LCD\GUI\_demo\emWin. The ReadMe.txt in each demo folder demonstrates how to use it.

## 22 PSRAM

Pseudo Static Random Access Memory (PSRAM) for high speed transmission of data stream is suitable for audio codec. RTL8721D uses PSRAM controller to communicate with PSRAM. PSRAM M4 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 powdown mode

### 22.1 Throughput

PSRAM supports direct access and DMA access.

Table 221 PSRAM throughput

| Access mode   |           | Write      |                                                  | Read       |                                |
|---------------|-----------|------------|--------------------------------------------------|------------|--------------------------------|
|               |           | Theory     | Test                                             | Theory     | Test                           |
| Direct Access | Cache off | 200Mbps    | <160Mbps                                         | 177.78Mbps | <(32)(180ns+360ns) / 59.24Mbps |
|               | Cache on  | 200Mbps    | 160Mbps (CS high for 40ns between two transmits) | 556.52Mbps | <(32*8)(460ns+360ns) = 312Mbps |
| DMA           |           | 731.43Mbps | 711.11Mbps                                       | 721.13Mbps | 589.18Mbps                     |

Note:

When Cache off:

Read or write operation only access 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 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 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 data to CPU needs 126ns

DMA sets burst length to 128 bytes and disable cache.

For DMA write, DMA moves data to PSRAM FIFO and PSRAM controller writing FIFO data to PSRAM slave can simultaneously so the interval between two burst operations is small.

For DMA read, similar operation as DMA write is not supported, so the interval between operations is large.

The test data above takes variable initial latency and 3 clocks initial latency for example.

Table 222 PSRAM throughput theoretical calculation

| Item                                                 | Writing 32bits              | Reading 32bits               |
|------------------------------------------------------|-----------------------------|------------------------------|
| Header + delay                                       | [3 + (3)] * 20ns = 100ns    | [3 + (3)] * 20ns = 100ns     |
| Data transmit period                                 | 2 * 20ns = 40ns             | 16 * 20ns = 320ns            |
| Hardware hold                                        | 1 * 20ns = 20ns             | 2 * 20ns = 40ns              |
| Total without considering instruction execution time | 100ns + 40ns + 20ns = 160ns | 100ns + 320ns + 40ns = 460ns |
| Throughput theoretical value                         | 32/160ns = 200Mbps          | (32*8)/460ns = 556.52Mbps    |

## 22.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 223 PSRAM power management

| Retention | Options                                       | Power Consumption (uA) | Comment                                                           |
|-----------|-----------------------------------------------|------------------------|-------------------------------------------------------------------|
| No        | KM4 PG<br>PSRAM_LDOFF                         | <30                    | PSRAM cannot keep memory retention applications are not supported |
| Yes       | KM4 CG<br>PSRAM_LDON<br>PSRAM Half Sleep mode | About 325              |                                                                   |

## 22.3 How to Use PSRAM

### 22.3.1 Initializing PSRAM

Before accessing PSRAM, you should enable PSRAM power, initialize PSRAM controller and PSRAM slave, synchronize the related parameters.

In SDK, you should set psram\_dev\_enable to rti8721dhp\_intfcfg if the chip works in the environment with large fluctuations in temperature, you should set psram\_dev\_cal\_enable to enable calibration function if you want to keep the PSRAM and save power. In half sleep mode, you should also 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
};
```

### 22.3.2 Adding BSS/TEXT/DATA Section into PSRAM Region

Table 224 lists how to add a BSS/TEXT/DATA section into PSRAM region

Table 224 Add a BSS/TEXT/DATA section into PSRAM region

| Section | Description                                                                                             | Operation                                                                                                                                          |
|---------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| BSS     | To put BSS section in PSRAM, add PSRAM_BSS_SECTION before the buffer definition                         | <code>PSRAM_BSS_SECTION u32 PSRAM_Testbuf[1024];</code>                                                                                            |
| TEXT    | To put TEXT section in PSRAM, add PSRAM_TEXT_SECTION before the function definition                     | <code>PSRAM_TEXT_SECTION VOID Test_Function(VOID) {     u32 i = 0;     for (i = 0; i &lt; 10; i++) {         DBG_8195A("test\r\n");     } }</code> |
| DATA    | To put DATA section in PSRAM, add PSRAM_DATA_SECTION or PSRAM_RODATA_SECTION before the data definition | <code>PSRAM_DATA_SECTION u8 Test_Data = FALSE;</code>                                                                                              |

After the operation, build KM4 project.

### 22.3.3 Allocating Heap from PSRAM

Before allocating heap, initializing PSRAM must be completed, then follow the steps below.

(1) Confirm the heap size you want Psram\_reserve

```
#define configTOTAL_PSRAM_HEAP_SIZE (0x200000)
```

(2) Use void \*Psram\_reserve\_malloc(int size) to allocate a heap or 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\_BSS\_SECTION will be cleared only in the void app\_init\_psram(void \*rtl8721dhp\_app\_start.c)

## 22.4 PSRAM# WriteBack Policy Change Note

### 22.4.1 Cache Policy Change

To prevent PSRAM charge leak from frequent access, the cache policy is changing. This change can enhance memory access performance and efficiency.

### 22.4.2 Scope

All of chips stacking PSRAM inside on Ameba-D series: RTL8721CSM, RTL8722CSM, RTL8721DM, and RTL8722DM

### 22.4.3 Notice

On Ameba-D, the cache policy is changing. It is recommended to use aligned 32 bytes for multiple access by different sources (e.g. serial ports and peripherals).

Follow the described instructions on the following paragraphs while manipulating PSRAM application and heap usage.

As cache line of Ameba-D cache is 32 bytes, and the operations are all based on cache line. So the buffer size and buffer starting address should be 32 bytes alignment to avoid synchronization issues.

#### 22.4.3.1 DMA Buffer Definition

When using Psram\_reserve\_malloc to allocate a space for DMA buffer, our Ameba-D has aligned 32 bytes of the address of the memory allocated. This approach is recommended to define DMA buffer.

When allocating a space for DMA buffer from PSRAM array, it is recommended to use aligned 32 bytes alignment.

```
char rx_buf[RX_BUF_SIZE] __attribute__((aligned(32));
```

#### 22.4.3.2 DMA Operation

The following steps should be added when executing DMA Rx/Tx.

| Operation | Step                                                                                                                                                                                                                              |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA Rx    | <ol style="list-style-type: none"> <li>(1) Prepare Rx Buffer</li> <li>(2) Do DCache_CleanInvalidation() to avoid cache data write back during DMA Rx</li> <li>(3) Do DMARx config</li> <li>(4) Trigger DMARx interrupt</li> </ol> |

|        |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | <p>(5) Do DCache_Invalidate in Rx Done Handler to clean old data (take example_sources/USI_UART/raw/usi_uart_stream_dma/srd/exampleuart_recv_string_dma_rx Done Interrupt Handler)</p> <pre><code>void uart_recv_string_done(void) {     ...     DCache_Invalidate((u32)rx_buf, SRX_BUF_SZ); /*!!!To solve the cache consistency problem, DMA mode need it!!!*/     dma_free();     rx_done += 1; }</code></pre> <p>(6) CPU reads Rx Buffer</p> |
| DMA Tx | <p>(1) CPU prepares Tx buffer data</p> <p>(2) Do DCache_CleanInvalidate before Tx buffer to synchronize the data</p> <p>(3) Do DMA tx config</p> <p>(4) Trigger DMA tx interrupt</p>                                                                                                                                                                                                                                                            |

In SDK, only the example of one time xxx\_GDMA\_Init one time transmission is illustrated. This step is included in xxx\_GDMA\_Init by default.

If you need multitime DMA TRx with only one time xxx\_GDMA\_Init, DCache\_CleanInvalidate should be called every time before DMA transmission starts.

|                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre><code>BOOL USI_UARTTXGDMA_Init(     ...     u8 USIIndex,     GDMA_InitTypeDef *GDMA_InitStruct,     void *CallbackData,     IRQ_FUN CallbackFunc,     u8 *pTxBuf,     int TxCount ) {     ...     u8 GdmaChnl;     ...      assert_param(GDMA_InitStruct != NULL);      DCache_CleanInvalidate((u32)pTxBuf, TxCount); }</code></pre> | <pre><code>BOOL USI_UARTRXGDMA_Init(     ...     u8 USIIndex,     GDMA_InitTypeDef *GDMA_InitStruct,     void *CallbackData,     IRQ_FUN CallbackFunc,     u8 *pRxBuf,     int RxCount ) {     ...     u8 GdmaChnl;     USI_TypeDef *pUSIx;     ...      assert_param(GDMA_InitStruct != NULL);      DCache_CleanInvalidate((u32)pRxBuf, RxCount); }</code></pre> |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 22.4.3.3 Heap Usage

If you want to allocate heap in PSRAM, Psram\_reserve\_malloc(int size) should be used to allocate a heap for the starting address 32 bytes alignment. It returns a pointer to the starting address of the allocation. void Psram\_reserve\_free(void \*mem) is used to free the allocation.

# 23 MPU and Cache

## 23.1 Functional description

### 23.1.1 MPU

Memory Protection Unit (MPU) is used to provide Hardware Protection by Software. ~~the provider~~ ~~cpu\_region\_config~~ structure to include ~~the~~ region memory attribute. Default attribute of all KMO & KM4 SRAM ~~attribute~~

Table231 shows member variables of ~~the~~ ~~cpu\_region\_config~~ structure

Table231 ~~mpu\_region\_config~~ structure

| MemberVariableName | Type     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| region_base        | uint32_t | MPU region base, 32 bytes aligned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| region_size        | uint32_t | MPU region size, 32 bytes aligned                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| xn                 | uint8_t  | Execute Never attribute<br>MPU_EXEC_ALLOW: allows program execution in this region<br>MPU_EXEC_NEVER: Does not allow program execution in this region                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ap                 | uint8_t  | Access permissions<br>MPU_PRIV_RW: Read/write by privileged code only<br>MPU_UN_PRIV_RW: Read/write by any privilege level<br>MPU_PRIV_R: Read only by privileged code only<br>MPU_PRIV_W: Read only by any privilege level                                                                                                                                                                                                                                                                                                                                                                                                |
| sh                 | uint8_t  | Shareability for Normal memory<br>MPU_NON_SHAREABLE: Non-shareable<br>MPU_OUT_SHAREABLE: Outer shareable<br>MPU_INR_SHAREABLE: Inner shareable                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| attr_idx           | uint8_t  | 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:<br>0: MPU_MEM_ATTR_IDX_NOCACHE: memory attribute of Normal memory with cacheable<br>1: MPU_MEM_ATTR_IDX_WT_T: memory attribute of Normal memory with writethrough transient allocation<br>2: MPU_MEM_ATTR_IDX_WB_T: memory attribute of Normal memory with writeback transient allocation<br>3~7: MPU_MEM_ATTR_IDX_DEVICE: memory attribute of Device memory with non-gathering, no recording, no early Write Acknowledge |

Table232 shows how to set a MPU region

Table232 How to set a MPU region

| Steps                                 | Description                                                                                                     |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| New variable and structure            | Variable to store Memory index<br>Structure <code>mpu_region_config</code> to store the region memory attribute |
| Allocate a free MPU entry             | Call <code>mpu_entry_all()</code>                                                                               |
| Set region memory attribute           | Set structure <code>regionmemoryattribute</code>                                                                |
| Configure MPU region memory attribute | Call <code>mpu_region_cfg()</code>                                                                              |

### 23.1.2 Cache

Cache is used to improve CPU performance of data access. Ameba-D Cache supports Enable/Disable, Flush and Clean Operations. Table 233 lists.

Table23.3 Enable/Disable,Flush and Clean operations supported by Cache

| Operation         | Description                                                                                                                                                       | I-Cache | D-Cache |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|
| Enable/Disable    | Enable or Disable Cache function                                                                                                                                  |         |         |
| Flush(Invalidate) | Flush Cache<br>D-Cache can be flushed by address<br>Can be used after DMA Rx, and CPU DMA data from DMA buffer to D-Cache                                         |         |         |
| Clean             | Clean D-Cache<br>D-Cache will be write back to memory<br>D-Cache can be cleaned by address<br>Can be used before DMA Tx, after CPU write to DMA buffer to D-Cache |         |         |

## 23.2 MPU API

### 23.2.1 mpu\_init

| Items        | Description                                             |
|--------------|---------------------------------------------------------|
| Introduction | Initialize MPU region memory attribute to typical value |
| Parameters   | N/A                                                     |
| Return       | N/A                                                     |

### 23.2.2 mpu\_set\_mem\_attr

| Items        | Description                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------|
| Introduction | Change MPU region memory attribute                                                               |
| Parameters   | attr_id: region memory attribute index, which can be 0~7.<br>mem_attr: region memory attributes. |
| Return       | N/A                                                                                              |

### 23.2.3 mpu\_region\_cfg

| Items        | Description                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Configure MPU region memory attribute                                                                                                       |
| Parameters   | region_num<br>KMO: 0~3<br>KM4_NS: 0~7<br>KM4_S: 0~3<br>pmpu_cfg: pointer to <code>mpu_region_cfg</code> structure which has been configured |
| Return       | N/A                                                                                                                                         |

### 23.2.4 mpu\_entry\_free

| Items        | Description                                          |
|--------------|------------------------------------------------------|
| Introduction | Free MPU entry                                       |
| Parameters   | entry_index<br>KMO: 0~3<br>KM4_NS: 0~7<br>KM4_S: 0~3 |
| Return       | N/A                                                  |

## 23.2.5mpu\_entry\_alloc

| Items        | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Introduction | Allocate a free MPUentry                                            |
| Parameters   | N/A                                                                 |
| Return       | MPUentry index<br>KM0: 0~3<br>KM4_NS: 0~7<br>KM4_S: 0~3<br>Fail: -1 |

## 23.3 CacheAPIs

### 23.3.1ICache\_Enable

| Items        | Description    |
|--------------|----------------|
| Introduction | Enable I-Cache |
| Parameters   | N/A            |
| Return       | N/A            |

### 23.3.2ICache\_Disable

| Items        | Description     |
|--------------|-----------------|
| Introduction | Disable I-Cache |
| Parameters   | N/A             |
| Return       | N/A             |

### 23.3.3ICache\_Invalidate

| Items        | Description        |
|--------------|--------------------|
| Introduction | Invalidate I-Cache |
| Parameters   | N/A                |
| Return       | N/A                |

### 23.3.4DCache\_IsEnabled

| Items        | Description                                       |
|--------------|---------------------------------------------------|
| Introduction | Check D-Cache enabled or not                      |
| Parameters   | N/A                                               |
| Return       | D-Cache enable status:<br>1: Enable<br>0: Disable |

### 23.3.5DCache\_Enable

| Items        | Description    |
|--------------|----------------|
| Introduction | Enable D-Cache |
| Parameters   | N/A            |
| Return       | N/A            |

### 23.3.6 DCache\_Disable

| Items        | Description     |
|--------------|-----------------|
| Introduction | Disable D-Cache |
| Parameters   | N/A             |
| Return       | N/A             |

### 23.3.7 DCache\_Invalidate

| Items        | Description                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------|
| Introduction | Invalidate DCache by address                                                                          |
| Parameters   | AddressInvalidate address (aligned to 32e boundary)<br>BytesSize of memory block (in number of bytes) |
| Return       | N/A                                                                                                   |

### 23.3.8 DCache\_Clean

| Items        | Description                                                                                                                                                |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clean DCache by address                                                                                                                                    |
| Parameters   | AddressClean address (aligned to 32e boundary)<br>Bytesize of memory block (in number of bytes)<br>Note Addressset 0xFFFFFFFF is used to clear all D-Cache |
| Return       | N/A                                                                                                                                                        |

### 23.3.9 DCache\_CleanInvalidate

| Items        | Description                                                                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clean and invalidate DCache by address                                                                                                                                         |
| Parameters   | AddressClean and invalidate address (aligned to 32e boundary)<br>Bytesize of memory block (in number of bytes)<br>Note Addressset 0xFFFFFFFF is used to clean and flush DCache |
| Return       | N/A                                                                                                                                                                            |

## 23.4 How to Define a Noncacheable Data Buffer

To define a data buffer with non-cacheable attribute, you should add `SRAM_NOCACHE_DATA_SECTION` before the buffer definition.

```
SRAM_NOCACHE_DATA_SECTION u8 noncache_buffer[DATA_BUFFER_SIZE];
```

# 24 Audio Codec Control Guide

## 24.1 Audio Codec

Ameba-D audio codec (ADC) 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-ended or differential.

Ameba-D audio codec integrates a pop filter circuit for audible pop noise cancellation, a bias circuit for MIC power supply and programmable MIC boost ability.

Ameba-D audio codec transmits data to or receives playback data from platform through SPI interface or 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 up to 384kHz sampling frequency.

### 24.1.1 Diagram

The diagram of ADC is shown in Fig 241.



Fig 241 Audio codec diagram

## 24.1.2 Features

Mono and stereo channel  
 8-bit, 16bit and 24bit sample bits  
 8k, 16k, 32k, 48k, 44.1k, 48k and 88.2k sample rate  
 I2S, left justify, PCM mode A, PCM mode B, PCM mode C, ACM mode N data format  
 Antipop function to reduce audible pop  
 Programmable MIC boost gain  
 Programmable gain in ADC and DAC path  
 Three lineout output modes: capless, differential and single  
 Three input ways: line, AMICin and DMICin

## 24.1.3 Application Mode

Audio codec supports three input ways, AMICin and DMICin, but only supports one output way: digital.

### 24.1.3.1 Lineout

Lineout has no amplifier to amplify output voice. It supports three output modes: capless, differential and single. User can select the wanted mode by setting the related registers.

#### Lineout cap-less mode

In this mode, the end of L/R channel outputs common voltage, while end drives the available analog audio signal. When earphone inserts into jack, the ground must short to output for audio signal. That is why the ground is called virtual ground.



Fig242 Capless mode connection with headphone jack

#### Lineout differential mode

In this mode, both end and end drive the available analog audio signal. User should select the differential jack and earphone accordingly.



Fig243 Differential mode connection with headphone jack

**Line-out single-ended mode**  
 In this mode, board circuit designers often replace a capacitor to the output path for analog audio signal pickup. No Nend output is required.



Fig24-4 Singleended mode connection with headphone jack

#### 24.1.3.2 Line-in

Line-in has no preamplifier its input signal often has low output power it often connects to the audio output equipment such as electric guitar electronic organ and synthesizer

Connect the left channel of line signal to AUX\_L, and the right channel to AUX\_R accordingly.



Fig245 Line-in mode connection

#### 24.1.3.3 AMIC-in

Analog microphone(AMIC) records audio data, it has no preamplifier its input signal often has low output power AMIC-in supports differential mode and singlended mode

**AMIC-in single-ended mode**  
 Connect MIC\_P with single-ended analog microphone, while MICBIAS provides the microphone bias voltage.



Fig246 AMICin singleended mode connection

**AMIC-in differential mode**  
 Connect MIC\_P/MIC\_N with differential analog microphone, while MICBIAS provides the microphone bias voltage.



Fig247 AMICin differential mode connection

#### 24.1.3.4 DMICin

Digital microphone(DMIC) records audio data, it is integrated with ADC internal and can directly output digital signal. DMICin supports mono mode and stereo mode.

**DMICin mono mode**  
Tie the L/R of digital microphone to ground or VDD if only one microphone is placed.



Fig248 DMICin mono mode connection

**DMICin stereo mode**  
Tie the L/R of two digital microphones to ground and VDD respectively if stereo microphone is needed. The two microphones share the DMIC\_DATA according to rising/falling edge.



Fig249 DMICin stereo mode connection

## 24.2 Audio Codec Controller

Ameba-D audio codec controller (ACC) is the bridge between host audio buffers and audio codec modules for audio codec input/output control.

Ameba-D audio codec controller uses GDMA to move data, transfers audio data to or from audio codec via SPORT and configure audio codec module via SI.

The diagram of ACC is shown in Fig2410



Fig2410 Audio code controller diagram

### 24.2.1 Features

- Mono and stereo channel
- 8-bit, 16bit and 24bit sample bits
- I2S, left justify, PCM mode A, PCM mode B, PCM mode N data format
- Mandatory or optional sample rate which audio codec modules support
- GDMA for data moving
- Data loopback between SDI and SDO

### 24.2.2 Control Interface

There are two control interfaces: SPORT interface and SI interface

#### SPORT interface

Audio codec transfers audio data via SPORT interface sequentially according to settings. It supports multiple data format, such as I2S, left justify, PCM mode A, PCM mode B, PCM mode N.

#### SI interface

Audio codec needs to configure the related analog and digital parameters before transferring data. SI interface is used to figure codec parameters. It can read or write codec register.

For more details about AC and ACC refer to UMO40 Ameba-D User Manual.

## 24.3 Audio PLL

The ACC clock architecture is shown in Fig2411.



Fig2411 ACC clock architecture

### 24.3.1 Diagram

The ACC clock diagram is illustrated Fig2412



Fig2412 ACC clock diagram

Where  $f_i$  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_i$  is  $f_i/2^6$ .

The relationship between crystal clock and  $f_i$  is listed in Table 241.

Table 241 Relationship between crystal clock<sub>i</sub> and  $f_i$ 

| Crystal Clock (MHz) | $f_i$ (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 |

## 24.3.2 Operation Mode

### 24.3.2.1 Auto Mode

In auto mode, PLL circuit automatically sets the parameters (div.N, fo.N, fo.f, etc.) to output clock with the ~~196.608MHz~~ frequency (=98.304MHz) offered by PLL while 180.6336MHz (=45.1584MHz x 4) by PCM PLL.

### 24.3.2.2 Manual Mode

If fine tuning Pclock is required, users could switch the PCM PLL to manual mode. In this mode, users could control the output frequency of SI PLL max 100ppm around 196.608MHz or PCM PLL 100ppm around 180.6336MHz by calling the corresponding APIs. As the adjusted step of  $\frac{f_{in}}{2^6}$  equals to  $\frac{1}{2^{16}}$ ,  $f_{in}$  decides the exact ppm per step ( $\frac{1}{2^{16}} \times 196.608$  or  $\frac{1}{2^{16}} \times 180.6336$ ).

The relationship between  $f_{in}$  and ppm per step is listed in Table 242.

Table 242 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             |

## 24.4 Audio Codec APIs

### 24.4.1 PLL APIs

| API               | Introduction                                                                  |
|-------------------|-------------------------------------------------------------------------------|
| <PLL_Div>         | Divider to generate 256*fs or 128*fs clock                                    |
| <PLL_Sel>         | Selects PLL or PCM PLL                                                        |
| <PLL_I2S_Set>     | Enables or disables I <sup>2</sup> S PLL                                      |
| <PLL_PCM_Set>     | Enables or disables PCM PLL                                                   |
| <PLL_I2S_ClkTune> | Tunes I <sup>2</sup> S PLL output faster or slower, or resets it to auto mode |

|                   |                                                         |
|-------------------|---------------------------------------------------------|
| <PLL_PCM_ClkTune> | Tunes PCM PLL output faster or slower, or reset to mode |
|-------------------|---------------------------------------------------------|

#### 24.4.1.1 PLL\_Div

| Parameter | Type | Introduction                                |
|-----------|------|---------------------------------------------|
| <div>     | u32  | Divider to generate 256*fs or 128*fs clock. |

#### 24.4.1.2 PLL\_Sel

| Parameter | Type | Introduction                                                                |
|-----------|------|-----------------------------------------------------------------------------|
| <sel>     | u32  | Selects \$ PLL if fs=8/16/32/48/96kHz<br>Selects PCM PLL if fs=44.1/88.2kHz |

#### 24.4.1.3 PLL\_I2S\_Set

| Parameter   | Type | Introduction               |
|-------------|------|----------------------------|
| <new_state> | u32  | Enables or disables \$ PLL |

#### 24.4.1.4 PLL\_PCM\_Set

| Parameter     | Type | Introduction                |
|---------------|------|-----------------------------|
| < new_state > | u32  | Enables or disables PCM PLL |

#### 24.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 |

#### 24.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 |

### 24.4.2SPORT 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 <code>parSPInitStruct</code> |
| <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_SetMstereo>  | 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                                                       |

#### 24.4.2.1 AUDIO\_SP\_StructInit

Fill each SP\_StructInit member with its default value

| Parameter      | Type            | Introduction                                                                                             |
|----------------|-----------------|----------------------------------------------------------------------------------------------------------|
| <SP_InitStruct | SP_InitTypeDef* | SP_InitTypeDef structure that contains configuration information for the specific audio SPORT peripheral |

#### 24.4.2.2 AUDIO\_SP\_Init

Initializes the audio SPORT registers according to the specified 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 configuration information for the specific audio SPORT peripheral |

#### 24.4.2.3 AUDIO\_SP\_TxStart

Start or stop SPORT Tx path.

If playing with audio code it starts 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   |

#### 24.4.2.4 AUDIO\_SP\_RxStart

Start or stop SPORT Rx path.

If recording with audio code it starts 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   |

#### 24.4.2.5 AUDIO\_SP\_TdmaCmd

Enable or disable SPORT T DMA request.

If Tx DMA request is not enabled, you 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 DMA request |

#### 24.4.2.6 AUDIO\_SP\_RdmaCmd

Enable or disable SPORT Rx DMA request.

If Rx DMA request is not enabled, you should start Rx when GDMA complete every time

| Parameter  | Type                 | Introduction                                      |
|------------|----------------------|---------------------------------------------------|
| <SPORTx>   | AUDIO_SPORT_TypeDef* | The base address of audioSPORT peripheral         |
| <NewState> | u32                  | State(enable or disable) of the SPORT DMA request |

#### 24.4.2.7 AUDIO\_SP\_SetWordLen

Sets the audioSPORT word length.

| Parameter    | Type                 | Introduction                              |
|--------------|----------------------|-------------------------------------------|
| <SPORTx>     | AUDIO_SPORT_TypeDef* | The base address of audioSPORT peripheral |
| <SP_WordLen> | u32                  | The value of word length                  |

#### 24.4.2.8 AUDIO\_SP\_GetWordLen

Gets the audioSPORT word length

| Parameter | Type                 | Introduction                              |
|-----------|----------------------|-------------------------------------------|
| <SPORTx>  | AUDIO_SPORT_TypeDef* | The base address of audioSPORT peripheral |

#### 24.4.2.9 AUDIO\_SP\_SetMonoStereo

Sets the audioSPORT channel number

SUPPORTS stereo channel and mono channel.

| Parameter       | Type                 | Introduction                              |
|-----------------|----------------------|-------------------------------------------|
| <SPORTx>        | AUDIO_SPORT_TypeDef* | The base address of audioSPORT peripheral |
| <SP_MonoStereo> | u32                  | Mono or stereo channel                    |

#### 24.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 configuration information for the GDMA peripheral |
| <CallbackData>    | void *             | GDMA callback data                                                                         |
| <CallbackFun&>    | IRQ_FUN            | GDMA callback function                                                                     |
| <pTxData>         | u8 *               | Tx buffer that stores data                                                                 |
| <Length>          | u32                | Tx data length                                                                             |

#### 24.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                                                                             |
| <CallbackFun&>    | IRQ_FUN            | GDMA callback function                                                                         |
| <pRxData>         | u8 *               | Rx buffer that stores received data                                                            |

|          |     |                |
|----------|-----|----------------|
| <Length> | u32 | Rx data length |
|----------|-----|----------------|

## 24.4.3 SI API

SI APIs are used to read and write codec register.

| API                 | Introduction                                                    |
|---------------------|-----------------------------------------------------------------|
| <AUDIO_SI_Cmd>      | Enables or disables the specified SI peripheral                 |
| <AUDIO_SI_WriteReg> | SI writes codec register                                        |
| <AUDIO_SI_ReadReg>  | SI reads codec register                                         |
| <AUDIO_SI_ClkCmd>   | Turns on or turns off the clock of register bank of audio codec |

### 24.4.3.1 AUDIO\_SI\_Cmd

Enables or disables the specified SI peripheral.

| Parameter   | Type | Introduction                   |
|-------------|------|--------------------------------|
| <new_state> | u8   | New state of the SI peripheral |

### 24.4.3.2 AUDIO\_SI\_WriteReg

Uses SI interface to write codec register

| Parameter | Type | Introduction                       |
|-----------|------|------------------------------------|
| <address> | u32  | Codec register address             |
| <data>    | u32  | Data value written to the register |

### 24.4.3.3 AUDIO\_SI\_ReadReg

Uses SI interface to read codec register

| Parameter | Type | Introduction           |
|-----------|------|------------------------|
| <address> | u32  | Codec register address |

### 24.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 |

## 24.4.4 Codec API

| API                | Introduction                                                   |
|--------------------|----------------------------------------------------------------|
| <CODEC_Init>       | Initializes codec peripheral according to the application mode |
| <CODEC_SetVolume>  | Sets codec volume by controlling mono DAC channel gain         |
| <CODEC_GetVolume>  | Gets codec mono 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 | Set MIC_BIAS output voltage      |
| <CODEC_MuteRecord | Mutes or unmutes per AD channel  |
| <CODEC_MutePlay   | Mutes or unmutes per DA channel. |
| <CODEC_DelInit    | De-initializes codec peripheral  |

#### 24.4.4.1 CODEC\_Init

Initializes codec peripheral according to the 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_INAPP_LINE_OUT |

#### 24.4.4.2 CODEC\_SetVolume

Sets codec volume by controlling mon DAC channel gain.

| Parameter | Type | Introduction                                                                              |
|-----------|------|-------------------------------------------------------------------------------------------|
| <vol_lch> | u8   | Codec mon DAC left channel VOLgain control(0.375dB/step)<br>8'hAF: 0dB<br>8'h00:65.625dB  |
| <vol_rch> | u8   | Codec mon DAC right channel VOLgain control(0.375dB/step)<br>8'hAF: 0dB<br>8'h00:65.625dB |

#### 24.4.4.3 CODEC\_GetVolume

Gets codec mon DAC channel gain control.

| Parameter | Type  | Introduction                                                 |
|-----------|-------|--------------------------------------------------------------|
| <vol>     | u16 ^ | Mon DAC channel VOLgain(high 8 bits RGain, low 8 bits LGain) |

#### 24.4.4.4 CODEC\_SetSr

Sets codec ADC and DAC sample rate.

| Parameter     | Type | Introduction                  |
|---------------|------|-------------------------------|
| <sample_rate> | u32  | Codec ADC and DAC sample rate |

#### 24.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 |

#### 24.4.4.6 CODEC\_SetAmicBst

Sets codec AMIC boost.

| Parameter       | Type | Introduction                  |
|-----------------|------|-------------------------------|
| <amic_bst_left  | u32  | AMIC left channel boost gain  |
| <amic_bst_right | u32  | AMIC right channel boost gain |

#### 24.4.4.7 CODEC\_SetMicBst

Sets codecMIC boost.

| Parameter       | Type | Introduction                  |
|-----------------|------|-------------------------------|
| <dmic_bst_left  | u32  | DMIC left channel boost gain  |
| <dmic_bst_right | u32  | DMIC right channel boost gain |

#### 24.4.4.8 CODEC\_SetMicBias

Sets MIC\_BIAS output voltage

| Parameter | Type | Introduction                    |
|-----------|------|---------------------------------|
| <mic_bias | u8   | Microphone bias voltage setting |

#### 24.4.4.9 CODEC\_MuteRecord

Mutes or unmutes per AD channel.

| Parameter | Type | Introduction               |
|-----------|------|----------------------------|
| <mute_lch | u32  | Mutes for left AD channel  |
| <mute_rch | u32  | Mutes for right AD channel |

#### 24.4.4.10 CODEC\_MutePlay

Mutes or unmutes per DA channel.

| Parameter | Type | Introduction               |
|-----------|------|----------------------------|
| <mute_lch | u32  | Mutes for left DA channel  |
| <mute_rch | u32  | Mutes for right DA channel |

#### 24.4.4.11 CODEC\_DelInit

De-initializes codec peripheral.

| Parameter    | Type | Introduction         |
|--------------|------|----------------------|
| <application | u32  | Codecappliation mode |

### 24.5 How to Use AC APIs

#### 24.5.1 Audio Play

To play the audio data through audio codec, follow the steps below:

- (1) Open audio codec clock and function

PLlx\_Set (0, ENABLE) is 0 or 1)

RCC\_PeriphClockCmd (APBPeriph\_AUDIOC, APBPeriph\_AUDIOCK, ENABLE);

- RCC\_PeriphClockCmd (APBPeriph\_SPORT, APBPeriph\_SPORT\_CLOCK, ENABLE);  
(2) Enable pin for audio codec function  
PAD\_CMD (PinName, DISABLE)  
(3) Initialize codec with desired parameters  
CODEC\_InitSampleRate, WordLen, MonoStereo, Application (Application is APP\_LINE\_OUT)  
(4) If you need to change codec volume, use  
CODEC\_SetVolume(vol\_lch, vol\_rch);  
(5) If you want to adjust microphone input voltage  
CODEC\_SetMicBias(mic\_bias);  
(6) Fill the SPORT desired parameters  
AUDIO\_SP\_InitStruct (SP\_InitStruct)  
(7) Configure audio SPORT with the corresponding configuration  
AUDIO\_SP\_Init (AUDIO\_SP\_DEV, &SP\_InitStruct)  
(8) Start Tx path  
AUDIO\_SP\_TdmaCmd (AUDIO\_SPORT\_DEV, ENABLE);  
AUDIO\_SP\_TxStart (AUDIO\_SPORT\_DEV, ENABLE);  
(9) Activate GDMA Rx Tx data  
AUDIO\_SP\_TXGDMA\_Init (Index, &GDMA\_InitStruct, CallbackData, CallbackFunc, TxData, Length)

## 24.5.2 Audio Record

To record the audio data through audio codec, follow the steps below:

- (1) Open audio codec clock and function  
PLIx\_Set (0, ENABLE); 0 is 0 or 1  
RCC\_PeriphClockCmd (APBPeriph\_AUDIOC, APBPeriph\_AUDIOC\_CLOCK, ENABLE);  
RCC\_PeriphClockCmd (APBPeriph\_SPORT, APBPeriph\_SPORT\_CLOCK, ENABLE);  
(2) Enable pin for audio codec function  
PAD\_CMD (PinName, DISABLE)  
(3) Initialize codec with desired parameters  
CODEC\_InitSampleRate, WordLen, MonoStereo, Application;  
Application can select APP\_AMIC\_IN for analog microphone, select APP\_DMIC\_IN for digital microphone or select APP\_LINE\_IN  
(4) If codec needs to change volume, use  
CODEC\_SetVolume(vol\_lch, vol\_rch);  
(5) If codec needs to change ADC gain, use  
CODEC\_SetAdcGain(ad\_gain\_left, ad\_gain\_right);  
(6) Fill the desired parameters  
AUDIO\_SP\_InitStruct (SP\_InitStruct)  
(7) Configure audio SPORT with the corresponding configuration  
AUDIO\_SP\_Init (AUDIO\_SP\_DEV, &SP\_InitStruct)  
(8) Start Rx path  
AUDIO\_SPORT\_RdmaCmd (AUDIO\_SPORT\_DEV, ENABLE);  
AUDIO\_SPORT\_RxStart (AUDIO\_SPORT\_DEV, ENABLE);  
(9) Activate GDMA Rx data  
AUDIO\_SPORT\_RXGDMA\_Init (Index, &GDMA\_InitStruct, CallbackData, CallbackFunc, RxData, Length)

## 24.5.3 Example List

| Example             | Location                                                      |
|---------------------|---------------------------------------------------------------|
| Playback            | /project/realtek_amebaD_v20/example/example_sources/Audio/dac |
| Record and playback | AMIC                                                          |
|                     | /project/realtek_amebaD_v20/example/example_sources/Audio/adc |
| Record and store    | AMIC                                                          |
| Record and upload   | DMIC                                                          |
| Decode algorithm    | AMR                                                           |
|                     | AC3                                                           |
|                     | FLAC                                                          |

|  |               |                                                           |
|--|---------------|-----------------------------------------------------------|
|  | Helix AAC     | /component/common/example/audio_sport/audio_helix_aac     |
|  | Helix MP3     | /component/common/example/audio_sport/audio_helix_mp3     |
|  | HLS           | /component/common/example/audio_sport/audio_hls           |
|  | M4A           | /component/common/example/audio_sport/audio_m4a           |
|  | M4A selfparse | /component/common/example/audio_sport/audio_m4a_selfparse |
|  | MP3           | /component/common/example/audio_sport/audio_mp3           |

Note @ are available. If you want to disable the GDMA, it should be done in a GDMA related interrupt routine. Disabling the GDMA outside of an interrupt routine may cause an exception if the GDMA is transferring data.

## 24.6 Hardware Design Guide

### 24.6.1 Line-out

The lineout connection of audio codecs illustrated Fig2413. The capacitors between 3.5mm jack and IC should be 47uF tantalum capacitors rather than ceramic capacitors because the capacitance value of ceramic capacitors may decrease when bias voltage is applied to them, which causes audio performance bad.



Fig2413Line-out connection

### 24.6.2 AMIC-in

The AMICin connection of audio codecs illustrated Fig2414. The capacitor between analog microphone and IC should be 1uF. Larger capacitance value makes longer period needed for cap charging.



Fig2414AMIC-in connection

MIC\_BIAS connects to the positive side of microphone through a 2.2kohm resistor to offer bias voltage.

Short the negative side of microphone to ground if using single ended mode, or connect to ground through a 2.2kohm resistor at differential mode.

Connect the negative side of microphone to MIC\_N through a 1uF capacitor at differential mode.

## 24.6.3 Power

The power connection of audio code is illustrated Fig2415

stabilization

The capacitor between AVCC or AVCC\_DRIV and ground should be 1uF or a little larger to keep voltage stable.



Fig2415 Powerconnection

## 24.7 Performance of Encoding & Decoding

The performance of decoding or encoding audio files of different formats is listed in Table243~Table249. Data listed in these tables are obtained when the dynamic memory is allocated in SRAM. Data may be different if memory is allocated in PSRAM.

### 24.7.1 AC3 Format

The performance of decoding AC3 format audio data is listed in Table243.

Table243 Performance of decoding AC3 format audio data

| AC Channel | BitRate(kHz) | SampleRate(kHz) | OutputChannel | Average MIPS Measured | MIPS Simulated |         |
|------------|--------------|-----------------|---------------|-----------------------|----------------|---------|
|            |              |                 |               |                       | Average        | Maximum |
| 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    |

1. The values are evaluated on the nebad\_QFN88\_EVB\_V1

2. The values are evaluated with the Keilulator

### 24.7.2 OPUS Format

The simulated CPU load of encoding and decoding OPUS audio data is listed in Table244. Keil simulator is used during the whole process. The decoding filter used in the measurement process was created with opusols0.2opus1.3.

Table244 Simulated CPU load of encoding and decoding OPUS audio data

| Rate(kHz) | Channel | BitRate(kbps) | Complexity | MIPS     |          | Measured |          |
|-----------|---------|---------------|------------|----------|----------|----------|----------|
|           |         |               |            | Decoding | Encoding | Decoding | Encoding |
| 48        | 2       | 256           | 10         | 63       | 153.5    | 82.7     | 261      |
| 48        | 2       | 256           | 3          | 58       | 122.5    | 71.4     | 142.2    |
| 48        | 2       | 256           | 0          | 53       | 102      | 67.6     | 129.8    |

|    |   |     |   |     |      |      |       |
|----|---|-----|---|-----|------|------|-------|
| 48 | 1 | 256 | 3 | 38  | 74.5 | 53.4 | 81.8  |
| 16 | 1 | 48  | 3 | 8.5 | 46.5 | TBD  | 108.6 |
| 16 | 1 | 20  | 3 | 7   | 44.5 | TBD  | 101.6 |

If users decide to use libopus library to deal with their data, the code size requirement is listed in Table 245. The version used here is libopus 1.1.4.

Table 245 Code size requirement using libopus

| Type                                   | ProgramSize | DataSize |
|----------------------------------------|-------------|----------|
| SILKencoder                            | 77.1k       | 8.5k     |
| Original Source Code (Encode + Decode) | 133k        | 23.6k    |

In Table 246, CPU load on using Silk encoder is listed.

Table 246 CPU load on using Silk encoder

| Test Condition                | Complexity | Average CPU Load (MHz) | Remarks  |
|-------------------------------|------------|------------------------|----------|
| SILKencoder, 16k, 1ch, 20kbps | 3          | 42                     | SILK VBR |
|                               | 10         | 182                    |          |

### 24.7.3 FLAC Format

The simulated with Keil simulator and measured CPU load for decoding FLAC audio data is listed in Table 247. The tested file last for 279.64s, and the decoding time is 18.15s, means 2.89s decoding time per minute audio data.

Table 247 CPU load of decoding FLAC audio data

| Rate(kHz) | Channel | WordLength | MIPS Simulated | MIPS Measured |
|-----------|---------|------------|----------------|---------------|
| 44.1      | 2       | 16         | 19             | 9.66          |

### 24.7.4 AAC Format

The measured CPU load for decoding AAC audio data is listed in Table 248. The tested file last for 24.576s and the decoding time is 1.68s, which means 8.68 decoding time for minute audio data.

Table 248 CPU load of decoding AAC audio data

| Rate(kHz) | Channel | BitRate(kbps) | MIPS  |
|-----------|---------|---------------|-------|
| 48        | 2       | 320           | 28.93 |

### 24.7.5 MP3 Format

The measured CPU load for decoding MP3 audio data is listed in Table 249. The tested file last for 5.58s and the decoding time is 0.49s, which means 9.13 decoding time for minute audio data.

Table 249 CPU load of decoding MP3 audio data

| Rate(kHz) | Channel | BitRate(kbps) | MIPS  |
|-----------|---------|---------------|-------|
| 32        | 2       | 320           | 30.43 |

## 24.8 Q & A

### 24.8.1 How to Connect the Output of DAC to Power Amplifier?

In our SDK, the output of DAC is configured as single ended by default. The end should be left alone. The end of L/R should be connected to the amplifier respectively. Choose either the P or R if only one channel is needed.

If the power amplifier is an AB type amplifier, refer to the design Fig2416 (power amplifier is LM4991).

If the power amplifier is a D type amplifier, refer to the design Fig2417 (power amplifier is ALC1003).



Fig2416 Reference design of using AB type power amplifier



Fig2417 Reference design of using D type power amplifier

### 24.8.2 What is the Difference between Single-ended MIC Input and Differential MIC Input?

The SNR of differential mic input is better than single ended input, but one more pin is needed. And it supports 2 mics. One supports both single ended input and differential input, but another only supports single ended input.

### 24.8.3 How to Play Local Audio Files?

If audio files are stored in SD card, you need APIs 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 directly to speaker. The APIs are listed below:

# 25 CapTouch

Ameba-D CapTouch provides 4 channels for capacitive sensing. The sensitivity and threshold for each channel are configurable. For different applications and surroundings users should tune parameters to achieve best performance.

This chapter introduces how to use CapTouch and design touchkey.

## 25.1 Pinmux

The pin assignments of CapTouch channels are listed in Table 21-4.

Table 25-1 CapTouch pin assignment

| Channel | Port Name | Pin Name   | QFN48 | QFN68 | QFN88 |
|---------|-----------|------------|-------|-------|-------|
| 0       | PB[4]     | TOUCH_KEY0 |       |       |       |
| 1       | PB[5]     | TOUCH_KEY1 |       |       |       |
| 2       | PB[6]     | TOUCH_KEY2 |       |       |       |
| 3       | PB[7]     | TOUCH_KEY3 |       |       |       |

## 25.2 APIs

### 25.2.1 CapTouch\_StructInit

| Items        | Description                                                                            |
|--------------|----------------------------------------------------------------------------------------|
| Introduction | Initializes the parameters in the CapTouch_InitStruct with default values.             |
| Parameters   | CapTouch_InitStruct: pointer to a CapTouch_InitTypeDef structure which is initialized. |
| Return       | N/A                                                                                    |

Note: CapTouch\_InitStruct contains the configuration parameters for CapTouch and each channel, which includes the source control, ETC parameters, bias current and threshold for channels.

### 25.2.2 CapTouch\_Init

| Items        | Description                                                                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the CapTouch peripheral according to the specified parameters in the CapTouch_InitStruct.                                                                                          |
| Parameters   | CapTouch: which should be CAPTOUCH_DEV.<br>CapTouch_InitStruct: pointer to a CapTouch_InitTypeDef structure that contains the configuration information for the specified CapTouch peripheral. |
| Return       | N/A                                                                                                                                                                                            |

### 25.2.3 CapTouch\_Cmd

| Items        | Description                                                                                                                         |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the specified CapTouch peripheral.                                                                              |
| Parameters   | CapTouch: which should be CAPTOUCH_DEV.<br>NewState: new state of the CapTouch peripheral. This parameter can be ENABLE or DISABLE. |
| Return       | N/A                                                                                                                                 |

## 25.2.4CapTouch\_INTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the specified CapTouch interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Parameters   | CapTouch which should be CAPTOUCH_DEV.<br>CapTouch_IT: specifies the CapTouch interrupt to be enabled or masked. This parameter can be one or combinations of the following values:<br>BIT_CT_OVER_N_NOISE_THRESHOLD_INT: CapTouch negative noise overflow interrupt<br>BIT_CT_FIFO_OVERFLOW_INT: CapTouch FIFO overflow interrupt<br>BIT_CT_OVER_P_NOISE_THRESHOLD_INT: CapTouch positive noise overflow interrupt<br>CT_CHX_PRESS_INT(x): CapTouch channel(x) press interrupt, where x can be 0~3<br>CT_CHX_RELEASE_INT(x): CapTouch channel(x) release interrupt, where x can be 0~3<br>NewState: new state of the specified CapTouch interrupts mask. This parameter can be ENABLE or DISABLE |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## 25.2.5CapTouch\_GetISR

| Items        | Description                             |
|--------------|-----------------------------------------|
| Introduction | Gets Cap-Touch interrupt status.        |
| Parameters   | CapTouch: which should be CAPTOUCH_DEV. |
| Return       | Interrupt status                        |

## 25.2.6CapTouch\_INTClearPendingBit

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clears the specified CapTouch interrupt pending bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Parameters   | CapTouch: which should be CAPTOUCH_DEV.<br>CapTouch_IT: specifies the CapTouch interrupt to be cleared. This parameter can be one or combinations of the following values:<br>BIT_CT_N_NOISE_OVERFLOW_INT_CLR: CapTouch negative noise overflow interrupt<br>BIT_CT_FIFO_OVERFLOW_INT_CLR: CapTouch FIFO overflow interrupt<br>BIT_CT_P_NOISE_OVERFLOW_INT_CLR: CapTouch positive noise overflow interrupt<br>CT_CHX_PRESS_INT(x): CapTouch channel(x) press interrupt, where x can be 0~3<br>CT_CHX_RELEASE_INT(x): CapTouch channel(x) release interrupt, where x can be 0~3 |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

## 25.3 How to Use CTC

### 25.3.1 CTC Initialization

The CapTouch initialization is implemented by the `captouch_init()` function in `main.c`. You can follow these steps to use it:

- (1) Set the `km0_enable_key_touch` in `ps_d1lp_sleepcfg_toBIT_CAPTOUCH_ENABLE` enable Cap-Touch when KM0 boot

```
PSCFG_TypeDef ps_config = {
    .km0_config_wifi_enable = TRUE,
    .km0_enable_key_touch = FALSE, //BIT_KEY_ENABLE / BIT_CAPTOUCH_ENABLE,
    .km0_ticks_debug = FALSE, /* if open WIFI FW, should close it, or beacon will lost in WLAN */
    .km0_osc2m_close = TRUE,
    .km0_pg_enable = FALSE,
    .km0_rtc_calibration = FALSE,
    .km0_audio_pad_enable = TRUE,
};
```

- (2) Set configuration parameters in the following `stouchkey`, which includes touch threshold, mbias current, enable control for each channel. The method to tune parameters for each channel can be found in Table252.

```
static CapTouch_CHInitTypeDef CTCChan[4] =
{
    /*DiffThreshold, MbiasCurrent, ETCNNoiseThr, ETCPNoiseThr, CHEnable*/
    {35,      0x16,      3,          18,          ENABLE}, /* Channel 0 */
    {500,     0x08,     250,        250,        DISABLE}, /* Channel 1 */
    {500,     0x08,     250,        250,        DISABLE}, /* Channel 2 */
    {500,     0x0b,     250,        250,        DISABLE}, /* Channel 3 */
};
```

- (3) Rebuild SDK and burn images, the Cap-Touch would work after boot up. When finger touch or proximity detected, the Cap-Touch would send a Key Press interrupt to system.

### 25.3.2 CTCCalibration

To achieve the best performance (sensitivity or response time), users need to tune threshold, noise threshold and mbias current during development. The reference value of parameters is shown in Table252. Of course, users can tune other parameters manually to fit special requirements.

The parameters for each channel should be initialized. To calibrate for channel 0, for example, users can follow these steps:

- (1) Initialize the parameter CapTouch\_InitStruct with default values using `CapTouch_StructInit()` to enable channel 0.  
`CapTouch_StructInit(&CapTouch_InitStruct);`  
`CapTouch_InitStruct.CT_Channel[0].CT_CHEnable = ENABLE;`
- (2) Initialize the Cap-Touch peripheral according to step(1)  
`CapTouch_Init(CAPTOUCH_DEV, &CapTouch_InitStruct);`
- (3) Enable Cap-Touch  
`CapTouch_Cmd(CAPTOUCH_DEV, ENABLE);`
- (4) Call `CapTouch_GetChAveData()` to read the sample data from channel 0 periodically  
`CapTouch_GetChAveData(CAPTOUCH_DEV);`

Table252 Reference value of parameters

| Parameters           | Description                                                                                                                | Reference Range      |                     |
|----------------------|----------------------------------------------------------------------------------------------------------------------------|----------------------|---------------------|
|                      |                                                                                                                            | FingerTouchDetection | ProximityDetection  |
| mbias                | Set to a value which makes the baseline within the reference range                                                         | Baseline: 2500~3500  | Baseline: 3500~3800 |
| Difference Threshold | Set to 80% of the touched difference value                                                                                 | 500~600              | 30~80               |
| Noise Threshold      | Set to no more than 50% of difference threshold and it can be adjusted according to actual situation<br>Maximum value: 255 | 200~255              | 0~40                |

## 25.4 Cap-Touch Schematic Design and PCB Layout Guidelines

The CTC of Ameba-D has 4 Cap-Touch channels, and all of them support button and proximity sensor. Both the schematic design and PCB layout are important for Cap-Touch application. This chapter provides guidelines for Cap-Touch schematic design and PCB layout.

### 25.4.1 Cap-Touch Schematic Design

The CTC supports 4 channels, each channel supports button and proximity sensor. Only 2 channels are used when designing the Gap Touch schematic, you should select the sensor pins that are far apart from each other for better stability, do not make the sensor trace run parallel to clock signal or driven signal, which may result in crosstalk and may cause the sensor next to those signals to make trigger false. Refer to PCB Layout getting started with PCB layout design guidelines to avoid crosstalk.

All Cap-Touch channels must have a touch sensor (placed close to the chip) to prove noise immunity both for button and proximity sensor. If any Cap-Touch channel is not used, it is recommended to disable this channel and connect it to ground. Refer to Use CTC for details of disabling a channel.

For example Fig 251 is a schematic in which 4 channels are enabled.



Fig 251 4 Channels enabled schematic

## 25.4.2 PCB Layout

In a typical Cap-Touch application, sensors are constructed with traces on a FR4/FR2 or flexible printed circuit (FPC). Cap-Touch layout design is an important step in the design phase. Following the PCB layout design guidelines can help your design achieve higher noise immunity, lower parasitic capacitance (CP), and higher signal-to-noise ratio (SNR).

**Sensor parasitic capacitance:** Sensor CP depends on sensor dimensions, PCB overlay and trace length. A longer sensor CP makes it more difficult to sense small changes in capacitance and thereby reduces sensitivity.

**Sensor dimensions:** The sensor dimensions depend on the overlay thickness and suitable dimension for human touch. For touch convenience a larger dimension is needed. A thicker overlay requires a larger sensor dimension. But a larger dimension causes higher parasitic capacitance.

**Sensor trace length:** Longer trace length adds sensor CP and reduce the sensor sensitivity. Also, a long trace acts as an antenna and reduces the noise immunity of the sensor.

**Power consumption:** The power consumption of the sensor depends on period and sensitivity (mbias), while the sensitivity depends on the CP of the sensor. Higher CP results in higher sensitivity and smaller scan results in high power consumption. To achieve a lower power consumption, reduce the sensor CP. To achieve a lower CP, higher SNR, and lower power consumption, follow the layout design guidelines.

For better performance, the following table summarizes the recommendations of the sensor shape, minimum and maximum sensor dimensions, placement of the sensor, and routing traces on the PCB or FPC. Table 253 summarizes the sensor layout guidelines while designing a Cap-Touch application both of button application and proximity application.

Table 253 Sensor layout recommendations

| Category  | Item                                | Min                     | Max    | Description                                                                                                                                                                               |
|-----------|-------------------------------------|-------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Button    | Button parasitic capacitance        | 4pF                     | 50pF   | Lower CP, lower sensitivity, lower power consumption                                                                                                                                      |
|           | Button shape                        | N/A                     | N/A    | Round or rectangle with round corners                                                                                                                                                     |
|           | Button size                         | 5mm                     | 15mm   | Larger size causes more power consumption. Recommended size is 8mm~12mm for round shape                                                                                                   |
|           | Button spacing                      | Button/Ground clearance | N/A    | Depending on button application, for better stability, the recommended spacing is larger than 8mm.                                                                                        |
|           | Button GND clearance                | 0.5mm                   | 2.54mm | The recommended clearance is equal to the overlay thickness                                                                                                                               |
| Proximity | Proximity parasitic capacitance     | 8pF                     | 50pF   | Proximity needs lower CP and higher mbias for better sensitivity, which causes more power consumption                                                                                     |
|           | Proximity sensor shape              | N/A                     | N/A    | Circular or rectangular loop (with round corners) on PCB for large area. Circular or rectangular solid fill (with round corners) for small area. Line with recommended sensor trace width |
|           | Proximity sensor trace width        | 2mm                     |        | A GND loop surrounding the sensor results in better noise immunity. Worse sensitivity.                                                                                                    |
|           | Proximity sensor GND loop clearance | 1.5mm                   | 2.5mm  | The recommended width is 2mm                                                                                                                                                              |

|  |                                |       |  |                                                                              |
|--|--------------------------------|-------|--|------------------------------------------------------------------------------|
|  | GND loop trace width           | 1.5mm |  | 1.5mm                                                                        |
|  | Proximity sensor loop diameter |       |  | The recommended loop diameter needs to be larger than the proximity distance |

Table 254 summarizes the layout guidelines for placement of components, routing of sensor trace and GND layer when designing a CapTouch application both button application and proximity application.

Table 254 Other layout recommendations

| Category  | Item                     | Min        | Max         | Description                                                                                                                                                                                                                                                                                                                   |
|-----------|--------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Placement | 2 layer PCB              | N/A        | N/A         | Top: Sensors, devices, and components; VDD and GND traces, other signal traces<br>Bottom: Sensor traces, devices and components; VDD and GND traces, other signal traces<br>Note:<br>Avoid VDD traces, clock traces, and driven traces over sensor traces.<br>Avoid sensor trace run parallel to clock signal or drive signal |
|           | 4 layer PCB              | N/A        | N/A         | Top: Sensors, devices, and components<br>Second layer: Hatched ground<br>Third layer: Sensor traces, VDD layer<br>Bottom: Devices, and components<br>Note Avoid VDD traces, clock traces, and driven traces parallel under or over sensor traces.                                                                             |
| Routing   | Sensor trace length      |            |             | Not limited, make sure the total capacitance and sensor capacitance is less than 50pF.                                                                                                                                                                                                                                        |
|           | Sensor trace width       | 6mil       | 9mil        | The recommended value is 7mil(FR4/FR2/FPC)                                                                                                                                                                                                                                                                                    |
|           | Sensor trace routing     | N/A        | N/A         | The best choice for sensor is routed on the sensor side. Otherwise, make sure the sensor trace area is a touch forbidden area.<br>Note Avoid sensor trace run parallel to clock signal or drive signal. If any sensor trace crosses the sensor trace, make sure that the intersection is orthogonal                           |
|           | Via position             | N/A        | N/A         | Via should be placed near the edge.                                                                                                                                                                                                                                                                                           |
|           | Via number               | 0          | 3           | 1 via is needed, more results other parasitic capacitance                                                                                                                                                                                                                                                                     |
|           | Via hole size            | 12mil/6mil | 24mil/12mil | The recommended via hole size is 16mil/10mil                                                                                                                                                                                                                                                                                  |
|           | Trace series resistor    | 47         | 560         | Series resistors close to the chip for better suppression of ESD                                                                                                                                                                                                                                                              |
|           | Trace GND layer distance | 10mil      | 20mil       | 20mil                                                                                                                                                                                                                                                                                                                         |
| GND       | GND-Top layer            |            |             | Hatched pattern 7mil trace and 35~45 mil grid                                                                                                                                                                                                                                                                                 |
|           | GND-Bottom layer         |            |             | Hatched pattern 7mil trace and 65~75 mil grid                                                                                                                                                                                                                                                                                 |
| Overlay   | Overlay thickness        | N/A        | 3mm         | Depends on your product, 3mm for glass or plastic, thickness may decrease the sensitivity.                                                                                                                                                                                                                                    |
|           | Overlay material         | N/A        | N/A         | Non-conductive material                                                                                                                                                                                                                                                                                                       |

For example Fig 252 is a PCB design of button and proximity application



Fig252PCB design of button and proximity application

# 26 DuerOS

## 26.1 DuerOS Platform

DuerOS is an important application. Baidu Artificial Intelligence (AI) technology has huge amounts of data and can control 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. All users can use it to build their own exclusive artificial intelligence products.

This chapter takes story machine as an example.

### 26.1.1 Apply product

DuerOS development platform home page <http://open.duer.baidu.com/didp/main/index>

To apply your own product, follow the steps:

- (1) Enter DuerOS home page and register as a developer.



Fig261 Register guide

- (2) Configure new device.
  - a) After successful registration, click 'Configure New Device' and enter the next step.



Fig262 Device control platform

- b) Configure the device as your need, story machine as an example.



Fig263 Configuring new product

c) Choose FreeRTOS and enter the next step



Fig264 Choosing FreeRTOS

d) Give the product name and click the Apply ClientID button.



Fig265 Apply ClientID

e) Click the LightDeviceConfiguration button.



Fig266 Configuring device

After the above steps, story machine product has been created. You can get story machine information through the **Product Information** menu, and can customize DuerOS service.

| 产品中心 / 故事机 - AmebaD |            |                  |
|---------------------|------------|------------------|
| 产品研发                | DuerOS服务列表 |                  |
| 产品信息                |            |                  |
| 数据点设置               | 儿童故事       | 面向儿童的故事、儿歌等丰富资源  |
| 数据点测试               | 系统画像       | 自定义产品形象和语音交互问答   |
| 设备端开发               | 有声博物馆      | 动物、乐器、大自然等声音的博物馆 |
| 批量生产                | 猜谜语        | 趣味儿童互动游戏——猜谜语    |
| 服务                  | 词语接龙       | 趣味儿童互动游戏——词语接龙   |
| IFTTT               | 天气         | 灵敏、智能的天气机器人      |
| 运行日志                | 有声笑话       | 海量有声笑话           |
| OTA升级               | 硬件控制       |                  |
| 应用配置                | 信息         | 时间、翻译、百科、问答等通用问题 |
| 数据统计                | 音乐 (已停用)   | 百度正版音乐资源         |
| 定制化                 | 有声点播 (已停用) | 娱乐、相声、戏曲及有声节目    |
| DuerOS服务            | 新闻 (已停用)   | 每日实时新闻           |

Fig267 Product center

## 26.1.2 Apply Profile

After product has been applied, get a set of profiles through the **Development** menu



Fig268 Gettingprofile

Duer profile, which contains UUID, Token, server address, port, and certificate 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 be used directly, ~~because~~ we only support mp3 format. Product manager should negotiate with Baidu to obtain the other format for these profiles.

## 26.2 Hardware Requirement

| Hardware                  | Description                                                         |
|---------------------------|---------------------------------------------------------------------|
| Ameba-D development board | Use AmebaD_QFN88_EVB_V1.hd connect as follows.<br>                  |
| MicroUSB cable            | Used to provide power for Ameba board, and can view serial port log |
| Play equipment            | Headset or speaker can be used to play audio data.                  |

## 26.3 Software Component

DuerOS software component show in Fig1-1.



Fig269 Software component

### 26.3.1 duerapp

| Items   | Description                                                                                                               |
|---------|---------------------------------------------------------------------------------------------------------------------------|
| include | duerapp header files                                                                                                      |
| src     | public: AmebaD initializes peripheral: Audio code Wi-Fi, OTA<br>private: parse play file, record from file, load profile. |

### 26.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

## 26.4 How to Use DuerOS

### 26.4.1 Build and Download

#### (1) Modify the profile

As every device has a unique profile, we should change the profile for each device. Zip the profile and choose one file to open. Copy 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
#if (PROFILE_FROM_SD CARD == 0)
#if (DWER_PROFILE_UUID == 1)
SDRAM_DATA_SECTION static const char duer_profile[] =
    {"\\"configures": [{"\""}, {"\"bindToken\": \"9071f6a0954fce1796999c4b83c2437\", \"coapPort\": 443, \
    \"token\": \"9071f6a0954fce1796999c4b83c2437\", \"serverAddr\": \"device.riot.baidu.com\", \"lwm2mPort\": 443, \
    \"uuid\": \"19c8000000000001\", \"rsaCaCrt\": \"----- BEGIN CERTIFICATE -----\\n\\
    MIIDUDCCAgCCQCMVPUERhYhJANBGeWBAQUFADBQgQSwCQYDVQGEWdJ\\n\\
    TzJETBMGA1UECAwKU29tZS1TdfG02TEMAwGA1UECgwJpZtHxDmABNgBvNBBM\\n\\
    Dyoual90LmJhNmlNbVtcBMeBGCSqS1BdQ3EJARYNa90QGJhawR1LnNbTae\\n\\
    FwXxjhA1ZMTWmZhN1dlaFw0NyJazKdwMmWnD1ahGoxCzAJBgNVBAYTAKNORMlw\\n\\
    EQYDVQIDPdTB211LN0YXR1MwDAYDVQKQDAVY1uk1dTEYMBYGA1UeAwPKi5p\\n\\
    b3QuYmpFzHUy29tRwmpGJYKzoIvhNaOKBrgFplb3RAympFzHUuY29tMII8jAN\\n\\
    BgkXgkQ98AEQFAACOA80A11IBcgKCAoAtBie1n7PznzuMsWslKQj2xB02+51\\n\\
    OvC15d1162Fljepc9tq1loQNFBw+AmJ5N2aAH3tsetTHMiitY4dtGmOpw4d1Gx\\n\\
    luoz50KjhQJzR+6DLPN64EUeLO5vbKHUyPPPTT88eVn1959n/17DcjeAJYC\\n\\
    Y1f3b6+K9x+Ti19RvChVkcZQH9Rym91g+7CKGMCIwKc-6iKhGD/XG40=7RkCy\\n\\
    bd53KnnBj8QFH41L3rG1ZKWhMw3zC6RT52ekfsgAtDvR0Kd4rNs+DUJ9xAbLO\\n\\
    dT15XusgudH2VnwlzJt090UDbxTcQFDIn120BcrkvU+HEIR0p0DibwIDAQAB\\n\\
    MA0GCSqS1B3DQEBBQJAA1IBAQcZTT91hJnh/yvBEFekSVNg1h1kPsuj1wEDDF\\n\\
    pjqPJQzrWw0cm'sy18b985JB887JMFV9ESg/v0Y/Ybvcnro15gaenwQONL4\\n\\
    h2f80A5wEFL0/Ead1GTH301cYK2G6Grz+uFKHv57TMiF1AcBdu37ALGjA\\n\\
    r1jwzQxG6bWlR9468hKKFnWg3d1bHkVmQ8x420FJRMqkbk2aa8d1uW4xYSXwM\\n\\
    S1Q5x67tr0g0A35+4dg5u1LVN4YVpQ94SM7yL7zz12Ax96tNhNrhySw1C2r\\n\\
    OVSDxsItztxEBG9t7gsBte556B1vufzx+BXgyycJ3dBu3\\n\\
    ----- END CERTIFICATE -----\\n\\", \"macId\": \"\", \"version\": \"12237\"};\\n"

```

Fig2610Profile in duerapp.c

- (2) Select AMIC or DMIC to record.
  - (3) Modify macr6ONFIG\_DMIC\_SEL project\realtek\_amebaD\_va0\_example\inc\h\platform\_opts.h

| Items                   | Value | Description        |
|-------------------------|-------|--------------------|
| #define CONFIG_DMIC_SEL | 0     | Use AMIC to record |
|                         | 1     | Use DMIC to record |

- (4) Build the project to generate DuerOS image.
  - (5) Use ImageTool to download DuerOS image into ~~Andriod~~ platform.

#### 26.4.2 Configure the Network

After download and the image successfully, reset the Amelba board.

If it is the first up, it enters simple configuration mode. You can use the simple configuration tools to config the network. If it is not the first, it connects to the network automatically because the SSID and password are saved in the Flash.

```
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 Switch to channel(3)
18:09:02.432
18:09:02.558 Switch to channel(4)
18:09:02.555
18:09:02.719 Switch to channel(5)
18:09:02.719
18:09:02.854 Switch to channel(6)
18:09:02.856
18:09:03.014 Switch to channel(7)
18:09:03.020
18:09:03.157 Switch to channel(8)
18:09:03.160
18:09:03.317 Switch to channel(9)
18:09:03.319
18:09:03.487 Switch to channel(10)
18:09:03.487
18:09:03.642 Switch to channel(11)
18:09:03.642
18:09:03.749 Input frame da: 01 00 5E 00 00 FB, data length: 39
18:09:03.781
```

Fig2611 Simple configuration log

## 26.4.3 DuerOS Connection Success

After connecting to the network successfully, the device connects to Baidu Clouds automatically. When in the log like Fig2612, it means that DuerOS connection is successful.

```
18:38:02.748 duerapp: duer_events_call_internal, handler not initialized...
18:38:02.749 duerapp: duer_engine_start, g_handler:0x10053e00, length:1469, profile:0x10042690
18:38:02.750 duerapp:     duer_conf_get_string: uid = 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:, fd:-1, ref_count:0, timer:0x10043580
18:38:09.138 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.520 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:12.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.680 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!!
```

Fig2612 DuerOS connection success log

## 26.4.4 Trigger Record and Speak

- (1) PA[2] 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[2], so use PA[2] to trigger.
- (2) Make a voice command
- (3) After PA[2] pull high, DuerOS would response with '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);
}
```

Fig2613 Trigger code

## 26.5 OTA Upgrade

### 26.5.1 Generating OTA Image

- (1) Change FIRMWARE\_VERSION component common application baidu\_duerapp.h 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"
```

Fig2614 Firmware version

- (2) Change OTA2 address mapping

As the size of DuerOS image is more than 1M, there should be at least 4M Flash OTA is needed. If the Flash size is 4M, modify the components so realtekamebadfwlibusrcf\rtl8721d\_bootcfgs follows

```

00038: /*
00039: * @brief OTA start address. Because KM0 & KM4 IMG2 are combined, users only need to set the start address
00040: * of KM0 IMG2.
00041: */
00042: BOOT_RAM_DATA_SECTION
00043: u32 OTA_Region[2] = {
00044:     0x08006000, /* OTA1 region start address */
00045:     0x08206000, /* OTA2 region start address */
00046: };

```

Fig2615OTA Region

## (3) Generate OTA image

For AmebaD, km0\_km4\_image2.bin folder\project\realtek\_amebaD\_va0\_exam\RELEASE\project\_h\asdk\image is the OTA image

## 26.5.2OTA with DuerOS Platform

## (1) Add OTA firmware

## (2) ClickAdd button, then fill in the OTA firmware information, such as version, file, file name, and file type.



Fig2616AddingOTA firmware

## (3) Verify OTA image.

## a) ClickCheckbutton to enter the OTA image verification page.



Fig2617Check button

## b) Verify the OTA firmware.



Fig2618Verificationbutton

c) Fill in the UUID to show OTA status.



Fig2619Inputting profile UUID

(3) Check whether OTA update succeeded or not

If OTA update succeeded, the state upgrade is shown as Fig2620. Otherwise OTA upgrade is failed.



Fig2620OTA update result

Note:

OTA upgrade needs 4M byte Flash

OTA firmware file name must be consistent with the `induer_ota_register_installer` function in `induerapp_ota.c`.  
 OTA firmware version should be later than the old image.

## 26.6 How to Debug

### 26.6.1 Build Error

If the following errors occurs you must reduce the heap size in `project\realtek_amebaD_va0_example\inc\hpFreeRTOSConfig.h`

```
[...]
/cygdrive/d/iot/ameba-D/DuerOS/Ameba/v03_2018_back/project/realtek_amebaD_cm4_gcc_verification/toolchain/cygwin/asdk-6.4.1/cygwin/newlib/bin/..../lib/gcc/arm-none-eabi/6.4.1/..../arm-none-eabi/libc/region/BUILD_NS overflowed by 3008 bytes
error: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/v03_2018_back/project/realtek_amebaD_cm4_gcc_verification/asdk'
Makefile:29: recipe for target 'xip' failed
make: *** [xip] Error 2
```

### 26.6.2 Wi-Fi Signal

Use ATWS command to check Wi-Fi signal if the signal is bad move the electric resistance shown in Fig2621 to check.



Fig2621Electric resistance

### 26.6.3 Cannot Recognize the Recorder

- (1) Check if the DMIC or AMIC is correctly.
  - a) Check if the jumpers are connected correctly, and the `AMIC` is set correctly.
  - b) Open `project\realtek_amebaD_va0_example\inc\hpplatform_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: start timer:0x0
18:57:30.904 duerapp: start last timer:0x0, soc:0x10043580
18:57:30.908 duerapp: Action failed
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.918 duerapp: duer_events_call_internal, handler not initialised...
18:57:30.920 duerapp: duer_events_call_internal, handler not initialised...
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 = 19c8000000000001
```

Fig2622Network fail log

## 26.6.4 Checking 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
```

## 26.6.5 Checking the Device Status

You can see the running log on Baidu Cloud.

The left screenshot shows the '运行日志' (Operation Log) section of the product center. It displays a table with columns: 设备ID (Device ID), 首次心跳时间 (First Heartbeat Time), 最后一次心跳时间 (Last Heartbeat Time), 状态 (Status), and 行政日志 (Administrative Log). One entry is shown: 19:8000000001, 2018-12-13 17:41:08, 2018-12-13 18:51:21, 在线 (Online), and a link to the log details.

The right screenshot shows the '运行日志 / 19:8000000001' (Operation Log / 19:8000000001) page. It has a similar table structure with additional filters for 日志时间 (Log Time), 用途 (Purpose), and 操作 (Operation). The log entries show various system events and responses, such as 'duer\_private' and 'duer\_directive' messages with their respective timestamps and details.

# 27 Infrared Radiation (IR)

Ameba-D Infrared Radiation (IR) provides hardware modulation for Infrared Radiation and hardware auto capture for receiving.

This chapter introduces how to use IR.

## 27.1 Pinmux

The pin assignments of IR are listed in Table 27-1.

Table 27-1 IR pin assignment

| Port Name | Pin Name | QFN48 | QFN68 | QFN88 |
|-----------|----------|-------|-------|-------|
| PA[25]    | IR_TX    |       |       |       |
| PA[26]    | IR_RX    |       |       |       |
| PB[23]    | IR_TX    | X     |       |       |
| PB[22]    | IR_RX    | X     |       |       |
| PB[31]    | IR_TX    | X     |       |       |
| PB[29]    | IR_RX    | X     |       |       |

## 27.2 DataFormat

This section introduces the data format of Tx FIFO and Rx FIFO.

### 27.2.1 IR Tx

To send IR data you must write data into the 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. It represents the carrier frequency (the unit of is KHz), and represents the duration of a carrier symbol (the unit of is us).

Then,

→ ¥ °

Take NEC protocol for example, the carrier frequency is 38kHz. The format of NEC is shown in Fig 27-2. The NEC format consists of 2 start symbols, 6 bytes data and 1 stop symbol.



Fig 27-1 NEC format



Fig27-2NEC modulation

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] =  $380 * 21000 / 1000 = 64$ .  
 For the first data, bit[31] = 0, bit[30] = 0, bit[27:0] =  $380 * 11000 / 1000 = 21$ .  
 For the second data, bit[31] = 0, bit[30] = 0, bit[27:0] =  $380 * 11000 / 1000 = 21$ .  
 At last you need to send the stop symbol. In this symbol, set bit[30] = 1 because the stop symbol indicates the end of the transmission.

## 27.2.2 IR Rx

To receive IR data, you should read the data 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.  $\text{cycle duration} = \frac{\text{represents the sampling frequency (the unit of is kHz)}}{\text{represents the duration of each high level (the unit of is us)}}$ . Then,

With the use of , you can do further processing to get the information you need.

## 27.3 APIs

### 27.3.1 IR Setting APIs

#### 27.3.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                                                                              |

#### 27.3.1.2 IR\_Init

| Items        | Description                                                                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes the IR peripheral according to the specified parameters in the IR_InitStruct.                                                        |
| Parameters   | IRx: selected IR peripheral.<br>IR_InitStruct: pointer to a IR_InitTypeDef structure that contains the configuration information for peripheral. |
| Return       | N/A                                                                                                                                              |

### 27.3.1.3 IR\_Cmd

| Items        | Description                                                                                                                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the selected IR mode.                                                                                                                                                                                                         |
| Parameters   | IRx: selected IR peripheral.<br>mode: selected IR operation mode. This parameter can be the following values:<br>IR_MODE_TX: Transmission mode.<br>IR_MODE_RX: Receiving mode.<br>NewState: new state of the operation mode.<br>ENABLE<br>DISABLE |
| Return       | N/A                                                                                                                                                                                                                                               |

### 27.3.1.4 IR\_INTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Enables or disables the specified IR interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Parameters   | IRx: selected IR peripheral.<br>IR_INT: specifies the IR interrupt sources to be enabled. This parameter can be one or combination of the following values:<br>IR_TX_FIFO_EMPTY_INT_EN: Tx FIFO empty interrupt.<br>IR_TX_FIFO_LEVEL_INT_EN: Tx FIFO threshold interrupt.<br>IR_TX_FIFO_OVER_INT_EN: Tx FIFO overflow interrupt.<br>IR_RX_FIFO_FULL_INT_EN: Rx FIFO full interrupt.<br>IR_RX_FIFO_LEVEL_INT_EN: Rx FIFO threshold interrupt.<br>IR_RX_CNT_OF_INT_EN: Rx counter overflow interrupt.<br>IR_RX_FIFO_OF_INT_EN: Rx FIFO overflow interrupt.<br>IR_RX_CNT_THR_INT_EN: Rx counter threshold interrupt.<br>IR_RX_FIFO_ERROR_INT_EN: Rx FIFO error read interrupt. Trigger when Rx FIFO empty and ready.<br>NewState: new state of the specified IR interrupts.<br>ENABLE<br>DISABLE |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 27.3.1.5 IR\_MaskINTConfig

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Mask or unmask the specified IR interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Parameters   | IRx: selected IR peripheral.<br>IR_INT: specifies the IR interrupt sources to be mask or unmask. This parameter can be one or combination of the following values:<br>IR_TX_FIFO_EMPTY_INT_MASK: Tx FIFO empty interrupt mask.<br>IR_TX_FIFO_LEVEL_INT_MASK: Tx FIFO threshold interrupt mask.<br>IR_TX_FIFO_OVER_INT_MASK: Tx FIFO overflow interrupt mask.<br>IR_RX_FIFO_FULL_INT_Msk: Rx FIFO full interrupt mask.<br>IR_RX_FIFO_LEVEL_INT_Msk: Rx FIFO threshold interrupt mask.<br>IR_RX_CNT_OF_INT_Msk: Rx counter overflow interrupt mask.<br>IR_RX_FIFO_OF_INT_Msk: Rx FIFO overflow interrupt mask.<br>IR_RX_CNT_THR_INT_Msk: Rx counter threshold interrupt mask.<br>IR_RX_FIFO_ERROR_INT_Msk: Rx FIFO error read interrupt mask. Trigger when Rx FIFO empty and ready.<br>NewState: new state of the specified IR interrupt mask.<br>ENABLE<br>DISABLE |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 27.3.1.6 IR\_GetINTStatus

| Items        | Description                                   |
|--------------|-----------------------------------------------|
| Introduction | Get the specified IR interrupt status.        |
| Parameters   | IRx: selected IR peripheral.                  |
| Return       | The new state of IR interrupt<br>SET<br>RESET |

### 27.3.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 interrupt<br>SET<br>RESET |

### 27.3.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>TRUE: RUN<br>FALSE: IDLE |

### 27.3.1.9 IR\_ClearINTPendingBit

| Items        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Clears the IR interrupt pending bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Parameters   | IRx: selected IR peripheral.<br>IR_CLEAR_INT: specifies <del>the</del> interrupt pending bit to clear. This parameter can be any combination of the following values:<br>IR_TX_FIFO_EMPTY_INT_CLR: Clear Tx FIFO empty interrupt.<br>IR_TX_FIFO_LEVEL_INT_CLR: Clear Tx FIFO threshold interrupt.<br>IR_TX_FIFO_OVER_INT_CLR: Clear Tx FIFO overflow interrupt.<br>IR_RX_FIFO_FULL_INT_CLR: Clear Rx FIFO full interrupt.<br>IR_RX_FIFO_LEVEL_INT_CLR: Clear Rx FIFO threshold interrupt.<br>IR_RX_CNT_OF_INT_CLR: Clear Rx counter overflow interrupt.<br>IR_RX_FIFO_OF_INT_CLR: Clear Rx FIFO overflow interrupt.<br>IR_RX_CNT_THR_INT_CLR: Clear Rx counter threshold interrupt.<br>IR_RX_FIFO_ERROR_INT_CLR: Clear Rx FIFO error read interrupt. Trigger when Rx FIFO empty FIFO. |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## 27.3.2 IR Tx APIs

### 27.3.2.1 IR\_SendBuf

| Items        | Description                  |
|--------------|------------------------------|
| Introduction | Send data buffer.            |
| Parameters   | IRx: selected IR peripheral. |

|        |                                                                                                                                                                                                                                                                                                                |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | <p>pBuf: data buffer to send.<br/>len: buffer length.<br/>IsLastPacket: this parameter can be the following values:<br/>ENABLE: The last data in IR packet and there is no continuous data. In other words, an infrared transmission completed.<br/>DISABLE: There is data to be transmitted continuously.</p> |
| 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 the length of data buffer, while IR\_SendData() only send one data once.

### 27.3.2.2 IR\_SendData

| Items        | Description                                         |
|--------------|-----------------------------------------------------|
| Introduction | Send one data.                                      |
| Parameters   | IRx: selected IR peripheral.<br>data: data to send. |
| Return       | N/A                                                 |

### 27.3.2.3 IR\_SetTxThreshold

| Items        | Description                                                              |
|--------------|--------------------------------------------------------------------------|
| Introduction | Set Tx threshold. When Tx FIFO depth threshold value, trigger interrupt. |
| Parameters   | IRx: selected IR peripheral.<br>thd: Tx threshold.                       |
| Return       | N/A                                                                      |

### 27.3.2.4 IR\_GetTxFIFOFreeLen

| Items        | Description                  |
|--------------|------------------------------|
| Introduction | Get free size of Tx FIFO.    |
| Parameters   | IRx: selected IR peripheral. |
| Return       | The free size of FIFO.       |

### 27.3.2.5 IR\_ClearTxFIFO

| Items        | Description                  |
|--------------|------------------------------|
| Introduction | Clear IR Tx FIFO.            |
| Parameters   | IRx: selected IR peripheral. |
| Return       | N/A                          |

## 27.3.3 IR Rx APIs

### 27.3.3.1 IR\_ReceiveBuf

| Items        | Description                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------|
| Introduction | Read data from Rx FIFO.                                                                         |
| Parameters   | IRx: selected IR peripheral.<br>pBuf: buffer address to receive data.<br>len: read data length. |
| Return       | N/A                                                                                             |

Note the difference between IR\_ReceiveBuf() and IR\_ReceiveData() is that IR\_ReceiveBuf() read a data buffer once and the number can 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().

### 27.3.3.2 IR\_ReceiveData

| Items        | Description                   |
|--------------|-------------------------------|
| Introduction | Read one data.                |
| Parameters   | IRx: selected IR peripheral.  |
| Return       | Data which read from Rx FIFO. |

### 27.3.3.3 IR\_SetRxThreshold

| Items        | Description                                                               |
|--------------|---------------------------------------------------------------------------|
| Introduction | Set Rx threshold. When Rx FIFO depth > threshold value, trigger interrupt |
| Parameters   | IRx: selected IR peripheral.<br>thd: Rx threshold.                        |
| Return       | N/A                                                                       |

### 27.3.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. |

### 27.3.3.5 IR\_ClearRxFIFO

| Items        | Description                  |
|--------------|------------------------------|
| Introduction | Clear IR Rx FIFO.            |
| Parameters   | IRx: selected IR peripheral. |
| Return       | N/A                          |

### 27.3.3.6 IR\_SetRxCounterThreshold

| Items        | Description                                                                                                                                                                                                                                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Configure counter threshold value in receiving mode. You can use it to stop receiving IR data.                                                                                                                                                                                                                                                                       |
| Parameters   | IRx: selected IR peripheral.<br>IR_RxCntThrType: This parameter can be following values:<br>IR_RX_Count_Low_Level: Low level counter value >= IR_RxCntThr, trigger IR_INT_RX_CNT_T<br>IR_RX_Count_High_Level: High level counter value >= IR_RxCntThr, trigger IR_INT_RX_CNT_T<br>IR_RxCntThr: Configure IR Rx Counter threshold value which can be 0 to 0xffffffff. |
| Return       | N/A                                                                                                                                                                                                                                                                                                                                                                  |

### 27.3.3.7 IR\_StartManualRxTrigger

| Items        | Description                                                                           |
|--------------|---------------------------------------------------------------------------------------|
| Introduction | Start trigger only in manual receive mode.<br>Note manualreceive mode is seldom used. |
| Parameters   | IRx: selected IR peripheral.                                                          |
| Return       | N/A                                                                                   |

## 27.4 IR Usage

### 27.4.1 Sending

#### 27.4.1.1 Tx Polling Mode

To use IR sending function, the following steps are mandatory.

- (1) Configure the IR pinmux according to Table 27-1.

For example, in order to BB[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(3)tep  
`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.

You can refer to section 27.4.1.1.

#### 27.4.1.2 Special Notes

##### 27.4.1.2.1 Tx FIFO Offset Issue

@ TX\_FIFO\_OFFSET.

##### 27.4.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 the end of data packets to Tx FIFO. You can refer to step(2)and step(6)in section 27.4.1.1.

## 27.4.2 Receiving

### 27.4.2.1 Rx Interrupt Mode

To use IR receiving function, the following steps are mandatory.

- (1) Configure the IR pinmux according to Table 27-1.

For example, in order to BB[22] as 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 threshold type, Rx count threshold level, Rx trigger mode if needed.  
`IR_StructInit(IR_InitTypeDef *IR_InitStruct);`
- (3) Initialize hardware using the parameters in(2)tep  
`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 `RgClearRxFIFO()`.
- (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 27.2.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`.

#### 27.4.2.2 Rx Learning

The process of Rx learning is similar to common Rx introduced in section 27.4.2. As shown in Fig 27-3, the difference is that in interrupt handle function, Rx learning should store each pulse of the Rx waveform, while common Rx stores only the carrier duration.



Fig 27-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 interference. If the carrier frequency of learning waveform is larger than 400Hz, software may cannot respond to interrupt in time, which will result in decoding carrier frequency failed.

### 27.5 Tx Compensation Mechanism

#### 27.5.1 Introduction

Tx waveforms are composed of some carrier symbols and data 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 the compensation mechanism, the error will increase. So Tx compensation is proposed in IR Tx to decrease the error.

@ skip this section. Next we would introduce the application of compensation mechanism.

#### 27.5.2 Tx Compensation Mechanism Application

Take NEC application for example, the Tx NEC waveform in Fig 27-4 is with carrier frequency = 38kHz and duty = 1/3. The system clock is 100MHz.

For 38kHz carrier frequency



Compensation frequency is a dependent clock you can set to any value you want. In this example, we set 1MHz, so



Fig274Tx NEC waveform

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 (IR\_TX\_COMPENSATION = 0), the real wave can be calculated as follows.

The first carrier symbol: Referring to  $21 * 26.31 + 8.77 = 561.28\text{us}$ .

The second no carrier symbol:  $= 64, (2250 - 560)\text{us} = 1690\text{us}$ .

The third carrier symbol is the same as the first one.

The forth no carrier symbol:  $= 64, 560\text{us} = 21 * 26.31 + (26.31 - 8.77) = 570.05\text{us}$ .

If compensation mechanism is adopted (IR\_TX\_COMPENSATION ≠ 0), the real wave can be calculated as follows.

The first carrier symbol: Referring to  $21 * 26.31 + 8.77 = 561.28\text{us}$ .

The second no carrier symbol:  $= 1690, (2250 - 560)\text{us} = 1690\text{us} = 1690 * 1\text{us}$ .

The third carrier symbol is the same as the first one.

The forth no carrier symbol:  $= 560\text{us} = 560 * 1\text{us}$ .

Compare the above two calculating methods, we can find that by compensation mechanism, the accuracy can be improved.

#### Note

Compensation mechanism can only be used for no carrier symbol.

IR\_TX\_COMPENSATION is bit[28:29] of IR\_TX\_FIFO register. Compensation method 0 (IR\_TX\_COMPENSATION = 0) 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).

## 27.6 IR Schematic Design Guideline

### 27.6.1 Leakage

To avoid the leakage problem, we suggest using the circuit which is shown in Fig275.



Fig27-5 Circuit of IR

## 27.6.2 Carrier Problem in Rx Learning

Due to the characteristics of transistor, the response speed will slow down when work in deep saturation area. Therefore, when carrier frequency is set too large, the hardware has the risk of receiving carrier waveform failed in receiving, and the maximum carrier frequency that can achieve is related to the choice of transistor. The circuit we suggested support the maximum carrier frequency 70kHz, but you can choose the better transistor to support higher supported carrier frequency.

## 28 Brownout Detector(BOD)

BOD is mainly used to notify a user that the voltage level is low for the applications which use battery. BOD provides many thresholds to choose, the alternative levels and corresponding voltage value is shown in Table281 and Note: The voltage value may have 5% error.

Table282

Table281 High threshold of interrupt mode and reset mode (3.3V/1.8V)

| Voltage | Value | Symbol       | Reset | Interrupt |
|---------|-------|--------------|-------|-----------|
| 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     |

Note: The voltage value may have 5% error.

Table282 Low threshold of interrupt mode and reset mode (3.3V/1.8V)

| Voltage | Value | Symbol      | Reset | Interrupt |
|---------|-------|-------------|-------|-----------|
| 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 5% error.

### 28.1 Recommended Threshold Parameter

The recommended threshold parameters are shown in Table283

Table283 Recommended Threshold Parameter

| Work Voltage | Reset         |              | Interrupt     |              |
|--------------|---------------|--------------|---------------|--------------|
|              | HighThreshold | LowThreshold | HighThreshold | LowThreshold |
| 3.3V         | BOR_TH_HIGH1  | BOR_TH_LOW1  | BOR_TH_HIGH7  | BOR_TH_LOW7  |
| 1.8V         | BOR_TH_HIGH1  | BOR_TH_LOW1  | BOR_TH_HIGH7  | BOR_TH_LOW7  |

Note: To avoid voltage fluctuation during work, trigger BOD interrupt or reset by mistake, the difference between low threshold and high threshold should be appropriately increased.

## 28.2 BOD APIs

### 28.2.1 BOR\_ModeSet

| Items        | Description                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------|
| Introduction | Choose BOD mode and enable BOD function                                                               |
| Parameters   | Option<br>BOR_RESET: BOD reset mode<br>BOR_INTR: BOD interrupt mode<br>NewStatus<br>ENABLE<br>DISABLE |
| Return       | N/A                                                                                                   |

### 28.2.2 BOR\_ThresholdSet

| Items        | Description                                                                                                                                                                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Set BOD high and low threshold                                                                                                                                                                                                                                                          |
| Parameters   | Thres_Low: BOD low threshold<br>BOR_TH_LOW1<br>BOR_TH_LOW2<br>BOR_TH_LOW3<br>BOR_TH_LOW4<br>BOR_TH_LOW5<br>BOR_TH_LOW6<br>BOR_TH_LOW7<br>Thres_High: BOD high threshold<br>BOR_TH_HIGH1<br>BOR_TH_HIGH2<br>BOR_TH_HIGH3<br>BOR_TH_HIGH4<br>BOR_TH_HIGH5<br>BOR_TH_HIGH6<br>BOR_TH_HIGH7 |
| Return       | N/A                                                                                                                                                                                                                                                                                     |

### 28.2.3 BOR\_ClearINT

| Items        | Description          |
|--------------|----------------------|
| Introduction | Clear BOD interrupt. |
| Parameters   | N/A                  |
| Return       | N/A                  |

### 28.2.4 BOR\_DbncSet

| Items        | Description                            |
|--------------|----------------------------------------|
| Introduction | Set BOD interrupt mode debounce cycle  |
| Parameters   | Option<br>BOR_INTR: BOD interrupt mode |

|        |                                                            |
|--------|------------------------------------------------------------|
|        | Dbnc_Value: debounce cycle, in unit of ANA4M clock cycles. |
| Return | N/A                                                        |

Note: Only BOD interrupt mode can settlebouncecycle

# 29 Flash Translation Layer(FTL)

## 29.1 Overview

NOR-Flash is composed of blocks, which contain pages, and they contain individual cells of data. Flash write operations take place at page level. But erase operations take place at the block level. The flash needs to be erased. 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 has been introduced, which is provided to make the flash a friendly medium to store data. The architecture of flash memory system is shown in Fig 291.



Fig 291 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

As Fig 292 shows, to write data to logical map, FTL would generate a data packet in specified format and store it in flash. To modify 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 `7 u O`



Fig292 FTLOverview

## 29.2 Features

### Physical Map

- Physical page size: 4096 bytes
- Configurable physical page number
- Physical map size =  $4096 * \text{physical page number}$
- Logical Map: The maximum logical map size determined by  $\text{physical map size} * (\text{physical page number} - 1) * 4$ .
- Auto Garbage Collection
- Abnormal Poweroff Protection

## 29.3 FTL APIs

|                                            |                                                 |
|--------------------------------------------|-------------------------------------------------|
| API                                        | Introduction                                    |
| <code>&lt;ftl_init&gt;</code>              | Initializes FTL                                 |
| <code>&lt;ftl_load_from_storage&gt;</code> | Gets specified length of data from logical map. |
| <code>&lt;ftl_save_to_storage&gt;</code>   | Writes specified length of data to logical map. |

### 29.3.1 `ftl_init`

| Items        | Description                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------|
| Introduction | Initializes FTL                                                                                                    |
| Parameters   | <u>u32</u> <u>PageStartAdd</u> The start address of physical map<br><u>pagenum</u> The page number of physical map |
| Return       | N/A                                                                                                                |

### 29.3.2 `ftl_load_from_storage`

| Items        | Description                                                                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Gets specified length of data from logical map.                                                                                                                 |
| Parameters   | <u>pdata_tmp</u> Pointer to buffer to save logical data<br><u>offsetFrom</u> From which address read the logical map<br><u>size</u> The number of bytes to read |
| Return       | 0 Getting logical map values successfully<br>Others: Failed to get logical map value                                                                            |

## 29.3.3ftl\_save\_to\_storage

| Items        | Description                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction | Writes specified length of data to logical map.                                                                                                |
| Parameters   | pdata_tmpPointer to byte array of new logical data<br>offsetFrom which address to update the logical map<br>size The number of bytes to update |
| Return       | 0 Writing logical map values successfully<br>Others: Failed to write logical map value                                                         |

## 29.4 How to Use FTL

### 29.4.1 Precautions

When using FTL, you must follow the precautions below:

Theoretically, the logical map area can be extended to 64KB; but the maximum usable logical map area is limited by the actual physical space  $(511 * (\text{physical page number})^4) * 4$ .

The default physical page number is 3 and it is not recommended to increase it because the default internal implementation of FTL will allocate a buffer to cache the content of FTL.

For typical BLE application, each connection needs about 256bytes FTL memory, and SDK will maintain 3 connections information by default.

For BLE mesh, each node needs about 20bytes FTL memory. The maximum node number can be set by dev\_key\_num.

Table291 lists the typical scenarios of BLE, refer to it to set the appropriate offset application according to your actual situation.

Table291 Examples of recommended setting

| Scenario                                                                  | Calculation                                                           | Start address of application |             | Remark                                                                                                                                                                                            |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                           |                                                                       | Configurable                 | Recommended |                                                                                                                                                                                                   |
| 3 connections<br>Less than 50 mesh nodes<br>1KB FTL space for application | $((3 * 256 + 20 * 50) + 1024)$ bytes (< 4084bytes) are needed totally | 1768~3060                    | 2500        | It is recommended to reserve some memory for system extension. The recommended offset has some reservation for both system and application. For these two scenarios, 3 physical pages are enough. |
| 5 connections<br>2KB FTL space for application                            | $(5 * 256 + 2048)$ bytes (< 4084bytes) are needed totally             | 1280~2036                    | 1600        |                                                                                                                                                                                                   |
| 5 connections<br>Less than 60 mesh nodes<br>6KB FTL space for application | $((5 * 256 + 20 * 60) + 6144)$ bytes are needed totally               | -                            | -           | It is not recommended to store so much information in FTL. Try to find another solution such as DCT.                                                                                              |

### 29.4.2 General Steps

To use FTL in AmebaD the following steps are necessary.

(1) Define the macro CONFIG\_FTL\_ENABLED by yourself and set it to 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) Define FTL\_MEM\_CUSTEM in rtl8721dhp\_intfcfg.c

```

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

```

Note: If the memory layout is modified and overwrites FTL table address 0x0810\_000\_0x0810\_4FFF, you also need to modify the physical page address. Otherwise, an error would be thrown out to remind.

```
cd /cygdrive/e/AmebaD/AmebaD_svn/project/realtek_amebaD_cm4_gcc_verification/asdk/../../../../component/soc/realtek/amebad/fwlib/usrcfg/tl8721dhp_intfcfg.c  
-o rt18721dhp_intfcfg.o  
/cygdrive/e/AmebaD/AmebaD_svn/project/realtek_amebaD_cm4_gcc_verification/asdk/../../../../component/soc/realtek/amebad/fwlib/usrcfg/tl8721dhp_intfcfg.c:64:2: error: #error "You should allocate flash sectors to for FTL physical map as following, then set FTL_MEM_CUSTOM 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_CUSTOM 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.include.gen:449: rt18721dhp_intfcfg.o] Error 1  
make[4]: Leaving directory '/cygdrive/e/AmebaD/AmebaD_svn/project/realtek_amebaD_cm4_gcc_verification/asdk/make/target/fwlib'  
make[3]: *** [Makefile:19: all] Error 2
```

The default configuration for logical & physical map follows:

3 pages allocated for physical 0x0810\_000\_0x0810\_4FFF  
Logical map size 4084 bytes

- (3) Call `ftl_load_from_storage`/`ftl_save_to_storage` functions to read from/write to logical map.

# 30 Audio Signal Generation and Analysis

## 30.1 Introduction

When developing digital audio related applications, you may need to generate a signal of a certain frequency to test whether it works well or not. This chapter introduces how to generate a signal and how to analyze the signals collected by the DMIC first. Then, digital analog (analog digital) loopback is explained. DAAD loopback is helpful in determining which part (codec or driver) work well when problems occur.

### 30.1.1 Compilation

You need to add `example_audio_signal_generate.c` to your project before you can use all the commands mentioned in this chapter. Related files are placed under the path `path/component/common/example/audio_sport/audio_signal_generate`.

Follow two steps to use this function:

- (1) Open the file `V_O_V_k.c` under the path: `/project/realtek_amebaD_vao_example/inc_hp`
- (2) In Cygwin terminal, change to the directory `/project/realtek_amebaD_vao_example`, run `CCRELEASE project_hptypemake menuconfig`, and enable audio related configuration (`MENUCONFIG FOR CHIP CONFIG Audio Config Enable Audio`).

### 30.1.2 Generating a Signal of Certain Frequency

Frequencies of signals supported by the program range from 20Hz to 20000Hz, which is the frequency range that people can hear.

Type `f` to generate a signal whose frequency is between 20Hz and 20000Hz.

### 30.1.3 Analyzing Signals Collected by DMIC

One way of testing DMICs is to analyze the signals collected by DMIC in frequency domain. If the detected frequency is the same as the frequency of the signal, DMIC works well.

Type `f` to analyze the signals collected by DMIC in frequency domain. The main frequency and relative strength will be printed out. Due to frequency leakage, the frequency detected may not be the same as the one you play, but the number should be close. You can use this command to analyze signals whose frequencies range from 20~20000Hz.

### 30.1.4 DAAD

DMIC related problems can be caused by internal codec itself. This section explains how to use DAAD loopback to determine whether the internal codec works in a normal way or not.

Fig 30.1 depicts how DAAD loopback works. Data transmitted from DA Digital IP is received directly by AD Digital IP without the interference of DMIC.

Type `c` to generate a signal whose frequency is `f`. The main frequency detected and relative strength calculated will be printed. If the frequency detected is close to the one you generated, it means that the internal codec works well. The problem may be caused by DMIC.

Fig301 DAAD loopbackdiagram

### 30.1.5 Command

All the commands that can be used are listed in Table301. Each command is composed of several parameters which are surrounded by \$ should be set by users.

Table301 Available commands in audio signal generation and analysis

| Command Format               | Command Function | Example |
|------------------------------|------------------|---------|
| Audio_generate tone \$pr (\$ | Generator        |         |