NuMaker emWin HMI

Committer:
csyang2
Date:
Mon Mar 04 15:47:41 2024 +0800
Revision:
10:c8165817d92a
Parent:
1:c0f972361605
Support NuMaker-IoT-M467

Who changed what in which revision?

UserRevisionLine numberNew contents of line
csyang2 1:c0f972361605 1 /*********************************************************************
csyang2 1:c0f972361605 2 * SEGGER Software GmbH *
csyang2 1:c0f972361605 3 * Solutions for real time microcontroller applications *
csyang2 1:c0f972361605 4 **********************************************************************
csyang2 1:c0f972361605 5 * *
csyang2 1:c0f972361605 6 * (c) 1996 - 2018 SEGGER Microcontroller GmbH *
csyang2 1:c0f972361605 7 * *
csyang2 1:c0f972361605 8 * Internet: www.segger.com Support: support@segger.com *
csyang2 1:c0f972361605 9 * *
csyang2 1:c0f972361605 10 **********************************************************************
csyang2 1:c0f972361605 11
csyang2 1:c0f972361605 12 ** emWin V5.48 - Graphical user interface for embedded applications **
csyang2 1:c0f972361605 13 All Intellectual Property rights in the Software belongs to SEGGER.
csyang2 1:c0f972361605 14 emWin is protected by international copyright laws. Knowledge of the
csyang2 1:c0f972361605 15 source code may not be used to write a similar product. This file may
csyang2 1:c0f972361605 16 only be used in accordance with the following terms:
csyang2 1:c0f972361605 17
csyang2 1:c0f972361605 18 The software has been licensed by SEGGER Software GmbH to Nuvoton Technology Corporationat the address: No. 4, Creation Rd. III, Hsinchu Science Park, Taiwan
csyang2 1:c0f972361605 19 for the purposes of creating libraries for its
csyang2 1:c0f972361605 20 Arm Cortex-M and Arm9 32-bit microcontrollers, commercialized and distributed by Nuvoton Technology Corporation
csyang2 1:c0f972361605 21 under the terms and conditions of an End User
csyang2 1:c0f972361605 22 License Agreement supplied with the libraries.
csyang2 1:c0f972361605 23 Full source code is available at: www.segger.com
csyang2 1:c0f972361605 24
csyang2 1:c0f972361605 25 We appreciate your understanding and fairness.
csyang2 1:c0f972361605 26 ----------------------------------------------------------------------
csyang2 1:c0f972361605 27 Licensing information
csyang2 1:c0f972361605 28 Licensor: SEGGER Software GmbH
csyang2 1:c0f972361605 29 Licensed to: Nuvoton Technology Corporation, No. 4, Creation Rd. III, Hsinchu Science Park, 30077 Hsinchu City, Taiwan
csyang2 1:c0f972361605 30 Licensed SEGGER software: emWin
csyang2 1:c0f972361605 31 License number: GUI-00735
csyang2 1:c0f972361605 32 License model: emWin License Agreement, signed February 27, 2018
csyang2 1:c0f972361605 33 Licensed platform: Cortex-M and ARM9 32-bit series microcontroller designed and manufactured by or for Nuvoton Technology Corporation
csyang2 1:c0f972361605 34 ----------------------------------------------------------------------
csyang2 1:c0f972361605 35 Support and Update Agreement (SUA)
csyang2 1:c0f972361605 36 SUA period: 2018-03-26 - 2019-03-27
csyang2 1:c0f972361605 37 Contact to extend SUA: sales@segger.com
csyang2 1:c0f972361605 38 ----------------------------------------------------------------------
csyang2 1:c0f972361605 39 File : GUIDRV_SLin.h
csyang2 1:c0f972361605 40 Purpose : Interface definition for GUIDRV_SLin driver
csyang2 1:c0f972361605 41 ---------------------------END-OF-HEADER------------------------------
csyang2 1:c0f972361605 42 */
csyang2 1:c0f972361605 43
csyang2 1:c0f972361605 44 #ifndef GUIDRV_SLIN_H
csyang2 1:c0f972361605 45 #define GUIDRV_SLIN_H
csyang2 1:c0f972361605 46
csyang2 1:c0f972361605 47 #if defined(__cplusplus)
csyang2 1:c0f972361605 48 extern "C" { /* Make sure we have C-declarations in C++ programs */
csyang2 1:c0f972361605 49 #endif
csyang2 1:c0f972361605 50
csyang2 1:c0f972361605 51 /*********************************************************************
csyang2 1:c0f972361605 52 *
csyang2 1:c0f972361605 53 * Configuration structure
csyang2 1:c0f972361605 54 */
csyang2 1:c0f972361605 55 typedef struct {
csyang2 1:c0f972361605 56 //
csyang2 1:c0f972361605 57 // Function pointers of hardware access routines
csyang2 1:c0f972361605 58 //
csyang2 1:c0f972361605 59 //HW_API_SLIN HW_API;
csyang2 1:c0f972361605 60 //
csyang2 1:c0f972361605 61 // Driver specific configuration items
csyang2 1:c0f972361605 62 //
csyang2 1:c0f972361605 63 int FirstSEG;
csyang2 1:c0f972361605 64 int FirstCOM;
csyang2 1:c0f972361605 65 int UseCache;
csyang2 1:c0f972361605 66 int UseMirror; // Only used for SSD1848
csyang2 1:c0f972361605 67 int CheckBusy;
csyang2 1:c0f972361605 68 U8 UseDualScan; // Used for T6963
csyang2 1:c0f972361605 69 } CONFIG_SLIN;
csyang2 1:c0f972361605 70
csyang2 1:c0f972361605 71 /*********************************************************************
csyang2 1:c0f972361605 72 *
csyang2 1:c0f972361605 73 * Display drivers
csyang2 1:c0f972361605 74 */
csyang2 1:c0f972361605 75 //
csyang2 1:c0f972361605 76 // Addresses
csyang2 1:c0f972361605 77 //
csyang2 1:c0f972361605 78 extern const GUI_DEVICE_API GUIDRV_SLin_1_API;
csyang2 1:c0f972361605 79 extern const GUI_DEVICE_API GUIDRV_SLin_OY_1_API;
csyang2 1:c0f972361605 80 extern const GUI_DEVICE_API GUIDRV_SLin_OX_1_API;
csyang2 1:c0f972361605 81 extern const GUI_DEVICE_API GUIDRV_SLin_OXY_1_API;
csyang2 1:c0f972361605 82 extern const GUI_DEVICE_API GUIDRV_SLin_OS_1_API;
csyang2 1:c0f972361605 83 extern const GUI_DEVICE_API GUIDRV_SLin_OSY_1_API;
csyang2 1:c0f972361605 84 extern const GUI_DEVICE_API GUIDRV_SLin_OSX_1_API;
csyang2 1:c0f972361605 85 extern const GUI_DEVICE_API GUIDRV_SLin_OSXY_1_API;
csyang2 1:c0f972361605 86
csyang2 1:c0f972361605 87 extern const GUI_DEVICE_API GUIDRV_SLin_2_API;
csyang2 1:c0f972361605 88 extern const GUI_DEVICE_API GUIDRV_SLin_OY_2_API;
csyang2 1:c0f972361605 89 extern const GUI_DEVICE_API GUIDRV_SLin_OX_2_API;
csyang2 1:c0f972361605 90 extern const GUI_DEVICE_API GUIDRV_SLin_OXY_2_API;
csyang2 1:c0f972361605 91 extern const GUI_DEVICE_API GUIDRV_SLin_OS_2_API;
csyang2 1:c0f972361605 92 extern const GUI_DEVICE_API GUIDRV_SLin_OSY_2_API;
csyang2 1:c0f972361605 93 extern const GUI_DEVICE_API GUIDRV_SLin_OSX_2_API;
csyang2 1:c0f972361605 94 extern const GUI_DEVICE_API GUIDRV_SLin_OSXY_2_API;
csyang2 1:c0f972361605 95
csyang2 1:c0f972361605 96 extern const GUI_DEVICE_API GUIDRV_SLin_4_API;
csyang2 1:c0f972361605 97 extern const GUI_DEVICE_API GUIDRV_SLin_OY_4_API;
csyang2 1:c0f972361605 98 extern const GUI_DEVICE_API GUIDRV_SLin_OX_4_API;
csyang2 1:c0f972361605 99 extern const GUI_DEVICE_API GUIDRV_SLin_OXY_4_API;
csyang2 1:c0f972361605 100 extern const GUI_DEVICE_API GUIDRV_SLin_OS_4_API;
csyang2 1:c0f972361605 101 extern const GUI_DEVICE_API GUIDRV_SLin_OSY_4_API;
csyang2 1:c0f972361605 102 extern const GUI_DEVICE_API GUIDRV_SLin_OSX_4_API;
csyang2 1:c0f972361605 103 extern const GUI_DEVICE_API GUIDRV_SLin_OSXY_4_API;
csyang2 1:c0f972361605 104
csyang2 1:c0f972361605 105 //
csyang2 1:c0f972361605 106 // Macros to be used in configuration files
csyang2 1:c0f972361605 107 //
csyang2 1:c0f972361605 108 #if defined(WIN32) && !defined(LCD_SIMCONTROLLER)
csyang2 1:c0f972361605 109
csyang2 1:c0f972361605 110 #define GUIDRV_SLIN_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 111 #define GUIDRV_SLIN_OY_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 112 #define GUIDRV_SLIN_OX_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 113 #define GUIDRV_SLIN_OXY_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 114 #define GUIDRV_SLIN_OS_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 115 #define GUIDRV_SLIN_OSY_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 116 #define GUIDRV_SLIN_OSX_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 117 #define GUIDRV_SLIN_OSXY_1 &GUIDRV_Win_API
csyang2 1:c0f972361605 118
csyang2 1:c0f972361605 119 #define GUIDRV_SLIN_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 120 #define GUIDRV_SLIN_OY_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 121 #define GUIDRV_SLIN_OX_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 122 #define GUIDRV_SLIN_OXY_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 123 #define GUIDRV_SLIN_OS_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 124 #define GUIDRV_SLIN_OSY_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 125 #define GUIDRV_SLIN_OSX_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 126 #define GUIDRV_SLIN_OSXY_2 &GUIDRV_Win_API
csyang2 1:c0f972361605 127
csyang2 1:c0f972361605 128 #define GUIDRV_SLIN_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 129 #define GUIDRV_SLIN_OY_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 130 #define GUIDRV_SLIN_OX_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 131 #define GUIDRV_SLIN_OXY_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 132 #define GUIDRV_SLIN_OS_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 133 #define GUIDRV_SLIN_OSY_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 134 #define GUIDRV_SLIN_OSX_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 135 #define GUIDRV_SLIN_OSXY_4 &GUIDRV_Win_API
csyang2 1:c0f972361605 136
csyang2 1:c0f972361605 137 #else
csyang2 1:c0f972361605 138
csyang2 1:c0f972361605 139 #define GUIDRV_SLIN_1 &GUIDRV_SLin_1_API
csyang2 1:c0f972361605 140 #define GUIDRV_SLIN_OY_1 &GUIDRV_SLin_OY_1_API
csyang2 1:c0f972361605 141 #define GUIDRV_SLIN_OX_1 &GUIDRV_SLin_OX_1_API
csyang2 1:c0f972361605 142 #define GUIDRV_SLIN_OXY_1 &GUIDRV_SLin_OXY_1_API
csyang2 1:c0f972361605 143 #define GUIDRV_SLIN_OS_1 &GUIDRV_SLin_OS_1_API
csyang2 1:c0f972361605 144 #define GUIDRV_SLIN_OSY_1 &GUIDRV_SLin_OSY_1_API
csyang2 1:c0f972361605 145 #define GUIDRV_SLIN_OSX_1 &GUIDRV_SLin_OSX_1_API
csyang2 1:c0f972361605 146 #define GUIDRV_SLIN_OSXY_1 &GUIDRV_SLin_OSXY_1_API
csyang2 1:c0f972361605 147
csyang2 1:c0f972361605 148 #define GUIDRV_SLIN_2 &GUIDRV_SLin_2_API
csyang2 1:c0f972361605 149 #define GUIDRV_SLIN_OY_2 &GUIDRV_SLin_OY_2_API
csyang2 1:c0f972361605 150 #define GUIDRV_SLIN_OX_2 &GUIDRV_SLin_OX_2_API
csyang2 1:c0f972361605 151 #define GUIDRV_SLIN_OXY_2 &GUIDRV_SLin_OXY_2_API
csyang2 1:c0f972361605 152 #define GUIDRV_SLIN_OS_2 &GUIDRV_SLin_OS_2_API
csyang2 1:c0f972361605 153 #define GUIDRV_SLIN_OSY_2 &GUIDRV_SLin_OSY_2_API
csyang2 1:c0f972361605 154 #define GUIDRV_SLIN_OSX_2 &GUIDRV_SLin_OSX_2_API
csyang2 1:c0f972361605 155 #define GUIDRV_SLIN_OSXY_2 &GUIDRV_SLin_OSXY_2_API
csyang2 1:c0f972361605 156
csyang2 1:c0f972361605 157 #define GUIDRV_SLIN_4 &GUIDRV_SLin_4_API
csyang2 1:c0f972361605 158 #define GUIDRV_SLIN_OY_4 &GUIDRV_SLin_OY_4_API
csyang2 1:c0f972361605 159 #define GUIDRV_SLIN_OX_4 &GUIDRV_SLin_OX_4_API
csyang2 1:c0f972361605 160 #define GUIDRV_SLIN_OXY_4 &GUIDRV_SLin_OXY_4_API
csyang2 1:c0f972361605 161 #define GUIDRV_SLIN_OS_4 &GUIDRV_SLin_OS_4_API
csyang2 1:c0f972361605 162 #define GUIDRV_SLIN_OSY_4 &GUIDRV_SLin_OSY_4_API
csyang2 1:c0f972361605 163 #define GUIDRV_SLIN_OSX_4 &GUIDRV_SLin_OSX_4_API
csyang2 1:c0f972361605 164 #define GUIDRV_SLIN_OSXY_4 &GUIDRV_SLin_OSXY_4_API
csyang2 1:c0f972361605 165
csyang2 1:c0f972361605 166 #endif
csyang2 1:c0f972361605 167
csyang2 1:c0f972361605 168 /*********************************************************************
csyang2 1:c0f972361605 169 *
csyang2 1:c0f972361605 170 * Public routines
csyang2 1:c0f972361605 171 */
csyang2 1:c0f972361605 172 #if defined(WIN32) && !defined(LCD_SIMCONTROLLER)
csyang2 1:c0f972361605 173
csyang2 1:c0f972361605 174 #define GUIDRV_SLin_Config(pDevice, pConfig)
csyang2 1:c0f972361605 175 #define GUIDRV_SLin_SetBus8(pDevice, pHW_API)
csyang2 1:c0f972361605 176 #define GUIDRV_SLin_SetS1D13700(pDevice)
csyang2 1:c0f972361605 177 #define GUIDRV_SLin_SetSSD1848(pDevice)
csyang2 1:c0f972361605 178 #define GUIDRV_SLin_SetT6963(pDevice)
csyang2 1:c0f972361605 179 #define GUIDRV_SLin_SetUC1617(pDevice)
csyang2 1:c0f972361605 180
csyang2 1:c0f972361605 181 #else
csyang2 1:c0f972361605 182
csyang2 1:c0f972361605 183 void GUIDRV_SLin_Config (GUI_DEVICE * pDevice, CONFIG_SLIN * pConfig);
csyang2 1:c0f972361605 184 void GUIDRV_SLin_SetBus8 (GUI_DEVICE * pDevice, GUI_PORT_API * pHW_API);
csyang2 1:c0f972361605 185 void GUIDRV_SLin_SetS1D13700(GUI_DEVICE * pDevice);
csyang2 1:c0f972361605 186 void GUIDRV_SLin_SetSSD1325 (GUI_DEVICE * pDevice);
csyang2 1:c0f972361605 187 void GUIDRV_SLin_SetSSD1848 (GUI_DEVICE * pDevice);
csyang2 1:c0f972361605 188 void GUIDRV_SLin_SetT6963 (GUI_DEVICE * pDevice);
csyang2 1:c0f972361605 189 void GUIDRV_SLin_SetUC1617 (GUI_DEVICE * pDevice);
csyang2 1:c0f972361605 190
csyang2 1:c0f972361605 191 #endif
csyang2 1:c0f972361605 192
csyang2 1:c0f972361605 193 #if defined(__cplusplus)
csyang2 1:c0f972361605 194 }
csyang2 1:c0f972361605 195 #endif
csyang2 1:c0f972361605 196
csyang2 1:c0f972361605 197 #endif
csyang2 1:c0f972361605 198
csyang2 1:c0f972361605 199 /*************************** End of file ****************************/