Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SEGGER Embedded Studio support for X-HEEP #370

Merged
merged 67 commits into from
Oct 5, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
67 commits
Select commit Hold shift + click to select a range
fd12f2d
sw Makefile and general readme minor modifications
JoseCalero Aug 11, 2022
135c9d3
Merge branch 'main' into main
JoseCalero Aug 12, 2022
4945c02
updating with upstream main
JoseCalero Aug 17, 2022
059e67c
fix uart pins and spi flash memory size
JoseCalero Aug 25, 2022
058a58b
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Aug 26, 2022
2551109
Added macro for uart baudrate by default based on the target
JoseCalero Aug 26, 2022
57e2303
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Aug 29, 2022
d1cc7d2
linker modification for the flash (.data section being in wrong place)
JoseCalero Aug 29, 2022
e7446ba
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Sep 13, 2022
c5599f3
Merge branch 'esl-epfl:main' into main
JoseCalero Oct 18, 2022
aa1e5a4
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Oct 25, 2022
bd75bfa
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Oct 28, 2022
e504411
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Oct 31, 2022
29dca2d
Added cmake + cpp with the same upstream folder structure
JoseCalero Oct 31, 2022
0947793
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Nov 9, 2022
2351ef9
Update + minor changes cmake
JoseCalero Dec 16, 2022
b336f9d
Major commit includding Makefile doc automatisation, CMake, and FreeR…
JoseCalero Jan 5, 2023
e339eaa
Merge remote-tracking branch 'upstream/main'
JoseCalero Jan 5, 2023
9a25bf8
Minor permission changes
JoseCalero Jan 5, 2023
f9a9629
Update README.md
JoseCalero Jan 23, 2023
58e43e4
Minor CMake, linker, freeRTOS, and Makefile modifications
JoseCalero Jan 24, 2023
1238aa4
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Jan 24, 2023
2845068
FPGA testing + commands automatizations
JoseCalero Jan 25, 2023
e2a462a
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Feb 13, 2023
052007b
Updating readme and app for freertos
JoseCalero Feb 14, 2023
db39d42
CMake auto backend
JoseCalero Feb 27, 2023
8cb859b
fix CMake include list
JoseCalero Feb 27, 2023
5d47c35
minor update
JoseCalero Feb 27, 2023
48065d9
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Feb 27, 2023
1eae6f8
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Mar 31, 2023
a1d91d3
Using the needed HEAP for the current freeRTOS example
JoseCalero Mar 31, 2023
7a5362b
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Apr 4, 2023
b32277a
Fixing apps and CMakeLists
JoseCalero Apr 4, 2023
d8d6e2a
Re-adjust ram. Re-size also stack and heap for on-chip linker
JoseCalero Apr 5, 2023
ad419db
Add comment hjson
JoseCalero Apr 5, 2023
1b6b468
Modify Readme
JoseCalero Apr 5, 2023
d177a8e
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Apr 5, 2023
47dcad1
Merge remote-tracking branch 'upstream/main' into main
JoseCalero Apr 5, 2023
7635837
Updating CMake backend
JoseCalero May 9, 2023
3de5278
Merge branch 'esl-epfl:main' into main
JoseCalero May 9, 2023
6b33bbd
Change crt logic based on supported preprocessor variables
JoseCalero May 15, 2023
3ad1040
Merge remote-tracking branch 'upstream/main' into main
JoseCalero May 15, 2023
e332d09
Added vector file for freertos
JoseCalero May 15, 2023
edff111
Merge branch 'esl-epfl:main' into app_fix
JoseCalero May 17, 2023
1ec980e
Fix compilation issues with some APPs
JoseCalero May 17, 2023
013bd49
Merge branch 'esl-epfl:main' into app_fix
JoseCalero May 17, 2023
40af91f
Added script to compile them all
JoseCalero May 18, 2023
8e3b578
Added script file
JoseCalero May 18, 2023
bd5fab3
Merge branch 'esl-epfl:main' into main
JoseCalero May 24, 2023
92784ce
Merge branch 'esl-epfl:main' into main
JoseCalero May 31, 2023
868c4ec
Fill linker flash load up to __boot_address
JoseCalero May 31, 2023
27d4dda
Merge branch 'esl-epfl:main' into main
JoseCalero Jul 28, 2023
162b16b
Merge branch 'esl-epfl:main' into main
JoseCalero Sep 6, 2023
ca75899
Added SES support
JoseCalero Sep 6, 2023
d4ceebb
Minor fixes, read, delete some files, add 2nd image
JoseCalero Sep 7, 2023
8f6ce8a
Update IDEs.md
JoseCalero Sep 7, 2023
2966b4d
Update IDEs.md
JoseCalero Sep 7, 2023
9241e74
Minor fixes, delete some files outputs
JoseCalero Sep 7, 2023
51c709d
Merge branch 'main' of https://github.com/JoseCalero/x-heep into main
JoseCalero Sep 7, 2023
0fe943d
test readthedocs
JoseCalero Sep 12, 2023
dd801b5
Test readthedocs
JoseCalero Sep 12, 2023
b6d3fea
Test readthedocs
JoseCalero Sep 12, 2023
020eebb
Readthedocs first integration
JoseCalero Sep 12, 2023
84ad5f1
Readthedocs first integration fix
JoseCalero Sep 12, 2023
435fbed
Readthedocs first integration fix
JoseCalero Sep 12, 2023
8219005
minor delete
JoseCalero Oct 5, 2023
0ddda95
minor delete
JoseCalero Oct 5, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
45 changes: 45 additions & 0 deletions IDEs.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@

