# **DWIN T5L ASIC Development Guide** Version V1.1 #### Catalog | 1. Summary | 3 - | |---------------------------------------|------| | 2. Hardware Description | 5 - | | 2.1 PIN Definition | 5 - | | 2.2 Packaging Dimension | 10 - | | 2.3 Basic performance parameters | 10 - | | 2.4 Notices for Hardware Design | 11 - | | 3. OS CPU Description | 12 - | | 3.1 Initial Configuration | 12 - | | 3.2 Memory | 13 - | | 3.2.1 Code memory(64KBytes) | 13 - | | 3.2.2 DGUS Variable Memory(256KBytes) | 14 - | | 3.2.3 Data Memory(32KBytes) | 16 - | | 3.2.4 Extended SFR register | 17 - | | 3.3 Mathematical operating unit(MDU) | 18 - | | 3.4 Timer | 19 - | | 3.5 Watchdog Timer(WDT) | 21 - | | 3.6 IO | 22 - | | 3.7 UART communication interface | 23 - | | 3.7.1 UART2 interface | | | 3.7.2 UART3 interface | 24 - | | 3.7.3 UART4 interface | 24 - | | 3.7.4 UART5 interface | 25 - | | 3.8 CAN communication interface | 26 - | | 3.9 Interrupt system | 28 - | | 3.9.1 Interrupt control SFR | 28 - | | 3.9.2 Interrupt priority | 29 - | | 3.10 8051 Instruction set of T5L ASIC | 30 - | | 4. Simulation Debug | 32 - | | 5. EK043 Evaluation Board | 34 - | | Amoundin 1 | 25 | # 1. Summary The T5L series ASIC is a single-chip and dual-core ASIC IC designed by DWIN technology co., ltd for AIOT applications with low power consumption, high cost performance, GUI and highly integrated application, including T5L1(low resolution) and T5L2(high resolution). Its main features are as follow: - (1) Using 8051 core which is the most widely used, mature and stable, the maximum operating frequency of T5L is up to 250MHZ, 1T(single instruction cycle)high speed operation. - (2) Separated GUI CPU Core running DGUS II System: - ➤ High-speed display memory, 2.4 GB/S bandwidth, 24bit color display resolution supporting to 800\*600(T5L1) or 1366\*768(T5L2). - ➤ 2D hardware acceleration, the decompression speed of JPEG is up to 200fps@1280\*800, the UI interface with animation and icons as its main feature is extremely cool and smooth. - > JPEG stores images and icons in compressed mode, external memory greatly reduced to low-cost 16Mbytes SPI Flash. - ➤ With maximum 400 Hz touch point speed, touch screen supports resistance or capacitance, and its sensitivity can be adjusted. - ➤ High-quality speech compression storage and playback. - ➤ 128Kbytes variable storage space, exchanging data with OS CPU Core using memory interface, extremely simple to apply. - ➤ 2-way 10bit, 800KHz, DC/DC controller, simplify LED backlight, analog power supply design and save cost and space. - > 1-way 15bit32Ksps PWM digital power amplifier driver loudspeaker, save power amplifier cost and achieve high signal-to-noise ratio and sound quality restoration. - > Supporting PC configuration development and simulation, supporting background remote upgrade. - (3) Separated CPU (OS CPU) core runs user 8051 code or DWIN OS system, user CPU is omitted in practical application. - Standard 8051 architecture and instruction set, 64Kbytes code space, 32Kbytes on-chip RAM. - ➤ 64 bit integer mathematical operation unit(MDU), including 64 bit MAC and 64 bit divider. - ▶ Built-in software WDT, three 16 bit Timers, 12 interrupt signals with the highest four interrupt nesting. - ➤ 22 IO, 4-channel UARTS,1-channel CAN interface, up to 8-channel 12-bit A/D, 1-channle 16-bit resolution adjustable PWM. - > Support IAP on-line simulation and debugging, unlimited number of breakpoints. - Upgrade code online through DGUS system. - (4) 1Mbytes on-chip Flash with DWIN patent encryption technology ensure code and data security, eliminate copycat and cloning. - (5) Reduces crystal requirements and PCB design challenges for a variety of inexpensive wide-range tuned impedance crystal oscillators and PLLs. - (6) 3.3V IO voltage, can adapt to 1.8/2.5/3.3 various levels. - (7) Supporting SD interface or UART1 download and configuration, supporting SD card file reading and rewriting. - (8) Supporting DWIN WiFi module to access to DWIN cloud directly, and easily developing various cloud platform applications. - (9) Working temperature ranges from 40°C to +85°C (Customizable IC for -55°C to 105°C operating temperature range ) - (10) With low power consumption and strong anti-interference ability, it can work steadily on the double-sided PCB design, and easy to pass EMC/EMI test. - (11) Using 0.4mm ELQFP128 packaging, low manufacturing difficulty and low cost. - (12)Providing T5L IC + LCD + touch screen + design support for industry customers with cost-effective matching program sales and comprehensive technical service support. # 2. Hardware Description ### 2.1 PIN Definition T5L ASIC is packaged in ELQFP128 (16\*16\*1.5mm), pins arrangement are shown in Fig 2-1. Fig.2-1 The arrangement of T5L pin | | | | | | Definition | | | |-----|------|------------|------------------------|------------|--------------------------------|------------|--------------| | CPU | PIN# | Function 1 | Instructions | Function 2 | Instructions | Function 3 | Instructions | | os | 119 | TX4 | UART4 data transmition | | | | | | os | 120 | RX4 | UART4 data reception | | | | | | os | 121 | TX5 | UART5 data transmition | | | | | | os | 122 | RX5 | UART5 data reception | | | | | | os | 123 | P0.0 | I/O port | | | | | | os | 124 | P0.1 | I/O port | | | | | | os | 125 | P0.2 | I/O port | CAN_TX | CAN interface data transmition | | | | os | 126 | P0.3 | I/O port | CAN_RX | CAN interface data reception | | | | os | 127 | P0.4 | I/O port | TX2 | UART2 data transmition | | | | os | 128 | P0.5 | I/O port | RX2 | UART2 data reception | | | | os | 1 | P0.6 | I/O port | TX3 | UART3 data transmition | | | | | | | | | Development Guide of DV | VIIV I JL ASIC | Ver1.1 | |-----|-----|-------------|--------------------------|-----|----------------------------|----------------|---------------------------| | OS | 2 | P0.7 | I/O port | RX3 | UART3 data reception | | | | os | 3 | VDD | T5L1=1.25V | | | | | | US | 3 | עטע | T5L2=1.2V | | | | | | os | 4 | VIO | 3.3V | | | | | | OS | 5 | P1.0 | I/O port | | | | | | os | 6 | P1.1 | I/O port | | | | | | OS | 7 | P1.2 | I/O port | | | | | | OS | 8 | P1.3 | I/O port | | | | | | OS | 9 | P1.4 | I/O port | | | | | | os | 10 | P1.5 | I/O port | | | | | | OS | 11 | P1.6 | I/O port | | | | | | os | 12 | P1.7 | I/O port | | | | | | 00 | 1.2 | LIDD | T5L1=1.25V | | | | | | OS | 13 | VDD | T5L2=1.2V | | | | | | os | 14 | VIO | 3.3V | | | | | | OS | 15 | P2.0 | I/O port | | | | | | OS | 16 | P2.1 | I/O port | | | | | | os | 17 | P2.2 | I/O port | | | | | | os | 18 | P2.3 | I/O port | | | | | | os | 19 | P2.4 | I/O port | | | | | | os | 20 | P2.5 | I/O port | | | | | | os | 21 | P2.6 | I/O port | | | | | | os | 22 | P2.7 | I/O port | | | | | | | | | T5L1=1.25V | | | | | | OS | 23 | VDD | T5L2=1.2V | | | | | | OS | 24 | VIO | 3.3V | | | | | | OS | 25 | P3.0 | I/O port | EX0 | External interrupt 0 input | | | | os | 26 | P3.1 | I/O port | EX1 | External interrupt 1 input | | | | os | 27 | P3.2 | I/O port | | | | | | OS | 28 | P3.3 | I/O port | | | | | | | 29 | GND | | | | | | | | 30 | GND | | | | | | | | 31 | GND | | | | | | | | 32 | OS/GUI | 0:GUI JTAG, 1=OS<br>JTAG | | | | | | | 33 | /RST | System reset input | | | | | | | 34 | JTAGS | PIN35#-PIN38# Select: | | =I/O port | | | | GUI | | P0.0 | I/O port | TMS | JTAG interface | TCON_CS | LCD screen TCON interface | | GUI | 36 | P0.1 | I/O port | TCK | JTAG interface | TCON_CLK | LCD screen TCON interface | | GUI | 37 | P0.2 | I/O port | TDI | JTAG interface | TCON_DAT<br>A | LCD screen TCON interface | | GUI | 38 | P0.3 | I/O port | TDO | JTAG interface | TCON RST | | | | | /IN Technol | 1 - | 1 | 100 018 0008 | _ | Advin com en | | | | | | | Development Guide of DV | VIIV I JE ASIC | Ver1.1 | | | |-----|----|--------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----------------|-----------------------------|--|--| | | | | | | | | TCON interface | | | | GUI | 39 | P0.4 | I/O port | TX1 | UART1 data transmition | | | | | | GUI | 40 | P0.5 | I/O port | RX1 | UART1 data reception | | | | | | GUI | 41 | P0.6 | I/O port | FSK_TX | FSK transceiver data transmition | | | | | | GUI | 42 | P0.7 | I/O port | FSK_RX | FSK transceiver data reception | | | | | | GUI | 43 | ADC0 | AD input | RTP_X0 | 4-wire resistance touch screen interface | | | | | | GUI | 44 | ADC1 | AD input | RTP_Y0 | 4-wire resistance touch screen interface | | | | | | GUI | 45 | ADC2 | AD input | RTP_X1 | 4-wire resistance touch screen interface | | | | | | GUI | 46 | ADC3 | AD input | RTP_Y1 | 4-wire resistance touch screen interface | | | | | | GUI | 47 | ADC4 | AD input | IF_0.4 | DC/DC 0.4V voltage feedback | | | | | | GUI | 48 | ADC5 | AD input | VF_1.25 | DC/DC 1.25V voltage feedback | | | | | | GUI | 49 | ADC6 | AD input | IF_0.4 | | | | | | | GUI | 50 | ADC7 | AD input | VF_1.25 | | | | | | | GUI | 51 | AGND | AD GND | | | | | | | | GUI | 52 | AVDD | AD power supply,3.3V, p in parallel with 105 for ca | | se as possible to the AVDD pin to c | connect the 470 | pJ(COG materal) | | | | GUI | 53 | VREF | AD reference power supp | AD reference power supply, please as close as possible to the VREF pin to connect the 470pJ(COG materal) in parallel with 105 for capacitor filtering | | | | | | | GUI | 54 | VDDPLL | T5L1=1.25V T5L2=1.2V | T5L1=1.25V T5L2=1.2V, please as close as possible to the VDDPLL pin to connect the 470pJ(COOnateral) in parallel with 105 for capacitor filtering | | | | | | | GUI | 55 | XIN | Crystal,10MHz-12MHZ | | 3.3V clock input | | | | | | GUI | 56 | XOUT | Crystal | | | | | | | | GUI | 57 | VDD | 1.1V | | | | | | | | GUI | 58 | VIO | 3.3V | | | | | | | | GUI | 59 | P1.0 | I/O port | PWM0 | 16bit PWM output | | | | | | GUI | 60 | P1.1 | I/O port | PWM1 | 16bit PWM output | PWM_V | LCD screen AVDD DC/DC | | | | GUI | 61 | P1.2 | I/O port | PWM2 | 16bit PWM output | PWM_I | LCD backlight DC/DC | | | | GUI | 62 | P1.3 | I/O port | PWM3 | 16bit PWM output | BUZZ&SPK | Buzzer/speaker<br>drive | | | | GUI | 63 | P1.4 | I/O port | SDD0 | SD card interface:data | SPI_D0 | SPI Flash interface:data | | | | GUI | 64 | P1.5 | I/O port | SDD1 | SD card interface:data | SPI_D1 | SPI Flash<br>interface:data | | | | GUI | 65 | P1.6 | I/O port | SDD2 | SD card interface:data | SPI_D2 | SPI Flash<br>interface:data | | | | GUI | 66 | P1.7 | I/O port | SDD3 | SD card interface:data | SPI_D3 | SPI Flash<br>interface:data | | | | GUI | 67 | VDD | T5L1=1.25V | | | | | | | | _ | | | T. 5. 1. 0. 1. | | Development Guide of DV | VIN ISLASIC | Ver1.1 | |-----|----|------|-------------------------|--------------|-------------------------------------------------------------|-------------|-------------------------------------------| | | | | T5L2=1.2V | | | | | | GUI | 68 | VIO | 3.3V | | | | | | GUI | 69 | P2.0 | I/O port | SDCK | SD card interface:clock | PA_EN | Amplifier power switch for voice playing. | | GUI | 70 | P2.1 | I/O port | SDCK | SD card interface:instructions | | | | GUI | 71 | P2.2 | I/O port | SPI_CS | SPI Flash interface:chip selection | | | | GUI | 72 | P2.3 | I/O port | SPI_CLK | SPI Flash interface:clock | | | | GUI | 73 | P2.4 | I/O port | RTP_Y1 | 4-wire resistance touch screen interface | CTP_SDA | Capacitance touch screen interface | | GUI | 74 | P2.5 | I/O port | RTP_X1 | 4-wire resistance touch screen interface | CTP_INT | Capacitance<br>touch screen<br>interface | | GUI | 75 | P2.6 | I/O port | RTP_Y0 | 4-wire resistance touch screen interface | CTP_SCL | Capacitance touch screen interface | | GUI | 76 | P2.7 | I/O port | RTP_X0 | 4-wire resistance touch screen interface | CTP_RST | Capacitance touch screen interface | | GUI | 77 | VDD | T5L1=1.25V<br>T5L2=1.2V | | | | | | GUI | 78 | VIO | 3.3V | | | | | | GUI | 79 | P3.0 | I/O port | CLK_OUT | System clock frequency division output | | | | GUI | 80 | P3.1 | I/O port | FSK_TR | T/R switching signal for half-duplex use of SFK transceiver | | | | GUI | 81 | P3.2 | I/O port | | | | | | GUI | 82 | P3.3 | I/O port | | | | | | GUI | 83 | P3.4 | I/O port | LCD_PCL<br>K | LCD interface | | | | GUI | 84 | P3.5 | I/O port | LCD_DE | LCD interface | | | | GUI | 85 | P3.6 | I/O port | LCD_HS | LCD interface | | | | GUI | 86 | P3.7 | I/O port | LCD_VS | LCD interface | | | | GUI | 87 | VDD | T5L1=1.25V<br>T5L2=1.2V | | | | | | GUI | 88 | VIO | 3.3V | | | | | | GUI | | P4.0 | I/O port | LCD B0 | LCD interface | | | | GUI | 90 | P4.1 | I/O port | | LCD interface | | | | GUI | 91 | P4.2 | I/O port | | LCD interface | | | | GUI | | P4.3 | I/O port | | LCD interface | | | | GUI | 93 | P4.4 | I/O port | LCD_B4 | LCD interface | | | | GUI | 94 | P4.5 | I/O port | | LCD interface | | | | | | | | | Development Guide of DWIN 13L ASIC | ver1.1 | |------|-----|------|------------|--------|------------------------------------|--------| | GUI | 95 | P4.6 | I/O port | LCD_B6 | LCD interface | | | GUI | 96 | P4.7 | I/O port | LCD_B7 | LCD interface | | | CIII | 97 | VDD | T5L1=1.25V | | | | | GUI | 9/ | VDD | T5L2=1.2V | | | | | GUI | 98 | VIO | 3.3V | | | | | GUI | 99 | P5.0 | I/O port | LCD_G0 | LCD interface | | | GUI | 100 | P5.1 | I/O port | LCD_G1 | LCD interface | | | GUI | 101 | P5.2 | I/O port | LCD_G2 | LCD interface | | | GUI | 102 | P5.3 | I/O port | LCD_G3 | LCD interface | | | GUI | 103 | P5.4 | I/O port | LCD_G4 | LCD interface | | | GUI | 104 | P5.5 | I/O port | LCD_G5 | LCD interface | | | GUI | 105 | P5.6 | I/O port | LCD_G6 | LCD interface | | | GUI | 106 | P5.7 | I/O port | LCD_G7 | LCD interface | | | CIII | 107 | VDD | T5L1=1.25V | | | | | GUI | 107 | VDD | T5L2=1.2V | | | | | GUI | 108 | VIO | 3.3V | | | | | GUI | 109 | P6.0 | I/O port | LCD_R0 | LCD interface | | | GUI | 110 | P6.1 | I/O port | LCD_R1 | LCD interface | | | GUI | 111 | P6.2 | I/O port | LCD_R2 | LCD interface | | | GUI | 112 | P6.3 | I/O port | LCD_R3 | LCD interface | | | GUI | 113 | P6.4 | I/O port | LCD_R4 | LCD interface | | | GUI | 114 | P6.5 | I/O port | LCD_R5 | LCD interface | | | GUI | 115 | P6.6 | I/O port | LCD_R6 | LCD interface | | | GUI | 116 | P6.7 | I/O port | LCD_R7 | LCD interface | | | CIII | 117 | VDD | T5L1=1.25V | | | | | GUI | 11/ | VDD | T5L2=1.2V | | | | | GUI | 118 | VIO | 3.3V | | | | Note that the pad on the bottom of the IC must be grounded reliably, otherwise the performance of the IC will be affected. ### 2.2 Packaging Dimension For PCB design, please use the device packaging and reference design provided by DWIN Technology. # 2.3 Basic performance parameters | Parameter | Unit | Minimum value | Typical value | Maximum value | Instructions | |------------------------------|------|---------------|---------------|---------------|-----------------------------| | CDI I 14 | V | 1.10 | 1.20 | 1.30 | T5L2 | | CPU core voltage | V | 1.20 | 1.25 | 1.35 | T5L1 | | CPU core current | mA | | 100 | | Dual-core 200MHz full speed | | Cro core current | IIIA | | 100 | | operation | | | | | | | 5V TTL/CMOS level input | | IO voltage (VIO) | V | 1.8 | 3.3 | 3.6 | requires voltage divider or | | | | | | | clamp protection | | AD operating voltage(VADD) | V | 1.8 | 3.3 | 3.6 | | | AD reference voltage (Vref) | V | | | VADD+0.3 | | | AD input voltage | V | | | Vref+0.3 | | | IO high level output | V | 3.0 | | | VIO=3.3V,IO load current | | amplitude(VOH) | V | 3.0 | | | 8mA | | IO low level 1utput | V | | | 0.3 | VIO=3.3V,IO load current | | amplitude(Vol) | V | | | 0.3 | 8mA | | IO high level output current | mA | -10 | | | VIO=3.3V,VOH=3V | | IO low level output current | mA | 10 | | | VIO=3.3V,VOL=0.3V | | IO port turnover speed | MHz | | 100 | | | |----------------------------------------|-----|------|----------|------|----------------------------------------------------------------------------------------------------------------------------------| | IO high level recognition voltage(VIH) | V | 1.6 | | | | | IO low level recognition voltage(VIL) | V | | | 0.6 | | | External crystal frequency | MHz | 10.0 | 11.0592 | 12.0 | | | CPU main frequency<br>(CPU_CLK) | MHz | | 206.4384 | | Corresponding to 11.0592MHz crystal, CPU main frequency = crystal frequency* 56/3. 350MHz version of the code can be customized. | | Working temperature | °C | -40 | | +85 | | | Storage temperature | °C | -55 | | +105 | | | ESD protection capability | KV | | 2 | | HBM | ## 2.4 Notices for Hardware Design - (1) The core power voltage must be stable, otherwise it will lead to abnormal CPU operation. - (2) Reset is recommended to use low-level reset IC processing such as SGM809S instead of simple RC reset circuit. Each T5L CPU core has a built-in watchdog(WDT), doesn't need external WDT IC. - (3) Four layer PCB application design is recommended to achieve excellent EMC characteristics. When designing in a dual panel application, please as close as possible to the IC power supply pin to connect the 470pF in parallel with 104 (or 105) for capacitor filtering and reduce noise emissions. - (4) When IO input signal is over 0.3V of VIO voltage, IO must be protected by voltage divider or clamp, otherwise it may cause abnormal signal or damage IC. - (5) All IO ports are floating input when they are configured as input mode, without internal pull-up or pull-down. All IO ports are in the input state during the reset process. If they are output, they can be pulled down or pulled up externally to ensure that the reset process has a definite level. - (6) The 4-bit bus speed of T5L and external SPI Flash is 100MHz, thus the wiring should be as close as possible, and capacitor filtering of 470pF parallel 105 must be arranged on the power pin of SPI Flash. # 3. OS CPU Description The T5L OS CPU adopt the 8051 kernel, which is the most widely used in industry and has the longest time in mass production. On the basis of keeping 8051 real-time, fast IO speed, stability and reliability, DWIN has greatly improved 8051 memory access and calculation capability by optimizing code processing, expanding SFR bus and adding hardware mathematical processor. Users can also let OS CPU run DWIN OS platform for secondary application development on DWIN OS platform. For specific development methods, please refer to "DWIN OS program development guide based on T5L CPU". # 3.1 Initial Configuration When the 8051 kernel is powered on, the special function register (SFR) in the following table must be initialized correctly. | SFR name | Address | Initial<br>configuration<br>values | Instructions | |-----------|---------------------------------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CKON | 0X8E | 0X00 | CPU runs in 1T mode | | T2CON | 0XC8 | 10X70 | Configure extended interrupt system, configure timer T2 to run in Autoload mode | | DPC | 0X93 | 0X00 or 0x01 | After the operation of MOVX instruction, how DPTR's changed. It must be configured as 0x00 when process is developed in C51. 0x00:unchanged. 0x01:DPTR=DPTR+1. 0X03:DPTR=DPTR-1. | | PAGESEL | 0X94 | 0X01 | 64KB code space | | D_PAGESEL | 0X95 | 0X02 | 32KB RAM space accessed by MOVX, address 0x8000-0xFFFF | | MUX_SEL | MUX_SEL 0x60 or configuration according to application needs | | Peripheral multiplexing selection: .7 1 = CAN interface leads to P0.2, P0.3, 0 = CAN interface does not lead out, it is IO interface; .6 1 = UART2 interface leads to P0.4, P0.5, 0 = UART2 interface does not lead out, it is IO interface; .5 1 = UART3 interface leads to P 0.6, P 0.7, 0 = UART3 interface does not lead out, it is IO interface; .42 retain; .1 WDT control 1=open 0=close; | | | | | .0 WDT feed dog, 1=feed the dog one time(The WDT count becomes zero, | |---------|------|------|----------------------------------------------------------------------------------------------| | | | | and the watchdog's overflowing time is one second. ); | | PORTDRV | 0XF9 | | Driver capability configuration of IO port output mode,0x00=4mA 0X01=8mA 0X02=16mA 0X03=32mA | | RAMMODE | 0XF8 | 0X00 | DGUS variable memory access interface control | # 3.2 Memory The 8051 kernel of OS can access seven different kinds of memory, which are shown in the table below. | Memory type | Size | Address space | Access mode | |-----------------------------|-----------|---------------------|-------------------------------------------------------------------------------------------------| | Code memory | 64KBytes | 0x0000-0xFFFF | It can only be read by MOVC instruction, which is same as standard 8051. | | Data register | 256KBytes | 0x00-0xFF | The same as standard 8051 | | SFR register | 128KBytes | 0X80-0XFF | The same as standard 8051, DWIN can provide user SFR definition files (.INC or .H header file). | | Extended SFR register | 64KBytes | 0x00-0x3F | Access with the SFR register interface defined by EXADR and EXDATA. | | Data memory | 32KBytes | 0x8000-0xFFFF | Using MOVX instruction to access. When DPC is configured as 0x00, it is same as standard 8051. | | DGUS variable memory | 256KBytes | 0x00:0000-0x00:FFFF | Access using DGUS variable memory interface. | | CAN Communication interface | 48KBytes | 0xFF:0060-0xFF:006B | Access using DGUS variable memory interface. | # 3.2.1 Code memory(64KBytes) Functional partitioning and definition of the code memory space are shown in the following table. | Address | Definition | Instructions | |---------|-----------------|--------------------------------------------------| | 0x0000 | Reset_PC | After reset, the program starts running address. | | 0x0003 | EX0_ISR_PC | External interrupt 0 program interface | | 0x000B | T0_ISR_PC | Timer0 interrupt program interface | | 0x0013 | EX1_ISR_PC | External interrupt 1 program interface | | 0x001B | T1_ISR_PC | Timer1 interrupt program interface | | 0x0023 | UART2_ISR_PC | UART2 TX/RX interrupt program interface | | 0x002B | T2_ISR_PC | Timer2 interrupt program interface | | 0x004B | CAN_ISR_PC | CAN interface interrupt program interface | | 0x0053 | UART4_TX_ISR_PC | UART4 TX interrupt program interface | | 0x005B | UART4_RX_ISR_PC | UART4 RX interrupt program interface | | 0x0063 | UART5_TX_ISR_PC | UART5 TX interrupt program interface | | 0x006B | UART5_RX_ISR_PC | UART5 RX interrupt program interface | |--------|------------------------|---------------------------------------------------------------------------------------------------------------| | 0x0083 | UART3_ISR_PC | UART3 TX/RX interrupt program interface | | 0x00F8 | JTAG interface enabled | 0xFFFF will allow connection to JTAG interface for simulation debugging, and other values will be prohibited. | | 0x00FA | "DWINT5" | Code identification, illegal values will cause OS 8051 to stop running. | | 0x0100 | Application code start | Maximum 63.75KB | The OS 8051 code is stored in the 0x01:0000-0x01:FFFF position of the 1Mbytes on chip Flash. After power-on reset, the system loads and runs in RAM.Code can only be written to on-chip Flash through SD interface or UART1 interface (or WIFI network interface). ## 3.2.2 DGUS Variable Memory(256KBytes) The bit width of DGUS variable memory is 32 bits, and each address corresponds to 4Bytes data, in which: (1)Address from 0x00:0000 to 0x00:7FFF, corresponding to 128Kbytes variable memory space, are currently used by DGUSII system. For example, 0x1000 and 0x1001 DGUSII variable memory correspond to 0x800 address of OS 8051 DGUS variable memory. D3 corresponds to 0x1000 variable high byte, D2 corresponds to 0x1000 variable low byte, D1 corresponds to 0x1001 variable high byte, D0 corresponds to 0x1001 variable low byte. (2)Address from 0x00:8000to 0x00:0800 are not currently in use. Users can define themselves as variable (3)Address from 0xFF:0060 to 0XFF:006B address, are CAN communication interface configuration and transceiver buffer. Accessing DGUS variable memory uses the SFR register interface of the table below. | SFR name | Address | Instruction | | |----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | RAMMODE | 0xF8 | The interface control of DGUS variable memory access, which is Bit Addressable. 7. Write 1 to occupy DGUS variable memory for reading and writing, and must be cleared when not occupied; 8. APP_EN Write 1 to start reading and writing once, and it is cleared after hardware execution; 8. APP_RW 1= read variable memory 0= write variable memory; 9. 4APP_ACK hardware pair 8051 occupies the variable memory request, 1 = OK, 0 = BUSY, need to continue to wait; 10. 30 Corresponding Data3:DATA0 Writing Enables 1=corresponding Byte is written 0=corresponding Byte is not written; | | | ADR_H | 0XF1 | DGUS variable memory high 8-bit address,A23:A16. | | | ADR_M | 0XF2 | DGUS variable memory middle 8-bit address,A15:A8. | | memory to use. | ADR_L | 0XF3 | DGUS variable memory low 8-bit address,A7:A0. | | |---------|------|---------------------------------------------------------------------------------------------|--| | | | The increment of address automatically increases after reading and writing of DGUS variable | | | ADR_INC | 0xF4 | memory, that is after reading and writing ADR_H:M:L=before reading and writing | | | | | ADR_H:M:L+ADR_INC. | | | DATA3 | 0xFA | DGUS variable data interface, write selection corresponds to RAMMODE.3. | | | DATA2 | 0XFB | DGUS variable data interface, write selection corresponds to RAMMODE.2. | | | DATA1 | 0XFC | DGUS variable data interface, write selection corresponds to RAMMODE.1. | | | DATA0 | 0XFD | DGUS variable data interface, write selection corresponds to RAMMODE.0. | | DGUS variable memory must be read and written according to the following process(If you want to use interrupt in the application, the interrupt must be closed when the main application reads and writes DGUS variable data, not nested.) - (1) Configured address and address increment; - (2) Set RAMMODE as 0x8F (write) or 0xAF (read), check if RAMMODE. 4=1 confirms access to read and write control. - (3) Read and write data, set RAMMODE as 0X00 after reading and writing. Examples of application: Read and write two double words in 0x0800 address (corresponding to DGUSII variable memory address 0x1000). MOV ADR H,#00H ;Configure DGUS variable memory address MOV ADR M,#08H MOV ADR L,#00H MOV ADR INC,#01H ;Configuration address increment MOV ;Start read mode RAMMODE,#0AFH JNB APP\_ACK,\$ ;Waiting for confirmation MOV R0,#TEST BUF ;Demonstration reading MOV R1,#2 RDVP: APP\_EN **SETB** ;Start reading data once JB APP EN,\$ MOV @R0,DATA3 **INC** R<sub>0</sub> MOV @R0,DATA2 **INC** R<sub>0</sub> MOV @R0,DATA1 **INC** R0 MOV @R0,DATA0 INC R0 DJNZ R1,RDVP CLR APP\_RW ;Writing mode, demo writing MOV ADR\_L,#00H ;Adjust the address to 0x08:0000 MOV R0,#TEST BUF MOV R1,#2 WRVP: MOV DATA3,@R0 INC R0 MOV DATA2,@R0 INC R0 MOV DATA1,@R0 INC R0 MOV DATA0,@R0 SETB APP\_EN ;Start writing data once JNB APP EN,\$ INC R0 DJNZ R1,WRVP MOV RAMMODE, #00H ;Variable memory read and write ends # 3.2.3 Data Memory(32KBytes) OS 8051 CPU Of T5L has 32KBytes RAM as data storage, corresponding address from 0x8000 to 0xFFFF, related interface SFR are as follows. | SFR name | Address | Instruction | | | |----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | DPC | 0x93 | After using DPTP MOVX instruction operation, DPTR change mode: DPC=0X00:DPTR remains unchanged after operation of MOVX instructions. If developed using C51, DPTR must be configured as 0x00 DPC=0X01 After MOVX instruction operation, DPTR=DPTR+1 DPC=0X03 After MOVX instruction operation, DPTR=DPTR-1 | | | | DPH | 0X83 | DPTR data pointer | | | | DPL | 0X82 | | | | The address space from 0x0000 to 0x7FFF prohibit using MOVX instructions to read and write, which may cause code to run abnormally. T5L MOVX instruction takes three instruction cycles (14.5nS in 3T, 11.0592MHz crystal), and DPC can configure DPTR automatic incremental (or decrement) mode, which makes T5L read-write data memory much faster than standard 8051, especially for reverse storage read-write applications. #### Examples of application: MOV DPC,#01H ;DPTR++ MOV DPTR,#8000H MOVX A,@DPTR ;A=@8000 MOVX A,@DPTR ;A=@8001,After readingDPTR=8002 ### 3.2.4 Extended SFR register Extended SFR registers use EXADR, EXDDATA register to read and write. | SFR name | Address | Instruction | |----------|---------|------------------------------------------------------------------------------------------------| | EXADR | 0xFE | Extend the SFR address and automatically add 1 to the next SFR after each reading and writing. | | EXDATA | 0xFF | Expanding SFR data interface | The extended SFR register defines the register interface of the Mathematical Operating Unit (MDU) and provides 48 additional data storage for users. The following table is defined: | EXADR | Definition | Instruction | |-------|------------|--------------------------------------| | 0x00 | MDU_A7 | Maximum bit of MDU A register(64bit) | | ••••• | | | | 0x07 | MDU_A0 | Minimum bit of MDU A register(64bit) | | 0x08 | MDU_B7 | Maximum bit of MDU B register(64bit) | | ••••• | | | | 0x0F | MDU_B0 | Minimum bit of MDU B register(64bit) | | 0x10 | MDU_C7 | Maximum bit of MDU C register(64bit) | | ••••• | | | | 0x17 | MDU_C0 | Minimum bit of MDU C register(64bit) | | 0x18 | EXR0 | First extended data register. | | 0x19 | EXR1 | Second extended data register | | 0x3F | EXR39 | Fortieth extended data register | If read-write extension SFR is needed in interrupt application, the main program must shutdown interrupt when read-write extension SFR, and can not be nested. # 3.3 Mathematical operating unit(MDU) Due to the limited computing power of 8051, the hardware mathematic unit (MDU) is extended in T5L to improve computing power. OS 8051 applications can access hardware MAC and hardware divider. The related SFR definitions are as follows: | SFR name | Address | Instruction | | |----------|---------|------------------------------------------------------------------------------------------------------|--| | | | The MAC hardware multiplier-adder control register is defined as follows: | | | | | .7 MAC enabled, write 1 to perform a calculation, becomes zero after hardware treatment; | | | | | .6 MAC mode, 1 is multiplier-adder mode: C=A*B+C,0 is multiplier mode:C=A*B; | | | | | .5 Write 0; | | | MAC_CN | 0xE5 | .4 1=64bit MAC 0=32bit MAC(A3:0/B3:0/C7:0,note that C is still 64bit ); | | | | | .3 1 = Signed number, 0 = Unsigned number; | | | | | .20 Write 0; | | | | | The A . B . C register group is the MDU_A, MDU_B, MDU_C register group of extended SFR | | | | | registers. | | | | | DIV hardware divider control register (division C/A, quotient A, remainder B) is defined as follows: | | | | | .7 DIV enabled write 1 to perform a calculation and the hardware to perform zero clearance; | | | | | .6 DIV mode 1: Rounded 0: Not rounded; | | | DIV CN | | .54 Undefined, write 0; | | | DIV_CIV | | .3 1 = Signed number 0 = unsigned number; | | | | | .20 Write 0; | | | | | The A . B . C register group is the MDU_A, MDU_B, MDU_C register group of extended SFR | | | | | registers. | | Examples of application: 32bit MAC calculate 0x1234\*0x5678-0x2000 | MOV | EXADR,#04H | ;write A3:A0=0x 00 00 12 34 | |-----|-------------|-----------------------------| | MOV | EXDATA,#00H | | | MOV | EXDATA,#00H | | | MOV | EXDATA,#12H | | | MOV | EXADR,#34H | ;write B3:B0=0x 00 00 56 78 | | MOV | EXDATA,#00H | | | MOV | EXDATA,#00H | | | MOV | EXDATA,#56H | | | | | 1 | |------------|--------------|--------------------------------------------------| | MOV | EXDATA,#78H | | | MOV | EXADR,#10H | ;write C7:C0=0xFF FF FF FF FF FF E0 00 (-0x2000) | | MOV | EXDATA,#0FFH | | | MOV | EXDATA,#0FFH | | | MOV | EXDATA,#0FFH | | | MOV | EXDATA,#0FFH | | | MOV | EXDATA,#0FFH | | | MOV | EXDATA,#0FFH | | | MOV | EXDATA,#0E0H | | | MOV | EXDATA,#00H | | | MOV | MAC_CN,#0C8H | ;32bit integer MAC | | WTMAC: MOV | A,MAC_CN | | | JB | ACC,7,WTMAC | | | MOV | EXADR,#10H | ;read results00 00 00 00 06 25 E0 60 | | MOV | R7,EXDATA | | | MOV | R6,EXDATA | | | MOV | R5,EXDATA | | | MOV | R4,EXDATA | | | MOV | R3,EXDATA | | | MOV | R2,EXDATA | | | MOV | R1,EXDATA | | | MOV | R0,EXDATA | | | | | | ### **3.4** Timer T5L OS 8051 has three timers T0/T1/T2, of which T0/T1 is consistent with standard 8051, and T2 can only work in 16 bit Autoload mode. The clocks of T0 and T1 are 1/12 of the CPU main frequency. The clocks of T2 can be configured as 1/12 or 1/24 of the CPU main frequency. Relevant SFR are shown in the table below. | SFR name | Address | Instructions | |----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TCON | 0x88 | T0, T1 control registers, same as standard 8051, can be addressable by bit .7=TF1 .6=TR1 .5=TF0 .4=TR0 .3=IE1 .1=IEO .0=ITO IT1 and IT0 are external interrupt trigger mode selection: 0 = low level trigger 1 = down-jump edge trigger. | | TMOD | 0x89 | T0, T1 mode selection, same as standard 8051. | | TH0 | 0x8C | | | TL0 | 0x8A | | | TH1 | 0x8D | | | TL1 | 0x8B | | | T2CON | 0xC8 | The T2 control register can be addressable by bit. 7:Clock frequency division selection,0=CPU Main frequency /12, 1=CPU Main frequency /24; 64:must write 1; 31:must write 0; .0:TR2,1=T2 run 0=T2 close; | | TH2 | 0xCD | T2 running value, automatically loaded every time counting overflow TH2=CRCH | | TL2 | 0xCC | TL2=CRCL. | | TRL2H | OxCB The reload value of T2 = 65536-T2 timer interval (uS)*T2 clock frequency (MHz). CPU main frequency = crystal frequency * 56/3, corresponding CPU main frequency | | | TRL2L | 0xCA | crystal frequency * 14/9, CPU main frequency / 24 = crystal frequency * 7/9. For example, the CPU main frequency is 206.438 MHz, T2 chooses 1/12 frequency division, and the setting value of 1 mS timer interval is 48333 (0xBCCD). | The relevant settings of timer interrupt are as follows: | Interrupt type | Program entry address | Trigger marker | Interrupt enabling control | Remarks | |-----------------|-----------------------|----------------|----------------------------|-------------------------------------------------------------------------------------------------------------| | T0 interruption | 0x000B | TF0(TCON.5) | IEN0.1 | Automatic clearing of TF0 in interrupt response | | T1 interruption | 0x001B | TF1(TCON.7) | IEN0.3 | Automatic clearing of TF0 in interrupt response | | T2 interruption | 0x002B | TF2(TCON.6) | IEN0.5 | After interrupt response, TF2 needs to be cleared by software, otherwise interrupt will be triggered again. | Examples of application: In 11.0592 MHz crystal (corresponding to the main frequency of CPU 206.4384 MHz), T2 1mS interruption is set to output 500 MHz square wave at P 1.0. ORG 002BH ;T2 interrupt program entry LJMP T21NT T21NT: CLR TF2 ;T2 interrupt program CPL P1.0 **RETI** ;initialization of T2-related SFR MOV CRCH,#HIGH(48333) ;1mS timer MOV CRCL,#LOW(48333) MOV T2CON,#71H ;TR2=1 ORL IEN0,#20H ;ET2=1 turn on T2 interrupt ## 3.5 Watchdog Timer(WDT) WDT count overflow time is saved at 0xFF001B variable address, WDT reset time = set value/CPU main frequency (Hz), in seconds. WDT operations relate code example: ANL MUX\_SEL,#0FDH; WDT must be turned off before setting overflow time MOV ADR H,#0FFH; Configure WDT reset time 1 S=206438400 (0x0C 4E 00 00) MOV ADR M,#00H MOV ADR L,#1BH MOV RAMMODE,#8FH JNB APP ACK,\$ MOV DATA3,#0CH MOV DATA2,#4EH MOV DATA1,#00H MOV DATA0,#00H SETB APP EN JB APP\_EN,\$ MOV RAMMODE,#00H ORL MUX\_SEL,#02H; Turn on WDT; Once turned on, the dog must be fed before WDT overflow to avoid system reset. ORL MUX SEL,#01H; WDT reset (feed the dog) #### 3.6 IO T5L OS 8051 has three 8 bit parallel ports(P0-P2) and a 4 bit parallel port(P3.0-P3.3), a total of 28 IO ports. P0-P0.7 of P0 port is multiplexed with UART and CAN interface, and multiplexing function or IO function can be selected through MUX SEL register. The input of all IO ports is always open, the input is floating, and there is no internal pull-up or pull-down. When IO port is used as output, it is necessary to open the output control, and the output driving ability can also be configured. Because the IO interface of power-on reset process is input mode, when used as output, it must be pulled up or pulled down externally to ensure that the reliable output of power-on process is ensured, and will not malfunction due to IO floating. P3.0 is external interrupt 0, and P3.1 is external interrupt 1 input. It can be configured as low level trigger (0) or jump down edge trigger (1) through IT0 and IT1. In addition to the need to control the output switch, output strength and peripheral multiplexing power-on initialization configuration, the subsequent use of IO is consistent with the standard 8051. IO-related SFR are shown in the following table: | SFR name | Address | Instructions | | | |----------|---------|-------------------------------------------------------------------------------------------------|--|--| | P0 | 0x80 | Addressable by bit, same as standard 8051 | | | | P1 | 0x90 | Addressable by bit, same as standard 8051 | | | | P2 | 0xA0 | Addressable by bit, same as standard 8051 | | | | Р3 | 0xB0 | It can be addressable by bit, the same as standard 8051, only P3.0-P3.3 is valid. | | | | | | P0 Interface Output Configuration: | | | | | | .7 0=P0.7Output shutdown 1=P0.7Output Open (push-pull output); | | | | | | .6 0=P0.6Output shutdown 1=P0.6Output Open (push-pull output ); | | | | | | .5 0=P0.5Output shutdown 1=P0.5Output Open (push-pull output ); | | | | POMDOUT | 0xB7 | .4 0=P0.4Output shutdown 1=P0.4Output Open (push-pull output); | | | | | | .3 0=P0.3Output shutdown 1=P0.3Output Open (push-pull output); | | | | | | .2 0=P0.2Output shutdown 1=P0.2Output Open (push-pull output); | | | | | | .1 0=P0.1Output shutdown 1=P0.1Output Open (push-pull output); | | | | | | .0 0=P0.0Output shutdown 1=P0.0Output Open (push-pull output); | | | | P1MDOUT | 0xBC | P1 interface output configuration | | | | P2MDOUT | 0xBD | P2 interface output configuration | | | | P3MDOUT | 0xBE | P3 interface output configuration | | | | | | Selection of peripheral reuse: | | | | | | .7 1 = CAN interface leads to P 0.2 and P 0.3,0 = CAN interface is not introduced, it is IO | | | | MUX_SEL | 0xC9 | interface. | | | | | | .6 1 = UART2 interface leads to P 0.4 and P 0.5,0 = UART2 interface is not introduced, it is IO | | | | | | interface; | | | | | | .5 1 = UART3 interface leads to P 0.6 and P 0.7,0 = UART3 interface is not introduced, it is IO | | | | |----------|------|-------------------------------------------------------------------------------------------------|--|--|--| | | | interface; | | | | | | | .42 Retain; | | | | | | | .1 WDT control, 1=open 0=close; | | | | | | | .0 WDT feed dog, 1=feed the dog one time(The WDT count becomes zero, and the watchdog' | | | | | | | overflowing time is one second. ); | | | | | DODTDDIA | 0 50 | Driver capability configuration of IO port output mode, $0x00 = 4mA \ 0x01 = 8mA$ (recommended | | | | | PORTDRV | 0xF9 | values) 0x02=16mA 0x03=32mA | | | | The relevant settings of external interrupt of IO port are as follows: | Interrupt | Program | Trigger | Interrupt enabling | Remarks | | |------------------|---------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | type | entry address | marker | control | Remarks | | | EX0<br>interrupt | 0x0003 | IE0(TCON.1) | IEN0.0 | IE0 is cleared automatically when interrupt response, corresponding to P3.0. IT0 (TCON.0) = 0 low level trigger interrupt, IT0 = 1 jump down edge trigger interrupt. | | | EX1<br>interrupt | 0x0013 | IE1(TCON.3) | IEN0.2 | IE1 is cleared automatically when interrupt response, corresponding to P3.1. IT1 (TCON.2) = low level trigger interrupt, IT1 = 1 jump down edge trigger interrupt. | | # 3.7 UART communication interface ### 3.7.1 UART2 interface UART2 related SFR are shown in the following table. | SFR name | Address | Instructions | | | | | |----------|---------|---------------------------------------------------------------------------------------------------|--|--|--|--| | MUX SEL | 0xC9 | .6 1 = UART2 interface leads to P 0.4 and P 0.5, 0 = UART02 interface does not lead out, it is IO | | | | | | WICH_BEE | | port . | | | | | | | | UART2 control interface, the same as standard 8051, can be addressable by bit. | | | | | | SCONO | 0x98 | .7=SM0 .6=SM1 .5=SM2(multiprocessor communication bit) | | | | | | | | .4=REN0 .3=TB80 .2=RB80 .1=TI0 .0=RI0. | | | | | | SBUF0 | 0x99 | UART2 transceiver data interface | | | | | | ADCON | 0xD8 | Baud rate generator selection, $0x00 = T1$ timer (standard 8051), $0x80 = SRELOH$ : L. | | | | | | PCON | 0x87 | .7 = SMOD baud rate frequency doubling selection, 0 = no frequency doubling, 1 = frequency | | | | | | rcon | UX8/ | doubling. | | | | | | SRELOH | 0xBA | When ADCON = $0x80$ , SRELOH:L is used to set the baud rate without taking up T1. | | | | | | | | SMOD=0 SREOH:L=1024-CPU main frequency/(64*baud rate) | | | | | | SRELOL | 0 4 4 | SMOD=1 SREOH:L=1024-CPU main frequency/(32*baud rate) | | | | | | SKELUL | | CPU main frequency = crystal frequency * 56/3, 11.0592 MHz crystal corresponds to 206.4384 MHz | | | | | | | | main frequency. | | | | | The relevant settings for UART2 interruption are as follows: | Interrupt type | Program entry address | Trigger marker | Interrupt enabling control | Remarks | |----------------|-----------------------|----------------|----------------------------|--------------------------------------------------------| | UART2 | 0x0023 | RIO(SCON0.0) | IEN0.4 | After interruption processing, software needs to clear | | interrupt | 0x0025 | TIO(SCON0.1) | 112110.4 | the interruption trigger mark. | ### 3.7.2 UART3 interface UART3 related SFR are shown in the following table. | SFR name | Address | Instructions | | | | | | |----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | MUX_SEL | 0xC9 | .5 1 = UART3 interface leads to P 0.6, P 0.7, 0 = UART3 interface does not lead out, it is IO port. | | | | | | | SCON1 | 0x9B | UART3 control interface, it is not addressable by bit. 7 0=9bit UART, 1=8bit UART; 6 Undefined; .5=SM2(multiprocessor communication bit) .4=REN .3=TB8 .2=RB8 .1=TI .0=RI. Clearing the SCON1 bit tag requires two consecutive writings, such as ANL SCON1,#0FEH ANL SCON1,#0FEH | | | | | | | SBUF1 | 0x9C | UART3 transceiver data interface | | | | | | | SREL1H | 0xBB | UART3 baud rate setting (CPU main frequency = crystal frequency * 56/3, 11.0592 crystal | | | | | | | SREL1L | 0x9D | corresponding to 206.4384 MHz main frequency): SRE1H:L=1024-CPU main frequency/(32*baud rate) | | | | | | The relevant settings for UART3 interruption are as follows: | Interrupt | Program entry | Trigger | Interrupt enabling | Remarks | |-----------|---------------|------------|--------------------|------------------------------------------------------------| | type | address | marker | control | Remarks | | UART3 | 0.0002 | SCON1.0,SC | IENO O | After interruption processing, software needs to clear the | | interrupt | 0x0083 | ON1.1 | IEN2.0 | interruption trigger mark. | ### 3.7.3 UART4 interface UART4 related SFR are shown in the following table. | SFR name Address Instructions | |-------------------------------| |-------------------------------| | | | 1 | | | |-------------|------|--------------------------------------------------------------------------------------------|--|--| | | | UART4 transmition control: | | | | | | .7 UART4 sending enables,0=close,1=open; | | | | SCON2T | 0x96 | .6 0=8bit Mode,1=9bit Mode; | | | | SCONZI | 0.00 | .5 TB8, 9 <sup>th</sup> bit sent in 9bit mode; | | | | | | .41 Write0; | | | | | | .0 TI, send flag, the position at which the stop bit is sent. | | | | | | UART4 receive control: | | | | | 0x97 | .7 UART4 sending enables,0=close,1=open; | | | | SCON2R | | .6 Write0; | | | | SCONZK | | .5 TB8, 9th bit sent in 9bit mode; | | | | | | .41 Write0; | | | | | | .0 R RI, receive tag, set when the stop bit is received when a valid stop bit is received. | | | | SBUF2_TX | 0x9E | UART4 sending data interface | | | | SBUF3_RX | 0x9F | UART4 receiving data interface | | | | BODE2_DIV_H | 0XD9 | UART4 baud rate setting | | | | BODE2_DIV_L | 0XD7 | BODE2_DIV_H:L=CPU main frequency/(8*baud rate) | | | ### The relevant settings of UART4 interruption are as follows: | Interment type | Program entry | Trigger | Interrupt enabling | Remarks | |----------------|---------------|----------|--------------------|------------------------------------------------------------| | Interrupt type | address | marker | control | Remarks | | UART4 send | 00052 | SCONAT O | IENII 2 | After interruption processing, software needs to clear the | | interrupt | 0x0053 | SCON2T.0 | IEN1.2 | interruption trigger mark. | | UART4 receive | 0.005D | CCONOD O | IENII 2 | After interruption processing, software needs to clear the | | Interruption | 0x005B | SCON2R.0 | IEN1.3 | interruption trigger mark. | # 3.7.4 UART5 interface The relevant settings of UART5 are as follows: | SFR name | Address | Instructions | | | |-------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | SCON3T 0xA7 | | UART5 transmition control: .7 UART5 sending enables,0=close,1=open; .6 0=8bit Mode,1=9bit Mode; .5 TB8, 9 <sup>th</sup> bit sent in 9bit mode; .41 Write0; .0 TI, send flag, set when the stop bit is received when a valid stop bit is received. | | | | SCON3R | 0xAB | UART5 receive control: .7 UART5 sending enables,0=close,1=open; .6 Write0; .5 TB8, 9 <sup>th</sup> bit sent in 9bit mode; .41 Write0; .0 R RI, receive tag, set when the stop bit is received when a valid stop bit is received. | | | | SBUF3_TX | 0xAC | UART5 sending data interface | | | | SBUF4_RX | 0xAD | UART5 receiving data interface | | | |------------------|------|------------------------------------------------|--|--| | BODE3_DIV_H | 0xAE | UART5 baud rate setting | | | | BODE3 DIV L 0xAF | | BODE3_DIV_H:L=CPU main frequency/(8*baud rate) | | | The relevant settings of UART5 interruption are as follows: | Interrupt type | Program entry | Trigger | Interrupt enabling | Remarks | |----------------|---------------|----------|--------------------|------------------------------------------------------------| | | address | marker | control | | | UART5 send | 0x0063 | SCON3T.0 | IEN1.4 | After interruption processing, software needs to clear the | | interrupt | 0x0003 | SCONS1.0 | ILINI.4 | interruption trigger mark. | | UART5 receive | 0~006D | CCON2D O | IDNI 5 | After interruption processing, software needs to clear the | | Interruption | 0x006B | SCON3R.0 | IEN1.5 | interruption trigger mark. | # 3.8 CAN communication interface The SFR associated with the CAN interface are shown in the following table: | SFR name | Address | Instrctions | |----------|---------|-------------------------------------------------------------------------------------------------------| | MUX_SEL | 0xC9 | .7.1 = CAN interface leads to P 0.4 and P 0.5,0 = CAN interface does not lead out, it is IO port. | | | | CAN Interface Control Register: | | | | .7 CAN interface enabled,1=open 0=close; | | | | .6 CAN interface mode, 1=software reset 0=working normally; | | | | .5 Write 1 to configure the configuration data of CAN interface once (0xFF:0060-0xFF:0062), and | | CAN CR | 0x8F | cleaned up after hardware processing; | | | 0.101 | .4 Set speed mode, $1 = 1$ Sampling $0 = 3$ Sampling; | | | | .3 Setting filter mode,1=double 0=single; | | | | .2 Write 1 starts sending once, and the hardware processing (sending success, arbitration failure, EI | | | | (CAN_IR.3) occurred, software reset) clears up; | | | | .1-0 Undefined,write 0. | | | | CAN Interface Interrupt Status Register | | | | .7 RF_IF, remote frame receiving interrupt flag, hardware configuration, software clearance is | | | 0x91 | required; | | | | .6 CAN_RX_IF, CAN receives interrupt markers, hardware placement, software clearance is required. | | | | During the placement period, the hardware can no longer update the data; | | CANLID | | .5 CAN_RX_IF, CAN sends a successful interrupt marker, hardware placement, software clearance is | | CAN_IR | | required; | | | | .4 OI, receiving overflow markers, hardware blanking, software clearance is required; | | | | .3 EI, error marker, CAN ET [4:0] has an error when the bit is raised and software clearance is | | | | required; | | | | .2 JI, send arbitration mark, 1 = send arbitration failure, 0 = send arbitration success; | | | | .10 Undefined. | | | | CAN interface error type register, hardware blanking, need software zeroing. Addressable by bit. | | CANTE | 0.50 | .7 Node suspension identification; | | CAN_ET | 0xE8 | .6 Active error identification; | | | | .5 Passive error identification; | | | <br> | |--------------------------------------|------| | .4 CRC Check error identification; | | | .3 Response error identification; | | | .2 Format error identification; | | | .1 Bit filling error identification; | | | .0 Bit error identification. | | The CAN communication interface is defined in terms of DGUS variable space. The related variables are defined in the following table: | Address | Position | Length | Definition | Instructions | | |---------------|----------------|--------|------------|--------------------------------------------------------------------------------------------------------------------------|--| | | D3 | 1 | BRP | | | | | D2 | 1 | BTR0 | BRP: Baud rate frequency divider register BTR0: [7:5] is the synchronous jump width sjw, [3:0] prop propagation time T0. | | | 0xFF:0060 | | | BTR1 | [7:4] is phase buffer segment 1, T1, [3:0] is phase buffer segment 2, T2. | | | | | | Undefined, | T0+T1+T2=CPU main frequency/(baud rate*(BRP*2+1))-4 | | | | D0 | 1 | write 0 | 10+11+12 et e main nequency/(bada fate (BRI 2+1)) i | | | 0xFF:0061 | D3:D0 | 4 | ACR3:0 | Acceptance code register | | | 0xFF:0062 | D3:D0 | 4 | AMR3:0 | Acceptance code register | | | | D3 | 1 | RXERR | Receiving error count register | | | 0xFF:0063 | D2 | 1 | TXERR | Sending error count register | | | | D1:D0 | 2 | Undefined | Write 0 | | | | D3 | 1 | CAN_TX_ | [7]IDE,[6]RTR,[3:0]—DLC, frame data length | | | 0xFF:0064 | D3 | 1 | BUFFER | [7]IDE,[0]KTK,[5.0]—DEC, Italiic data length | | | | D2:D0 | 3 | Undefined | | | | | | | ID | ID, 29bit is valid when expanding frames, 11bit is valid for standard frames. | | | | D3 | 1 | | ID, first byte, standard frame and extended frame. | | | 0vFF:0065 | 0xFF:0065 D2 1 | | | ID, the second byte, [7:5] is 3bit of the standard frame, and the second byte of the | | | 0XI17.0003 | | | | extended frame. | | | | D1 | 1 | | ID, third byte, invalid standard frame, third byte of extended frame. | | | | D0 | 1 | | ID, fourth byte, invalid standard frame, [7:3] extended frame height 5 bit. | | | 0xFF:0066 | D3:D0 | 4 | Data | Send data,DATA1-DATA4 | | | 0xFF:0067 | D3:D0 | 4 | Data | Send data,DATA5-DATA8 | | | | D3 | 1 | CAN_RX_ | [7]IDE,[6]RTR,[3:0]—DLC, frame data length | | | 0xFF:0068 | D3 | 1 | BUFFER | [7]DE,[0]KTK,[5.0] DEC, Hame data length | | | | D2:D0 | 3 | Undefined | | | | | | | ID | ID, 29bit is valid when expanding frames, 11bit is valid for standard frames. | | | | D3 | 1 | | ID, first byte, standard frame and extended frame. | | | 0xFF:0069 | D2 | 1 | | ID, the second byte, [7:5] standard frame height 3 bit, and the second byte of the | | | D2 | | 1 | | extended frame. | | | | D1 | 1 | | ID, third byte, invalid standard frame, third byte of extended frame. | | | | D0 | 1 | | ID, fourth byte, invalid standard frame, [7:3] extended frame height 5 bit. | | | 0xFF:006<br>A | D3:D0 | 4 | Data | Receive data,DATA1-DATA4 | | | 0xFF:006<br>B | D3:D0 | 4 | Data | Receive data,DATA5-DATA8 | | The relevant settings of CAN interface interruption are as follows: | Interrupt type | Program entry address | Trigger<br>marker | Interrupt enabling control | Remarks | |------------------------|-----------------------|-------------------|----------------------------|---------------------------------------------------------------------------------------| | interface interruption | 0x004B | CAN_IR | I IEN1.1 | After interruption processing, software needs to clear the interruption trigger mark. | # 3.9 Interrupt system # 3.9.1 Interrupt control SFR T5L OS CPU has 12 interrupts. The related control SFR list is as follows: | SFR name | Address | Instructions | |----------|---------|---------------------------------------------------------------------------------------------------------------| | | | The interrupt enable controller 0 can be addressed by bit. | | | | .7 Interrupt master control bit;0=all interrupts closed 1=Whether an interrupt is opened is controlled by the | | | | control bit of each interrupt; | | | | .6 Must write 0; | | IEN0 | 0xA8 | .5 ET2 T2 timer interrupt enable control bit; | | ILINO | UXAO | .4 ES0 USRT2 interrupt enable control bit; | | | | .3 ET1 T1 timer interrupt enable control bit; | | | | .2 EX1 external interrupt 1 (P3.1 pin) interrupt enabling control bit; | | | | .1 ET0 T0 timer interrupt enable control bit; | | | | .0 EX0 external interrupt 1 (P3.0 pin) interrupt enabling control bit. | | | | The interrupt enable controller 1 can be addressed by bit. | | | | .76 Must write 0; | | | | .5 ES3R UART5 receiving interrupt enabled control bit; | | IEN1 | 0xB8 | .4 ES3T UART5 receiving interrupt enabled control bit; | | ILINI | ОХВ | .3 ES2R UART4 receiving interrupt enabled control bit; | | | | .2 ES2R UART4 receiving interrupt enabled control bit; | | | | .1 ECAN CAN communication interrupt enabling control bit; | | | | .0 Must write 0. | | | | Interrupt enabling controller 2 | | IEN2 | 0x9A | .71 Must write 0 | | | | .0 ESI USRT3 interrupt enabling control bit | | IEN3 | 0xD1 | Interrupt enabling controller 3, must write 0x00 | | IP0 | 0xA9 | Interrupt priority controller 0 | | IP1 | 0xB9 | Interrupt priority controller 1 | # 3.9.2 Interrupt priority The interrupt priority of T5L OS CPU is handled according to the following rules: (1) Twelve interrupts are divided into six groups with two interrupts in each group. The priority in the same group is fixed. For example, the priority of interrupt 0 is higher than that of UART3, as shown in the table below. | Cassains | IDO a a magna a dan a a | ID1 comesmon dones | Interrupt correspondence | | | | |----------|-------------------------|--------------------|--------------------------|------------------------------|--|--| | Grouping | IP0 correspondence | IP1 correspondence | High priority | Low priority | | | | G0 | .0 | .0 | External interrupt 0 | UART3 interruption | | | | G1 | 1 | 1 | T0 timer interrupt | CAN communication | | | | UI | .1 | .1 | 10 timer interrupt | interruption | | | | G2 | .2 | .2 | External interrupt 1 | UART4 send interrupt | | | | G3 | .3 | .3 | T1 timer interrupt | UART4 receiving interruption | | | | G4 | .4 | .4 | UART2 interrupt | UART5 send interrupt | | | | G5 | .5 | .5 | T2 timer interrupt | UART5 receiving interruption | | | (2) There are four levels of priority among the six groups, which can be configured by the corresponding bits of IP0 and IP1 according to the table below. | Inter group priority | IP1 counterpart | IP0 counterpart | |----------------------|-----------------|-----------------| | 3(highest) | 1 | 1 | | 2 | 1 | 0 | | 1 | 0 | 1 | | 0(minimum) | 0 | 0 | For example, to set the G2 group's T2 timer interrupt and UART5 receive interrupt priority to the highest, you can set 1P1=0x20, 1P0=0x20. (3)If the configurations have the same priority (IP1 = 0x00 IP0 = 0x00), the G0 group has the highest priority and the G5 group has the lowest priority. The interrupt priority weights with the same configuration are as follows: | Weight | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|---------|-------|-----|-----|-----|----------|-----|----------|-------|----------|-----|----------| | Priority | Maximum | | | | | | | | | | | Minimum | | Interrupt | EX0 | UART3 | ET0 | CAN | EX1 | UART4-TX | ET1 | UART4-RX | UART2 | UART5-TX | ET2 | UART5-RX | (4)High priority interrupts can be nested in low priority interrupts (i.e. interrupts with small weights can be interrupted by interrupts with large weights), and at most four levels can be nested. #### Special Notice: T5L OS CPU is fast (1 uS can execute 130-150 instructions on average). Interrupt execution time is short and real-time is very high. It is not recommended that users use interrupt nesting to cause complex program architecture. Interrupt is closed directly at the execution of each interrupt service program (EA = 0), and interrupt is opened again at exit of program (EA = 1). ### 3.10 8051 Instruction set of T5L ASIC | Instruction format | Instruction length | Instruction cycle | Instruction format | Instruction length | Instruction cycle | |--------------------------|--------------------|-------------------|--------------------|--------------------|-------------------| | ADD/ADDDC A,Rn | 1 | 1 | MOV @Ri,direct | 2 | 2 | | ADD/ADDDC A,direct | 2 | 2 | MOV @Ri,#data | 2 | 2 | | ADD/ADDDC A,@Ri | 1 | 2 | MOV DPTR,#data16 | 3 | 3 | | ADD/ADDDC A,@data | 2 | 2 | MOVC A,@A+DPTR | 1 | 3 | | SUBB A,Rn | 1 | 1 | MOVC A,@A+PC | 1 | 3 | | SUBB A,direct | 2 | 2 | MOVX A,@Ri | 1 | 3 | | SUBB A,@Ri | 1 | 2 | MOVX A,@DPTR | 1 | 3 | | SUBB A,#data | 2 | 2 | MOVX A,@Ri,A | 1 | 3 | | INC/DEC A | 1 | 1 | MOVX @DPTR,A | 1 | 3 | | INC/DEC Rn | 1 | 1 | PUSH/POP | 1 | 2 | | INC/DEC direct | 2 | 2 | XCH A,Rn | 1 | 1 | | INC/DEC @Ri | 1 | 2 | XCH A,direct | 2 | 2 | | INC DPTP | 1 | 1 | XCH A,@Ri | 1 | 2 | | MUL AB | 1 | 4 | XCHD A,@Ri | 1 | 2 | | DIV AB | 1 | 4 | ACALL addr11 | 2 | 2 | | DA A | 1 | 1 | LCALL addr16 | 3 | 3 | | ANL/ORL/XRL A,Rn | 1 | 1 | RET/RETI | 1 | 4 | | ANL/ORL/XRL A,direct | 2 | 2 | AJMP addr11 | 2 | 2 | | ANL/ORL/XRL A,@Ri | 1 | 2 | LJMP addr16 | 3 | 3 | | ANL/ORL/XRL A,#data | 2 | 2 | SJMP rel | 2 | 2 | | ANL/ORL/XRL direct,A | 2 | 2 | JMP @A+DPTR | 1 | 3 | | ANL/0RL/XRL direct,#data | 3 | 3 | JZ/JNZ/JC/JNC rel | 2 | 3 | | CLR A | 1 | 1 | JB/JNB/JBC | 3 | 4 | | CPL A | 1 | 1 | CJNE A,direct,rel | 3 | 4 | | RL/RR A | 1 | 1 | CJNE A,#data,rel | 3 | 4 | | RLC/RRC A | 1 | 1 | CJNE Rn,#data,rel | 3 | 4 | | SWAP A | 1 | 1 | CJNE @Ri,#data,rel | 3 | 5 | | MOV A,Rn | 1 | 1 | DJNZ Rn,rel | 2 | 3 | | MOV A,direct | 2 | 2 | DJNZ direct,rel | 3 | 4 | | MOV A,@Ri | 1 | 2 | NOP | 1 | 1 | | MOV A,#data | 2 | 2 | CLR/SETB C | 1 | 1 | | MOV Rn,A | 1 | 1 | CLR/SETB bit | 2 | 2 | Ver1.1 | MOV Rn, direct | 2 | 2 | CPL C | 1 | 2 | |---------------------|---|---|------------|---|---| | MOV Rn,#data | 2 | 2 | CPL bit | 2 | 2 | | MOV direct,A | 2 | 2 | ANL C,bit | 2 | 2 | | MOV direct,Rn | 2 | 2 | ANL C,/bit | 2 | 2 | | MOV direct1,direct2 | 3 | 3 | ORL C,bit | 2 | 2 | | MOV direct,@Ri | 2 | 2 | ORL C,/bit | 2 | 2 | | MOV direct,#data | 3 | 3 | MOV C,bit | 2 | 2 | | MOV @Ri,A | 1 | 1 | MOV bit,C | 2 | 2 | CPU main frequency = crystal frequency \* 56/3, 11.0592MHz crystal corresponds to 206.438MHz main frequency, corresponding to an instruction cycle (1T) of 4.844nS. #### Such as: Under 11.0592 MHz crystal, the following code will output 206.4384/((2+2)\*2)=25.8048 MHz square wave on the P3.3 IO interface. OUTTEST:CPL P3.3 ;2T AJMP OUTTEST ;2T # 4. Simulation Debug With the help of HME05 simulator (need to install the corresponding USB driver), users can connect T5L JTAG interface and debug code IAP and run simulation under Keil development environment. The following points should be paid attention in simulation debugging: - (1)JTAG interface must be selected to OS CPU, and must be JTAG mode, that is, OS/GUI (PIN#32) = 0 JTAGS (PIN#34) = 1. When the 4.3 inch evaluation board is used for simulation, the jumper pad on the JTAG interface side is disconnected. - (2)The AGDI driver is installed to enable Keil to support T5 and HME05 simulators. After installation, select and configure according to the following figure. After installation, copy the header file of T5L OS CPU (\*. INC or \*. h) to KEIL/C51/INC/DWIN directory. - (3)Before setting the breakpoint to read the content of data storage (XDATA), DPC = 0x00 must be ensured, otherwise the data will be misaligned. - (4)Before simulation, it is necessary to ensure that the OS CPU code address 0x00F8 of T5L Flash starts with 0xFF FF 4457 494E 5435, otherwise the JTAG interface of OS CPU is prohibited and HME05 emulator cannot be connected. - (5)Users for standard C or other 8051 platform code migration, please pay attention to SFR header file loading at compile time to select T5L corresponding. INC or. H file. If the SFR definition and T5L definition in customer code are different, you can modify the code or T5L SFR header file to be consistent. - (6)HME05 realizes hardware simulation by downloading code to Code RAM of T5L OS CPU. The code is not burned to Flash in the chip. To burn code into the chip, it is necessary to use SD card interface or UART1 debugging interface. When SD interface is burned, T5L underlying software will automatically change the location of OS code 0x00F8 to 0x0000 (JTAG interface is forbidden) 44 57 49 4E 54 35. T5L OS CPU adopts the standard 8051 architecture. Except for the slight difference between SFR and extended peripheral access, the instruction set is identical. When the user has the original 8051 code, pay attention to the following aspects and you can complete it quickly: - (1)According to the hardware design, after reset, the startup.A51 (C51 startup code) or initcpu () program provided by DWIN is used to simply modify and configure T5L-specific SFR and parameter settings. Typical differences are IO, main frequency of timer, baud rate, interrupt, WDT and so on. - (2)T5L IO output mode is controllable. When switching between input and output modes, PxMDOUT registers should be configured accordingly, otherwise errors will occur. - (3) Turn off interrupt nesting, EA = 0 for each interrupt service program and set 1 when exiting. - (4)When using Out-of-chip RAM (XRAM) as data storage in the code, it should be noted that the starting address of T5L 32KB data RAM starts at 0x8000. - (5)Code 0x00F8 position plus 0xFFFF (or 0x0000 forbid JTAG interface) 44 57 49 4E 54 35. - (6)Accelerate the algorithm of optimizing original code with MDU hardware operation: Move UI and Internet (such as access to DWIN cloud through DWIN WiFi module) function to DGUSII platform, user code is processed by simple read-write DGUS variable space, greatly improve product performance and the efficiency of research and development. # 5. EK043 Evaluation Board EK043 evaluation board uses T5L1 to drive 4.3 inch 480\*272 TFT screen, and matches capacitor touch screen. Its main features include: - (1)11.0592 MHz crystal, 206.4384 MHz main frequency operation, support HME05 simulator. - (2) External 16MB SPI Flash, run standard DGUS II UI; - (3) Power supply and debugging use USB interface; - (4)The OS CPU 8051 program can be downloaded through the USB interface and automatically reset by hardware; - (5)It can read and write DGUS variable memory and download pictures and word libraries through USB interface to facilitate DGUS debugging; - (6) The assembly location of DWIN WiFi module is reserved for easy access to DWIN cloud (both WiFi module and USB occupy UART1 interface, with a baud rate of 921600 bps); - (7)All interfaces of T5L OS CPU are drawn out with 2.54mm spacing through-hole bonding pad and marked. - (8)Six AD, ADC0-ADC3, ADC6-ADC7 which can be used by users are drawn out and marked with 2.54mm spacing through-hole bonding pad. # **Appendix 1** | Date | Revision | Document version | |------------|----------------------------------------------------------|------------------| | 2019.03.15 | First released | V1.0 | | | Modify some errors in the document. | | | 2020.06.22 | Added a description of the WDT reset time settings in OS | V1.1 | | | core. | | If you have any questions or want to know more about the latest information of DWIN products during the use of this document or DWIN products, please contact us in time: 400 toll-free telephone: 400 018 9008 Enterprise QQ and wechat: 400 018 9008 Enterprise mail:dwinhmi@dwin.com.cn Thank you for your support for DWIN. Your support is the driving force of our progress. Thank you all.