

# **Development Guide of DWIN OS Platform Based on T5L CPU**

## Contents

| 1. DWIN OS Platform Structure       | 2        |
|-------------------------------------|----------|
|                                     | 4        |
| 3. Storage Space                    | 5        |
| 3.1 Users Data Library              | 5        |
| 3.2 Data Variable Space             | 5        |
| 3.3 Register                        |          |
| 3.4 Port Register                   |          |
| 4. DWIN OS Assembly Instruction Set |          |
| 4.1 Data Exchange                   |          |
| 4.2 Computation                     |          |
|                                     |          |
| 4.4 Data Processing                 |          |
|                                     |          |
| 4.6 Peripheral Operation            | <b>9</b> |
| 5. Appendix                         |          |





## 1. DWIN OS Platform Structure

#### (1) DWIN OS Code Space Definition

| Code Address  | Definition | Description                                                                                               |  |
|---------------|------------|-----------------------------------------------------------------------------------------------------------|--|
| 0x0000-0x0FFF | L2_Cache   | The space of program dynamically loads and calls, 4KB.                                                    |  |
| 0x1000        | RESET      | The start address of program operating when reset, place one GOTO command to jump to the main program.    |  |
| 0x1004        | T0 _INT    | The entrance address of T0 INT program, applying GOTO command to jump to T0 interrupting service program. |  |
| 0x1008        | T1 _INT    | The entrance addressT1 INT program, applying GOTO command to jump to T1 interrupting service program.     |  |
| 0x100C        | T2 _INT    | The entrance address T2 INT program, applying GOTO command to jump to T2 interrupting service program.    |  |
| 0x1020-0x107F | Reserved   | Reserved.                                                                                                 |  |
| 0x1080-0x7FFF | Main Code  | Main program code space.                                                                                  |  |

(2) The max nested call of subroutine including interrupted program, up to grade 127.



(3) Typical program structure.

| ORG 1000H                           |                                                                                           |
|-------------------------------------|-------------------------------------------------------------------------------------------|
| GOTO MAIN                           | ; The first command must GOTO.                                                            |
| GOTO TOINT                          | ; When interrupt, jumping to T0 to interrupting program, must use GOTO, can not use CALL. |
| NOP                                 | ; T1 Discontinuity not be used.                                                           |
| GOTO T2INT                          | ; Discontinuity produces, jumping to T2 to interrupting service program.                  |
| ORG 1080H<br>MAIN: NOP<br>GOTO MAIN | ; Main program                                                                            |
| T0INT: NOP<br>RET1                  | ; T0 interrupt handling<br>; Use RETI end, can not use RET.                               |
| T1INT: NOP<br>RET1                  | ; T1 interrupt handling                                                                   |

If interrupts were not adopted(closed the interrupt), the code space of 0x1004-0x107F could be used at will.

If the main program is needed to operate breakpoint simulation, the interrupt shall be closed. otherwise, the timer keeps running under simulation status, opening interrupt would cause the main program to fail operating breakpoint simulation.

www.dwin.com.cn

silino M



# 2. DWIN OS Debugging Port (UART2)

System debug serial port UART2's mode is 8N1, baud rate can be installed, data frame is made up by 5 parts.

| Data                          | 1            | 2                                    | 3                    | 4        | 5                       |
|-------------------------------|--------------|--------------------------------------|----------------------|----------|-------------------------|
| Definition                    | Frame Header | Data Length                          | Command              | Data     | CRC Check<br>(Optional) |
| Data Length                   | 2            | 1                                    | 1                    | n        | 2                       |
| Description                   | 0x5AA5       | Including command,<br>data and check | 0x80/0x81/0x82//0x83 |          |                         |
| Example<br>(without<br>check) | 5A A5        | 04                                   | 83                   | 00 10 04 |                         |
| Example<br>(with check)       | 5A A5        | 06                                   | 83                   | 00 10 04 | 25 A3                   |

#### Explanation of UART2 debug port instruction below:

