Overview
---
This is an example which demonstrates how to use a GEL timer to periodically read the value of a variable and output it to the C I/O Console View in CCS.
Example
---
In the example below, the `GEL_SetTimer()` call is used to create a periodic timer that calls another GEL function, `recordVariables()`, when the timer goes off. The `recordVariables()` function will output a string and the value of a variable to the console window. The example prints the value of a variable called `CputTimer0.InterruptCount` which appears in a cpu timer example program, but any global variable in the program being debugged will work.
```C
menuitem "Record Variables";
hotmenu startTimer()
{
// GEL_SetTimer(milliseconds, timer_id, "callback");
// Parameters
// milliseconds: specifies the amount of time in milliseconds that should elapse between callbacks.
// timer_id: specifies a number to uniquely identify this timer.
// callback: is a string representing the GEL expression to evaluate every time the timer fires.
GEL_SetTimer(5000, 1, "recordVariables()");
}
hotmenu stopTimer()
{
// GEL_CancelTimer(timer_id);
// Parameter:
// timer_id: the id of the timer to cancel
GEL_CancelTimer(1);
}
recordVariables()
{
GEL_TextOut("CpuTimer0.InterruptCount: %d \n",,,,,CpuTimer0.InterruptCount);
}
```
The timer can be enabled and disabled using `startTimer()` and `stopTimer()` functions respectively. When the GEL script is loaded in CCS, these functions will appear in a **Record Variables** hotmenu, under **Scripts** in the menu bar.
data:image/s3,"s3://crabby-images/7d337/7d33703d9c2c84b443ce23f2849dabab462e54f6" alt="Under **Scripts** in the menu bar, there is a **Record Variables** submenu containing two items **startTimer** and **stopTimer**."
[[r Note:
GEL memory accesses are normally intrusive. This means that they will momentarily halt the target to read memory. If the debugger is configured to not automatically allow target halts for debugger memory read requests, then the read will fail.
If your device has real-time memory access support and it is enabled, GEL will be able to read memory non-intrusively. You can learn more about real-time memory access [here](https://processors.wiki.ti.com/index.php/CCS_Modules_Library#Real-time_Debug).]]
Enabling Output to a File
---
You can have CCS stream all C I/O output to a file so that the output of the GEL functions above gets recorded in a file.
1. Click on **Run → Debug Configurations** to open the **Debug Configurations** window.
2. Select the debug configuration you wish to modify in the left pane. If you don't already have a debug configuration for your project, debugging it once will cause CCS to create one.
3. Select the **Common** tab in the right pane.
4. Under **Standard Input and Output**, enable the **Output File** option and enter a file location.
data:image/s3,"s3://crabby-images/6d9ff/6d9ff29d5931915ae446942e41226b5bf60ca8f5" alt="The Debug Configurations Window with an output file selected under the Common tab."