]> git.sur5r.net Git - freertos/commitdiff
Final preparation for new release:
authorrtel <rtel@1d2547de-c912-0410-9cb9-b8ca96c0e9e2>
Wed, 12 Aug 2015 10:34:30 +0000 (10:34 +0000)
committerrtel <rtel@1d2547de-c912-0410-9cb9-b8ca96c0e9e2>
Wed, 12 Aug 2015 10:34:30 +0000 (10:34 +0000)
FreeRTOS+Trace:
 - Add trace macros for task notifications.
 - Update to the latest trace recorder library.

Demo projects:
 - Only include the CLI command to show run time states if configGENERATE_RUN_TIME_STATS is set to 1.

git-svn-id: https://svn.code.sf.net/p/freertos/code/trunk@2366 1d2547de-c912-0410-9cb9-b8ca96c0e9e2

23 files changed:
FreeRTOS-Plus/Demo/Common/FreeRTOS_Plus_CLI_Demos/Sample-CLI-commands.c
FreeRTOS-Plus/Demo/FreeRTOS_Plus_Reliance_Edge_and_CLI_Windows_Simulator/Instructions_ReadMe.url
FreeRTOS-Plus/Demo/FreeRTOS_Plus_Reliance_Edge_and_CLI_Windows_Simulator/main.c
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/ConfigurationTemplate/trcConfig.h
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/Include/trcHardwarePort.h
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/Include/trcKernel.h
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/Include/trcKernelPort.h
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/Include/trcKernelPortFreeRTOS.h [deleted file]
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/Include/trcUser.h
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/trcKernel.c
FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/trcUser.c
FreeRTOS/Demo/IA32_flat_GCC_Galileo_Gen_2/.cproject
FreeRTOS/Demo/IA32_flat_GCC_Galileo_Gen_2/.project
FreeRTOS/Demo/IA32_flat_GCC_Galileo_Gen_2/.settings/language.settings.xml
FreeRTOS/Demo/MSP430X_MSP430F5438_IAR/RTOSDemo.ewd
FreeRTOS/Demo/MSP430X_MSP430F5438_IAR/RTOSDemo.ewp
FreeRTOS/Demo/MSP430X_MSP430F5438_IAR/RTOSDemo.ewt
FreeRTOS/Demo/MSP430X_MSP430F5438_IAR/settings/RTOSDemo.dni
FreeRTOS/Demo/MSP430X_MSP430F5438_IAR/settings/RTOSDemo.wsdt
FreeRTOS/Demo/Xilinx_FreeRTOS_BSP/Instructions_ReadMe.url [new file with mode: 0644]
FreeRTOS/Source/include/FreeRTOS.h
FreeRTOS/Source/portable/MPLAB/PIC24_dsPIC/portmacro.h
FreeRTOS/Source/tasks.c

index 700d84cc4ea2d9150a2b306a7934e30e1565be50..0b06ac00b73dd060a91cfd6289f69f0ab76ac131 100644 (file)
@@ -110,7 +110,9 @@ static BaseType_t prvTaskStatsCommand( char *pcWriteBuffer, size_t xWriteBufferL
 /*\r
  * Implements the run-time-stats command.\r
  */\r
-static BaseType_t prvRunTimeStatsCommand( char *pcWriteBuffer, size_t xWriteBufferLen, const char *pcCommandString );\r
+#if( configGENERATE_RUN_TIME_STATS == 1 )\r
+       static BaseType_t prvRunTimeStatsCommand( char *pcWriteBuffer, size_t xWriteBufferLen, const char *pcCommandString );\r
+#endif /* configGENERATE_RUN_TIME_STATS */\r
 \r
 /*\r
  * Implements the echo-three-parameters command.\r
@@ -136,16 +138,6 @@ static BaseType_t prvParameterEchoCommand( char *pcWriteBuffer, size_t xWriteBuf
        static BaseType_t prvStartStopTraceCommand( char *pcWriteBuffer, size_t xWriteBufferLen, const char *pcCommandString );\r
 #endif\r
 \r
-/* Structure that defines the "run-time-stats" command line command.   This\r
-generates a table that shows how much run time each task has */\r
-static const CLI_Command_Definition_t xRunTimeStats =\r
-{\r
-       "run-time-stats", /* The command string to type. */\r
-       "\r\nrun-time-stats:\r\n Displays a table showing how much processing time each FreeRTOS task has used\r\n",\r
-       prvRunTimeStatsCommand, /* The function to run. */\r
-       0 /* No parameters are expected. */\r
-};\r
-\r
 /* Structure that defines the "task-stats" command line command.  This generates\r
 a table that gives information on each task in the system. */\r
 static const CLI_Command_Definition_t xTaskStats =\r
@@ -178,6 +170,18 @@ static const CLI_Command_Definition_t xParameterEcho =
        -1 /* The user can enter any number of commands. */\r
 };\r
 \r
+#if( configGENERATE_RUN_TIME_STATS == 1 )\r
+       /* Structure that defines the "run-time-stats" command line command.   This\r
+       generates a table that shows how much run time each task has */\r
+       static const CLI_Command_Definition_t xRunTimeStats =\r
+       {\r
+               "run-time-stats", /* The command string to type. */\r
+               "\r\nrun-time-stats:\r\n Displays a table showing how much processing time each FreeRTOS task has used\r\n",\r
+               prvRunTimeStatsCommand, /* The function to run. */\r
+               0 /* No parameters are expected. */\r
+       };\r
+#endif /* configGENERATE_RUN_TIME_STATS */\r
+\r
 #if( configINCLUDE_QUERY_HEAP_COMMAND == 1 )\r
        /* Structure that defines the "query_heap" command line command. */\r
        static const CLI_Command_Definition_t xQueryHeap =\r
@@ -206,11 +210,16 @@ static const CLI_Command_Definition_t xParameterEcho =
 void vRegisterSampleCLICommands( void )\r
 {\r
        /* Register all the command line commands defined immediately above. */\r
-       FreeRTOS_CLIRegisterCommand( &xTaskStats );\r
-       FreeRTOS_CLIRegisterCommand( &xRunTimeStats );\r
+       FreeRTOS_CLIRegisterCommand( &xTaskStats );     \r
        FreeRTOS_CLIRegisterCommand( &xThreeParameterEcho );\r
        FreeRTOS_CLIRegisterCommand( &xParameterEcho );\r
 \r
+       #if( configGENERATE_RUN_TIME_STATS == 1 )\r
+       {\r
+               FreeRTOS_CLIRegisterCommand( &xRunTimeStats );\r
+       }\r
+       #endif\r
+       \r
        #if( configINCLUDE_QUERY_HEAP_COMMAND == 1 )\r
        {\r
                FreeRTOS_CLIRegisterCommand( &xQueryHeap );\r
@@ -283,43 +292,47 @@ BaseType_t xSpacePadding;
 #endif /* configINCLUDE_QUERY_HEAP */\r
 /*-----------------------------------------------------------*/\r
 \r
-static BaseType_t prvRunTimeStatsCommand( char *pcWriteBuffer, size_t xWriteBufferLen, const char *pcCommandString )\r
-{\r
-const char * const pcHeader = "  Abs Time      % Time\r\n****************************************\r\n";\r
-BaseType_t xSpacePadding;\r
+#if( configGENERATE_RUN_TIME_STATS == 1 )\r
+       \r
+       static BaseType_t prvRunTimeStatsCommand( char *pcWriteBuffer, size_t xWriteBufferLen, const char *pcCommandString )\r
+       {\r
+       const char * const pcHeader = "  Abs Time      % Time\r\n****************************************\r\n";\r
+       BaseType_t xSpacePadding;\r
 \r
-       /* Remove compile time warnings about unused parameters, and check the\r
-       write buffer is not NULL.  NOTE - for simplicity, this example assumes the\r
-       write buffer length is adequate, so does not check for buffer overflows. */\r
-       ( void ) pcCommandString;\r
-       ( void ) xWriteBufferLen;\r
-       configASSERT( pcWriteBuffer );\r
+               /* Remove compile time warnings about unused parameters, and check the\r
+               write buffer is not NULL.  NOTE - for simplicity, this example assumes the\r
+               write buffer length is adequate, so does not check for buffer overflows. */\r
+               ( void ) pcCommandString;\r
+               ( void ) xWriteBufferLen;\r
+               configASSERT( pcWriteBuffer );\r
 \r
-       /* Generate a table of task stats. */\r
-       strcpy( pcWriteBuffer, "Task" );\r
-       pcWriteBuffer += strlen( pcWriteBuffer );\r
+               /* Generate a table of task stats. */\r
+               strcpy( pcWriteBuffer, "Task" );\r
+               pcWriteBuffer += strlen( pcWriteBuffer );\r
 \r
-       /* Pad the string "task" with however many bytes necessary to make it the\r
-       length of a task name.  Minus three for the null terminator and half the\r
-       number of characters in "Task" so the column lines up with the centre of\r
-       the heading. */\r
-       for( xSpacePadding = strlen( "Task" ); xSpacePadding < ( configMAX_TASK_NAME_LEN - 3 ); xSpacePadding++ )\r
-       {\r
-               /* Add a space to align columns after the task's name. */\r
-               *pcWriteBuffer = ' ';\r
-               pcWriteBuffer++;\r
+               /* Pad the string "task" with however many bytes necessary to make it the\r
+               length of a task name.  Minus three for the null terminator and half the\r
+               number of characters in "Task" so the column lines up with the centre of\r
+               the heading. */\r
+               for( xSpacePadding = strlen( "Task" ); xSpacePadding < ( configMAX_TASK_NAME_LEN - 3 ); xSpacePadding++ )\r
+               {\r
+                       /* Add a space to align columns after the task's name. */\r
+                       *pcWriteBuffer = ' ';\r
+                       pcWriteBuffer++;\r
 \r
-               /* Ensure always terminated. */\r
-               *pcWriteBuffer = 0x00;\r
-       }\r
+                       /* Ensure always terminated. */\r
+                       *pcWriteBuffer = 0x00;\r
+               }\r
 \r
-       strcpy( pcWriteBuffer, pcHeader );\r
-       vTaskGetRunTimeStats( pcWriteBuffer + strlen( pcHeader ) );\r
+               strcpy( pcWriteBuffer, pcHeader );\r
+               vTaskGetRunTimeStats( pcWriteBuffer + strlen( pcHeader ) );\r
 \r
-       /* There is no more data to return after this single string, so return\r
-       pdFALSE. */\r
-       return pdFALSE;\r
-}\r
+               /* There is no more data to return after this single string, so return\r
+               pdFALSE. */\r
+               return pdFALSE;\r
+       }\r
+       \r
+#endif /* configGENERATE_RUN_TIME_STATS */\r
 /*-----------------------------------------------------------*/\r
 \r
 static BaseType_t prvThreeParameterEchoCommand( char *pcWriteBuffer, size_t xWriteBufferLen, const char *pcCommandString )\r
index 277474be2c1e0ec39fe4eb5a692b9a7dabd56a9a..9aca2c69ee076a0ac376a72b659aab2890d4cf38 100644 (file)
@@ -1,5 +1,6 @@
 [{000214A0-0000-0000-C000-000000000046}]\r
 Prop3=19,2\r
 [InternetShortcut]\r
-URL=http://www.freertos.org/FreeRTOS-Plus/Fail_Safe_File_System/Reliance_Edge_Fail_Safe_File_System.shtml\r
+URL=http://www.freertos.org/FreeRTOS-Plus/Fail_Safe_File_System/Fail_Safe_Embedded_File_System_demo.shtml\r
 IDList=\r
+HotKey=0\r
index 0a7028d3c074321f56b4f6549a3f0e671e082de5..687e05029b24f70740cf6d6f23d15885c565a84d 100644 (file)
@@ -71,7 +71,7 @@
  *\r
  * This demo is described on the following web page:\r
  * TODO: This link describes the FAT version of this demo.\r
- * http://FreeRTOS-Plus/Fail_Safe_File_System/Fail_Safe_Embedded_File_System_demo.shtml\r
+ * http://www.freertos.org/FreeRTOS-Plus/Fail_Safe_File_System/Fail_Safe_Embedded_File_System_demo.shtml\r
  *\r
  ******************************************************************************/\r
 \r
@@ -112,7 +112,10 @@ extern void vUDPCommandInterpreterTask( void *pvParameters );
 extern void vCreateAndVerifySampleFiles( void );\r
 \r
 /*-----------------------------------------------------------*/\r
-#pragma warning - add link to documentation page\r
+\r
+/* See http://www.freertos.org/FreeRTOS-Plus/Fail_Safe_File_System/Fail_Safe_Embedded_File_System_demo.shtml\r
+for instructions. */\r
+\r
 int main( void )\r
 {\r
 const uint32_t ulLongTime_ms = 250UL;\r
index 4f3c2e924a1b68cf2cb21e030e6a7cd4ede6eab9..4a08f47f96040d380ec5c7136b8bb77589a76b94 100644 (file)
@@ -1,5 +1,5 @@
 /*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
+ * Tracealyzer v2.7.7 Recorder Library\r
  * Percepio AB, www.percepio.com\r
  *\r
  * trcConfig.h\r
@@ -38,7 +38,7 @@
  *\r
  * Tabs are used for indent in this file (1 tab = 4 spaces)\r
  *\r
- * Copyright Percepio AB, 2014.\r
+ * Copyright Percepio AB, 2012-2015.\r
  * www.percepio.com\r
  ******************************************************************************/\r
 \r
  * PORT_NXP_LPC210X                                            13              No                      Any                             \r
  * PORT_MICROCHIP_PIC32MZ                              14              Yes                     Any                     \r
  * PORT_ARM_CORTEX_A9                                  15              No                      Any\r
+ * PORT_ARM_CORTEX_M0                                  16              Yes                     Any\r
  *****************************************************************************/\r
 \r
-#ifndef WIN32\r
-       // Set the port setting here!\r
-       #define SELECTED_PORT PORT_NOT_SET\r
+// Set the port setting here!\r
+#define SELECTED_PORT PORT_NOT_SET\r
 \r
-       #if (SELECTED_PORT == PORT_NOT_SET)\r
-               #error "You need to define SELECTED_PORT here!"\r
-       #endif\r
-#else\r
-       // For Win32 demo projects this is set automatically\r
-       #define SELECTED_PORT PORT_Win32        \r
+#if (SELECTED_PORT == PORT_ARM_CortexM)\r
+       /* For ARM Cortex-M: make sure ARM's CMSIS library is included here, which\r
+       is used for accessing the PRIMASK register. e.g. #include "board.h" */\r
+#endif\r
+\r
+\r
+#if (SELECTED_PORT == PORT_NOT_SET)\r
+       #error "You need to define SELECTED_PORT here!"\r
 #endif\r
 \r
 /******************************************************************************\r
index 7c93d4ef4cdf1cdf0d7393cafe589fa2bf177d72..e307a01a6205bc51a29e7f86f231fd15050a42ab 100644 (file)
@@ -1,5 +1,5 @@
 /*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
+ * Tracealyzer v2.7.7 Recorder Library\r
  * Percepio AB, www.percepio.com\r
  *\r
  * trcHardwarePort.h\r
@@ -34,7 +34,7 @@
  *\r
  * Tabs are used for indent in this file (1 tab = 4 spaces)\r
  *\r
- * Copyright Percepio AB, 2014.\r
+ * Copyright Percepio AB, 2012-2015.\r
  * www.percepio.com\r
  ******************************************************************************/\r
 \r
 #define PORT_NXP_LPC210X                                       13      /*      No                      Any                                     */\r
 #define PORT_MICROCHIP_PIC32MZ                         14      /*      Yes                     Any                                     */\r
 #define PORT_ARM_CORTEX_A9                                     15      /*      No                      Any                                     */\r
+#define PORT_ARM_CORTEX_M0                                     16      /*      Yes                     Any                                     */\r
 \r
 #include "trcConfig.h"\r
 \r
 #elif (SELECTED_PORT == PORT_ARM_CortexM)\r
 \r
        void prvTraceInitCortexM(void);\r
-       \r
+\r
        #define REG_DEMCR (*(volatile unsigned int*)0xE000EDFC)\r
        #define REG_DWT_CTRL (*(volatile unsigned int*)0xE0001000)\r
        #define REG_DWT_CYCCNT (*(volatile unsigned int*)0xE0001004)\r
        #define REG_DWT_EXCCNT (*(volatile unsigned int*)0xE000100C)\r
-       \r
+\r
        /* Bit mask for TRCENA bit in DEMCR - Global enable for DWT and ITM */\r
        #define DEMCR_TRCENA (1 << 24)\r
 \r
        #define PORT_SPECIFIC_INIT() prvTraceInitCortexM()\r
 \r
        extern uint32_t DWT_CYCLES_ADDED;\r
-       \r
+\r
        #define HWTC_COUNT_DIRECTION DIRECTION_INCREMENTING\r
        #define HWTC_COUNT (REG_DWT_CYCCNT + DWT_CYCLES_ADDED)\r
        #define HWTC_PERIOD 0\r
 \r
        #define IRQ_PRIORITY_ORDER 0 // lower IRQ priority values are more significant\r
 \r
+#elif (SELECTED_PORT == PORT_ARM_CORTEX_M0)\r
+    #define HWTC_COUNT_DIRECTION DIRECTION_DECREMENTING\r
+    #define HWTC_COUNT (*((uint32_t*)0xE000E018))\r
+    #define HWTC_PERIOD ((*(uint32_t*)0xE000E014) + 1)\r
+    #define HWTC_DIVISOR 2\r
+       \r
+    #define IRQ_PRIORITY_ORDER 0 // lower IRQ priority values are more significant\r
+       \r
 #elif (SELECTED_PORT == PORT_Renesas_RX600)\r
 \r
        #include "iodefine.h"\r
        #define HWTC_DIVISOR 1\r
        #define IRQ_PRIORITY_ORDER 1 // higher IRQ priority values are more significant\r
 \r
-#elif (SELECTED_PORT == PORT_MICROCHIP_PIC32MX || SELECTED_PORT == PORT_MICROCHIP_PIC32MZ)\r
-       \r
+#elif ((SELECTED_PORT == PORT_MICROCHIP_PIC32MX) || (SELECTED_PORT == PORT_MICROCHIP_PIC32MZ))\r
+\r
        #define HWTC_COUNT_DIRECTION DIRECTION_INCREMENTING\r
        #define HWTC_COUNT (TMR1)\r
        #define HWTC_PERIOD (PR1 + 1)\r
 \r
        /* UNOFFICIAL PORT - NOT YET VERIFIED BY PERCEPIO */\r
 \r
-       #define RTIFRC0 *((uint32_t *)0xFFFFFC10)\r
-       #define RTICOMP0 *((uint32_t *)0xFFFFFC50)\r
-       #define RTIUDCP0 *((uint32_t *)0xFFFFFC54)\r
+       #define TRC_RTIFRC0 *((uint32_t *)0xFFFFFC10)\r
+       #define TRC_RTICOMP0 *((uint32_t *)0xFFFFFC50)\r
+       #define TRC_RTIUDCP0 *((uint32_t *)0xFFFFFC54)\r
        #define HWTC_COUNT_DIRECTION DIRECTION_INCREMENTING\r
-       #define HWTC_COUNT (RTIFRC0 - (RTICOMP0 - RTIUDCP0))\r
+       #define HWTC_COUNT (TRC_RTIFRC0 - (TRC_RTICOMP0 - TRC_RTIUDCP0))\r
        #define HWTC_PERIOD (RTIUDCP0)\r
        #define HWTC_DIVISOR 1\r
 \r
index 1ee5e4bf1b46a402c2a5c55425c0d6b76c12fa81..7be8770706f18cd8abb60cd1b98105d396f988a5 100644 (file)
@@ -1,5 +1,5 @@
 /*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
+ * Tracealyzer v2.7.7 Recorder Library\r
  * Percepio AB, www.percepio.com\r
  *\r
  * trcKernel.h\r
@@ -31,7 +31,7 @@
  * damages, or the exclusion of implied warranties or limitations on how long an\r
  * implied warranty may last, so the above limitations may not apply to you.\r
  *\r
- * Copyright Percepio AB, 2013.\r
+ * Copyright Percepio AB, 2012-2015.\r
  * www.percepio.com\r
  ******************************************************************************/\r
 \r
 /* Internal functions */\r
 \r
 #if !defined INCLUDE_READY_EVENTS || INCLUDE_READY_EVENTS == 1\r
-void vTraceStoreTaskReady(objectHandleType handle);\r
+       void vTraceSetReadyEventsEnabled(int status);\r
+       void vTraceStoreTaskReady(objectHandleType handle);\r
+#else\r
+       #define vTraceSetReadyEventsEnabled(status)\r
 #endif\r
 \r
 void vTraceStoreLowPower(uint32_t flag);\r
index 59dc94bc8a3efcf7e4c65a805f085ec81575ae81..904258606e731f25283cc07cac391c86ce8ff3d9 100644 (file)
 /*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
+ * Tracealyzer v2.7.7 Recorder Library\r
  * Percepio AB, www.percepio.com\r
  *\r
- * trcKernelPort.h\r
+ * trcKernelPortFreeRTOS.h\r
+ *\r
+ * Kernel-specific functionality for FreeRTOS, used by the recorder library.\r
  *\r
- * Wrapper for kernel-specific port (trcKernelPort<KERNEL>.h)\r
- * \r
  * Terms of Use\r
  * This software is copyright Percepio AB. The recorder library is free for\r
  * use together with Percepio products. You may distribute the recorder library\r
  * in its original form, including modifications in trcHardwarePort.c/.h\r
  * given that these modification are clearly marked as your own modifications\r
- * and documented in the initial comment section of these source files. \r
- * This software is the intellectual property of Percepio AB and may not be \r
- * sold or in other ways commercially redistributed without explicit written \r
+ * and documented in the initial comment section of these source files.\r
+ * This software is the intellectual property of Percepio AB and may not be\r
+ * sold or in other ways commercially redistributed without explicit written\r
  * permission by Percepio AB.\r
  *\r
- * Disclaimer \r
- * The trace tool and recorder library is being delivered to you AS IS and \r
- * Percepio AB makes no warranty as to its use or performance. Percepio AB does \r
- * not and cannot warrant the performance or results you may obtain by using the \r
- * software or documentation. Percepio AB make no warranties, express or \r
- * implied, as to noninfringement of third party rights, merchantability, or \r
- * fitness for any particular purpose. In no event will Percepio AB, its \r
- * technology partners, or distributors be liable to you for any consequential, \r
- * incidental or special damages, including any lost profits or lost savings, \r
- * even if a representative of Percepio AB has been advised of the possibility \r
- * of such damages, or for any claim by any third party. Some jurisdictions do \r
- * not allow the exclusion or limitation of incidental, consequential or special \r
- * damages, or the exclusion of implied warranties or limitations on how long an \r
+ * Disclaimer\r
+ * The trace tool and recorder library is being delivered to you AS IS and\r
+ * Percepio AB makes no warranty as to its use or performance. Percepio AB does\r
+ * not and cannot warrant the performance or results you may obtain by using the\r
+ * software or documentation. Percepio AB make no warranties, express or\r
+ * implied, as to noninfringement of third party rights, merchantability, or\r
+ * fitness for any particular purpose. In no event will Percepio AB, its\r
+ * technology partners, or distributors be liable to you for any consequential,\r
+ * incidental or special damages, including any lost profits or lost savings,\r
+ * even if a representative of Percepio AB has been advised of the possibility\r
+ * of such damages, or for any claim by any third party. Some jurisdictions do\r
+ * not allow the exclusion or limitation of incidental, consequential or special\r
+ * damages, or the exclusion of implied warranties or limitations on how long an\r
  * implied warranty may last, so the above limitations may not apply to you.\r
  *\r
  * Tabs are used for indent in this file (1 tab = 4 spaces)\r
  *\r
- * Copyright Percepio AB, 2014.\r
+ * Copyright Percepio AB, 2012-2015.\r
  * www.percepio.com\r
  ******************************************************************************/\r
 \r
-/* Change the included file below, if using the recorder with other kernels */\r
 \r
-#include "trcKernelPortFreeRTOS.h"\r
-/* #include "trcKernelPort<OTHERKERNEL>.h" */\r
+#ifndef TRCKERNELPORTFREERTOS_H\r
+#define TRCKERNELPORTFREERTOS_H\r
+\r
+#include "FreeRTOS.h"  /* Defines configUSE_TRACE_FACILITY */\r
+#include "trcHardwarePort.h"\r
+\r
+extern int uiInEventGroupSetBitsFromISR;\r
+\r
+#define USE_TRACEALYZER_RECORDER configUSE_TRACE_FACILITY\r
+\r
+#if (USE_TRACEALYZER_RECORDER == 1)\r
+\r
+/* Defines that must be set for the recorder to work properly */\r
+#define TRACE_KERNEL_VERSION 0x1AA1\r
+#define TRACE_TICK_RATE_HZ configTICK_RATE_HZ /* Defined in "FreeRTOS.h" */\r
+#define TRACE_CPU_CLOCK_HZ configCPU_CLOCK_HZ /* Defined in "FreeRTOSConfig.h" */\r
+\r
+#if (SELECTED_PORT == PORT_ARM_CortexM)\r
+               \r
+    /* If you get warnings regarding __get_PRIMASK and __set_PRIMASK, make sure that ARM's CMSIS API is included \r
+       by the recorder using your chip vendor header file (e.g., "board.h", "stm32f4xx.h", "lpc17xx.h") */\r
+       \r
+       #define TRACE_SR_ALLOC_CRITICAL_SECTION() int __irq_status; \r
+       #define TRACE_ENTER_CRITICAL_SECTION() {__irq_status = __get_PRIMASK(); __set_PRIMASK(1);}\r
+       #define TRACE_EXIT_CRITICAL_SECTION() {__set_PRIMASK(__irq_status);}\r
+\r
+#endif\r
+\r
+#if ((SELECTED_PORT == PORT_ARM_CORTEX_A9) || (SELECTED_PORT == PORT_Renesas_RX600) || (SELECTED_PORT == PORT_MICROCHIP_PIC32MX) || (SELECTED_PORT == PORT_MICROCHIP_PIC32MZ))\r
+       #define TRACE_SR_ALLOC_CRITICAL_SECTION() int __irq_status;\r
+       #define TRACE_ENTER_CRITICAL_SECTION() {__irq_status = portSET_INTERRUPT_MASK_FROM_ISR();}\r
+       #define TRACE_EXIT_CRITICAL_SECTION() {portCLEAR_INTERRUPT_MASK_FROM_ISR(__irq_status);}\r
+#endif\r
+\r
+#if (SELECTED_PORT == PORT_Win32)\r
+    /* In the Win32 port, there are no real interrupts, so we can use the normal critical sections */\r
+       #define TRACE_SR_ALLOC_CRITICAL_SECTION()\r
+       #define TRACE_ENTER_CRITICAL_SECTION() portENTER_CRITICAL()\r
+       #define TRACE_EXIT_CRITICAL_SECTION() portEXIT_CRITICAL()\r
+#endif\r
+\r
+#ifndef TRACE_ENTER_CRITICAL_SECTION\r
+       #error "This port has no valid definition for critical sections! See http://percepio.com/2014/10/27/how-to-define-critical-sections-for-the-recorder/"\r
+#endif\r
+\r
+#if (SELECTED_PORT == PORT_ARM_CortexM)\r
+       #define trcCRITICAL_SECTION_BEGIN_ON_CORTEX_M_ONLY trcCRITICAL_SECTION_BEGIN\r
+       #define trcCRITICAL_SECTION_END_ON_CORTEX_M_ONLY trcCRITICAL_SECTION_END\r
+#else\r
+       #define trcCRITICAL_SECTION_BEGIN_ON_CORTEX_M_ONLY() recorder_busy++;\r
+       #define trcCRITICAL_SECTION_END_ON_CORTEX_M_ONLY() recorder_busy--;\r
+#endif\r
+\r
+/*************************************************************************/\r
+/* KERNEL SPECIFIC OBJECT CONFIGURATION                                                                         */\r
+/*************************************************************************/\r
+#define TRACE_NCLASSES 7\r
+#define TRACE_CLASS_QUEUE ((traceObjectClass)0)\r
+#define TRACE_CLASS_SEMAPHORE ((traceObjectClass)1)\r
+#define TRACE_CLASS_MUTEX ((traceObjectClass)2)\r
+#define TRACE_CLASS_TASK ((traceObjectClass)3)\r
+#define TRACE_CLASS_ISR ((traceObjectClass)4)\r
+#define TRACE_CLASS_TIMER ((traceObjectClass)5)\r
+#define TRACE_CLASS_EVENTGROUP ((traceObjectClass)6)\r
+\r
+#define TRACE_KERNEL_OBJECT_COUNT (NQueue + NSemaphore + NMutex + NTask + NISR + NTimer + NEventGroup)\r
+\r
+/* The size of the Object Property Table entries, in bytes, per object */\r
+\r
+/* Queue properties (except name):     current number of message in queue */\r
+#define PropertyTableSizeQueue         (NameLenQueue + 1)\r
+\r
+/* Semaphore properties (except name): state (signaled = 1, cleared = 0) */\r
+#define PropertyTableSizeSemaphore     (NameLenSemaphore + 1)\r
+\r
+/* Mutex properties (except name):     owner (task handle, 0 = free) */\r
+#define PropertyTableSizeMutex         (NameLenMutex + 1)\r
+\r
+/* Task properties (except name):      Byte 0: Current priority\r
+                                                                       Byte 1: state (if already active)\r
+                                                                       Byte 2: legacy, not used\r
+                                                                       Byte 3: legacy, not used */\r
+#define PropertyTableSizeTask          (NameLenTask + 4)\r
+\r
+/* ISR properties:                                     Byte 0: priority\r
+                                                                       Byte 1: state (if already active) */\r
+#define PropertyTableSizeISR           (NameLenISR + 2)\r
+\r
+/* NTimer properties:                          Byte 0: state (unused for now) */\r
+#define PropertyTableSizeTimer         (NameLenTimer + 1)\r
+\r
+/* NEventGroup properties:                     Byte 0-3: state (unused for now)*/\r
+#define PropertyTableSizeEventGroup    (NameLenEventGroup + 4)\r
+\r
+\r
+/* The layout of the byte array representing the Object Property Table */\r
+#define StartIndexQueue                        0\r
+#define StartIndexSemaphore            StartIndexQueue         + NQueue                * PropertyTableSizeQueue\r
+#define StartIndexMutex                        StartIndexSemaphore + NSemaphore        * PropertyTableSizeSemaphore\r
+#define StartIndexTask                 StartIndexMutex         + NMutex                * PropertyTableSizeMutex\r
+#define StartIndexISR                  StartIndexTask          + NTask                 * PropertyTableSizeTask\r
+#define StartIndexTimer                        StartIndexISR           + NISR                  * PropertyTableSizeISR\r
+#define StartIndexEventGroup   StartIndexTimer         + NTimer                * PropertyTableSizeTimer\r
+\r
+/* Number of bytes used by the object table */\r
+#define TRACE_OBJECT_TABLE_SIZE        StartIndexEventGroup + NEventGroup * PropertyTableSizeEventGroup\r
+\r
+#define FREERTOS_VERSION_NOT_SET                       0\r
+#define FREERTOS_VERSION_7_3_OR_7_4                    1\r
+#define FREERTOS_VERSION_7_5_OR_7_6                    2\r
+#define FREERTOS_VERSION_8_0_OR_LATER          3\r
+\r
+/* Includes */\r
+#include "trcConfig.h" /* Must be first, even before trcTypes.h */\r
+#include "trcHardwarePort.h"\r
+#include "trcTypes.h"\r
+#include "trcKernelHooks.h"\r
+#include "trcBase.h"\r
+#include "trcKernel.h"\r
+#include "trcUser.h"\r
+\r
+#if (INCLUDE_NEW_TIME_EVENTS == 1 && configUSE_TICKLESS_IDLE != 0)\r
+#error "NewTime events can not be used in combination with tickless idle!"\r
+#endif\r
+\r
+/* Initialization of the object property table */\r
+void vTraceInitObjectPropertyTable(void);\r
+\r
+/* Initialization of the handle mechanism, see e.g, xTraceGetObjectHandle */\r
+void vTraceInitObjectHandleStack(void);\r
+\r
+/* Returns the "Not enough handles" error message for the specified object class */\r
+const char* pszTraceGetErrorNotEnoughHandles(traceObjectClass objectclass);\r
+\r
+/*******************************************************************************\r
+ * The event codes - should match the offline config file.\r
+ *\r
+ * Some sections below are encoded to allow for constructions like:\r
+ *\r
+ * vTraceStoreKernelCall(EVENTGROUP_CREATE + objectclass, ...\r
+ *\r
+ * The object class ID is given by the three LSB bits, in such cases. Since each\r
+ * object class has a separate object property table, the class ID is needed to\r
+ * know what section in the object table to use for getting an object name from\r
+ * an object handle.\r
+ ******************************************************************************/\r
+\r
+#define NULL_EVENT                                     (0x00) /* Ignored in the analysis*/\r
+\r
+/*******************************************************************************\r
+ * EVENTGROUP_DIV\r
+ *\r
+ * Miscellaneous events.\r
+ ******************************************************************************/\r
+#define EVENTGROUP_DIV                         (NULL_EVENT + 1)                                        /*0x01*/\r
+#define DIV_XPS                                                (EVENTGROUP_DIV + 0)                            /*0x01*/\r
+#define DIV_TASK_READY                         (EVENTGROUP_DIV + 1)                            /*0x02*/\r
+#define DIV_NEW_TIME                           (EVENTGROUP_DIV + 2)                            /*0x03*/\r
+\r
+/*******************************************************************************\r
+ * EVENTGROUP_TS\r
+ *\r
+ * Events for storing task-switches and interrupts. The RESUME events are\r
+ * generated if the task/interrupt is already marked active.\r
+ ******************************************************************************/\r
+#define EVENTGROUP_TS                          (EVENTGROUP_DIV + 3)                            /*0x04*/\r
+#define TS_ISR_BEGIN                           (EVENTGROUP_TS + 0)                                     /*0x04*/\r
+#define TS_ISR_RESUME                          (EVENTGROUP_TS + 1)                                     /*0x05*/\r
+#define TS_TASK_BEGIN                          (EVENTGROUP_TS + 2)                                     /*0x06*/\r
+#define TS_TASK_RESUME                         (EVENTGROUP_TS + 3)                                     /*0x07*/\r
+\r
+/*******************************************************************************\r
+ * EVENTGROUP_OBJCLOSE_NAME\r
+ *\r
+ * About Close Events\r
+ * When an object is evicted from the object property table (object close), two\r
+ * internal events are stored (EVENTGROUP_OBJCLOSE_NAME and\r
+ * EVENTGROUP_OBJCLOSE_PROP), containing the handle-name mapping and object\r
+ * properties valid up to this point.\r
+ ******************************************************************************/\r
+#define EVENTGROUP_OBJCLOSE_NAME       (EVENTGROUP_TS + 4)                                     /*0x08*/\r
+\r
+/*******************************************************************************\r
+ * EVENTGROUP_OBJCLOSE_PROP\r
+ *\r
+ * The internal event carrying properties of deleted objects\r
+ * The handle and object class of the closed object is not stored in this event,\r
+ * but is assumed to be the same as in the preceding CLOSE event. Thus, these\r
+ * two events must be generated from within a critical section.\r
+ * When queues are closed, arg1 is the "state" property (i.e., number of\r
+ * buffered messages/signals).\r
+ * When actors are closed, arg1 is priority, arg2 is handle of the "instance\r
+ * finish" event, and arg3 is event code of the "instance finish" event.\r
+ * In this case, the lower three bits is the object class of the instance finish\r
+ * handle. The lower three bits are not used (always zero) when queues are\r
+ * closed since the queue type is given in the previous OBJCLOSE_NAME event.\r
+ ******************************************************************************/\r
+#define EVENTGROUP_OBJCLOSE_PROP       (EVENTGROUP_OBJCLOSE_NAME + 8)          /*0x10*/\r
+\r
+/*******************************************************************************\r
+ * EVENTGROUP_CREATE\r
+ *\r
+ * The events in this group are used to log Kernel object creations.\r
+ * The lower three bits in the event code gives the object class, i.e., type of\r
+ * create operation (task, queue, semaphore, etc).\r
+ ******************************************************************************/\r
+#define EVENTGROUP_CREATE_OBJ_SUCCESS  (EVENTGROUP_OBJCLOSE_PROP + 8)  /*0x18*/\r
+\r
+/*******************************************************************************\r
+ * EVENTGROUP_SEND\r
+ *\r
+ * The events in this group are used to log Send/Give events on queues,\r
+ * semaphores and mutexes The lower three bits in the event code gives the\r
+ * object class, i.e., what type of object that is operated on (queue, semaphore\r
+ * or mutex).\r
+ ******************************************************************************/\r
+#define EVENTGROUP_SEND_SUCCESS        (EVENTGROUP_CREATE_OBJ_SUCCESS + 8)             /*0x20*/\r
+\r
+/*******************************************************************************\r
+ * EVENTGROUP_RECEIVE\r
+ *\r
+ * The events in this group are used to log Receive/Take events on queues,\r
+ * semaphores and mutexes. The lower three bits in the event code gives the\r
+ * object class, i.e., what type of object that is operated on (queue, semaphore\r
+ * or mutex).\r
+ ******************************************************************************/\r
+#define EVENTGROUP_RECEIVE_SUCCESS     (EVENTGROUP_SEND_SUCCESS + 8)           /*0x28*/\r
+\r
+/* Send/Give operations, from ISR */\r
+#define EVENTGROUP_SEND_FROM_ISR_SUCCESS \\r
+                                                                       (EVENTGROUP_RECEIVE_SUCCESS + 8)        /*0x30*/\r
+\r
+/* Receive/Take operations, from ISR */\r
+#define EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS \\r
+                                                       (EVENTGROUP_SEND_FROM_ISR_SUCCESS + 8)          /*0x38*/\r
+\r
+/* "Failed" event type versions of above (timeout, failed allocation, etc) */\r
+#define EVENTGROUP_KSE_FAILED \\r
+                                                       (EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS + 8)       /*0x40*/\r
+\r
+/* Failed create calls - memory allocation failed */\r
+#define EVENTGROUP_CREATE_OBJ_FAILED   (EVENTGROUP_KSE_FAILED)                 /*0x40*/\r
+\r
+/* Failed send/give - timeout! */\r
+#define EVENTGROUP_SEND_FAILED         (EVENTGROUP_CREATE_OBJ_FAILED + 8)      /*0x48*/\r
+\r
+/* Failed receive/take - timeout! */\r
+#define EVENTGROUP_RECEIVE_FAILED       (EVENTGROUP_SEND_FAILED + 8)           /*0x50*/\r
+\r
+/* Failed non-blocking send/give - queue full */\r
+#define EVENTGROUP_SEND_FROM_ISR_FAILED (EVENTGROUP_RECEIVE_FAILED + 8) /*0x58*/\r
+\r
+/* Failed non-blocking receive/take - queue empty */\r
+#define EVENTGROUP_RECEIVE_FROM_ISR_FAILED \\r
+                                                                (EVENTGROUP_SEND_FROM_ISR_FAILED + 8)  /*0x60*/\r
+\r
+/* Events when blocking on receive/take */\r
+#define EVENTGROUP_RECEIVE_BLOCK \\r
+                                                       (EVENTGROUP_RECEIVE_FROM_ISR_FAILED + 8)        /*0x68*/\r
+\r
+/* Events when blocking on send/give */\r
+#define EVENTGROUP_SEND_BLOCK  (EVENTGROUP_RECEIVE_BLOCK + 8)                  /*0x70*/\r
+\r
+/* Events on queue peek (receive) */\r
+#define EVENTGROUP_PEEK_SUCCESS        (EVENTGROUP_SEND_BLOCK + 8)                             /*0x78*/\r
+\r
+/* Events on object delete (vTaskDelete or vQueueDelete) */\r
+#define EVENTGROUP_DELETE_OBJ_SUCCESS  (EVENTGROUP_PEEK_SUCCESS + 8)   /*0x80*/\r
+\r
+/* Other events - object class is implied: TASK */\r
+#define EVENTGROUP_OTHERS      (EVENTGROUP_DELETE_OBJ_SUCCESS + 8)                     /*0x88*/\r
+#define TASK_DELAY_UNTIL       (EVENTGROUP_OTHERS + 0)                                         /*0x88*/\r
+#define TASK_DELAY                     (EVENTGROUP_OTHERS + 1)                                         /*0x89*/\r
+#define TASK_SUSPEND           (EVENTGROUP_OTHERS + 2)                                         /*0x8A*/\r
+#define TASK_RESUME                    (EVENTGROUP_OTHERS + 3)                                         /*0x8B*/\r
+#define TASK_RESUME_FROM_ISR   (EVENTGROUP_OTHERS + 4)                                 /*0x8C*/\r
+#define TASK_PRIORITY_SET              (EVENTGROUP_OTHERS + 5)                                 /*0x8D*/\r
+#define TASK_PRIORITY_INHERIT  (EVENTGROUP_OTHERS + 6)                                 /*0x8E*/\r
+#define TASK_PRIORITY_DISINHERIT       (EVENTGROUP_OTHERS + 7)                         /*0x8F*/\r
+\r
+#define EVENTGROUP_MISC_PLACEHOLDER    (EVENTGROUP_OTHERS + 8)                         /*0x90*/\r
+#define PEND_FUNC_CALL         (EVENTGROUP_MISC_PLACEHOLDER+0)                         /*0x90*/\r
+#define PEND_FUNC_CALL_FROM_ISR (EVENTGROUP_MISC_PLACEHOLDER+1)                        /*0x91*/\r
+#define PEND_FUNC_CALL_FAILED (EVENTGROUP_MISC_PLACEHOLDER+2)                  /*0x92*/\r
+#define PEND_FUNC_CALL_FROM_ISR_FAILED (EVENTGROUP_MISC_PLACEHOLDER+3) /*0x93*/\r
+#define MEM_MALLOC_SIZE (EVENTGROUP_MISC_PLACEHOLDER+4)                                        /*0x94*/\r
+#define MEM_MALLOC_ADDR (EVENTGROUP_MISC_PLACEHOLDER+5)                                        /*0x95*/\r
+#define MEM_FREE_SIZE (EVENTGROUP_MISC_PLACEHOLDER+6)                                  /*0x96*/\r
+#define MEM_FREE_ADDR (EVENTGROUP_MISC_PLACEHOLDER+7)                                  /*0x97*/\r
+\r
+/* User events */\r
+#define EVENTGROUP_USEREVENT (EVENTGROUP_MISC_PLACEHOLDER + 8)                 /*0x98*/\r
+#define USER_EVENT (EVENTGROUP_USEREVENT + 0)\r
+\r
+/* Allow for 0-15 arguments (the number of args is added to event code) */\r
+#define USER_EVENT_LAST (EVENTGROUP_USEREVENT + 15)                                            /*0xA7*/\r
+\r
+/*******************************************************************************\r
+ * XTS Event - eXtended TimeStamp events\r
+ * The timestamps used in the recorder are "differential timestamps" (DTS), i.e.\r
+ * the time since the last stored event. The DTS fields are either 1 or 2 bytes\r
+ * in the other events, depending on the bytes available in the event struct.\r
+ * If the time since the last event (the DTS) is larger than allowed for by\r
+ * the DTS field of the current event, an XTS event is inserted immediately\r
+ * before the original event. The XTS event contains up to 3 additional bytes\r
+ * of the DTS value - the higher bytes of the true DTS value. The lower 1-2\r
+ * bytes are stored in the normal DTS field.\r
+ * There are two types of XTS events, XTS8 and XTS16. An XTS8 event is stored\r
+ * when there is only room for 1 byte (8 bit) DTS data in the original event,\r
+ * which means a limit of 0xFF (255). The XTS16 is used when the original event\r
+ * has a 16 bit DTS field and thereby can handle values up to 0xFFFF (65535).\r
+ *\r
+ * Using a very high frequency time base can result in many XTS events.\r
+ * Preferably, the time between two OS ticks should fit in 16 bits, i.e.,\r
+ * at most 65535. If your time base has a higher frequency, you can define\r
+ * the TRACE\r
+ ******************************************************************************/\r
+\r
+#define EVENTGROUP_SYS (EVENTGROUP_USEREVENT + 16)                                             /*0xA8*/\r
+#define XTS8 (EVENTGROUP_SYS + 0)                                                                              /*0xA8*/\r
+#define XTS16 (EVENTGROUP_SYS + 1)                                                                             /*0xA9*/\r
+#define EVENT_BEING_WRITTEN (EVENTGROUP_SYS + 2)                                               /*0xAA*/\r
+#define RESERVED_DUMMY_CODE (EVENTGROUP_SYS + 3)                                               /*0xAB*/\r
+#define LOW_POWER_BEGIN (EVENTGROUP_SYS + 4)                                                   /*0xAC*/\r
+#define LOW_POWER_END (EVENTGROUP_SYS + 5)                                                             /*0xAD*/\r
+#define XID (EVENTGROUP_SYS + 6)                                                                               /*0xAE*/\r
+#define XTS16L (EVENTGROUP_SYS + 7)                                                                            /*0xAF*/\r
+\r
+#define EVENTGROUP_TIMER (EVENTGROUP_SYS + 8)                                                  /*0xB0*/\r
+#define TIMER_CREATE (EVENTGROUP_TIMER + 0)                                                            /*0xB0*/\r
+#define TIMER_START (EVENTGROUP_TIMER + 1)                                                             /*0xB1*/\r
+#define TIMER_RST (EVENTGROUP_TIMER + 2)                                                               /*0xB2*/\r
+#define TIMER_STOP (EVENTGROUP_TIMER + 3)                                                              /*0xB3*/\r
+#define TIMER_CHANGE_PERIOD (EVENTGROUP_TIMER + 4)                                             /*0xB4*/\r
+#define TIMER_DELETE (EVENTGROUP_TIMER + 5)                                                            /*0xB5*/\r
+#define TIMER_START_FROM_ISR (EVENTGROUP_TIMER + 6)                                            /*0xB6*/\r
+#define TIMER_RESET_FROM_ISR (EVENTGROUP_TIMER + 7)                                            /*0xB7*/\r
+#define TIMER_STOP_FROM_ISR (EVENTGROUP_TIMER + 8)                                             /*0xB8*/\r
+\r
+#define TIMER_CREATE_FAILED (EVENTGROUP_TIMER + 9)                                             /*0xB9*/\r
+#define TIMER_START_FAILED (EVENTGROUP_TIMER + 10)                                             /*0xBA*/\r
+#define TIMER_RESET_FAILED (EVENTGROUP_TIMER + 11)                                             /*0xBB*/\r
+#define TIMER_STOP_FAILED (EVENTGROUP_TIMER + 12)                                              /*0xBC*/\r
+#define TIMER_CHANGE_PERIOD_FAILED (EVENTGROUP_TIMER + 13)                             /*0xBD*/\r
+#define TIMER_DELETE_FAILED (EVENTGROUP_TIMER + 14)                                            /*0xBE*/\r
+#define TIMER_START_FROM_ISR_FAILED (EVENTGROUP_TIMER + 15)                            /*0xBF*/\r
+#define TIMER_RESET_FROM_ISR_FAILED (EVENTGROUP_TIMER + 16)                            /*0xC0*/\r
+#define TIMER_STOP_FROM_ISR_FAILED (EVENTGROUP_TIMER + 17)                             /*0xC1*/\r
+\r
+#define EVENTGROUP_EG (EVENTGROUP_TIMER + 18)                                                  /*0xC2*/\r
+#define EVENT_GROUP_CREATE (EVENTGROUP_EG + 0)                                                 /*0xC2*/\r
+#define EVENT_GROUP_CREATE_FAILED (EVENTGROUP_EG + 1)                                  /*0xC3*/\r
+#define EVENT_GROUP_SYNC_BLOCK (EVENTGROUP_EG + 2)                                             /*0xC4*/\r
+#define EVENT_GROUP_SYNC_END (EVENTGROUP_EG + 3)                                               /*0xC5*/\r
+#define EVENT_GROUP_WAIT_BITS_BLOCK (EVENTGROUP_EG + 4)                                        /*0xC6*/\r
+#define EVENT_GROUP_WAIT_BITS_END (EVENTGROUP_EG + 5)                                  /*0xC7*/\r
+#define EVENT_GROUP_CLEAR_BITS (EVENTGROUP_EG + 6)                                             /*0xC8*/\r
+#define EVENT_GROUP_CLEAR_BITS_FROM_ISR (EVENTGROUP_EG + 7)                            /*0xC9*/\r
+#define EVENT_GROUP_SET_BITS (EVENTGROUP_EG + 8)                                               /*0xCA*/\r
+#define EVENT_GROUP_DELETE (EVENTGROUP_EG + 9)                                                 /*0xCB*/\r
+#define EVENT_GROUP_SYNC_END_FAILED (EVENTGROUP_EG + 10)                               /*0xCC*/\r
+#define EVENT_GROUP_WAIT_BITS_END_FAILED (EVENTGROUP_EG + 11)                  /*0xCD*/\r
+#define EVENT_GROUP_SET_BITS_FROM_ISR (EVENTGROUP_EG + 12)                             /*0xCE*/\r
+#define EVENT_GROUP_SET_BITS_FROM_ISR_FAILED (EVENTGROUP_EG + 13)              /*0xCF*/\r
+\r
+#define TASK_INSTANCE_FINISHED_NEXT_KSE (EVENTGROUP_EG + 14)                   /*0xD0*/\r
+#define TASK_INSTANCE_FINISHED_DIRECT (EVENTGROUP_EG + 15)                             /*0xD1*/\r
+\r
+#define TRACE_TASK_NOTIFY_GROUP (EVENTGROUP_EG + 16)                                   /*0xD2*/\r
+#define TRACE_TASK_NOTIFY (TRACE_TASK_NOTIFY_GROUP + 0)                                        /*0xD2*/\r
+#define TRACE_TASK_NOTIFY_TAKE (TRACE_TASK_NOTIFY_GROUP + 1)                   /*0xD3*/\r
+#define TRACE_TASK_NOTIFY_TAKE_BLOCK (TRACE_TASK_NOTIFY_GROUP + 2)             /*0xD4*/\r
+#define TRACE_TASK_NOTIFY_TAKE_FAILED (TRACE_TASK_NOTIFY_GROUP + 3)            /*0xD5*/\r
+#define TRACE_TASK_NOTIFY_WAIT (TRACE_TASK_NOTIFY_GROUP + 4)                   /*0xD6*/\r
+#define TRACE_TASK_NOTIFY_WAIT_BLOCK (TRACE_TASK_NOTIFY_GROUP + 5)             /*0xD7*/\r
+#define TRACE_TASK_NOTIFY_WAIT_FAILED (TRACE_TASK_NOTIFY_GROUP + 6)            /*0xD8*/\r
+#define TRACE_TASK_NOTIFY_FROM_ISR (TRACE_TASK_NOTIFY_GROUP + 7)               /*0xD9*/\r
+#define TRACE_TASK_NOTIFY_GIVE_FROM_ISR (TRACE_TASK_NOTIFY_GROUP + 8)  /*0xDA*/\r
+\r
+/************************************************************************/\r
+/* KERNEL SPECIFIC DATA AND FUNCTIONS NEEDED TO PROVIDE THE                            */\r
+/* FUNCTIONALITY REQUESTED BY THE TRACE RECORDER                                               */\r
+/************************************************************************/\r
+\r
+/******************************************************************************\r
+ * TraceObjectClassTable\r
+ * Translates a FreeRTOS QueueType into trace objects classes (TRACE_CLASS_).\r
+ * This was added since we want to map both types of Mutex and both types of\r
+ * Semaphores on common classes for all Mutexes and all Semaphores respectively.\r
+ *\r
+ * FreeRTOS Queue types\r
+ * #define queueQUEUE_TYPE_BASE                                        (0U) => TRACE_CLASS_QUEUE\r
+ * #define queueQUEUE_TYPE_MUTEX                               (1U) => TRACE_CLASS_MUTEX\r
+ * #define queueQUEUE_TYPE_COUNTING_SEMAPHORE  (2U) => TRACE_CLASS_SEMAPHORE\r
+ * #define queueQUEUE_TYPE_BINARY_SEMAPHORE            (3U) => TRACE_CLASS_SEMAPHORE\r
+ * #define queueQUEUE_TYPE_RECURSIVE_MUTEX             (4U) => TRACE_CLASS_MUTEX\r
+ ******************************************************************************/\r
+\r
+extern traceObjectClass TraceObjectClassTable[5];\r
+\r
+/* These functions are implemented in the .c file since certain header files\r
+must not be included in this one */\r
+objectHandleType prvTraceGetObjectNumber(void* handle);\r
+unsigned char prvTraceGetObjectType(void* handle);\r
+objectHandleType prvTraceGetTaskNumber(void* handle);\r
+unsigned char prvTraceIsSchedulerActive(void);\r
+unsigned char prvTraceIsSchedulerSuspended(void);\r
+unsigned char prvTraceIsSchedulerStarted(void);\r
+void* prvTraceGetCurrentTaskHandle(void);\r
+\r
+#if (configUSE_TIMERS == 1)\r
+#undef INCLUDE_xTimerGetTimerDaemonTaskHandle\r
+#define INCLUDE_xTimerGetTimerDaemonTaskHandle 1\r
+#endif\r
+\r
+/************************************************************************/\r
+/* KERNEL SPECIFIC MACROS USED BY THE TRACE RECORDER                                   */\r
+/************************************************************************/\r
+\r
+#define TRACE_MALLOC(size) pvPortMalloc(size)\r
+#define TRACE_IS_SCHEDULER_ACTIVE() prvTraceIsSchedulerActive()\r
+#define TRACE_IS_SCHEDULER_STARTED() prvTraceIsSchedulerStarted()\r
+#define TRACE_IS_SCHEDULER_SUSPENDED() prvTraceIsSchedulerSuspended()\r
+#define TRACE_GET_CURRENT_TASK() prvTraceGetCurrentTaskHandle()\r
+\r
+#define TRACE_GET_TASK_PRIORITY(pxTCB) ((uint8_t)pxTCB->uxPriority)\r
+#define TRACE_GET_TASK_NAME(pxTCB) ((char*)pxTCB->pcTaskName)\r
+#define TRACE_GET_TASK_NUMBER(pxTCB) (prvTraceGetTaskNumber(pxTCB))\r
+#define TRACE_SET_TASK_NUMBER(pxTCB) pxTCB->uxTaskNumber = xTraceGetObjectHandle(TRACE_CLASS_TASK);\r
+\r
+#define TRACE_GET_CLASS_TRACE_CLASS(CLASS, kernelClass) TraceObjectClassTable[kernelClass]\r
+#define TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject) TRACE_GET_CLASS_TRACE_CLASS(CLASS, prvTraceGetObjectType(pxObject))\r
+\r
+/* Note: Timer tracing only supported on FreeRTOS v8 or later, so "Timer_t" is safe to use! */\r
+#define TRACE_GET_TIMER_NUMBER(tmr) ( ( objectHandleType ) ((Timer_t*)tmr)->uxTimerNumber )\r
+#define TRACE_SET_TIMER_NUMBER(tmr) ((Timer_t*)tmr)->uxTimerNumber = xTraceGetObjectHandle(TRACE_CLASS_TIMER);\r
+#define TRACE_GET_TIMER_NAME(pxTimer) pxTimer->pcTimerName\r
+#define TRACE_GET_TIMER_PERIOD(pxTimer) pxTimer->xTimerPeriodInTicks\r
+\r
+#define TRACE_GET_EVENTGROUP_NUMBER(eg) ( ( objectHandleType ) uxEventGroupGetNumber(eg) )\r
+#define TRACE_SET_EVENTGROUP_NUMBER(eg) ((EventGroup_t*)eg)->uxEventGroupNumber = xTraceGetObjectHandle(TRACE_CLASS_EVENTGROUP);\r
+\r
+#define TRACE_GET_OBJECT_NUMBER(CLASS, pxObject) (prvTraceGetObjectNumber(pxObject))\r
+\r
+#if (FREERTOS_VERSION < FREERTOS_VERSION_8_0_OR_LATER)\r
+       #define TRACE_SET_OBJECT_NUMBER(CLASS, pxObject) pxObject->ucQueueNumber = xTraceGetObjectHandle(TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject));\r
+#else\r
+       #define TRACE_SET_OBJECT_NUMBER(CLASS, pxObject) pxObject->uxQueueNumber = xTraceGetObjectHandle(TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject));\r
+#endif\r
+\r
+#define TRACE_GET_CLASS_EVENT_CODE(SERVICE, RESULT, CLASS, kernelClass) (uint8_t)(EVENTGROUP_##SERVICE##_##RESULT + TRACE_GET_CLASS_TRACE_CLASS(CLASS, kernelClass))\r
+#define TRACE_GET_OBJECT_EVENT_CODE(SERVICE, RESULT, CLASS, pxObject) (uint8_t)(EVENTGROUP_##SERVICE##_##RESULT + TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject))\r
+#define TRACE_GET_TASK_EVENT_CODE(SERVICE, RESULT, CLASS, pxTCB) (uint8_t)(EVENTGROUP_##SERVICE##_##RESULT + TRACE_CLASS_TASK)\r
+\r
+/************************************************************************/\r
+/* KERNEL SPECIFIC WRAPPERS THAT SHOULD BE CALLED BY THE KERNEL                 */\r
+/************************************************************************/\r
+\r
+#if (configUSE_TICKLESS_IDLE != 0)\r
+\r
+#undef traceLOW_POWER_IDLE_BEGIN\r
+#define traceLOW_POWER_IDLE_BEGIN() \\r
+       { \\r
+               extern uint32_t trace_disable_timestamp; \\r
+               vTraceStoreLowPower(0); \\r
+               trace_disable_timestamp = 1; \\r
+       }\r
+\r
+#undef traceLOW_POWER_IDLE_END\r
+#define traceLOW_POWER_IDLE_END() \\r
+       { \\r
+               extern uint32_t trace_disable_timestamp; \\r
+               trace_disable_timestamp = 0; \\r
+               vTraceStoreLowPower(1); \\r
+       }\r
+\r
+#endif\r
+\r
+/* A macro that will update the tick count when returning from tickless idle */\r
+#undef traceINCREASE_TICK_COUNT\r
+/* Note: This can handle time adjustments of max 2^32 ticks, i.e., 35 seconds at 120 MHz. Thus, tick-less idle periods longer than 2^32 ticks will appear "compressed" on the time line.*/\r
+#define traceINCREASE_TICK_COUNT( xCount ) { DWT_CYCLES_ADDED += (xCount * (TRACE_CPU_CLOCK_HZ / TRACE_TICK_RATE_HZ)); }\r
+\r
+/* Called for each task that becomes ready */\r
+#undef traceMOVED_TASK_TO_READY_STATE\r
+#define traceMOVED_TASK_TO_READY_STATE( pxTCB ) \\r
+       trcKERNEL_HOOKS_MOVED_TASK_TO_READY_STATE(pxTCB);\r
+\r
+/* Called on each OS tick. Will call uiPortGetTimestamp to make sure it is called at least once every OS tick. */\r
+#undef traceTASK_INCREMENT_TICK\r
+\r
+#if (FREERTOS_VERSION == FREERTOS_VERSION_7_3_OR_7_4)\r
+\r
+#define traceTASK_INCREMENT_TICK( xTickCount ) \\r
+       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdTRUE || uxMissedTicks == 0) { trcKERNEL_HOOKS_INCREMENT_TICK(); } \\r
+       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE) { trcKERNEL_HOOKS_NEW_TIME(DIV_NEW_TIME, xTickCount + 1); }\r
+\r
+#else\r
+\r
+#define traceTASK_INCREMENT_TICK( xTickCount ) \\r
+       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdTRUE || uxPendedTicks == 0) { trcKERNEL_HOOKS_INCREMENT_TICK(); } \\r
+       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE) { trcKERNEL_HOOKS_NEW_TIME(DIV_NEW_TIME, xTickCount + 1); }\r
+\r
+#endif\r
+\r
+/* Called on each task-switch */\r
+#undef traceTASK_SWITCHED_IN\r
+#define traceTASK_SWITCHED_IN() \\r
+               trcKERNEL_HOOKS_TASK_SWITCH(TRACE_GET_CURRENT_TASK());\r
+\r
+/* Called on vTaskSuspend */\r
+#undef traceTASK_SUSPEND\r
+#define traceTASK_SUSPEND( pxTaskToSuspend ) \\r
+       trcKERNEL_HOOKS_TASK_SUSPEND(TASK_SUSPEND, pxTaskToSuspend);\r
+\r
+/* Called on vTaskDelay - note the use of FreeRTOS variable xTicksToDelay */\r
+#undef traceTASK_DELAY\r
+#define traceTASK_DELAY() \\r
+       trcKERNEL_HOOKS_TASK_DELAY(TASK_DELAY, pxCurrentTCB, xTicksToDelay); \\r
+       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
+\r
+/* Called on vTaskDelayUntil - note the use of FreeRTOS variable xTimeToWake */\r
+#undef traceTASK_DELAY_UNTIL\r
+#define traceTASK_DELAY_UNTIL() \\r
+       trcKERNEL_HOOKS_TASK_DELAY(TASK_DELAY_UNTIL, pxCurrentTCB, xTimeToWake); \\r
+       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
+\r
+#if (INCLUDE_OBJECT_DELETE == 1)\r
+/* Called on vTaskDelete */\r
+#undef traceTASK_DELETE\r
+#define traceTASK_DELETE( pxTaskToDelete ) \\r
+       { TRACE_SR_ALLOC_CRITICAL_SECTION(); \\r
+       TRACE_ENTER_CRITICAL_SECTION(); \\r
+       trcKERNEL_HOOKS_TASK_DELETE(DELETE_OBJ, pxTaskToDelete); \\r
+       TRACE_EXIT_CRITICAL_SECTION(); }\r
+#endif\r
+\r
+#if (INCLUDE_OBJECT_DELETE == 1)\r
+/* Called on vQueueDelete */\r
+#undef traceQUEUE_DELETE\r
+#define traceQUEUE_DELETE( pxQueue ) \\r
+       { TRACE_SR_ALLOC_CRITICAL_SECTION(); \\r
+       TRACE_ENTER_CRITICAL_SECTION(); \\r
+       trcKERNEL_HOOKS_OBJECT_DELETE(DELETE_OBJ, UNUSED, pxQueue); \\r
+       TRACE_EXIT_CRITICAL_SECTION(); }\r
+#endif\r
+\r
+/* Called on vTaskCreate */\r
+#undef traceTASK_CREATE\r
+#define traceTASK_CREATE(pxNewTCB) \\r
+       if (pxNewTCB != NULL) \\r
+       { \\r
+               trcKERNEL_HOOKS_TASK_CREATE(CREATE_OBJ, UNUSED, pxNewTCB); \\r
+       }\r
+\r
+/* Called in vTaskCreate, if it fails (typically if the stack can not be allocated) */\r
+#undef traceTASK_CREATE_FAILED\r
+#define traceTASK_CREATE_FAILED() \\r
+       trcKERNEL_HOOKS_TASK_CREATE_FAILED(CREATE_OBJ, UNUSED);\r
+\r
+/* Called in xQueueCreate, and thereby for all other object based on queues, such as semaphores. */\r
+#undef traceQUEUE_CREATE\r
+#define traceQUEUE_CREATE( pxNewQueue )\\r
+       trcKERNEL_HOOKS_OBJECT_CREATE(CREATE_OBJ, UNUSED, pxNewQueue);\r
+\r
+/* Called in xQueueCreate, if the queue creation fails */\r
+#undef traceQUEUE_CREATE_FAILED\r
+#define traceQUEUE_CREATE_FAILED( queueType ) \\r
+       trcKERNEL_HOOKS_OBJECT_CREATE_FAILED(CREATE_OBJ, UNUSED, queueType);\r
+\r
+/* Called in xQueueCreateMutex, and thereby also from xSemaphoreCreateMutex and xSemaphoreCreateRecursiveMutex */\r
+#undef traceCREATE_MUTEX\r
+#define traceCREATE_MUTEX( pxNewQueue ) \\r
+       trcKERNEL_HOOKS_OBJECT_CREATE(CREATE_OBJ, UNUSED, pxNewQueue);\r
+\r
+/* Called in xQueueCreateMutex when the operation fails (when memory allocation fails) */\r
+#undef traceCREATE_MUTEX_FAILED\r
+#define traceCREATE_MUTEX_FAILED() \\r
+       trcKERNEL_HOOKS_OBJECT_CREATE_FAILED(CREATE_OBJ, UNUSED, queueQUEUE_TYPE_MUTEX);\r
+\r
+/* Called when the Mutex can not be given, since not holder */\r
+#undef traceGIVE_MUTEX_RECURSIVE_FAILED\r
+#define traceGIVE_MUTEX_RECURSIVE_FAILED( pxMutex ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, FAILED, UNUSED, pxMutex);\r
+\r
+/* Called when a message is sent to a queue */ /* CS IS NEW ! */\r
+#undef traceQUEUE_SEND\r
+#define traceQUEUE_SEND( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, SUCCESS, UNUSED, pxQueue); \\r
+       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, pxQueue) == TRACE_CLASS_MUTEX ? (uint8_t)0 : (uint8_t)(pxQueue->uxMessagesWaiting + 1));\r
+\r
+/* Called when a message failed to be sent to a queue (timeout) */\r
+#undef traceQUEUE_SEND_FAILED\r
+#define traceQUEUE_SEND_FAILED( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, FAILED, UNUSED, pxQueue);\r
+\r
+/* Called when the task is blocked due to a send operation on a full queue */\r
+#undef traceBLOCKING_ON_QUEUE_SEND\r
+#define traceBLOCKING_ON_QUEUE_SEND( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, BLOCK, UNUSED, pxQueue);\r
+\r
+/* Called when a message is received from a queue */\r
+#undef traceQUEUE_RECEIVE\r
+#define traceQUEUE_RECEIVE( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE, SUCCESS, UNUSED, pxQueue); \\r
+       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, pxQueue) == TRACE_CLASS_MUTEX ? TRACE_GET_TASK_NUMBER(TRACE_GET_CURRENT_TASK()) : (uint8_t)(pxQueue->uxMessagesWaiting - 1));\r
+\r
+/* Called when a receive operation on a queue fails (timeout) */\r
+#undef traceQUEUE_RECEIVE_FAILED\r
+#define traceQUEUE_RECEIVE_FAILED( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE, FAILED, UNUSED, pxQueue);\r
+\r
+/* Called when the task is blocked due to a receive operation on an empty queue */\r
+#undef traceBLOCKING_ON_QUEUE_RECEIVE\r
+#define traceBLOCKING_ON_QUEUE_RECEIVE( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE, BLOCK, UNUSED, pxQueue); \\r
+       if (TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, pxQueue) != TRACE_CLASS_MUTEX) \\r
+       {trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();}\r
+\r
+/* Called on xQueuePeek */\r
+#undef traceQUEUE_PEEK\r
+#define traceQUEUE_PEEK( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(PEEK, SUCCESS, UNUSED, pxQueue);\r
+\r
+/* Called when a message is sent from interrupt context, e.g., using xQueueSendFromISR */\r
+#undef traceQUEUE_SEND_FROM_ISR\r
+#define traceQUEUE_SEND_FROM_ISR( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND_FROM_ISR, SUCCESS, UNUSED, pxQueue); \\r
+       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, (uint8_t)(pxQueue->uxMessagesWaiting + 1));\r
+\r
+/* Called when a message send from interrupt context fails (since the queue was full) */\r
+#undef traceQUEUE_SEND_FROM_ISR_FAILED\r
+#define traceQUEUE_SEND_FROM_ISR_FAILED( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND_FROM_ISR, FAILED, UNUSED, pxQueue);\r
+\r
+/* Called when a message is received in interrupt context, e.g., using xQueueReceiveFromISR */\r
+#undef traceQUEUE_RECEIVE_FROM_ISR\r
+#define traceQUEUE_RECEIVE_FROM_ISR( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE_FROM_ISR, SUCCESS, UNUSED, pxQueue); \\r
+       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, (uint8_t)(pxQueue->uxMessagesWaiting - 1));\r
+\r
+/* Called when a message receive from interrupt context fails (since the queue was empty) */\r
+#undef traceQUEUE_RECEIVE_FROM_ISR_FAILED\r
+#define traceQUEUE_RECEIVE_FROM_ISR_FAILED( pxQueue ) \\r
+       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE_FROM_ISR, FAILED, UNUSED, pxQueue);\r
+\r
+/* Called in vTaskPrioritySet */\r
+#undef traceTASK_PRIORITY_SET\r
+#define traceTASK_PRIORITY_SET( pxTask, uxNewPriority ) \\r
+       trcKERNEL_HOOKS_TASK_PRIORITY_CHANGE(TASK_PRIORITY_SET, pxTask, uxNewPriority);\r
+\r
+/* Called in vTaskPriorityInherit, which is called by Mutex operations */\r
+#undef traceTASK_PRIORITY_INHERIT\r
+#define traceTASK_PRIORITY_INHERIT( pxTask, uxNewPriority ) \\r
+       trcKERNEL_HOOKS_TASK_PRIORITY_CHANGE(TASK_PRIORITY_INHERIT, pxTask, uxNewPriority);\r
+\r
+/* Called in vTaskPriorityDisinherit, which is called by Mutex operations */\r
+#undef traceTASK_PRIORITY_DISINHERIT\r
+#define traceTASK_PRIORITY_DISINHERIT( pxTask, uxNewPriority ) \\r
+       trcKERNEL_HOOKS_TASK_PRIORITY_CHANGE(TASK_PRIORITY_DISINHERIT, pxTask, uxNewPriority);\r
+\r
+/* Called in vTaskResume */\r
+#undef traceTASK_RESUME\r
+#define traceTASK_RESUME( pxTaskToResume ) \\r
+       trcKERNEL_HOOKS_TASK_RESUME(TASK_RESUME, pxTaskToResume);\r
+\r
+/* Called in vTaskResumeFromISR */\r
+#undef traceTASK_RESUME_FROM_ISR\r
+#define traceTASK_RESUME_FROM_ISR( pxTaskToResume ) \\r
+       trcKERNEL_HOOKS_TASK_RESUME(TASK_RESUME_FROM_ISR, pxTaskToResume);\r
+\r
+\r
+#if (FREERTOS_VERSION >= FREERTOS_VERSION_8_0_OR_LATER)\r
+\r
+#if (INCLUDE_MEMMANG_EVENTS == 1)\r
+\r
+extern void vTraceStoreMemMangEvent(uint32_t ecode, uint32_t address, int32_t size);\r
+\r
+#undef traceMALLOC\r
+#define traceMALLOC( pvAddress, uiSize ) {if (pvAddress != 0) vTraceStoreMemMangEvent(MEM_MALLOC_SIZE, ( uint32_t ) pvAddress, (int32_t)uiSize); }\r
+\r
+#undef traceFREE\r
+#define traceFREE( pvAddress, uiSize ) {vTraceStoreMemMangEvent(MEM_FREE_SIZE, ( uint32_t ) pvAddress, (int32_t)(-uiSize)); }\r
+\r
+#endif\r
+\r
+/* Called in timer.c - xTimerCreate */\r
+#undef traceTIMER_CREATE\r
+#define traceTIMER_CREATE(tmr) \\r
+       trcKERNEL_HOOKS_TIMER_CREATE(TIMER_CREATE, tmr);\r
+\r
+#undef traceTIMER_CREATE_FAILED\r
+#define traceTIMER_CREATE_FAILED() \\r
+       trcKERNEL_HOOKS_TIMER_EVENT(TIMER_CREATE_FAILED, 0);\r
+\r
+/* Note that xCommandID can never be tmrCOMMAND_EXECUTE_CALLBACK (-1) since the trace macro is not called in that case */\r
+#undef traceTIMER_COMMAND_SEND\r
+#define traceTIMER_COMMAND_SEND(tmr, xCommandID, xOptionalValue, xReturn) \\r
+if (xCommandID > tmrCOMMAND_START_DONT_TRACE){\\r
+               if (xCommandID == tmrCOMMAND_CHANGE_PERIOD) vTraceStoreKernelCallWithParam((xReturn == pdPASS) ? TIMER_CHANGE_PERIOD : TIMER_CHANGE_PERIOD_FAILED, TRACE_CLASS_TIMER, TRACE_GET_TIMER_NUMBER(tmr), xOptionalValue);\\r
+               else if ((xCommandID == tmrCOMMAND_DELETE) && (xReturn == pdPASS)){ trcKERNEL_HOOKS_TIMER_DELETE(TIMER_DELETE, tmr); } \\r
+               else {trcKERNEL_HOOKS_TIMER_EVENT(EVENTGROUP_TIMER + xCommandID + ((xReturn == pdPASS)?0:(TIMER_CREATE_FAILED - TIMER_CREATE)), tmr); }\\r
+}\r
+\r
+#undef tracePEND_FUNC_CALL\r
+#define tracePEND_FUNC_CALL(func, arg1, arg2, ret) \\r
+if (ret == pdPASS) \\r
+       vTraceStoreKernelCall(PEND_FUNC_CALL, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTimerGetTimerDaemonTaskHandle()) ); \\r
+else \\r
+       vTraceStoreKernelCall(PEND_FUNC_CALL_FAILED, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTimerGetTimerDaemonTaskHandle()) );\r
+\r
+#undef tracePEND_FUNC_CALL_FROM_ISR\r
+#define tracePEND_FUNC_CALL_FROM_ISR(func, arg1, arg2, ret) \\r
+       if (! uiInEventGroupSetBitsFromISR) vTraceStoreKernelCall(PEND_FUNC_CALL_FROM_ISR, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTimerGetTimerDaemonTaskHandle()) ); \\r
+       uiInEventGroupSetBitsFromISR = 0;\r
+#endif\r
+\r
+#undef traceEVENT_GROUP_CREATE\r
+#define traceEVENT_GROUP_CREATE(eg) \\r
+       TRACE_SET_EVENTGROUP_NUMBER(eg); \\r
+       vTraceStoreKernelCall(EVENT_GROUP_CREATE, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg));\r
+\r
+#undef traceEVENT_GROUP_DELETE\r
+#define traceEVENT_GROUP_DELETE(eg) \\r
+       vTraceStoreKernelCall(EVENT_GROUP_DELETE, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg)); \\r
+       vTraceStoreObjectNameOnCloseEvent(TRACE_GET_EVENTGROUP_NUMBER(eg), TRACE_CLASS_EVENTGROUP); \\r
+       vTraceStoreObjectPropertiesOnCloseEvent(TRACE_GET_EVENTGROUP_NUMBER(eg), TRACE_CLASS_EVENTGROUP); \\r
+       vTraceFreeObjectHandle(TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg));\r
+\r
+#undef traceEVENT_GROUP_CREATE_FAILED\r
+#define traceEVENT_GROUP_CREATE_FAILED() \\r
+       vTraceStoreKernelCall(EVENT_GROUP_CREATE_FAILED, TRACE_CLASS_EVENTGROUP, 0);\r
+\r
+#undef traceEVENT_GROUP_SYNC_BLOCK\r
+#define traceEVENT_GROUP_SYNC_BLOCK(eg, bitsToSet, bitsToWaitFor) \\r
+       vTraceStoreKernelCallWithParam(EVENT_GROUP_SYNC_BLOCK, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor);\r
+\r
+#undef traceEVENT_GROUP_SYNC_END\r
+#define traceEVENT_GROUP_SYNC_END(eg, bitsToSet, bitsToWaitFor, wasTimeout) \\r
+       if (wasTimeout){ vTraceStoreKernelCallWithParam(EVENT_GROUP_SYNC_END_FAILED, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor);} \\r
+       else{ vTraceStoreKernelCallWithParam(EVENT_GROUP_SYNC_END, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); }\r
+\r
+#undef traceEVENT_GROUP_WAIT_BITS_BLOCK\r
+#define traceEVENT_GROUP_WAIT_BITS_BLOCK(eg, bitsToWaitFor) \\r
+       vTraceStoreKernelCallWithParam(EVENT_GROUP_WAIT_BITS_BLOCK, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); \\r
+       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
+\r
+#undef traceEVENT_GROUP_WAIT_BITS_END\r
+#define traceEVENT_GROUP_WAIT_BITS_END(eg, bitsToWaitFor, wasTimeout) \\r
+       if (wasTimeout){ vTraceStoreKernelCallWithParam(EVENT_GROUP_WAIT_BITS_END_FAILED, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); } \\r
+       else{ vTraceStoreKernelCallWithParam(EVENT_GROUP_WAIT_BITS_END, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); }\r
+\r
+#undef traceEVENT_GROUP_CLEAR_BITS\r
+#define traceEVENT_GROUP_CLEAR_BITS(eg, bitsToClear) \\r
+       if (bitsToClear) vTraceStoreKernelCallWithParam(EVENT_GROUP_CLEAR_BITS, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToClear);\r
+\r
+#undef traceEVENT_GROUP_CLEAR_BITS_FROM_ISR\r
+#define traceEVENT_GROUP_CLEAR_BITS_FROM_ISR(eg, bitsToClear) \\r
+       if (bitsToClear) vTraceStoreKernelCallWithParam(EVENT_GROUP_CLEAR_BITS_FROM_ISR, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToClear);\r
+\r
+#undef traceEVENT_GROUP_SET_BITS\r
+#define traceEVENT_GROUP_SET_BITS(eg, bitsToSet) \\r
+       vTraceStoreKernelCallWithParam(EVENT_GROUP_SET_BITS, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToSet);\r
+\r
+#undef traceEVENT_GROUP_SET_BITS_FROM_ISR\r
+#define traceEVENT_GROUP_SET_BITS_FROM_ISR(eg, bitsToSet) \\r
+       vTraceStoreKernelCallWithParam(EVENT_GROUP_SET_BITS_FROM_ISR, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToSet); \\r
+       uiInEventGroupSetBitsFromISR = 1;\r
+\r
+#undef traceTASK_NOTIFY_TAKE\r
+#define traceTASK_NOTIFY_TAKE() \\r
+       if (pxCurrentTCB->eNotifyState == eNotified) \\r
+               vTraceStoreKernelCallWithParam(TRACE_TASK_NOTIFY_TAKE, TRACE_CLASS_TASK, uxTaskGetTaskNumber(pxCurrentTCB), xTicksToWait); \\r
+       else \\r
+               vTraceStoreKernelCallWithParam(TRACE_TASK_NOTIFY_TAKE_FAILED, TRACE_CLASS_TASK, uxTaskGetTaskNumber(pxCurrentTCB), xTicksToWait);\r
+\r
+#undef traceTASK_NOTIFY_TAKE_BLOCK\r
+#define traceTASK_NOTIFY_TAKE_BLOCK() \\r
+       vTraceStoreKernelCallWithParam(TRACE_TASK_NOTIFY_TAKE_BLOCK, TRACE_CLASS_TASK, uxTaskGetTaskNumber(pxCurrentTCB), xTicksToWait); \\r
+       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
+\r
+#undef traceTASK_NOTIFY_WAIT\r
+#define traceTASK_NOTIFY_WAIT() \\r
+       if (pxCurrentTCB->eNotifyState == eNotified) \\r
+               vTraceStoreKernelCallWithParam(TRACE_TASK_NOTIFY_WAIT, TRACE_CLASS_TASK, uxTaskGetTaskNumber(pxCurrentTCB), xTicksToWait); \\r
+       else \\r
+               vTraceStoreKernelCallWithParam(TRACE_TASK_NOTIFY_WAIT_FAILED, TRACE_CLASS_TASK, uxTaskGetTaskNumber(pxCurrentTCB), xTicksToWait);\r
+\r
+#undef traceTASK_NOTIFY_WAIT_BLOCK\r
+#define traceTASK_NOTIFY_WAIT_BLOCK() \\r
+       vTraceStoreKernelCallWithParam(TRACE_TASK_NOTIFY_WAIT_BLOCK, TRACE_CLASS_TASK, uxTaskGetTaskNumber(pxCurrentTCB), xTicksToWait); \\r
+       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
+\r
+#undef traceTASK_NOTIFY\r
+#define traceTASK_NOTIFY() \\r
+       vTraceStoreKernelCall(TRACE_TASK_NOTIFY, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTaskToNotify));\r
+\r
+#undef traceTASK_NOTIFY_FROM_ISR\r
+#define traceTASK_NOTIFY_FROM_ISR() \\r
+       vTraceStoreKernelCall(TRACE_TASK_NOTIFY_FROM_ISR, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTaskToNotify));\r
+       \r
+#undef traceTASK_NOTIFY_GIVE_FROM_ISR\r
+#define traceTASK_NOTIFY_GIVE_FROM_ISR() \\r
+       vTraceStoreKernelCall(TRACE_TASK_NOTIFY_GIVE_FROM_ISR, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTaskToNotify));\r
+\r
+/************************************************************************/\r
+/* KERNEL SPECIFIC MACROS TO EXCLUDE OR INCLUDE THINGS IN TRACE                        */\r
+/************************************************************************/\r
+\r
+/* Returns the exclude state of the object */\r
+uint8_t uiTraceIsObjectExcluded(traceObjectClass objectclass, objectHandleType handle);\r
+\r
+#define TRACE_SET_QUEUE_FLAG_ISEXCLUDED(queueIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, queueIndex)\r
+#define TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(queueIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, queueIndex)\r
+#define TRACE_GET_QUEUE_FLAG_ISEXCLUDED(queueIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, queueIndex)\r
+\r
+#define TRACE_SET_SEMAPHORE_FLAG_ISEXCLUDED(semaphoreIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+semaphoreIndex)\r
+#define TRACE_CLEAR_SEMAPHORE_FLAG_ISEXCLUDED(semaphoreIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+semaphoreIndex)\r
+#define TRACE_GET_SEMAPHORE_FLAG_ISEXCLUDED(semaphoreIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+semaphoreIndex)\r
+\r
+#define TRACE_SET_MUTEX_FLAG_ISEXCLUDED(mutexIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+mutexIndex)\r
+#define TRACE_CLEAR_MUTEX_FLAG_ISEXCLUDED(mutexIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+mutexIndex)\r
+#define TRACE_GET_MUTEX_FLAG_ISEXCLUDED(mutexIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+mutexIndex)\r
+\r
+#define TRACE_SET_TASK_FLAG_ISEXCLUDED(taskIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+taskIndex)\r
+#define TRACE_CLEAR_TASK_FLAG_ISEXCLUDED(taskIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+taskIndex)\r
+#define TRACE_GET_TASK_FLAG_ISEXCLUDED(taskIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+taskIndex)\r
+\r
+#define TRACE_SET_TIMER_FLAG_ISEXCLUDED(timerIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+timerIndex)\r
+#define TRACE_CLEAR_TIMER_FLAG_ISEXCLUDED(timerIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+timerIndex)\r
+#define TRACE_GET_TIMER_FLAG_ISEXCLUDED(timerIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+timerIndex)\r
+\r
+#define TRACE_SET_EVENTGROUP_FLAG_ISEXCLUDED(egIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+NTimer+1+egIndex)\r
+#define TRACE_CLEAR_EVENTGROUP_FLAG_ISEXCLUDED(egIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+NTimer+1+egIndex)\r
+#define TRACE_GET_EVENTGROUP_FLAG_ISEXCLUDED(egIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+NTimer+1+egIndex)\r
+\r
+\r
+#define TRACE_CLEAR_OBJECT_FLAG_ISEXCLUDED(objectclass, handle) \\r
+switch (objectclass) \\r
+{ \\r
+case TRACE_CLASS_QUEUE: \\r
+       TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_SEMAPHORE: \\r
+       TRACE_CLEAR_SEMAPHORE_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_MUTEX: \\r
+       TRACE_CLEAR_MUTEX_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_TASK: \\r
+       TRACE_CLEAR_TASK_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_TIMER: \\r
+       TRACE_CLEAR_TIMER_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_EVENTGROUP: \\r
+       TRACE_CLEAR_EVENTGROUP_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+}\r
+\r
+#define TRACE_SET_OBJECT_FLAG_ISEXCLUDED(objectclass, handle) \\r
+switch (objectclass) \\r
+{ \\r
+case TRACE_CLASS_QUEUE: \\r
+       TRACE_SET_QUEUE_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_SEMAPHORE: \\r
+       TRACE_SET_SEMAPHORE_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_MUTEX: \\r
+       TRACE_SET_MUTEX_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_TASK: \\r
+       TRACE_SET_TASK_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_TIMER: \\r
+       TRACE_SET_TIMER_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+case TRACE_CLASS_EVENTGROUP: \\r
+       TRACE_SET_EVENTGROUP_FLAG_ISEXCLUDED(handle); \\r
+       break; \\r
+}\r
+\r
+/* Task */\r
+#define vTraceExcludeTaskFromTrace(handle) \\r
+TRACE_SET_TASK_FLAG_ISEXCLUDED(TRACE_GET_TASK_NUMBER(handle));\r
+\r
+#define vTraceIncludeTaskInTrace(handle) \\r
+TRACE_CLEAR_TASK_FLAG_ISEXCLUDED(TRACE_GET_TASK_NUMBER(handle));\r
+\r
+\r
+/* Queue */\r
+#define vTraceExcludeQueueFromTrace(handle) \\r
+TRACE_SET_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
+\r
+#define vTraceIncludeQueueInTrace(handle) \\r
+TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
+\r
+\r
+/* Semaphore */\r
+#define vTraceExcludeSemaphoreFromTrace(handle) \\r
+TRACE_SET_SEMAPHORE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
+\r
+#define vTraceIncludeSemaphoreInTrace(handle) \\r
+TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
+\r
+\r
+/* Mutex */\r
+#define vTraceExcludeMutexFromTrace(handle) \\r
+TRACE_SET_MUTEX_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
+\r
+#define vTraceIncludeMutexInTrace(handle) \\r
+TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
+\r
+/* Timer */\r
+#define vTraceExcludeTimerFromTrace(handle) \\r
+TRACE_SET_TIMER_FLAG_ISEXCLUDED(TRACE_GET_TIMER_NUMBER(handle));\r
+\r
+#define vTraceIncludeTimerInTrace(handle) \\r
+TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_TIMER_NUMBER(handle));\r
+\r
+/* Event Group */\r
+#define vTraceExcludeEventGroupFromTrace(handle) \\r
+TRACE_SET_EVENTGROUP_FLAG_ISEXCLUDED(TRACE_GET_EVENTGROUP_NUMBER(handle));\r
+\r
+#define vTraceIncludeEventGroupInTrace(handle) \\r
+TRACE_CLEAR_EVENTGROUP_FLAG_ISEXCLUDED(TRACE_GET_EVENTGROUP_NUMBER(handle));\r
+\r
+\r
+/* Kernel Services */\r
+#define vTraceExcludeKernelServiceDelayFromTrace() \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY_UNTIL);\r
+\r
+#define vTraceIncludeKernelServiceDelayInTrace() \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY_UNTIL);\r
+\r
+/* HELPER MACROS FOR KERNEL SERVICES FOR OBJECTS */\r
+#define vTraceExcludeKernelServiceSendFromTrace_HELPER(class) \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_SUCCESS + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_BLOCK + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FAILED + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_SUCCESS + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_FAILED + class);\r
+\r
+#define vTraceIncludeKernelServiceSendInTrace_HELPER(class) \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_SUCCESS + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_BLOCK + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FAILED + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_SUCCESS + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_FAILED + class);\r
+\r
+#define vTraceExcludeKernelServiceReceiveFromTrace_HELPER(class) \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_SUCCESS + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_BLOCK + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FAILED + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS + class); \\r
+TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_FAILED + class);\r
+\r
+#define vTraceIncludeKernelServiceReceiveInTrace_HELPER(class) \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_SUCCESS + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_BLOCK + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FAILED + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS + class); \\r
+TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_FAILED + class);\r
+\r
+/* EXCLUDE AND INCLUDE FOR QUEUE */\r
+#define vTraceExcludeKernelServiceQueueSendFromTrace() \\r
+vTraceExcludeKernelServiceSendFromTrace_HELPER(TRACE_CLASS_QUEUE);\r
+\r
+#define vTraceIncludeKernelServiceQueueSendInTrace() \\r
+vTraceIncludeKernelServiceSendInTrace_HELPER(TRACE_CLASS_QUEUE);\r
+\r
+#define vTraceExcludeKernelServiceQueueReceiveFromTrace() \\r
+vTraceExcludeKernelServiceReceiveFromTrace_HELPER(TRACE_CLASS_QUEUE);\r
+\r
+#define vTraceIncludeKernelServiceQueueReceiveInTrace() \\r
+vTraceIncludeKernelServiceReceiveInTrace_HELPER(TRACE_CLASS_QUEUE);\r
+\r
+/* EXCLUDE AND INCLUDE FOR SEMAPHORE */\r
+#define vTraceExcludeKernelServiceSemaphoreSendFromTrace() \\r
+vTraceExcludeKernelServiceSendFromTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
+\r
+#define vTraceIncludeKernelServicSemaphoreSendInTrace() \\r
+vTraceIncludeKernelServiceSendInTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
+\r
+#define vTraceExcludeKernelServiceSemaphoreReceiveFromTrace() \\r
+vTraceExcludeKernelServiceReceiveFromTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
+\r
+#define vTraceIncludeKernelServiceSemaphoreReceiveInTrace() \\r
+vTraceIncludeKernelServiceReceiveInTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
+\r
+/* EXCLUDE AND INCLUDE FOR MUTEX */\r
+#define vTraceExcludeKernelServiceMutexSendFromTrace() \\r
+vTraceExcludeKernelServiceSendFromTrace_HELPER(TRACE_CLASS_MUTEX);\r
+\r
+#define vTraceIncludeKernelServiceMutexSendInTrace() \\r
+vTraceIncludeKernelServiceSendInTrace_HELPER(TRACE_CLASS_MUTEX);\r
+\r
+#define vTraceExcludeKernelServiceMutexReceiveFromTrace() \\r
+vTraceExcludeKernelServiceReceiveFromTrace_HELPER(TRACE_CLASS_MUTEX);\r
+\r
+#define vTraceIncludeKernelServiceMutexReceiveInTrace() \\r
+vTraceIncludeKernelServiceReceiveInTrace_HELPER(TRACE_CLASS_MUTEX);\r
+\r
+/************************************************************************/\r
+/* KERNEL SPECIFIC MACROS TO NAME OBJECTS, IF NECESSARY                                 */\r
+/************************************************************************/\r
+#define vTraceSetQueueName(object, name) \\r
+vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
+\r
+#define vTraceSetSemaphoreName(object, name) \\r
+vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
+\r
+#define vTraceSetMutexName(object, name) \\r
+vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
+\r
+#define vTraceSetEventGroupName(object, name) \\r
+vTraceSetObjectName(TRACE_CLASS_EVENTGROUP, (objectHandleType)uxEventGroupGetNumber(object), name);\r
+\r
+#undef traceQUEUE_REGISTRY_ADD\r
+#define traceQUEUE_REGISTRY_ADD(object, name) vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
+#endif\r
+\r
+#endif /* TRCKERNELPORTFREERTOS_H_ */\r
+\r
+\r
+\r
+\r
+\r
+\r
+\r
+\r
diff --git a/FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/Include/trcKernelPortFreeRTOS.h b/FreeRTOS-Plus/Source/FreeRTOS-Plus-Trace/Include/trcKernelPortFreeRTOS.h
deleted file mode 100644 (file)
index a3d8b2f..0000000
+++ /dev/null
@@ -1,1023 +0,0 @@
-/*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
- * Percepio AB, www.percepio.com\r
- *\r
- * trcKernelPortFreeRTOS.h\r
- *\r
- * Kernel-specific functionality for FreeRTOS, used by the recorder library.\r
- *\r
- * Terms of Use\r
- * This software is copyright Percepio AB. The recorder library is free for\r
- * use together with Percepio products. You may distribute the recorder library\r
- * in its original form, including modifications in trcHardwarePort.c/.h\r
- * given that these modification are clearly marked as your own modifications\r
- * and documented in the initial comment section of these source files.\r
- * This software is the intellectual property of Percepio AB and may not be\r
- * sold or in other ways commercially redistributed without explicit written\r
- * permission by Percepio AB.\r
- *\r
- * Disclaimer\r
- * The trace tool and recorder library is being delivered to you AS IS and\r
- * Percepio AB makes no warranty as to its use or performance. Percepio AB does\r
- * not and cannot warrant the performance or results you may obtain by using the\r
- * software or documentation. Percepio AB make no warranties, express or\r
- * implied, as to noninfringement of third party rights, merchantability, or\r
- * fitness for any particular purpose. In no event will Percepio AB, its\r
- * technology partners, or distributors be liable to you for any consequential,\r
- * incidental or special damages, including any lost profits or lost savings,\r
- * even if a representative of Percepio AB has been advised of the possibility\r
- * of such damages, or for any claim by any third party. Some jurisdictions do\r
- * not allow the exclusion or limitation of incidental, consequential or special\r
- * damages, or the exclusion of implied warranties or limitations on how long an\r
- * implied warranty may last, so the above limitations may not apply to you.\r
- *\r
- * Tabs are used for indent in this file (1 tab = 4 spaces)\r
- *\r
- * Copyright Percepio AB, 2014.\r
- * www.percepio.com\r
- ******************************************************************************/\r
-\r
-\r
-#ifndef TRCKERNELPORTFREERTOS_H\r
-#define TRCKERNELPORTFREERTOS_H\r
-\r
-#include "FreeRTOS.h"  /* Defines configUSE_TRACE_FACILITY */\r
-#include "trcHardwarePort.h"\r
-\r
-extern int uiInEventGroupSetBitsFromISR;\r
-\r
-#define USE_TRACEALYZER_RECORDER configUSE_TRACE_FACILITY\r
-\r
-#if (USE_TRACEALYZER_RECORDER == 1)\r
-\r
-/* Defines that must be set for the recorder to work properly */\r
-#define TRACE_KERNEL_VERSION 0x1AA1\r
-#define TRACE_TICK_RATE_HZ configTICK_RATE_HZ /* Defined in "FreeRTOS.h" */\r
-#define TRACE_CPU_CLOCK_HZ configCPU_CLOCK_HZ /* Defined in "FreeRTOSConfig.h" */\r
-\r
-#if (SELECTED_PORT == PORT_ARM_CortexM)\r
-       \r
-       #include "board.h" // Uses CMSIS API\r
-       \r
-       #define TRACE_SR_ALLOC_CRITICAL_SECTION() int __irq_status;\r
-       #define TRACE_ENTER_CRITICAL_SECTION() {__irq_status = __get_PRIMASK(); __set_PRIMASK(1);}\r
-       #define TRACE_EXIT_CRITICAL_SECTION() {__set_PRIMASK(__irq_status);}\r
-       \r
-#endif \r
-\r
-#if ((SELECTED_PORT == PORT_ARM_CORTEX_A9) || (SELECTED_PORT == PORT_Renesas_RX600) || (SELECTED_PORT == PORT_MICROCHIP_PIC32MX) || (SELECTED_PORT == PORT_MICROCHIP_PIC32MZ))\r
-       #define TRACE_SR_ALLOC_CRITICAL_SECTION() int __irq_status;\r
-       #define TRACE_ENTER_CRITICAL_SECTION() {__irq_status = portSET_INTERRUPT_MASK_FROM_ISR();}\r
-       #define TRACE_EXIT_CRITICAL_SECTION() {portCLEAR_INTERRUPT_MASK_FROM_ISR(__irq_status);}\r
-#endif\r
-\r
-#ifndef TRACE_ENTER_CRITICAL_SECTION\r
-       #error "This port has no valid definition for critical sections! See http://percepio.com/2014/10/27/how-to-define-critical-sections-for-the-recorder/"\r
-#endif\r
-\r
-#ifndef TRACE_EXIT_CRITICAL_SECTION\r
-       #error "This port has no valid definition for critical sections! See http://percepio.com/2014/10/27/how-to-define-critical-sections-for-the-recorder/"\r
-#endif\r
-\r
-#if (SELECTED_PORT == PORT_ARM_CortexM)\r
-       #define trcCRITICAL_SECTION_BEGIN_ON_CORTEX_M_ONLY trcCRITICAL_SECTION_BEGIN\r
-       #define trcCRITICAL_SECTION_END_ON_CORTEX_M_ONLY trcCRITICAL_SECTION_END\r
-#else\r
-       #define trcCRITICAL_SECTION_BEGIN_ON_CORTEX_M_ONLY() recorder_busy++;\r
-       #define trcCRITICAL_SECTION_END_ON_CORTEX_M_ONLY() recorder_busy--;\r
-#endif\r
-\r
-/*************************************************************************/\r
-/* KERNEL SPECIFIC OBJECT CONFIGURATION                                                                         */\r
-/*************************************************************************/\r
-#define TRACE_NCLASSES 7\r
-#define TRACE_CLASS_QUEUE ((traceObjectClass)0)\r
-#define TRACE_CLASS_SEMAPHORE ((traceObjectClass)1)\r
-#define TRACE_CLASS_MUTEX ((traceObjectClass)2)\r
-#define TRACE_CLASS_TASK ((traceObjectClass)3)\r
-#define TRACE_CLASS_ISR ((traceObjectClass)4)\r
-#define TRACE_CLASS_TIMER ((traceObjectClass)5)\r
-#define TRACE_CLASS_EVENTGROUP ((traceObjectClass)6)\r
-\r
-#define TRACE_KERNEL_OBJECT_COUNT (NQueue + NSemaphore + NMutex + NTask + NISR + NTimer + NEventGroup)\r
-\r
-/* The size of the Object Property Table entries, in bytes, per object */\r
-\r
-/* Queue properties (except name):     current number of message in queue */\r
-#define PropertyTableSizeQueue         (NameLenQueue + 1)\r
-\r
-/* Semaphore properties (except name): state (signaled = 1, cleared = 0) */\r
-#define PropertyTableSizeSemaphore     (NameLenSemaphore + 1)\r
-\r
-/* Mutex properties (except name):     owner (task handle, 0 = free) */\r
-#define PropertyTableSizeMutex         (NameLenMutex + 1)\r
-\r
-/* Task properties (except name):      Byte 0: Current priority\r
-                                                                       Byte 1: state (if already active)\r
-                                                                       Byte 2: legacy, not used\r
-                                                                       Byte 3: legacy, not used */\r
-#define PropertyTableSizeTask          (NameLenTask + 4)\r
-\r
-/* ISR properties:                                     Byte 0: priority\r
-                                                                       Byte 1: state (if already active) */\r
-#define PropertyTableSizeISR           (NameLenISR + 2)\r
-\r
-/* NTimer properties:                          Byte 0: state (unused for now) */\r
-#define PropertyTableSizeTimer         (NameLenTimer + 1)\r
-\r
-/* NEventGroup properties:                     Byte 0-3: state (unused for now)*/\r
-#define PropertyTableSizeEventGroup    (NameLenEventGroup + 4)\r
-\r
-\r
-/* The layout of the byte array representing the Object Property Table */\r
-#define StartIndexQueue                        0\r
-#define StartIndexSemaphore            StartIndexQueue         + NQueue                * PropertyTableSizeQueue\r
-#define StartIndexMutex                        StartIndexSemaphore + NSemaphore        * PropertyTableSizeSemaphore\r
-#define StartIndexTask                 StartIndexMutex         + NMutex                * PropertyTableSizeMutex\r
-#define StartIndexISR                  StartIndexTask          + NTask                 * PropertyTableSizeTask\r
-#define StartIndexTimer                        StartIndexISR           + NISR                  * PropertyTableSizeISR\r
-#define StartIndexEventGroup   StartIndexTimer         + NTimer                * PropertyTableSizeTimer\r
-\r
-/* Number of bytes used by the object table */\r
-#define TRACE_OBJECT_TABLE_SIZE        StartIndexEventGroup + NEventGroup * PropertyTableSizeEventGroup\r
-\r
-#define FREERTOS_VERSION_NOT_SET                       0\r
-#define FREERTOS_VERSION_7_3_OR_7_4                    1\r
-#define FREERTOS_VERSION_7_5_OR_7_6                    2\r
-#define FREERTOS_VERSION_8_0_OR_LATER          3\r
-\r
-/* Includes */\r
-#include "trcConfig.h" /* Must be first, even before trcTypes.h */\r
-#include "trcHardwarePort.h"\r
-#include "trcTypes.h"\r
-#include "trcKernelHooks.h"\r
-#include "trcBase.h"\r
-#include "trcKernel.h"\r
-#include "trcUser.h"\r
-\r
-#if (INCLUDE_NEW_TIME_EVENTS == 1 && configUSE_TICKLESS_IDLE != 0)\r
-#error "NewTime events can not be used in combination with tickless idle!"\r
-#endif\r
-\r
-/* Initialization of the object property table */\r
-void vTraceInitObjectPropertyTable(void);\r
-\r
-/* Initialization of the handle mechanism, see e.g, xTraceGetObjectHandle */\r
-void vTraceInitObjectHandleStack(void);\r
-\r
-/* Returns the "Not enough handles" error message for the specified object class */\r
-const char* pszTraceGetErrorNotEnoughHandles(traceObjectClass objectclass);\r
-\r
-/*******************************************************************************\r
- * The event codes - should match the offline config file.\r
- *\r
- * Some sections below are encoded to allow for constructions like:\r
- *\r
- * vTraceStoreKernelCall(EVENTGROUP_CREATE + objectclass, ...\r
- *\r
- * The object class ID is given by the three LSB bits, in such cases. Since each\r
- * object class has a separate object property table, the class ID is needed to\r
- * know what section in the object table to use for getting an object name from\r
- * an object handle.\r
- ******************************************************************************/\r
-\r
-#define NULL_EVENT                                     (0x00) /* Ignored in the analysis*/\r
-\r
-/*******************************************************************************\r
- * EVENTGROUP_DIV\r
- *\r
- * Miscellaneous events.\r
- ******************************************************************************/\r
-#define EVENTGROUP_DIV                         (NULL_EVENT + 1)                                        /*0x01*/\r
-#define DIV_XPS                                                (EVENTGROUP_DIV + 0)                            /*0x01*/\r
-#define DIV_TASK_READY                         (EVENTGROUP_DIV + 1)                            /*0x02*/\r
-#define DIV_NEW_TIME                           (EVENTGROUP_DIV + 2)                            /*0x03*/\r
-\r
-/*******************************************************************************\r
- * EVENTGROUP_TS\r
- *\r
- * Events for storing task-switches and interrupts. The RESUME events are\r
- * generated if the task/interrupt is already marked active.\r
- ******************************************************************************/\r
-#define EVENTGROUP_TS                          (EVENTGROUP_DIV + 3)                            /*0x04*/\r
-#define TS_ISR_BEGIN                           (EVENTGROUP_TS + 0)                                     /*0x04*/\r
-#define TS_ISR_RESUME                          (EVENTGROUP_TS + 1)                                     /*0x05*/\r
-#define TS_TASK_BEGIN                          (EVENTGROUP_TS + 2)                                     /*0x06*/\r
-#define TS_TASK_RESUME                         (EVENTGROUP_TS + 3)                                     /*0x07*/\r
-\r
-/*******************************************************************************\r
- * EVENTGROUP_OBJCLOSE_NAME\r
- *\r
- * About Close Events\r
- * When an object is evicted from the object property table (object close), two\r
- * internal events are stored (EVENTGROUP_OBJCLOSE_NAME and\r
- * EVENTGROUP_OBJCLOSE_PROP), containing the handle-name mapping and object\r
- * properties valid up to this point.\r
- ******************************************************************************/\r
-#define EVENTGROUP_OBJCLOSE_NAME       (EVENTGROUP_TS + 4)                                     /*0x08*/\r
-\r
-/*******************************************************************************\r
- * EVENTGROUP_OBJCLOSE_PROP\r
- *\r
- * The internal event carrying properties of deleted objects\r
- * The handle and object class of the closed object is not stored in this event,\r
- * but is assumed to be the same as in the preceding CLOSE event. Thus, these\r
- * two events must be generated from within a critical section.\r
- * When queues are closed, arg1 is the "state" property (i.e., number of\r
- * buffered messages/signals).\r
- * When actors are closed, arg1 is priority, arg2 is handle of the "instance\r
- * finish" event, and arg3 is event code of the "instance finish" event.\r
- * In this case, the lower three bits is the object class of the instance finish\r
- * handle. The lower three bits are not used (always zero) when queues are\r
- * closed since the queue type is given in the previous OBJCLOSE_NAME event.\r
- ******************************************************************************/\r
-#define EVENTGROUP_OBJCLOSE_PROP       (EVENTGROUP_OBJCLOSE_NAME + 8)          /*0x10*/\r
-\r
-/*******************************************************************************\r
- * EVENTGROUP_CREATE\r
- *\r
- * The events in this group are used to log Kernel object creations.\r
- * The lower three bits in the event code gives the object class, i.e., type of\r
- * create operation (task, queue, semaphore, etc).\r
- ******************************************************************************/\r
-#define EVENTGROUP_CREATE_OBJ_SUCCESS  (EVENTGROUP_OBJCLOSE_PROP + 8)  /*0x18*/\r
-\r
-/*******************************************************************************\r
- * EVENTGROUP_SEND\r
- *\r
- * The events in this group are used to log Send/Give events on queues,\r
- * semaphores and mutexes The lower three bits in the event code gives the\r
- * object class, i.e., what type of object that is operated on (queue, semaphore\r
- * or mutex).\r
- ******************************************************************************/\r
-#define EVENTGROUP_SEND_SUCCESS        (EVENTGROUP_CREATE_OBJ_SUCCESS + 8)             /*0x20*/\r
-\r
-/*******************************************************************************\r
- * EVENTGROUP_RECEIVE\r
- *\r
- * The events in this group are used to log Receive/Take events on queues,\r
- * semaphores and mutexes. The lower three bits in the event code gives the\r
- * object class, i.e., what type of object that is operated on (queue, semaphore\r
- * or mutex).\r
- ******************************************************************************/\r
-#define EVENTGROUP_RECEIVE_SUCCESS     (EVENTGROUP_SEND_SUCCESS + 8)           /*0x28*/\r
-\r
-/* Send/Give operations, from ISR */\r
-#define EVENTGROUP_SEND_FROM_ISR_SUCCESS \\r
-                                                                       (EVENTGROUP_RECEIVE_SUCCESS + 8)        /*0x30*/\r
-\r
-/* Receive/Take operations, from ISR */\r
-#define EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS \\r
-                                                       (EVENTGROUP_SEND_FROM_ISR_SUCCESS + 8)          /*0x38*/\r
-\r
-/* "Failed" event type versions of above (timeout, failed allocation, etc) */\r
-#define EVENTGROUP_KSE_FAILED \\r
-                                                       (EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS + 8)       /*0x40*/\r
-\r
-/* Failed create calls - memory allocation failed */\r
-#define EVENTGROUP_CREATE_OBJ_FAILED   (EVENTGROUP_KSE_FAILED)                 /*0x40*/\r
-\r
-/* Failed send/give - timeout! */\r
-#define EVENTGROUP_SEND_FAILED         (EVENTGROUP_CREATE_OBJ_FAILED + 8)      /*0x48*/\r
-\r
-/* Failed receive/take - timeout! */\r
-#define EVENTGROUP_RECEIVE_FAILED       (EVENTGROUP_SEND_FAILED + 8)           /*0x50*/\r
-\r
-/* Failed non-blocking send/give - queue full */\r
-#define EVENTGROUP_SEND_FROM_ISR_FAILED (EVENTGROUP_RECEIVE_FAILED + 8) /*0x58*/\r
-\r
-/* Failed non-blocking receive/take - queue empty */\r
-#define EVENTGROUP_RECEIVE_FROM_ISR_FAILED \\r
-                                                                (EVENTGROUP_SEND_FROM_ISR_FAILED + 8)  /*0x60*/\r
-\r
-/* Events when blocking on receive/take */\r
-#define EVENTGROUP_RECEIVE_BLOCK \\r
-                                                       (EVENTGROUP_RECEIVE_FROM_ISR_FAILED + 8)        /*0x68*/\r
-\r
-/* Events when blocking on send/give */\r
-#define EVENTGROUP_SEND_BLOCK  (EVENTGROUP_RECEIVE_BLOCK + 8)                  /*0x70*/\r
-\r
-/* Events on queue peek (receive) */\r
-#define EVENTGROUP_PEEK_SUCCESS        (EVENTGROUP_SEND_BLOCK + 8)                             /*0x78*/\r
-\r
-/* Events on object delete (vTaskDelete or vQueueDelete) */\r
-#define EVENTGROUP_DELETE_OBJ_SUCCESS  (EVENTGROUP_PEEK_SUCCESS + 8)   /*0x80*/\r
-\r
-/* Other events - object class is implied: TASK */\r
-#define EVENTGROUP_OTHERS      (EVENTGROUP_DELETE_OBJ_SUCCESS + 8)                     /*0x88*/\r
-#define TASK_DELAY_UNTIL       (EVENTGROUP_OTHERS + 0)                                         /*0x88*/\r
-#define TASK_DELAY                     (EVENTGROUP_OTHERS + 1)                                         /*0x89*/\r
-#define TASK_SUSPEND           (EVENTGROUP_OTHERS + 2)                                         /*0x8A*/\r
-#define TASK_RESUME                    (EVENTGROUP_OTHERS + 3)                                         /*0x8B*/\r
-#define TASK_RESUME_FROM_ISR   (EVENTGROUP_OTHERS + 4)                                 /*0x8C*/\r
-#define TASK_PRIORITY_SET              (EVENTGROUP_OTHERS + 5)                                 /*0x8D*/\r
-#define TASK_PRIORITY_INHERIT  (EVENTGROUP_OTHERS + 6)                                 /*0x8E*/\r
-#define TASK_PRIORITY_DISINHERIT       (EVENTGROUP_OTHERS + 7)                         /*0x8F*/\r
-\r
-#define EVENTGROUP_MISC_PLACEHOLDER    (EVENTGROUP_OTHERS + 8)                         /*0x90*/\r
-#define PEND_FUNC_CALL         (EVENTGROUP_MISC_PLACEHOLDER+0)                         /*0x90*/\r
-#define PEND_FUNC_CALL_FROM_ISR (EVENTGROUP_MISC_PLACEHOLDER+1)                        /*0x91*/\r
-#define PEND_FUNC_CALL_FAILED (EVENTGROUP_MISC_PLACEHOLDER+2)                  /*0x92*/\r
-#define PEND_FUNC_CALL_FROM_ISR_FAILED (EVENTGROUP_MISC_PLACEHOLDER+3) /*0x93*/\r
-#define MEM_MALLOC_SIZE (EVENTGROUP_MISC_PLACEHOLDER+4)                                        /*0x94*/\r
-#define MEM_MALLOC_ADDR (EVENTGROUP_MISC_PLACEHOLDER+5)                                        /*0x95*/\r
-#define MEM_FREE_SIZE (EVENTGROUP_MISC_PLACEHOLDER+6)                                  /*0x96*/\r
-#define MEM_FREE_ADDR (EVENTGROUP_MISC_PLACEHOLDER+7)                                  /*0x97*/\r
-\r
-/* User events */\r
-#define EVENTGROUP_USEREVENT (EVENTGROUP_MISC_PLACEHOLDER + 8)                 /*0x98*/\r
-#define USER_EVENT (EVENTGROUP_USEREVENT + 0)\r
-\r
-/* Allow for 0-15 arguments (the number of args is added to event code) */\r
-#define USER_EVENT_LAST (EVENTGROUP_USEREVENT + 15)                                            /*0xA7*/\r
-\r
-/*******************************************************************************\r
- * XTS Event - eXtended TimeStamp events\r
- * The timestamps used in the recorder are "differential timestamps" (DTS), i.e.\r
- * the time since the last stored event. The DTS fields are either 1 or 2 bytes\r
- * in the other events, depending on the bytes available in the event struct.\r
- * If the time since the last event (the DTS) is larger than allowed for by\r
- * the DTS field of the current event, an XTS event is inserted immediately\r
- * before the original event. The XTS event contains up to 3 additional bytes\r
- * of the DTS value - the higher bytes of the true DTS value. The lower 1-2\r
- * bytes are stored in the normal DTS field.\r
- * There are two types of XTS events, XTS8 and XTS16. An XTS8 event is stored\r
- * when there is only room for 1 byte (8 bit) DTS data in the original event,\r
- * which means a limit of 0xFF (255). The XTS16 is used when the original event\r
- * has a 16 bit DTS field and thereby can handle values up to 0xFFFF (65535).\r
- *\r
- * Using a very high frequency time base can result in many XTS events.\r
- * Preferably, the time between two OS ticks should fit in 16 bits, i.e.,\r
- * at most 65535. If your time base has a higher frequency, you can define\r
- * the TRACE\r
- ******************************************************************************/\r
-\r
-#define EVENTGROUP_SYS (EVENTGROUP_USEREVENT + 16)                                             /*0xA8*/\r
-#define XTS8 (EVENTGROUP_SYS + 0)                                                                              /*0xA8*/\r
-#define XTS16 (EVENTGROUP_SYS + 1)                                                                             /*0xA9*/\r
-#define EVENT_BEING_WRITTEN (EVENTGROUP_SYS + 2)                                               /*0xAA*/\r
-#define RESERVED_DUMMY_CODE (EVENTGROUP_SYS + 3)                                               /*0xAB*/\r
-#define LOW_POWER_BEGIN (EVENTGROUP_SYS + 4)                                                   /*0xAC*/\r
-#define LOW_POWER_END (EVENTGROUP_SYS + 5)                                                             /*0xAD*/\r
-#define XID (EVENTGROUP_SYS + 6)                                                                               /*0xAE*/\r
-#define XTS16L (EVENTGROUP_SYS + 7)                                                                            /*0xAF*/\r
-\r
-#define EVENTGROUP_TIMER (EVENTGROUP_SYS + 8)                                                  /*0xB0*/\r
-#define TIMER_CREATE (EVENTGROUP_TIMER + 0)                                                            /*0xB0*/\r
-#define TIMER_START (EVENTGROUP_TIMER + 1)                                                             /*0xB1*/\r
-#define TIMER_RST (EVENTGROUP_TIMER + 2)                                                               /*0xB2*/\r
-#define TIMER_STOP (EVENTGROUP_TIMER + 3)                                                              /*0xB3*/\r
-#define TIMER_CHANGE_PERIOD (EVENTGROUP_TIMER + 4)                                             /*0xB4*/\r
-#define TIMER_DELETE (EVENTGROUP_TIMER + 5)                                                            /*0xB5*/\r
-#define TIMER_START_FROM_ISR (EVENTGROUP_TIMER + 6)                                            /*0xB6*/\r
-#define TIMER_RESET_FROM_ISR (EVENTGROUP_TIMER + 7)                                            /*0xB7*/\r
-#define TIMER_STOP_FROM_ISR (EVENTGROUP_TIMER + 8)                                             /*0xB8*/\r
-\r
-#define TIMER_CREATE_FAILED (EVENTGROUP_TIMER + 9)                                             /*0xB9*/\r
-#define TIMER_START_FAILED (EVENTGROUP_TIMER + 10)                                             /*0xBA*/\r
-#define TIMER_RESET_FAILED (EVENTGROUP_TIMER + 11)                                             /*0xBB*/\r
-#define TIMER_STOP_FAILED (EVENTGROUP_TIMER + 12)                                              /*0xBC*/\r
-#define TIMER_CHANGE_PERIOD_FAILED (EVENTGROUP_TIMER + 13)                             /*0xBD*/\r
-#define TIMER_DELETE_FAILED (EVENTGROUP_TIMER + 14)                                            /*0xBE*/\r
-#define TIMER_START_FROM_ISR_FAILED (EVENTGROUP_TIMER + 15)                            /*0xBF*/\r
-#define TIMER_RESET_FROM_ISR_FAILED (EVENTGROUP_TIMER + 16)                            /*0xC0*/\r
-#define TIMER_STOP_FROM_ISR_FAILED (EVENTGROUP_TIMER + 17)                             /*0xC1*/\r
-\r
-#define EVENTGROUP_EG (EVENTGROUP_TIMER + 18)                                                  /*0xC2*/\r
-#define EVENT_GROUP_CREATE (EVENTGROUP_EG + 0)                                                 /*0xC2*/\r
-#define EVENT_GROUP_CREATE_FAILED (EVENTGROUP_EG + 1)                                  /*0xC3*/\r
-#define EVENT_GROUP_SYNC_BLOCK (EVENTGROUP_EG + 2)                                             /*0xC4*/\r
-#define EVENT_GROUP_SYNC_END (EVENTGROUP_EG + 3)                                               /*0xC5*/\r
-#define EVENT_GROUP_WAIT_BITS_BLOCK (EVENTGROUP_EG + 4)                                        /*0xC6*/\r
-#define EVENT_GROUP_WAIT_BITS_END (EVENTGROUP_EG + 5)                                  /*0xC7*/\r
-#define EVENT_GROUP_CLEAR_BITS (EVENTGROUP_EG + 6)                                             /*0xC8*/\r
-#define EVENT_GROUP_CLEAR_BITS_FROM_ISR (EVENTGROUP_EG + 7)                            /*0xC9*/\r
-#define EVENT_GROUP_SET_BITS (EVENTGROUP_EG + 8)                                               /*0xCA*/\r
-#define EVENT_GROUP_DELETE (EVENTGROUP_EG + 9)                                                 /*0xCB*/\r
-#define EVENT_GROUP_SYNC_END_FAILED (EVENTGROUP_EG + 10)                               /*0xCC*/\r
-#define EVENT_GROUP_WAIT_BITS_END_FAILED (EVENTGROUP_EG + 11)                  /*0xCD*/\r
-#define EVENT_GROUP_SET_BITS_FROM_ISR (EVENTGROUP_EG + 12)                             /*0xCE*/\r
-#define EVENT_GROUP_SET_BITS_FROM_ISR_FAILED (EVENTGROUP_EG + 13)              /*0xCF*/\r
-\r
-#define TASK_INSTANCE_FINISHED_NEXT_KSE (EVENTGROUP_EG + 14)                   /*0xD0*/\r
-#define TASK_INSTANCE_FINISHED_DIRECT (EVENTGROUP_EG + 15)                             /*0xD1*/\r
-\r
-/************************************************************************/\r
-/* KERNEL SPECIFIC DATA AND FUNCTIONS NEEDED TO PROVIDE THE                            */\r
-/* FUNCTIONALITY REQUESTED BY THE TRACE RECORDER                                               */\r
-/************************************************************************/\r
-\r
-/******************************************************************************\r
- * TraceObjectClassTable\r
- * Translates a FreeRTOS QueueType into trace objects classes (TRACE_CLASS_).\r
- * This was added since we want to map both types of Mutex and both types of\r
- * Semaphores on common classes for all Mutexes and all Semaphores respectively.\r
- *\r
- * FreeRTOS Queue types\r
- * #define queueQUEUE_TYPE_BASE                                        (0U) => TRACE_CLASS_QUEUE\r
- * #define queueQUEUE_TYPE_MUTEX                               (1U) => TRACE_CLASS_MUTEX\r
- * #define queueQUEUE_TYPE_COUNTING_SEMAPHORE  (2U) => TRACE_CLASS_SEMAPHORE\r
- * #define queueQUEUE_TYPE_BINARY_SEMAPHORE            (3U) => TRACE_CLASS_SEMAPHORE\r
- * #define queueQUEUE_TYPE_RECURSIVE_MUTEX             (4U) => TRACE_CLASS_MUTEX\r
- ******************************************************************************/\r
-\r
-extern traceObjectClass TraceObjectClassTable[5];\r
-\r
-/* These functions are implemented in the .c file since certain header files\r
-must not be included in this one */\r
-objectHandleType prvTraceGetObjectNumber(void* handle);\r
-unsigned char prvTraceGetObjectType(void* handle);\r
-objectHandleType prvTraceGetTaskNumber(void* handle);\r
-unsigned char prvTraceIsSchedulerActive(void);\r
-unsigned char prvTraceIsSchedulerSuspended(void);\r
-unsigned char prvTraceIsSchedulerStarted(void);\r
-void* prvTraceGetCurrentTaskHandle(void);\r
-\r
-#if (configUSE_TIMERS == 1)\r
-#undef INCLUDE_xTimerGetTimerDaemonTaskHandle\r
-#define INCLUDE_xTimerGetTimerDaemonTaskHandle 1\r
-#endif\r
-\r
-/************************************************************************/\r
-/* KERNEL SPECIFIC MACROS USED BY THE TRACE RECORDER                                   */\r
-/************************************************************************/\r
-\r
-#define TRACE_MALLOC(size) pvPortMalloc(size)\r
-#define TRACE_IS_SCHEDULER_ACTIVE() prvTraceIsSchedulerActive()\r
-#define TRACE_IS_SCHEDULER_STARTED() prvTraceIsSchedulerStarted()\r
-#define TRACE_IS_SCHEDULER_SUSPENDED() prvTraceIsSchedulerSuspended()\r
-#define TRACE_GET_CURRENT_TASK() prvTraceGetCurrentTaskHandle()\r
-\r
-#define TRACE_GET_TASK_PRIORITY(pxTCB) ((uint8_t)pxTCB->uxPriority)\r
-#define TRACE_GET_TASK_NAME(pxTCB) ((char*)pxTCB->pcTaskName)\r
-#define TRACE_GET_TASK_NUMBER(pxTCB) (prvTraceGetTaskNumber(pxTCB))\r
-#define TRACE_SET_TASK_NUMBER(pxTCB) pxTCB->uxTaskNumber = xTraceGetObjectHandle(TRACE_CLASS_TASK);\r
-\r
-#define TRACE_GET_CLASS_TRACE_CLASS(CLASS, kernelClass) TraceObjectClassTable[kernelClass]\r
-#define TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject) TRACE_GET_CLASS_TRACE_CLASS(CLASS, prvTraceGetObjectType(pxObject))\r
-\r
-#define TRACE_GET_TIMER_NUMBER(tmr) ( ( objectHandleType ) ((Timer_t*)tmr)->uxTimerNumber )\r
-#define TRACE_SET_TIMER_NUMBER(tmr) ((Timer_t*)tmr)->uxTimerNumber = xTraceGetObjectHandle(TRACE_CLASS_TIMER);\r
-#define TRACE_GET_TIMER_NAME(pxTimer) pxTimer->pcTimerName\r
-#define TRACE_GET_TIMER_PERIOD(pxTimer) pxTimer->xTimerPeriodInTicks\r
-\r
-#define TRACE_GET_EVENTGROUP_NUMBER(eg) ( ( objectHandleType ) uxEventGroupGetNumber(eg) )\r
-#define TRACE_SET_EVENTGROUP_NUMBER(eg) ((EventGroup_t*)eg)->uxEventGroupNumber = xTraceGetObjectHandle(TRACE_CLASS_EVENTGROUP);\r
-\r
-#define TRACE_GET_OBJECT_NUMBER(CLASS, pxObject) (prvTraceGetObjectNumber(pxObject))\r
-\r
-#if (FREERTOS_VERSION < FREERTOS_VERSION_8_0_OR_LATER)\r
-       #define TRACE_SET_OBJECT_NUMBER(CLASS, pxObject) pxObject->ucQueueNumber = xTraceGetObjectHandle(TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject));\r
-#else\r
-       #define TRACE_SET_OBJECT_NUMBER(CLASS, pxObject) pxObject->uxQueueNumber = xTraceGetObjectHandle(TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject));\r
-#endif\r
-\r
-#define TRACE_GET_CLASS_EVENT_CODE(SERVICE, RESULT, CLASS, kernelClass) (uint8_t)(EVENTGROUP_##SERVICE##_##RESULT + TRACE_GET_CLASS_TRACE_CLASS(CLASS, kernelClass))\r
-#define TRACE_GET_OBJECT_EVENT_CODE(SERVICE, RESULT, CLASS, pxObject) (uint8_t)(EVENTGROUP_##SERVICE##_##RESULT + TRACE_GET_OBJECT_TRACE_CLASS(CLASS, pxObject))\r
-#define TRACE_GET_TASK_EVENT_CODE(SERVICE, RESULT, CLASS, pxTCB) (uint8_t)(EVENTGROUP_##SERVICE##_##RESULT + TRACE_CLASS_TASK)\r
-\r
-/************************************************************************/\r
-/* KERNEL SPECIFIC WRAPPERS THAT SHOULD BE CALLED BY THE KERNEL                 */\r
-/************************************************************************/\r
-\r
-#if (configUSE_TICKLESS_IDLE != 0)\r
-\r
-#undef traceLOW_POWER_IDLE_BEGIN\r
-#define traceLOW_POWER_IDLE_BEGIN() \\r
-       { \\r
-               extern uint32_t trace_disable_timestamp; \\r
-               vTraceStoreLowPower(0); \\r
-               trace_disable_timestamp = 1; \\r
-       }\r
-\r
-#undef traceLOW_POWER_IDLE_END\r
-#define traceLOW_POWER_IDLE_END() \\r
-       { \\r
-               extern uint32_t trace_disable_timestamp; \\r
-               trace_disable_timestamp = 0; \\r
-               vTraceStoreLowPower(1); \\r
-       }\r
-\r
-#endif\r
-\r
-/* A macro that will update the tick count when returning from tickless idle */\r
-#undef traceINCREASE_TICK_COUNT\r
-/* Note: This can handle time adjustments of max 2^32 ticks, i.e., 35 seconds at 120 MHz. Thus, tick-less idle periods longer than 2^32 ticks will appear "compressed" on the time line.*/\r
-#define traceINCREASE_TICK_COUNT( xCount ) { DWT_CYCLES_ADDED += (xCount * (TRACE_CPU_CLOCK_HZ / TRACE_TICK_RATE_HZ)); }\r
-\r
-/* Called for each task that becomes ready */\r
-#undef traceMOVED_TASK_TO_READY_STATE\r
-#define traceMOVED_TASK_TO_READY_STATE( pxTCB ) \\r
-       trcKERNEL_HOOKS_MOVED_TASK_TO_READY_STATE(pxTCB);\r
-\r
-/* Called on each OS tick. Will call uiPortGetTimestamp to make sure it is called at least once every OS tick. */\r
-#undef traceTASK_INCREMENT_TICK\r
-\r
-#if (FREERTOS_VERSION == FREERTOS_VERSION_7_3_OR_7_4)\r
-\r
-#define traceTASK_INCREMENT_TICK( xTickCount ) \\r
-       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdTRUE || uxMissedTicks == 0) { trcKERNEL_HOOKS_INCREMENT_TICK(); } \\r
-       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE) { trcKERNEL_HOOKS_NEW_TIME(DIV_NEW_TIME, xTickCount + 1); }\r
-\r
-#else\r
-\r
-#define traceTASK_INCREMENT_TICK( xTickCount ) \\r
-       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdTRUE || uxPendedTicks == 0) { trcKERNEL_HOOKS_INCREMENT_TICK(); } \\r
-       if (uxSchedulerSuspended == ( unsigned portBASE_TYPE ) pdFALSE) { trcKERNEL_HOOKS_NEW_TIME(DIV_NEW_TIME, xTickCount + 1); }\r
-\r
-#endif\r
-\r
-/* Called on each task-switch */\r
-#undef traceTASK_SWITCHED_IN\r
-#define traceTASK_SWITCHED_IN() \\r
-               trcKERNEL_HOOKS_TASK_SWITCH(TRACE_GET_CURRENT_TASK());\r
-\r
-/* Called on vTaskSuspend */\r
-#undef traceTASK_SUSPEND\r
-#define traceTASK_SUSPEND( pxTaskToSuspend ) \\r
-       trcKERNEL_HOOKS_TASK_SUSPEND(TASK_SUSPEND, pxTaskToSuspend);\r
-\r
-/* Called on vTaskDelay - note the use of FreeRTOS variable xTicksToDelay */\r
-#undef traceTASK_DELAY\r
-#define traceTASK_DELAY() \\r
-       trcKERNEL_HOOKS_TASK_DELAY(TASK_DELAY, pxCurrentTCB, xTicksToDelay); \\r
-       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
-\r
-/* Called on vTaskDelayUntil - note the use of FreeRTOS variable xTimeToWake */\r
-#undef traceTASK_DELAY_UNTIL\r
-#define traceTASK_DELAY_UNTIL() \\r
-       trcKERNEL_HOOKS_TASK_DELAY(TASK_DELAY_UNTIL, pxCurrentTCB, xTimeToWake); \\r
-       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
-\r
-#if (INCLUDE_OBJECT_DELETE == 1)\r
-/* Called on vTaskDelete */\r
-#undef traceTASK_DELETE\r
-#define traceTASK_DELETE( pxTaskToDelete ) \\r
-       { TRACE_SR_ALLOC_CRITICAL_SECTION(); \\r
-       TRACE_ENTER_CRITICAL_SECTION(); \\r
-       trcKERNEL_HOOKS_TASK_DELETE(DELETE_OBJ, pxTaskToDelete); \\r
-       TRACE_EXIT_CRITICAL_SECTION(); }\r
-#endif\r
-\r
-#if (INCLUDE_OBJECT_DELETE == 1)\r
-/* Called on vQueueDelete */\r
-#undef traceQUEUE_DELETE\r
-#define traceQUEUE_DELETE( pxQueue ) \\r
-       { TRACE_SR_ALLOC_CRITICAL_SECTION(); \\r
-       TRACE_ENTER_CRITICAL_SECTION(); \\r
-       trcKERNEL_HOOKS_OBJECT_DELETE(DELETE_OBJ, UNUSED, pxQueue); \\r
-       TRACE_EXIT_CRITICAL_SECTION(); }\r
-#endif\r
-\r
-/* Called on vTaskCreate */\r
-#undef traceTASK_CREATE\r
-#define traceTASK_CREATE(pxNewTCB) \\r
-       if (pxNewTCB != NULL) \\r
-       { \\r
-               trcKERNEL_HOOKS_TASK_CREATE(CREATE_OBJ, UNUSED, pxNewTCB); \\r
-       }\r
-\r
-/* Called in vTaskCreate, if it fails (typically if the stack can not be allocated) */\r
-#undef traceTASK_CREATE_FAILED\r
-#define traceTASK_CREATE_FAILED() \\r
-       trcKERNEL_HOOKS_TASK_CREATE_FAILED(CREATE_OBJ, UNUSED);\r
-\r
-/* Called in xQueueCreate, and thereby for all other object based on queues, such as semaphores. */\r
-#undef traceQUEUE_CREATE\r
-#define traceQUEUE_CREATE( pxNewQueue )\\r
-       trcKERNEL_HOOKS_OBJECT_CREATE(CREATE_OBJ, UNUSED, pxNewQueue);\r
-\r
-/* Called in xQueueCreate, if the queue creation fails */\r
-#undef traceQUEUE_CREATE_FAILED\r
-#define traceQUEUE_CREATE_FAILED( queueType ) \\r
-       trcKERNEL_HOOKS_OBJECT_CREATE_FAILED(CREATE_OBJ, UNUSED, queueType);\r
-\r
-/* Called in xQueueCreateMutex, and thereby also from xSemaphoreCreateMutex and xSemaphoreCreateRecursiveMutex */\r
-#undef traceCREATE_MUTEX\r
-#define traceCREATE_MUTEX( pxNewQueue ) \\r
-       trcKERNEL_HOOKS_OBJECT_CREATE(CREATE_OBJ, UNUSED, pxNewQueue);\r
-\r
-/* Called in xQueueCreateMutex when the operation fails (when memory allocation fails) */\r
-#undef traceCREATE_MUTEX_FAILED\r
-#define traceCREATE_MUTEX_FAILED() \\r
-       trcKERNEL_HOOKS_OBJECT_CREATE_FAILED(CREATE_OBJ, UNUSED, queueQUEUE_TYPE_MUTEX);\r
-\r
-/* Called when the Mutex can not be given, since not holder */\r
-#undef traceGIVE_MUTEX_RECURSIVE_FAILED\r
-#define traceGIVE_MUTEX_RECURSIVE_FAILED( pxMutex ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, FAILED, UNUSED, pxMutex);\r
-\r
-/* Called when a message is sent to a queue */ /* CS IS NEW ! */\r
-#undef traceQUEUE_SEND\r
-#define traceQUEUE_SEND( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, SUCCESS, UNUSED, pxQueue); \\r
-       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, pxQueue) == TRACE_CLASS_MUTEX ? (uint8_t)0 : (uint8_t)(pxQueue->uxMessagesWaiting + 1));\r
-\r
-/* Called when a message failed to be sent to a queue (timeout) */\r
-#undef traceQUEUE_SEND_FAILED\r
-#define traceQUEUE_SEND_FAILED( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, FAILED, UNUSED, pxQueue);\r
-\r
-/* Called when the task is blocked due to a send operation on a full queue */\r
-#undef traceBLOCKING_ON_QUEUE_SEND\r
-#define traceBLOCKING_ON_QUEUE_SEND( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND, BLOCK, UNUSED, pxQueue);\r
-\r
-/* Called when a message is received from a queue */\r
-#undef traceQUEUE_RECEIVE\r
-#define traceQUEUE_RECEIVE( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE, SUCCESS, UNUSED, pxQueue); \\r
-       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, pxQueue) == TRACE_CLASS_MUTEX ? TRACE_GET_TASK_NUMBER(TRACE_GET_CURRENT_TASK()) : (uint8_t)(pxQueue->uxMessagesWaiting - 1));\r
-\r
-/* Called when a receive operation on a queue fails (timeout) */\r
-#undef traceQUEUE_RECEIVE_FAILED\r
-#define traceQUEUE_RECEIVE_FAILED( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE, FAILED, UNUSED, pxQueue);\r
-\r
-/* Called when the task is blocked due to a receive operation on an empty queue */\r
-#undef traceBLOCKING_ON_QUEUE_RECEIVE\r
-#define traceBLOCKING_ON_QUEUE_RECEIVE( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE, BLOCK, UNUSED, pxQueue); \\r
-       if (TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, pxQueue) != TRACE_CLASS_MUTEX) \\r
-       {trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();}\r
-\r
-/* Called on xQueuePeek */\r
-#undef traceQUEUE_PEEK\r
-#define traceQUEUE_PEEK( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(PEEK, SUCCESS, UNUSED, pxQueue);\r
-\r
-/* Called when a message is sent from interrupt context, e.g., using xQueueSendFromISR */\r
-#undef traceQUEUE_SEND_FROM_ISR\r
-#define traceQUEUE_SEND_FROM_ISR( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND_FROM_ISR, SUCCESS, UNUSED, pxQueue); \\r
-       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, (uint8_t)(pxQueue->uxMessagesWaiting + 1));\r
-\r
-/* Called when a message send from interrupt context fails (since the queue was full) */\r
-#undef traceQUEUE_SEND_FROM_ISR_FAILED\r
-#define traceQUEUE_SEND_FROM_ISR_FAILED( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(SEND_FROM_ISR, FAILED, UNUSED, pxQueue);\r
-\r
-/* Called when a message is received in interrupt context, e.g., using xQueueReceiveFromISR */\r
-#undef traceQUEUE_RECEIVE_FROM_ISR\r
-#define traceQUEUE_RECEIVE_FROM_ISR( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE_FROM_ISR, SUCCESS, UNUSED, pxQueue); \\r
-       trcKERNEL_HOOKS_SET_OBJECT_STATE(UNUSED, pxQueue, (uint8_t)(pxQueue->uxMessagesWaiting - 1));\r
-\r
-/* Called when a message receive from interrupt context fails (since the queue was empty) */\r
-#undef traceQUEUE_RECEIVE_FROM_ISR_FAILED\r
-#define traceQUEUE_RECEIVE_FROM_ISR_FAILED( pxQueue ) \\r
-       trcKERNEL_HOOKS_KERNEL_SERVICE(RECEIVE_FROM_ISR, FAILED, UNUSED, pxQueue);\r
-\r
-/* Called in vTaskPrioritySet */\r
-#undef traceTASK_PRIORITY_SET\r
-#define traceTASK_PRIORITY_SET( pxTask, uxNewPriority ) \\r
-       trcKERNEL_HOOKS_TASK_PRIORITY_CHANGE(TASK_PRIORITY_SET, pxTask, uxNewPriority);\r
-\r
-/* Called in vTaskPriorityInherit, which is called by Mutex operations */\r
-#undef traceTASK_PRIORITY_INHERIT\r
-#define traceTASK_PRIORITY_INHERIT( pxTask, uxNewPriority ) \\r
-       trcKERNEL_HOOKS_TASK_PRIORITY_CHANGE(TASK_PRIORITY_INHERIT, pxTask, uxNewPriority);\r
-\r
-/* Called in vTaskPriorityDisinherit, which is called by Mutex operations */\r
-#undef traceTASK_PRIORITY_DISINHERIT\r
-#define traceTASK_PRIORITY_DISINHERIT( pxTask, uxNewPriority ) \\r
-       trcKERNEL_HOOKS_TASK_PRIORITY_CHANGE(TASK_PRIORITY_DISINHERIT, pxTask, uxNewPriority);\r
-\r
-/* Called in vTaskResume */\r
-#undef traceTASK_RESUME\r
-#define traceTASK_RESUME( pxTaskToResume ) \\r
-       trcKERNEL_HOOKS_TASK_RESUME(TASK_RESUME, pxTaskToResume);\r
-\r
-/* Called in vTaskResumeFromISR */\r
-#undef traceTASK_RESUME_FROM_ISR\r
-#define traceTASK_RESUME_FROM_ISR( pxTaskToResume ) \\r
-       trcKERNEL_HOOKS_TASK_RESUME(TASK_RESUME_FROM_ISR, pxTaskToResume);\r
-\r
-\r
-#if (FREERTOS_VERSION >= FREERTOS_VERSION_8_0_OR_LATER)\r
-\r
-#if (INCLUDE_MEMMANG_EVENTS == 1)\r
-\r
-extern void vTraceStoreMemMangEvent(uint32_t ecode, uint32_t address, int32_t size);\r
-\r
-#undef traceMALLOC\r
-#define traceMALLOC( pvAddress, uiSize ) {if (pvAddress != 0) vTraceStoreMemMangEvent(MEM_MALLOC_SIZE, ( uint32_t ) pvAddress, (int32_t)uiSize); }\r
-\r
-#undef traceFREE\r
-#define traceFREE( pvAddress, uiSize ) {vTraceStoreMemMangEvent(MEM_FREE_SIZE, ( uint32_t ) pvAddress, (int32_t)(-uiSize)); }\r
-\r
-#endif\r
-\r
-/* Called in timer.c - xTimerCreate */\r
-#undef traceTIMER_CREATE\r
-#define traceTIMER_CREATE(tmr) \\r
-       trcKERNEL_HOOKS_TIMER_CREATE(TIMER_CREATE, tmr);\r
-\r
-#undef traceTIMER_CREATE_FAILED\r
-#define traceTIMER_CREATE_FAILED() \\r
-       trcKERNEL_HOOKS_TIMER_EVENT(TIMER_CREATE_FAILED, 0);\r
-\r
-/* Note that xCommandID can never be tmrCOMMAND_EXECUTE_CALLBACK (-1) since the trace macro is not called in that case */\r
-#undef traceTIMER_COMMAND_SEND\r
-#define traceTIMER_COMMAND_SEND(tmr, xCommandID, xOptionalValue, xReturn) \\r
-if (xCommandID > tmrCOMMAND_START_DONT_TRACE){\\r
-               if (xCommandID == tmrCOMMAND_CHANGE_PERIOD) vTraceStoreKernelCallWithParam((xReturn == pdPASS) ? TIMER_CHANGE_PERIOD : TIMER_CHANGE_PERIOD_FAILED, TRACE_CLASS_TIMER, TRACE_GET_TIMER_NUMBER(tmr), xOptionalValue);\\r
-               else if ((xCommandID == tmrCOMMAND_DELETE) && (xReturn == pdPASS)){ trcKERNEL_HOOKS_TIMER_DELETE(TIMER_DELETE, tmr); } \\r
-               else {trcKERNEL_HOOKS_TIMER_EVENT(EVENTGROUP_TIMER + xCommandID + ((xReturn == pdPASS)?0:(TIMER_CREATE_FAILED - TIMER_CREATE)), tmr); }\\r
-}\r
-\r
-#undef tracePEND_FUNC_CALL\r
-#define tracePEND_FUNC_CALL(func, arg1, arg2, ret) \\r
-if (ret == pdPASS) \\r
-       vTraceStoreKernelCall(PEND_FUNC_CALL, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTimerGetTimerDaemonTaskHandle()) ); \\r
-else \\r
-       vTraceStoreKernelCall(PEND_FUNC_CALL_FAILED, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTimerGetTimerDaemonTaskHandle()) );\r
-\r
-#undef tracePEND_FUNC_CALL_FROM_ISR\r
-#define tracePEND_FUNC_CALL_FROM_ISR(func, arg1, arg2, ret) \\r
-       if (! uiInEventGroupSetBitsFromISR) vTraceStoreKernelCall(PEND_FUNC_CALL_FROM_ISR, TRACE_CLASS_TASK, uxTaskGetTaskNumber(xTimerGetTimerDaemonTaskHandle()) ); \\r
-       uiInEventGroupSetBitsFromISR = 0;\r
-#endif\r
-\r
-#undef traceEVENT_GROUP_CREATE\r
-#define traceEVENT_GROUP_CREATE(eg) \\r
-       TRACE_SET_EVENTGROUP_NUMBER(eg); \\r
-       vTraceStoreKernelCall(EVENT_GROUP_CREATE, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg));\r
-\r
-#undef traceEVENT_GROUP_DELETE\r
-#define traceEVENT_GROUP_DELETE(eg) \\r
-       vTraceStoreKernelCall(EVENT_GROUP_DELETE, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg)); \\r
-       vTraceStoreObjectNameOnCloseEvent(TRACE_GET_EVENTGROUP_NUMBER(eg), TRACE_CLASS_EVENTGROUP); \\r
-       vTraceStoreObjectPropertiesOnCloseEvent(TRACE_GET_EVENTGROUP_NUMBER(eg), TRACE_CLASS_EVENTGROUP); \\r
-       vTraceFreeObjectHandle(TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg));\r
-\r
-#undef traceEVENT_GROUP_CREATE_FAILED\r
-#define traceEVENT_GROUP_CREATE_FAILED() \\r
-       vTraceStoreKernelCall(EVENT_GROUP_CREATE_FAILED, TRACE_CLASS_EVENTGROUP, 0);\r
-\r
-#undef traceEVENT_GROUP_SYNC_BLOCK\r
-#define traceEVENT_GROUP_SYNC_BLOCK(eg, bitsToSet, bitsToWaitFor) \\r
-       vTraceStoreKernelCallWithParam(EVENT_GROUP_SYNC_BLOCK, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor);\r
-\r
-#undef traceEVENT_GROUP_SYNC_END\r
-#define traceEVENT_GROUP_SYNC_END(eg, bitsToSet, bitsToWaitFor, wasTimeout) \\r
-       if (wasTimeout){ vTraceStoreKernelCallWithParam(EVENT_GROUP_SYNC_END_FAILED, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor);} \\r
-       else{ vTraceStoreKernelCallWithParam(EVENT_GROUP_SYNC_END, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); }\r
-\r
-#undef traceEVENT_GROUP_WAIT_BITS_BLOCK\r
-#define traceEVENT_GROUP_WAIT_BITS_BLOCK(eg, bitsToWaitFor) \\r
-       vTraceStoreKernelCallWithParam(EVENT_GROUP_WAIT_BITS_BLOCK, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); \\r
-       trcKERNEL_HOOKS_SET_TASK_INSTANCE_FINISHED();\r
-\r
-#undef traceEVENT_GROUP_WAIT_BITS_END\r
-#define traceEVENT_GROUP_WAIT_BITS_END(eg, bitsToWaitFor, wasTimeout) \\r
-       if (wasTimeout){ vTraceStoreKernelCallWithParam(EVENT_GROUP_WAIT_BITS_END_FAILED, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); } \\r
-       else{ vTraceStoreKernelCallWithParam(EVENT_GROUP_WAIT_BITS_END, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToWaitFor); }\r
-\r
-#undef traceEVENT_GROUP_CLEAR_BITS\r
-#define traceEVENT_GROUP_CLEAR_BITS(eg, bitsToClear) \\r
-       if (bitsToClear) vTraceStoreKernelCallWithParam(EVENT_GROUP_CLEAR_BITS, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToClear);\r
-\r
-#undef traceEVENT_GROUP_CLEAR_BITS_FROM_ISR\r
-#define traceEVENT_GROUP_CLEAR_BITS_FROM_ISR(eg, bitsToClear) \\r
-       if (bitsToClear) vTraceStoreKernelCallWithParam(EVENT_GROUP_CLEAR_BITS_FROM_ISR, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToClear);\r
-\r
-#undef traceEVENT_GROUP_SET_BITS\r
-#define traceEVENT_GROUP_SET_BITS(eg, bitsToSet) \\r
-       vTraceStoreKernelCallWithParam(EVENT_GROUP_SET_BITS, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToSet);\r
-\r
-#undef traceEVENT_GROUP_SET_BITS_FROM_ISR\r
-#define traceEVENT_GROUP_SET_BITS_FROM_ISR(eg, bitsToSet) \\r
-       vTraceStoreKernelCallWithParam(EVENT_GROUP_SET_BITS_FROM_ISR, TRACE_CLASS_EVENTGROUP, TRACE_GET_EVENTGROUP_NUMBER(eg), bitsToSet); \\r
-       uiInEventGroupSetBitsFromISR = 1;\r
-\r
-\r
-/************************************************************************/\r
-/* KERNEL SPECIFIC MACROS TO EXCLUDE OR INCLUDE THINGS IN TRACE                        */\r
-/************************************************************************/\r
-\r
-/* Returns the exclude state of the object */\r
-uint8_t uiTraceIsObjectExcluded(traceObjectClass objectclass, objectHandleType handle);\r
-\r
-#define TRACE_SET_QUEUE_FLAG_ISEXCLUDED(queueIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, queueIndex)\r
-#define TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(queueIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, queueIndex)\r
-#define TRACE_GET_QUEUE_FLAG_ISEXCLUDED(queueIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, queueIndex)\r
-\r
-#define TRACE_SET_SEMAPHORE_FLAG_ISEXCLUDED(semaphoreIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+semaphoreIndex)\r
-#define TRACE_CLEAR_SEMAPHORE_FLAG_ISEXCLUDED(semaphoreIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+semaphoreIndex)\r
-#define TRACE_GET_SEMAPHORE_FLAG_ISEXCLUDED(semaphoreIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+semaphoreIndex)\r
-\r
-#define TRACE_SET_MUTEX_FLAG_ISEXCLUDED(mutexIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+mutexIndex)\r
-#define TRACE_CLEAR_MUTEX_FLAG_ISEXCLUDED(mutexIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+mutexIndex)\r
-#define TRACE_GET_MUTEX_FLAG_ISEXCLUDED(mutexIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+mutexIndex)\r
-\r
-#define TRACE_SET_TASK_FLAG_ISEXCLUDED(taskIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+taskIndex)\r
-#define TRACE_CLEAR_TASK_FLAG_ISEXCLUDED(taskIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+taskIndex)\r
-#define TRACE_GET_TASK_FLAG_ISEXCLUDED(taskIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+taskIndex)\r
-\r
-#define TRACE_SET_TIMER_FLAG_ISEXCLUDED(timerIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+timerIndex)\r
-#define TRACE_CLEAR_TIMER_FLAG_ISEXCLUDED(timerIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+timerIndex)\r
-#define TRACE_GET_TIMER_FLAG_ISEXCLUDED(timerIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+timerIndex)\r
-\r
-#define TRACE_SET_EVENTGROUP_FLAG_ISEXCLUDED(egIndex) TRACE_SET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+NTimer+1+egIndex)\r
-#define TRACE_CLEAR_EVENTGROUP_FLAG_ISEXCLUDED(egIndex) TRACE_CLEAR_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+NTimer+1+egIndex)\r
-#define TRACE_GET_EVENTGROUP_FLAG_ISEXCLUDED(egIndex) TRACE_GET_FLAG_ISEXCLUDED(excludedObjects, NQueue+1+NSemaphore+1+NMutex+1+NTask+1+NTimer+1+egIndex)\r
-\r
-\r
-#define TRACE_CLEAR_OBJECT_FLAG_ISEXCLUDED(objectclass, handle) \\r
-switch (objectclass) \\r
-{ \\r
-case TRACE_CLASS_QUEUE: \\r
-       TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_SEMAPHORE: \\r
-       TRACE_CLEAR_SEMAPHORE_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_MUTEX: \\r
-       TRACE_CLEAR_MUTEX_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_TASK: \\r
-       TRACE_CLEAR_TASK_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_TIMER: \\r
-       TRACE_CLEAR_TIMER_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_EVENTGROUP: \\r
-       TRACE_CLEAR_EVENTGROUP_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-}\r
-\r
-#define TRACE_SET_OBJECT_FLAG_ISEXCLUDED(objectclass, handle) \\r
-switch (objectclass) \\r
-{ \\r
-case TRACE_CLASS_QUEUE: \\r
-       TRACE_SET_QUEUE_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_SEMAPHORE: \\r
-       TRACE_SET_SEMAPHORE_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_MUTEX: \\r
-       TRACE_SET_MUTEX_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_TASK: \\r
-       TRACE_SET_TASK_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_TIMER: \\r
-       TRACE_SET_TIMER_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-case TRACE_CLASS_EVENTGROUP: \\r
-       TRACE_SET_EVENTGROUP_FLAG_ISEXCLUDED(handle); \\r
-       break; \\r
-}\r
-\r
-/* Task */\r
-#define vTraceExcludeTaskFromTrace(handle) \\r
-TRACE_SET_TASK_FLAG_ISEXCLUDED(TRACE_GET_TASK_NUMBER(handle));\r
-\r
-#define vTraceIncludeTaskInTrace(handle) \\r
-TRACE_CLEAR_TASK_FLAG_ISEXCLUDED(TRACE_GET_TASK_NUMBER(handle));\r
-\r
-\r
-/* Queue */\r
-#define vTraceExcludeQueueFromTrace(handle) \\r
-TRACE_SET_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
-\r
-#define vTraceIncludeQueueInTrace(handle) \\r
-TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
-\r
-\r
-/* Semaphore */\r
-#define vTraceExcludeSemaphoreFromTrace(handle) \\r
-TRACE_SET_SEMAPHORE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
-\r
-#define vTraceIncludeSemaphoreInTrace(handle) \\r
-TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
-\r
-\r
-/* Mutex */\r
-#define vTraceExcludeMutexFromTrace(handle) \\r
-TRACE_SET_MUTEX_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
-\r
-#define vTraceIncludeMutexInTrace(handle) \\r
-TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_OBJECT_NUMBER(UNUSED, handle));\r
-\r
-/* Timer */\r
-#define vTraceExcludeTimerFromTrace(handle) \\r
-TRACE_SET_TIMER_FLAG_ISEXCLUDED(TRACE_GET_TIMER_NUMBER(handle));\r
-\r
-#define vTraceIncludeTimerInTrace(handle) \\r
-TRACE_CLEAR_QUEUE_FLAG_ISEXCLUDED(TRACE_GET_TIMER_NUMBER(handle));\r
-\r
-/* Event Group */\r
-#define vTraceExcludeEventGroupFromTrace(handle) \\r
-TRACE_SET_EVENTGROUP_FLAG_ISEXCLUDED(TRACE_GET_EVENTGROUP_NUMBER(handle));\r
-\r
-#define vTraceIncludeEventGroupInTrace(handle) \\r
-TRACE_CLEAR_EVENTGROUP_FLAG_ISEXCLUDED(TRACE_GET_EVENTGROUP_NUMBER(handle));\r
-\r
-\r
-/* Kernel Services */\r
-#define vTraceExcludeKernelServiceDelayFromTrace() \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY_UNTIL);\r
-\r
-#define vTraceIncludeKernelServiceDelayInTrace() \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(TASK_DELAY_UNTIL);\r
-\r
-/* HELPER MACROS FOR KERNEL SERVICES FOR OBJECTS */\r
-#define vTraceExcludeKernelServiceSendFromTrace_HELPER(class) \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_SUCCESS + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_BLOCK + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FAILED + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_SUCCESS + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_FAILED + class);\r
-\r
-#define vTraceIncludeKernelServiceSendInTrace_HELPER(class) \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_SUCCESS + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_BLOCK + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FAILED + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_SUCCESS + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_SEND_FROM_ISR_FAILED + class);\r
-\r
-#define vTraceExcludeKernelServiceReceiveFromTrace_HELPER(class) \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_SUCCESS + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_BLOCK + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FAILED + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS + class); \\r
-TRACE_SET_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_FAILED + class);\r
-\r
-#define vTraceIncludeKernelServiceReceiveInTrace_HELPER(class) \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_SUCCESS + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_BLOCK + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FAILED + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_SUCCESS + class); \\r
-TRACE_CLEAR_EVENT_CODE_FLAG_ISEXCLUDED(EVENTGROUP_RECEIVE_FROM_ISR_FAILED + class);\r
-\r
-/* EXCLUDE AND INCLUDE FOR QUEUE */\r
-#define vTraceExcludeKernelServiceQueueSendFromTrace() \\r
-vTraceExcludeKernelServiceSendFromTrace_HELPER(TRACE_CLASS_QUEUE);\r
-\r
-#define vTraceIncludeKernelServiceQueueSendInTrace() \\r
-vTraceIncludeKernelServiceSendInTrace_HELPER(TRACE_CLASS_QUEUE);\r
-\r
-#define vTraceExcludeKernelServiceQueueReceiveFromTrace() \\r
-vTraceExcludeKernelServiceReceiveFromTrace_HELPER(TRACE_CLASS_QUEUE);\r
-\r
-#define vTraceIncludeKernelServiceQueueReceiveInTrace() \\r
-vTraceIncludeKernelServiceReceiveInTrace_HELPER(TRACE_CLASS_QUEUE);\r
-\r
-/* EXCLUDE AND INCLUDE FOR SEMAPHORE */\r
-#define vTraceExcludeKernelServiceSemaphoreSendFromTrace() \\r
-vTraceExcludeKernelServiceSendFromTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
-\r
-#define vTraceIncludeKernelServicSemaphoreSendInTrace() \\r
-vTraceIncludeKernelServiceSendInTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
-\r
-#define vTraceExcludeKernelServiceSemaphoreReceiveFromTrace() \\r
-vTraceExcludeKernelServiceReceiveFromTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
-\r
-#define vTraceIncludeKernelServiceSemaphoreReceiveInTrace() \\r
-vTraceIncludeKernelServiceReceiveInTrace_HELPER(TRACE_CLASS_SEMAPHORE);\r
-\r
-/* EXCLUDE AND INCLUDE FOR MUTEX */\r
-#define vTraceExcludeKernelServiceMutexSendFromTrace() \\r
-vTraceExcludeKernelServiceSendFromTrace_HELPER(TRACE_CLASS_MUTEX);\r
-\r
-#define vTraceIncludeKernelServiceMutexSendInTrace() \\r
-vTraceIncludeKernelServiceSendInTrace_HELPER(TRACE_CLASS_MUTEX);\r
-\r
-#define vTraceExcludeKernelServiceMutexReceiveFromTrace() \\r
-vTraceExcludeKernelServiceReceiveFromTrace_HELPER(TRACE_CLASS_MUTEX);\r
-\r
-#define vTraceIncludeKernelServiceMutexReceiveInTrace() \\r
-vTraceIncludeKernelServiceReceiveInTrace_HELPER(TRACE_CLASS_MUTEX);\r
-\r
-/************************************************************************/\r
-/* KERNEL SPECIFIC MACROS TO NAME OBJECTS, IF NECESSARY                                 */\r
-/************************************************************************/\r
-#define vTraceSetQueueName(object, name) \\r
-vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
-\r
-#define vTraceSetSemaphoreName(object, name) \\r
-vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
-\r
-#define vTraceSetMutexName(object, name) \\r
-vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
-\r
-#define vTraceSetEventGroupName(object, name) \\r
-vTraceSetObjectName(TRACE_CLASS_EVENTGROUP, (objectHandleType)uxEventGroupGetNumber(object), name);\r
-\r
-#undef traceQUEUE_REGISTRY_ADD\r
-#define traceQUEUE_REGISTRY_ADD(object, name) vTraceSetObjectName(TRACE_GET_OBJECT_TRACE_CLASS(UNUSED, object), TRACE_GET_OBJECT_NUMBER(UNUSED, object), name);\r
-#endif\r
-\r
-#endif /* TRCKERNELPORTFREERTOS_H_ */\r
-\r
-\r
-\r
-\r
-\r
-\r
-\r
-\r
index a2682e6814cb03816d200e4f3c01a382758cecae..6b99c970c26e8d1c446af23a81acadd5663a2cad 100644 (file)
@@ -1,5 +1,5 @@
 /*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
+ * Tracealyzer v2.7.7 Recorder Library\r
  * Percepio AB, www.percepio.com\r
  *\r
  * trcUser.h\r
@@ -32,7 +32,7 @@
  *\r
  * Tabs are used for indent in this file (1 tab = 4 spaces)\r
  *\r
- * Copyright Percepio AB, 2014.\r
+ * Copyright Percepio AB, 2012-2015.\r
  * www.percepio.com\r
  ******************************************************************************/\r
 \r
@@ -448,7 +448,7 @@ void vTraceChannelUserEvent(UserEventChannel channel);
 \r
 #define vTraceSetISRProperties(handle, name, priority)\r
 #define vTraceStoreISRBegin(id)\r
-#define vTraceStoreISREnd()\r
+#define vTraceStoreISREnd(flag)\r
 #define vTraceExcludeTaskFromTrace(handle)\r
 #define vTraceSetQueueName(a, b)\r
 #define vTraceSetMutexName(a, b)\r
index 5cf073dc1b7ab035b2dd5b68cb73a53a0c5dd037..cf624c850b07b89a842cec2676c9f6e96578a50f 100644 (file)
@@ -1,5 +1,5 @@
 /*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
+ * Tracealyzer v2.7.7 Recorder Library\r
  * Percepio AB, www.percepio.com\r
  *\r
  * trcKernel.c\r
@@ -33,7 +33,7 @@
  *\r
  * Tabs are used for indent in this file (1 tab = 4 spaces)\r
  *\r
- * Copyright Percepio AB, 2014.\r
+ * Copyright Percepio AB, 2012-2015.\r
  * www.percepio.com\r
  ******************************************************************************/\r
 \r
 #include <stdint.h>\r
 \r
 /* Internal variables */\r
-uint8_t nISRactive = 0;\r
+int8_t nISRactive = 0;\r
 objectHandleType handle_of_last_logged_task = 0;\r
 uint8_t inExcludedTask = 0;\r
 \r
+#if (INCLUDE_MEMMANG_EVENTS == 1)\r
 /* Current heap usage. Always updated. */\r
 static uint32_t heapMemUsage = 0;\r
+#endif\r
 \r
 #if (TRACE_SCHEDULING_ONLY == 0)\r
 static uint32_t prvTraceGetParam(uint32_t, uint32_t);\r
 #endif\r
 \r
 #if !defined INCLUDE_READY_EVENTS || INCLUDE_READY_EVENTS == 1\r
+\r
+static int readyEventsEnabled = 1;\r
+\r
+void vTraceSetReadyEventsEnabled(int status)\r
+{\r
+       readyEventsEnabled = status;\r
+}\r
+\r
 /*******************************************************************************\r
  * vTraceStoreTaskReady\r
  *\r
@@ -75,6 +85,14 @@ void vTraceStoreTaskReady(objectHandleType handle)
                placement of the trace macro. In that case, the events are ignored. */\r
                return;\r
        }\r
+       \r
+       if (! readyEventsEnabled)\r
+       {\r
+               /* When creating tasks, ready events are also created. If creating \r
+               a "hidden" (not traced) task, we must therefore disable recording \r
+               of ready events to avoid an undesired ready event... */\r
+               return;\r
+       }\r
 \r
        TRACE_ASSERT(handle <= NTask, "vTraceStoreTaskReady: Invalid value for handle", );\r
 \r
@@ -171,13 +189,15 @@ void vTraceStoreMemMangEvent(uint32_t ecode, uint32_t address, int32_t signed_si
        uint16_t addr_low;\r
        uint8_t addr_high;\r
        uint32_t size;\r
+       TRACE_SR_ALLOC_CRITICAL_SECTION();\r
+\r
+       if (RecorderDataPtr == NULL) // This happens in vTraceInitTraceData, if using dynamic allocation...\r
+               return;\r
        \r
        if (signed_size < 0)\r
                size = (uint32_t)(- signed_size);\r
        else\r
                size = (uint32_t)(signed_size);\r
-       \r
-       TRACE_SR_ALLOC_CRITICAL_SECTION();\r
 \r
        trcCRITICAL_SECTION_BEGIN();\r
        \r
@@ -619,9 +639,9 @@ void vTraceSetPriorityProperty(uint8_t objectclass, objectHandleType id, uint8_t
 uint8_t uiTraceGetPriorityProperty(uint8_t objectclass, objectHandleType id)\r
 {\r
        TRACE_ASSERT(objectclass < TRACE_NCLASSES,\r
-               "uiTraceGetPriorityProperty: objectclass >= TRACE_NCLASSES", 0);\r
+               "uiTraceGetPriorityProperty: Invalid objectclass number (>= TRACE_NCLASSES)", 0);\r
        TRACE_ASSERT(id <= RecorderDataPtr->ObjectPropertyTable.NumberOfObjectsPerClass[objectclass],\r
-               "uiTraceGetPriorityProperty: Invalid value for id", 0);\r
+               "uiTraceGetPriorityProperty: Task handle exceeds NTask. You may need to increase this constant in trcConfig.h.", 0);\r
 \r
        return TRACE_PROPERTY_ACTOR_PRIORITY(objectclass, id);\r
 }\r
index 57c53ffbca848973f108a4a20d364ffebeb757c2..f2d212c3ec81098c199e8df0de2efb344f944bcb 100644 (file)
@@ -1,5 +1,5 @@
 /*******************************************************************************\r
- * Tracealyzer v2.7.0 Recorder Library\r
+ * Tracealyzer v2.7.7 Recorder Library\r
  * Percepio AB, www.percepio.com\r
  *\r
  * trcUser.c\r
@@ -33,7 +33,7 @@
  *\r
  * Tabs are used for indent in this file (1 tab = 4 spaces)\r
  *\r
- * Copyright Percepio AB, 2014.\r
+ * Copyright Percepio AB, 2012-2015.\r
  * www.percepio.com\r
  ******************************************************************************/\r
 #include "FreeRTOS.h"\r
@@ -50,7 +50,7 @@
 TRACE_STOP_HOOK vTraceStopHookPtr = (TRACE_STOP_HOOK)0;\r
 \r
 extern uint8_t inExcludedTask;\r
-extern uint8_t nISRactive;\r
+extern int8_t nISRactive;\r
 extern objectHandleType handle_of_last_logged_task;\r
 extern uint32_t dts_min;\r
 extern uint32_t hwtc_count_max_after_tick;\r
@@ -127,6 +127,8 @@ void vTraceClear(void)
 \r
        memset(RecorderDataPtr->eventData, 0, RecorderDataPtr->maxEvents * 4);\r
 \r
+       handle_of_last_logged_task = 0;\r
+       \r
        trcCRITICAL_SECTION_END();\r
 \r
 }\r
@@ -632,47 +634,55 @@ void vTraceStoreISREnd(int pendingISR)
        uint16_t dts5;\r
        TRACE_SR_ALLOC_CRITICAL_SECTION();\r
 \r
+       if (! RecorderDataPtr->recorderActive ||  ! handle_of_last_logged_task)\r
+       {\r
+               return;\r
+       }\r
+\r
        if (recorder_busy)\r
        {\r
                vTraceError("Illegal call to vTraceStoreISREnd, recorder busy!");\r
                return;\r
        }\r
+       \r
+       if (nISRactive == 0)\r
+       {\r
+               vTraceError("Unmatched call to vTraceStoreISREnd (nISRactive == 0, expected > 0)");\r
+               return;\r
+       }\r
 \r
        trcCRITICAL_SECTION_BEGIN();\r
        if (pendingISR == 0)\r
        {\r
-               if (RecorderDataPtr->recorderActive && handle_of_last_logged_task)\r
-               {\r
-                       uint8_t hnd8, type;\r
-                       dts5 = (uint16_t)prvTraceGetDTS(0xFFFF);\r
-\r
-                       if (nISRactive > 1)\r
-                       {\r
-                               /* return to another isr */\r
-                               type = TS_ISR_RESUME;\r
-                               hnd8 = prvTraceGet8BitHandle(isrstack[nISRactive]);\r
-                       }\r
-                       else\r
-                       {\r
-                               /* return to task */\r
-                               type = TS_TASK_RESUME;\r
-                               hnd8 = prvTraceGet8BitHandle(handle_of_last_logged_task);\r
-                       }\r
+               uint8_t hnd8, type;\r
+               dts5 = (uint16_t)prvTraceGetDTS(0xFFFF);\r
 \r
-                       ts = (TSEvent*)xTraceNextFreeEventBufferSlot();\r
-                       if (ts != NULL)\r
-                       {\r
-                               ts->type = type;\r
-                               ts->objHandle = hnd8;\r
-                               ts->dts = dts5;\r
-                               prvTraceUpdateCounters();\r
-                       }\r
+               if (nISRactive > 1)\r
+               {\r
+                       /* return to another isr */\r
+                       type = TS_ISR_RESUME;\r
+                       hnd8 = prvTraceGet8BitHandle(isrstack[nISRactive]);\r
+               }\r
+               else\r
+               {\r
+                       /* return to task */\r
+                       type = TS_TASK_RESUME;\r
+                       hnd8 = prvTraceGet8BitHandle(handle_of_last_logged_task);\r
+               }\r
 \r
-                       #if (SELECTED_PORT == PORT_ARM_CortexM)\r
-                       /* Remember the last ISR exit event, as the event needs to be modified in case of a following ISR entry (if tail-chained ISRs) */\r
-                       ptrLastISRExitEvent = (uint8_t*)ts;\r
-                       #endif\r
+               ts = (TSEvent*)xTraceNextFreeEventBufferSlot();\r
+               if (ts != NULL)\r
+               {\r
+                       ts->type = type;\r
+                       ts->objHandle = hnd8;\r
+                       ts->dts = dts5;\r
+                       prvTraceUpdateCounters();\r
                }\r
+\r
+               #if (SELECTED_PORT == PORT_ARM_CortexM)\r
+               /* Remember the last ISR exit event, as the event needs to be modified in case of a following ISR entry (if tail-chained ISRs) */\r
+               ptrLastISRExitEvent = (uint8_t*)ts;\r
+               #endif          \r
        }\r
        nISRactive--;\r
 \r
index ee8957dd9063197c767a4703a9d793a6da8e3f04..329453521bca7a12d65019133f470c7244f062c4 100644 (file)
                                                        </tool>\r
                                                </toolChain>\r
                                        </folderInfo>\r
-                                       <folderInfo id="cdt.managedbuild.config.gnu.cygwin.exe.debug.5899473.1173721081" name="/" resourcePath="Full_Demo/Standard_Demo_Tasks">\r
-                                               <toolChain id="cdt.managedbuild.toolchain.gnu.cross.base.1555812406" name="Cross GCC" superClass="cdt.managedbuild.toolchain.gnu.cross.base" unusedChildren="">\r
-                                                       <option id="cdt.managedbuild.option.gnu.cross.prefix.1160671315.1680026821" name="Prefix" superClass="cdt.managedbuild.option.gnu.cross.prefix.1160671315"/>\r
-                                                       <option id="cdt.managedbuild.option.gnu.cross.path.942625968.1399515051" name="Path" superClass="cdt.managedbuild.option.gnu.cross.path.942625968"/>\r
-                                                       <tool id="cdt.managedbuild.tool.gnu.cross.c.compiler.100957841" name="Cross GCC Compiler" superClass="cdt.managedbuild.tool.gnu.cross.c.compiler.850200804">\r
-                                                               <inputType id="cdt.managedbuild.tool.gnu.c.compiler.input.1496229673" superClass="cdt.managedbuild.tool.gnu.c.compiler.input"/>\r
-                                                       </tool>\r
-                                                       <tool id="cdt.managedbuild.tool.gnu.cross.cpp.compiler.1644078528" name="Cross G++ Compiler" superClass="cdt.managedbuild.tool.gnu.cross.cpp.compiler.1667900842"/>\r
-                                                       <tool id="cdt.managedbuild.tool.gnu.cross.c.linker.1073540094" name="Cross GCC Linker" superClass="cdt.managedbuild.tool.gnu.cross.c.linker.2047125905"/>\r
-                                                       <tool id="cdt.managedbuild.tool.gnu.cross.cpp.linker.956115598" name="Cross G++ Linker" superClass="cdt.managedbuild.tool.gnu.cross.cpp.linker.1304180380"/>\r
-                                                       <tool id="cdt.managedbuild.tool.gnu.cross.archiver.520187407" name="Cross GCC Archiver" superClass="cdt.managedbuild.tool.gnu.cross.archiver.2001524857"/>\r
-                                                       <tool id="cdt.managedbuild.tool.gnu.cross.assembler.737789519" name="Cross GCC Assembler" superClass="cdt.managedbuild.tool.gnu.cross.assembler.500911803">\r
-                                                               <inputType id="cdt.managedbuild.tool.gnu.assembler.input.225651200" superClass="cdt.managedbuild.tool.gnu.assembler.input"/>\r
-                                                       </tool>\r
-                                               </toolChain>\r
-                                       </folderInfo>\r
                                        <sourceEntries>\r
                                                <entry excluding="Support_Files/stdlib_functions.c|nops.c|Source|uart.c|early_uart.c" flags="VALUE_WORKSPACE_PATH|RESOLVED" kind="sourcePath" name=""/>\r
                                        </sourceEntries>\r
index e7ec93029a2562e5e67db94e188469ae901e74b1..02878e7a341968a1e738eddff6b6924ff4ba343f 100644 (file)
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438277863568</id>\r
+                       <id>1438864614809</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks</name>\r
                        <type>9</type>\r
                        <matcher>\r
                                <id>org.eclipse.ui.ide.multiFilter</id>\r
-                               <arguments>1.0-name-matches-false-false-include</arguments>\r
+                               <arguments>1.0-name-matches-false-false-Minimal</arguments>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438277863618</id>\r
+                       <id>1438864614839</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks</name>\r
                        <type>9</type>\r
                        <matcher>\r
                                <id>org.eclipse.ui.ide.multiFilter</id>\r
-                               <arguments>1.0-name-matches-false-false-Minimal</arguments>\r
+                               <arguments>1.0-name-matches-false-false-include</arguments>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
@@ -91,7 +91,7 @@
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034257</id>\r
+                       <id>1438864777066</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034267</id>\r
+                       <id>1438864777076</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034287</id>\r
+                       <id>1438864777126</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                                <id>org.eclipse.ui.ide.multiFilter</id>\r
-                               <arguments>1.0-name-matches-true-false-countsem.c</arguments>\r
+                               <arguments>1.0-name-matches-false-false-countsem.c</arguments>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034297</id>\r
+                       <id>1438864777146</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034307</id>\r
+                       <id>1438864777146</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034317</id>\r
+                       <id>1438864777156</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034327</id>\r
+                       <id>1438864777166</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034337</id>\r
+                       <id>1438864777166</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034347</id>\r
+                       <id>1438864777176</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034357</id>\r
+                       <id>1438864777186</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034367</id>\r
+                       <id>1438864777206</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034367</id>\r
+                       <id>1438864777206</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034377</id>\r
+                       <id>1438864777216</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034387</id>\r
+                       <id>1438864777226</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034397</id>\r
+                       <id>1438864777226</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
                        </matcher>\r
                </filter>\r
                <filter>\r
-                       <id>1438278034407</id>\r
+                       <id>1438864777236</id>\r
                        <name>Full_Demo/Standard_Demo_Tasks/Minimal</name>\r
                        <type>5</type>\r
                        <matcher>\r
index 4218c77f85e35377fffa651bd01d03822310442a..2e531ad1886198bc0993d771493bc9b8cdfee464 100644 (file)
@@ -5,7 +5,7 @@
                        <provider copy-of="extension" id="org.eclipse.cdt.ui.UserLanguageSettingsProvider"/>\r
                        <provider-reference id="org.eclipse.cdt.core.ReferencedProjectsLanguageSettingsProvider" ref="shared-provider"/>\r
                        <provider-reference id="org.eclipse.cdt.managedbuilder.core.MBSLanguageSettingsProvider" ref="shared-provider"/>\r
-                       <provider class="org.eclipse.cdt.internal.build.crossgcc.CrossGCCBuiltinSpecsDetector" console="false" env-hash="-1521042937261237789" id="org.eclipse.cdt.build.crossgcc.CrossGCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT Cross GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD &quot;${INPUTS}&quot;" prefer-non-shared="true">\r
+                       <provider class="org.eclipse.cdt.internal.build.crossgcc.CrossGCCBuiltinSpecsDetector" console="false" env-hash="-388082630224803112" id="org.eclipse.cdt.build.crossgcc.CrossGCCBuiltinSpecsDetector" keep-relative-paths="false" name="CDT Cross GCC Built-in Compiler Settings" parameter="${COMMAND} ${FLAGS} -E -P -v -dD &quot;${INPUTS}&quot;" prefer-non-shared="true">\r
                                <language-scope id="org.eclipse.cdt.core.gcc"/>\r
                                <language-scope id="org.eclipse.cdt.core.g++"/>\r
                        </provider>\r
index 1488d1af9a131495ae650519a3d8baa76c76a739..f1be6d40ae4293dac49e2c77d2ad5e64f430fc11 100644 (file)
@@ -10,7 +10,7 @@
     <debug>1</debug>\r
     <settings>\r
       <name>C-SPY</name>\r
-      <archiveVersion>4</archiveVersion>\r
+      <archiveVersion>5</archiveVersion>\r
       <data>\r
         <version>27</version>\r
         <wantNonLocal>1</wantNonLocal>\r
@@ -57,7 +57,7 @@
         </option>\r
         <option>\r
           <name>DdfFileName</name>\r
-          <state>$TOOLKIT_DIR$\config\debugger\MSP430F5438A.ddf</state>\r
+          <state>$TOOLKIT_DIR$\config\debugger\msp430f5438a.ddf</state>\r
         </option>\r
         <option>\r
           <name>ProcTMS</name>\r
       <name>430FET</name>\r
       <archiveVersion>1</archiveVersion>\r
       <data>\r
-        <version>26</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
         </option>\r
         <option>\r
           <name>CRadioProtocolType</name>\r
-          <state>1</state>\r
+          <state>0</state>\r
         </option>\r
         <option>\r
           <name>CCRadioModuleTypeSlave</name>\r
         </option>\r
         <option>\r
           <name>FetConnection</name>\r
-          <version>2</version>\r
+          <version>4</version>\r
           <state>0</state>\r
         </option>\r
         <option>\r
           <name>memoryTypeSlave</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>fuseBlowDisabledSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>eraseTypeSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>DataSampleBpReservation</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>cycleCounterLevel</name>\r
+          <state>0</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
     </settings>\r
     <debuggerPlugins>\r
       <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\Lcd\lcd.ewplugin</file>\r
+        <file>$TOOLKIT_DIR$\plugins\lcd\lcd.ewplugin</file>\r
         <loadFlag>1</loadFlag>\r
       </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
       </plugin>\r
-      <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\rtos\PowerPac\PowerPacRTOS.ewplugin</file>\r
-        <loadFlag>0</loadFlag>\r
-      </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
     <debug>1</debug>\r
     <settings>\r
       <name>C-SPY</name>\r
-      <archiveVersion>4</archiveVersion>\r
+      <archiveVersion>5</archiveVersion>\r
       <data>\r
         <version>27</version>\r
         <wantNonLocal>1</wantNonLocal>\r
       <name>430FET</name>\r
       <archiveVersion>1</archiveVersion>\r
       <data>\r
-        <version>26</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
         </option>\r
         <option>\r
           <name>FetConnection</name>\r
-          <version>2</version>\r
+          <version>4</version>\r
           <state>0</state>\r
         </option>\r
         <option>\r
           <name>memoryTypeSlave</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>fuseBlowDisabledSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>eraseTypeSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>DataSampleBpReservation</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>cycleCounterLevel</name>\r
+          <state>0</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
     </settings>\r
     <debuggerPlugins>\r
       <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\Lcd\lcd.ewplugin</file>\r
+        <file>$TOOLKIT_DIR$\plugins\lcd\lcd.ewplugin</file>\r
         <loadFlag>1</loadFlag>\r
       </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
       </plugin>\r
-      <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\rtos\PowerPac\PowerPacRTOS.ewplugin</file>\r
-        <loadFlag>0</loadFlag>\r
-      </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
     <debug>1</debug>\r
     <settings>\r
       <name>C-SPY</name>\r
-      <archiveVersion>4</archiveVersion>\r
+      <archiveVersion>5</archiveVersion>\r
       <data>\r
         <version>27</version>\r
         <wantNonLocal>1</wantNonLocal>\r
       <name>430FET</name>\r
       <archiveVersion>1</archiveVersion>\r
       <data>\r
-        <version>26</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
         </option>\r
         <option>\r
           <name>FetConnection</name>\r
-          <version>2</version>\r
+          <version>4</version>\r
           <state>0</state>\r
         </option>\r
         <option>\r
           <name>memoryTypeSlave</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>fuseBlowDisabledSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>eraseTypeSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>DataSampleBpReservation</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>cycleCounterLevel</name>\r
+          <state>0</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
     </settings>\r
     <debuggerPlugins>\r
       <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\Lcd\lcd.ewplugin</file>\r
+        <file>$TOOLKIT_DIR$\plugins\lcd\lcd.ewplugin</file>\r
         <loadFlag>1</loadFlag>\r
       </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
       </plugin>\r
-      <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\rtos\PowerPac\PowerPacRTOS.ewplugin</file>\r
-        <loadFlag>0</loadFlag>\r
-      </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
     <debug>1</debug>\r
     <settings>\r
       <name>C-SPY</name>\r
-      <archiveVersion>4</archiveVersion>\r
+      <archiveVersion>5</archiveVersion>\r
       <data>\r
         <version>27</version>\r
         <wantNonLocal>1</wantNonLocal>\r
       <name>430FET</name>\r
       <archiveVersion>1</archiveVersion>\r
       <data>\r
-        <version>26</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
         </option>\r
         <option>\r
           <name>FetConnection</name>\r
-          <version>2</version>\r
+          <version>4</version>\r
           <state>0</state>\r
         </option>\r
         <option>\r
           <name>memoryTypeSlave</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>fuseBlowDisabledSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>eraseTypeSlave</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>DataSampleBpReservation</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>cycleCounterLevel</name>\r
+          <state>0</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
     </settings>\r
     <debuggerPlugins>\r
       <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\Lcd\lcd.ewplugin</file>\r
+        <file>$TOOLKIT_DIR$\plugins\lcd\lcd.ewplugin</file>\r
         <loadFlag>1</loadFlag>\r
       </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
       </plugin>\r
-      <plugin>\r
-        <file>$TOOLKIT_DIR$\plugins\rtos\PowerPac\PowerPacRTOS.ewplugin</file>\r
-        <loadFlag>0</loadFlag>\r
-      </plugin>\r
       <plugin>\r
         <file>$TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin</file>\r
         <loadFlag>0</loadFlag>\r
index 2bb3bd35afd76c4dd289ee0507a0133794fbb319..0febc9540b37a5387ec37a6b095f1ea65352e5f2 100644 (file)
@@ -10,9 +10,9 @@
     <debug>1</debug>\r
     <settings>\r
       <name>General</name>\r
-      <archiveVersion>14</archiveVersion>\r
+      <archiveVersion>17</archiveVersion>\r
       <data>\r
-        <version>32</version>\r
+        <version>33</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
@@ -58,7 +58,7 @@
         </option>\r
         <option>\r
           <name>RTLibraryPath</name>\r
-          <state>$TOOLKIT_DIR$\LIB\DLIB\dl430xlff.r43</state>\r
+          <state>$TOOLKIT_DIR$\lib\dlib\dl430xllff.r43</state>\r
         </option>\r
         <option>\r
           <name>Input variant</name>\r
           <name>GLockIpe</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>Math variant</name>\r
+          <version>0</version>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>Math description</name>\r
+          <state>Default variants of cos, sin, tan, log, log10, pow, and exp.</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
       <data>\r
         <extensions></extensions>\r
         <cmdline></cmdline>\r
+        <hasPrio>0</hasPrio>\r
       </data>\r
     </settings>\r
     <settings>\r
       <name>XLINK</name>\r
       <archiveVersion>4</archiveVersion>\r
       <data>\r
-        <version>27</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
         </option>\r
         <option>\r
           <name>XclOverride</name>\r
-          <state>1</state>\r
+          <state>0</state>\r
         </option>\r
         <option>\r
           <name>XclFile</name>\r
-          <state>$PROJ_DIR$\lnk430F5438A_mod.xcl</state>\r
+          <state>$TOOLKIT_DIR$\config\linker\lnk430f5438a.xcl</state>\r
         </option>\r
         <option>\r
           <name>XclFileSlave</name>\r
           <name>XlinkIPE</name>\r
           <state>1</state>\r
         </option>\r
+        <option>\r
+          <name>XlinkLogEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogInputFiles</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogModuleSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogPrintfScanf</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogSegmentSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogStackDepth</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkStackUsageEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkControlFiles</name>\r
+          <state></state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileName</name>\r
+          <state>$LIST_DIR$\$PROJ_FNAME$.call_graph.cgx</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
     <debug>1</debug>\r
     <settings>\r
       <name>General</name>\r
-      <archiveVersion>14</archiveVersion>\r
+      <archiveVersion>17</archiveVersion>\r
       <data>\r
-        <version>32</version>\r
+        <version>33</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
           <name>GLockIpe</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>Math variant</name>\r
+          <version>0</version>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>Math description</name>\r
+          <state></state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
       <data>\r
         <extensions></extensions>\r
         <cmdline></cmdline>\r
+        <hasPrio>0</hasPrio>\r
       </data>\r
     </settings>\r
     <settings>\r
       <name>XLINK</name>\r
       <archiveVersion>4</archiveVersion>\r
       <data>\r
-        <version>27</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
           <name>XlinkIPE</name>\r
           <state>1</state>\r
         </option>\r
+        <option>\r
+          <name>XlinkLogEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogInputFiles</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogModuleSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogPrintfScanf</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogSegmentSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogStackDepth</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkStackUsageEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkControlFiles</name>\r
+          <state></state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileName</name>\r
+          <state>$LIST_DIR$\$PROJ_FNAME$.call_graph.cgx</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
     <debug>1</debug>\r
     <settings>\r
       <name>General</name>\r
-      <archiveVersion>14</archiveVersion>\r
+      <archiveVersion>17</archiveVersion>\r
       <data>\r
-        <version>32</version>\r
+        <version>33</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
           <name>GLockIpe</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>Math variant</name>\r
+          <version>0</version>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>Math description</name>\r
+          <state></state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
       <data>\r
         <extensions></extensions>\r
         <cmdline></cmdline>\r
+        <hasPrio>0</hasPrio>\r
       </data>\r
     </settings>\r
     <settings>\r
       <name>XLINK</name>\r
       <archiveVersion>4</archiveVersion>\r
       <data>\r
-        <version>27</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
           <name>XlinkIPE</name>\r
           <state>1</state>\r
         </option>\r
+        <option>\r
+          <name>XlinkLogEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogInputFiles</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogModuleSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogPrintfScanf</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogSegmentSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogStackDepth</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkStackUsageEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkControlFiles</name>\r
+          <state></state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileName</name>\r
+          <state>$LIST_DIR$\$PROJ_FNAME$.call_graph.cgx</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
     <debug>1</debug>\r
     <settings>\r
       <name>General</name>\r
-      <archiveVersion>14</archiveVersion>\r
+      <archiveVersion>17</archiveVersion>\r
       <data>\r
-        <version>32</version>\r
+        <version>33</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
           <name>GLockIpe</name>\r
           <state>0</state>\r
         </option>\r
+        <option>\r
+          <name>Math variant</name>\r
+          <version>0</version>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>Math description</name>\r
+          <state></state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
       <data>\r
         <extensions></extensions>\r
         <cmdline></cmdline>\r
+        <hasPrio>0</hasPrio>\r
       </data>\r
     </settings>\r
     <settings>\r
       <name>XLINK</name>\r
       <archiveVersion>4</archiveVersion>\r
       <data>\r
-        <version>27</version>\r
+        <version>29</version>\r
         <wantNonLocal>1</wantNonLocal>\r
         <debug>1</debug>\r
         <option>\r
           <name>XlinkIPE</name>\r
           <state>1</state>\r
         </option>\r
+        <option>\r
+          <name>XlinkLogEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogInputFiles</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogModuleSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogPrintfScanf</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogSegmentSelection</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkLogStackDepth</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkStackUsageEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkControlFiles</name>\r
+          <state></state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileEnable</name>\r
+          <state>0</state>\r
+        </option>\r
+        <option>\r
+          <name>XlinkCallGraphFileName</name>\r
+          <state>$LIST_DIR$\$PROJ_FNAME$.call_graph.cgx</state>\r
+        </option>\r
       </data>\r
     </settings>\r
     <settings>\r
index 55b6aadb4e837c27c9a1707345d66718cb73fa08..dc279528642c2c83e8b568e73ccaf11c92f6058f 100644 (file)
@@ -8,6 +8,970 @@
       <name>MSP430</name>\r
     </toolchain>\r
     <debug>1</debug>\r
+    <settings>\r
+      <name>C-STAT</name>\r
+      <archiveVersion>1</archiveVersion>\r
+      <data>\r
+        <cstatsettings>\r
+          <package checked="true" name="STDCHECKS">\r
+            <group checked="true" name="ARR">\r
+              <check checked="true" name="ARR-inv-index-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr"/>\r
+              <check checked="true" name="ARR-inv-index"/>\r
+              <check checked="true" name="ARR-neg-index"/>\r
+              <check checked="true" name="ARR-uninit-index"/>\r
+            </group>\r
+            <group checked="true" name="ATH">\r
+              <check checked="true" name="ATH-cmp-float"/>\r
+              <check checked="true" name="ATH-cmp-unsign-neg"/>\r
+              <check checked="true" name="ATH-cmp-unsign-pos"/>\r
+              <check checked="true" name="ATH-div-0-assign"/>\r
+              <check checked="true" name="ATH-div-0-cmp-aft"/>\r
+              <check checked="true" name="ATH-div-0-cmp-bef"/>\r
+              <check checked="true" name="ATH-div-0-interval"/>\r
+              <check checked="true" name="ATH-div-0-pos"/>\r
+              <check checked="true" name="ATH-div-0-unchk-global"/>\r
+              <check checked="true" name="ATH-div-0-unchk-local"/>\r
+              <check checked="true" name="ATH-div-0-unchk-param"/>\r
+              <check checked="true" name="ATH-div-0"/>\r
+              <check checked="true" name="ATH-inc-bool"/>\r
+              <check checked="true" name="ATH-malloc-overrun"/>\r
+              <check checked="true" name="ATH-neg-check-nonneg"/>\r
+              <check checked="true" name="ATH-neg-check-pos"/>\r
+              <check checked="true" name="ATH-new-overrun"/>\r
+              <check checked="false" name="ATH-overflow-cast"/>\r
+              <check checked="true" name="ATH-overflow"/>\r
+              <check checked="true" name="ATH-shift-bounds"/>\r
+              <check checked="true" name="ATH-shift-neg"/>\r
+              <check checked="true" name="ATH-sizeof-by-sizeof"/>\r
+            </group>\r
+            <group checked="true" name="CAST">\r
+              <check checked="false" name="CAST-old-style"/>\r
+            </group>\r
+            <group checked="true" name="CATCH">\r
+              <check checked="true" name="CATCH-object-slicing"/>\r
+              <check checked="false" name="CATCH-xtor-bad-member"/>\r
+            </group>\r
+            <group checked="true" name="COMMA">\r
+              <check checked="false" name="COMMA-overload"/>\r
+            </group>\r
+            <group checked="true" name="COMMENT">\r
+              <check checked="true" name="COMMENT-nested"/>\r
+            </group>\r
+            <group checked="false" name="CONCURRENCY">\r
+              <check checked="true" name="CONCURRENCY-double-lock"/>\r
+              <check checked="true" name="CONCURRENCY-double-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-lock-no-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-sleep-while-locking"/>\r
+            </group>\r
+            <group checked="true" name="CONST">\r
+              <check checked="false" name="CONST-local"/>\r
+              <check checked="true" name="CONST-member-ret"/>\r
+              <check checked="false" name="CONST-param"/>\r
+            </group>\r
+            <group checked="true" name="COP">\r
+              <check checked="true" name="COP-alloc-ctor"/>\r
+              <check checked="true" name="COP-assign-op-ret"/>\r
+              <check checked="true" name="COP-assign-op-self"/>\r
+              <check checked="true" name="COP-assign-op"/>\r
+              <check checked="true" name="COP-copy-ctor"/>\r
+              <check checked="true" name="COP-dealloc-dtor"/>\r
+              <check checked="true" name="COP-dtor-throw"/>\r
+              <check checked="true" name="COP-dtor"/>\r
+              <check checked="true" name="COP-init-order"/>\r
+              <check checked="true" name="COP-init-uninit"/>\r
+              <check checked="true" name="COP-member-uninit"/>\r
+            </group>\r
+            <group checked="true" name="CPU">\r
+              <check checked="true" name="CPU-ctor-call-virt"/>\r
+              <check checked="false" name="CPU-ctor-implicit"/>\r
+              <check checked="true" name="CPU-delete-throw"/>\r
+              <check checked="true" name="CPU-delete-void"/>\r
+              <check checked="true" name="CPU-dtor-call-virt"/>\r
+              <check checked="true" name="CPU-malloc-class"/>\r
+              <check checked="true" name="CPU-nonvirt-dtor"/>\r
+              <check checked="true" name="CPU-return-ref-to-class-data"/>\r
+            </group>\r
+            <group checked="true" name="DECL">\r
+              <check checked="false" name="DECL-implicit-int"/>\r
+            </group>\r
+            <group checked="true" name="DEFINE">\r
+              <check checked="true" name="DEFINE-hash-multiple"/>\r
+            </group>\r
+            <group checked="true" name="ENUM">\r
+              <check checked="false" name="ENUM-bounds"/>\r
+            </group>\r
+            <group checked="true" name="EXP">\r
+              <check checked="true" name="EXP-cond-assign"/>\r
+              <check checked="true" name="EXP-dangling-else"/>\r
+              <check checked="true" name="EXP-loop-exit"/>\r
+              <check checked="false" name="EXP-main-ret-int"/>\r
+              <check checked="false" name="EXP-null-stmt"/>\r
+              <check checked="false" name="EXP-stray-semicolon"/>\r
+            </group>\r
+            <group checked="true" name="EXPR">\r
+              <check checked="true" name="EXPR-const-overflow"/>\r
+            </group>\r
+            <group checked="true" name="FPT">\r
+              <check checked="true" name="FPT-arith-address"/>\r
+              <check checked="true" name="FPT-arith"/>\r
+              <check checked="true" name="FPT-cmp-null"/>\r
+              <check checked="false" name="FPT-literal"/>\r
+              <check checked="true" name="FPT-misuse"/>\r
+            </group>\r
+            <group checked="true" name="FUNC">\r
+              <check checked="false" name="FUNC-implicit-decl"/>\r
+              <check checked="false" name="FUNC-unprototyped-all"/>\r
+              <check checked="true" name="FUNC-unprototyped-used"/>\r
+            </group>\r
+            <group checked="true" name="IDENT">\r
+              <check checked="false" name="IDENT-long-scope-31-chars"/>\r
+              <check checked="false" name="IDENT-long-scope-63-chars"/>\r
+            </group>\r
+            <group checked="true" name="INCLUDE">\r
+              <check checked="false" name="INCLUDE-c-file"/>\r
+            </group>\r
+            <group checked="true" name="INT">\r
+              <check checked="false" name="INT-use-signed-as-unsigned-pos"/>\r
+              <check checked="true" name="INT-use-signed-as-unsigned"/>\r
+            </group>\r
+            <group checked="true" name="ITR">\r
+              <check checked="true" name="ITR-end-cmp-aft"/>\r
+              <check checked="true" name="ITR-end-cmp-bef"/>\r
+              <check checked="true" name="ITR-invalidated"/>\r
+              <check checked="true" name="ITR-mismatch-alg"/>\r
+              <check checked="true" name="ITR-store"/>\r
+              <check checked="true" name="ITR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="LIB">\r
+              <check checked="false" name="LIB-bsearch-overrun-pos"/>\r
+              <check checked="false" name="LIB-bsearch-overrun"/>\r
+              <check checked="false" name="LIB-buf-size"/>\r
+              <check checked="false" name="LIB-fn-unsafe"/>\r
+              <check checked="false" name="LIB-fread-overrun-pos"/>\r
+              <check checked="true" name="LIB-fread-overrun"/>\r
+              <check checked="false" name="LIB-memchr-overrun-pos"/>\r
+              <check checked="true" name="LIB-memchr-overrun"/>\r
+              <check checked="false" name="LIB-memcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-memcpy-overrun"/>\r
+              <check checked="false" name="LIB-memset-overrun-pos"/>\r
+              <check checked="true" name="LIB-memset-overrun"/>\r
+              <check checked="false" name="LIB-putenv"/>\r
+              <check checked="false" name="LIB-qsort-overrun-pos"/>\r
+              <check checked="false" name="LIB-qsort-overrun"/>\r
+              <check checked="true" name="LIB-return-const"/>\r
+              <check checked="true" name="LIB-return-error"/>\r
+              <check checked="true" name="LIB-return-leak"/>\r
+              <check checked="true" name="LIB-return-neg"/>\r
+              <check checked="true" name="LIB-return-null"/>\r
+              <check checked="false" name="LIB-sprintf-overrun"/>\r
+              <check checked="false" name="LIB-std-sort-overrun-pos"/>\r
+              <check checked="true" name="LIB-std-sort-overrun"/>\r
+              <check checked="false" name="LIB-strcat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcat-overrun"/>\r
+              <check checked="false" name="LIB-strcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcpy-overrun"/>\r
+              <check checked="false" name="LIB-strncat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncat-overrun"/>\r
+              <check checked="false" name="LIB-strncmp-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncmp-overrun"/>\r
+              <check checked="false" name="LIB-strncpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncpy-overrun"/>\r
+            </group>\r
+            <group checked="true" name="LOGIC">\r
+              <check checked="false" name="LOGIC-overload"/>\r
+            </group>\r
+            <group checked="true" name="MEM">\r
+              <check checked="true" name="MEM-alias-double-free"/>\r
+              <check checked="true" name="MEM-delete-array-op"/>\r
+              <check checked="true" name="MEM-delete-op"/>\r
+              <check checked="true" name="MEM-double-free-alias"/>\r
+              <check checked="true" name="MEM-double-free-some"/>\r
+              <check checked="true" name="MEM-double-free"/>\r
+              <check checked="true" name="MEM-free-field"/>\r
+              <check checked="true" name="MEM-free-fptr"/>\r
+              <check checked="false" name="MEM-free-no-alloc-struct"/>\r
+              <check checked="true" name="MEM-free-no-alloc"/>\r
+              <check checked="true" name="MEM-free-no-use"/>\r
+              <check checked="true" name="MEM-free-op"/>\r
+              <check checked="true" name="MEM-free-struct-field"/>\r
+              <check checked="true" name="MEM-free-variable-alias"/>\r
+              <check checked="true" name="MEM-free-variable"/>\r
+              <check checked="true" name="MEM-leak-alias"/>\r
+              <check checked="false" name="MEM-leak"/>\r
+              <check checked="false" name="MEM-malloc-arith"/>\r
+              <check checked="true" name="MEM-malloc-diff-type"/>\r
+              <check checked="true" name="MEM-malloc-sizeof-ptr"/>\r
+              <check checked="true" name="MEM-malloc-sizeof"/>\r
+              <check checked="false" name="MEM-malloc-strlen"/>\r
+              <check checked="true" name="MEM-realloc-diff-type"/>\r
+              <check checked="true" name="MEM-return-free"/>\r
+              <check checked="true" name="MEM-return-no-assign"/>\r
+              <check checked="true" name="MEM-stack-alias"/>\r
+              <check checked="true" name="MEM-stack-global-alias"/>\r
+              <check checked="true" name="MEM-stack-global-field"/>\r
+              <check checked="true" name="MEM-stack-global"/>\r
+              <check checked="true" name="MEM-stack-param-ref"/>\r
+              <check checked="true" name="MEM-stack-param"/>\r
+              <check checked="true" name="MEM-stack-pos"/>\r
+              <check checked="true" name="MEM-stack-ref"/>\r
+              <check checked="true" name="MEM-stack"/>\r
+              <check checked="true" name="MEM-use-free-all"/>\r
+              <check checked="true" name="MEM-use-free-some"/>\r
+            </group>\r
+            <group checked="true" name="POR">\r
+              <check checked="true" name="POR-imp-cast-subscript"/>\r
+              <check checked="false" name="POR-imp-cast-ternary"/>\r
+            </group>\r
+            <group checked="true" name="PTR">\r
+              <check checked="true" name="PTR-alias-null-pos-deref"/>\r
+              <check checked="true" name="PTR-arith-field"/>\r
+              <check checked="true" name="PTR-arith-stack"/>\r
+              <check checked="true" name="PTR-arith-var"/>\r
+              <check checked="true" name="PTR-cmp-str-lit"/>\r
+              <check checked="true" name="PTR-null-assign-fun-pos"/>\r
+              <check checked="true" name="PTR-null-assign-pos"/>\r
+              <check checked="true" name="PTR-null-assign"/>\r
+              <check checked="true" name="PTR-null-cmp-aft"/>\r
+              <check checked="true" name="PTR-null-cmp-bef-fun"/>\r
+              <check checked="true" name="PTR-null-cmp-bef"/>\r
+              <check checked="true" name="PTR-null-fun-pos"/>\r
+              <check checked="true" name="PTR-null-literal-pos"/>\r
+              <check checked="false" name="PTR-overload"/>\r
+              <check checked="true" name="PTR-singleton-arith-pos"/>\r
+              <check checked="true" name="PTR-singleton-arith"/>\r
+              <check checked="true" name="PTR-unchk-param-some"/>\r
+              <check checked="false" name="PTR-unchk-param"/>\r
+              <check checked="true" name="PTR-uninit-pos"/>\r
+              <check checked="true" name="PTR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="RED">\r
+              <check checked="false" name="RED-case-reach"/>\r
+              <check checked="false" name="RED-cmp-always"/>\r
+              <check checked="false" name="RED-cmp-never"/>\r
+              <check checked="false" name="RED-cond-always"/>\r
+              <check checked="true" name="RED-cond-const-assign"/>\r
+              <check checked="false" name="RED-cond-const-expr"/>\r
+              <check checked="false" name="RED-cond-const"/>\r
+              <check checked="false" name="RED-cond-never"/>\r
+              <check checked="true" name="RED-dead"/>\r
+              <check checked="false" name="RED-expr"/>\r
+              <check checked="false" name="RED-func-no-effect"/>\r
+              <check checked="true" name="RED-local-hides-global"/>\r
+              <check checked="true" name="RED-local-hides-local"/>\r
+              <check checked="true" name="RED-local-hides-member"/>\r
+              <check checked="true" name="RED-local-hides-param"/>\r
+              <check checked="false" name="RED-no-effect"/>\r
+              <check checked="true" name="RED-self-assign"/>\r
+              <check checked="true" name="RED-unused-assign"/>\r
+              <check checked="false" name="RED-unused-param"/>\r
+              <check checked="false" name="RED-unused-return-val"/>\r
+              <check checked="false" name="RED-unused-val"/>\r
+              <check checked="true" name="RED-unused-var-all"/>\r
+            </group>\r
+            <group checked="true" name="RESOURCE">\r
+              <check checked="false" name="RESOURCE-deref-file"/>\r
+              <check checked="true" name="RESOURCE-double-close"/>\r
+              <check checked="true" name="RESOURCE-file-no-close-all"/>\r
+              <check checked="false" name="RESOURCE-file-pos-neg"/>\r
+              <check checked="true" name="RESOURCE-file-use-after-close"/>\r
+              <check checked="false" name="RESOURCE-implicit-deref-file"/>\r
+              <check checked="true" name="RESOURCE-write-ronly-file"/>\r
+            </group>\r
+            <group checked="true" name="SEM">\r
+              <check checked="false" name="SEM-const-call"/>\r
+              <check checked="false" name="SEM-const-global"/>\r
+              <check checked="false" name="SEM-pure-call"/>\r
+              <check checked="false" name="SEM-pure-global"/>\r
+            </group>\r
+            <group checked="true" name="SIZEOF">\r
+              <check checked="true" name="SIZEOF-side-effect"/>\r
+            </group>\r
+            <group checked="true" name="SPC">\r
+              <check checked="false" name="SPC-init-list"/>\r
+              <check checked="true" name="SPC-order"/>\r
+              <check checked="true" name="SPC-return"/>\r
+              <check checked="true" name="SPC-uninit-arr-all"/>\r
+              <check checked="true" name="SPC-uninit-struct-field-heap"/>\r
+              <check checked="true" name="SPC-uninit-struct-field"/>\r
+              <check checked="true" name="SPC-uninit-struct"/>\r
+              <check checked="true" name="SPC-uninit-var-all"/>\r
+              <check checked="true" name="SPC-uninit-var-some"/>\r
+              <check checked="false" name="SPC-volatile-reads"/>\r
+              <check checked="false" name="SPC-volatile-writes"/>\r
+            </group>\r
+            <group checked="true" name="STR">\r
+              <check checked="true" name="STR-trigraph"/>\r
+            </group>\r
+            <group checked="true" name="STRUCT">\r
+              <check checked="false" name="STRUCT-signed-bit"/>\r
+            </group>\r
+            <group checked="true" name="SWITCH">\r
+              <check checked="true" name="SWITCH-fall-through"/>\r
+            </group>\r
+            <group checked="true" name="THROW">\r
+              <check checked="false" name="THROW-empty"/>\r
+              <check checked="false" name="THROW-main"/>\r
+              <check checked="true" name="THROW-null"/>\r
+              <check checked="true" name="THROW-ptr"/>\r
+              <check checked="true" name="THROW-static"/>\r
+              <check checked="true" name="THROW-unhandled"/>\r
+            </group>\r
+            <group checked="true" name="UNION">\r
+              <check checked="true" name="UNION-overlap-assign"/>\r
+              <check checked="true" name="UNION-type-punning"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2004">\r
+            <group checked="true" name="MISRAC2004-1">\r
+              <check checked="true" name="MISRAC2004-1.1"/>\r
+              <check checked="true" name="MISRAC2004-1.2_a"/>\r
+              <check checked="true" name="MISRAC2004-1.2_b"/>\r
+              <check checked="true" name="MISRAC2004-1.2_c"/>\r
+              <check checked="true" name="MISRAC2004-1.2_d"/>\r
+              <check checked="true" name="MISRAC2004-1.2_e"/>\r
+              <check checked="true" name="MISRAC2004-1.2_f"/>\r
+              <check checked="true" name="MISRAC2004-1.2_g"/>\r
+              <check checked="true" name="MISRAC2004-1.2_h"/>\r
+              <check checked="true" name="MISRAC2004-1.2_i"/>\r
+              <check checked="true" name="MISRAC2004-1.2_j"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-10">\r
+              <check checked="true" name="MISRAC2004-10.1_a"/>\r
+              <check checked="true" name="MISRAC2004-10.1_b"/>\r
+              <check checked="true" name="MISRAC2004-10.1_c"/>\r
+              <check checked="true" name="MISRAC2004-10.1_d"/>\r
+              <check checked="true" name="MISRAC2004-10.2_a"/>\r
+              <check checked="true" name="MISRAC2004-10.2_b"/>\r
+              <check checked="true" name="MISRAC2004-10.2_c"/>\r
+              <check checked="true" name="MISRAC2004-10.2_d"/>\r
+              <check checked="true" name="MISRAC2004-10.3"/>\r
+              <check checked="true" name="MISRAC2004-10.4"/>\r
+              <check checked="true" name="MISRAC2004-10.5"/>\r
+              <check checked="true" name="MISRAC2004-10.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-11">\r
+              <check checked="true" name="MISRAC2004-11.1"/>\r
+              <check checked="false" name="MISRAC2004-11.3"/>\r
+              <check checked="false" name="MISRAC2004-11.4"/>\r
+              <check checked="true" name="MISRAC2004-11.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-12">\r
+              <check checked="false" name="MISRAC2004-12.1"/>\r
+              <check checked="true" name="MISRAC2004-12.10"/>\r
+              <check checked="false" name="MISRAC2004-12.11"/>\r
+              <check checked="true" name="MISRAC2004-12.12_a"/>\r
+              <check checked="true" name="MISRAC2004-12.12_b"/>\r
+              <check checked="false" name="MISRAC2004-12.13"/>\r
+              <check checked="true" name="MISRAC2004-12.2_a"/>\r
+              <check checked="true" name="MISRAC2004-12.2_b"/>\r
+              <check checked="true" name="MISRAC2004-12.2_c"/>\r
+              <check checked="true" name="MISRAC2004-12.3"/>\r
+              <check checked="true" name="MISRAC2004-12.4"/>\r
+              <check checked="false" name="MISRAC2004-12.6_a"/>\r
+              <check checked="false" name="MISRAC2004-12.6_b"/>\r
+              <check checked="true" name="MISRAC2004-12.7"/>\r
+              <check checked="true" name="MISRAC2004-12.8"/>\r
+              <check checked="true" name="MISRAC2004-12.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-13">\r
+              <check checked="true" name="MISRAC2004-13.1"/>\r
+              <check checked="false" name="MISRAC2004-13.2_a"/>\r
+              <check checked="false" name="MISRAC2004-13.2_b"/>\r
+              <check checked="false" name="MISRAC2004-13.2_c"/>\r
+              <check checked="false" name="MISRAC2004-13.2_d"/>\r
+              <check checked="false" name="MISRAC2004-13.2_e"/>\r
+              <check checked="true" name="MISRAC2004-13.3"/>\r
+              <check checked="true" name="MISRAC2004-13.4"/>\r
+              <check checked="true" name="MISRAC2004-13.5"/>\r
+              <check checked="true" name="MISRAC2004-13.6"/>\r
+              <check checked="true" name="MISRAC2004-13.7_a"/>\r
+              <check checked="true" name="MISRAC2004-13.7_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-14">\r
+              <check checked="true" name="MISRAC2004-14.1"/>\r
+              <check checked="true" name="MISRAC2004-14.10"/>\r
+              <check checked="true" name="MISRAC2004-14.2"/>\r
+              <check checked="true" name="MISRAC2004-14.3"/>\r
+              <check checked="true" name="MISRAC2004-14.4"/>\r
+              <check checked="true" name="MISRAC2004-14.5"/>\r
+              <check checked="true" name="MISRAC2004-14.6"/>\r
+              <check checked="true" name="MISRAC2004-14.7"/>\r
+              <check checked="true" name="MISRAC2004-14.8_a"/>\r
+              <check checked="true" name="MISRAC2004-14.8_b"/>\r
+              <check checked="true" name="MISRAC2004-14.8_c"/>\r
+              <check checked="true" name="MISRAC2004-14.8_d"/>\r
+              <check checked="true" name="MISRAC2004-14.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-15">\r
+              <check checked="true" name="MISRAC2004-15.0"/>\r
+              <check checked="true" name="MISRAC2004-15.1"/>\r
+              <check checked="true" name="MISRAC2004-15.2"/>\r
+              <check checked="true" name="MISRAC2004-15.3"/>\r
+              <check checked="true" name="MISRAC2004-15.4"/>\r
+              <check checked="true" name="MISRAC2004-15.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-16">\r
+              <check checked="true" name="MISRAC2004-16.1"/>\r
+              <check checked="true" name="MISRAC2004-16.10"/>\r
+              <check checked="true" name="MISRAC2004-16.2_a"/>\r
+              <check checked="true" name="MISRAC2004-16.2_b"/>\r
+              <check checked="true" name="MISRAC2004-16.3"/>\r
+              <check checked="true" name="MISRAC2004-16.5"/>\r
+              <check checked="true" name="MISRAC2004-16.7"/>\r
+              <check checked="true" name="MISRAC2004-16.8"/>\r
+              <check checked="true" name="MISRAC2004-16.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-17">\r
+              <check checked="true" name="MISRAC2004-17.1_a"/>\r
+              <check checked="true" name="MISRAC2004-17.1_b"/>\r
+              <check checked="true" name="MISRAC2004-17.1_c"/>\r
+              <check checked="true" name="MISRAC2004-17.4_a"/>\r
+              <check checked="true" name="MISRAC2004-17.4_b"/>\r
+              <check checked="true" name="MISRAC2004-17.5"/>\r
+              <check checked="true" name="MISRAC2004-17.6_a"/>\r
+              <check checked="true" name="MISRAC2004-17.6_b"/>\r
+              <check checked="true" name="MISRAC2004-17.6_c"/>\r
+              <check checked="true" name="MISRAC2004-17.6_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-18">\r
+              <check checked="true" name="MISRAC2004-18.1"/>\r
+              <check checked="true" name="MISRAC2004-18.2"/>\r
+              <check checked="true" name="MISRAC2004-18.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-19">\r
+              <check checked="true" name="MISRAC2004-19.12"/>\r
+              <check checked="false" name="MISRAC2004-19.13"/>\r
+              <check checked="true" name="MISRAC2004-19.15"/>\r
+              <check checked="false" name="MISRAC2004-19.2"/>\r
+              <check checked="true" name="MISRAC2004-19.6"/>\r
+              <check checked="false" name="MISRAC2004-19.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-2">\r
+              <check checked="true" name="MISRAC2004-2.1"/>\r
+              <check checked="true" name="MISRAC2004-2.2"/>\r
+              <check checked="true" name="MISRAC2004-2.3"/>\r
+              <check checked="false" name="MISRAC2004-2.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-20">\r
+              <check checked="true" name="MISRAC2004-20.1"/>\r
+              <check checked="true" name="MISRAC2004-20.10"/>\r
+              <check checked="true" name="MISRAC2004-20.11"/>\r
+              <check checked="true" name="MISRAC2004-20.12"/>\r
+              <check checked="true" name="MISRAC2004-20.4"/>\r
+              <check checked="true" name="MISRAC2004-20.5"/>\r
+              <check checked="true" name="MISRAC2004-20.6"/>\r
+              <check checked="true" name="MISRAC2004-20.7"/>\r
+              <check checked="true" name="MISRAC2004-20.8"/>\r
+              <check checked="true" name="MISRAC2004-20.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-4">\r
+              <check checked="true" name="MISRAC2004-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-5">\r
+              <check checked="true" name="MISRAC2004-5.1"/>\r
+              <check checked="true" name="MISRAC2004-5.2_a"/>\r
+              <check checked="true" name="MISRAC2004-5.2_b"/>\r
+              <check checked="true" name="MISRAC2004-5.2_c"/>\r
+              <check checked="true" name="MISRAC2004-5.3"/>\r
+              <check checked="true" name="MISRAC2004-5.4"/>\r
+              <check checked="false" name="MISRAC2004-5.5"/>\r
+              <check checked="false" name="MISRAC2004-5.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-6">\r
+              <check checked="true" name="MISRAC2004-6.1"/>\r
+              <check checked="false" name="MISRAC2004-6.3"/>\r
+              <check checked="true" name="MISRAC2004-6.4"/>\r
+              <check checked="true" name="MISRAC2004-6.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-7">\r
+              <check checked="true" name="MISRAC2004-7.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-8">\r
+              <check checked="true" name="MISRAC2004-8.1"/>\r
+              <check checked="true" name="MISRAC2004-8.12"/>\r
+              <check checked="true" name="MISRAC2004-8.2"/>\r
+              <check checked="true" name="MISRAC2004-8.5_a"/>\r
+              <check checked="true" name="MISRAC2004-8.5_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-9">\r
+              <check checked="true" name="MISRAC2004-9.1_a"/>\r
+              <check checked="true" name="MISRAC2004-9.1_b"/>\r
+              <check checked="true" name="MISRAC2004-9.1_c"/>\r
+              <check checked="true" name="MISRAC2004-9.2"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2012">\r
+            <group checked="true" name="MISRAC2012-Dir-4">\r
+              <check checked="true" name="MISRAC2012-Dir-4.10"/>\r
+              <check checked="true" name="MISRAC2012-Dir-4.3"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.4"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_a"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_b"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-1">\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_g"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_h"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-10">\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-11">\r
+              <check checked="true" name="MISRAC2012-Rule-11.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-11.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-12">\r
+              <check checked="false" name="MISRAC2012-Rule-12.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-12.2"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-13">\r
+              <check checked="true" name="MISRAC2012-Rule-13.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_a"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-14">\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-15">\r
+              <check checked="false" name="MISRAC2012-Rule-15.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.4"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-16">\r
+              <check checked="true" name="MISRAC2012-Rule-16.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-17">\r
+              <check checked="true" name="MISRAC2012-Rule-17.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-18">\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_d"/>\r
+              <check checked="false" name="MISRAC2012-Rule-18.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-19">\r
+              <check checked="true" name="MISRAC2012-Rule-19.1"/>\r
+              <check checked="false" name="MISRAC2012-Rule-19.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-2">\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-2.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-20">\r
+              <check checked="false" name="MISRAC2012-Rule-20.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c99"/>\r
+              <check checked="false" name="MISRAC2012-Rule-20.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-21">\r
+              <check checked="true" name="MISRAC2012-Rule-21.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-22">\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-3">\r
+              <check checked="true" name="MISRAC2012-Rule-3.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-4">\r
+              <check checked="false" name="MISRAC2012-Rule-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-5">\r
+              <check checked="true" name="MISRAC2012-Rule-5.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-6">\r
+              <check checked="true" name="MISRAC2012-Rule-6.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-6.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-7">\r
+              <check checked="true" name="MISRAC2012-Rule-7.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-8">\r
+              <check checked="true" name="MISRAC2012-Rule-8.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.10"/>\r
+              <check checked="false" name="MISRAC2012-Rule-8.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.14"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-9">\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_b"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC++2008">\r
+            <group checked="true" name="MISRAC++2008-0-1">\r
+              <check checked="true" name="MISRAC++2008-0-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-11"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-3"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-4"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-6"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-7"/>\r
+              <check checked="false" name="MISRAC++2008-0-1-8"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-2">\r
+              <check checked="true" name="MISRAC++2008-0-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-3">\r
+              <check checked="true" name="MISRAC++2008-0-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-12-1">\r
+              <check checked="true" name="MISRAC++2008-12-1-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-0">\r
+              <check checked="false" name="MISRAC++2008-15-0-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-1">\r
+              <check checked="true" name="MISRAC++2008-15-1-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-3">\r
+              <check checked="true" name="MISRAC++2008-15-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-15-3-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-4"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-5">\r
+              <check checked="true" name="MISRAC++2008-15-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-0">\r
+              <check checked="true" name="MISRAC++2008-16-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-0-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-2">\r
+              <check checked="true" name="MISRAC++2008-16-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-4"/>\r
+              <check checked="false" name="MISRAC++2008-16-2-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-3">\r
+              <check checked="true" name="MISRAC++2008-16-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-16-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-17-0">\r
+              <check checked="true" name="MISRAC++2008-17-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-0">\r
+              <check checked="true" name="MISRAC++2008-18-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-2">\r
+              <check checked="true" name="MISRAC++2008-18-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-4">\r
+              <check checked="true" name="MISRAC++2008-18-4-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-7">\r
+              <check checked="true" name="MISRAC++2008-18-7-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-19-3">\r
+              <check checked="true" name="MISRAC++2008-19-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-10">\r
+              <check checked="true" name="MISRAC++2008-2-10-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_d"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-4"/>\r
+              <check checked="false" name="MISRAC++2008-2-10-5"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-6_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-13">\r
+              <check checked="true" name="MISRAC++2008-2-13-2"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-3">\r
+              <check checked="true" name="MISRAC++2008-2-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-7">\r
+              <check checked="true" name="MISRAC++2008-2-7-1"/>\r
+              <check checked="true" name="MISRAC++2008-2-7-2"/>\r
+              <check checked="false" name="MISRAC++2008-2-7-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-27-0">\r
+              <check checked="true" name="MISRAC++2008-27-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-1">\r
+              <check checked="true" name="MISRAC++2008-3-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-3-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-9">\r
+              <check checked="false" name="MISRAC++2008-3-9-2"/>\r
+              <check checked="true" name="MISRAC++2008-3-9-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-4-5">\r
+              <check checked="true" name="MISRAC++2008-4-5-1"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-0">\r
+              <check checked="true" name="MISRAC++2008-5-0-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-14"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_e"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_f"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-19"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_c"/>\r
+              <check checked="false" name="MISRAC++2008-5-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-21"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-7"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-8"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-14">\r
+              <check checked="true" name="MISRAC++2008-5-14-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-18">\r
+              <check checked="true" name="MISRAC++2008-5-18-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-19">\r
+              <check checked="false" name="MISRAC++2008-5-19-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-2">\r
+              <check checked="false" name="MISRAC++2008-5-2-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-7"/>\r
+              <check checked="false" name="MISRAC++2008-5-2-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-3">\r
+              <check checked="true" name="MISRAC++2008-5-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-8">\r
+              <check checked="true" name="MISRAC++2008-5-8-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-2">\r
+              <check checked="true" name="MISRAC++2008-6-2-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-3">\r
+              <check checked="true" name="MISRAC++2008-6-3-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-4">\r
+              <check checked="true" name="MISRAC++2008-6-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-6"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-7"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-5">\r
+              <check checked="true" name="MISRAC++2008-6-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-6">\r
+              <check checked="true" name="MISRAC++2008-6-6-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-1">\r
+              <check checked="true" name="MISRAC++2008-7-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-7-1-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-2">\r
+              <check checked="true" name="MISRAC++2008-7-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-4">\r
+              <check checked="true" name="MISRAC++2008-7-4-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-5">\r
+              <check checked="true" name="MISRAC++2008-7-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_d"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_a"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-0">\r
+              <check checked="true" name="MISRAC++2008-8-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-4">\r
+              <check checked="true" name="MISRAC++2008-8-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-5">\r
+              <check checked="true" name="MISRAC++2008-8-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-3">\r
+              <check checked="true" name="MISRAC++2008-9-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-9-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-5">\r
+              <check checked="true" name="MISRAC++2008-9-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-6">\r
+              <check checked="true" name="MISRAC++2008-9-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-3"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-4"/>\r
+            </group>\r
+          </package>\r
+        </cstatsettings>\r
+      </data>\r
+    </settings>\r
   </configuration>\r
   <configuration>\r
     <name>Release_Large_Data_Model</name>\r
       <name>MSP430</name>\r
     </toolchain>\r
     <debug>1</debug>\r
+    <settings>\r
+      <name>C-STAT</name>\r
+      <archiveVersion>1</archiveVersion>\r
+      <data>\r
+        <cstatsettings>\r
+          <package checked="true" name="STDCHECKS">\r
+            <group checked="true" name="ARR">\r
+              <check checked="true" name="ARR-inv-index-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr"/>\r
+              <check checked="true" name="ARR-inv-index"/>\r
+              <check checked="true" name="ARR-neg-index"/>\r
+              <check checked="true" name="ARR-uninit-index"/>\r
+            </group>\r
+            <group checked="true" name="ATH">\r
+              <check checked="true" name="ATH-cmp-float"/>\r
+              <check checked="true" name="ATH-cmp-unsign-neg"/>\r
+              <check checked="true" name="ATH-cmp-unsign-pos"/>\r
+              <check checked="true" name="ATH-div-0-assign"/>\r
+              <check checked="true" name="ATH-div-0-cmp-aft"/>\r
+              <check checked="true" name="ATH-div-0-cmp-bef"/>\r
+              <check checked="true" name="ATH-div-0-interval"/>\r
+              <check checked="true" name="ATH-div-0-pos"/>\r
+              <check checked="true" name="ATH-div-0-unchk-global"/>\r
+              <check checked="true" name="ATH-div-0-unchk-local"/>\r
+              <check checked="true" name="ATH-div-0-unchk-param"/>\r
+              <check checked="true" name="ATH-div-0"/>\r
+              <check checked="true" name="ATH-inc-bool"/>\r
+              <check checked="true" name="ATH-malloc-overrun"/>\r
+              <check checked="true" name="ATH-neg-check-nonneg"/>\r
+              <check checked="true" name="ATH-neg-check-pos"/>\r
+              <check checked="true" name="ATH-new-overrun"/>\r
+              <check checked="false" name="ATH-overflow-cast"/>\r
+              <check checked="true" name="ATH-overflow"/>\r
+              <check checked="true" name="ATH-shift-bounds"/>\r
+              <check checked="true" name="ATH-shift-neg"/>\r
+              <check checked="true" name="ATH-sizeof-by-sizeof"/>\r
+            </group>\r
+            <group checked="true" name="CAST">\r
+              <check checked="false" name="CAST-old-style"/>\r
+            </group>\r
+            <group checked="true" name="CATCH">\r
+              <check checked="true" name="CATCH-object-slicing"/>\r
+              <check checked="false" name="CATCH-xtor-bad-member"/>\r
+            </group>\r
+            <group checked="true" name="COMMA">\r
+              <check checked="false" name="COMMA-overload"/>\r
+            </group>\r
+            <group checked="true" name="COMMENT">\r
+              <check checked="true" name="COMMENT-nested"/>\r
+            </group>\r
+            <group checked="false" name="CONCURRENCY">\r
+              <check checked="true" name="CONCURRENCY-double-lock"/>\r
+              <check checked="true" name="CONCURRENCY-double-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-lock-no-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-sleep-while-locking"/>\r
+            </group>\r
+            <group checked="true" name="CONST">\r
+              <check checked="false" name="CONST-local"/>\r
+              <check checked="true" name="CONST-member-ret"/>\r
+              <check checked="false" name="CONST-param"/>\r
+            </group>\r
+            <group checked="true" name="COP">\r
+              <check checked="true" name="COP-alloc-ctor"/>\r
+              <check checked="true" name="COP-assign-op-ret"/>\r
+              <check checked="true" name="COP-assign-op-self"/>\r
+              <check checked="true" name="COP-assign-op"/>\r
+              <check checked="true" name="COP-copy-ctor"/>\r
+              <check checked="true" name="COP-dealloc-dtor"/>\r
+              <check checked="true" name="COP-dtor-throw"/>\r
+              <check checked="true" name="COP-dtor"/>\r
+              <check checked="true" name="COP-init-order"/>\r
+              <check checked="true" name="COP-init-uninit"/>\r
+              <check checked="true" name="COP-member-uninit"/>\r
+            </group>\r
+            <group checked="true" name="CPU">\r
+              <check checked="true" name="CPU-ctor-call-virt"/>\r
+              <check checked="false" name="CPU-ctor-implicit"/>\r
+              <check checked="true" name="CPU-delete-throw"/>\r
+              <check checked="true" name="CPU-delete-void"/>\r
+              <check checked="true" name="CPU-dtor-call-virt"/>\r
+              <check checked="true" name="CPU-malloc-class"/>\r
+              <check checked="true" name="CPU-nonvirt-dtor"/>\r
+              <check checked="true" name="CPU-return-ref-to-class-data"/>\r
+            </group>\r
+            <group checked="true" name="DECL">\r
+              <check checked="false" name="DECL-implicit-int"/>\r
+            </group>\r
+            <group checked="true" name="DEFINE">\r
+              <check checked="true" name="DEFINE-hash-multiple"/>\r
+            </group>\r
+            <group checked="true" name="ENUM">\r
+              <check checked="false" name="ENUM-bounds"/>\r
+            </group>\r
+            <group checked="true" name="EXP">\r
+              <check checked="true" name="EXP-cond-assign"/>\r
+              <check checked="true" name="EXP-dangling-else"/>\r
+              <check checked="true" name="EXP-loop-exit"/>\r
+              <check checked="false" name="EXP-main-ret-int"/>\r
+              <check checked="false" name="EXP-null-stmt"/>\r
+              <check checked="false" name="EXP-stray-semicolon"/>\r
+            </group>\r
+            <group checked="true" name="EXPR">\r
+              <check checked="true" name="EXPR-const-overflow"/>\r
+            </group>\r
+            <group checked="true" name="FPT">\r
+              <check checked="true" name="FPT-arith-address"/>\r
+              <check checked="true" name="FPT-arith"/>\r
+              <check checked="true" name="FPT-cmp-null"/>\r
+              <check checked="false" name="FPT-literal"/>\r
+              <check checked="true" name="FPT-misuse"/>\r
+            </group>\r
+            <group checked="true" name="FUNC">\r
+              <check checked="false" name="FUNC-implicit-decl"/>\r
+              <check checked="false" name="FUNC-unprototyped-all"/>\r
+              <check checked="true" name="FUNC-unprototyped-used"/>\r
+            </group>\r
+            <group checked="true" name="IDENT">\r
+              <check checked="false" name="IDENT-long-scope-31-chars"/>\r
+              <check checked="false" name="IDENT-long-scope-63-chars"/>\r
+            </group>\r
+            <group checked="true" name="INCLUDE">\r
+              <check checked="false" name="INCLUDE-c-file"/>\r
+            </group>\r
+            <group checked="true" name="INT">\r
+              <check checked="false" name="INT-use-signed-as-unsigned-pos"/>\r
+              <check checked="true" name="INT-use-signed-as-unsigned"/>\r
+            </group>\r
+            <group checked="true" name="ITR">\r
+              <check checked="true" name="ITR-end-cmp-aft"/>\r
+              <check checked="true" name="ITR-end-cmp-bef"/>\r
+              <check checked="true" name="ITR-invalidated"/>\r
+              <check checked="true" name="ITR-mismatch-alg"/>\r
+              <check checked="true" name="ITR-store"/>\r
+              <check checked="true" name="ITR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="LIB">\r
+              <check checked="false" name="LIB-bsearch-overrun-pos"/>\r
+              <check checked="false" name="LIB-bsearch-overrun"/>\r
+              <check checked="false" name="LIB-buf-size"/>\r
+              <check checked="false" name="LIB-fn-unsafe"/>\r
+              <check checked="false" name="LIB-fread-overrun-pos"/>\r
+              <check checked="true" name="LIB-fread-overrun"/>\r
+              <check checked="false" name="LIB-memchr-overrun-pos"/>\r
+              <check checked="true" name="LIB-memchr-overrun"/>\r
+              <check checked="false" name="LIB-memcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-memcpy-overrun"/>\r
+              <check checked="false" name="LIB-memset-overrun-pos"/>\r
+              <check checked="true" name="LIB-memset-overrun"/>\r
+              <check checked="false" name="LIB-putenv"/>\r
+              <check checked="false" name="LIB-qsort-overrun-pos"/>\r
+              <check checked="false" name="LIB-qsort-overrun"/>\r
+              <check checked="true" name="LIB-return-const"/>\r
+              <check checked="true" name="LIB-return-error"/>\r
+              <check checked="true" name="LIB-return-leak"/>\r
+              <check checked="true" name="LIB-return-neg"/>\r
+              <check checked="true" name="LIB-return-null"/>\r
+              <check checked="false" name="LIB-sprintf-overrun"/>\r
+              <check checked="false" name="LIB-std-sort-overrun-pos"/>\r
+              <check checked="true" name="LIB-std-sort-overrun"/>\r
+              <check checked="false" name="LIB-strcat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcat-overrun"/>\r
+              <check checked="false" name="LIB-strcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcpy-overrun"/>\r
+              <check checked="false" name="LIB-strncat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncat-overrun"/>\r
+              <check checked="false" name="LIB-strncmp-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncmp-overrun"/>\r
+              <check checked="false" name="LIB-strncpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncpy-overrun"/>\r
+            </group>\r
+            <group checked="true" name="LOGIC">\r
+              <check checked="false" name="LOGIC-overload"/>\r
+            </group>\r
+            <group checked="true" name="MEM">\r
+              <check checked="true" name="MEM-alias-double-free"/>\r
+              <check checked="true" name="MEM-delete-array-op"/>\r
+              <check checked="true" name="MEM-delete-op"/>\r
+              <check checked="true" name="MEM-double-free-alias"/>\r
+              <check checked="true" name="MEM-double-free-some"/>\r
+              <check checked="true" name="MEM-double-free"/>\r
+              <check checked="true" name="MEM-free-field"/>\r
+              <check checked="true" name="MEM-free-fptr"/>\r
+              <check checked="false" name="MEM-free-no-alloc-struct"/>\r
+              <check checked="true" name="MEM-free-no-alloc"/>\r
+              <check checked="true" name="MEM-free-no-use"/>\r
+              <check checked="true" name="MEM-free-op"/>\r
+              <check checked="true" name="MEM-free-struct-field"/>\r
+              <check checked="true" name="MEM-free-variable-alias"/>\r
+              <check checked="true" name="MEM-free-variable"/>\r
+              <check checked="true" name="MEM-leak-alias"/>\r
+              <check checked="false" name="MEM-leak"/>\r
+              <check checked="false" name="MEM-malloc-arith"/>\r
+              <check checked="true" name="MEM-malloc-diff-type"/>\r
+              <check checked="true" name="MEM-malloc-sizeof-ptr"/>\r
+              <check checked="true" name="MEM-malloc-sizeof"/>\r
+              <check checked="false" name="MEM-malloc-strlen"/>\r
+              <check checked="true" name="MEM-realloc-diff-type"/>\r
+              <check checked="true" name="MEM-return-free"/>\r
+              <check checked="true" name="MEM-return-no-assign"/>\r
+              <check checked="true" name="MEM-stack-alias"/>\r
+              <check checked="true" name="MEM-stack-global-alias"/>\r
+              <check checked="true" name="MEM-stack-global-field"/>\r
+              <check checked="true" name="MEM-stack-global"/>\r
+              <check checked="true" name="MEM-stack-param-ref"/>\r
+              <check checked="true" name="MEM-stack-param"/>\r
+              <check checked="true" name="MEM-stack-pos"/>\r
+              <check checked="true" name="MEM-stack-ref"/>\r
+              <check checked="true" name="MEM-stack"/>\r
+              <check checked="true" name="MEM-use-free-all"/>\r
+              <check checked="true" name="MEM-use-free-some"/>\r
+            </group>\r
+            <group checked="true" name="POR">\r
+              <check checked="true" name="POR-imp-cast-subscript"/>\r
+              <check checked="false" name="POR-imp-cast-ternary"/>\r
+            </group>\r
+            <group checked="true" name="PTR">\r
+              <check checked="true" name="PTR-alias-null-pos-deref"/>\r
+              <check checked="true" name="PTR-arith-field"/>\r
+              <check checked="true" name="PTR-arith-stack"/>\r
+              <check checked="true" name="PTR-arith-var"/>\r
+              <check checked="true" name="PTR-cmp-str-lit"/>\r
+              <check checked="true" name="PTR-null-assign-fun-pos"/>\r
+              <check checked="true" name="PTR-null-assign-pos"/>\r
+              <check checked="true" name="PTR-null-assign"/>\r
+              <check checked="true" name="PTR-null-cmp-aft"/>\r
+              <check checked="true" name="PTR-null-cmp-bef-fun"/>\r
+              <check checked="true" name="PTR-null-cmp-bef"/>\r
+              <check checked="true" name="PTR-null-fun-pos"/>\r
+              <check checked="true" name="PTR-null-literal-pos"/>\r
+              <check checked="false" name="PTR-overload"/>\r
+              <check checked="true" name="PTR-singleton-arith-pos"/>\r
+              <check checked="true" name="PTR-singleton-arith"/>\r
+              <check checked="true" name="PTR-unchk-param-some"/>\r
+              <check checked="false" name="PTR-unchk-param"/>\r
+              <check checked="true" name="PTR-uninit-pos"/>\r
+              <check checked="true" name="PTR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="RED">\r
+              <check checked="false" name="RED-case-reach"/>\r
+              <check checked="false" name="RED-cmp-always"/>\r
+              <check checked="false" name="RED-cmp-never"/>\r
+              <check checked="false" name="RED-cond-always"/>\r
+              <check checked="true" name="RED-cond-const-assign"/>\r
+              <check checked="false" name="RED-cond-const-expr"/>\r
+              <check checked="false" name="RED-cond-const"/>\r
+              <check checked="false" name="RED-cond-never"/>\r
+              <check checked="true" name="RED-dead"/>\r
+              <check checked="false" name="RED-expr"/>\r
+              <check checked="false" name="RED-func-no-effect"/>\r
+              <check checked="true" name="RED-local-hides-global"/>\r
+              <check checked="true" name="RED-local-hides-local"/>\r
+              <check checked="true" name="RED-local-hides-member"/>\r
+              <check checked="true" name="RED-local-hides-param"/>\r
+              <check checked="false" name="RED-no-effect"/>\r
+              <check checked="true" name="RED-self-assign"/>\r
+              <check checked="true" name="RED-unused-assign"/>\r
+              <check checked="false" name="RED-unused-param"/>\r
+              <check checked="false" name="RED-unused-return-val"/>\r
+              <check checked="false" name="RED-unused-val"/>\r
+              <check checked="true" name="RED-unused-var-all"/>\r
+            </group>\r
+            <group checked="true" name="RESOURCE">\r
+              <check checked="false" name="RESOURCE-deref-file"/>\r
+              <check checked="true" name="RESOURCE-double-close"/>\r
+              <check checked="true" name="RESOURCE-file-no-close-all"/>\r
+              <check checked="false" name="RESOURCE-file-pos-neg"/>\r
+              <check checked="true" name="RESOURCE-file-use-after-close"/>\r
+              <check checked="false" name="RESOURCE-implicit-deref-file"/>\r
+              <check checked="true" name="RESOURCE-write-ronly-file"/>\r
+            </group>\r
+            <group checked="true" name="SEM">\r
+              <check checked="false" name="SEM-const-call"/>\r
+              <check checked="false" name="SEM-const-global"/>\r
+              <check checked="false" name="SEM-pure-call"/>\r
+              <check checked="false" name="SEM-pure-global"/>\r
+            </group>\r
+            <group checked="true" name="SIZEOF">\r
+              <check checked="true" name="SIZEOF-side-effect"/>\r
+            </group>\r
+            <group checked="true" name="SPC">\r
+              <check checked="false" name="SPC-init-list"/>\r
+              <check checked="true" name="SPC-order"/>\r
+              <check checked="true" name="SPC-return"/>\r
+              <check checked="true" name="SPC-uninit-arr-all"/>\r
+              <check checked="true" name="SPC-uninit-struct-field-heap"/>\r
+              <check checked="true" name="SPC-uninit-struct-field"/>\r
+              <check checked="true" name="SPC-uninit-struct"/>\r
+              <check checked="true" name="SPC-uninit-var-all"/>\r
+              <check checked="true" name="SPC-uninit-var-some"/>\r
+              <check checked="false" name="SPC-volatile-reads"/>\r
+              <check checked="false" name="SPC-volatile-writes"/>\r
+            </group>\r
+            <group checked="true" name="STR">\r
+              <check checked="true" name="STR-trigraph"/>\r
+            </group>\r
+            <group checked="true" name="STRUCT">\r
+              <check checked="false" name="STRUCT-signed-bit"/>\r
+            </group>\r
+            <group checked="true" name="SWITCH">\r
+              <check checked="true" name="SWITCH-fall-through"/>\r
+            </group>\r
+            <group checked="true" name="THROW">\r
+              <check checked="false" name="THROW-empty"/>\r
+              <check checked="false" name="THROW-main"/>\r
+              <check checked="true" name="THROW-null"/>\r
+              <check checked="true" name="THROW-ptr"/>\r
+              <check checked="true" name="THROW-static"/>\r
+              <check checked="true" name="THROW-unhandled"/>\r
+            </group>\r
+            <group checked="true" name="UNION">\r
+              <check checked="true" name="UNION-overlap-assign"/>\r
+              <check checked="true" name="UNION-type-punning"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2004">\r
+            <group checked="true" name="MISRAC2004-1">\r
+              <check checked="true" name="MISRAC2004-1.1"/>\r
+              <check checked="true" name="MISRAC2004-1.2_a"/>\r
+              <check checked="true" name="MISRAC2004-1.2_b"/>\r
+              <check checked="true" name="MISRAC2004-1.2_c"/>\r
+              <check checked="true" name="MISRAC2004-1.2_d"/>\r
+              <check checked="true" name="MISRAC2004-1.2_e"/>\r
+              <check checked="true" name="MISRAC2004-1.2_f"/>\r
+              <check checked="true" name="MISRAC2004-1.2_g"/>\r
+              <check checked="true" name="MISRAC2004-1.2_h"/>\r
+              <check checked="true" name="MISRAC2004-1.2_i"/>\r
+              <check checked="true" name="MISRAC2004-1.2_j"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-10">\r
+              <check checked="true" name="MISRAC2004-10.1_a"/>\r
+              <check checked="true" name="MISRAC2004-10.1_b"/>\r
+              <check checked="true" name="MISRAC2004-10.1_c"/>\r
+              <check checked="true" name="MISRAC2004-10.1_d"/>\r
+              <check checked="true" name="MISRAC2004-10.2_a"/>\r
+              <check checked="true" name="MISRAC2004-10.2_b"/>\r
+              <check checked="true" name="MISRAC2004-10.2_c"/>\r
+              <check checked="true" name="MISRAC2004-10.2_d"/>\r
+              <check checked="true" name="MISRAC2004-10.3"/>\r
+              <check checked="true" name="MISRAC2004-10.4"/>\r
+              <check checked="true" name="MISRAC2004-10.5"/>\r
+              <check checked="true" name="MISRAC2004-10.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-11">\r
+              <check checked="true" name="MISRAC2004-11.1"/>\r
+              <check checked="false" name="MISRAC2004-11.3"/>\r
+              <check checked="false" name="MISRAC2004-11.4"/>\r
+              <check checked="true" name="MISRAC2004-11.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-12">\r
+              <check checked="false" name="MISRAC2004-12.1"/>\r
+              <check checked="true" name="MISRAC2004-12.10"/>\r
+              <check checked="false" name="MISRAC2004-12.11"/>\r
+              <check checked="true" name="MISRAC2004-12.12_a"/>\r
+              <check checked="true" name="MISRAC2004-12.12_b"/>\r
+              <check checked="false" name="MISRAC2004-12.13"/>\r
+              <check checked="true" name="MISRAC2004-12.2_a"/>\r
+              <check checked="true" name="MISRAC2004-12.2_b"/>\r
+              <check checked="true" name="MISRAC2004-12.2_c"/>\r
+              <check checked="true" name="MISRAC2004-12.3"/>\r
+              <check checked="true" name="MISRAC2004-12.4"/>\r
+              <check checked="false" name="MISRAC2004-12.6_a"/>\r
+              <check checked="false" name="MISRAC2004-12.6_b"/>\r
+              <check checked="true" name="MISRAC2004-12.7"/>\r
+              <check checked="true" name="MISRAC2004-12.8"/>\r
+              <check checked="true" name="MISRAC2004-12.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-13">\r
+              <check checked="true" name="MISRAC2004-13.1"/>\r
+              <check checked="false" name="MISRAC2004-13.2_a"/>\r
+              <check checked="false" name="MISRAC2004-13.2_b"/>\r
+              <check checked="false" name="MISRAC2004-13.2_c"/>\r
+              <check checked="false" name="MISRAC2004-13.2_d"/>\r
+              <check checked="false" name="MISRAC2004-13.2_e"/>\r
+              <check checked="true" name="MISRAC2004-13.3"/>\r
+              <check checked="true" name="MISRAC2004-13.4"/>\r
+              <check checked="true" name="MISRAC2004-13.5"/>\r
+              <check checked="true" name="MISRAC2004-13.6"/>\r
+              <check checked="true" name="MISRAC2004-13.7_a"/>\r
+              <check checked="true" name="MISRAC2004-13.7_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-14">\r
+              <check checked="true" name="MISRAC2004-14.1"/>\r
+              <check checked="true" name="MISRAC2004-14.10"/>\r
+              <check checked="true" name="MISRAC2004-14.2"/>\r
+              <check checked="true" name="MISRAC2004-14.3"/>\r
+              <check checked="true" name="MISRAC2004-14.4"/>\r
+              <check checked="true" name="MISRAC2004-14.5"/>\r
+              <check checked="true" name="MISRAC2004-14.6"/>\r
+              <check checked="true" name="MISRAC2004-14.7"/>\r
+              <check checked="true" name="MISRAC2004-14.8_a"/>\r
+              <check checked="true" name="MISRAC2004-14.8_b"/>\r
+              <check checked="true" name="MISRAC2004-14.8_c"/>\r
+              <check checked="true" name="MISRAC2004-14.8_d"/>\r
+              <check checked="true" name="MISRAC2004-14.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-15">\r
+              <check checked="true" name="MISRAC2004-15.0"/>\r
+              <check checked="true" name="MISRAC2004-15.1"/>\r
+              <check checked="true" name="MISRAC2004-15.2"/>\r
+              <check checked="true" name="MISRAC2004-15.3"/>\r
+              <check checked="true" name="MISRAC2004-15.4"/>\r
+              <check checked="true" name="MISRAC2004-15.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-16">\r
+              <check checked="true" name="MISRAC2004-16.1"/>\r
+              <check checked="true" name="MISRAC2004-16.10"/>\r
+              <check checked="true" name="MISRAC2004-16.2_a"/>\r
+              <check checked="true" name="MISRAC2004-16.2_b"/>\r
+              <check checked="true" name="MISRAC2004-16.3"/>\r
+              <check checked="true" name="MISRAC2004-16.5"/>\r
+              <check checked="true" name="MISRAC2004-16.7"/>\r
+              <check checked="true" name="MISRAC2004-16.8"/>\r
+              <check checked="true" name="MISRAC2004-16.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-17">\r
+              <check checked="true" name="MISRAC2004-17.1_a"/>\r
+              <check checked="true" name="MISRAC2004-17.1_b"/>\r
+              <check checked="true" name="MISRAC2004-17.1_c"/>\r
+              <check checked="true" name="MISRAC2004-17.4_a"/>\r
+              <check checked="true" name="MISRAC2004-17.4_b"/>\r
+              <check checked="true" name="MISRAC2004-17.5"/>\r
+              <check checked="true" name="MISRAC2004-17.6_a"/>\r
+              <check checked="true" name="MISRAC2004-17.6_b"/>\r
+              <check checked="true" name="MISRAC2004-17.6_c"/>\r
+              <check checked="true" name="MISRAC2004-17.6_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-18">\r
+              <check checked="true" name="MISRAC2004-18.1"/>\r
+              <check checked="true" name="MISRAC2004-18.2"/>\r
+              <check checked="true" name="MISRAC2004-18.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-19">\r
+              <check checked="true" name="MISRAC2004-19.12"/>\r
+              <check checked="false" name="MISRAC2004-19.13"/>\r
+              <check checked="true" name="MISRAC2004-19.15"/>\r
+              <check checked="false" name="MISRAC2004-19.2"/>\r
+              <check checked="true" name="MISRAC2004-19.6"/>\r
+              <check checked="false" name="MISRAC2004-19.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-2">\r
+              <check checked="true" name="MISRAC2004-2.1"/>\r
+              <check checked="true" name="MISRAC2004-2.2"/>\r
+              <check checked="true" name="MISRAC2004-2.3"/>\r
+              <check checked="false" name="MISRAC2004-2.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-20">\r
+              <check checked="true" name="MISRAC2004-20.1"/>\r
+              <check checked="true" name="MISRAC2004-20.10"/>\r
+              <check checked="true" name="MISRAC2004-20.11"/>\r
+              <check checked="true" name="MISRAC2004-20.12"/>\r
+              <check checked="true" name="MISRAC2004-20.4"/>\r
+              <check checked="true" name="MISRAC2004-20.5"/>\r
+              <check checked="true" name="MISRAC2004-20.6"/>\r
+              <check checked="true" name="MISRAC2004-20.7"/>\r
+              <check checked="true" name="MISRAC2004-20.8"/>\r
+              <check checked="true" name="MISRAC2004-20.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-4">\r
+              <check checked="true" name="MISRAC2004-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-5">\r
+              <check checked="true" name="MISRAC2004-5.1"/>\r
+              <check checked="true" name="MISRAC2004-5.2_a"/>\r
+              <check checked="true" name="MISRAC2004-5.2_b"/>\r
+              <check checked="true" name="MISRAC2004-5.2_c"/>\r
+              <check checked="true" name="MISRAC2004-5.3"/>\r
+              <check checked="true" name="MISRAC2004-5.4"/>\r
+              <check checked="false" name="MISRAC2004-5.5"/>\r
+              <check checked="false" name="MISRAC2004-5.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-6">\r
+              <check checked="true" name="MISRAC2004-6.1"/>\r
+              <check checked="false" name="MISRAC2004-6.3"/>\r
+              <check checked="true" name="MISRAC2004-6.4"/>\r
+              <check checked="true" name="MISRAC2004-6.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-7">\r
+              <check checked="true" name="MISRAC2004-7.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-8">\r
+              <check checked="true" name="MISRAC2004-8.1"/>\r
+              <check checked="true" name="MISRAC2004-8.12"/>\r
+              <check checked="true" name="MISRAC2004-8.2"/>\r
+              <check checked="true" name="MISRAC2004-8.5_a"/>\r
+              <check checked="true" name="MISRAC2004-8.5_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-9">\r
+              <check checked="true" name="MISRAC2004-9.1_a"/>\r
+              <check checked="true" name="MISRAC2004-9.1_b"/>\r
+              <check checked="true" name="MISRAC2004-9.1_c"/>\r
+              <check checked="true" name="MISRAC2004-9.2"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2012">\r
+            <group checked="true" name="MISRAC2012-Dir-4">\r
+              <check checked="true" name="MISRAC2012-Dir-4.10"/>\r
+              <check checked="true" name="MISRAC2012-Dir-4.3"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.4"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_a"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_b"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-1">\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_g"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_h"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-10">\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-11">\r
+              <check checked="true" name="MISRAC2012-Rule-11.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-11.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-12">\r
+              <check checked="false" name="MISRAC2012-Rule-12.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-12.2"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-13">\r
+              <check checked="true" name="MISRAC2012-Rule-13.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_a"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-14">\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-15">\r
+              <check checked="false" name="MISRAC2012-Rule-15.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.4"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-16">\r
+              <check checked="true" name="MISRAC2012-Rule-16.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-17">\r
+              <check checked="true" name="MISRAC2012-Rule-17.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-18">\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_d"/>\r
+              <check checked="false" name="MISRAC2012-Rule-18.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-19">\r
+              <check checked="true" name="MISRAC2012-Rule-19.1"/>\r
+              <check checked="false" name="MISRAC2012-Rule-19.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-2">\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-2.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-20">\r
+              <check checked="false" name="MISRAC2012-Rule-20.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c99"/>\r
+              <check checked="false" name="MISRAC2012-Rule-20.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-21">\r
+              <check checked="true" name="MISRAC2012-Rule-21.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-22">\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-3">\r
+              <check checked="true" name="MISRAC2012-Rule-3.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-4">\r
+              <check checked="false" name="MISRAC2012-Rule-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-5">\r
+              <check checked="true" name="MISRAC2012-Rule-5.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-6">\r
+              <check checked="true" name="MISRAC2012-Rule-6.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-6.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-7">\r
+              <check checked="true" name="MISRAC2012-Rule-7.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-8">\r
+              <check checked="true" name="MISRAC2012-Rule-8.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.10"/>\r
+              <check checked="false" name="MISRAC2012-Rule-8.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.14"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-9">\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_b"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC++2008">\r
+            <group checked="true" name="MISRAC++2008-0-1">\r
+              <check checked="true" name="MISRAC++2008-0-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-11"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-3"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-4"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-6"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-7"/>\r
+              <check checked="false" name="MISRAC++2008-0-1-8"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-2">\r
+              <check checked="true" name="MISRAC++2008-0-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-3">\r
+              <check checked="true" name="MISRAC++2008-0-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-12-1">\r
+              <check checked="true" name="MISRAC++2008-12-1-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-0">\r
+              <check checked="false" name="MISRAC++2008-15-0-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-1">\r
+              <check checked="true" name="MISRAC++2008-15-1-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-3">\r
+              <check checked="true" name="MISRAC++2008-15-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-15-3-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-4"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-5">\r
+              <check checked="true" name="MISRAC++2008-15-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-0">\r
+              <check checked="true" name="MISRAC++2008-16-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-0-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-2">\r
+              <check checked="true" name="MISRAC++2008-16-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-4"/>\r
+              <check checked="false" name="MISRAC++2008-16-2-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-3">\r
+              <check checked="true" name="MISRAC++2008-16-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-16-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-17-0">\r
+              <check checked="true" name="MISRAC++2008-17-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-0">\r
+              <check checked="true" name="MISRAC++2008-18-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-2">\r
+              <check checked="true" name="MISRAC++2008-18-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-4">\r
+              <check checked="true" name="MISRAC++2008-18-4-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-7">\r
+              <check checked="true" name="MISRAC++2008-18-7-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-19-3">\r
+              <check checked="true" name="MISRAC++2008-19-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-10">\r
+              <check checked="true" name="MISRAC++2008-2-10-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_d"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-4"/>\r
+              <check checked="false" name="MISRAC++2008-2-10-5"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-6_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-13">\r
+              <check checked="true" name="MISRAC++2008-2-13-2"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-3">\r
+              <check checked="true" name="MISRAC++2008-2-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-7">\r
+              <check checked="true" name="MISRAC++2008-2-7-1"/>\r
+              <check checked="true" name="MISRAC++2008-2-7-2"/>\r
+              <check checked="false" name="MISRAC++2008-2-7-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-27-0">\r
+              <check checked="true" name="MISRAC++2008-27-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-1">\r
+              <check checked="true" name="MISRAC++2008-3-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-3-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-9">\r
+              <check checked="false" name="MISRAC++2008-3-9-2"/>\r
+              <check checked="true" name="MISRAC++2008-3-9-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-4-5">\r
+              <check checked="true" name="MISRAC++2008-4-5-1"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-0">\r
+              <check checked="true" name="MISRAC++2008-5-0-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-14"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_e"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_f"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-19"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_c"/>\r
+              <check checked="false" name="MISRAC++2008-5-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-21"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-7"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-8"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-14">\r
+              <check checked="true" name="MISRAC++2008-5-14-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-18">\r
+              <check checked="true" name="MISRAC++2008-5-18-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-19">\r
+              <check checked="false" name="MISRAC++2008-5-19-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-2">\r
+              <check checked="false" name="MISRAC++2008-5-2-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-7"/>\r
+              <check checked="false" name="MISRAC++2008-5-2-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-3">\r
+              <check checked="true" name="MISRAC++2008-5-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-8">\r
+              <check checked="true" name="MISRAC++2008-5-8-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-2">\r
+              <check checked="true" name="MISRAC++2008-6-2-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-3">\r
+              <check checked="true" name="MISRAC++2008-6-3-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-4">\r
+              <check checked="true" name="MISRAC++2008-6-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-6"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-7"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-5">\r
+              <check checked="true" name="MISRAC++2008-6-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-6">\r
+              <check checked="true" name="MISRAC++2008-6-6-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-1">\r
+              <check checked="true" name="MISRAC++2008-7-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-7-1-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-2">\r
+              <check checked="true" name="MISRAC++2008-7-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-4">\r
+              <check checked="true" name="MISRAC++2008-7-4-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-5">\r
+              <check checked="true" name="MISRAC++2008-7-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_d"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_a"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-0">\r
+              <check checked="true" name="MISRAC++2008-8-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-4">\r
+              <check checked="true" name="MISRAC++2008-8-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-5">\r
+              <check checked="true" name="MISRAC++2008-8-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-3">\r
+              <check checked="true" name="MISRAC++2008-9-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-9-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-5">\r
+              <check checked="true" name="MISRAC++2008-9-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-6">\r
+              <check checked="true" name="MISRAC++2008-9-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-3"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-4"/>\r
+            </group>\r
+          </package>\r
+        </cstatsettings>\r
+      </data>\r
+    </settings>\r
   </configuration>\r
   <configuration>\r
     <name>Debug_Small_Data_Model</name>\r
       <name>MSP430</name>\r
     </toolchain>\r
     <debug>1</debug>\r
+    <settings>\r
+      <name>C-STAT</name>\r
+      <archiveVersion>1</archiveVersion>\r
+      <data>\r
+        <cstatsettings>\r
+          <package checked="true" name="STDCHECKS">\r
+            <group checked="true" name="ARR">\r
+              <check checked="true" name="ARR-inv-index-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr"/>\r
+              <check checked="true" name="ARR-inv-index"/>\r
+              <check checked="true" name="ARR-neg-index"/>\r
+              <check checked="true" name="ARR-uninit-index"/>\r
+            </group>\r
+            <group checked="true" name="ATH">\r
+              <check checked="true" name="ATH-cmp-float"/>\r
+              <check checked="true" name="ATH-cmp-unsign-neg"/>\r
+              <check checked="true" name="ATH-cmp-unsign-pos"/>\r
+              <check checked="true" name="ATH-div-0-assign"/>\r
+              <check checked="true" name="ATH-div-0-cmp-aft"/>\r
+              <check checked="true" name="ATH-div-0-cmp-bef"/>\r
+              <check checked="true" name="ATH-div-0-interval"/>\r
+              <check checked="true" name="ATH-div-0-pos"/>\r
+              <check checked="true" name="ATH-div-0-unchk-global"/>\r
+              <check checked="true" name="ATH-div-0-unchk-local"/>\r
+              <check checked="true" name="ATH-div-0-unchk-param"/>\r
+              <check checked="true" name="ATH-div-0"/>\r
+              <check checked="true" name="ATH-inc-bool"/>\r
+              <check checked="true" name="ATH-malloc-overrun"/>\r
+              <check checked="true" name="ATH-neg-check-nonneg"/>\r
+              <check checked="true" name="ATH-neg-check-pos"/>\r
+              <check checked="true" name="ATH-new-overrun"/>\r
+              <check checked="false" name="ATH-overflow-cast"/>\r
+              <check checked="true" name="ATH-overflow"/>\r
+              <check checked="true" name="ATH-shift-bounds"/>\r
+              <check checked="true" name="ATH-shift-neg"/>\r
+              <check checked="true" name="ATH-sizeof-by-sizeof"/>\r
+            </group>\r
+            <group checked="true" name="CAST">\r
+              <check checked="false" name="CAST-old-style"/>\r
+            </group>\r
+            <group checked="true" name="CATCH">\r
+              <check checked="true" name="CATCH-object-slicing"/>\r
+              <check checked="false" name="CATCH-xtor-bad-member"/>\r
+            </group>\r
+            <group checked="true" name="COMMA">\r
+              <check checked="false" name="COMMA-overload"/>\r
+            </group>\r
+            <group checked="true" name="COMMENT">\r
+              <check checked="true" name="COMMENT-nested"/>\r
+            </group>\r
+            <group checked="false" name="CONCURRENCY">\r
+              <check checked="true" name="CONCURRENCY-double-lock"/>\r
+              <check checked="true" name="CONCURRENCY-double-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-lock-no-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-sleep-while-locking"/>\r
+            </group>\r
+            <group checked="true" name="CONST">\r
+              <check checked="false" name="CONST-local"/>\r
+              <check checked="true" name="CONST-member-ret"/>\r
+              <check checked="false" name="CONST-param"/>\r
+            </group>\r
+            <group checked="true" name="COP">\r
+              <check checked="true" name="COP-alloc-ctor"/>\r
+              <check checked="true" name="COP-assign-op-ret"/>\r
+              <check checked="true" name="COP-assign-op-self"/>\r
+              <check checked="true" name="COP-assign-op"/>\r
+              <check checked="true" name="COP-copy-ctor"/>\r
+              <check checked="true" name="COP-dealloc-dtor"/>\r
+              <check checked="true" name="COP-dtor-throw"/>\r
+              <check checked="true" name="COP-dtor"/>\r
+              <check checked="true" name="COP-init-order"/>\r
+              <check checked="true" name="COP-init-uninit"/>\r
+              <check checked="true" name="COP-member-uninit"/>\r
+            </group>\r
+            <group checked="true" name="CPU">\r
+              <check checked="true" name="CPU-ctor-call-virt"/>\r
+              <check checked="false" name="CPU-ctor-implicit"/>\r
+              <check checked="true" name="CPU-delete-throw"/>\r
+              <check checked="true" name="CPU-delete-void"/>\r
+              <check checked="true" name="CPU-dtor-call-virt"/>\r
+              <check checked="true" name="CPU-malloc-class"/>\r
+              <check checked="true" name="CPU-nonvirt-dtor"/>\r
+              <check checked="true" name="CPU-return-ref-to-class-data"/>\r
+            </group>\r
+            <group checked="true" name="DECL">\r
+              <check checked="false" name="DECL-implicit-int"/>\r
+            </group>\r
+            <group checked="true" name="DEFINE">\r
+              <check checked="true" name="DEFINE-hash-multiple"/>\r
+            </group>\r
+            <group checked="true" name="ENUM">\r
+              <check checked="false" name="ENUM-bounds"/>\r
+            </group>\r
+            <group checked="true" name="EXP">\r
+              <check checked="true" name="EXP-cond-assign"/>\r
+              <check checked="true" name="EXP-dangling-else"/>\r
+              <check checked="true" name="EXP-loop-exit"/>\r
+              <check checked="false" name="EXP-main-ret-int"/>\r
+              <check checked="false" name="EXP-null-stmt"/>\r
+              <check checked="false" name="EXP-stray-semicolon"/>\r
+            </group>\r
+            <group checked="true" name="EXPR">\r
+              <check checked="true" name="EXPR-const-overflow"/>\r
+            </group>\r
+            <group checked="true" name="FPT">\r
+              <check checked="true" name="FPT-arith-address"/>\r
+              <check checked="true" name="FPT-arith"/>\r
+              <check checked="true" name="FPT-cmp-null"/>\r
+              <check checked="false" name="FPT-literal"/>\r
+              <check checked="true" name="FPT-misuse"/>\r
+            </group>\r
+            <group checked="true" name="FUNC">\r
+              <check checked="false" name="FUNC-implicit-decl"/>\r
+              <check checked="false" name="FUNC-unprototyped-all"/>\r
+              <check checked="true" name="FUNC-unprototyped-used"/>\r
+            </group>\r
+            <group checked="true" name="IDENT">\r
+              <check checked="false" name="IDENT-long-scope-31-chars"/>\r
+              <check checked="false" name="IDENT-long-scope-63-chars"/>\r
+            </group>\r
+            <group checked="true" name="INCLUDE">\r
+              <check checked="false" name="INCLUDE-c-file"/>\r
+            </group>\r
+            <group checked="true" name="INT">\r
+              <check checked="false" name="INT-use-signed-as-unsigned-pos"/>\r
+              <check checked="true" name="INT-use-signed-as-unsigned"/>\r
+            </group>\r
+            <group checked="true" name="ITR">\r
+              <check checked="true" name="ITR-end-cmp-aft"/>\r
+              <check checked="true" name="ITR-end-cmp-bef"/>\r
+              <check checked="true" name="ITR-invalidated"/>\r
+              <check checked="true" name="ITR-mismatch-alg"/>\r
+              <check checked="true" name="ITR-store"/>\r
+              <check checked="true" name="ITR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="LIB">\r
+              <check checked="false" name="LIB-bsearch-overrun-pos"/>\r
+              <check checked="false" name="LIB-bsearch-overrun"/>\r
+              <check checked="false" name="LIB-buf-size"/>\r
+              <check checked="false" name="LIB-fn-unsafe"/>\r
+              <check checked="false" name="LIB-fread-overrun-pos"/>\r
+              <check checked="true" name="LIB-fread-overrun"/>\r
+              <check checked="false" name="LIB-memchr-overrun-pos"/>\r
+              <check checked="true" name="LIB-memchr-overrun"/>\r
+              <check checked="false" name="LIB-memcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-memcpy-overrun"/>\r
+              <check checked="false" name="LIB-memset-overrun-pos"/>\r
+              <check checked="true" name="LIB-memset-overrun"/>\r
+              <check checked="false" name="LIB-putenv"/>\r
+              <check checked="false" name="LIB-qsort-overrun-pos"/>\r
+              <check checked="false" name="LIB-qsort-overrun"/>\r
+              <check checked="true" name="LIB-return-const"/>\r
+              <check checked="true" name="LIB-return-error"/>\r
+              <check checked="true" name="LIB-return-leak"/>\r
+              <check checked="true" name="LIB-return-neg"/>\r
+              <check checked="true" name="LIB-return-null"/>\r
+              <check checked="false" name="LIB-sprintf-overrun"/>\r
+              <check checked="false" name="LIB-std-sort-overrun-pos"/>\r
+              <check checked="true" name="LIB-std-sort-overrun"/>\r
+              <check checked="false" name="LIB-strcat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcat-overrun"/>\r
+              <check checked="false" name="LIB-strcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcpy-overrun"/>\r
+              <check checked="false" name="LIB-strncat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncat-overrun"/>\r
+              <check checked="false" name="LIB-strncmp-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncmp-overrun"/>\r
+              <check checked="false" name="LIB-strncpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncpy-overrun"/>\r
+            </group>\r
+            <group checked="true" name="LOGIC">\r
+              <check checked="false" name="LOGIC-overload"/>\r
+            </group>\r
+            <group checked="true" name="MEM">\r
+              <check checked="true" name="MEM-alias-double-free"/>\r
+              <check checked="true" name="MEM-delete-array-op"/>\r
+              <check checked="true" name="MEM-delete-op"/>\r
+              <check checked="true" name="MEM-double-free-alias"/>\r
+              <check checked="true" name="MEM-double-free-some"/>\r
+              <check checked="true" name="MEM-double-free"/>\r
+              <check checked="true" name="MEM-free-field"/>\r
+              <check checked="true" name="MEM-free-fptr"/>\r
+              <check checked="false" name="MEM-free-no-alloc-struct"/>\r
+              <check checked="true" name="MEM-free-no-alloc"/>\r
+              <check checked="true" name="MEM-free-no-use"/>\r
+              <check checked="true" name="MEM-free-op"/>\r
+              <check checked="true" name="MEM-free-struct-field"/>\r
+              <check checked="true" name="MEM-free-variable-alias"/>\r
+              <check checked="true" name="MEM-free-variable"/>\r
+              <check checked="true" name="MEM-leak-alias"/>\r
+              <check checked="false" name="MEM-leak"/>\r
+              <check checked="false" name="MEM-malloc-arith"/>\r
+              <check checked="true" name="MEM-malloc-diff-type"/>\r
+              <check checked="true" name="MEM-malloc-sizeof-ptr"/>\r
+              <check checked="true" name="MEM-malloc-sizeof"/>\r
+              <check checked="false" name="MEM-malloc-strlen"/>\r
+              <check checked="true" name="MEM-realloc-diff-type"/>\r
+              <check checked="true" name="MEM-return-free"/>\r
+              <check checked="true" name="MEM-return-no-assign"/>\r
+              <check checked="true" name="MEM-stack-alias"/>\r
+              <check checked="true" name="MEM-stack-global-alias"/>\r
+              <check checked="true" name="MEM-stack-global-field"/>\r
+              <check checked="true" name="MEM-stack-global"/>\r
+              <check checked="true" name="MEM-stack-param-ref"/>\r
+              <check checked="true" name="MEM-stack-param"/>\r
+              <check checked="true" name="MEM-stack-pos"/>\r
+              <check checked="true" name="MEM-stack-ref"/>\r
+              <check checked="true" name="MEM-stack"/>\r
+              <check checked="true" name="MEM-use-free-all"/>\r
+              <check checked="true" name="MEM-use-free-some"/>\r
+            </group>\r
+            <group checked="true" name="POR">\r
+              <check checked="true" name="POR-imp-cast-subscript"/>\r
+              <check checked="false" name="POR-imp-cast-ternary"/>\r
+            </group>\r
+            <group checked="true" name="PTR">\r
+              <check checked="true" name="PTR-alias-null-pos-deref"/>\r
+              <check checked="true" name="PTR-arith-field"/>\r
+              <check checked="true" name="PTR-arith-stack"/>\r
+              <check checked="true" name="PTR-arith-var"/>\r
+              <check checked="true" name="PTR-cmp-str-lit"/>\r
+              <check checked="true" name="PTR-null-assign-fun-pos"/>\r
+              <check checked="true" name="PTR-null-assign-pos"/>\r
+              <check checked="true" name="PTR-null-assign"/>\r
+              <check checked="true" name="PTR-null-cmp-aft"/>\r
+              <check checked="true" name="PTR-null-cmp-bef-fun"/>\r
+              <check checked="true" name="PTR-null-cmp-bef"/>\r
+              <check checked="true" name="PTR-null-fun-pos"/>\r
+              <check checked="true" name="PTR-null-literal-pos"/>\r
+              <check checked="false" name="PTR-overload"/>\r
+              <check checked="true" name="PTR-singleton-arith-pos"/>\r
+              <check checked="true" name="PTR-singleton-arith"/>\r
+              <check checked="true" name="PTR-unchk-param-some"/>\r
+              <check checked="false" name="PTR-unchk-param"/>\r
+              <check checked="true" name="PTR-uninit-pos"/>\r
+              <check checked="true" name="PTR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="RED">\r
+              <check checked="false" name="RED-case-reach"/>\r
+              <check checked="false" name="RED-cmp-always"/>\r
+              <check checked="false" name="RED-cmp-never"/>\r
+              <check checked="false" name="RED-cond-always"/>\r
+              <check checked="true" name="RED-cond-const-assign"/>\r
+              <check checked="false" name="RED-cond-const-expr"/>\r
+              <check checked="false" name="RED-cond-const"/>\r
+              <check checked="false" name="RED-cond-never"/>\r
+              <check checked="true" name="RED-dead"/>\r
+              <check checked="false" name="RED-expr"/>\r
+              <check checked="false" name="RED-func-no-effect"/>\r
+              <check checked="true" name="RED-local-hides-global"/>\r
+              <check checked="true" name="RED-local-hides-local"/>\r
+              <check checked="true" name="RED-local-hides-member"/>\r
+              <check checked="true" name="RED-local-hides-param"/>\r
+              <check checked="false" name="RED-no-effect"/>\r
+              <check checked="true" name="RED-self-assign"/>\r
+              <check checked="true" name="RED-unused-assign"/>\r
+              <check checked="false" name="RED-unused-param"/>\r
+              <check checked="false" name="RED-unused-return-val"/>\r
+              <check checked="false" name="RED-unused-val"/>\r
+              <check checked="true" name="RED-unused-var-all"/>\r
+            </group>\r
+            <group checked="true" name="RESOURCE">\r
+              <check checked="false" name="RESOURCE-deref-file"/>\r
+              <check checked="true" name="RESOURCE-double-close"/>\r
+              <check checked="true" name="RESOURCE-file-no-close-all"/>\r
+              <check checked="false" name="RESOURCE-file-pos-neg"/>\r
+              <check checked="true" name="RESOURCE-file-use-after-close"/>\r
+              <check checked="false" name="RESOURCE-implicit-deref-file"/>\r
+              <check checked="true" name="RESOURCE-write-ronly-file"/>\r
+            </group>\r
+            <group checked="true" name="SEM">\r
+              <check checked="false" name="SEM-const-call"/>\r
+              <check checked="false" name="SEM-const-global"/>\r
+              <check checked="false" name="SEM-pure-call"/>\r
+              <check checked="false" name="SEM-pure-global"/>\r
+            </group>\r
+            <group checked="true" name="SIZEOF">\r
+              <check checked="true" name="SIZEOF-side-effect"/>\r
+            </group>\r
+            <group checked="true" name="SPC">\r
+              <check checked="false" name="SPC-init-list"/>\r
+              <check checked="true" name="SPC-order"/>\r
+              <check checked="true" name="SPC-return"/>\r
+              <check checked="true" name="SPC-uninit-arr-all"/>\r
+              <check checked="true" name="SPC-uninit-struct-field-heap"/>\r
+              <check checked="true" name="SPC-uninit-struct-field"/>\r
+              <check checked="true" name="SPC-uninit-struct"/>\r
+              <check checked="true" name="SPC-uninit-var-all"/>\r
+              <check checked="true" name="SPC-uninit-var-some"/>\r
+              <check checked="false" name="SPC-volatile-reads"/>\r
+              <check checked="false" name="SPC-volatile-writes"/>\r
+            </group>\r
+            <group checked="true" name="STR">\r
+              <check checked="true" name="STR-trigraph"/>\r
+            </group>\r
+            <group checked="true" name="STRUCT">\r
+              <check checked="false" name="STRUCT-signed-bit"/>\r
+            </group>\r
+            <group checked="true" name="SWITCH">\r
+              <check checked="true" name="SWITCH-fall-through"/>\r
+            </group>\r
+            <group checked="true" name="THROW">\r
+              <check checked="false" name="THROW-empty"/>\r
+              <check checked="false" name="THROW-main"/>\r
+              <check checked="true" name="THROW-null"/>\r
+              <check checked="true" name="THROW-ptr"/>\r
+              <check checked="true" name="THROW-static"/>\r
+              <check checked="true" name="THROW-unhandled"/>\r
+            </group>\r
+            <group checked="true" name="UNION">\r
+              <check checked="true" name="UNION-overlap-assign"/>\r
+              <check checked="true" name="UNION-type-punning"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2004">\r
+            <group checked="true" name="MISRAC2004-1">\r
+              <check checked="true" name="MISRAC2004-1.1"/>\r
+              <check checked="true" name="MISRAC2004-1.2_a"/>\r
+              <check checked="true" name="MISRAC2004-1.2_b"/>\r
+              <check checked="true" name="MISRAC2004-1.2_c"/>\r
+              <check checked="true" name="MISRAC2004-1.2_d"/>\r
+              <check checked="true" name="MISRAC2004-1.2_e"/>\r
+              <check checked="true" name="MISRAC2004-1.2_f"/>\r
+              <check checked="true" name="MISRAC2004-1.2_g"/>\r
+              <check checked="true" name="MISRAC2004-1.2_h"/>\r
+              <check checked="true" name="MISRAC2004-1.2_i"/>\r
+              <check checked="true" name="MISRAC2004-1.2_j"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-10">\r
+              <check checked="true" name="MISRAC2004-10.1_a"/>\r
+              <check checked="true" name="MISRAC2004-10.1_b"/>\r
+              <check checked="true" name="MISRAC2004-10.1_c"/>\r
+              <check checked="true" name="MISRAC2004-10.1_d"/>\r
+              <check checked="true" name="MISRAC2004-10.2_a"/>\r
+              <check checked="true" name="MISRAC2004-10.2_b"/>\r
+              <check checked="true" name="MISRAC2004-10.2_c"/>\r
+              <check checked="true" name="MISRAC2004-10.2_d"/>\r
+              <check checked="true" name="MISRAC2004-10.3"/>\r
+              <check checked="true" name="MISRAC2004-10.4"/>\r
+              <check checked="true" name="MISRAC2004-10.5"/>\r
+              <check checked="true" name="MISRAC2004-10.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-11">\r
+              <check checked="true" name="MISRAC2004-11.1"/>\r
+              <check checked="false" name="MISRAC2004-11.3"/>\r
+              <check checked="false" name="MISRAC2004-11.4"/>\r
+              <check checked="true" name="MISRAC2004-11.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-12">\r
+              <check checked="false" name="MISRAC2004-12.1"/>\r
+              <check checked="true" name="MISRAC2004-12.10"/>\r
+              <check checked="false" name="MISRAC2004-12.11"/>\r
+              <check checked="true" name="MISRAC2004-12.12_a"/>\r
+              <check checked="true" name="MISRAC2004-12.12_b"/>\r
+              <check checked="false" name="MISRAC2004-12.13"/>\r
+              <check checked="true" name="MISRAC2004-12.2_a"/>\r
+              <check checked="true" name="MISRAC2004-12.2_b"/>\r
+              <check checked="true" name="MISRAC2004-12.2_c"/>\r
+              <check checked="true" name="MISRAC2004-12.3"/>\r
+              <check checked="true" name="MISRAC2004-12.4"/>\r
+              <check checked="false" name="MISRAC2004-12.6_a"/>\r
+              <check checked="false" name="MISRAC2004-12.6_b"/>\r
+              <check checked="true" name="MISRAC2004-12.7"/>\r
+              <check checked="true" name="MISRAC2004-12.8"/>\r
+              <check checked="true" name="MISRAC2004-12.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-13">\r
+              <check checked="true" name="MISRAC2004-13.1"/>\r
+              <check checked="false" name="MISRAC2004-13.2_a"/>\r
+              <check checked="false" name="MISRAC2004-13.2_b"/>\r
+              <check checked="false" name="MISRAC2004-13.2_c"/>\r
+              <check checked="false" name="MISRAC2004-13.2_d"/>\r
+              <check checked="false" name="MISRAC2004-13.2_e"/>\r
+              <check checked="true" name="MISRAC2004-13.3"/>\r
+              <check checked="true" name="MISRAC2004-13.4"/>\r
+              <check checked="true" name="MISRAC2004-13.5"/>\r
+              <check checked="true" name="MISRAC2004-13.6"/>\r
+              <check checked="true" name="MISRAC2004-13.7_a"/>\r
+              <check checked="true" name="MISRAC2004-13.7_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-14">\r
+              <check checked="true" name="MISRAC2004-14.1"/>\r
+              <check checked="true" name="MISRAC2004-14.10"/>\r
+              <check checked="true" name="MISRAC2004-14.2"/>\r
+              <check checked="true" name="MISRAC2004-14.3"/>\r
+              <check checked="true" name="MISRAC2004-14.4"/>\r
+              <check checked="true" name="MISRAC2004-14.5"/>\r
+              <check checked="true" name="MISRAC2004-14.6"/>\r
+              <check checked="true" name="MISRAC2004-14.7"/>\r
+              <check checked="true" name="MISRAC2004-14.8_a"/>\r
+              <check checked="true" name="MISRAC2004-14.8_b"/>\r
+              <check checked="true" name="MISRAC2004-14.8_c"/>\r
+              <check checked="true" name="MISRAC2004-14.8_d"/>\r
+              <check checked="true" name="MISRAC2004-14.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-15">\r
+              <check checked="true" name="MISRAC2004-15.0"/>\r
+              <check checked="true" name="MISRAC2004-15.1"/>\r
+              <check checked="true" name="MISRAC2004-15.2"/>\r
+              <check checked="true" name="MISRAC2004-15.3"/>\r
+              <check checked="true" name="MISRAC2004-15.4"/>\r
+              <check checked="true" name="MISRAC2004-15.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-16">\r
+              <check checked="true" name="MISRAC2004-16.1"/>\r
+              <check checked="true" name="MISRAC2004-16.10"/>\r
+              <check checked="true" name="MISRAC2004-16.2_a"/>\r
+              <check checked="true" name="MISRAC2004-16.2_b"/>\r
+              <check checked="true" name="MISRAC2004-16.3"/>\r
+              <check checked="true" name="MISRAC2004-16.5"/>\r
+              <check checked="true" name="MISRAC2004-16.7"/>\r
+              <check checked="true" name="MISRAC2004-16.8"/>\r
+              <check checked="true" name="MISRAC2004-16.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-17">\r
+              <check checked="true" name="MISRAC2004-17.1_a"/>\r
+              <check checked="true" name="MISRAC2004-17.1_b"/>\r
+              <check checked="true" name="MISRAC2004-17.1_c"/>\r
+              <check checked="true" name="MISRAC2004-17.4_a"/>\r
+              <check checked="true" name="MISRAC2004-17.4_b"/>\r
+              <check checked="true" name="MISRAC2004-17.5"/>\r
+              <check checked="true" name="MISRAC2004-17.6_a"/>\r
+              <check checked="true" name="MISRAC2004-17.6_b"/>\r
+              <check checked="true" name="MISRAC2004-17.6_c"/>\r
+              <check checked="true" name="MISRAC2004-17.6_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-18">\r
+              <check checked="true" name="MISRAC2004-18.1"/>\r
+              <check checked="true" name="MISRAC2004-18.2"/>\r
+              <check checked="true" name="MISRAC2004-18.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-19">\r
+              <check checked="true" name="MISRAC2004-19.12"/>\r
+              <check checked="false" name="MISRAC2004-19.13"/>\r
+              <check checked="true" name="MISRAC2004-19.15"/>\r
+              <check checked="false" name="MISRAC2004-19.2"/>\r
+              <check checked="true" name="MISRAC2004-19.6"/>\r
+              <check checked="false" name="MISRAC2004-19.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-2">\r
+              <check checked="true" name="MISRAC2004-2.1"/>\r
+              <check checked="true" name="MISRAC2004-2.2"/>\r
+              <check checked="true" name="MISRAC2004-2.3"/>\r
+              <check checked="false" name="MISRAC2004-2.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-20">\r
+              <check checked="true" name="MISRAC2004-20.1"/>\r
+              <check checked="true" name="MISRAC2004-20.10"/>\r
+              <check checked="true" name="MISRAC2004-20.11"/>\r
+              <check checked="true" name="MISRAC2004-20.12"/>\r
+              <check checked="true" name="MISRAC2004-20.4"/>\r
+              <check checked="true" name="MISRAC2004-20.5"/>\r
+              <check checked="true" name="MISRAC2004-20.6"/>\r
+              <check checked="true" name="MISRAC2004-20.7"/>\r
+              <check checked="true" name="MISRAC2004-20.8"/>\r
+              <check checked="true" name="MISRAC2004-20.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-4">\r
+              <check checked="true" name="MISRAC2004-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-5">\r
+              <check checked="true" name="MISRAC2004-5.1"/>\r
+              <check checked="true" name="MISRAC2004-5.2_a"/>\r
+              <check checked="true" name="MISRAC2004-5.2_b"/>\r
+              <check checked="true" name="MISRAC2004-5.2_c"/>\r
+              <check checked="true" name="MISRAC2004-5.3"/>\r
+              <check checked="true" name="MISRAC2004-5.4"/>\r
+              <check checked="false" name="MISRAC2004-5.5"/>\r
+              <check checked="false" name="MISRAC2004-5.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-6">\r
+              <check checked="true" name="MISRAC2004-6.1"/>\r
+              <check checked="false" name="MISRAC2004-6.3"/>\r
+              <check checked="true" name="MISRAC2004-6.4"/>\r
+              <check checked="true" name="MISRAC2004-6.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-7">\r
+              <check checked="true" name="MISRAC2004-7.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-8">\r
+              <check checked="true" name="MISRAC2004-8.1"/>\r
+              <check checked="true" name="MISRAC2004-8.12"/>\r
+              <check checked="true" name="MISRAC2004-8.2"/>\r
+              <check checked="true" name="MISRAC2004-8.5_a"/>\r
+              <check checked="true" name="MISRAC2004-8.5_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-9">\r
+              <check checked="true" name="MISRAC2004-9.1_a"/>\r
+              <check checked="true" name="MISRAC2004-9.1_b"/>\r
+              <check checked="true" name="MISRAC2004-9.1_c"/>\r
+              <check checked="true" name="MISRAC2004-9.2"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2012">\r
+            <group checked="true" name="MISRAC2012-Dir-4">\r
+              <check checked="true" name="MISRAC2012-Dir-4.10"/>\r
+              <check checked="true" name="MISRAC2012-Dir-4.3"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.4"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_a"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_b"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-1">\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_g"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_h"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-10">\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-11">\r
+              <check checked="true" name="MISRAC2012-Rule-11.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-11.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-12">\r
+              <check checked="false" name="MISRAC2012-Rule-12.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-12.2"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-13">\r
+              <check checked="true" name="MISRAC2012-Rule-13.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_a"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-14">\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-15">\r
+              <check checked="false" name="MISRAC2012-Rule-15.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.4"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-16">\r
+              <check checked="true" name="MISRAC2012-Rule-16.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-17">\r
+              <check checked="true" name="MISRAC2012-Rule-17.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-18">\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_d"/>\r
+              <check checked="false" name="MISRAC2012-Rule-18.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-19">\r
+              <check checked="true" name="MISRAC2012-Rule-19.1"/>\r
+              <check checked="false" name="MISRAC2012-Rule-19.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-2">\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-2.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-20">\r
+              <check checked="false" name="MISRAC2012-Rule-20.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c99"/>\r
+              <check checked="false" name="MISRAC2012-Rule-20.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-21">\r
+              <check checked="true" name="MISRAC2012-Rule-21.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-22">\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-3">\r
+              <check checked="true" name="MISRAC2012-Rule-3.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-4">\r
+              <check checked="false" name="MISRAC2012-Rule-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-5">\r
+              <check checked="true" name="MISRAC2012-Rule-5.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-6">\r
+              <check checked="true" name="MISRAC2012-Rule-6.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-6.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-7">\r
+              <check checked="true" name="MISRAC2012-Rule-7.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-8">\r
+              <check checked="true" name="MISRAC2012-Rule-8.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.10"/>\r
+              <check checked="false" name="MISRAC2012-Rule-8.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.14"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-9">\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_b"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC++2008">\r
+            <group checked="true" name="MISRAC++2008-0-1">\r
+              <check checked="true" name="MISRAC++2008-0-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-11"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-3"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-4"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-6"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-7"/>\r
+              <check checked="false" name="MISRAC++2008-0-1-8"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-2">\r
+              <check checked="true" name="MISRAC++2008-0-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-3">\r
+              <check checked="true" name="MISRAC++2008-0-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-12-1">\r
+              <check checked="true" name="MISRAC++2008-12-1-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-0">\r
+              <check checked="false" name="MISRAC++2008-15-0-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-1">\r
+              <check checked="true" name="MISRAC++2008-15-1-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-3">\r
+              <check checked="true" name="MISRAC++2008-15-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-15-3-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-4"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-5">\r
+              <check checked="true" name="MISRAC++2008-15-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-0">\r
+              <check checked="true" name="MISRAC++2008-16-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-0-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-2">\r
+              <check checked="true" name="MISRAC++2008-16-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-4"/>\r
+              <check checked="false" name="MISRAC++2008-16-2-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-3">\r
+              <check checked="true" name="MISRAC++2008-16-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-16-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-17-0">\r
+              <check checked="true" name="MISRAC++2008-17-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-0">\r
+              <check checked="true" name="MISRAC++2008-18-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-2">\r
+              <check checked="true" name="MISRAC++2008-18-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-4">\r
+              <check checked="true" name="MISRAC++2008-18-4-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-7">\r
+              <check checked="true" name="MISRAC++2008-18-7-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-19-3">\r
+              <check checked="true" name="MISRAC++2008-19-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-10">\r
+              <check checked="true" name="MISRAC++2008-2-10-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_d"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-4"/>\r
+              <check checked="false" name="MISRAC++2008-2-10-5"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-6_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-13">\r
+              <check checked="true" name="MISRAC++2008-2-13-2"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-3">\r
+              <check checked="true" name="MISRAC++2008-2-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-7">\r
+              <check checked="true" name="MISRAC++2008-2-7-1"/>\r
+              <check checked="true" name="MISRAC++2008-2-7-2"/>\r
+              <check checked="false" name="MISRAC++2008-2-7-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-27-0">\r
+              <check checked="true" name="MISRAC++2008-27-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-1">\r
+              <check checked="true" name="MISRAC++2008-3-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-3-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-9">\r
+              <check checked="false" name="MISRAC++2008-3-9-2"/>\r
+              <check checked="true" name="MISRAC++2008-3-9-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-4-5">\r
+              <check checked="true" name="MISRAC++2008-4-5-1"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-0">\r
+              <check checked="true" name="MISRAC++2008-5-0-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-14"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_e"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_f"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-19"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_c"/>\r
+              <check checked="false" name="MISRAC++2008-5-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-21"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-7"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-8"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-14">\r
+              <check checked="true" name="MISRAC++2008-5-14-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-18">\r
+              <check checked="true" name="MISRAC++2008-5-18-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-19">\r
+              <check checked="false" name="MISRAC++2008-5-19-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-2">\r
+              <check checked="false" name="MISRAC++2008-5-2-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-7"/>\r
+              <check checked="false" name="MISRAC++2008-5-2-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-3">\r
+              <check checked="true" name="MISRAC++2008-5-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-8">\r
+              <check checked="true" name="MISRAC++2008-5-8-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-2">\r
+              <check checked="true" name="MISRAC++2008-6-2-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-3">\r
+              <check checked="true" name="MISRAC++2008-6-3-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-4">\r
+              <check checked="true" name="MISRAC++2008-6-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-6"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-7"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-5">\r
+              <check checked="true" name="MISRAC++2008-6-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-6">\r
+              <check checked="true" name="MISRAC++2008-6-6-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-1">\r
+              <check checked="true" name="MISRAC++2008-7-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-7-1-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-2">\r
+              <check checked="true" name="MISRAC++2008-7-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-4">\r
+              <check checked="true" name="MISRAC++2008-7-4-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-5">\r
+              <check checked="true" name="MISRAC++2008-7-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_d"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_a"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-0">\r
+              <check checked="true" name="MISRAC++2008-8-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-4">\r
+              <check checked="true" name="MISRAC++2008-8-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-5">\r
+              <check checked="true" name="MISRAC++2008-8-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-3">\r
+              <check checked="true" name="MISRAC++2008-9-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-9-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-5">\r
+              <check checked="true" name="MISRAC++2008-9-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-6">\r
+              <check checked="true" name="MISRAC++2008-9-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-3"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-4"/>\r
+            </group>\r
+          </package>\r
+        </cstatsettings>\r
+      </data>\r
+    </settings>\r
   </configuration>\r
   <configuration>\r
     <name>Debug_Medium_Data_Model</name>\r
       <name>MSP430</name>\r
     </toolchain>\r
     <debug>1</debug>\r
+    <settings>\r
+      <name>C-STAT</name>\r
+      <archiveVersion>1</archiveVersion>\r
+      <data>\r
+        <cstatsettings>\r
+          <package checked="true" name="STDCHECKS">\r
+            <group checked="true" name="ARR">\r
+              <check checked="true" name="ARR-inv-index-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr-pos"/>\r
+              <check checked="true" name="ARR-inv-index-ptr"/>\r
+              <check checked="true" name="ARR-inv-index"/>\r
+              <check checked="true" name="ARR-neg-index"/>\r
+              <check checked="true" name="ARR-uninit-index"/>\r
+            </group>\r
+            <group checked="true" name="ATH">\r
+              <check checked="true" name="ATH-cmp-float"/>\r
+              <check checked="true" name="ATH-cmp-unsign-neg"/>\r
+              <check checked="true" name="ATH-cmp-unsign-pos"/>\r
+              <check checked="true" name="ATH-div-0-assign"/>\r
+              <check checked="true" name="ATH-div-0-cmp-aft"/>\r
+              <check checked="true" name="ATH-div-0-cmp-bef"/>\r
+              <check checked="true" name="ATH-div-0-interval"/>\r
+              <check checked="true" name="ATH-div-0-pos"/>\r
+              <check checked="true" name="ATH-div-0-unchk-global"/>\r
+              <check checked="true" name="ATH-div-0-unchk-local"/>\r
+              <check checked="true" name="ATH-div-0-unchk-param"/>\r
+              <check checked="true" name="ATH-div-0"/>\r
+              <check checked="true" name="ATH-inc-bool"/>\r
+              <check checked="true" name="ATH-malloc-overrun"/>\r
+              <check checked="true" name="ATH-neg-check-nonneg"/>\r
+              <check checked="true" name="ATH-neg-check-pos"/>\r
+              <check checked="true" name="ATH-new-overrun"/>\r
+              <check checked="false" name="ATH-overflow-cast"/>\r
+              <check checked="true" name="ATH-overflow"/>\r
+              <check checked="true" name="ATH-shift-bounds"/>\r
+              <check checked="true" name="ATH-shift-neg"/>\r
+              <check checked="true" name="ATH-sizeof-by-sizeof"/>\r
+            </group>\r
+            <group checked="true" name="CAST">\r
+              <check checked="false" name="CAST-old-style"/>\r
+            </group>\r
+            <group checked="true" name="CATCH">\r
+              <check checked="true" name="CATCH-object-slicing"/>\r
+              <check checked="false" name="CATCH-xtor-bad-member"/>\r
+            </group>\r
+            <group checked="true" name="COMMA">\r
+              <check checked="false" name="COMMA-overload"/>\r
+            </group>\r
+            <group checked="true" name="COMMENT">\r
+              <check checked="true" name="COMMENT-nested"/>\r
+            </group>\r
+            <group checked="false" name="CONCURRENCY">\r
+              <check checked="true" name="CONCURRENCY-double-lock"/>\r
+              <check checked="true" name="CONCURRENCY-double-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-lock-no-unlock"/>\r
+              <check checked="true" name="CONCURRENCY-sleep-while-locking"/>\r
+            </group>\r
+            <group checked="true" name="CONST">\r
+              <check checked="false" name="CONST-local"/>\r
+              <check checked="true" name="CONST-member-ret"/>\r
+              <check checked="false" name="CONST-param"/>\r
+            </group>\r
+            <group checked="true" name="COP">\r
+              <check checked="true" name="COP-alloc-ctor"/>\r
+              <check checked="true" name="COP-assign-op-ret"/>\r
+              <check checked="true" name="COP-assign-op-self"/>\r
+              <check checked="true" name="COP-assign-op"/>\r
+              <check checked="true" name="COP-copy-ctor"/>\r
+              <check checked="true" name="COP-dealloc-dtor"/>\r
+              <check checked="true" name="COP-dtor-throw"/>\r
+              <check checked="true" name="COP-dtor"/>\r
+              <check checked="true" name="COP-init-order"/>\r
+              <check checked="true" name="COP-init-uninit"/>\r
+              <check checked="true" name="COP-member-uninit"/>\r
+            </group>\r
+            <group checked="true" name="CPU">\r
+              <check checked="true" name="CPU-ctor-call-virt"/>\r
+              <check checked="false" name="CPU-ctor-implicit"/>\r
+              <check checked="true" name="CPU-delete-throw"/>\r
+              <check checked="true" name="CPU-delete-void"/>\r
+              <check checked="true" name="CPU-dtor-call-virt"/>\r
+              <check checked="true" name="CPU-malloc-class"/>\r
+              <check checked="true" name="CPU-nonvirt-dtor"/>\r
+              <check checked="true" name="CPU-return-ref-to-class-data"/>\r
+            </group>\r
+            <group checked="true" name="DECL">\r
+              <check checked="false" name="DECL-implicit-int"/>\r
+            </group>\r
+            <group checked="true" name="DEFINE">\r
+              <check checked="true" name="DEFINE-hash-multiple"/>\r
+            </group>\r
+            <group checked="true" name="ENUM">\r
+              <check checked="false" name="ENUM-bounds"/>\r
+            </group>\r
+            <group checked="true" name="EXP">\r
+              <check checked="true" name="EXP-cond-assign"/>\r
+              <check checked="true" name="EXP-dangling-else"/>\r
+              <check checked="true" name="EXP-loop-exit"/>\r
+              <check checked="false" name="EXP-main-ret-int"/>\r
+              <check checked="false" name="EXP-null-stmt"/>\r
+              <check checked="false" name="EXP-stray-semicolon"/>\r
+            </group>\r
+            <group checked="true" name="EXPR">\r
+              <check checked="true" name="EXPR-const-overflow"/>\r
+            </group>\r
+            <group checked="true" name="FPT">\r
+              <check checked="true" name="FPT-arith-address"/>\r
+              <check checked="true" name="FPT-arith"/>\r
+              <check checked="true" name="FPT-cmp-null"/>\r
+              <check checked="false" name="FPT-literal"/>\r
+              <check checked="true" name="FPT-misuse"/>\r
+            </group>\r
+            <group checked="true" name="FUNC">\r
+              <check checked="false" name="FUNC-implicit-decl"/>\r
+              <check checked="false" name="FUNC-unprototyped-all"/>\r
+              <check checked="true" name="FUNC-unprototyped-used"/>\r
+            </group>\r
+            <group checked="true" name="IDENT">\r
+              <check checked="false" name="IDENT-long-scope-31-chars"/>\r
+              <check checked="false" name="IDENT-long-scope-63-chars"/>\r
+            </group>\r
+            <group checked="true" name="INCLUDE">\r
+              <check checked="false" name="INCLUDE-c-file"/>\r
+            </group>\r
+            <group checked="true" name="INT">\r
+              <check checked="false" name="INT-use-signed-as-unsigned-pos"/>\r
+              <check checked="true" name="INT-use-signed-as-unsigned"/>\r
+            </group>\r
+            <group checked="true" name="ITR">\r
+              <check checked="true" name="ITR-end-cmp-aft"/>\r
+              <check checked="true" name="ITR-end-cmp-bef"/>\r
+              <check checked="true" name="ITR-invalidated"/>\r
+              <check checked="true" name="ITR-mismatch-alg"/>\r
+              <check checked="true" name="ITR-store"/>\r
+              <check checked="true" name="ITR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="LIB">\r
+              <check checked="false" name="LIB-bsearch-overrun-pos"/>\r
+              <check checked="false" name="LIB-bsearch-overrun"/>\r
+              <check checked="false" name="LIB-buf-size"/>\r
+              <check checked="false" name="LIB-fn-unsafe"/>\r
+              <check checked="false" name="LIB-fread-overrun-pos"/>\r
+              <check checked="true" name="LIB-fread-overrun"/>\r
+              <check checked="false" name="LIB-memchr-overrun-pos"/>\r
+              <check checked="true" name="LIB-memchr-overrun"/>\r
+              <check checked="false" name="LIB-memcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-memcpy-overrun"/>\r
+              <check checked="false" name="LIB-memset-overrun-pos"/>\r
+              <check checked="true" name="LIB-memset-overrun"/>\r
+              <check checked="false" name="LIB-putenv"/>\r
+              <check checked="false" name="LIB-qsort-overrun-pos"/>\r
+              <check checked="false" name="LIB-qsort-overrun"/>\r
+              <check checked="true" name="LIB-return-const"/>\r
+              <check checked="true" name="LIB-return-error"/>\r
+              <check checked="true" name="LIB-return-leak"/>\r
+              <check checked="true" name="LIB-return-neg"/>\r
+              <check checked="true" name="LIB-return-null"/>\r
+              <check checked="false" name="LIB-sprintf-overrun"/>\r
+              <check checked="false" name="LIB-std-sort-overrun-pos"/>\r
+              <check checked="true" name="LIB-std-sort-overrun"/>\r
+              <check checked="false" name="LIB-strcat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcat-overrun"/>\r
+              <check checked="false" name="LIB-strcpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strcpy-overrun"/>\r
+              <check checked="false" name="LIB-strncat-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncat-overrun"/>\r
+              <check checked="false" name="LIB-strncmp-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncmp-overrun"/>\r
+              <check checked="false" name="LIB-strncpy-overrun-pos"/>\r
+              <check checked="true" name="LIB-strncpy-overrun"/>\r
+            </group>\r
+            <group checked="true" name="LOGIC">\r
+              <check checked="false" name="LOGIC-overload"/>\r
+            </group>\r
+            <group checked="true" name="MEM">\r
+              <check checked="true" name="MEM-alias-double-free"/>\r
+              <check checked="true" name="MEM-delete-array-op"/>\r
+              <check checked="true" name="MEM-delete-op"/>\r
+              <check checked="true" name="MEM-double-free-alias"/>\r
+              <check checked="true" name="MEM-double-free-some"/>\r
+              <check checked="true" name="MEM-double-free"/>\r
+              <check checked="true" name="MEM-free-field"/>\r
+              <check checked="true" name="MEM-free-fptr"/>\r
+              <check checked="false" name="MEM-free-no-alloc-struct"/>\r
+              <check checked="true" name="MEM-free-no-alloc"/>\r
+              <check checked="true" name="MEM-free-no-use"/>\r
+              <check checked="true" name="MEM-free-op"/>\r
+              <check checked="true" name="MEM-free-struct-field"/>\r
+              <check checked="true" name="MEM-free-variable-alias"/>\r
+              <check checked="true" name="MEM-free-variable"/>\r
+              <check checked="true" name="MEM-leak-alias"/>\r
+              <check checked="false" name="MEM-leak"/>\r
+              <check checked="false" name="MEM-malloc-arith"/>\r
+              <check checked="true" name="MEM-malloc-diff-type"/>\r
+              <check checked="true" name="MEM-malloc-sizeof-ptr"/>\r
+              <check checked="true" name="MEM-malloc-sizeof"/>\r
+              <check checked="false" name="MEM-malloc-strlen"/>\r
+              <check checked="true" name="MEM-realloc-diff-type"/>\r
+              <check checked="true" name="MEM-return-free"/>\r
+              <check checked="true" name="MEM-return-no-assign"/>\r
+              <check checked="true" name="MEM-stack-alias"/>\r
+              <check checked="true" name="MEM-stack-global-alias"/>\r
+              <check checked="true" name="MEM-stack-global-field"/>\r
+              <check checked="true" name="MEM-stack-global"/>\r
+              <check checked="true" name="MEM-stack-param-ref"/>\r
+              <check checked="true" name="MEM-stack-param"/>\r
+              <check checked="true" name="MEM-stack-pos"/>\r
+              <check checked="true" name="MEM-stack-ref"/>\r
+              <check checked="true" name="MEM-stack"/>\r
+              <check checked="true" name="MEM-use-free-all"/>\r
+              <check checked="true" name="MEM-use-free-some"/>\r
+            </group>\r
+            <group checked="true" name="POR">\r
+              <check checked="true" name="POR-imp-cast-subscript"/>\r
+              <check checked="false" name="POR-imp-cast-ternary"/>\r
+            </group>\r
+            <group checked="true" name="PTR">\r
+              <check checked="true" name="PTR-alias-null-pos-deref"/>\r
+              <check checked="true" name="PTR-arith-field"/>\r
+              <check checked="true" name="PTR-arith-stack"/>\r
+              <check checked="true" name="PTR-arith-var"/>\r
+              <check checked="true" name="PTR-cmp-str-lit"/>\r
+              <check checked="true" name="PTR-null-assign-fun-pos"/>\r
+              <check checked="true" name="PTR-null-assign-pos"/>\r
+              <check checked="true" name="PTR-null-assign"/>\r
+              <check checked="true" name="PTR-null-cmp-aft"/>\r
+              <check checked="true" name="PTR-null-cmp-bef-fun"/>\r
+              <check checked="true" name="PTR-null-cmp-bef"/>\r
+              <check checked="true" name="PTR-null-fun-pos"/>\r
+              <check checked="true" name="PTR-null-literal-pos"/>\r
+              <check checked="false" name="PTR-overload"/>\r
+              <check checked="true" name="PTR-singleton-arith-pos"/>\r
+              <check checked="true" name="PTR-singleton-arith"/>\r
+              <check checked="true" name="PTR-unchk-param-some"/>\r
+              <check checked="false" name="PTR-unchk-param"/>\r
+              <check checked="true" name="PTR-uninit-pos"/>\r
+              <check checked="true" name="PTR-uninit"/>\r
+            </group>\r
+            <group checked="true" name="RED">\r
+              <check checked="false" name="RED-case-reach"/>\r
+              <check checked="false" name="RED-cmp-always"/>\r
+              <check checked="false" name="RED-cmp-never"/>\r
+              <check checked="false" name="RED-cond-always"/>\r
+              <check checked="true" name="RED-cond-const-assign"/>\r
+              <check checked="false" name="RED-cond-const-expr"/>\r
+              <check checked="false" name="RED-cond-const"/>\r
+              <check checked="false" name="RED-cond-never"/>\r
+              <check checked="true" name="RED-dead"/>\r
+              <check checked="false" name="RED-expr"/>\r
+              <check checked="false" name="RED-func-no-effect"/>\r
+              <check checked="true" name="RED-local-hides-global"/>\r
+              <check checked="true" name="RED-local-hides-local"/>\r
+              <check checked="true" name="RED-local-hides-member"/>\r
+              <check checked="true" name="RED-local-hides-param"/>\r
+              <check checked="false" name="RED-no-effect"/>\r
+              <check checked="true" name="RED-self-assign"/>\r
+              <check checked="true" name="RED-unused-assign"/>\r
+              <check checked="false" name="RED-unused-param"/>\r
+              <check checked="false" name="RED-unused-return-val"/>\r
+              <check checked="false" name="RED-unused-val"/>\r
+              <check checked="true" name="RED-unused-var-all"/>\r
+            </group>\r
+            <group checked="true" name="RESOURCE">\r
+              <check checked="false" name="RESOURCE-deref-file"/>\r
+              <check checked="true" name="RESOURCE-double-close"/>\r
+              <check checked="true" name="RESOURCE-file-no-close-all"/>\r
+              <check checked="false" name="RESOURCE-file-pos-neg"/>\r
+              <check checked="true" name="RESOURCE-file-use-after-close"/>\r
+              <check checked="false" name="RESOURCE-implicit-deref-file"/>\r
+              <check checked="true" name="RESOURCE-write-ronly-file"/>\r
+            </group>\r
+            <group checked="true" name="SEM">\r
+              <check checked="false" name="SEM-const-call"/>\r
+              <check checked="false" name="SEM-const-global"/>\r
+              <check checked="false" name="SEM-pure-call"/>\r
+              <check checked="false" name="SEM-pure-global"/>\r
+            </group>\r
+            <group checked="true" name="SIZEOF">\r
+              <check checked="true" name="SIZEOF-side-effect"/>\r
+            </group>\r
+            <group checked="true" name="SPC">\r
+              <check checked="false" name="SPC-init-list"/>\r
+              <check checked="true" name="SPC-order"/>\r
+              <check checked="true" name="SPC-return"/>\r
+              <check checked="true" name="SPC-uninit-arr-all"/>\r
+              <check checked="true" name="SPC-uninit-struct-field-heap"/>\r
+              <check checked="true" name="SPC-uninit-struct-field"/>\r
+              <check checked="true" name="SPC-uninit-struct"/>\r
+              <check checked="true" name="SPC-uninit-var-all"/>\r
+              <check checked="true" name="SPC-uninit-var-some"/>\r
+              <check checked="false" name="SPC-volatile-reads"/>\r
+              <check checked="false" name="SPC-volatile-writes"/>\r
+            </group>\r
+            <group checked="true" name="STR">\r
+              <check checked="true" name="STR-trigraph"/>\r
+            </group>\r
+            <group checked="true" name="STRUCT">\r
+              <check checked="false" name="STRUCT-signed-bit"/>\r
+            </group>\r
+            <group checked="true" name="SWITCH">\r
+              <check checked="true" name="SWITCH-fall-through"/>\r
+            </group>\r
+            <group checked="true" name="THROW">\r
+              <check checked="false" name="THROW-empty"/>\r
+              <check checked="false" name="THROW-main"/>\r
+              <check checked="true" name="THROW-null"/>\r
+              <check checked="true" name="THROW-ptr"/>\r
+              <check checked="true" name="THROW-static"/>\r
+              <check checked="true" name="THROW-unhandled"/>\r
+            </group>\r
+            <group checked="true" name="UNION">\r
+              <check checked="true" name="UNION-overlap-assign"/>\r
+              <check checked="true" name="UNION-type-punning"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2004">\r
+            <group checked="true" name="MISRAC2004-1">\r
+              <check checked="true" name="MISRAC2004-1.1"/>\r
+              <check checked="true" name="MISRAC2004-1.2_a"/>\r
+              <check checked="true" name="MISRAC2004-1.2_b"/>\r
+              <check checked="true" name="MISRAC2004-1.2_c"/>\r
+              <check checked="true" name="MISRAC2004-1.2_d"/>\r
+              <check checked="true" name="MISRAC2004-1.2_e"/>\r
+              <check checked="true" name="MISRAC2004-1.2_f"/>\r
+              <check checked="true" name="MISRAC2004-1.2_g"/>\r
+              <check checked="true" name="MISRAC2004-1.2_h"/>\r
+              <check checked="true" name="MISRAC2004-1.2_i"/>\r
+              <check checked="true" name="MISRAC2004-1.2_j"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-10">\r
+              <check checked="true" name="MISRAC2004-10.1_a"/>\r
+              <check checked="true" name="MISRAC2004-10.1_b"/>\r
+              <check checked="true" name="MISRAC2004-10.1_c"/>\r
+              <check checked="true" name="MISRAC2004-10.1_d"/>\r
+              <check checked="true" name="MISRAC2004-10.2_a"/>\r
+              <check checked="true" name="MISRAC2004-10.2_b"/>\r
+              <check checked="true" name="MISRAC2004-10.2_c"/>\r
+              <check checked="true" name="MISRAC2004-10.2_d"/>\r
+              <check checked="true" name="MISRAC2004-10.3"/>\r
+              <check checked="true" name="MISRAC2004-10.4"/>\r
+              <check checked="true" name="MISRAC2004-10.5"/>\r
+              <check checked="true" name="MISRAC2004-10.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-11">\r
+              <check checked="true" name="MISRAC2004-11.1"/>\r
+              <check checked="false" name="MISRAC2004-11.3"/>\r
+              <check checked="false" name="MISRAC2004-11.4"/>\r
+              <check checked="true" name="MISRAC2004-11.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-12">\r
+              <check checked="false" name="MISRAC2004-12.1"/>\r
+              <check checked="true" name="MISRAC2004-12.10"/>\r
+              <check checked="false" name="MISRAC2004-12.11"/>\r
+              <check checked="true" name="MISRAC2004-12.12_a"/>\r
+              <check checked="true" name="MISRAC2004-12.12_b"/>\r
+              <check checked="false" name="MISRAC2004-12.13"/>\r
+              <check checked="true" name="MISRAC2004-12.2_a"/>\r
+              <check checked="true" name="MISRAC2004-12.2_b"/>\r
+              <check checked="true" name="MISRAC2004-12.2_c"/>\r
+              <check checked="true" name="MISRAC2004-12.3"/>\r
+              <check checked="true" name="MISRAC2004-12.4"/>\r
+              <check checked="false" name="MISRAC2004-12.6_a"/>\r
+              <check checked="false" name="MISRAC2004-12.6_b"/>\r
+              <check checked="true" name="MISRAC2004-12.7"/>\r
+              <check checked="true" name="MISRAC2004-12.8"/>\r
+              <check checked="true" name="MISRAC2004-12.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-13">\r
+              <check checked="true" name="MISRAC2004-13.1"/>\r
+              <check checked="false" name="MISRAC2004-13.2_a"/>\r
+              <check checked="false" name="MISRAC2004-13.2_b"/>\r
+              <check checked="false" name="MISRAC2004-13.2_c"/>\r
+              <check checked="false" name="MISRAC2004-13.2_d"/>\r
+              <check checked="false" name="MISRAC2004-13.2_e"/>\r
+              <check checked="true" name="MISRAC2004-13.3"/>\r
+              <check checked="true" name="MISRAC2004-13.4"/>\r
+              <check checked="true" name="MISRAC2004-13.5"/>\r
+              <check checked="true" name="MISRAC2004-13.6"/>\r
+              <check checked="true" name="MISRAC2004-13.7_a"/>\r
+              <check checked="true" name="MISRAC2004-13.7_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-14">\r
+              <check checked="true" name="MISRAC2004-14.1"/>\r
+              <check checked="true" name="MISRAC2004-14.10"/>\r
+              <check checked="true" name="MISRAC2004-14.2"/>\r
+              <check checked="true" name="MISRAC2004-14.3"/>\r
+              <check checked="true" name="MISRAC2004-14.4"/>\r
+              <check checked="true" name="MISRAC2004-14.5"/>\r
+              <check checked="true" name="MISRAC2004-14.6"/>\r
+              <check checked="true" name="MISRAC2004-14.7"/>\r
+              <check checked="true" name="MISRAC2004-14.8_a"/>\r
+              <check checked="true" name="MISRAC2004-14.8_b"/>\r
+              <check checked="true" name="MISRAC2004-14.8_c"/>\r
+              <check checked="true" name="MISRAC2004-14.8_d"/>\r
+              <check checked="true" name="MISRAC2004-14.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-15">\r
+              <check checked="true" name="MISRAC2004-15.0"/>\r
+              <check checked="true" name="MISRAC2004-15.1"/>\r
+              <check checked="true" name="MISRAC2004-15.2"/>\r
+              <check checked="true" name="MISRAC2004-15.3"/>\r
+              <check checked="true" name="MISRAC2004-15.4"/>\r
+              <check checked="true" name="MISRAC2004-15.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-16">\r
+              <check checked="true" name="MISRAC2004-16.1"/>\r
+              <check checked="true" name="MISRAC2004-16.10"/>\r
+              <check checked="true" name="MISRAC2004-16.2_a"/>\r
+              <check checked="true" name="MISRAC2004-16.2_b"/>\r
+              <check checked="true" name="MISRAC2004-16.3"/>\r
+              <check checked="true" name="MISRAC2004-16.5"/>\r
+              <check checked="true" name="MISRAC2004-16.7"/>\r
+              <check checked="true" name="MISRAC2004-16.8"/>\r
+              <check checked="true" name="MISRAC2004-16.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-17">\r
+              <check checked="true" name="MISRAC2004-17.1_a"/>\r
+              <check checked="true" name="MISRAC2004-17.1_b"/>\r
+              <check checked="true" name="MISRAC2004-17.1_c"/>\r
+              <check checked="true" name="MISRAC2004-17.4_a"/>\r
+              <check checked="true" name="MISRAC2004-17.4_b"/>\r
+              <check checked="true" name="MISRAC2004-17.5"/>\r
+              <check checked="true" name="MISRAC2004-17.6_a"/>\r
+              <check checked="true" name="MISRAC2004-17.6_b"/>\r
+              <check checked="true" name="MISRAC2004-17.6_c"/>\r
+              <check checked="true" name="MISRAC2004-17.6_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-18">\r
+              <check checked="true" name="MISRAC2004-18.1"/>\r
+              <check checked="true" name="MISRAC2004-18.2"/>\r
+              <check checked="true" name="MISRAC2004-18.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-19">\r
+              <check checked="true" name="MISRAC2004-19.12"/>\r
+              <check checked="false" name="MISRAC2004-19.13"/>\r
+              <check checked="true" name="MISRAC2004-19.15"/>\r
+              <check checked="false" name="MISRAC2004-19.2"/>\r
+              <check checked="true" name="MISRAC2004-19.6"/>\r
+              <check checked="false" name="MISRAC2004-19.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-2">\r
+              <check checked="true" name="MISRAC2004-2.1"/>\r
+              <check checked="true" name="MISRAC2004-2.2"/>\r
+              <check checked="true" name="MISRAC2004-2.3"/>\r
+              <check checked="false" name="MISRAC2004-2.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-20">\r
+              <check checked="true" name="MISRAC2004-20.1"/>\r
+              <check checked="true" name="MISRAC2004-20.10"/>\r
+              <check checked="true" name="MISRAC2004-20.11"/>\r
+              <check checked="true" name="MISRAC2004-20.12"/>\r
+              <check checked="true" name="MISRAC2004-20.4"/>\r
+              <check checked="true" name="MISRAC2004-20.5"/>\r
+              <check checked="true" name="MISRAC2004-20.6"/>\r
+              <check checked="true" name="MISRAC2004-20.7"/>\r
+              <check checked="true" name="MISRAC2004-20.8"/>\r
+              <check checked="true" name="MISRAC2004-20.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-4">\r
+              <check checked="true" name="MISRAC2004-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-5">\r
+              <check checked="true" name="MISRAC2004-5.1"/>\r
+              <check checked="true" name="MISRAC2004-5.2_a"/>\r
+              <check checked="true" name="MISRAC2004-5.2_b"/>\r
+              <check checked="true" name="MISRAC2004-5.2_c"/>\r
+              <check checked="true" name="MISRAC2004-5.3"/>\r
+              <check checked="true" name="MISRAC2004-5.4"/>\r
+              <check checked="false" name="MISRAC2004-5.5"/>\r
+              <check checked="false" name="MISRAC2004-5.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-6">\r
+              <check checked="true" name="MISRAC2004-6.1"/>\r
+              <check checked="false" name="MISRAC2004-6.3"/>\r
+              <check checked="true" name="MISRAC2004-6.4"/>\r
+              <check checked="true" name="MISRAC2004-6.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-7">\r
+              <check checked="true" name="MISRAC2004-7.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-8">\r
+              <check checked="true" name="MISRAC2004-8.1"/>\r
+              <check checked="true" name="MISRAC2004-8.12"/>\r
+              <check checked="true" name="MISRAC2004-8.2"/>\r
+              <check checked="true" name="MISRAC2004-8.5_a"/>\r
+              <check checked="true" name="MISRAC2004-8.5_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2004-9">\r
+              <check checked="true" name="MISRAC2004-9.1_a"/>\r
+              <check checked="true" name="MISRAC2004-9.1_b"/>\r
+              <check checked="true" name="MISRAC2004-9.1_c"/>\r
+              <check checked="true" name="MISRAC2004-9.2"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC2012">\r
+            <group checked="true" name="MISRAC2012-Dir-4">\r
+              <check checked="true" name="MISRAC2012-Dir-4.10"/>\r
+              <check checked="true" name="MISRAC2012-Dir-4.3"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.4"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_a"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.6_b"/>\r
+              <check checked="false" name="MISRAC2012-Dir-4.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-1">\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_g"/>\r
+              <check checked="true" name="MISRAC2012-Rule-1.3_h"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-10">\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.1_R8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-10.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-11">\r
+              <check checked="true" name="MISRAC2012-Rule-11.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-11.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-11.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-12">\r
+              <check checked="false" name="MISRAC2012-Rule-12.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-12.2"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-12.4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-13">\r
+              <check checked="true" name="MISRAC2012-Rule-13.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_a"/>\r
+              <check checked="false" name="MISRAC2012-Rule-13.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-13.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-14">\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-14.4_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-15">\r
+              <check checked="false" name="MISRAC2012-Rule-15.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.3"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.4"/>\r
+              <check checked="false" name="MISRAC2012-Rule-15.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.6_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-15.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-16">\r
+              <check checked="true" name="MISRAC2012-Rule-16.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-16.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-17">\r
+              <check checked="true" name="MISRAC2012-Rule-17.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-17.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-18">\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.1_d"/>\r
+              <check checked="false" name="MISRAC2012-Rule-18.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.6_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-18.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-19">\r
+              <check checked="true" name="MISRAC2012-Rule-19.1"/>\r
+              <check checked="false" name="MISRAC2012-Rule-19.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-2">\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-2.2_c"/>\r
+              <check checked="false" name="MISRAC2012-Rule-2.7"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-20">\r
+              <check checked="false" name="MISRAC2012-Rule-20.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-20.4_c99"/>\r
+              <check checked="false" name="MISRAC2012-Rule-20.5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-21">\r
+              <check checked="true" name="MISRAC2012-Rule-21.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.10"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.5"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.8"/>\r
+              <check checked="true" name="MISRAC2012-Rule-21.9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-22">\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.2_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.4"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.5_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-22.6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-3">\r
+              <check checked="true" name="MISRAC2012-Rule-3.1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-4">\r
+              <check checked="false" name="MISRAC2012-Rule-4.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-5">\r
+              <check checked="true" name="MISRAC2012-Rule-5.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.3_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.4_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c89"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.5_c99"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.6"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.7"/>\r
+              <check checked="true" name="MISRAC2012-Rule-5.8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-6">\r
+              <check checked="true" name="MISRAC2012-Rule-6.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-6.2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-7">\r
+              <check checked="true" name="MISRAC2012-Rule-7.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.2"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-7.4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-8">\r
+              <check checked="true" name="MISRAC2012-Rule-8.1"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.10"/>\r
+              <check checked="false" name="MISRAC2012-Rule-8.11"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.14"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-8.2_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC2012-Rule-9">\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_b"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_c"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_d"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_e"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.1_f"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.3"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_a"/>\r
+              <check checked="true" name="MISRAC2012-Rule-9.5_b"/>\r
+            </group>\r
+          </package>\r
+          <package checked="false" name="MISRAC++2008">\r
+            <group checked="true" name="MISRAC++2008-0-1">\r
+              <check checked="true" name="MISRAC++2008-0-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-11"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-3"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-4"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-6"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-7"/>\r
+              <check checked="false" name="MISRAC++2008-0-1-8"/>\r
+              <check checked="true" name="MISRAC++2008-0-1-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-2">\r
+              <check checked="true" name="MISRAC++2008-0-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-0-3">\r
+              <check checked="true" name="MISRAC++2008-0-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-12-1">\r
+              <check checked="true" name="MISRAC++2008-12-1-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-12-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-0">\r
+              <check checked="false" name="MISRAC++2008-15-0-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-1">\r
+              <check checked="true" name="MISRAC++2008-15-1-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-3">\r
+              <check checked="true" name="MISRAC++2008-15-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-15-3-2"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-4"/>\r
+              <check checked="true" name="MISRAC++2008-15-3-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-15-5">\r
+              <check checked="true" name="MISRAC++2008-15-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-0">\r
+              <check checked="true" name="MISRAC++2008-16-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-0-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-2">\r
+              <check checked="true" name="MISRAC++2008-16-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-3"/>\r
+              <check checked="true" name="MISRAC++2008-16-2-4"/>\r
+              <check checked="false" name="MISRAC++2008-16-2-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-16-3">\r
+              <check checked="true" name="MISRAC++2008-16-3-1"/>\r
+              <check checked="false" name="MISRAC++2008-16-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-17-0">\r
+              <check checked="true" name="MISRAC++2008-17-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-17-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-0">\r
+              <check checked="true" name="MISRAC++2008-18-0-1"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-18-0-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-2">\r
+              <check checked="true" name="MISRAC++2008-18-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-4">\r
+              <check checked="true" name="MISRAC++2008-18-4-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-18-7">\r
+              <check checked="true" name="MISRAC++2008-18-7-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-19-3">\r
+              <check checked="true" name="MISRAC++2008-19-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-10">\r
+              <check checked="true" name="MISRAC++2008-2-10-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-2_d"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-4"/>\r
+              <check checked="false" name="MISRAC++2008-2-10-5"/>\r
+              <check checked="true" name="MISRAC++2008-2-10-6_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-13">\r
+              <check checked="true" name="MISRAC++2008-2-13-2"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-3"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_a"/>\r
+              <check checked="true" name="MISRAC++2008-2-13-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-3">\r
+              <check checked="true" name="MISRAC++2008-2-3-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-2-7">\r
+              <check checked="true" name="MISRAC++2008-2-7-1"/>\r
+              <check checked="true" name="MISRAC++2008-2-7-2"/>\r
+              <check checked="false" name="MISRAC++2008-2-7-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-27-0">\r
+              <check checked="true" name="MISRAC++2008-27-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-1">\r
+              <check checked="true" name="MISRAC++2008-3-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-3-1-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-3-9">\r
+              <check checked="false" name="MISRAC++2008-3-9-2"/>\r
+              <check checked="true" name="MISRAC++2008-3-9-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-4-5">\r
+              <check checked="true" name="MISRAC++2008-4-5-1"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-4-5-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-0">\r
+              <check checked="true" name="MISRAC++2008-5-0-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-13_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-14"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-15_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_c"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_d"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_e"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-16_f"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-19"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-1_c"/>\r
+              <check checked="false" name="MISRAC++2008-5-0-2"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-21"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-7"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-8"/>\r
+              <check checked="true" name="MISRAC++2008-5-0-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-14">\r
+              <check checked="true" name="MISRAC++2008-5-14-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-18">\r
+              <check checked="true" name="MISRAC++2008-5-18-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-19">\r
+              <check checked="false" name="MISRAC++2008-5-19-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-2">\r
+              <check checked="false" name="MISRAC++2008-5-2-10"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-11_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-4"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-5"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-6"/>\r
+              <check checked="true" name="MISRAC++2008-5-2-7"/>\r
+              <check checked="false" name="MISRAC++2008-5-2-9"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-3">\r
+              <check checked="true" name="MISRAC++2008-5-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-3"/>\r
+              <check checked="true" name="MISRAC++2008-5-3-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-5-8">\r
+              <check checked="true" name="MISRAC++2008-5-8-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-2">\r
+              <check checked="true" name="MISRAC++2008-6-2-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-2-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-3">\r
+              <check checked="true" name="MISRAC++2008-6-3-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-6-3-1_d"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-4">\r
+              <check checked="true" name="MISRAC++2008-6-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-6"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-7"/>\r
+              <check checked="true" name="MISRAC++2008-6-4-8"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-5">\r
+              <check checked="true" name="MISRAC++2008-6-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-3"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-5"/>\r
+              <check checked="true" name="MISRAC++2008-6-5-6"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-6-6">\r
+              <check checked="true" name="MISRAC++2008-6-6-1"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-4"/>\r
+              <check checked="true" name="MISRAC++2008-6-6-5"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-1">\r
+              <check checked="true" name="MISRAC++2008-7-1-1"/>\r
+              <check checked="true" name="MISRAC++2008-7-1-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-2">\r
+              <check checked="true" name="MISRAC++2008-7-2-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-4">\r
+              <check checked="true" name="MISRAC++2008-7-4-3"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-7-5">\r
+              <check checked="true" name="MISRAC++2008-7-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_a"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_b"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_c"/>\r
+              <check checked="true" name="MISRAC++2008-7-5-2_d"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_a"/>\r
+              <check checked="false" name="MISRAC++2008-7-5-4_b"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-0">\r
+              <check checked="true" name="MISRAC++2008-8-0-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-4">\r
+              <check checked="true" name="MISRAC++2008-8-4-1"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-3"/>\r
+              <check checked="true" name="MISRAC++2008-8-4-4"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-8-5">\r
+              <check checked="true" name="MISRAC++2008-8-5-1_a"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_b"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-1_c"/>\r
+              <check checked="true" name="MISRAC++2008-8-5-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-3">\r
+              <check checked="true" name="MISRAC++2008-9-3-1"/>\r
+              <check checked="true" name="MISRAC++2008-9-3-2"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-5">\r
+              <check checked="true" name="MISRAC++2008-9-5-1"/>\r
+            </group>\r
+            <group checked="true" name="MISRAC++2008-9-6">\r
+              <check checked="true" name="MISRAC++2008-9-6-2"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-3"/>\r
+              <check checked="true" name="MISRAC++2008-9-6-4"/>\r
+            </group>\r
+          </package>\r
+        </cstatsettings>\r
+      </data>\r
+    </settings>\r
   </configuration>\r
   <group>\r
     <name>F5XX_6XX_Core_Lib</name>\r
index 650e12accd6b857b62981ee38874b4dc797e543f..2f40e79fd4273dd3cb7243f6aa8447a9bd363409 100644 (file)
@@ -85,6 +85,12 @@ UnspecRange=1
 ActionState=1\r
 [Simulator]\r
 Freq=1000000\r
+[EEM Sequencer]\r
+Buffer=AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\r
+[EEM Cycle Counter 0]\r
+Counter0=AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\r
+[EEM Cycle Counter 1]\r
+Counter1=AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\r
 [Breakpoints]\r
 Count=0\r
 [FET]\r
index 27f558a50a347051ed66133a4e19ed0cffcee07d..9eae4ffea8f5f8b73c044eefe26a3eb8538b680c 100644 (file)
@@ -25,7 +25,7 @@
     <Windows>\r
       \r
       \r
-    <Wnd0>\r
+    <Wnd2>\r
         <Tabs>\r
           <Tab>\r
             <Identity>TabID-18858-27566</Identity>\r
@@ -37,7 +37,7 @@
           </Tab>\r
         </Tabs>\r
         \r
-      <SelectedTab>0</SelectedTab></Wnd0><Wnd1><Tabs><Tab><Identity>TabID-15348-8476</Identity><TabName>Build</TabName><Factory>Build</Factory><Session/></Tab><Tab><Identity>TabID-12693-9958</Identity><TabName>Debug Log</TabName><Factory>Debug-Log</Factory><Session/></Tab></Tabs><SelectedTab>0</SelectedTab></Wnd1></Windows>\r
+      <SelectedTab>0</SelectedTab></Wnd2><Wnd3><Tabs><Tab><Identity>TabID-15348-8476</Identity><TabName>Build</TabName><Factory>Build</Factory><Session/></Tab><Tab><Identity>TabID-12693-9958</Identity><TabName>Debug Log</TabName><Factory>Debug-Log</Factory><Session/></Tab></Tabs><SelectedTab>0</SelectedTab></Wnd3></Windows>\r
     <Editor>\r
       \r
       \r
@@ -50,7 +50,7 @@
       \r
       \r
       \r
-    <Top><Row0><Sizes><Toolbar-00DD53D8><key>iaridepm.enu1</key></Toolbar-00DD53D8></Sizes></Row0></Top><Left><Row0><Sizes><Wnd0><Rect><Top>-2</Top><Left>-2</Left><Bottom>611</Bottom><Right>409</Right><x>-2</x><y>-2</y><xscreen>331</xscreen><yscreen>268</yscreen><sizeHorzCX>197024</sizeHorzCX><sizeHorzCY>272358</sizeHorzCY><sizeVertCX>244643</sizeVertCX><sizeVertCY>622967</sizeVertCY></Rect></Wnd0></Sizes></Row0></Left><Right><Row0><Sizes/></Row0></Right><Bottom><Row0><Sizes><Wnd1><Rect><Top>-2</Top><Left>-2</Left><Bottom>329</Bottom><Right>1682</Right><x>-2</x><y>-2</y><xscreen>1684</xscreen><yscreen>331</yscreen><sizeHorzCX>1002381</sizeHorzCX><sizeHorzCY>336382</sizeHorzCY><sizeVertCX>119048</sizeVertCX><sizeVertCY>203252</sizeVertCY></Rect></Wnd1></Sizes></Row0></Bottom><Float><Sizes/></Float></Positions>\r
+    <Top><Row0><Sizes><Toolbar-00F763E8><key>iaridepm.enu1</key></Toolbar-00F763E8></Sizes></Row0></Top><Left><Row0><Sizes><Wnd2><Rect><Top>-2</Top><Left>-2</Left><Bottom>611</Bottom><Right>409</Right><x>-2</x><y>-2</y><xscreen>331</xscreen><yscreen>268</yscreen><sizeHorzCX>197024</sizeHorzCX><sizeHorzCY>272358</sizeHorzCY><sizeVertCX>244643</sizeVertCX><sizeVertCY>622967</sizeVertCY></Rect></Wnd2></Sizes></Row0></Left><Right><Row0><Sizes/></Row0></Right><Bottom><Row0><Sizes><Wnd3><Rect><Top>-2</Top><Left>-2</Left><Bottom>329</Bottom><Right>1682</Right><x>-2</x><y>-2</y><xscreen>1684</xscreen><yscreen>331</yscreen><sizeHorzCX>1002381</sizeHorzCX><sizeHorzCY>336382</sizeHorzCY><sizeVertCX>119048</sizeVertCX><sizeVertCY>203252</sizeVertCY></Rect></Wnd3></Sizes></Row0></Bottom><Float><Sizes/></Float></Positions>\r
   </Desktop>\r
 </Workspace>\r
 \r
diff --git a/FreeRTOS/Demo/Xilinx_FreeRTOS_BSP/Instructions_ReadMe.url b/FreeRTOS/Demo/Xilinx_FreeRTOS_BSP/Instructions_ReadMe.url
new file mode 100644 (file)
index 0000000..87e9ab5
--- /dev/null
@@ -0,0 +1,5 @@
+[{000214A0-0000-0000-C000-000000000046}]\r
+Prop3=19,2\r
+[InternetShortcut]\r
+URL=http://www.freertos.org/RTOS-Xilinx-SDK-BSP.html\r
+IDList=\r
index ae01cdb99f9c48fd2b072a041a481949f3ece22c..d8f969d9fc08f1ec7a23c8c3b2cb16d0a49f2eb6 100644 (file)
@@ -617,6 +617,34 @@ extern "C" {
        #define traceQUEUE_REGISTRY_ADD(xQueue, pcQueueName)\r
 #endif\r
 \r
+#ifndef traceTASK_NOTIFY_TAKE_BLOCK\r
+       #define traceTASK_NOTIFY_TAKE_BLOCK()\r
+#endif\r
+\r
+#ifndef traceTASK_NOTIFY_TAKE\r
+       #define traceTASK_NOTIFY_TAKE()\r
+#endif\r
+\r
+#ifndef traceTASK_NOTIFY_WAIT_BLOCK\r
+       #define traceTASK_NOTIFY_WAIT_BLOCK()\r
+#endif\r
+\r
+#ifndef traceTASK_NOTIFY_WAIT\r
+       #define traceTASK_NOTIFY_WAIT()\r
+#endif\r
+\r
+#ifndef traceTASK_NOTIFY\r
+       #define traceTASK_NOTIFY()\r
+#endif\r
+\r
+#ifndef traceTASK_NOTIFY_FROM_ISR\r
+       #define traceTASK_NOTIFY_FROM_ISR()\r
+#endif\r
+\r
+#ifndef traceTASK_NOTIFY_GIVE_FROM_ISR\r
+       #define traceTASK_NOTIFY_GIVE_FROM_ISR()\r
+#endif\r
+\r
 #ifndef configGENERATE_RUN_TIME_STATS\r
        #define configGENERATE_RUN_TIME_STATS 0\r
 #endif\r
index 05252fead719a882b2d6623f9e5fbbae960d905d..8f22da6d95c83d7d382e30234477913b819dfa62 100644 (file)
@@ -113,10 +113,8 @@ typedef unsigned short UBaseType_t;
 /*-----------------------------------------------------------*/\r
 \r
 /* Critical section management. */\r
-#define portINTERRUPT_BITS                     ( ( uint16_t ) configKERNEL_INTERRUPT_PRIORITY << ( uint16_t ) 5 )\r
-\r
-#define portDISABLE_INTERRUPTS()       SR |= portINTERRUPT_BITS; __asm volatile ( "NOP" )\r
-#define portENABLE_INTERRUPTS()                SR &= ~portINTERRUPT_BITS\r
+#define portDISABLE_INTERRUPTS()       SET_CPU_IPL( configKERNEL_INTERRUPT_PRIORITY ); __asm volatile ( "NOP" )\r
+#define portENABLE_INTERRUPTS()                SET_CPU_IPL( 0 )\r
 \r
 /* Note that exiting a critical sectino will set the IPL bits to 0, nomatter\r
 what their value was prior to entering the critical section. */\r
index 683aa529c6f25fe4ff019683dceea4b17a4df37c..4e6b29d880ed91b120b38cf16592a0edc8ce2e02 100644 (file)
@@ -1062,8 +1062,8 @@ StackType_t *pxTopOfStack;
 \r
                taskENTER_CRITICAL();\r
                {\r
-                       /* If null is passed in here then we are changing the\r
-                       priority of the calling function. */\r
+                       /* If null is passed in here then it is the priority of the that\r
+                       called uxTaskPriorityGet() that is being queried. */\r
                        pxTCB = prvGetTCBFromHandle( xTask );\r
                        uxReturn = pxTCB->uxPriority;\r
                }\r
@@ -3960,6 +3960,8 @@ TickType_t uxReturn;
                                        }\r
                                        #endif /* INCLUDE_vTaskSuspend */\r
 \r
+                                       traceTASK_NOTIFY_TAKE_BLOCK();\r
+\r
                                        /* All ports are written to allow a yield in a critical\r
                                        section (some will yield immediately, others wait until the\r
                                        critical section exits) - but it is not something that\r
@@ -3980,6 +3982,7 @@ TickType_t uxReturn;
 \r
                taskENTER_CRITICAL();\r
                {\r
+                       traceTASK_NOTIFY_TAKE();\r
                        ulReturn = pxCurrentTCB->ulNotifiedValue;\r
 \r
                        if( ulReturn != 0UL )\r
@@ -4075,6 +4078,8 @@ TickType_t uxReturn;
                                        }\r
                                        #endif /* INCLUDE_vTaskSuspend */\r
 \r
+                                       traceTASK_NOTIFY_WAIT_BLOCK();\r
+                                       \r
                                        /* All ports are written to allow a yield in a critical\r
                                        section (some will yield immediately, others wait until the\r
                                        critical section exits) - but it is not something that\r
@@ -4095,6 +4100,8 @@ TickType_t uxReturn;
 \r
                taskENTER_CRITICAL();\r
                {\r
+                       traceTASK_NOTIFY_WAIT();\r
+                       \r
                        if( pulNotificationValue != NULL )\r
                        {\r
                                /* Output the current notification value, which may or may not\r
@@ -4183,6 +4190,7 @@ TickType_t uxReturn;
                                        break;\r
                        }\r
 \r
+                       traceTASK_NOTIFY();\r
 \r
                        /* If the task is in the blocked state specifically to wait for a\r
                        notification then unblock it now. */\r
@@ -4307,7 +4315,8 @@ TickType_t uxReturn;
                                        break;\r
                        }\r
 \r
-\r
+                       traceTASK_NOTIFY_FROM_ISR();\r
+                       \r
                        /* If the task is in the blocked state specifically to wait for a\r
                        notification then unblock it now. */\r
                        if( eOriginalNotifyState == eWaitingNotification )\r
@@ -4388,6 +4397,8 @@ TickType_t uxReturn;
                        /* 'Giving' is equivalent to incrementing a count in a counting\r
                        semaphore. */\r
                        ( pxTCB->ulNotifiedValue )++;\r
+                       \r
+                       traceTASK_NOTIFY_GIVE_FROM_ISR();\r
 \r
                        /* If the task is in the blocked state specifically to wait for a\r
                        notification then unblock it now. */\r