1 /****************************************************************************
 
   3   (c) SYSTEC electronic GmbH, D-07973 Greiz, August-Bebel-Str. 29
 
   4       www.systec-electronic.com
 
   8   Description:  Debug interface
 
  12     Redistribution and use in source and binary forms, with or without
 
  13     modification, are permitted provided that the following conditions
 
  16     1. Redistributions of source code must retain the above copyright
 
  17        notice, this list of conditions and the following disclaimer.
 
  19     2. Redistributions in binary form must reproduce the above copyright
 
  20        notice, this list of conditions and the following disclaimer in the
 
  21        documentation and/or other materials provided with the distribution.
 
  23     3. Neither the name of SYSTEC electronic GmbH nor the names of its
 
  24        contributors may be used to endorse or promote products derived
 
  25        from this software without prior written permission. For written
 
  26        permission, please contact info@systec-electronic.com.
 
  28     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 
  29     "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 
  30     LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 
  31     FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 
  32     COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 
  33     INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 
  34     BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 
  35     LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 
  36     CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 
  37     LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 
  38     ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 
  39     POSSIBILITY OF SUCH DAMAGE.
 
  43         If a provision of this License is or becomes illegal, invalid or
 
  44         unenforceable in any jurisdiction, that shall not affect:
 
  45         1. the validity or enforceability in that jurisdiction of any other
 
  46            provision of this License; or
 
  47         2. the validity or enforceability in other jurisdictions of that or
 
  48            any other provision of this License.
 
  50   -------------------------------------------------------------------------
 
  56                 $Revision: 1.4 $  $Date: 2008/10/17 15:32:32 $
 
  63   -------------------------------------------------------------------------
 
  67 ****************************************************************************/
 
  74 /***************************************************************************/
 
  77 /*          G L O B A L   D E F I N I T I O N S                            */
 
  80 /***************************************************************************/
 
  82 //---------------------------------------------------------------------------
 
  83 // global const defines
 
  84 //---------------------------------------------------------------------------
 
  86 // These definitions are important for level-debug traces.
 
  87 // A macro DEBUG_GLB_LVL() defines the current debug-level using following bis.
 
  88 // If the corresponding bit is set then trace message will be printed out
 
  89 // (only if NDEBUG is not defined). The upper debug-levels are reserved for
 
  90 // the debug-levels ALWAYS, ERROR and ASSERT.
 
  91 #define DEBUG_LVL_01                    0x00000001
 
  92 #define DEBUG_LVL_02                    0x00000002
 
  93 #define DEBUG_LVL_03                    0x00000004
 
  94 #define DEBUG_LVL_04                    0x00000008
 
  95 #define DEBUG_LVL_05                    0x00000010
 
  96 #define DEBUG_LVL_06                    0x00000020
 
  97 #define DEBUG_LVL_07                    0x00000040
 
  98 #define DEBUG_LVL_08                    0x00000080
 
  99 #define DEBUG_LVL_09                    0x00000100
 
 100 #define DEBUG_LVL_10                    0x00000200
 
 101 #define DEBUG_LVL_11                    0x00000400
 
 102 #define DEBUG_LVL_12                    0x00000800
 
 103 #define DEBUG_LVL_13                    0x00001000
 
 104 #define DEBUG_LVL_14                    0x00002000
 
 105 #define DEBUG_LVL_15                    0x00004000
 
 106 #define DEBUG_LVL_16                    0x00008000
 
 107 #define DEBUG_LVL_17                    0x00010000
 
 108 #define DEBUG_LVL_18                    0x00020000
 
 109 #define DEBUG_LVL_19                    0x00040000
 
 110 #define DEBUG_LVL_20                    0x00080000
 
 111 #define DEBUG_LVL_21                    0x00100000
 
 112 #define DEBUG_LVL_22                    0x00200000
 
 113 #define DEBUG_LVL_23                    0x00400000
 
 114 #define DEBUG_LVL_24                    0x00800000
 
 115 #define DEBUG_LVL_25                    0x01000000
 
 116 #define DEBUG_LVL_26                    0x02000000
 
 117 #define DEBUG_LVL_27                    0x04000000
 
 118 #define DEBUG_LVL_28                    0x08000000
 
 119 #define DEBUG_LVL_29                    0x10000000
 
 120 #define DEBUG_LVL_ASSERT                0x20000000
 
 121 #define DEBUG_LVL_ERROR                 0x40000000
 
 122 #define DEBUG_LVL_ALWAYS                0x80000000
 
 124 //---------------------------------------------------------------------------
 
 126 //---------------------------------------------------------------------------
 
 128 //---------------------------------------------------------------------------
 
 130 //---------------------------------------------------------------------------
 
 132 //---------------------------------------------------------------------------
 
 133 // global function prototypes
 
 134 //---------------------------------------------------------------------------
 
 136 //---------------------------------------------------------------------------
 
 138 //---------------------------------------------------------------------------
 
 140 //---------------------------------------------------------------------------
 
 141 // this macro defines a version string
 
 144 //---------------------------------------------------------------------------
 
 145 // this macro defines a build info string (e.g. for using in printf())
 
 146 #define DEBUG_MAKE_BUILD_INFO(prefix,product,prodid,descr,verstr,author) "\n" \
 
 147     prefix "***************************************************\n" \
 
 148     prefix "Project:   " product ", " prodid                  "\n" \
 
 149     prefix "Descript.: " descr                                "\n" \
 
 150     prefix "Author:    " author                               "\n" \
 
 151     prefix "Date:      " __DATE__                             "\n" \
 
 152     prefix "Version:   " verstr                               "\n" \
 
 153     prefix "***************************************************\n\n"
 
 155 //---------------------------------------------------------------------------
 
 156 // The default debug-level is: ERROR and ALWAYS.
 
 157 // You can define an other debug-level in project settings.
 
 158 #ifndef DEF_DEBUG_LVL
 
 159 #define DEF_DEBUG_LVL                   (DEBUG_LVL_ALWAYS | DEBUG_LVL_ERROR)
 
 161 #ifndef DEBUG_GLB_LVL
 
 162 #define DEBUG_GLB_LVL()                 (DEF_DEBUG_LVL)
 
 165 //---------------------------------------------------------------------------
 
 166 #if (DEV_SYSTEM == _DEV_WIN32_) && defined (TRACE_MSG)
 
 168     // For WIN32 the macro DEBUG_TRACE0 can be defined as function call TraceLvl()
 
 169     // or as macro TRACE().
 
 171     // Here the parameter 'lvl' can be used with more than one
 
 172     // debug-level (using OR).
 
 174     // Example: DEBUG_TRACE1(DEBUG_LVL_30 | DEBUG_LVL_02, "Hello %d", bCount);
 
 176 #define DEBUG_TRACE0(lvl,str)               TraceLvl((lvl),str)
 
 177 #define DEBUG_TRACE1(lvl,str,p1)            TraceLvl((lvl),str,p1)
 
 178 #define DEBUG_TRACE2(lvl,str,p1,p2)         TraceLvl((lvl),str,p1,p2)
 
 179 #define DEBUG_TRACE3(lvl,str,p1,p2,p3)      TraceLvl((lvl),str,p1,p2,p3)
 
 180 #define DEBUG_TRACE4(lvl,str,p1,p2,p3,p4)   TraceLvl((lvl),str,p1,p2,p3,p4)
 
 181 #define DEBUG_GLB_LVL()                     dwDebugLevel_g
 
 185     // At microcontrollers we do reduce the memory usage by deleting DEBUG_TRACE-lines
 
 186     // (compiler does delete the lines).
 
 188     // Here the parameter 'lvl' can only be used with one debug-level.
 
 190     // Example: DEBUG_TRACE1(DEBUG_LVL_ERROR, "error code %d", dwRet);
 
 192 #if (DEBUG_GLB_LVL() & DEBUG_LVL_ALWAYS)
 
 193 #define DEBUG_LVL_ALWAYS_TRACE0(str)                TRACE0(str)
 
 194 #define DEBUG_LVL_ALWAYS_TRACE1(str,p1)             TRACE1(str,p1)
 
 195 #define DEBUG_LVL_ALWAYS_TRACE2(str,p1,p2)          TRACE2(str,p1,p2)
 
 196 #define DEBUG_LVL_ALWAYS_TRACE3(str,p1,p2,p3)       TRACE3(str,p1,p2,p3)
 
 197 #define DEBUG_LVL_ALWAYS_TRACE4(str,p1,p2,p3,p4)    TRACE4(str,p1,p2,p3,p4)
 
 199 #define DEBUG_LVL_ALWAYS_TRACE0(str)
 
 200 #define DEBUG_LVL_ALWAYS_TRACE1(str,p1)
 
 201 #define DEBUG_LVL_ALWAYS_TRACE2(str,p1,p2)
 
 202 #define DEBUG_LVL_ALWAYS_TRACE3(str,p1,p2,p3)
 
 203 #define DEBUG_LVL_ALWAYS_TRACE4(str,p1,p2,p3,p4)
 
 206 #if (DEBUG_GLB_LVL() & DEBUG_LVL_ERROR)
 
 207 #define DEBUG_LVL_ERROR_TRACE0(str)                 TRACE0(str)
 
 208 #define DEBUG_LVL_ERROR_TRACE1(str,p1)              TRACE1(str,p1)
 
 209 #define DEBUG_LVL_ERROR_TRACE2(str,p1,p2)           TRACE2(str,p1,p2)
 
 210 #define DEBUG_LVL_ERROR_TRACE3(str,p1,p2,p3)        TRACE3(str,p1,p2,p3)
 
 211 #define DEBUG_LVL_ERROR_TRACE4(str,p1,p2,p3,p4)     TRACE4(str,p1,p2,p3,p4)
 
 213 #define DEBUG_LVL_ERROR_TRACE0(str)
 
 214 #define DEBUG_LVL_ERROR_TRACE1(str,p1)
 
 215 #define DEBUG_LVL_ERROR_TRACE2(str,p1,p2)
 
 216 #define DEBUG_LVL_ERROR_TRACE3(str,p1,p2,p3)
 
 217 #define DEBUG_LVL_ERROR_TRACE4(str,p1,p2,p3,p4)
 
 220 #if (DEBUG_GLB_LVL() & DEBUG_LVL_ASSERT)
 
 221 #define DEBUG_LVL_ASSERT_TRACE0(str)                TRACE0(str)
 
 222 #define DEBUG_LVL_ASSERT_TRACE1(str,p1)             TRACE1(str,p1)
 
 223 #define DEBUG_LVL_ASSERT_TRACE2(str,p1,p2)          TRACE2(str,p1,p2)
 
 224 #define DEBUG_LVL_ASSERT_TRACE3(str,p1,p2,p3)       TRACE3(str,p1,p2,p3)
 
 225 #define DEBUG_LVL_ASSERT_TRACE4(str,p1,p2,p3,p4)    TRACE4(str,p1,p2,p3,p4)
 
 227 #define DEBUG_LVL_ASSERT_TRACE0(str)
 
 228 #define DEBUG_LVL_ASSERT_TRACE1(str,p1)
 
 229 #define DEBUG_LVL_ASSERT_TRACE2(str,p1,p2)
 
 230 #define DEBUG_LVL_ASSERT_TRACE3(str,p1,p2,p3)
 
 231 #define DEBUG_LVL_ASSERT_TRACE4(str,p1,p2,p3,p4)
 
 234 #if (DEBUG_GLB_LVL() & DEBUG_LVL_29)
 
 235 #define DEBUG_LVL_29_TRACE0(str)                    TRACE0(str)
 
 236 #define DEBUG_LVL_29_TRACE1(str,p1)                 TRACE1(str,p1)
 
 237 #define DEBUG_LVL_29_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 238 #define DEBUG_LVL_29_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 239 #define DEBUG_LVL_29_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 241 #define DEBUG_LVL_29_TRACE0(str)
 
 242 #define DEBUG_LVL_29_TRACE1(str,p1)
 
 243 #define DEBUG_LVL_29_TRACE2(str,p1,p2)
 
 244 #define DEBUG_LVL_29_TRACE3(str,p1,p2,p3)
 
 245 #define DEBUG_LVL_29_TRACE4(str,p1,p2,p3,p4)
 
 248 #if (DEBUG_GLB_LVL() & DEBUG_LVL_28)
 
 249 #define DEBUG_LVL_28_TRACE0(str)                    TRACE0(str)
 
 250 #define DEBUG_LVL_28_TRACE1(str,p1)                 TRACE1(str,p1)
 
 251 #define DEBUG_LVL_28_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 252 #define DEBUG_LVL_28_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 253 #define DEBUG_LVL_28_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 255 #define DEBUG_LVL_28_TRACE0(str)
 
 256 #define DEBUG_LVL_28_TRACE1(str,p1)
 
 257 #define DEBUG_LVL_28_TRACE2(str,p1,p2)
 
 258 #define DEBUG_LVL_28_TRACE3(str,p1,p2,p3)
 
 259 #define DEBUG_LVL_28_TRACE4(str,p1,p2,p3,p4)
 
 262 #if (DEBUG_GLB_LVL() & DEBUG_LVL_27)
 
 263 #define DEBUG_LVL_27_TRACE0(str)                    TRACE0(str)
 
 264 #define DEBUG_LVL_27_TRACE1(str,p1)                 TRACE1(str,p1)
 
 265 #define DEBUG_LVL_27_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 266 #define DEBUG_LVL_27_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 267 #define DEBUG_LVL_27_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 269 #define DEBUG_LVL_27_TRACE0(str)
 
 270 #define DEBUG_LVL_27_TRACE1(str,p1)
 
 271 #define DEBUG_LVL_27_TRACE2(str,p1,p2)
 
 272 #define DEBUG_LVL_27_TRACE3(str,p1,p2,p3)
 
 273 #define DEBUG_LVL_27_TRACE4(str,p1,p2,p3,p4)
 
 276 #if (DEBUG_GLB_LVL() & DEBUG_LVL_26)
 
 277 #define DEBUG_LVL_26_TRACE0(str)                    TRACE0(str)
 
 278 #define DEBUG_LVL_26_TRACE1(str,p1)                 TRACE1(str,p1)
 
 279 #define DEBUG_LVL_26_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 280 #define DEBUG_LVL_26_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 281 #define DEBUG_LVL_26_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 283 #define DEBUG_LVL_26_TRACE0(str)
 
 284 #define DEBUG_LVL_26_TRACE1(str,p1)
 
 285 #define DEBUG_LVL_26_TRACE2(str,p1,p2)
 
 286 #define DEBUG_LVL_26_TRACE3(str,p1,p2,p3)
 
 287 #define DEBUG_LVL_26_TRACE4(str,p1,p2,p3,p4)
 
 290 #if (DEBUG_GLB_LVL() & DEBUG_LVL_25)
 
 291 #define DEBUG_LVL_25_TRACE0(str)                    TRACE0(str)
 
 292 #define DEBUG_LVL_25_TRACE1(str,p1)                 TRACE1(str,p1)
 
 293 #define DEBUG_LVL_25_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 294 #define DEBUG_LVL_25_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 295 #define DEBUG_LVL_25_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 297 #define DEBUG_LVL_25_TRACE0(str)
 
 298 #define DEBUG_LVL_25_TRACE1(str,p1)
 
 299 #define DEBUG_LVL_25_TRACE2(str,p1,p2)
 
 300 #define DEBUG_LVL_25_TRACE3(str,p1,p2,p3)
 
 301 #define DEBUG_LVL_25_TRACE4(str,p1,p2,p3,p4)
 
 304 #if (DEBUG_GLB_LVL() & DEBUG_LVL_24)
 
 305 #define DEBUG_LVL_24_TRACE0(str)                    TRACE0(str)
 
 306 #define DEBUG_LVL_24_TRACE1(str,p1)                 TRACE1(str,p1)
 
 307 #define DEBUG_LVL_24_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 308 #define DEBUG_LVL_24_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 309 #define DEBUG_LVL_24_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 311 #define DEBUG_LVL_24_TRACE0(str)
 
 312 #define DEBUG_LVL_24_TRACE1(str,p1)
 
 313 #define DEBUG_LVL_24_TRACE2(str,p1,p2)
 
 314 #define DEBUG_LVL_24_TRACE3(str,p1,p2,p3)
 
 315 #define DEBUG_LVL_24_TRACE4(str,p1,p2,p3,p4)
 
 318 #if (DEBUG_GLB_LVL() & DEBUG_LVL_23)
 
 319 #define DEBUG_LVL_23_TRACE0(str)                    TRACE0(str)
 
 320 #define DEBUG_LVL_23_TRACE1(str,p1)                 TRACE1(str,p1)
 
 321 #define DEBUG_LVL_23_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 322 #define DEBUG_LVL_23_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 323 #define DEBUG_LVL_23_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 325 #define DEBUG_LVL_23_TRACE0(str)
 
 326 #define DEBUG_LVL_23_TRACE1(str,p1)
 
 327 #define DEBUG_LVL_23_TRACE2(str,p1,p2)
 
 328 #define DEBUG_LVL_23_TRACE3(str,p1,p2,p3)
 
 329 #define DEBUG_LVL_23_TRACE4(str,p1,p2,p3,p4)
 
 332 #if (DEBUG_GLB_LVL() & DEBUG_LVL_22)
 
 333 #define DEBUG_LVL_22_TRACE0(str)                    TRACE0(str)
 
 334 #define DEBUG_LVL_22_TRACE1(str,p1)                 TRACE1(str,p1)
 
 335 #define DEBUG_LVL_22_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 336 #define DEBUG_LVL_22_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 337 #define DEBUG_LVL_22_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 339 #define DEBUG_LVL_22_TRACE0(str)
 
 340 #define DEBUG_LVL_22_TRACE1(str,p1)
 
 341 #define DEBUG_LVL_22_TRACE2(str,p1,p2)
 
 342 #define DEBUG_LVL_22_TRACE3(str,p1,p2,p3)
 
 343 #define DEBUG_LVL_22_TRACE4(str,p1,p2,p3,p4)
 
 346 #if (DEBUG_GLB_LVL() & DEBUG_LVL_21)
 
 347 #define DEBUG_LVL_21_TRACE0(str)                    TRACE0(str)
 
 348 #define DEBUG_LVL_21_TRACE1(str,p1)                 TRACE1(str,p1)
 
 349 #define DEBUG_LVL_21_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 350 #define DEBUG_LVL_21_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 351 #define DEBUG_LVL_21_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 353 #define DEBUG_LVL_21_TRACE0(str)
 
 354 #define DEBUG_LVL_21_TRACE1(str,p1)
 
 355 #define DEBUG_LVL_21_TRACE2(str,p1,p2)
 
 356 #define DEBUG_LVL_21_TRACE3(str,p1,p2,p3)
 
 357 #define DEBUG_LVL_21_TRACE4(str,p1,p2,p3,p4)
 
 360 #if (DEBUG_GLB_LVL() & DEBUG_LVL_20)
 
 361 #define DEBUG_LVL_20_TRACE0(str)                    TRACE0(str)
 
 362 #define DEBUG_LVL_20_TRACE1(str,p1)                 TRACE1(str,p1)
 
 363 #define DEBUG_LVL_20_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 364 #define DEBUG_LVL_20_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 365 #define DEBUG_LVL_20_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 367 #define DEBUG_LVL_20_TRACE0(str)
 
 368 #define DEBUG_LVL_20_TRACE1(str,p1)
 
 369 #define DEBUG_LVL_20_TRACE2(str,p1,p2)
 
 370 #define DEBUG_LVL_20_TRACE3(str,p1,p2,p3)
 
 371 #define DEBUG_LVL_20_TRACE4(str,p1,p2,p3,p4)
 
 374 #if (DEBUG_GLB_LVL() & DEBUG_LVL_19)
 
 375 #define DEBUG_LVL_19_TRACE0(str)                    TRACE0(str)
 
 376 #define DEBUG_LVL_19_TRACE1(str,p1)                 TRACE1(str,p1)
 
 377 #define DEBUG_LVL_19_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 378 #define DEBUG_LVL_19_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 379 #define DEBUG_LVL_19_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 381 #define DEBUG_LVL_19_TRACE0(str)
 
 382 #define DEBUG_LVL_19_TRACE1(str,p1)
 
 383 #define DEBUG_LVL_19_TRACE2(str,p1,p2)
 
 384 #define DEBUG_LVL_19_TRACE3(str,p1,p2,p3)
 
 385 #define DEBUG_LVL_19_TRACE4(str,p1,p2,p3,p4)
 
 388 #if (DEBUG_GLB_LVL() & DEBUG_LVL_18)
 
 389 #define DEBUG_LVL_18_TRACE0(str)                    TRACE0(str)
 
 390 #define DEBUG_LVL_18_TRACE1(str,p1)                 TRACE1(str,p1)
 
 391 #define DEBUG_LVL_18_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 392 #define DEBUG_LVL_18_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 393 #define DEBUG_LVL_18_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 395 #define DEBUG_LVL_18_TRACE0(str)
 
 396 #define DEBUG_LVL_18_TRACE1(str,p1)
 
 397 #define DEBUG_LVL_18_TRACE2(str,p1,p2)
 
 398 #define DEBUG_LVL_18_TRACE3(str,p1,p2,p3)
 
 399 #define DEBUG_LVL_18_TRACE4(str,p1,p2,p3,p4)
 
 402 #if (DEBUG_GLB_LVL() & DEBUG_LVL_17)
 
 403 #define DEBUG_LVL_17_TRACE0(str)                    TRACE0(str)
 
 404 #define DEBUG_LVL_17_TRACE1(str,p1)                 TRACE1(str,p1)
 
 405 #define DEBUG_LVL_17_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 406 #define DEBUG_LVL_17_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 407 #define DEBUG_LVL_17_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 409 #define DEBUG_LVL_17_TRACE0(str)
 
 410 #define DEBUG_LVL_17_TRACE1(str,p1)
 
 411 #define DEBUG_LVL_17_TRACE2(str,p1,p2)
 
 412 #define DEBUG_LVL_17_TRACE3(str,p1,p2,p3)
 
 413 #define DEBUG_LVL_17_TRACE4(str,p1,p2,p3,p4)
 
 416 #if (DEBUG_GLB_LVL() & DEBUG_LVL_16)
 
 417 #define DEBUG_LVL_16_TRACE0(str)                    TRACE0(str)
 
 418 #define DEBUG_LVL_16_TRACE1(str,p1)                 TRACE1(str,p1)
 
 419 #define DEBUG_LVL_16_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 420 #define DEBUG_LVL_16_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 421 #define DEBUG_LVL_16_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 423 #define DEBUG_LVL_16_TRACE0(str)
 
 424 #define DEBUG_LVL_16_TRACE1(str,p1)
 
 425 #define DEBUG_LVL_16_TRACE2(str,p1,p2)
 
 426 #define DEBUG_LVL_16_TRACE3(str,p1,p2,p3)
 
 427 #define DEBUG_LVL_16_TRACE4(str,p1,p2,p3,p4)
 
 430 #if (DEBUG_GLB_LVL() & DEBUG_LVL_15)
 
 431 #define DEBUG_LVL_15_TRACE0(str)                    TRACE0(str)
 
 432 #define DEBUG_LVL_15_TRACE1(str,p1)                 TRACE1(str,p1)
 
 433 #define DEBUG_LVL_15_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 434 #define DEBUG_LVL_15_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 435 #define DEBUG_LVL_15_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 437 #define DEBUG_LVL_15_TRACE0(str)
 
 438 #define DEBUG_LVL_15_TRACE1(str,p1)
 
 439 #define DEBUG_LVL_15_TRACE2(str,p1,p2)
 
 440 #define DEBUG_LVL_15_TRACE3(str,p1,p2,p3)
 
 441 #define DEBUG_LVL_15_TRACE4(str,p1,p2,p3,p4)
 
 444 #if (DEBUG_GLB_LVL() & DEBUG_LVL_14)
 
 445 #define DEBUG_LVL_14_TRACE0(str)                    TRACE0(str)
 
 446 #define DEBUG_LVL_14_TRACE1(str,p1)                 TRACE1(str,p1)
 
 447 #define DEBUG_LVL_14_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 448 #define DEBUG_LVL_14_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 449 #define DEBUG_LVL_14_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 451 #define DEBUG_LVL_14_TRACE0(str)
 
 452 #define DEBUG_LVL_14_TRACE1(str,p1)
 
 453 #define DEBUG_LVL_14_TRACE2(str,p1,p2)
 
 454 #define DEBUG_LVL_14_TRACE3(str,p1,p2,p3)
 
 455 #define DEBUG_LVL_14_TRACE4(str,p1,p2,p3,p4)
 
 458 #if (DEBUG_GLB_LVL() & DEBUG_LVL_13)
 
 459 #define DEBUG_LVL_13_TRACE0(str)                    TRACE0(str)
 
 460 #define DEBUG_LVL_13_TRACE1(str,p1)                 TRACE1(str,p1)
 
 461 #define DEBUG_LVL_13_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 462 #define DEBUG_LVL_13_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 463 #define DEBUG_LVL_13_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 465 #define DEBUG_LVL_13_TRACE0(str)
 
 466 #define DEBUG_LVL_13_TRACE1(str,p1)
 
 467 #define DEBUG_LVL_13_TRACE2(str,p1,p2)
 
 468 #define DEBUG_LVL_13_TRACE3(str,p1,p2,p3)
 
 469 #define DEBUG_LVL_13_TRACE4(str,p1,p2,p3,p4)
 
 472 #if (DEBUG_GLB_LVL() & DEBUG_LVL_12)
 
 473 #define DEBUG_LVL_12_TRACE0(str)                    TRACE0(str)
 
 474 #define DEBUG_LVL_12_TRACE1(str,p1)                 TRACE1(str,p1)
 
 475 #define DEBUG_LVL_12_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 476 #define DEBUG_LVL_12_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 477 #define DEBUG_LVL_12_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 479 #define DEBUG_LVL_12_TRACE0(str)
 
 480 #define DEBUG_LVL_12_TRACE1(str,p1)
 
 481 #define DEBUG_LVL_12_TRACE2(str,p1,p2)
 
 482 #define DEBUG_LVL_12_TRACE3(str,p1,p2,p3)
 
 483 #define DEBUG_LVL_12_TRACE4(str,p1,p2,p3,p4)
 
 486 #if (DEBUG_GLB_LVL() & DEBUG_LVL_11)
 
 487 #define DEBUG_LVL_11_TRACE0(str)                    TRACE0(str)
 
 488 #define DEBUG_LVL_11_TRACE1(str,p1)                 TRACE1(str,p1)
 
 489 #define DEBUG_LVL_11_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 490 #define DEBUG_LVL_11_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 491 #define DEBUG_LVL_11_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 493 #define DEBUG_LVL_11_TRACE0(str)
 
 494 #define DEBUG_LVL_11_TRACE1(str,p1)
 
 495 #define DEBUG_LVL_11_TRACE2(str,p1,p2)
 
 496 #define DEBUG_LVL_11_TRACE3(str,p1,p2,p3)
 
 497 #define DEBUG_LVL_11_TRACE4(str,p1,p2,p3,p4)
 
 500 #if (DEBUG_GLB_LVL() & DEBUG_LVL_10)
 
 501 #define DEBUG_LVL_10_TRACE0(str)                    TRACE0(str)
 
 502 #define DEBUG_LVL_10_TRACE1(str,p1)                 TRACE1(str,p1)
 
 503 #define DEBUG_LVL_10_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 504 #define DEBUG_LVL_10_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 505 #define DEBUG_LVL_10_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 507 #define DEBUG_LVL_10_TRACE0(str)
 
 508 #define DEBUG_LVL_10_TRACE1(str,p1)
 
 509 #define DEBUG_LVL_10_TRACE2(str,p1,p2)
 
 510 #define DEBUG_LVL_10_TRACE3(str,p1,p2,p3)
 
 511 #define DEBUG_LVL_10_TRACE4(str,p1,p2,p3,p4)
 
 514 #if (DEBUG_GLB_LVL() & DEBUG_LVL_09)
 
 515 #define DEBUG_LVL_09_TRACE0(str)                    TRACE0(str)
 
 516 #define DEBUG_LVL_09_TRACE1(str,p1)                 TRACE1(str,p1)
 
 517 #define DEBUG_LVL_09_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 518 #define DEBUG_LVL_09_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 519 #define DEBUG_LVL_09_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 521 #define DEBUG_LVL_09_TRACE0(str)
 
 522 #define DEBUG_LVL_09_TRACE1(str,p1)
 
 523 #define DEBUG_LVL_09_TRACE2(str,p1,p2)
 
 524 #define DEBUG_LVL_09_TRACE3(str,p1,p2,p3)
 
 525 #define DEBUG_LVL_09_TRACE4(str,p1,p2,p3,p4)
 
 528 #if (DEBUG_GLB_LVL() & DEBUG_LVL_08)
 
 529 #define DEBUG_LVL_08_TRACE0(str)                    TRACE0(str)
 
 530 #define DEBUG_LVL_08_TRACE1(str,p1)                 TRACE1(str,p1)
 
 531 #define DEBUG_LVL_08_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 532 #define DEBUG_LVL_08_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 533 #define DEBUG_LVL_08_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 535 #define DEBUG_LVL_08_TRACE0(str)
 
 536 #define DEBUG_LVL_08_TRACE1(str,p1)
 
 537 #define DEBUG_LVL_08_TRACE2(str,p1,p2)
 
 538 #define DEBUG_LVL_08_TRACE3(str,p1,p2,p3)
 
 539 #define DEBUG_LVL_08_TRACE4(str,p1,p2,p3,p4)
 
 542 #if (DEBUG_GLB_LVL() & DEBUG_LVL_07)
 
 543 #define DEBUG_LVL_07_TRACE0(str)                    TRACE0(str)
 
 544 #define DEBUG_LVL_07_TRACE1(str,p1)                 TRACE1(str,p1)
 
 545 #define DEBUG_LVL_07_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 546 #define DEBUG_LVL_07_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 547 #define DEBUG_LVL_07_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 549 #define DEBUG_LVL_07_TRACE0(str)
 
 550 #define DEBUG_LVL_07_TRACE1(str,p1)
 
 551 #define DEBUG_LVL_07_TRACE2(str,p1,p2)
 
 552 #define DEBUG_LVL_07_TRACE3(str,p1,p2,p3)
 
 553 #define DEBUG_LVL_07_TRACE4(str,p1,p2,p3,p4)
 
 556 #if (DEBUG_GLB_LVL() & DEBUG_LVL_06)
 
 557 #define DEBUG_LVL_06_TRACE0(str)                    TRACE0(str)
 
 558 #define DEBUG_LVL_06_TRACE1(str,p1)                 TRACE1(str,p1)
 
 559 #define DEBUG_LVL_06_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 560 #define DEBUG_LVL_06_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 561 #define DEBUG_LVL_06_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 563 #define DEBUG_LVL_06_TRACE0(str)
 
 564 #define DEBUG_LVL_06_TRACE1(str,p1)
 
 565 #define DEBUG_LVL_06_TRACE2(str,p1,p2)
 
 566 #define DEBUG_LVL_06_TRACE3(str,p1,p2,p3)
 
 567 #define DEBUG_LVL_06_TRACE4(str,p1,p2,p3,p4)
 
 570 #if (DEBUG_GLB_LVL() & DEBUG_LVL_05)
 
 571 #define DEBUG_LVL_05_TRACE0(str)                    TRACE0(str)
 
 572 #define DEBUG_LVL_05_TRACE1(str,p1)                 TRACE1(str,p1)
 
 573 #define DEBUG_LVL_05_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 574 #define DEBUG_LVL_05_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 575 #define DEBUG_LVL_05_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 577 #define DEBUG_LVL_05_TRACE0(str)
 
 578 #define DEBUG_LVL_05_TRACE1(str,p1)
 
 579 #define DEBUG_LVL_05_TRACE2(str,p1,p2)
 
 580 #define DEBUG_LVL_05_TRACE3(str,p1,p2,p3)
 
 581 #define DEBUG_LVL_05_TRACE4(str,p1,p2,p3,p4)
 
 584 #if (DEBUG_GLB_LVL() & DEBUG_LVL_04)
 
 585 #define DEBUG_LVL_04_TRACE0(str)                    TRACE0(str)
 
 586 #define DEBUG_LVL_04_TRACE1(str,p1)                 TRACE1(str,p1)
 
 587 #define DEBUG_LVL_04_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 588 #define DEBUG_LVL_04_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 589 #define DEBUG_LVL_04_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 591 #define DEBUG_LVL_04_TRACE0(str)
 
 592 #define DEBUG_LVL_04_TRACE1(str,p1)
 
 593 #define DEBUG_LVL_04_TRACE2(str,p1,p2)
 
 594 #define DEBUG_LVL_04_TRACE3(str,p1,p2,p3)
 
 595 #define DEBUG_LVL_04_TRACE4(str,p1,p2,p3,p4)
 
 598 #if (DEBUG_GLB_LVL() & DEBUG_LVL_03)
 
 599 #define DEBUG_LVL_03_TRACE0(str)                    TRACE0(str)
 
 600 #define DEBUG_LVL_03_TRACE1(str,p1)                 TRACE1(str,p1)
 
 601 #define DEBUG_LVL_03_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 602 #define DEBUG_LVL_03_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 603 #define DEBUG_LVL_03_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 605 #define DEBUG_LVL_03_TRACE0(str)
 
 606 #define DEBUG_LVL_03_TRACE1(str,p1)
 
 607 #define DEBUG_LVL_03_TRACE2(str,p1,p2)
 
 608 #define DEBUG_LVL_03_TRACE3(str,p1,p2,p3)
 
 609 #define DEBUG_LVL_03_TRACE4(str,p1,p2,p3,p4)
 
 612 #if (DEBUG_GLB_LVL() & DEBUG_LVL_02)
 
 613 #define DEBUG_LVL_02_TRACE0(str)                    TRACE0(str)
 
 614 #define DEBUG_LVL_02_TRACE1(str,p1)                 TRACE1(str,p1)
 
 615 #define DEBUG_LVL_02_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 616 #define DEBUG_LVL_02_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 617 #define DEBUG_LVL_02_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 619 #define DEBUG_LVL_02_TRACE0(str)
 
 620 #define DEBUG_LVL_02_TRACE1(str,p1)
 
 621 #define DEBUG_LVL_02_TRACE2(str,p1,p2)
 
 622 #define DEBUG_LVL_02_TRACE3(str,p1,p2,p3)
 
 623 #define DEBUG_LVL_02_TRACE4(str,p1,p2,p3,p4)
 
 626 #if (DEBUG_GLB_LVL() & DEBUG_LVL_01)
 
 627 #define DEBUG_LVL_01_TRACE0(str)                    TRACE0(str)
 
 628 #define DEBUG_LVL_01_TRACE1(str,p1)                 TRACE1(str,p1)
 
 629 #define DEBUG_LVL_01_TRACE2(str,p1,p2)              TRACE2(str,p1,p2)
 
 630 #define DEBUG_LVL_01_TRACE3(str,p1,p2,p3)           TRACE3(str,p1,p2,p3)
 
 631 #define DEBUG_LVL_01_TRACE4(str,p1,p2,p3,p4)        TRACE4(str,p1,p2,p3,p4)
 
 633 #define DEBUG_LVL_01_TRACE0(str)
 
 634 #define DEBUG_LVL_01_TRACE1(str,p1)
 
 635 #define DEBUG_LVL_01_TRACE2(str,p1,p2)
 
 636 #define DEBUG_LVL_01_TRACE3(str,p1,p2,p3)
 
 637 #define DEBUG_LVL_01_TRACE4(str,p1,p2,p3,p4)
 
 640 #define DEBUG_TRACE0(lvl,str)                           lvl##_TRACE0(str)
 
 641 #define DEBUG_TRACE1(lvl,str,p1)                        lvl##_TRACE1(str,p1)
 
 642 #define DEBUG_TRACE2(lvl,str,p1,p2)                     lvl##_TRACE2(str,p1,p2)
 
 643 #define DEBUG_TRACE3(lvl,str,p1,p2,p3)                  lvl##_TRACE3(str,p1,p2,p3)
 
 644 #define DEBUG_TRACE4(lvl,str,p1,p2,p3,p4)               lvl##_TRACE4(str,p1,p2,p3,p4)
 
 648 //---------------------------------------------------------------------------
 
 649 // The macro DEBUG_DUMP_DATA() can be used with the same debug-levels to dump
 
 650 // out data bytes. Function DumpData() has to be included.
 
 651 // NOTE: DUMP_DATA has to be defined in project settings.
 
 652 #if (!defined (NDEBUG) && defined (DUMP_DATA)) || (DEV_SYSTEM == _DEV_WIN32_)
 
 658         void DumpData(char *szStr_p, BYTE MEM * pbData_p, WORD wSize_p);
 
 663 #define DEBUG_DUMP_DATA(lvl,str,ptr,siz)    if ((DEBUG_GLB_LVL() & (lvl))==(lvl)) \
 
 664                                                     DumpData (str, (BYTE MEM*) (ptr), (WORD) (siz));
 
 667 #define DEBUG_DUMP_DATA(lvl,str,ptr,siz)
 
 671 //---------------------------------------------------------------------------
 
 672 // The macro DEBUG_ASSERT() can be used to print out an error string if the
 
 673 // parametered expresion does not result TRUE.
 
 674 // NOTE: If DEBUG_KEEP_ASSERT is defined, then DEBUG_ASSERT-line will not be
 
 675 //       deleted from compiler (in release version too).
 
 676 #if !defined (NDEBUG) || defined (DEBUG_KEEP_ASSERT)
 
 678 #if (DEV_SYSTEM == _DEV_WIN32_)
 
 680         // For WIN32 process will be killed after closing message box.
 
 682 #define DEBUG_ASSERT0(expr,str)         if (!(expr ) && ((DEBUG_GLB_LVL() & DEBUG_LVL_ASSERT)!=0)) { \
 
 684                                                         "Assertion failed: line " __LINE__ " file " __FILE__ \
 
 685                                                         "\n    -> " str "\n"); \
 
 688 #define DEBUG_ASSERT1(expr,str,p1)      if (!(expr ) && ((DEBUG_GLB_LVL() & DEBUG_LVL_ASSERT)!=0)) { \
 
 690                                                         "Assertion failed: line " __LINE__ " file " __FILE__ \
 
 691                                                         "\n    -> " str "\n"); \
 
 696         // For microcontrollers process will be stopped using endless loop.
 
 698 #define DEBUG_ASSERT0(expr,str)         if (!(expr )) { \
 
 699                                                     DEBUG_LVL_ASSERT_TRACE3 ( \
 
 700                                                         "Assertion failed: line %d file '%s'\n" \
 
 701                                                         "    -> '%s'\n", __LINE__, __FILE__, str); \
 
 704 #define DEBUG_ASSERT1(expr,str,p1)      if (!(expr )) { \
 
 705                                                     DEBUG_LVL_ASSERT_TRACE4 ( \
 
 706                                                         "Assertion failed: line %d file '%s'\n" \
 
 708                                                         "    -> 0x%08lX\n", __LINE__, __FILE__, str, (DWORD) p1); \
 
 715 #define DEBUG_ASSERT0(expr,str)
 
 716 #define DEBUG_ASSERT1(expr,str,p1)
 
 720 //---------------------------------------------------------------------------
 
 721 // The macro DEBUG_ONLY() implements code, if NDEBUG is not defined.
 
 722 #if !defined (DEBUG_ONLY)
 
 723 #if !defined (NDEBUG)
 
 725 #define DEBUG_ONLY(expr)    expr
 
 729 #define DEBUG_ONLY(expr)