| Instruction                                              | Data                                                                | Description                                                                              |
|----------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| 0x80                                                     | Issue: ADR(0x00-0x08)+ADR(0x00-0xFF)+Data_Pack                      | Write data in designated addresses in register.                                          |
| 0,00                                                     | Respond: 0x4F 0x4B                                                  | Write command respond.                                                                   |
| 0x81                                                     | Issue: ADR (0x00-0x08)+ADR(0x00-0xFF)+ RD_LEN (0x01-<br>0xFB)       | Read data in designated addresses in register.                                           |
|                                                          | Respond: ADR(0x00-0x08)+ADR(0x00-<br>0xFF)+RD_LEN+Data_Pack         | Response with data.                                                                      |
| 0x82                                                     | Issue: First ADR(0x0000-0xFFFF)+Data_Pack                           | Write data in designated addresses in variable SRAM.                                     |
|                                                          | Respond: 0x4F 0x4B                                                  | Write Instruction respond.                                                               |
| 0x83 Issued: First ADR (0x0000-0xFFFF) + RD_LEN (0x01-0> |                                                                     | Read the specified length of word data from the specified address in the variable space. |
|                                                          | Respond: First ADR + variable data word length + read variable data | Response with data.                                                                      |

#### Data respond register page is defined as follow:

| Register Page ID | Definition    | Description                                                                                                   |
|------------------|---------------|---------------------------------------------------------------------------------------------------------------|
| 0x00-0x07        | Data Register | Each group 256, R0-R255                                                                                       |
| 0x08             | Port Register | DR0-DR255<br>Details in DWIN OS development guide basing on T5L, 3.4 port register definition<br>description. |



## 3. Storage Space

### 3.1Users Data Library

Include two parts:

(1) The flash in the T5L chip can be accessed by system variable interface and all DWIN OS based on T5 can be supported.

(2) A large database or data store located on an off-chip flash, accessed through a system variable interface, depending on the hardware platform.

## 3.2 Data Variable Space

The data variable space is a 128kbytes double-port RAM, the separated of T5L core can exchange data, the definition as below:

| Variable<br>Port Interval | Interval<br>(K words) | Definition                   | Description                                                                                          |
|---------------------------|-----------------------|------------------------------|------------------------------------------------------------------------------------------------------|
| 0x0000-0x03FF             | 1.0                   | System variable port         | Hardware, storage visit control, data exchange. detailed definition is related to hardware platform. |
| 0x0400-0x07FF             | 1.0                   | Reserved                     | Users do not apply.                                                                                  |
| 0x0800-0x0BFF             | 1.0                   | Reserved                     | Users do not apply.                                                                                  |
| 0x0C00-0x0FFF             | 1.0                   | Reserved                     | Users do not apply.                                                                                  |
| 0x1000-0xFFFF             | 60                    | Users variable<br>data/space | Users variable, storage read, write buffer and so on, users program by themselves.                   |

At all DWIN OS platform based on T5L CPU, the first 16-word definition of system variable port is unified, shown as follows:

| Address | Definition           | Length | Description                                                                                                                                                                                                                                                                                                                                                            |
|---------|----------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00    | Reserve              | 4      |                                                                                                                                                                                                                                                                                                                                                                        |
| 0x04    | System_Reset         | 2      | 0x55AA 5AA5=reset T5L;                                                                                                                                                                                                                                                                                                                                                 |
| 0x06    | OS_Update_CMD        | 2      | <ul> <li>D3: 0x5A first updates DWIN OS program(inserting into ram Flash), clearing after CPU operation finish.</li> <li>D2: Fixing as 0x10, DWIN OS code should be start from 0x1000.</li> <li>D1: 0:The initial data variation space address of store-and-update code 0x1000-0x0C7E should be even.</li> </ul>                                                       |
| 0x08    | NOR_<br>Flash_RW_CMD | 4      | <ul> <li>D7: operation mode 0x5A=read 0xA5=write, clearing after CPU operation finished.</li> <li>D6: 4: the initial address of ram Nor Flash data base should be even. 0x000000-0x02:</li> <li>FFFE, 256KWords.</li> <li>D3: 2: the initial data variation space address should be even.</li> <li>D1: 0: the length of read and write word should be even.</li> </ul> |
| 0x0C    | UART2_Set            | 2      | D3=0x5A means UART2 serial mode setting, only used for GUI CPU setting, UART2<br>mode after reset, OS can not operate itself.<br>D2=serial mode, 0x00=8N1.<br>D1: D0=baud rate value, baud rate value=3225600/set baud rate.                                                                                                                                           |
| 0x0E    | Reserve              | 1      |                                                                                                                                                                                                                                                                                                                                                                        |
| 0x0F    | Ver                  | 1      | Application software version. D1 refers to CPU0 soft version, D0 refers to CPU1 software version.                                                                                                                                                                                                                                                                      |



Since variable memory is shared by two CPU cores, too frequent continuous reading and writing variable memory will seriously affect the processing efficiency of the CPU. Therefore, a 1mS timer interrupt is used to periodically query the data update of variable memory.

#### 3.3 Register

DWIN OS based on T5L has a total of 2048 registers, divided into 8 pages for access, each page has 256 registers, corresponding to R0-R255.

#### 3.4 Port Register

Based on T5L, DWIN OS has a port register page, with 256 port registers, as a quick visit port for hardware resources.

| DR# | Length | R/W | Definition       | Description                                                                                                                             |
|-----|--------|-----|------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0   | 1      | R/W | REG_Page_Sel     | 8 register pages of OS change, DR0=0x00-0x07                                                                                            |
| 1   | 1      | R/W | SYS_STATUS       | System status register, bitwise definition:<br>.7 CY carry flag.<br>.6 DGUS screen variation automatic uploading control 1=close 0=open |
| 2   | 14     |     | System Reserve   | Access forbidden.                                                                                                                       |
| 16  | 1      | R   | UART3_TTL_Status |                                                                                                                                         |
| 17  | 1      | R   | UART3_TTL_Status | G                                                                                                                                       |
| 18  | 1      | R   | UART4_TTL_Status | Serial received frame overtime timer status:<br>0x00= received frame overtime timer overflowing others=no overflowing.                  |
| 19  | 1      | R   | UART5_TTL_Status | It should be done first that applying RDXLEN command reads received length, when length is not 0, then checking overtime timer status.  |
| 20  | 1      | R   | UART6_TTL_Status |                                                                                                                                         |
| 20  | 1      | R   | UART7_TTL_Status |                                                                                                                                         |
| 21  | 1      |     | Reserve          |                                                                                                                                         |
| 22  | 1      | R   | UART3_TX_LEN     | UART3 the applying depth(Bytes) of buffer sending buffer size is 256Bytes, users read only.                                             |
| 23  | 1      | R   | UART4_TX_LEN     | UART4 the applying depth(Bytes) of buffer sending buffer size is 256Bytes, users read only.                                             |
| 24  | 1      | R   | UART5_TX_LEN     | UART5 the applying depth(Bytes) of buffer sending buffer size is 256Bytes, users read only.                                             |
| 25  | 1      | R   | UART6_TX_LEN     | UART6 the applying depth(Bytes) of buffer sending buffer size is 256Bytes, users read only.                                             |
| 26  | 1      | R   | UART7_TX_LEN     | UART7 the applying depth(Bytes) of buffer sending buffer size is 256Bytes, users read only.                                             |
| 27  | 1      |     | Reserve          |                                                                                                                                         |
| 28  | 1      | R/W | UART3_TTL_SET    | UART3 the time of received frame overtime timer. Unit 0.5mS, 0x01-0xff, power-on set as 0x0A.                                           |
| 29  | 1      | R/W | UART4_TTL_SET    | UART4 the time of received frame overtime timer. Unit 0.5mS, 0x01-0xff, power-on set as 0x0A.                                           |



| 30 | 1  | R/W | UART5_TTL_SET    | UART5 the time of received frame overtime timer. Unit 0.5mS, 0x01-0xff, power-on set as 0x0A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----|----|-----|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 | 1  | R/W | UART6_TTL_SET    | UART6 the time of received frame overtime timer. Unit 0.5mS, 0x01-0xff, power-on set as 0x0A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 32 | 1  | R/W | UART7_TTL_SET    | UART7 the time of received frame overtime timer. Unit 0.5mS, 0x01-0xff, power-on set as 0x0A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 33 | 1  |     | Reserve          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 34 | 1  | R/W | ТО               | 8bit user timer 0, ++counting, datum 10uS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 35 | 2  | R/W | T1               | 16bit user timer 1, ++ counting, datum 10uS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 37 | 2  | R/W | T2               | 16bit user timer 2, ++ counting, datum designed by users through CONFIG command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 39 | 2  | R/W | Т3               | 16bit user timer 3, ++ counting, datum designed by users through CONFIG command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 41 | 1  | R/W | CNT0_Sel         | Relevant position 1 choosing related I/O to counting changes, corresponding IO7-IO0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 42 | 1  | R/W | CNT1_Sel         | Relevant position 1 choosing related I/O to counting changes, corresponding IO7-IO0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 43 | 1  | R/W | CNT2_Sel         | Relevant position 1 choosing related I/O to counting changes, corresponding IO15-IO8.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 44 | 1  | R/W | CNT3_Sel         | Relevant position 1 choosing related I/O to counting changes, corresponding IO15-IO8.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 45 | 1  | R/W | Int_Reg          | Interrupting control register.<br>.7=Interrupt main switch 1= enable(open or not depending on single<br>interrupting control position) 0=ban.<br>.6=Timer INT0 Enable 1=interrupt timer 0 interrupt on 0=interrupt timer 0<br>interrupt off.<br>.5=Timer INT1 Enable 1=interrupt timer 1 interrupt on 0=interrupt timer 1<br>interrupt off.<br>.4=Timer INT2 Enable 1=interrupt timer 2 interrupt on 0=interrupt timer 2<br>interrupt off.                                                                                                                                                                                                               |
| 46 | 1  | R/W | Timer INT0 Set   | 8Bit timer interrupt 0 settings value, interrupt time=timer_INT0_Set*10uS, 0x00=256.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 47 | 1  | R/W | Timer INT1 Set   | 8Bit timer interrupt 1 setting value, interrupt time=timer_INT1_Set*10uS, 0x00=256.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 48 | 2  | R/W | Timer INT2 Set   | 16Bit timer interrupt 2 setting value, interrupt time=timer_INT2_Set+1*10uS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 50 | 10 | R/W | Polling_Out0_Set | The firstly IO0-IO15 scans output configuration timely, 10 bites each.<br>D9(DR50): 0x5A=scan output applying, other as no applying.<br>D8: Outputting register page of data, 0x00-0x07.<br>D7: Outputting start and end address of data, 0x00-0xFF<br>D6: Outputting the word length of data, 0x01-0x80, each data 2 Bytes<br>corresponding to IO15-IO0.<br>D5-D4: IO15-IO0 output aisle choosing, needing output aisle, corresponding bit<br>set as 1.<br>D3-D2: single outputting interval T, unit as (T+1) *10uS.<br>D1-D0: Outputting cycle counting designed, it minus 1 after finishing 1 cycle<br>every time, then outputting 0 till minus to 0. |
| 60 | 10 | R/W | Polling_Out1_Set | The second IO0-IO15 scans output configuration timely.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 70 | 9  |     | Reserve          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 80 | 6  | R/W | IO6 Trigger time | D5=0x5A means that an IO 6 falling edge trigger is captured.<br>D4: D3=IO15-IO0's condition when triggered.<br>D2: D0=the catching time of system timer 0x000000-0x00FFFF cycle, unit as 1/41.75uS.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



| 86  | 6   | R/W | IO7 Trigger time | D5=0x5A means that an IO7 falling edge trigger is captured.<br>D4: D3=IO15-IO0's condition when triggered.<br>D2: D0=the catching time of system timer 0x000000-0x00FFFF cycle, unit as 1/41.75uS. |  |  |
|-----|-----|-----|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 92  | 37  |     | Reserve          |                                                                                                                                                                                                    |  |  |
| 129 | 3   | R/W | IO_Status        | The real-time status of IO19-IO0's                                                                                                                                                                 |  |  |
| 132 | 2   | R/W | CNT0             | CNT0 changing counting value, resetting to 0x0000 when counting to 0xFFFF.                                                                                                                         |  |  |
| 134 | 2   | R/W | CNT1             | CNT1 changing counting value, resetting to 0x0000 when counting to 0xFFFF.                                                                                                                         |  |  |
| 136 | 2   | R/W | CNT2             | CNT2 changing counting value, resetting to 0x0000 when counting to 0xFFFF.                                                                                                                         |  |  |
| 138 | 2   | R/W | CNT3             | CNT3 changing counting value, resetting to 0x0000 when counting to 0xFFFF.                                                                                                                         |  |  |
| 140 | 116 |     | Reserve          |                                                                                                                                                                                                    |  |  |
|     | Q   |     |                  | technology                                                                                                                                                                                         |  |  |



## 4. DWIN OS Assembly Instruction Set

- (1) R# means DWIN OS in present register page, any or any group of 256 register, R0-R255;
- (2) DR# means one or any group of 256 port register, DR0-DR255;
- (3) < >means Immediate number, in the Assembly code,100, 0x64, 64H, 064H all means 10 hex data 100.
- (4) Pseudo directives: ORG DB DW.
- (5) Use; as a comment symbol.
- (6) Description of variable and data type can be visited by DWIN OS as following:

| Variable Type       | Mark      | Туре | Space                 | Description                                              |
|---------------------|-----------|------|-----------------------|----------------------------------------------------------|
| DWIN OS register    | R0-R255   | Byte | 2048 Bytes            | Divided into 8 pages, control page by DR0 port register. |
| Port register       | DR0-DR255 | Byte | 256 Bytes             |                                                          |
| Data variable space | XRAM      | Word | 64K Words             | Range of address: 0x0000-0xFFFF                          |
| User data library   | LIB       | Word | Depend on<br>hardware | 20                                                       |

(7)When T5L CPU runs at the speed of 200MHz, the average operating time of one DWIN OS command is about 125nS (8MIPS).

### 4.1Data Exchange

| Command Function                                                       | Code  | Number                                                                                           | Description                                                                                                                                                                                                                                                                                     |  |
|------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Data exchange<br>between Variables &<br>Registers                      | MOVXR | R#, <mod>,<br/><num></num></mod>                                                                 | R#:Register or Register group.<br><mod>: 0=Register to variable 1=Variable to register.<br/><num>: exchange data word (Word) length, 0x00-0x80;<br/>When<num>is 0x00, data length depends on R9.<br/>Data variable pointer is defined by R0: R1 register.<br/>MOVXR R20, 0, 2</num></num></mod> |  |
| Load N 8bit<br>Immediate number to<br>register group                   | LDBR  | R#, <data>,<br/><num></num></data>                                                               | R#: Register or Register group.<br><data>: Data need loading.<br/><num>: Number of Register need loading, 0x00 means 256.<br/>LDBR R8, 0x82, 3</num></data>                                                                                                                                     |  |
| Load 1 16 bit<br>numbers to Registers                                  | LDWR  | R#: Register group.<br><data>: Number of that loading<br/>LDWR R8,1000.<br/>LDWR R8, -300</data> |                                                                                                                                                                                                                                                                                                 |  |
| Load address code<br>space                                             | LDADR | <address></address>                                                                              | Load <address> to R5: R6: R7 LDADR TAB<br/>LDADR 0x123456</address>                                                                                                                                                                                                                             |  |
| Look up in Program<br>Space (Program<br>Space to DWIN_OS<br>Registers) | MOVC  | R#, <num></num>                                                                                  | R#: Register or Register group.<br><num>: byte data length Look up table return Address pointer is<br/>defined by R5: R6: R7 register MOVC R20,10<br/>Attention, code after 0x1000 can not read code content before 0x1000.</num>                                                               |  |
| Data transfer from<br>Register to DGUS<br>Register                     | MOV   | R#S, R#T,<br><num></num>                                                                         | R#S: Origin register or register group R#T: goal register or register<br>group.<br><num>: Font data length exchanged, 0x00 means length is defined by<br/>R9 register.<br/>MOV R8, R20, 3</num>                                                                                                 |  |



| Register to port<br>register              | MOVRD | R#, DR#,<br><num></num> | R#: Register or Register group; DR#:Port Register or Register group;<br><num>: Font data length exchanged, 0x00 means length is defined by<br/>R9 register.<br/>MOVRD R10, 3, 2</num>                                                                                                                                                                                                                 |
|-------------------------------------------|-------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port register to register                 | MOVDR | DR#, R#,<br><num></num> | R#: Register or register group; DR#:port register or register group;<br><num>: Font data length exchanged, 0x00 means length is defined b<br/>R9 register.<br/>MOVDR 3, R10, 2</num>                                                                                                                                                                                                                  |
| Exchange data<br>between<br>data variable | MOVXX | <num></num>             | <num>: exchange (Word) length of data.<br/><num> 0 means length is defined by R8: R9 register Origin variable<br/>address length is defined by R0:R1 register. Goal variable address is<br/>defined by R2:R3.<br/>When the distance between source address and target address is<br/>shorter than the length of moving data, the later length shall not longer<br/>than 32.<br/>MOVXX 100</num></num> |
|                                           |       | Without or 0x00         | Register data exchange, according to register paging access:<br>R2 stipulate origin address of register (group)<br>R3 stipulate rule goal address of register group R9 stipulate data length<br>exchanged, bytes.<br>MOVA or MOVA 0x00                                                                                                                                                                |
| Registers Indexed addressing              | MOVA  | 0x01                    | Register data exchange, all registers as a 2KB data area to access:<br>R0: R1stipulate origin address of register, 0x0000-0x7FF;<br>R2: R3stipulate rule goal address of register, 0x0000-0x7FF;<br>R9 stipulate date length exchanged, bytes, 0x00-0xFF, 0x00 show 256<br>Address high byte = source or destination register DR0 low byte =<br>source or destination register address.<br>MOVA 0x01  |
| Register stack                            | PUSH  | R# <num></num>          | Save the <num> register data starting with R# to the data stack.<br/>PUSH R8, 4</num>                                                                                                                                                                                                                                                                                                                 |
| 256 bytes                                 | POP   | R# <num></num>          | Fetch data from the data stack to the <num> registers starting with R# POP R8, 4</num>                                                                                                                                                                                                                                                                                                                |

# 4.2 Computation

| Command<br>Function            | Code                                                                                                                                                             | Number                                                                                                                                                                                                                                                                          | Description                                                      |  |  |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--|--|
| 32bit integers addition        | ADD                                                                                                                                                              | DD R#A, R#B, R#C C=A+B, A, B are 32bit integers, C is 64bit integer.<br>E.g. ADD R10, R20, R30                                                                                                                                                                                  |                                                                  |  |  |
| 32bit integers subtraction     | SUB                                                                                                                                                              | JB R#A, R#B, R#C C=A-B, A, B are 32bit integers, C is 64bit integer.<br>E.g. SUB R10, R20, R30                                                                                                                                                                                  |                                                                  |  |  |
| 64bit MAC for long<br>integers | MAC                                                                                                                                                              | R#A, R#B, R#CC=(A*B+C), A, B are 32bit integers, C is 64bit integer.<br>E.g. MAC R10, R20, R30                                                                                                                                                                                  |                                                                  |  |  |
| 64bit integers division        | DIV                                                                                                                                                              | R#A, R#B,<br><mod>A/B, A is quotient, B is reminder. A and B are 64bit regist<br/><mod>: 0: The quotient will not be rounded. 1: The quoti<br/>ROUNDED.<br/>E.g. DIV R10, R20, 1</mod></mod>                                                                                    |                                                                  |  |  |
| Expand variable to<br>32bit    | EXP                                                                                                                                                              | R#S, R#T,       Expand the data in R#S to 32bit and save to R#T R#S: Source register(s)         R#S, R#T,       R#T: Target register <mod>       O=8Bit unsigned; 1=8bit signed 2=16bit unsigned 3=16bit integer.         E.g. EXP R10, R20, 2       E.g. EXP R10, R20, 2</mod> |                                                                  |  |  |
| 32bit unsigned MAC             | SMAC R#A, R#B, R#C C=A*B+C<br>A and B are 16bit unsigned integer, C is 32bit unsigned integer<br>E.g. SMAC R10, R20, R30                                         |                                                                                                                                                                                                                                                                                 | A and B are 16bit unsigned integer, C is 32bit unsigned integer. |  |  |
| Register self-increase         | INC R#, R#=R#+NUM, unsigned self-increasing calculation, <num>0x00-0x<br/><mod>, <mod>: Data type of R#; 0=8bit 1=16bit<br/>E.g. INC R10, 1, 5</mod></mod></num> |                                                                                                                                                                                                                                                                                 |                                                                  |  |  |



| Floating-point and    | -INT R | R#A, R#B<br>R#F, R#I,<br><mod></mod> | Count a 64 bit unsigned R#A's Square root and reserve it into R#B.<br>R#A: Reserve 8 Bytes unsigned;<br>R#B: Reserve 4 Bytes unsigned result.<br>E.g. SQRT R80, R90<br>Implement 1 floating point number and 1 64bit fixed point integer<br>conversion.<br>R#F: The r egister that holds the floating-point number, 32bit or 64bit;<br>R#I : Register to store fixed-point integer, 64bit;<br><mod>:<br/>.7 Represents the floating-point number format: 0=32bit single precision<br/>1=64bit double precision.<br/>.6 Conversion type 0=Convert floating-point number to fixed-point<br/>integer 1=Convert fixed-point integer to floating-point number.<br/>.5 Undefined, write 0<br/>.40 The number of decimal places for fixed-point integers, 0x00-0x1F,<br/>up to 31 decimal places.</mod> |
|-----------------------|--------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| fixed-point integer F |        |                                      | <ul> <li>conversion.</li> <li>R#F: The r egister that holds the floating-point number, 32bit or 64bit;</li> <li>R#I : Register to store fixed-point integer, 64bit;</li> <li><mod>:</mod></li> <li>.7 Represents the floating-point number format: 0=32bit single precision</li> <li>1=64bit double precision.</li> <li>.6 Conversion type 0=Convert floating-point number to fixed-point integer 1=Convert fixed-point integer to floating-point number.</li> <li>.5 Undefined, write 0</li> <li>.40 The number of decimal places for fixed-point integers, 0x00-0x1F,</li> </ul>                                                                                                                                                                                                               |
|                       |        |                                      | 90cm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Beili                 | 1001   |                                      | echnology                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



# 4.3 Logic Operation

| Command<br>Function         | Code | Number                                   | Description                                                                                                                              |
|-----------------------------|------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Logical calculation: AND    |      | R#A, R#B,<br><num></num>                 | A=A AND B, Logical "AND" calculation for series of Registers.<br><num>: Data length of R#A, R#B in BYTES.<br/>E.g. AND R10, R20, 1</num> |
| Logical calculation:<br>OR  | OR   | R#A, R#B,<br><num></num>                 | A=A OR B, Logical "OR" calculation for series of Registers.<br><num>: Data length of R#A, R#B in BYTES.<br/>E.g. OR R10, R20,1</num>     |
| Logical calculation:<br>XOR | XOR  | R#A, R#B,<br><num></num>                 | A=A XOR B, Logical "XOR" calculation for series of Registers.<br><num>: Data length of R#A, R#B in BYTES<br/>E.g. XOR R10, R20, 1</num>  |
| Left ring move              | SHL  | R#, <num>,<br/><bit_num></bit_num></num> | Turn R#point <num> register left and ring move<bit_num>bit.<br/>E.g. SHL R10, 2, 1</bit_num></num>                                       |
| Right ring move             | SHR  | R#, <num>,<br/><bit_num></bit_num></num> | Turn R#point <num>register right and ring move<bit_num>bit.<br/>E.g. SHR R10, 2, 1</bit_num></num>                                       |
| .4 Data Proces              | sing |                                          | 20CDI                                                                                                                                    |
| Command                     | Codo | Number                                   | Description                                                                                                                              |

# 4.4 Data Processing

| Command<br>Function          | Code               | Number                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------|--------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sequence comparison          | TESTS              | R#A,R#B,<br><num></num>  | Compare the values in R#A and R#B by sequence.<br>If not match, return the current address of R#A to R0 register; If match,<br>return 0x00 to R0 register.<br>R#A: Starting register for register series A; R#B: Starting register for<br>register series B;<br><num>: max length for data comparison.<br/>E.g. TESTS R10, R20, 16</num>                                                                                                        |
| Integer linear equation      | ROOTLE             |                          | Calculate the Y value according to the given X value, which is a point<br>on the line defined by (X0, Y0) and (X1, Y1) in 16bit integer.<br>Input: X=R10, X0=R14, Y0=R16, X1=R18, Y1=R20<br>Output: Y=R12<br>E.g. ROOTE                                                                                                                                                                                                                         |
| ANSI CRC-16                  | CRCA R#S, R#T, R#N |                          | Perform ANSI CRC-16 calculation on series of Registers. ANSI CRC-<br>16(X16+X15+X2+1).<br>R#S: Registers for Input.<br>R#T: Registers to hold the result, 16bit, LSB mode.<br>R#N: Save the length for CRC byte data, 8bit.<br>E.g. CRCA R10, R80, R9                                                                                                                                                                                           |
| CCITT CRC-16                 | CRCC               | R#S, R#T, R#N            | Perform CCITT CRC-16 calculation on series of Registers. CCITT<br>CRC-16(X16+X12+X5+1).<br>R#S: Registers for Input.<br>R#T: Registers to hold the result, 16bit, MSB mode.<br>R#N: Save the length for CRC byte data, 8bit.<br>E.g. CRCC R10, R80, R9                                                                                                                                                                                          |
| HEX transfer ASCII<br>string | HEXASC             | R#S, R#T,<br><mod></mod> | R#S: 32bit Integer needed transfering; R#T: ASCII string register group<br>transfered;<br><mod>: Transfer mode,high 4bit is length of Integer bit, low 4bit is<br/>number of Decimal.<br/>ASCII string transfered with symbol, Right alignment, empty is filled<br/>with 0x20.<br/>To data 0x12345678,<br/><mod>=0x62 transfered result is+054198.96<br/><mod>=0xF2 transfered result is+3054198.96<br/>HEXASC R20, R30, 0x62</mod></mod></mod> |



| Convert ASCII string<br>to HEX characters | ASCHEX | R#S, R#T, <len></len>     | Convert ASCII string to signed 64-bit HEX data.<br>R#S: Starting address for registers stored ASCII Strings.<br>R#T: A 64bits register to hold the output 64-bit Hex data.<br><len>: The length for ASCII string, include sign bit and decimal point.<br/>0x01-0x15.<br/>E.g. ASCHEX R10, R80, 0x05</len>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------|--------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data processing                           | MATH   | <mod>, R#P,<br/>R#N</mod> | Process the data in the data storage area, and the data is a 16-bit<br>unsigned number.<br>R#P: 7 register data D0-D7 starting from R#P.<br>D0The start address of the register where the processing result is<br>saved.<br>D1: D2 The next (future) data is at the first address (relative address,<br>data location) of the data buffer the historical data will be read forward<br>from the current position during processing).<br>D3: D4 The start address of the data buffer area in the data storage<br>area.<br>D5: D6 The word length of a D6 data buffer area must not be less than<br>the value of R#N.<br>R#N: The number of data processing points (1-N words per point),<br>0x00-0xFF, 0x00 means 256.<br>< <u>MOD&gt;=0x00</u><br>Calculate the average value, and the result is a 32-bit unsigned number<br>with a unit of 1/65536.<br>< <u>MOD&gt;=0x01</u><br>Calculate the max value, and the result is a 16bit unsigned number.<br>< <u>MOD&gt;=0x01</u><br>Calculate the min value, and the result is a 16-bit unsigned number.<br>< <u>MOD&gt;=0x02</u><br>Calculate the root mean square (RMS), and the result is a 32-bit<br>unsigned number with a unit of 1/65536.<br>< <u>MOD&gt;=0x04</u><br>According to y=k*x+b, carry out least square method parameter<br>estimation.<br>The data storage format is (x0, y0)(xn, yn), and the return format is (k,<br>b).<br>k, b The returned result is a 32-bit integer, and the unit is 1/65536.<br>< <u>MOD&gt;=0x05</u><br>Not support.<br>< <u>MOD&gt;=0x06</u><br>Calculate the standard deviation (RMSE), and the result is a 32-bit<br>unsigned number with a unit of 1/65536.<br>MATH 0, R0, R10 |
| 80                                        | INO    |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



## **4.5 Process Controlling**

| Command<br>Function                                                                                                                                                                                                                                                                                 | Code | Number                             | Description                                                                                                                                                                                                                                                                                                                                                          |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| None                                                                                                                                                                                                                                                                                                | NOP  |                                    | None of operation.<br>NOP                                                                                                                                                                                                                                                                                                                                            |  |
| Conditional bit jump                                                                                                                                                                                                                                                                                | JB   | R#, <bit>, <tab></tab></bit>       | Evaluate the <bit> in R# register. If 1, jump to <num>; if 0, proceed to<br/>next instruction, jump range +/-127 instructions.<br/>R#: the register contains data to be evaluated.<br/><bit>: the index of the bit to be evaluated. 0x00-0x0F (MSB).<br/><tab>: jump position.<br/>E.g.JB R10, 15, TEST1<br/>NOP<br/>TEST1: ADD R8, R12, R16</tab></bit></num></bit> |  |
| Variable conditional<br>jump (not equal)                                                                                                                                                                                                                                                            | CJNE | R#A, R#B,<br><tab></tab>           | Compare the value of 2 8-bit registers (R#A and R#B). If equal, proceed to the next instruction; if not equal, jump to <num>.<br/>E.g. TEST1: NOP<br/>INC R10, 0, 1 CJNE R10,R11, TEST1</num>                                                                                                                                                                        |  |
| 16bit Integer<br>conditional jump (less<br>than)                                                                                                                                                                                                                                                    | JS   | R#A, R#B,<br><tab></tab>           | Compare the value for 2-bit integer in R#A and R#B. If A>=B, proceed to the next instruction; If A <b, <num="" jump="" to=""> E.g. JS R10, R12, TEST1 NOP TEST1: NOP</b,>                                                                                                                                                                                            |  |
| 16bit comparison,<br><jumping< td=""><td>JU</td><td>R#A, R#B,<br/><tab></tab></td><td colspan="2">Compare A, B 16bit the unsigned, A&gt;=B carry out next command, A<b +="" -127="" commands.<br="" jumping="" jumping,="" of="" range="">JU R10, R12, TEST1 NOP<br/>TEST1: NOP</b></td></jumping<> | JU   | R#A, R#B,<br><tab></tab>           | Compare A, B 16bit the unsigned, A>=B carry out next command, A <b +="" -127="" commands.<br="" jumping="" jumping,="" of="" range="">JU R10, R12, TEST1 NOP<br/>TEST1: NOP</b>                                                                                                                                                                                      |  |
| Value conditional jump<br>(number and Variable)                                                                                                                                                                                                                                                     | IJNE | R#, <inst>,<br/><tab></tab></inst> | Compare the value in 8-bit Register and a instant Number <inst>. If equal, process to next instruction; if not equal, jump to <num>.<br/>E.g. IJNE R10, 100, TEST1 NOP<br/>TEST1: NOP</num></inst>                                                                                                                                                                   |  |
| Decrement> 0 jumping                                                                                                                                                                                                                                                                                | DJNZ | R#, <num>,<br/><tab></tab></num>   | R#is 16bit, every count R#=R#- <num>, if R#&gt; 0 jumping,<br/>In contrast, carry out next command, range of jumping +/-<br/>127commands.<br/>TEST1: NOP<br/>DJNZ R10, 1, TEST1</num>                                                                                                                                                                                |  |
| Return                                                                                                                                                                                                                                                                                              | RET  |                                    | Return to the main program by calling this function in the sub-program.<br>E.g.RET                                                                                                                                                                                                                                                                                   |  |
| Interrupt program<br>return                                                                                                                                                                                                                                                                         | REIT |                                    | Interrupting program and return.<br>RETI                                                                                                                                                                                                                                                                                                                             |  |
| Call sub-function                                                                                                                                                                                                                                                                                   | CALL | <pc></pc>                          | Call sub-program in a position of program counter max support 32 levels of program nesting.<br>E.g. CALL TEST                                                                                                                                                                                                                                                        |  |
| Direct jump                                                                                                                                                                                                                                                                                         | бото | <pc></pc>                          | Program jump.<br>If <pc>=0xFFFF, it means taking the position of <r5:r6:r7> as the<br/>reference, and R1: R0 as the relative PC.<br/>Pointer to jump.<br/>E.g. GOTO TEST1 NOP<br/>TEST1: NOP</r5:r6:r7></pc>                                                                                                                                                         |  |
| Program end                                                                                                                                                                                                                                                                                         | END  |                                    | DWIN OS program over command after carrying out this command, PC pointer reset to 0x1000, run again. same as software reset.<br>END                                                                                                                                                                                                                                  |  |

#### Notice:

Interrupting program should apply GOTO, RETI command.

Subprogram calling must use CALL and RET commands in pairs, transferring the program with GOTO and RET command will result in an abnormal stack overflow.



# 4.6 Peripheral Operation

| Command<br>Function    | Code   | Number                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------|--------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serial setting         | COMSET | <mode r#="">,<br/><bs></bs></mode> | Set serial port mode:<br><mode>: high 4bit choose serial port needed to be set, 3=UART3<br/> 5=UART5<br/>low 4bit choice mode. 0x*0=N81, 0x*1=E81,<br/>0x*2=O81, 0x*3=N82 mode.<br/><bs>: baud rate setting value,<br/>2Bytes.<br/>For UART3,<br/>Setting value= 6451200/ set baud,<br/>rate. setting value= 6451200/ set baud,<br/>rate. setting value= 1-1023.<br/>To UART4-UART5, setting value= 25804800/ set, range of setting<br/>value 1-65535.<br/>Corresponding UART's transceiver buffer will be cleared during each<br/>setting procedure.<br/>If<bs>=0x0000, then<mode>will be register pointer, pointing<br/>3 registers, in sequence corresponded to<mode>, <bs><br/>value. COMSET 0x30, 136</bs></mode></mode></bs></bs></mode> |
| Serial send            | COMTXD | <com>,<br/>R#S, R# N</com>         | Dispatching data to specified port.<br><com>: choose port, 0-2 no support 3=UART3<br/>5=UART5<br/>R#S: data register group to be sent.<br/>R#N: bytes register to be sent, 8bit, register data 0x00 refers to sending<br/>256 Bytes data. COMTXD 3, R10, R9</com>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Check<br>COM_Rx_FIFO   | RDXLEN | <com>, R#</com>                    | Returning to COM, receiving buffer area (FIFO) and data bytes<br>length (0-255) to R# register.<br>0x00 refers to no data.<br><com>: choose port, 0-2 no support 3=UART3<br/>5=UART5 RDXLEN 3, R10</com>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Read COM_Rx_FIFO       | RDXDAT | <com>,<br/>R#A, R#B</com>          | Receiving buffer (FIFO) from COM, then reading R#B bytes (01-<br>255) to R#A register.<br><com>: choose serial port, 0-2 no support, 3=UART3<br/>5=UART5 RDXDAT 3, R11, R10</com>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Direct serial transmit | СОМТХІ | <com>,<br/>R#, <num></num></com>   | <num> register content with R# points sent to COM.<br/><com>: choose serial port, 0-2 no support, 3=UART3 5=UART5<br/>COMTXI 3, R20,16</com></num>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| Hardware setting     | CONFIG                               | <type>,<br/><d1 r#="">,<br/><d0></d0></d1></type> | <type>: hardware type choice, just low 7bit effective.<br/>TYPE.7=0 refers to D1, D0 as immediate values.<br/>TYPE.7=1 refers to D1 will be register pointer, pointing 2 registers.<br/>TYPE.6-TYPE.0 select the hardware type,<br/>0x00: Setting I/O port mode.<br/>D1 chooses IO port, 0x00-0x02 corresponds P0-P2, among them P0.7-<br/>P0.0 corresponds IO7-IO0<br/>P1.7-P1.0 corresponds IO15-IO8 P2.1-<br/>P2.0 corresponds IO17-IO16 D0 is<br/>corresponds setting value.<br/>D0.X=1 as output (Push-Pull) D0.X=0 as input (Open Drain)<br/>0x01: Setting timer.<br/>D1 chooses timer, and 0x02-0x03 corresponds T2, T3. D0<br/>sets timer datum, unit as 1ms, 0x00 refers to 256.<br/>0x02: LIB code loading. As variable space address, D1: D0 should<br/>be even.<br/>Loading to code space starting as 0x0000, adopting CALL 0x0000 to<br/>transfer.<br/>0x03: DWIN OS code loading. As variable space address, D1: D0<br/>should be even.<br/>0x04: Unencrypted 512-byte OS code loading (program call or process<br/>management); D1: 00 is the variable space word address of the stored<br/>code, and D0: 00 is the code space byte address.<br/>Loading time is about 200uS.<br/>CONFIG 0, 0, 0x0F</type> |
|----------------------|--------------------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IO operation: output | ut OUTPUT <p#>,<br/><pre></pre></p#> |                                                   | 0x01=8 bit output, output is R# specified value.<br>0x*2=output R#.0, then put R# right ring shift once, <mod> high 4bit<br/>as IO position.<br/>0x*3=output R#.7, then put R# left ring shift once, <mod> high 4bit<br/>as IO position.<br/>OUTPUT 0, 0, 0x55; P0 ( IO7-IO0 ) port outputs 01010101<br/>OUTPUT 1, 0x32, R2; R2.0 outputs to IO11, and R2 right ring shift</mod></mod>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| IO operation: input  | INPUT                                | <p#>,<br/><mod>,<br/>R#</mod></p#>                | Read the content of specified IO port ( 8-bit or 1bit) to register.<br><p#>: The serial number of IO port, 0x00-0x02 corresponds P1-P3.<br/><mod>: Inputting mode<br/>0x00=8 bit parallel<br/>inputting.<br/>0x*2=R# right ring move once, reading R#.7, <mod> high 4bit as<br/>IO position.<br/>0x*3=R# left ring move once, read R#.0, <mod> high 4bit as<br/>IO position.<br/>R#: Register ID read from IO port data.<br/>INPUT 1, 0, R20; IO15-IO8 outputs R20 register value<br/>INPUT 1, 0x32, R2; R2 right ring move once, reading R2.7 as IO11<br/>status.</mod></mod></mod></p#>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



## 5. Appendix

| Date       | Content Revision | Software version |
|------------|------------------|------------------|
| 2019.02.12 | First Issuance   | V1.0             |

wind the second of the second If there is any question when you using this file or DWIN product, or willing to know more about DWIN product news, feel free to contact us:

Hotline: 86-4000189008

Mail: dwinhmi@dwin.com.cn