For FW development, `X-HEEP` can be used together with different Integrated Development Environments (IDEs) flavours. Up to now, full support is just provided by [Segger Embedded Studio (SES)](https://www.segger.com/products/development-tools/embedded-studio/editions/risc-v/). This readme guides you through all the needed steps to get SES working and debugging when prototyping `X-HEEP` into the pynq-z2 board.

# Prerequisite

## 1. SES installation.
The platform was only tested under Linux and version 7.32 of the Embedded Studio for RISC-V. Please, go to the Segger [download center](https://www.segger.com/downloads/embedded-studio/) to get that version. It is assumed that you have already installed the RISC-V compiler and openOCD. If the latter is not true, check the main [Readme](https://github.com/esl-epfl/x-heep) please.

# Configuration

After installing SES, you need to indicate to Segger your Toolchain directory (RISC-V Compiler) as well as your openOCD installation folder. Those need to be specified into `xheep.emProject` file.

For the RISC-V Compiler path, **line 71**:
```
build_toolchain_directory="/home/< user >/tools/riscv/bin"
```
Please, substitute that path to your current path where the RISC-V compiler was installed. Do not forget to target the `bin` folder inside the installation folder of the toolchain.

For the openOCS path, **line 88**:
```
gdb_server_command_line="/home/< user >/tools/openocd/bin/openocd -f &quot;$(ProjectDir)/../../tb/core-v-mini-mcu-pynq-z2-esl-programmer.cfg&quot;"
```
Please, substitute that path to your current path where openOCD was installed. Do not forget to target the `openocd` file inside the `bin` installation folder of openocd.

# Building

Once the paths are set properly, you can open `xheep.emProject` with SES. That will launch SES with one solution already configured, `xheep_ses`, and one project into that solution `helloworld`. Note that this project has already everything configured to run the `helloworld` application of the main repo, i.e. all the source files are linked to the project as well as the `c user include directories` already set up. Moreover, this project is configured to be running (compile, linking, and debug) by using the on-chip linker `sw/linker/link.ld`. If you want to change any of these options, you will need to change the options of the project or the options of the solution. Note that the project is currently set-up to be working on the `Debug_External` configuration. Please, do not move to other configuration when building and/or debugging. Finally, to build the whole project just press `F7` or `Build > Build helloworld`.

The output should be like this:

<p align="left"><img src="ides/img/build_screenshot.png" width="450"></p>

Note that on the right part, you have the memory usage based on the linker we have configured. If you do not see this, you can activate that view in `View > Memory Usage`.

# Debugging

Finally, after building (compile and linking), you can directly start debugging by pressing `F5` or also `Target > Connect GDB Server` and `Debug > Go`. You also have the possibility to activate the terminal to see directly into the SES window the printing characters.

The output should be something like this:

<p align="left"><img src="ides/img/debug_screenshot.png" width="450"></p>

Note that when debugging and setting breakpoints, please, go one-by-one (one breakpoint at a time). Several breakpoints support will be supported in the following releases.

Further improvements and support will be provided and explain in following releases.
6 changes: 5 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -228,10 +228,12 @@ Or, if you use the OpenHW Group [GCC](https://www.embecosm.com/resources/tool-ch
make app COMPILER_PREFIX=riscv32-corev- ARCH=rv32imc_zicsr_zifencei_xcvhwlp1p0_xcvmem1p0_xcvmac1p0_xcvbi1p0_xcvalu1p0_xcvsimd1p0_xcvbitmanip1p0
```

This will create the executable file to be loaded in your target system (ASIC, FPGA, Simulation).
This will create the executable file to be loaded into your target system (ASIC, FPGA, Simulation).
Remember that, `X-HEEP` is using CMake to compile and link. Thus, the generated files after having
compiled and linked are under `sw\build`

Alternatively, in case you are doing pure FW development and you are used to developing using Integrated Development Evironments (IDEs), please check [the IDE readme](./IDEs.md).

## FreeROTS based applications

'X-HEEP' supports 'FreeRTOS' based applications. Please see `sw\applications\blinky_freertos`.
Expand Down Expand Up @@ -452,6 +454,8 @@ The success of the script is not required for merging of a PR.

Follow the [Debug](./Debug.md) guide to debug core-v-mini-mcu.

Alternatively, in case you are used to developing using Integrated Development Environments (IDEs), please check [the IDE readme](./IDEs.md).

## Execute From Flash

Follow the [ExecuteFromFlash](./ExecuteFromFlash.md) guide to exxecute code directly from the FLASH with modelsim, FPGA, or ASIC.
Expand Down
Binary file added ides/img/build_screenshot.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added ides/img/debug_screenshot.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
155 changes: 155 additions & 0 deletions ides/ses/xheep.emProject
Original file line number Diff line number Diff line change
@@ -0,0 +1,155 @@
<!DOCTYPE CrossStudio_Project_File>
<solution Name="xheep_ses" target="20" version="2">
<configuration Name="Debug" hidden="Yes" />
<configuration
Name="Debug External"
build_toolchain_directory="$(ProjectDir)/tools/riscv/bin"
inherited_configurations="External GNU" />
<configuration
Name="Debug Internal"
inherited_configurations="Internal;Debug" />
<configuration Name="External GNU" Platform="RISCV" hidden="Yes" />
<configuration
Name="Release"
c_preprocessor_definitions="NDEBUG"
gcc_debugging_level="Level 2"
gcc_omit_frame_pointer="Yes"
gcc_optimization_level="Level 2 balanced"
hidden="Yes" />
<configuration
Name="Release External"
inherited_configurations="External GNU" />
<configuration
Name="Release Internal"
inherited_configurations="Internal;Release" />
<project Name="helloworld">
<configuration
LIBRARY_HEAP_TYPE="None"
LIBRARY_IO_TYPE="SEMIHOST (host-formatted)"
Name="Common"
arm_keep_assembly="Yes"
arm_linker_search_path="$(ProjectDir)/../../sw/device/lib/base/;$(ProjectDir)/../../sw/device/lib/base/freestanding/;$(ProjectDir)/../../sw/device/lib/runtime/;$(ProjectDir)/../../sw/device/lib/drivers/uart/;$(ProjectDir)/../../sw/device/lib/drivers/rv_plic/;$(ProjectDir)/../../sw/device/lib/drivers/fast_intr_ctrl/;$(ProjectDir)/../../sw/device/lib/drivers/soc_ctrl/;$(ProjectDir)/../../sw/device/lib/drivers/i2s/;$(ProjectDir)/../../sw/device/lib/drivers/i2c/;$(ProjectDir)/../../sw/device/lib/drivers/gpio/;$(ProjectDir)/../../sw/device/lib/drivers/dma/;$(ProjectDir)/../../sw/device/lib/drivers/spi_host/;$(ProjectDir)/../../sw/device/target/pynq-z2/"
build_always_rebuild="Yes"
build_quietly="No"
build_toolchain_directory=""
compiler_diagnostics_show_caret="No"
debug_target_connection="GDB Server"
gcc_debugging_level="Level 3"
gcc_dwarf_generate_pubnames="No"
gcc_dwarf_version="None"
gcc_short_enum="None"
gcc_use_cxa_at_exit="No"
gdb_server_allow_memory_access_during_execution="Yes"
gdb_server_autostart_server="No"
gdb_server_command_line=""
gdb_server_ignore_checksum_errors="No"
gdb_server_port="3333"
gdb_server_register_access="General and Individual"
gdb_server_reset_command="reset halt"
gdb_server_type="OpenOCD"
link_include_standard_libraries="No"
link_linker_script_file="$(ProjectDir)/../../sw/linker/link.ld"
link_use_linker_script_file="Yes"
linker_additional_files=""
linker_output_format="hex"
linker_pre_build_command="$(StudioDir)/bin/mkld -section-placement-file $(StudioDir)/targets/flash_placement_riscv.xml -memory-map-segments &quot;$(MemorySegments)&quot; -symbols __STACKSIZE__=1024;__HEAPSIZE__=1024 Setup/flash_rv32.ld"
linker_section_placements_segments="RAM0 RX 0x00000000 0x00000C800;RAM1 RWX 0x00000C800 0x00003800"
project_directory=""
project_type="Executable"
rv_abi="ilp32"
rv_architecture="rv32imc"
rv_relax="No"
target_device_name="RV32" />
<configuration
BUILD_OPTIONS="RV32 GNU"
Name="Debug External"
RISCV_TOOLCHAIN_VARIANT="Standard"
arm_assembler_variant="gcc"
arm_compiler_variant="gcc"
build_always_rebuild="Yes"
build_generic_options_file_name=""
build_toolchain_directory="/home/< user >/tools/riscv/bin"
c_additional_options="-march=rv32imc -w -Os -g -nostdlib"
c_include_files=""
c_preprocessor_definitions="HOST_BUILD;ON_CHIP"
c_user_include_directories="$(ProjectDir)/../../sw/device/lib/base/;$(ProjectDir)/../../sw/device/lib/base/freestanding/;$(ProjectDir)/../../sw/device/lib/runtime/;$(ProjectDir)/../../sw/device/lib/drivers/uart/;$(ProjectDir)/../../sw/device/lib/drivers/rv_plic/;$(ProjectDir)/../../sw/device/lib/drivers/fast_intr_ctrl/;$(ProjectDir)/../../sw/device/lib/drivers/soc_ctrl/;$(ProjectDir)/../../sw/device/lib/drivers/i2s/;$(ProjectDir)/../../sw/device/lib/drivers/i2c/;$(ProjectDir)/../../sw/device/lib/drivers/gpio/;$(ProjectDir)/../../sw/device/lib/drivers/dma/;$(ProjectDir)/../../sw/device/lib/drivers/spi_host/;$(ProjectDir)/../../sw/device/target/pynq-z2/"
c_user_include_directories_c_only=""
debug_target_connection="GDB Server"
external_build_file_name=""
external_c_compile_command="&quot;$(ToolChainDir)/$(GCCPrefix)gcc&quot; $(COptions) $(COnlyOptions) $(Defines) $(Undefines) $(Includes) $(IncludeFiles) -c &quot;$(RelInputPath)&quot; -o &quot;$(RelTargetPath)&quot;"
external_cpp_compile_command="&quot;$(ToolChainDir)/$(GCCPrefix)g++&quot; -c $(COptions) $(CppOnlyOptions) $(Defines) $(Undefines) $(Includes) $(IncludeFiles) &quot;$(RelInputPath)&quot; -MD -MF &quot;$(RelDependencyPath)&quot; -fno-diagnostics-show-caret -o &quot;$(RelTargetPath)&quot;"
external_cpp_link_command="&quot;$(ToolChainDir)/$(GCCPrefix)g++&quot; $(Objects) $(LinkOptions) -T &quot;$(RelLinkerScriptPath)&quot; -o &quot;$(RelTargetPath)&quot; -Xlinker -Map=&quot;$(RelMapPath)&quot;"
external_link_command="&quot;$(ToolChainDir)/$(GCCPrefix)gcc&quot; $(Objects) $(LinkOptions) -Wl,-Map=&quot;$(RelMapPath)&quot; -T &quot;$(RelLinkerScriptPath)&quot; -o &quot;$(RelTargetPath)&quot;"
external_load_file_type="Detect"
gcc_cl_dwarf_version="None"
gdb_breakpoint_types="Hardware Only"
gdb_server_allow_memory_access_during_execution="Yes"
gdb_server_autostart_server="Yes"
gdb_server_command_line="/home/< user >/tools/openocd/bin/openocd -f &quot;$(ProjectDir)/../../tb/core-v-mini-mcu-pynq-z2-esl-programmer.cfg&quot;"
gdb_server_ignore_checksum_errors="No"
gdb_server_log_file="$(ProjectDir)/gdb_out.txt"
gdb_server_port="3333"
gdb_server_register_access="General and Individual"
gdb_server_reset_command="reset halt"
gdb_server_type="OpenOCD"
gnu_cl_enable_debug_info="Yes"
gnu_cl_optimization_level="None"
link_linker_script_file="$(ProjectDir)/../../sw/linker/link.ld"
linker_additional_options="-I &quot;$(ProjectDir)/../../sw/device/lib/base/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/base/freestanding/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/runtime/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/uart/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/rv_plic/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/fast_intr_ctrl/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/soc_ctrl/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/i2s/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/i2c/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/gpio/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/dma/&quot;;-I &quot;$(ProjectDir)/../../sw/device/lib/drivers/spi_host/&quot;;-I &quot;$(ProjectDir)/../../sw/device/target/pynq-z2/&quot;;-static &quot;$(ProjectDir)/../../sw/device/lib/crt/crt0.S&quot; &quot;$(ProjectDir)/../../sw/device/lib/crt/vectors.S&quot;;-L &quot;$(ToolChainDir)/../riscv32-unknown-elf/lib&quot;;-lc -lm -lgcc -flto -ffunction-sections -fdata-sections -specs=nano.specs -w -march=rv32imc -Os -g -nostdlib"
linker_post_build_command="$(ToolChainDir)/riscv32-unknown-elf-objdump -S &quot;$(ProjectDir)/$(OutDir)/$(ProjectName).elf&quot; &gt; &quot;$(ProjectDir)/$(OutDir)/$(ProjectName).disasm&quot;"
linker_pre_build_command=""
linker_section_placements_segments="RAM0 RX 0x00000000 0x00000C800;RAM1 RWX 0x00000C800 0x00003800"
post_build_command="$(ToolChainDir)/riscv32-unknown-elf-objcopy -O verilog &quot;$(ProjectDir)/$(OutDir)/$(ProjectName).elf&quot; &quot;$(ProjectDir)/$(OutDir)/$(ProjectName)_vfmt.hex&quot;"
pre_build_command=""
rv32gnu_cl_arch="rv32imc"
rv_arch_ext=""
rv_arch_zicsr="Yes"
rv_arch_zifencei="Yes"
rv_debug_extensions="None"
rv_toolchain_prefix=""
use_compiler_driver="No" />
<configuration
BUILD_OPTIONS="RV32 GNU"
Name="External GNU"
build_generic_options_file_name="$(StudioDir)/targets/RV32GNU_build_options.xml"
build_toolchain_directory=""
gcc_prefix="riscv32-unknown-elf-"
link_linker_script_file="Setup/flash_rv32.ld"
link_use_linker_script_file="Yes"
linker_additional_options=""
linker_pre_build_command="$(StudioDir)/bin/mkld -section-placement-file $(StudioDir)/targets/flash_placement_riscv.xml -memory-map-segments &quot;$(MemorySegments)&quot; -symbols __STACKSIZE__=1024;__HEAPSIZE__=1024 Setup/flash_rv32.ld"
project_type="Externally Built Executable"
rv32gnu_cl_abi="ilp32"
rv32gnu_cl_arch="rv32i" />
<configuration
Name="Release External"
gnu_cl_enable_debug_info="No"
gnu_cl_optimization_level="Level 1" />
<folder Name="base">
<file file_name="../../sw/device/lib/base/bitfield.c" />
<file file_name="../../sw/device/lib/base/memory.c" />
<file file_name="../../sw/device/lib/base/memory.h" />
<file file_name="../../sw/device/lib/base/mmio.c" />
</folder>
<folder Name="crt">
<file file_name="../../sw/device/lib/crt/crt0.S" />
<file file_name="../../sw/device/lib/crt/vectors.S" />
</folder>
<folder Name="drivers">
<file file_name="../../sw/device/lib/drivers/dma/dma.c" />
<file file_name="../../sw/device/lib/drivers/fast_intr_ctrl/fast_intr_ctrl.c" />
<file file_name="../../sw/device/lib/drivers/gpio/gpio.c" />
<file file_name="../../sw/device/lib/drivers/rv_plic/rv_plic.c" />
<file file_name="../../sw/device/lib/drivers/soc_ctrl/soc_ctrl.c" />
<file file_name="../../sw/device/lib/drivers/uart/uart.c" />
</folder>
<folder Name="runtime">
<file file_name="../../sw/device/lib/runtime/handler.c" />
<file file_name="../../sw/device/lib/runtime/init.c" />
<file file_name="../../sw/device/lib/runtime/syscalls.c" />
</folder>
<folder Name="source">
<file file_name="../../sw/applications/hello_world/main.c" />
</folder>
</project>
</solution>
39 changes: 39 additions & 0 deletions ides/ses/xheep.emSession
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
<!DOCTYPE CrossStudio_Session_File>
<session>
<Bookmarks/>
<Breakpoints groups="Breakpoints" active_group="Breakpoints"/>
<ExecutionProfileWindow/>
<FrameBuffer/>
<Memory1/>
<Memory2/>
<Memory3/>
<Memory4/>
<Project>
<ProjectSessionItem path="xheep_ses"/>
<ProjectSessionItem path="xheep_ses;helloworld"/>
</Project>
<Register1/>
<Register2/>
<Register3/>
<Register4/>
<Threads>
<ThreadsWindow showLists=""/>
</Threads>
<TraceWindow>
<Trace enabled="Yes"/>
</TraceWindow>
<Watch1>
<Watches active="1" update="Never"/>
</Watch1>
<Watch2>
<Watches active="0" update="Never"/>
</Watch2>
<Watch3>
<Watches active="0" update="Never"/>
</Watch3>
<Watch4>
<Watches active="0" update="Never"/>
</Watch4>
<Files/>
<EMStudioWindow activeProject="helloworld" fileDialogDefaultFilter="*" autoConnectTarget="GDB Server" buildConfiguration="Debug External" sessionSettings="" debugSearchFileMap="" fileDialogInitialDirectory="" debugSearchPath="" autoConnectCapabilities="1343"/>
</session>
Loading