# HG changeset patch # User timkelly # Date 1264610090 21600 # Node ID ce9defbd72a6d06403743bed61ba639d4eea479f # Parent 17e718655d7355f848c817ab05f2b4bbfaefade4# Parent 0396114c1f2e60976fefdf221b99c72b460b4192 merge commit diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/.project --- a/core/com.nokia.carbide.cpp.doc.user/.project Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,22 +0,0 @@ - - - com.nokia.carbide.cpp.doc.user - - - - - - org.eclipse.pde.ManifestBuilder - - - - - org.eclipse.pde.SchemaBuilder - - - - - - org.eclipse.pde.PluginNature - - diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/cheatsheets/stop_mode_cs.xml --- a/core/com.nokia.carbide.cpp.doc.user/html/cheatsheets/stop_mode_cs.xml Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/cheatsheets/stop_mode_cs.xml Wed Jan 27 10:34:50 2010 -0600 @@ -1,22 +1,22 @@ - - - - - - Follow these steps to install on-device stop mode debug software and compilers, create ROM images, and define launch configurations. - - - - - - Before you begin stop mode debugging, make sure all preconditions are met. - - - - - - Define debug launch configurations for the selected project. - - - - + + + + + + Follow these steps to install on-device stop mode debug software and compilers, create ROM images, and define launch configurations. + + + + + + Before you begin stop mode debugging, make sure all preconditions are met. + + + + + + Define debug launch configurations for the selected project. + + + + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/context_help/carbide_debug_dialogs_help.xml --- a/core/com.nokia.carbide.cpp.doc.user/html/context_help/carbide_debug_dialogs_help.xml Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/context_help/carbide_debug_dialogs_help.xml Wed Jan 27 10:34:50 2010 -0600 @@ -237,15 +237,6 @@ - - - Specify the settings for Sophia debugging. - - - - - - Specify the ROM image details. @@ -287,12 +278,6 @@ - - Specify Sophia configuration information. - - - - Specify Trace32 configuration information. diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/context_help/eclipse_dialogs_help.xml --- a/core/com.nokia.carbide.cpp.doc.user/html/context_help/eclipse_dialogs_help.xml Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/context_help/eclipse_dialogs_help.xml Wed Jan 27 10:34:50 2010 -0600 @@ -1,376 +1,370 @@ - - - - - - - - - - - - - - - - - - - - - - The Debug view shows the target debugging information in a tree hierarchy. - - - - - - - - - Use the Variables view to manipulate the variables or variable hierarchy used in source code. - - - - - - - - - - Use the Breakpoints view to examine, enable or disable the breakpoints in one or more build configurations. - - - - - - - - - Use the Expressions view to monitor and manipulate variables, structures, and arrays. - - - - - - - - - - - - - Use the Registers view to view general, FPU, and host-specific registers of the host computer, not the target device. - - - - - - - - - - - Use the Memory view to inspect and change process memory. - - - - - - - - - Specify where the debugger should look for source files. - - - - - - Specify where the debugger should store the debug configuration. - - - - - Select a launch type to create a launch configuration. - - - - - - - - Review launch configuration information. - - - - - - Specify Sophia configuration information. - - - - - - Specify Trace32 configuration information. - - - - - - Specify TRK connection information. - - - - - Specify ROM image information. - - - - - - Specify SIS information. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Use the Debug or Run panels to create launch configurations for your applications. - - - - - - - - - - Use the environment pane to add or remove environment variables. - - - - - - - - - - - - - - - - - - - - - Select the project, class, or file to create. - - - - - - - - - - Select the type of file to import for debugging. - - - - - - - - Import an executable for debugging. - - - - - - - - Use the Console view to show the output of a process and provide keyboard input to a process. - - - - - - - - - - - - - - - - - Use the Console view to show the output of a process and provide keyboard input to a process. - - - - - - - - - - - - - - Select the project type to create. - - - - - - - - - - - Configuration details of this Carbide.c++ installation. May include useful information that should be included with a bug report. - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + The Debug view shows the target debugging information in a tree hierarchy. + + + + + + + + + Use the Variables view to manipulate the variables or variable hierarchy used in source code. + + + + + + + + + + Use the Breakpoints view to examine, enable or disable the breakpoints in one or more build configurations. + + + + + + + + + Use the Expressions view to monitor and manipulate variables, structures, and arrays. + + + + + + + + + + + + + Use the Registers view to view general, FPU, and host-specific registers of the host computer, not the target device. + + + + + + + + + + + Use the Memory view to inspect and change process memory. + + + + + + + + + Specify where the debugger should look for source files. + + + + + + Specify where the debugger should store the debug configuration. + + + + + Select a launch type to create a launch configuration. + + + + + + + + Review launch configuration information. + + + + + + Specify Trace32 configuration information. + + + + + + Specify TRK connection information. + + + + + Specify ROM image information. + + + + + + Specify SIS information. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Use the Debug or Run panels to create launch configurations for your applications. + + + + + + + + + + Use the environment pane to add or remove environment variables. + + + + + + + + + + + + + + + + + + + + + Select the project, class, or file to create. + + + + + + + + + + Select the type of file to import for debugging. + + + + + + + + Import an executable for debugging. + + + + + + + + Use the Console view to show the output of a process and provide keyboard input to a process. + + + + + + + + + + + + + + + + + Use the Console view to show the output of a process and provide keyboard input to a process. + + + + + + + + + + + + + + Select the project type to create. + + + + + + + + + + + Configuration details of this Carbide.c++ installation. May include useful information that should be included with a bug report. + + + + + + + + + + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/projects/launch/launch_configs_overview.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/launch_configs_overview.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/launch_configs_overview.htm Wed Jan 27 10:34:50 2010 -0600 @@ -21,7 +21,6 @@
  • Symbian OS Attach to Process —used to debug processes running on a target device for which a symbol file is available. This is available only for TRK and stop mode debugging. This launch configuration is not available for emulator debugging. Stop mode and TRK can both attach to a process from the Symbian OS Data view.
  • Symbian OS Crash Debugger —used to launch an interactive command-line session with the Symbian OS crash debugger when the device crashes
  • Symbian OS Emulation —used to run or debug executables on an emulator.
  • -
  • Symbian OS Sophia (only available in OEM Edition)—is an external debugger that the Carbide debugger communicates with, to debug any Symbian OS module on a target using a JTAG connection.
  • Symbian OS System TRK (not available Developer Editions) —used to run or debug applications or ROM code on a target device using the System TRK on-device debug agent. System TRK is an application that runs on reference boards and prototype phones and allows you to debug your executables. The debugger will download files to the phone prior to launching.
  • Symbian OS Trace32 (only available in OEM Edition)—is an external debugger that the Carbide debugger communicates with, to debug any Symbian OS module on a target using a JTAG connection.
  • @@ -32,6 +31,6 @@
  • New Launch Configuration Wizard
  • Debug dialog
  • - + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/projects/launch/launch_types.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/launch_types.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/launch_types.htm Wed Jan 27 10:34:50 2010 -0600 @@ -15,7 +15,6 @@
  • Application TRK
  • Attach to Process
  • Emulation
  • -
  • Sophia (STI)
  • System TRK
  • Trace32
  • @@ -23,6 +22,6 @@ - + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/projects/launch/page_debugger.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/page_debugger.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/page_debugger.htm Wed Jan 27 10:34:50 2010 -0600 @@ -1,155 +1,154 @@ - - - - - - -Carbide Debugger panes - - - -

    Debugger panes

    -

    The options shown in the Debugger page differ based upon the type of launch configuration. Generally, the options fall into these choices:

    - -

    Emulation Debugger page

    -

    The Symbian OS Emulation launch configurations the Debugger page to specify entry point breaks and which logs to output to the Console view.

    -

    -

    Figure 1 - Debugger page showing emulation options

    -
    Table 1. Debugger page — emulation options
    - - - - - - - - - - - - - - - - - - - - - -
    OptionExplanation
    Break at entry point Select to halt program execution at a specified - function or address. Enter the desired function - name or address in the corresponding field. If you - enter an address, ensure that it is correct and within - your program.
    View program output

    Enable to direct standard output messages to the Emulation Program Output Console in the Console view.

    -

    NOTE In the epoc.ini file the option LogToFile must also be set to 1.

    View emulator output

    Enable to output emulator messages to the Emulator Output Console in the Console view.

    -

    NOTE In the epoc.ini file the option LogToDebugger must also be set to 1.

    View Windows system messages Enable to output Windows system messages to the Windows System Messages Console in the Console view.
    -

    Run-mode Debugger page

    -

    In a run-mode launch configuration like Application TRK, you can specify an entry break point and how messages are handled as well as define the default instruction set.

    -

    -

    Figure 2 - Debugger page showing run-mode options

    -
    Table 2. Debugger page — run-mode options
    - - - - - - - - - - - - - - - - - - - - - - - - - -
    OptionExplanation

    Break at entry point

    When checked, break at the specified entry point entered into the text field. For .EXE targets, the default entry point is set to E32Main. By default, the Break at entry point option is unchecked for all other target types.

    View program output

    Enable to direct standard output messages to the TRK Program Output Console in the Console view.

    -

    NOTE In the epoc.ini file the option LogToFile must also be set to 1.

    -
    View messages between Carbide and debug agent

    When checked, show the communications between Carbide and the target device in the TRK Communication Log Console of the Console view.

    -

    NOTE You can pin the TRK Communication Log view so that it does not lose focus.

    Message retry delay (ms) Enter the delay time in milliseconds (ms) between 100 and 10000 the debugger should wait for a response. The default Message Retry Delay value is 2000.

    Default Instructon Set

    Specifies the default instruction set to use if the debugger cannot determine the processor mode in order to set breakpoints and to disassemble code. The options are:

    -
      -
    • Auto (examine code at current PC location)
    • -
    • ARM (32-bit)
    • -
    • THUMB (16-bit)
    • -
    -

    By default the Instruction Set option uses ARM 32-bit.

    -

    Stop-mode Debugger page

    -

    In stop-mode launch configurations like System TRK, Trace32, Sophia, and Attach to Process, use the Startup Options to attach to a target and debug or run from the specified start address. Then use Target Options to specify the target's processor type, and set which initialization and memory configuration files to use in the debug session.

    -

    -

    Figure 3 - Debugger page showing stop-mode options

    -
    Table 3. Debugger page — stop-mode options
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    GroupOptionExplanation
     

    Break at entry point

    When checked, break at the specified entry point entered into the text field. For .EXE targets, the default entry point is set to E32Main. By default, the Break at entry point option is unchecked for all other target types.

    Startup Options Soft attach Enable the Soft attach option to attach a debug session to a target and debug from the specified start address instead of the target's default start address. When enabled the downloaded image option is ignored.
    Debug from start address Enable the Debug from start address option to debug from the target's default start address.
    Run from start address Enable the Run from start address option to run from the target's default start address.
    Start address (hex) Enter in hexidecimal format (0x0) the starting address to use during the debug session.
    Reset target at the start of each debug session Forces the Carbide IDE to reset the target at the start of each debug session. This ensures that the debugging session uses the most up-to-date program code.
    Target Options Target Processor A drop down with a list of all supported processors. The process selection should help in determining the memory model. This will in turn help determine the base address and the offsets for the Symbian OS kernel aware information.
     Target initialization file

    Check this box to have the debugger run an initialization script when the debug session starts. For example, if a target device requires initialization for the debugger to be able to read and write memory or registers, you can specify an initialization script here.

    -

    Click Browse to select a script file using a standard file selection dialog box. When using T32, most of the initialization is done in the CMM script file. With other debug protocols like Sophia, you can specify the initialization file, which can be run after connecting to the target.

     Memory configuration file Controls whether the debugger uses a memory configuration file when a debug session starts. The Carbide debugger uses this configuration file to know which memory is accessible, readable, and writable on the target.
    - -

    Other references

    - - - - + + + + + + +Carbide Debugger panes + + +

    Debugger panes

    +

    The options shown in the Debugger page differ based upon the type of launch configuration. Generally, the options fall into these choices:

    + +

    Emulation Debugger page

    +

    The Symbian OS Emulation launch configurations the Debugger page to specify entry point breaks and which logs to output to the Console view.

    +

    +

    Figure 1 - Debugger page showing emulation options

    +
    Table 1. Debugger page — emulation options
    + + + + + + + + + + + + + + + + + + + + + +
    OptionExplanation
    Break at entry point Select to halt program execution at a specified + function or address. Enter the desired function + name or address in the corresponding field. If you + enter an address, ensure that it is correct and within + your program.
    View program output

    Enable to direct standard output messages to the Emulation Program Output Console in the Console view.

    +

    NOTE In the epoc.ini file the option LogToFile must also be set to 1.

    View emulator output

    Enable to output emulator messages to the Emulator Output Console in the Console view.

    +

    NOTE In the epoc.ini file the option LogToDebugger must also be set to 1.

    View Windows system messages Enable to output Windows system messages to the Windows System Messages Console in the Console view.
    +

    Run-mode Debugger page

    +

    In a run-mode launch configuration like Application TRK, you can specify an entry break point and how messages are handled as well as define the default instruction set.

    +

    +

    Figure 2 - Debugger page showing run-mode options

    +
    Table 2. Debugger page — run-mode options
    + + + + + + + + + + + + + + + + + + + + + + + + + +
    OptionExplanation

    Break at entry point

    When checked, break at the specified entry point entered into the text field. For .EXE targets, the default entry point is set to E32Main. By default, the Break at entry point option is unchecked for all other target types.

    View program output

    Enable to direct standard output messages to the TRK Program Output Console in the Console view.

    +

    NOTE In the epoc.ini file the option LogToFile must also be set to 1.

    +
    View messages between Carbide and debug agent

    When checked, show the communications between Carbide and the target device in the TRK Communication Log Console of the Console view.

    +

    NOTE You can pin the TRK Communication Log view so that it does not lose focus.

    Message retry delay (ms) Enter the delay time in milliseconds (ms) between 100 and 10000 the debugger should wait for a response. The default Message Retry Delay value is 2000.

    Default Instructon Set

    Specifies the default instruction set to use if the debugger cannot determine the processor mode in order to set breakpoints and to disassemble code. The options are:

    +
      +
    • Auto (examine code at current PC location)
    • +
    • ARM (32-bit)
    • +
    • THUMB (16-bit)
    • +
    +

    By default the Instruction Set option uses ARM 32-bit.

    +

    Stop-mode Debugger page

    +

    In stop-mode launch configurations like System TRK, Trace32, and Attach to Process, use the Startup Options to attach to a target and debug or run from the specified start address. Then use Target Options to specify the target's processor type, and set which initialization and memory configuration files to use in the debug session.

    +

    +

    Figure 3 - Debugger page showing stop-mode options

    +
    Table 3. Debugger page — stop-mode options
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    GroupOptionExplanation
     

    Break at entry point

    When checked, break at the specified entry point entered into the text field. For .EXE targets, the default entry point is set to E32Main. By default, the Break at entry point option is unchecked for all other target types.

    Startup Options Soft attach Enable the Soft attach option to attach a debug session to a target and debug from the specified start address instead of the target's default start address. When enabled the downloaded image option is ignored.
    Debug from start address Enable the Debug from start address option to debug from the target's default start address.
    Run from start address Enable the Run from start address option to run from the target's default start address.
    Start address (hex) Enter in hexidecimal format (0x0) the starting address to use during the debug session.
    Reset target at the start of each debug session Forces the Carbide IDE to reset the target at the start of each debug session. This ensures that the debugging session uses the most up-to-date program code.
    Target Options Target Processor A drop down with a list of all supported processors. The process selection should help in determining the memory model. This will in turn help determine the base address and the offsets for the Symbian OS kernel aware information.
     Target initialization file

    Check this box to have the debugger run an initialization script when the debug session starts. For example, if a target device requires initialization for the debugger to be able to read and write memory or registers, you can specify an initialization script here.

    +

    Click Browse to select a script file using a standard file selection dialog box. When using T32, most of the initialization is done in the CMM script file. With other debug protocols you specify the initialization file, which can be run after connecting to the target.

     Memory configuration file Controls whether the debugger uses a memory configuration file when a debug session starts. The Carbide debugger uses this configuration file to know which memory is accessible, readable, and writable on the target.
    + +

    Other references

    + + + + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/projects/launch/page_main.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/page_main.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/page_main.htm Wed Jan 27 10:34:50 2010 -0600 @@ -13,7 +13,7 @@

    Emulation Main page

    The Symbian OS Emulation launch configuration uses the Main page to define the process to be launched by the emulator.

    @@ -88,7 +88,7 @@

    Stop-mode Main page

    -

    The Symbian OS System TRK, Sophia, and Trace32 launch configurations uses the Main page to defines the project and the executable to launch on the target device.

    +

    The Symbian OS System TRK and Trace32 launch configurations uses the Main page to defines the project and the executable to launch on the target device.

    Figure 3. Main page (TRACE32 shown)

    Table 3. Stop-mode Main page — items
    diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/projects/launch/sophia.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/sophia.htm Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,32 +0,0 @@ - - - - -Sophia Launch Configuration - - - - -

    Sophia Launch Configuration

    -

    Select the Symbian OS Sophia target interface (STI) launch configuration (only available in OEM Edition) to debug any Symbian OS module on a target using a JTAG connection. The external Sophia debugger communicates with the Carbide debugger and enables stop mode debugging of the target device.

    -

    If the New Launch Configuration Wizard was used to create an Sophia launch configuration no changes are usually needed. To modify the launch configuration settings, select the Run > Open Debug Dialog... menu option to open the Debug dialog. Select the Sophia configuration and click a tab to set specific options. Click Apply to save any option modifications. Click Debug to launch a debugging session using the new settings.

    -

    -

    Figure 1. Sophia launch configuration in the Debug dialog

    -

    The Sophia launch configuration panes include:

    -
      -
    • The Main tab defines the project to be launched. Enter the name of the project in the Project field, and the executable name in the Executable field.
    • -
    • The Connection tab defines the Sophia Target Interface, EJ_Debug type, and JTAG TCLK Frequency.
    • -
    • The Debugger tab defines debug configurations, such as entry point to begin debugging, target options, and instruction set.
    • -
    • The ROM Image tab allows you to define startup options and ROM image and ROM log file download information.
    • -
    • The Executables tab allows you to specify which executables that you want to debug that are part of the project.
    • -
    • The Source tab (standard CDT page) defines the location of source files used to display source when debugging an application. By default, these settings are derived from the associated project's build path. You may override these settings here.
    • -
    • The Common tab (standard CDT page) defines general information about the launch configuration. You may choose to store the launch configuration in a specific file.
    • -
    -

    Other references

    - - - - diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/projects/launch/stop_mode.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/stop_mode.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/stop_mode.htm Wed Jan 27 10:34:50 2010 -0600 @@ -9,7 +9,7 @@

    System TRK Launch Configuration (Stop-mode)

    -

    Select the Symbian OS System TRK launch configuration (only available in OEM Edition) provides C/C++ stop-mode debug options that use a JTAG interface when a Symbian OS Sophia or Trace32 launch configuration is created. The settings included in these launch configuration are a combination of Carbide, CDT, and Eclipse options.

    +

    Select the Symbian OS System TRK launch configuration (only available in OEM Edition) provides C/C++ stop-mode debug options that use a JTAG interface when a Symbian OS Trace32 launch configuration is created. The settings included in these launch configuration are a combination of Carbide, CDT, and Eclipse options.

    If the New Launch Configuration Wizard was used to create the System TRK launch configuration no changes are usually needed. To modify the launch configuration settings, select the Run > Open Debug Dialog... menu option to open the Debug dialog. Select the System TRK configuration and click a tab to set specific options. Click Apply to save any option modifications. Click Debug to launch a debugging session using the new settings.

    Figure 1. System TRK launch configuration in the Debug dialog

    @@ -26,6 +26,6 @@ - + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/projects/launch/wiz_new_launch_config.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/wiz_new_launch_config.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/projects/launch/wiz_new_launch_config.htm Wed Jan 27 10:34:50 2010 -0600 @@ -32,8 +32,7 @@
  • Executable Selection
  • Build Option Selection
  • New Launch Configuration
  • - - + Application TRK and System TRK @@ -50,13 +49,6 @@ - Sophia STI - - - Attach to Process
    • TRK Connection Settings
    • @@ -104,21 +96,16 @@

      This page only appears when creating a Trace32 launch configuration.

      Figure 9 - Trace32 Initialization Settings page

      -

      Sophia STI Initialization Settings

      -

      Use the Sophia STI Initialization Settings page to specify the target interface, initialization file, and target processor of the target device. Enter the Sophia Target Interface and Target Initialization File paths, choose a Target Processor, then click Next.

      -

      This page only appears when creating a Sophia STI launch configuration.

      -

      -

      Figure 10 - Sophia STI Initialization Settings page

      Symbian ROM Image Settings

      Use the Symbian ROM Image Settings page to specify the method of debugging, the start address, and the ROM Image and Log File locations.

      -

      This page appears when creating a Trace32 or Sophia STI launch configuration.

      +

      This page appears when creating a Trace32 launch configuration.

      -

      Figure 11 - Symbian ROM Image Settings page

      +

      Figure 10 - Symbian ROM Image Settings page

      Other references
      - + \ No newline at end of file diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/reference/trk/view_remote_connection.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/reference/trk/view_remote_connection.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/reference/trk/view_remote_connection.htm Wed Jan 27 10:34:50 2010 -0600 @@ -35,6 +35,9 @@

    Figure 1 - Remote Connections view

    +

    When the view is closed or another perspective opened, a small display item appears in the lower-left corner of the perspective. Click the connection name to open the drop-down menu where you can open the Remote Connections view or switch between connections.

    +

    +

    Figure 2. Remote Connections tab

    Remote Connections view toolbar icons

    The following commands appear on the toolbar within the Remote Connections view:

    @@ -106,7 +109,7 @@

    Remote Connections view context menu options

    Based on the current selection, one or more of the following commands appear on the context menu when you right-click within the Remote Connections view. For example, if no connections are defined, only the New Connection command is available on the context menu. Right-click on a connection name and the additional Enable Service Testing and Disable Service Testing are available.

    -

    Figure 2 - Remote Connections context menu

    +

    Figure 3 - Remote Connections context menu

    @@ -163,7 +166,7 @@
  • Install latest TRK
  • Plug-n-Play TRK Setup
  • - + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/reference/view_symbian_kernel.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/reference/view_symbian_kernel.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/reference/view_symbian_kernel.htm Wed Jan 27 10:34:50 2010 -0600 @@ -52,7 +52,7 @@ - @@ -108,7 +108,7 @@
  • Setting Symbian OS View Refresh Rate
  • - + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug.htm Wed Jan 27 10:34:50 2010 -0600 @@ -8,14 +8,14 @@

    Stop Mode Debug Example

    -

    This example shows how to create and build an application and debug it on a device using JTAG debug software and Lauterbach or Sophia hardware.

    +

    This example shows how to create and build an application and debug it on a device using JTAG debug software and Lauterbach hardware.

    The basic steps include:

    With stop mode debugging you can use the Carbide.c++ IDE and a JTAG interface to communicate between the debugger and a board to debug any target type within the Symbian OS.

    @@ -29,9 +29,8 @@ - + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_jtag.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_jtag.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_jtag.htm Wed Jan 27 10:34:50 2010 -0600 @@ -1,70 +1,49 @@ - - - - - -Stop Mode On-Device Debugging - - - -

    Installing JTAG

    -
    -

    Install the JTAG Software

    -
    Using Lauterbach Hardware
    -
      -
    1. Program Lauterbach with Proper License
    2. -

      You will need a Trace32 (Lauterbach), a USB cable, and a Lauterbach power supply. You will need to program the Lauterbach with licenses for the particular processors you will be targeting.

      -

      Older Lauterbachs have Xscale for Lubbock and ARM9 for H2/Renesas licenses installed on them already. Newer Lauterbachs should have ARM9 for H2/Renesas and ARM11 for H4 licenses installed on them already. If you don’t have the proper license installed on the Lauterbach for the processor you want to work with, you will receive an error when launching a debug session.

      -
    3. Run the Trace32 Installer -
        -
      • Run the Setup.bat file. During installation select the following options:

        - Product Type: In-Circuit Debugger
        - ICD interface Type: USB Interface
        - Selection of license for new software: License key not necessary
        - CPU selection: ICD ARM7 ARM9 ARM10 ARM11 ICD XSCALE
      • -
      -
    4. -
    5. Install the USB Drivers
    6. -
        -
      1. Place a Trace32 CD into the host machine.
      2. -
      3. Plug in the USB connector from the Lauterbach into the host machine.
      4. -
      5. Once the host machine detects the connection, install the drivers from the CD.
      6. -
      -
    7. Copy Trace32 License File to T32 Folder
    8. -

      The newer Lauterbachs require a license file in the T32 folder. Copy the trace32 license file called license.t32 to your C:\T32 folder.

      - -
    9. Copy Trace32 Configuration File
    10. -

      For H4 board: Copy the trace32 configuration file for the non-ARM11 processor, called config_arm11.t32, to your C:\T32 folder. You can also modify the default config_arm11.t32 file. This file needs to be modified to specify the port number and also enable T32 to support debugger commands outside T32. Carbide.c++ provides specific T32 config files in the support folder. The default config file will be called carbideconfig.t32.

      -
    11. Set up the Board
    12. -

      Power up the board. You should now be able to download the image.

      -
    - -
    Using Sophia Hardware
    -
      -
    1. If needed, install the following Watchpoint debugger software:
      -

      Watchpoint ARM9
      - Watchpoint ARM11
      - CodeWarrior - Watchpoint Connection tool
      - Driver for USB dongle for STI ARM
      - Watchpoint ARM9 Help Files

    2. -
    3. Setup Watchpoint
    4. -

      Copy and unzip Watchpoint project and initialization files to any directory on your PC.

      -
    5. Establish Target Connection -
        -
      1. Plug USB dongle into your PC, and install the drivers if necessary.
      2. -
      3. Connect Sophia EJ-Debug JTAG device to the Jtag on the mother board (make sure SW3-7 is off) and to PC via USB cable.
      4. -
      5. When Windows prompts you for a driver, navigate to your WATCHPOINT\US_ARM9 or WATCHPOINT\US_ARM11 installation.
      6. -
      7. Open the WatchPoint project file. If it launches successfully, you have established a connection.
      8. -
      -

      After successfully opening the project file, make sure that for the H4 target, the Jtag clock is set to 8.33MHz. This can be done from the Resource menu of WatchPoint. Select the ‘ICE Configuration’ option and then select the ‘Clock’ tab. Check the 8.33 MHz radio button and apply the settings.

      -
    6. -
    -
    -
    Related Tasks
    - - - - + + + + + +Stop Mode On-Device Debugging + + + +

    Installing JTAG

    +
    +

    Install the JTAG Software

    +
    Using Lauterbach Hardware
    +
      +
    1. Program Lauterbach with Proper License
    2. +

      You will need a Trace32 (Lauterbach), a USB cable, and a Lauterbach power supply. You will need to program the Lauterbach with licenses for the particular processors you will be targeting.

      +

      Older Lauterbachs have Xscale for Lubbock and ARM9 for H2/Renesas licenses installed on them already. Newer Lauterbachs should have ARM9 for H2/Renesas and ARM11 for H4 licenses installed on them already. If you don’t have the proper license installed on the Lauterbach for the processor you want to work with, you will receive an error when launching a debug session.

      +
    3. Run the Trace32 Installer +
        +
      • Run the Setup.bat file. During installation select the following options:

        + Product Type: In-Circuit Debugger
        + ICD interface Type: USB Interface
        + Selection of license for new software: License key not necessary
        + CPU selection: ICD ARM7 ARM9 ARM10 ARM11 ICD XSCALE
      • +
      +
    4. +
    5. Install the USB Drivers
    6. +
        +
      1. Place a Trace32 CD into the host machine.
      2. +
      3. Plug in the USB connector from the Lauterbach into the host machine.
      4. +
      5. Once the host machine detects the connection, install the drivers from the CD.
      6. +
      +
    7. Copy Trace32 License File to T32 Folder
    8. +

      The newer Lauterbachs require a license file in the T32 folder. Copy the trace32 license file called license.t32 to your C:\T32 folder.

      + +
    9. Copy Trace32 Configuration File
    10. +

      For H4 board: Copy the trace32 configuration file for the non-ARM11 processor, called config_arm11.t32, to your C:\T32 folder. You can also modify the default config_arm11.t32 file. This file needs to be modified to specify the port number and also enable T32 to support debugger commands outside T32. Carbide.c++ provides specific T32 config files in the support folder. The default config file will be called carbideconfig.t32.

      +
    11. Set up the Board
    12. +

      Power up the board. You should now be able to download the image.

      +
    +
    +
    Related Tasks
    + + + + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_launchcfg.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_launchcfg.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_launchcfg.htm Wed Jan 27 10:34:50 2010 -0600 @@ -1,301 +1,280 @@ - - - - - -Stop Mode On-Device Debugging - - - -

    Defining a Stop Mode Debug Configuration

    -

    After installing all necessary software such as Perl, JTAG, compilers, Devkits and SDKs and creating your project, you will need to define a Debug launch configuration for your project. For this example, we will define a Trace32 launch configuration. For new projects that do not have a launch configuration, a New Launch Configuration Wizard will appear and allow you to define settings. You can also cancel the wizard and define a launch configuration from the following instructions.

    -
    -

    Define a Launch Configuration

    -
      -
    1. Access the Debug window -
        -
      1. If necessary, import a project's .mmp or .inf file in Carbide.c++.
      2. -
      3. Select the Project in the C/C++ Project view that you want to debug.
      4. -
      5. Select the Run > Debug… menu option to display the Debug launch configuration window.
      6. -
      7. Define a debug launch configuration to communicate with the on-device debug agent or protocol interface.
      8. -
      9. In the Debug window, define the type of debug launch configuration to use when debugging programs on the target device.
      10. -
      -
    2. -

      -

      Figure 1 - Debug Configurations

      -

      Select either a Symbian OS Sophia or Symbian OS Trace32 configuration type for stop mode on-device debugging and click the New launch configuration icon. The following pages require review and possible option settings:

      -
        -
      • Main - defines the project to be launched on the target device
      • -
      • Connection - specifies the method used to transfer files to the target device
      • -
      • Debugger - provides control over entry points, message handling, and instruction set default settings
      • -
      • ROM Image- specifies startup options and ROM log and image files
      • -
      • Source - specifies the source lookup paths
      • -
      • Common - specifies general launch configuration settings
      • -
      -

      Click Debug after all the preference panels have been set. The Debug window closes and the Carbide.c++ debugger begins a debugging session using the new configuration. The next time you click the Debug icon, this debug launch configuration is used to start a debug session.

      -
    3. Define Main Tab Settings
    4. -

      The Main pane shown in Figure 2 defines the project to be launched on the target device. Table 1 defines the fields.

      -

      -

      Figure 2 - Debug Window - Main Tab

      -

      Table 1. Main pane

      -
    Item

    Debug process or thread

    Click the Debug button to attach to the process and debug the selected process or thread. Or right-click an item and choose Debug. This applys to both TRK (run mode) and Sophia/Trace32 (stop mode).

    +

    Click the Debug button to attach to the process and debug the selected process or thread. Or right-click an item and choose Debug. This applies to both TRK (run mode) and Trace32 (stop mode).

    - - - - - - - - - - - - -
    ItemExplanation
    Project

    The project to associate with this debug launch configuration. Click Browse to select a different project.

    ExecutableThis is the name of the executable that is linked to the project. Click Browse to select a different executable.
    -

    -
  • Define Connection Tab Settings
  • -

    -

    Figure 3 - Debug Window - Connection Tab

    -

    Table 2 - Connection pane

    - - - - - - - - - - - - - - - - - - - - - -
    ItemExplanation
    -

    Trace32 Executable

    Specify the path to the Trace32 executable. The default path assumes that the Trace32 executable is installed in the default location: C:\T32\T32marm.exe.

    -

    Trace32 Configuration File

    Specify the path to the config.t32 file or other custom configuration file. The default path assumes that the Trace32 configuration file is installed in the default location: C:\T32\config.t32. -

    For arm11 processors copy the trace32 configuration file for non-ARM11 processor (config_arm11.t32) to your C:\T32 folder and specify it in the edit box.

    -

    You can modify the config.t32 file to support UDP (User Datagram Protocol) connections by adding the following lines:
    - PBI=USB
    - RCL=NETASSIST
    - PACKLEN=1024
    - PORT=20000

    -

    - - Trace32 Initialization Script

    Specify the path to the initialization cmm file. This script will be run in T32 after connecting to T32. You can specify your own scripts for the targets used.

    -

    - - View messages between Carbide and Trace32

    Enable to log communications with Trace32 to the console window.
    -

    -
  • Define Debugger Tab Settings
  • -

    -

    Figure 4 - Debug Window - Debugger tab

    -

    Table 3 - Debugger pane

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    ItemExplanation
    Break at entry point

    When checked, break at the specified entry point entered in the text field. For .EXE targets, the default entry point is set to E32Main. By default, the Break at entry point option is unchecked for all other target types.

    Target Processor A drop down with a list of all supported processors. The process selection should help in determining the memory model. This will in turn help determine the base address and the offsets for the Symbian OS kernel aware information.
    -

    Target Initialization File

    Check this box to have the debugger run an initialization script when the debug session starts. For example, if a target device requires initialization for the debugger to be able to read and write memory or registers, you can specify an initialization script here. Click Browse to select a script file using a standard file selection dialog box.

    -

    When using T32, most of the initialization is done in the CMM script file. With other debug protocols like Sophia, you can specify the initialization file, which can be run after connecting to the target.

    -

    Memory Configuration File

    Controls whether the debugger uses a memory configuration file when a debug session starts. The Carbide debugger uses this configuration file to know which memory is accessible, readable, and writable on the target.
    -

    Reset target at the start of each debug session

    Forces the Carbide IDE to reset the target at the start of each debug session. This ensures that the debugging session uses the most up-to-date program code.

    Default Instructon Set

    Specifies the default instruction set to use if the debugger cannot determine the processor mode in order to set breakpoints and to disassemble code. This can happen at addresses for which we have no symbolic information. The debugger uses the mode when setting breakpoints and disassembling code. The options are:

    -
      -
    • Auto (examine code at current PC location)
    • -
    • ARM (32-bit)
    • -
    • THUMB (16-bit)
    • -
    -

    By default the Instruction Set option uses ARM 32-bit.

    -

    -
  • Define ROM Image Tab
  • -

    -

    Figure 5 - Debug Window - ROM Image Tab

    -

    Table 4 - ROM Image pane

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    ItemExplanation
    -

    - - Start Address

    Enter the physical address in memory where the Symbian OS start code begins execution. This address is target-specific. The address should be in hexadecimal format with the 0x prefix. For example, 0x8000000 is a valid entry.

    -

    NOTE The address entered in this field must match the start address specified in the source code used to build the Symbian OS ROM image to be debugged. The Start address must match the Download address.

    -

    - - Debug from Start address

    Select this option to have the debugger halt the program at the address specified in Start Address once the target initialization is done and the OS is downloaded; if the user has chosen to download the OS. You can then step through start-up code or run the target in bare-board mode.
    -

    - - - Run from start address

    Select this option to have the debugger start the code at the address specified in Start Address once the target initialization is done. If you have breakpoints set, the debugger stops at the first breakpoint encountered. You can click the Break button to halt the device.
    -

    - - - - Symbian ROM Log file

    Check the Parse ROM Log File option and specify the information that the debugger needs in order to show detailed stack information, set breakpoints, and show source level debugging information for ROM images. In the first text field, browse to or enter the full path and name of the log file that corresponds to the ROM image on the target device. This log file is generated by default when the ROM image is built.
    -

    - - - Symbian OS Kit EPOC32 Directory

    Specifies the epoc32 directory in which the ROM image and log files are stored. Since the log file may not contain full paths to the ROM components on the host PC, you need to enter this epoc32 directory.

    -

    NOTE Always include the epoc32 folder in this path.

    -

    - - - - - Log unresolved modules

    Check this box to have the debugger output a list of components from the specified ROMBUILD log file that do not have debugger symbolic information. The list is displayed in the debugger console window at the beginning of the debug session.

    -

    NOTE You cannot perform source-level debugging on components that do not include symbolic information.

    -

    - - - - - Debug non-XIP Executables

    Check this box to debug a project, or a dynamically loaded module, that is loaded from NAND-Flash or other removable media (MMC, memory stick, etc.) at run time and executed in RAM. Use this option to debug modules that work fine when executed in place as part of the ROM image, but sometimes fail when placed in NAND-Flash or other removable media.

    -

    NOTE Selecting this option will affect debugging performance. When the debugger needs to load a module (DLL, EXE, etc.) it will stop the target, read information from it, then restart it.

    -

    - - - - Symbian ROM Image

    Controls the logging of communication with Trace32. Enable to log communications with Trace32 to the console window.
    -

    Download Address (hex)

    Enter the physical address in memory at which the debugger should place the ROM image. This address is target-specific. The address should be in hexadecimal format with the 0x prefix. For example, 0x000FFF00 is a valid entry.

    -

    NOTE The address entered in this field must match the download address specified in the source code used to build the Symbian OS ROM image to be debugged. If you leave this field blank, the debugger does not download the ROM image to the device at the beginning of the debug session. The Download address must match the Start address.

    -

    Ask for download at the start of each debug session

    Check this box to have the debugger display a dialog box at the beginning of every debug session that lets you choose whether or not you want the debugger to download the ROM image to the device.
    -

     

    - -

    Sophia Target Interface Connection

    -

    The following Connection pane is specific to the Sophia Target Interface and is shown in a Sophia Launch Configuration only. Other panes are same as Trace32 panes.

    -

    -

    Figure 6 - Sophia Connection Window

    -

    Table 5 - Sophia Connection Window

    - - - - - - - - - - - - - - - - - - - - - -
    ItemExplanation
    -

    - - - - - - Sophia Target Interface (WTI.dll) location

    Specifies the location of a Sophia dll that the debugger will load and interface with in order to communicate with the Sophia JTAG interface. The preference panel will try to determine this value from the registry or some other means and auto fill it when possible.
    -

    - - - - EJ_Debug Type

    Sophia Systems' EJ-Debug is a compact, USB-powered JTAG emulator. Select the EJ_Debug type. Options include:

    -
      -
    • Auto (automatically detects target CPU)
    • -
    • ARM9 (target CPU)
    • -
    • ARM11 (target CPU)
    • -
    • ARM9_11 (target CPU)
    • -
    • ARM7_9_11 (target CPU)
    • -
    JTAG TCLK FrequencySelect the JTAG TCLK frequency. Options include: -
      -
    • Auto
    • -
    • 33 MHz
    • -
    • 16 MHz
    • -
    • 8 MHz
    • -
    • 500 KHz
    • -
    View messages between Carbide and STIThe View Messages between Carbide and STI check box allows you to specify if the debug protocol messages between Carbide and STI should be logged in a Communication Log console window.
    - - -
    Related Tasks
    - - - - - - + + + + + +Stop Mode On-Device Debugging + + + + +

    Defining a Stop Mode Debug Configuration

    +

    After installing all necessary software such as Perl, JTAG, compilers, Devkits and SDKs and creating your project, you will need to define a Debug launch configuration for your project. For this example, we will define a Trace32 launch configuration. For new projects that do not have a launch configuration, a New Launch Configuration Wizard will appear and allow you to define settings. You can also cancel the wizard and define a launch configuration from the following instructions.

    +
    +

    Define a Launch Configuration

    +
      +
    1. Access the Debug window +
        +
      1. If necessary, import a project's .mmp or .inf file in Carbide.c++.
      2. +
      3. Select the Project in the C/C++ Project view that you want to debug.
      4. +
      5. Select the Run > Debug… menu option to display the Debug launch configuration window.
      6. +
      7. Define a debug launch configuration to communicate with the on-device debug agent or protocol interface.
      8. +
      9. In the Debug window, define the type of debug launch configuration to use when debugging programs on the target device.
      10. +
      +
    2. +

      +

      Figure 1 - Debug Configurations

      +

      Select either a Symbian OS Trace32 configuration type for stop mode on-device debugging and click the New launch configuration icon. The following pages require review and possible option settings:

      +
        +
      • Main - defines the project to be launched on the target device
      • +
      • Connection - specifies the method used to transfer files to the target device
      • +
      • Debugger - provides control over entry points, message handling, and instruction set default settings
      • +
      • ROM Image- specifies startup options and ROM log and image files
      • +
      • Source - specifies the source lookup paths
      • +
      • Common - specifies general launch configuration settings
      • +
      +

      Click Debug after all the preference panels have been set. The Debug window closes and the Carbide.c++ debugger begins a debugging session using the new configuration. The next time you click the Debug icon, this debug launch configuration is used to start a debug session.

      +
    3. Define Main Tab Settings
    4. +

      The Main pane shown in Figure 2 defines the project to be launched on the target device. Table 1 defines the fields.

      +

      +

      Figure 2 - Debug Window - Main Tab

      +

      Table 1. Main pane

      + + + + + + + + + + + + + +
      ItemExplanation
      Project

      The project to associate with this debug launch configuration. Click Browse to select a different project.

      ExecutableThis is the name of the executable that is linked to the project. Click Browse to select a different executable.
      +

      +
    5. Define Connection Tab Settings
    6. +

      +

      Figure 3 - Debug Window - Connection Tab

      +

      Table 2 - Connection pane

      + + + + + + + + + + + + + + + + + + + + + +
      ItemExplanation
      +

      Trace32 Executable

      Specify the path to the Trace32 executable. The default path assumes that the Trace32 executable is installed in the default location: C:\T32\T32marm.exe.

      +

      Trace32 Configuration File

      Specify the path to the config.t32 file or other custom configuration file. The default path assumes that the Trace32 configuration file is installed in the default location: C:\T32\config.t32. +

      For arm11 processors copy the trace32 configuration file for non-ARM11 processor (config_arm11.t32) to your C:\T32 folder and specify it in the edit box.

      +

      You can modify the config.t32 file to support UDP (User Datagram Protocol) connections by adding the following lines:
      + PBI=USB
      + RCL=NETASSIST
      + PACKLEN=1024
      + PORT=20000

      +

      + + Trace32 Initialization Script

      Specify the path to the initialization cmm file. This script will be run in T32 after connecting to T32. You can specify your own scripts for the targets used.

      +

      + + View messages between Carbide and Trace32

      Enable to log communications with Trace32 to the console window.
      +

      +
    7. Define Debugger Tab Settings
    8. +

      +

      Figure 4 - Debug Window - Debugger tab

      +

      Table 3 - Debugger pane

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      ItemExplanation
      Break at entry point

      When checked, break at the specified entry point entered in the text field. For .EXE targets, the default entry point is set to E32Main. By default, the Break at entry point option is unchecked for all other target types.

      Target Processor A drop down with a list of all supported processors. The process selection should help in determining the memory model. This will in turn help determine the base address and the offsets for the Symbian OS kernel aware information.
      + + + +

      Target Initialization File

      Check this box to have the debugger run an initialization script when the debug session starts. For example, if a target device requires initialization for the debugger to be able to read and write memory or registers, you can specify an initialization script here. Click Browse to select a script file using a standard file selection dialog box.

      +

      When using T32, most of the initialization is done in the CMM script file. With other debug protocols you specify the initialization file, which can be run after connecting to the target.

      + + + +

      Memory Configuration File

      Controls whether the debugger uses a memory configuration file when a debug session starts. The Carbide debugger uses this configuration file to know which memory is accessible, readable, and writable on the target.
      + + + +

      Reset target at the start of each debug session

      Forces the Carbide IDE to reset the target at the start of each debug session. This ensures that the debugging session uses the most up-to-date program code.

      Default Instructon Set

      Specifies the default instruction set to use if the debugger cannot determine the processor mode in order to set breakpoints and to disassemble code. This can happen at addresses for which we have no symbolic information. The debugger uses the mode when setting breakpoints and disassembling code. The options are:

      +
        +
      • Auto (examine code at current PC location)
      • +
      • ARM (32-bit)
      • +
      • THUMB (16-bit)
      • +
      +

      By default the Instruction Set option uses ARM 32-bit.

      +

      +
    9. Define ROM Image Tab
    10. +

      +

      Figure 5 - Debug Window - ROM Image Tab

      +

      Table 4 - ROM Image pane

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      ItemExplanation
      + + +

      + + Start Address

      Enter the physical address in memory where the Symbian OS start code begins execution. This address is target-specific. The address should be in hexadecimal format with the 0x prefix. For example, 0x8000000 is a valid entry.

      +

      NOTE The address entered in this field must match the start address specified in the source code used to build the Symbian OS ROM image to be debugged. The Start address must match the Download address.

      + + +

      + + Debug from Start address

      Select this option to have the debugger halt the program at the address specified in Start Address once the target initialization is done and the OS is downloaded; if the user has chosen to download the OS. You can then step through start-up code or run the target in bare-board mode.
      + + +

      + + + Run from start address

      Select this option to have the debugger start the code at the address specified in Start Address once the target initialization is done. If you have breakpoints set, the debugger stops at the first breakpoint encountered. You can click the Break button to halt the device.
      + + +

      + + + + Symbian ROM Log file

      Check the Parse ROM Log File option and specify the information that the debugger needs in order to show detailed stack information, set breakpoints, and show source level debugging information for ROM images. In the first text field, browse to or enter the full path and name of the log file that corresponds to the ROM image on the target device. This log file is generated by default when the ROM image is built.
      + + +

      + + + Symbian OS Kit EPOC32 Directory

      Specifies the epoc32 directory in which the ROM image and log files are stored. Since the log file may not contain full paths to the ROM components on the host PC, you need to enter this epoc32 directory.

      +

      NOTE Always include the epoc32 folder in this path.

      + + +

      + + + + + Log unresolved modules

      Check this box to have the debugger output a list of components from the specified ROMBUILD log file that do not have debugger symbolic information. The list is displayed in the debugger console window at the beginning of the debug session.

      +

      NOTE You cannot perform source-level debugging on components that do not include symbolic information.

      + + +

      + + + + + Debug non-XIP Executables

      Check this box to debug a project, or a dynamically loaded module, that is loaded from NAND-Flash or other removable media (MMC, memory stick, etc.) at run time and executed in RAM. Use this option to debug modules that work fine when executed in place as part of the ROM image, but sometimes fail when placed in NAND-Flash or other removable media.

      +

      NOTE Selecting this option will affect debugging performance. When the debugger needs to load a module (DLL, EXE, etc.) it will stop the target, read information from it, then restart it.

      + + +

      + + + + Symbian ROM Image

      Controls the logging of communication with Trace32. Enable to log communications with Trace32 to the console window.
      + + +

      Download Address (hex)

      Enter the physical address in memory at which the debugger should place the ROM image. This address is target-specific. The address should be in hexadecimal format with the 0x prefix. For example, 0x000FFF00 is a valid entry.

      +

      NOTE The address entered in this field must match the download address specified in the source code used to build the Symbian OS ROM image to be debugged. If you leave this field blank, the debugger does not download the ROM image to the device at the beginning of the debug session. The Download address must match the Start address.

      + + +

      Ask for download at the start of each debug session

      Check this box to have the debugger display a dialog box at the beginning of every debug session that lets you choose whether or not you want the debugger to download the ROM image to the device.
      +
    +
    +
    Related Tasks
    + + + + + + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_precond.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_precond.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/tasks/debugger/stop_mode_debug_precond.htm Wed Jan 27 10:34:50 2010 -0600 @@ -16,7 +16,7 @@
  • Install the GCCE or RVCT 2.2 or greater compiler (not included with Carbide.c++).
  • Install the TechView Devkit
  • Install Board Support Package (BSP) for your target board
  • -
  • Install JTAG software and drivers for Trace32 or Sophia I/F tool support
  • +
  • Install JTAG software and drivers for Trace32 support
  • Connect JTAG interface between PC and hardware
  • Verify that your SDK or customer kit is recognized in the SDK preferences panel.
  • Build your ROM Image
  • @@ -25,8 +25,7 @@
    Related Tasks
    - + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/tasks/processes/images/sos_processes_choose_thread.png Binary file core/com.nokia.carbide.cpp.doc.user/html/tasks/processes/images/sos_processes_choose_thread.png has changed diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/tasks/projects/prj_debug_rom.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/tasks/projects/prj_debug_rom.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/tasks/projects/prj_debug_rom.htm Wed Jan 27 10:34:50 2010 -0600 @@ -18,15 +18,14 @@

    NOTE You cannot debug ROM DLLs using Application TRK.

      -
    • In Sophia or Trace32 you must specify the ROM log file in the ROM Image tab of the Trace32 or Sophia launch configuration
    • +
    • In Trace32 you must specify the ROM log file in the ROM Image tab of the Trace32 launch configuration
    Other references
    - + \ No newline at end of file diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/html/tasks/start/carbide_debugging.htm --- a/core/com.nokia.carbide.cpp.doc.user/html/tasks/start/carbide_debugging.htm Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/html/tasks/start/carbide_debugging.htm Wed Jan 27 10:34:50 2010 -0600 @@ -16,11 +16,11 @@

    NOTE You can only debug compiled programs. Use the Build Project command to compile project sources into a binary file if you do not already have an executable in the project. You will also need a symbolics ( .sym) file for debugging on a target device. Ensure that a .sym file has been created. If you are importing an existing application, you may have to rebuild the application and create a related .sym file. Make sure a .sym file has been created in the output directory.

    1. Set a breakpoint in the HelloCarbide program
    2. -

      Open the \src\CHelloCarbideAppUI.cpp file and set a breakpoint in the HandleCommandL routine.

      +

      Open the \src\CHelloCarbideAppUI.cpp file and set a breakpoint in the HandleCommandL routine.

      Figure 1 - Breakpoint set in CHelloCarbideAppUI::HandleCommandL routine.

    3. Launch the Carbide.c++ debugger and S60 EPOC Emulator
    4. -

      Start the Carbide debugger which launches the S60 EPOC Emulator and installs the HelloCarbide application. For on-device debugging, your application will be installed on your target device.

      +

      Start the Carbide debugger which launches the S60 EPOC Emulator and installs the HelloCarbide application. For on-device debugging, the application is installed on the target device.

      Figure 2 - S60 Emulator launches

    5. Open the Installed directory within the S60 Emulator or your target device
    6. diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/index.xml --- a/core/com.nokia.carbide.cpp.doc.user/index.xml Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/index.xml Wed Jan 27 10:34:50 2010 -0600 @@ -601,10 +601,6 @@ - - - - diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/intro/tutorialsCarbideExtContent.xml --- a/core/com.nokia.carbide.cpp.doc.user/intro/tutorialsCarbideExtContent.xml Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/intro/tutorialsCarbideExtContent.xml Wed Jan 27 10:34:50 2010 -0600 @@ -1,57 +1,57 @@ - - - - - - - - - - Learn how to create, build, and debug a program for the emulator called HelloCarbide using Carbide project templates. - - - - Learn how to create a simple “Test1” DLL project. - - - - Learn how create and build an application and debug it on a device using the App TRK on-device debug agent. - - - - Learn how to create and build an application and debug it on a device using JTAG debug software on Lauterbach or Sophia hardware. - - - - Learn how to use soft attach to debug an image flashed to ROM or on a memory card. - - - - - - + + + + + + + + + + Learn how to create, build, and debug a program for the emulator called HelloCarbide using Carbide project templates. + + + + Learn how to create a simple “Test1” DLL project. + + + + Learn how create and build an application and debug it on a device using the App TRK on-device debug agent. + + + + Learn how to create and build an application and debug it on a device using JTAG debug software on Lauterbach hardware. + + + + Learn how to use soft attach to debug an image flashed to ROM or on a memory card. + + + + + + diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.doc.user/tocCarbide.xml --- a/core/com.nokia.carbide.cpp.doc.user/tocCarbide.xml Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.doc.user/tocCarbide.xml Wed Jan 27 10:34:50 2010 -0600 @@ -155,7 +155,6 @@ - @@ -306,15 +305,6 @@ - - - - - - - - - diff -r 0396114c1f2e -r ce9defbd72a6 core/com.nokia.carbide.cpp.featureTracker/src/com/nokia/carbide/cpp/internal/featureTracker/FeatureUseTrackerConsts.java --- a/core/com.nokia.carbide.cpp.featureTracker/src/com/nokia/carbide/cpp/internal/featureTracker/FeatureUseTrackerConsts.java Mon Jan 25 15:43:57 2010 -0600 +++ b/core/com.nokia.carbide.cpp.featureTracker/src/com/nokia/carbide/cpp/internal/featureTracker/FeatureUseTrackerConsts.java Wed Jan 27 10:34:50 2010 -0600 @@ -25,7 +25,6 @@ public static final String CARBIDE_APPDEP = "Carbide_AppDep"; // dependency explorer public static final String CARBIDE_CODESCANNER = "Carbide_CodeScanner"; public static final String CARBIDE_TRACE32 = "Carbide_Trace32"; - public static final String CARBIDE_SOPHIAWTI = "Carbide_SophiaWTI"; public static final String CARBIDE_OST_TRACE = "Carbide_OST_Trace"; public static final String CARBIDE_IDE = "Carbide_IDE"; // did user launch IDE public static final String CARBIDE_INTERNALONLY = "Carbide_InternalOnly"; // many carbide extensions diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/STICommLogConsoleFactory.java --- a/debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/STICommLogConsoleFactory.java Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,37 +0,0 @@ -/* -* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "Eclipse Public License v1.0" -* which accompanies this distribution, and is available -* at the URL "http://www.eclipse.org/legal/epl-v10.html". -* -* Initial Contributors: -* Nokia Corporation - initial contribution. -* -* Contributors: -* -* Description: -* -*/ - -package com.nokia.cdt.debug.cw.symbian; - -import org.eclipse.ui.console.*; - -/** - * Console factory is used to show the console from the Console view "Open Console" - * drop-down action. This factory is registered via the org.eclipse.ui.console.consoleFactory - * extension point. - * - * @since 3.1 - */ -public class STICommLogConsoleFactory implements IConsoleFactory { - - public STICommLogConsoleFactory() { - } - - public void openConsole() { - SymbianPlugin.getDefault().openSTICommLogConsole(true); - } -} diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/SettingsData.java --- a/debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/SettingsData.java Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/SettingsData.java Wed Jan 27 10:34:50 2010 -0600 @@ -78,7 +78,6 @@ public static final String LaunchConfig_SysTRK = PREFIX + ".LaunchConfig_SysTRK"; //$NON-NLS-1$ public static final String LaunchConfig_CrashDebugger = PREFIX + ".LaunchConfig_CrashDebugger"; //$NON-NLS-1$ public static final String LaunchConfig_Trace32 = PREFIX + ".LaunchConfig_Trace32"; //$NON-NLS-1$ - public static final String LaunchConfig_SophiaSTI = PREFIX + ".LaunchConfig_SophiaSTI"; //$NON-NLS-1$ public static final String ATTR_originalName = "originalName"; //$NON-NLS-1$ @@ -97,7 +96,6 @@ public static final String APP_TRK_LAUNCH_TYPE_ID = LAUNCH_TYPE_PREFIX + "appTRKLaunch"; //$NON-NLS-1$ public static final String SYS_TRK_LAUNCH_TYPE_ID = LAUNCH_TYPE_PREFIX + "systemTRKLaunch"; //$NON-NLS-1$ public static final String ATTACH_LAUNCH_TYPE_ID = LAUNCH_TYPE_PREFIX + "attachLaunch"; //$NON-NLS-1$ - public static final String STI_LAUNCH_TYPE_ID = LAUNCH_TYPE_PREFIX + "stiLaunch"; //$NON-NLS-1$ public static final String T32_LAUNCH_TYPE_ID = LAUNCH_TYPE_PREFIX + "t32Launch"; //$NON-NLS-1$ //================ Shadowed CW Preference Panels ================================= @@ -135,14 +133,6 @@ public static final String spn_Trace32Conn_LogOption= SPN(spn_Trace32Conn, "Trace32LogOption"); //$NON-NLS-1$ public static final String spn_Trace32Conn_BootConfigArgs= SPN(spn_Trace32Conn, "Trace32BootConfigArgs"); //$NON-NLS-1$ - // ---< STI Connection Panel> ------------------- - public static final String spn_SophiaSTIConn= "Sophia Target Interface Connection"; //$NON-NLS-1$ - - public static final String spn_SophiaSTIConn_DllPath= SPN(spn_SophiaSTIConn, "SophiaTargetInterfaceDllPath"); //$NON-NLS-1$ - public static final String spn_SophiaSTIConn_LogOption= SPN(spn_SophiaSTIConn, "STILogOption"); //$NON-NLS-1 - public static final String spn_SophiaSTIConn_JtagClock= SPN(spn_SophiaSTIConn, "STIJTAGClock"); //$NON-NLS-1 - public static final String spn_SophiaSTIConn_StiEmulatorType= SPN(spn_SophiaSTIConn, "STIJTAGType"); //$NON-NLS-1 - //================= End of Shadowed panels =========================================== public static final String TARGET_PATH_INCLUDES_FILENAME = "TARGET_PATH_INCLUDES_FILENAME"; //$NON-NLS-1$ @@ -611,7 +601,7 @@ { configuration.setAttribute( PreferenceConstants.J_PN_IsSystemModeDebug, false ); } - else // others like T32, Sophia and crash debugger. + else // others like T32 and crash debugger. configuration.setAttribute( PreferenceConstants.J_PN_IsSystemModeDebug, true ); } @@ -758,8 +748,7 @@ setFileTransferTab(configuration, project); } - if (settingsGroup.equals(LaunchConfig_Trace32) || - settingsGroup.equals(LaunchConfig_SophiaSTI)) + if (settingsGroup.equals(LaunchConfig_Trace32)) { setStopModeMainTab(configuration, project); setStopModeDebuggerTab(configuration, project); @@ -837,26 +826,6 @@ ""); //$NON-NLS-1$ } - if (settingsGroup.equals(LaunchConfig_SophiaSTI)) { - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_DllPath, "C:\\CarbideIF_ARM\\WTI.dll"); //$NON-NLS-1$ - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_JtagClock, "Auto"); //$NON-NLS-1$ - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_LogOption, false); - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_StiEmulatorType, "Auto"); //$NON-NLS-1$ - - // Stop mode debugging using STI : specify Sophia STI debugger protocol plugin. - // - ConnectionTypeInfo connTI = new ConnectionTypeInfo( - "Carbide Sophia STI", // Internal ID //$NON-NLS-1$ - "Sophia STI Configuration", // Display name. //$NON-NLS-1$ - "Sophia Target Interface Connection"); // Pref panel name - - DebuggerCommonData.setLaunchConfigConnSettings( - configuration, - connTI, - "Sophia Target Interface Plugin", //$NON-NLS-1$ - ""); //$NON-NLS-1$ - } - // Add the Symbian OS SDK Mapping. addSymbianSDKMapping(project, configuration); @@ -986,8 +955,7 @@ ILaunchConfigurationType configurationType = configuration.getType(); String id = configurationType.getIdentifier(); return id.equals(T32_LAUNCH_TYPE_ID) || - id.endsWith("T32Launch")||//$NON-NLS-1$ - id.equals(STI_LAUNCH_TYPE_ID); + id.endsWith("T32Launch"); //$NON-NLS-1$ } catch (CoreException e) { } diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/SymbianPlugin.java --- a/debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/SymbianPlugin.java Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.cw.symbian/src/com/nokia/cdt/debug/cw/symbian/SymbianPlugin.java Wed Jan 27 10:34:50 2010 -0600 @@ -45,7 +45,6 @@ private final String commMessagesConsoleName = "TRK Communication Log"; //$NON-NLS-1$ private final String t32CommMessagesConsoleName = "Trace32 Communications Log"; //$NON-NLS-1$ private final String symbianRomLogMessagesConsoleName = "Rom Log File Messages"; - private final String STICommMessagesConsoleName = "Sophia Target Interface Console"; //$NON-NLS-1$ public static final String DebugTraceMessagesConsoleName = "Emulator Output"; //$NON-NLS-1$ public static final String DebugTraceLaunchSetting = "DebugTraceLaunchSetting"; //$NON-NLS-1$ @@ -154,10 +153,6 @@ openConsole(symbianRomLogMessagesConsoleName, clearConsole); } - public void openSTICommLogConsole(boolean clearConsole) { - openConsole(STICommMessagesConsoleName, clearConsole); - } - public void openDebugTraceConsole(boolean clearConsole) { openConsole(DebugTraceMessagesConsoleName, clearConsole); } diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/plugin.xml --- a/debuggercdi/com.nokia.cdt.debug.launch/plugin.xml Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.launch/plugin.xml Wed Jan 27 10:34:50 2010 -0600 @@ -60,17 +60,6 @@ sourcePathComputerId="com.nokia.cdt.debug.cw.symbian.CarbideSourcePathComputer"> - - - - - - - - - - - - - - diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/SophiaSTILaunchDelegate.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/SophiaSTILaunchDelegate.java Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,183 +0,0 @@ -/* -* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "Eclipse Public License v1.0" -* which accompanies this distribution, and is available -* at the URL "http://www.eclipse.org/legal/epl-v10.html". -* -* Initial Contributors: -* Nokia Corporation - initial contribution. -* -* Contributors: -* -* Description: -* -*/ -package com.nokia.cdt.internal.debug.launch; - -import java.io.File; - -import org.eclipse.cdt.core.IBinaryParser.IBinaryObject; -import org.eclipse.cdt.core.model.ICProject; -import org.eclipse.cdt.debug.core.ICDTLaunchConfigurationConstants; -import org.eclipse.cdt.debug.core.ICDebugConfiguration; -import org.eclipse.cdt.debug.core.cdi.ICDISession; -import org.eclipse.cdt.launch.internal.ui.LaunchMessages; -import org.eclipse.cdt.ui.CUIPlugin; -import org.eclipse.core.runtime.CoreException; -import org.eclipse.core.runtime.IPath; -import org.eclipse.core.runtime.IProgressMonitor; -import org.eclipse.core.runtime.NullProgressMonitor; -import org.eclipse.core.runtime.SubProgressMonitor; -import org.eclipse.debug.core.ILaunch; -import org.eclipse.debug.core.ILaunchConfiguration; -import org.eclipse.debug.core.ILaunchManager; -import org.eclipse.jface.dialogs.MessageDialog; -import org.eclipse.swt.widgets.Display; - -import com.freescale.cdt.debug.cw.CWException; -import com.freescale.cdt.debug.cw.core.cdi.Session; -import com.freescale.cdt.debug.cw.core.cdi.model.Target; -import com.nokia.cdt.debug.cw.symbian.SettingsData; -import com.nokia.cdt.debug.cw.symbian.SymbianPlugin; - -import cwdbg.PreferenceConstants; - -public class SophiaSTILaunchDelegate extends NokiaAbstractLaunchDelegate { - - public void launch(ILaunchConfiguration config, - String mode, - ILaunch launch, - IProgressMonitor monitor) throws CoreException { - - - // See comment at definition of the "mutex" for why this "synchronized". - synchronized(Session.sessionStartStopMutex()) { - - if (monitor == null) { - monitor = new NullProgressMonitor(); - } - - monitor.beginTask(LaunchMessages.getString("LocalRunLaunchDelegate.Launching_Local_C_Application"), 10); //$NON-NLS-1$ - // check for cancellation - if (monitor.isCanceled()) { - return; - } - try { - monitor.worked(1); - IPath exePath = verifyProgramPath(config); - ICProject project = verifyCProject(config); - IBinaryObject exeFile = verifyBinary(project, exePath); - String arguments[] = getProgramArgumentsArray(config); - - // See comment for this method for more. - SettingsData.setInternalPreferences(config, SettingsData.LaunchConfig_SophiaSTI); - - // set the default source locator if required - setDefaultSourceLocator(launch, config); - - if (mode.equals(ILaunchManager.DEBUG_MODE)) { - // debug mode - ICDebugConfiguration debugConfig = getDebugConfig(config); - ICDISession dsession = null; - String debugMode = config.getAttribute(ICDTLaunchConfigurationConstants.ATTR_DEBUGGER_START_MODE, - ICDTLaunchConfigurationConstants.DEBUGGER_MODE_RUN); - if (debugMode.equals(ICDTLaunchConfigurationConstants.DEBUGGER_MODE_RUN)) { - dsession = debugConfig.createDebugger().createDebuggerSession(launch, exeFile, - new SubProgressMonitor(monitor, 8)); - - assert(dsession instanceof Session); - Session cwDebugSession = (Session)dsession; - - doAdditionalSessionSetup(cwDebugSession); - - IPath[] otherExecutables = getOtherExecutables(project, exePath, config, monitor); - { - try { - monitor.worked(1); - - // if enabled in the prefs, show the console view(s) - if (config.getAttribute(SettingsData.spn_SophiaSTIConn_LogOption, false)) { - SymbianPlugin.getDefault().openSTICommLogConsole(true); - } - if (config.getAttribute(PreferenceConstants.J_PN_LogUnresolved, false)) { - SymbianPlugin.getDefault().openSymbianRomLogConsole(true); - } - - config = synchronizeWithProjectAccessPaths(project, config); - - File wd = getWorkingDirectory(config); - Target target = cwDebugSession.launchExecutable(launch, config, exeFile, otherExecutables, arguments, wd, getEnvironmentAsProperty(config), monitor, project, getTargetLabel(exeFile.getName()), true); - ATFLaunchSupport.saveDebugTargetFromLaunchDelegate(target.getCoreModelTarget()); - - } catch (CoreException e) { - Session session = (Session)dsession; - session.cleanupAfterLaunchFailure(); - throw e; - } catch (Exception e) { - Session session = (Session)dsession; - session.debuggingStopped(null); - this.abort(e.getLocalizedMessage(), null, 0); - } - } - } - } - else if (mode.equals(ILaunchManager.RUN_MODE)) { - // Run the program. - // Connect to DE, download and launch the program, close debug session. - ICDebugConfiguration debugConfig = getDebugConfig(config); - ICDISession dsession = null; - - // Set up communication with DE. - dsession = debugConfig.createDebugger().createDebuggerSession(launch, exeFile, - new SubProgressMonitor(monitor, 8)); - - // Launch the program through the DE. - Session cwDebugSession = (Session)dsession; - cwDebugSession.launchExecutable( - launch, - config, - exeFile, - new IPath[0], - arguments, - null, - getEnvironmentAsProperty(config), - monitor, - project, - "", //$NON-NLS-1$ - false /* run instead of debug */); - - // The above call would throw exception on error. So it must have succeeded - // if control gets here. Show success message in a dialog. - // - // get the name of the executable that's launched instead of, say, the DLL name if - // exeFile is a DLL. - final String exeLaunched = config.getAttribute(PreferenceConstants.J_PN_RemoteProcessToLaunch, exeFile.toString()); - Display display = Display.getCurrent(); - if (display == null) { - display = Display.getDefault(); - } - - display.syncExec(new Runnable() { - public void run() { - MessageDialog.openInformation( - CUIPlugin.getActiveWorkbenchShell(), - LaunchMessages.getString("CarbideCPPLaunchDelegate.DebuggerName"), //$NON-NLS-1$ - LaunchMessages.getString("TRKLaunchDelegate.runSucceed") + //$NON-NLS-1$ - "\n\t\"" + exeLaunched + "\""); //$NON-NLS-1$ //$NON-NLS-2$ - } - }); - } - } catch (CWException e) { - if (! monitor.isCanceled()) // don't throw on user cancellation - e.printStackTrace(); - } catch (CoreException e) { - if (! monitor.isCanceled()) // don't throw on user cancellation - throw e; - } finally { - monitor.done(); - } - } // end of synchronized. - } -} \ No newline at end of file diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/LaunchTabHelpIds.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/LaunchTabHelpIds.java Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/LaunchTabHelpIds.java Wed Jan 27 10:34:50 2010 -0600 @@ -60,8 +60,6 @@ public static final String STOP_MODE_T32_CONNECTION = HelpID_Prefix + "stopmode_t32connection"; //$NON-NLS-1$ - public static final String STOP_MODE_SOPHIA_CONNECTION = HelpID_Prefix + "stopmode_sophiaconnection"; //$NON-NLS-1$ - public static final String STOP_MODE_ROM_IMAGE = HelpID_Prefix + "stopmode_romimage"; //$NON-NLS-1$ public static final String RUN_MODE_ROM_LOG_FILE = HelpID_Prefix + "runmode_romlogfile"; //$NON-NLS-1$ diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/SophiaConfigurationTabGroup.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/SophiaConfigurationTabGroup.java Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,60 +0,0 @@ -/* -* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "Eclipse Public License v1.0" -* which accompanies this distribution, and is available -* at the URL "http://www.eclipse.org/legal/epl-v10.html". -* -* Initial Contributors: -* Nokia Corporation - initial contribution. -* -* Contributors: -* -* Description: -* -*/ -package com.nokia.cdt.internal.debug.launch.ui; - -import com.nokia.cdt.debug.cw.symbian.SettingsData; -import com.nokia.cdt.internal.debug.launch.LaunchPlugin; - -import org.eclipse.core.resources.IProject; -import org.eclipse.debug.core.ILaunchConfigurationWorkingCopy; -import org.eclipse.debug.ui.*; -import org.eclipse.debug.ui.sourcelookup.SourceLookupTab; - -public class SophiaConfigurationTabGroup extends - AbstractLaunchConfigurationTabGroup { - - public void createTabs(ILaunchConfigurationDialog dialog, String mode) { - ILaunchConfigurationTab[] tabs = new ILaunchConfigurationTab[] { - new StopModeMainTab(), - new SophiaTargetInterfaceTab(), - new StopModeDebuggerTab(), - new SymbianExceptionsTab(), - new RomImageTab(), - new ExecutablesTab(false), - new SourceLookupTab(), - new CommonTab() - }; - setTabs(tabs); - } - - - /** - * Set default for all preferences related to this launch configuration. - * - * @see ILaunchConfigurationTabGroup#setDefaults(ILaunchConfigurationWorkingCopy) - */ - public void setDefaults(ILaunchConfigurationWorkingCopy config) { - // Call this to make sure options on those CDT common tabs such as "Common" - // and "Source" have correct default. - super.setDefaults(config); - - // Get the current selected project in C project view. - IProject project = LaunchPlugin.getSelectedProject(); - - SettingsData.setDefaults(config, SettingsData.LaunchConfig_SophiaSTI, project); - } -} diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/SophiaTargetInterfaceTab.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/SophiaTargetInterfaceTab.java Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,237 +0,0 @@ -/* -* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "Eclipse Public License v1.0" -* which accompanies this distribution, and is available -* at the URL "http://www.eclipse.org/legal/epl-v10.html". -* -* Initial Contributors: -* Nokia Corporation - initial contribution. -* -* Contributors: -* -* Description: -* -*/ -package com.nokia.cdt.internal.debug.launch.ui; - -import com.nokia.cdt.debug.cw.symbian.SettingsData; -import com.nokia.cdt.internal.debug.launch.LaunchPlugin; - -import org.eclipse.cdt.launch.ui.CLaunchConfigurationTab; -import org.eclipse.core.runtime.CoreException; -import org.eclipse.debug.core.ILaunchConfiguration; -import org.eclipse.debug.core.ILaunchConfigurationWorkingCopy; -import org.eclipse.jface.dialogs.Dialog; -import org.eclipse.swt.SWT; -import org.eclipse.swt.events.*; -import org.eclipse.swt.graphics.Image; -import org.eclipse.swt.layout.GridData; -import org.eclipse.swt.layout.GridLayout; -import org.eclipse.swt.widgets.*; -import org.eclipse.ui.PlatformUI; - -import java.io.File; - -public class SophiaTargetInterfaceTab extends CLaunchConfigurationTab { - - // Radio Buttons - - // Boolean widgets - private Button viewMessages; - private Combo jtagClockCombo; - private Text text; - private Combo emulatorTypeCombo; - - /* (non-Javadoc) - * @see org.eclipse.debug.ui.ILaunchConfigurationTab#createControl(org.eclipse.swt.widgets.Composite) - */ - public void createControl(Composite parent) { - Composite comp = new Composite(parent, SWT.NONE); - setControl(comp); - - PlatformUI.getWorkbench().getHelpSystem().setHelp(getControl(), LaunchTabHelpIds.STOP_MODE_SOPHIA_CONNECTION); - - GridLayout topLayout = new GridLayout(); - topLayout.numColumns = 2; - comp.setLayout(topLayout); - - //createVerticalSpacer(comp, 2); - //createSymbolicsLoadingGroup(comp, 2); - //createVerticalSpacer(comp, 2); - //createBooleanGroup(comp, 2); - - final Label sophiaTargetInterfaceLabel = new Label(comp, SWT.NONE); - sophiaTargetInterfaceLabel.setText(Messages.getString("SophiaTargetInterfaceTab.0")); //$NON-NLS-1$ - - sophiaTargetInterfaceLabel.setToolTipText(Messages.getString("SophiaTargetInterfaceTab.10")); //$NON-NLS-1$ - new Label(comp, SWT.NONE); - - text = new Text(comp, SWT.BORDER); - text.setLayoutData(new GridData(GridData.FILL, GridData.CENTER, true, false)); - text.setToolTipText(Messages.getString("SophiaTargetInterfaceTab.10")); //$NON-NLS-1$ - text.addModifyListener(new ModifyListener() { - public void modifyText(ModifyEvent e) { - updateLaunchConfigurationDialog(); - } - }); - - final Button browseButton = new Button(comp, SWT.NONE); - browseButton.addSelectionListener(new SelectionAdapter() { - - public void widgetSelected(SelectionEvent evt) { - FileDialog dialog = new FileDialog(getShell(), SWT.NONE); - - dialog.setText(Messages.getString("SophiaTargetInterfaceTab.7")); //$NON-NLS-1$ - dialog.setFilterExtensions(new String[] {"*.dll*", "*.*"}); //$NON-NLS-1$ //$NON-NLS-2$ - dialog.setFilterNames(new String[] {Messages.getString("SophiaTargetInterfaceTab.8"), Messages.getString("SophiaTargetInterfaceTab.9")}); //$NON-NLS-1$ //$NON-NLS-2$ - - String result = dialog.open(); - if (result != null && new File(result).exists()) { - text.setText(result); - updateLaunchConfigurationDialog(); - } - } - }); - - browseButton.setText(Messages.getString("SophiaTargetInterfaceTab.1")); //$NON-NLS-1$ - - final Label jtagTypeLabel = new Label(comp, SWT.NONE); - jtagTypeLabel.setText(Messages.getString("SophiaTargetInterfaceTab.11")); //$NON-NLS-1$ - jtagTypeLabel.setToolTipText(Messages.getString("SophiaTargetInterfaceTab.12")); //$NON-NLS-1$ - new Label(comp, SWT.NONE); - - emulatorTypeCombo = new Combo(comp, SWT.READ_ONLY); - emulatorTypeCombo.setItems(new String[] {Messages.getString("SophiaTargetInterfaceTab.13"), Messages.getString("SophiaTargetInterfaceTab.14"), Messages.getString("SophiaTargetInterfaceTab.15"), Messages.getString("SophiaTargetInterfaceTab.16"), Messages.getString("SophiaTargetInterfaceTab.17")}); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$ - emulatorTypeCombo.setText(Messages.getString("SophiaTargetInterfaceTab.13")); //$NON-NLS-1$ - emulatorTypeCombo.setLayoutData(new GridData(GridData.BEGINNING, GridData.CENTER, true, false)); - emulatorTypeCombo.setToolTipText(Messages.getString("SophiaTargetInterfaceTab.12")); //$NON-NLS-1$ - - emulatorTypeCombo.addSelectionListener(new SelectionAdapter() { - public void widgetSelected(SelectionEvent e) { - updateLaunchConfigurationDialog(); - } - }); - - new Label(comp, SWT.NONE); - - final Label jtagRtckLabel = new Label(comp, SWT.NONE); - jtagRtckLabel.setText(Messages.getString("SophiaTargetInterfaceTab.19")); //$NON-NLS-1$ - jtagRtckLabel.setToolTipText(Messages.getString("SophiaTargetInterfaceTab.20")); //$NON-NLS-1$ - new Label(comp, SWT.NONE); - - jtagClockCombo = new Combo(comp, SWT.READ_ONLY); - jtagClockCombo.setItems(new String[] {Messages.getString("SophiaTargetInterfaceTab.13"), Messages.getString("SophiaTargetInterfaceTab.22"), Messages.getString("SophiaTargetInterfaceTab.23"), Messages.getString("SophiaTargetInterfaceTab.24"), Messages.getString("SophiaTargetInterfaceTab.25")}); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$ - jtagClockCombo.setText(Messages.getString("SophiaTargetInterfaceTab.13")); //$NON-NLS-1$ - jtagClockCombo.setLayoutData(new GridData(GridData.BEGINNING, GridData.CENTER, true, false)); - jtagClockCombo.setToolTipText(Messages.getString("SophiaTargetInterfaceTab.20")); //$NON-NLS-1$ - - jtagClockCombo.addSelectionListener(new SelectionAdapter() { - public void widgetSelected(SelectionEvent e) { - updateLaunchConfigurationDialog(); - } - }); - - new Label(comp, SWT.NONE); - - viewMessages = new Button(comp, SWT.CHECK); - viewMessages.setLayoutData(new GridData()); - viewMessages.setText(Messages.getString("SophiaTargetInterfaceTab.27")); //$NON-NLS-1$ - viewMessages.setToolTipText(Messages.getString("SophiaTargetInterfaceTab.18")); //$NON-NLS-1$ - - viewMessages.addSelectionListener(new SelectionAdapter() { - public void widgetSelected(SelectionEvent e) { - updateLaunchConfigurationDialog(); - } - }); - new Label(comp, SWT.NONE); - - Dialog.applyDialogFont(parent); - checkControlState(); - } - - - /* (non-Javadoc) - * @see org.eclipse.debug.ui.ILaunchConfigurationTab#setDefaults(org.eclipse.debug.core.ILaunchConfigurationWorkingCopy) - */ - public void setDefaults(ILaunchConfigurationWorkingCopy config) { - - } - - /* (non-Javadoc) - * @see org.eclipse.debug.ui.ILaunchConfigurationTab#initializeFrom(org.eclipse.debug.core.ILaunchConfiguration) - */ - public void initializeFrom(ILaunchConfiguration configuration) { - try { - text.setText(configuration.getAttribute( SettingsData.spn_SophiaSTIConn_DllPath, "C:\\CarbideIF_ARM\\WTI.dll")); //$NON-NLS-1$ - jtagClockCombo.setText(configuration.getAttribute( SettingsData.spn_SophiaSTIConn_JtagClock, "Auto")); //$NON-NLS-1$ - viewMessages.setSelection(configuration.getAttribute( SettingsData.spn_SophiaSTIConn_LogOption, false)); - emulatorTypeCombo.setText(configuration.getAttribute(SettingsData.spn_SophiaSTIConn_StiEmulatorType, Messages.getString("SophiaTargetInterfaceTab.13"))); //$NON-NLS-1$ - checkControlState(); - - } catch (CoreException e) { - LaunchPlugin.log(e); - } - - } - - /* (non-Javadoc) - * @see org.eclipse.debug.ui.ILaunchConfigurationTab#performApply(org.eclipse.debug.core.ILaunchConfigurationWorkingCopy) - */ - public void performApply(ILaunchConfigurationWorkingCopy configuration) { - - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_DllPath, text.getText()); - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_JtagClock, jtagClockCombo.getText()); - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_LogOption, viewMessages.getSelection()); - configuration.setAttribute( SettingsData.spn_SophiaSTIConn_StiEmulatorType, emulatorTypeCombo.getText()); - } - - /* (non-Javadoc) - * @see org.eclipse.debug.ui.ILaunchConfigurationTab#getName() - */ - public String getName() { - return Messages.getString("SophiaTargetInterfaceTab.4"); //$NON-NLS-1$ - } - /* - * (non-Javadoc) - * - * @see org.eclipse.debug.ui.ILaunchConfigurationTab#getImage() - */ - public Image getImage() { - return LaunchImages.get(LaunchImages.IMG_VIEW_CONNECTION_TAB); - } - - protected void checkControlState() - { - } - - public boolean isValid(ILaunchConfiguration config) { - - setErrorMessage(null); - setMessage(null); - - boolean result = super.isValid(config); - if (result){ - String pcPath = text.getText().trim(); - if (pcPath.length() < 1) { - setErrorMessage(Messages.getString("SophiaTargetInterfaceTab.5")); //$NON-NLS-1$ - return false; - } else { - if (!new File(pcPath).exists()) { - setErrorMessage(Messages.getString("SophiaTargetInterfaceTab.6")); //$NON-NLS-1$ - result = false; - } - } - } - return result; - } - - @Override - public void activated(ILaunchConfigurationWorkingCopy workingCopy) { - super.activated(workingCopy); - - // forces page to get focus so that help works without having to select some control first. - getControl().setFocus(); - } -} \ No newline at end of file diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/messages.properties --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/messages.properties Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/ui/messages.properties Wed Jan 27 10:34:50 2010 -0600 @@ -176,32 +176,6 @@ RunModeMainTab.7=Remote process to launch must be an absolute path. RunModeMainTab.8=The project associated with this launch configuration. RunModeMainTab.NoConnectionError=A valid remote connection must be selected. If none exist, create a new one. -SophiaTargetInterfaceTab.0=Sophia Target Interface (WTI.dll) location -SophiaTargetInterfaceTab.1=Browse -SophiaTargetInterfaceTab.10=The absolute path on your PC of the Carbide C++ interface to Sophia JTAG emulator (wti.dll) -SophiaTargetInterfaceTab.11=EJ_Debug Type -SophiaTargetInterfaceTab.12=Select the type of your Sophia JTAG emulator -SophiaTargetInterfaceTab.13=Auto -SophiaTargetInterfaceTab.14=ARM9 -SophiaTargetInterfaceTab.15=ARM11 -SophiaTargetInterfaceTab.16=ARM9_11 -SophiaTargetInterfaceTab.17=ARM7_9_11 -SophiaTargetInterfaceTab.18=This lets you see the debug command messages between the Carbide debugger and Sophia JTAG emulator -SophiaTargetInterfaceTab.19=JTAG TCLK Frequency -SophiaTargetInterfaceTab.2=STI Target Configuration File -SophiaTargetInterfaceTab.20=Select desired JTAG TCLK Frequency (Some boards don't support highest or 'Auto' settings) -SophiaTargetInterfaceTab.22=33 MHz -SophiaTargetInterfaceTab.23=16 MHz -SophiaTargetInterfaceTab.24=8 MHz -SophiaTargetInterfaceTab.25=500 KHz -SophiaTargetInterfaceTab.27=View messages between Carbide and STI -SophiaTargetInterfaceTab.3=Browse -SophiaTargetInterfaceTab.4=Connection -SophiaTargetInterfaceTab.5=STI DLL not specified -SophiaTargetInterfaceTab.6=STI DLL specified does not exist -SophiaTargetInterfaceTab.7=Select Sophia Target Interface library (WTI.dll) -SophiaTargetInterfaceTab.8=Dynamic Link Libraries -SophiaTargetInterfaceTab.9=All Files StopModeDebuggerTab.0=Break at entry point\: StopModeDebuggerTab.1=When enabled the debugger will automatically set a breakpoint at the function specified. StopModeDebuggerTab.10=Target Initialization files (*.cfg) diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchCreationWizard.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchCreationWizard.java Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchCreationWizard.java Wed Jan 27 10:34:50 2010 -0600 @@ -188,12 +188,6 @@ wizards.add(trace32Wizard); } - SophiaLaunchWizard sophiaWizard = new SophiaLaunchWizard(mmps, exes, defaultExecutable, project, configurationName); - if (sophiaWizard.supportsMode(mode)) { - sophiaWizard.addPages(); - wizards.add(sophiaWizard); - } - AttachTRKLaunchWizard attachTRKWizard = new AttachTRKLaunchWizard(mmps, exes, defaultExecutable, project, configurationName); if (attachTRKWizard.supportsMode(mode)) { attachTRKWizard.addPages(); diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchWizardHelpIds.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchWizardHelpIds.java Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/LaunchWizardHelpIds.java Wed Jan 27 10:34:50 2010 -0600 @@ -34,8 +34,6 @@ public static final String WIZARD_SUMMARY_PAGE = HelpID_Prefix + "wizard_summary_page"; //$NON-NLS-1$ - public static final String WIZARD_SOPHIA_PAGE = HelpID_Prefix + "wizard_sophia_page"; //$NON-NLS-1$ - public static final String WIZARD_TRACE32_PAGE = HelpID_Prefix + "wizard_trace32_page"; //$NON-NLS-1$ public static final String WIZARD_STOP_MODE_ROM_IMG_PAGE = HelpID_Prefix + "wizard_stop_mode_rom_img_page"; //$NON-NLS-1$ diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/SophiaLaunchWizard.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/SophiaLaunchWizard.java Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,100 +0,0 @@ -/* -* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "Eclipse Public License v1.0" -* which accompanies this distribution, and is available -* at the URL "http://www.eclipse.org/legal/epl-v10.html". -* -* Initial Contributors: -* Nokia Corporation - initial contribution. -* -* Contributors: -* -* Description: -* -*/ -package com.nokia.cdt.internal.debug.launch.wizard; - -import java.util.List; - -import org.eclipse.core.resources.IProject; -import org.eclipse.core.runtime.CoreException; -import org.eclipse.core.runtime.IPath; -import org.eclipse.debug.core.DebugPlugin; -import org.eclipse.debug.core.ILaunchConfigurationWorkingCopy; - -import com.nokia.cdt.debug.cw.symbian.SettingsData; - -public class SophiaLaunchWizard extends AbstractLaunchWizard { - - private BuildOptionsSelectionPage fBuildOptionsSelectionPage; - private SophiaWizardPage fSophiaPage; - private StopModeRomImageWizardPage fRomImgPage; - - private boolean hasFinished = false; - - public SophiaLaunchWizard(List mmps, List exes, IPath defaultExecutable, IProject project, String configurationName) { - super(project, configurationName, mmps, exes, defaultExecutable, true, false); - setWindowTitle(Messages.getString("SophiaLaunchWizard.1")); //$NON-NLS-1$ - } - - @Override - public String getLaunchTypeID() { - return SettingsData.STI_LAUNCH_TYPE_ID; - } - - @Override - public boolean supportsCategory(String categoryId) { - return categoryId.equals(BOARD_CATEGORY_ID); - } - - public boolean performFinish() { - hasFinished = true; - return true; - } - - public void addPages() { - super.addPages(); - fBuildOptionsSelectionPage = new BuildOptionsSelectionPage(); - fSophiaPage = new SophiaWizardPage(this); - fRomImgPage = new StopModeRomImageWizardPage(this); - addPage(fBuildOptionsSelectionPage); - addPage(fSophiaPage); - addPage(fRomImgPage); - addPage(getSummaryPage()); - } - - public String toString() { - return Messages.getString("SophiaLaunchWizard.2"); //$NON-NLS-1$ - } - - public String getDescription() { - return Messages.getString("SophiaLaunchWizard.3"); //$NON-NLS-1$ - } - - public ILaunchConfigurationWorkingCopy createLaunchConfiguration(IPath mmpPath, IPath exePath, IPath processToLaunchTargetPath) { - // if we haven't finished then don't create anything - if (!hasFinished) { - return null; - } - - ILaunchConfigurationWorkingCopy config = null; - try { - // create our config - config = DebugPlugin.getDefault().getLaunchManager().getLaunchConfigurationType(SettingsData.STI_LAUNCH_TYPE_ID).newInstance(null, getConfigName()); - - // set the default values - SettingsData.setDefaults(config, SettingsData.LaunchConfig_SophiaSTI, getProject(), mmpPath, exePath); - - // now let the wizard pages update values - fBuildOptionsSelectionPage.updateConfiguration(config); - fSophiaPage.updateConfiguration(config); - fRomImgPage.updateConfiguration(config); - - } catch (CoreException e) { - e.printStackTrace(); - } - return config; - } -} diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/SophiaWizardPage.java --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/SophiaWizardPage.java Mon Jan 25 15:43:57 2010 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,226 +0,0 @@ -/* -* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "Eclipse Public License v1.0" -* which accompanies this distribution, and is available -* at the URL "http://www.eclipse.org/legal/epl-v10.html". -* -* Initial Contributors: -* Nokia Corporation - initial contribution. -* -* Contributors: -* -* Description: -* -*/ -package com.nokia.cdt.internal.debug.launch.wizard; - -import java.io.File; -import java.text.MessageFormat; - -import org.eclipse.cdt.utils.ui.controls.ControlFactory; -import org.eclipse.debug.core.ILaunchConfigurationWorkingCopy; -import org.eclipse.jface.dialogs.Dialog; -import org.eclipse.jface.wizard.WizardPage; -import org.eclipse.swt.SWT; -import org.eclipse.swt.events.SelectionAdapter; -import org.eclipse.swt.events.SelectionEvent; -import org.eclipse.swt.layout.GridData; -import org.eclipse.swt.layout.GridLayout; -import org.eclipse.swt.widgets.Button; -import org.eclipse.swt.widgets.Combo; -import org.eclipse.swt.widgets.Composite; -import org.eclipse.swt.widgets.FileDialog; -import org.eclipse.swt.widgets.Label; -import org.eclipse.swt.widgets.Text; -import org.eclipse.ui.PlatformUI; - -import com.nokia.cdt.debug.cw.symbian.SettingsData; -import com.nokia.cpp.internal.api.utils.core.Check; - -import cwdbg.PreferenceConstants; - -public class SophiaWizardPage extends WizardPage { - - private boolean isDisposed = false; - - private Label sophiaSTIDLLLabel; - private Text sophiaSTIDLLPath; - private Button sophiaSTIDLLBrowse; - private String sophiaSTIDLL; - - private Label targetInitFileLabel; - private Text targetInitFilePath; - private Button targetInitFileBrowse; - private String targetInitFile; - - private Combo processorsList; - private int selectedProcIndex; - - private final ISummaryTextItemContainer summaryTextItemContainer; - - public SophiaWizardPage(ISummaryTextItemContainer summaryTextItemContainer) { - super(Messages.getString("SophiaWizardPage.0")); //$NON-NLS-1$ - Check.checkArg(summaryTextItemContainer); - this.summaryTextItemContainer = summaryTextItemContainer; - setPageComplete(false); - setTitle(Messages.getString("SophiaWizardPage.0")); //$NON-NLS-1$ - setDescription(Messages.getString("SophiaWizardPage.1")); //$NON-NLS-1$ - } - public void dispose() { - isDisposed = true; - sophiaSTIDLL = sophiaSTIDLLPath.getText().trim(); - targetInitFile = targetInitFilePath.getText().trim(); - selectedProcIndex = processorsList.getSelectionIndex(); - super.dispose(); - } - - - /* - * @see IDialogPage#createControl(Composite) - */ - public void createControl(Composite parent) { - Composite composite = new Composite(parent, SWT.NULL); - GridLayout layout = new GridLayout(); - layout.numColumns = 3; - composite.setLayout(layout); - - GridData data = new GridData(); - composite.setLayoutData(data); - - sophiaSTIDLLLabel = new Label(composite, SWT.NONE); - sophiaSTIDLLLabel.setText(Messages.getString("SophiaWizardPage.2")); //$NON-NLS-1$ - data = new GridData(); - data.horizontalSpan = 3; - sophiaSTIDLLLabel.setLayoutData(data); - sophiaSTIDLLLabel.setToolTipText(Messages.getString("SophiaWizardPage.3")); //$NON-NLS-1$ - sophiaSTIDLLLabel.setData(".uid", "SophiaWizardPage.sophiaSTIDLLLabel"); - - sophiaSTIDLLPath = new Text(composite, SWT.BORDER); - data = new GridData(GridData.FILL_HORIZONTAL); - data.horizontalSpan = 2; - sophiaSTIDLLPath.setLayoutData(data); - sophiaSTIDLLPath.setToolTipText(Messages.getString("SophiaWizardPage.3")); //$NON-NLS-1$ - sophiaSTIDLLPath.setData(".uid", "SophiaWizardPage.sophiaSTIDLLPath"); - - sophiaSTIDLLBrowse = ControlFactory.createPushButton(composite, Messages.getString("SophiaWizardPage.13")); //$NON-NLS-1$ - sophiaSTIDLLBrowse.addSelectionListener(new SelectionAdapter() { - public void widgetSelected(SelectionEvent evt) { - FileDialog dialog = new FileDialog(getShell(), SWT.NONE); - - dialog.setText(Messages.getString("SophiaWizardPage.4")); //$NON-NLS-1$ - dialog.setFilterExtensions(new String[] {"*.dll*", "*.*"}); //$NON-NLS-1$ //$NON-NLS-2$ - dialog.setFilterNames(new String[] {Messages.getString("SophiaWizardPage.5"), Messages.getString("SophiaWizardPage.6")}); //$NON-NLS-1$ //$NON-NLS-2$ - - String result = dialog.open(); - if (result != null && new File(result).exists()) { - sophiaSTIDLLPath.setText(result); - } - } - }); - sophiaSTIDLLBrowse.setData(".uid", "SophiaWizardPage.sophiaSTIDLLBrowse"); - - targetInitFileLabel = new Label(composite, SWT.NONE); - targetInitFileLabel.setText(Messages.getString("SophiaWizardPage.7")); //$NON-NLS-1$ - data = new GridData(); - data.horizontalSpan = 3; - targetInitFileLabel.setLayoutData(data); - targetInitFileLabel.setToolTipText(Messages.getString("SophiaWizardPage.8")); //$NON-NLS-1$ - targetInitFileLabel.setData(".uid", "SophiaWizardPage.targetInitFileLabel"); - - targetInitFilePath = new Text(composite, SWT.BORDER); - data = new GridData(GridData.FILL_HORIZONTAL); - data.horizontalSpan = 2; - targetInitFilePath.setLayoutData(data); - targetInitFilePath.setToolTipText(Messages.getString("SophiaWizardPage.8")); //$NON-NLS-1$ - targetInitFilePath.setData(".uid", "SophiaWizardPage.targetInitFilePath"); - - targetInitFileBrowse = ControlFactory.createPushButton(composite, Messages.getString("SophiaWizardPage.13")); //$NON-NLS-1$ - targetInitFileBrowse.addSelectionListener(new SelectionAdapter() { - public void widgetSelected(SelectionEvent evt) { - FileDialog dialog = new FileDialog(getShell(), SWT.NONE); - - dialog.setText(Messages.getString("SophiaWizardPage.9")); //$NON-NLS-1$ - dialog.setFilterExtensions(new String[] {"*.cfg*", "*.*"}); //$NON-NLS-1$ //$NON-NLS-2$ - dialog.setFilterNames(new String[] {Messages.getString("SophiaWizardPage.10"), Messages.getString("SophiaWizardPage.6")}); //$NON-NLS-1$ //$NON-NLS-2$ - - String result = dialog.open(); - if (result != null && new File(result).exists()) { - targetInitFilePath.setText(result); - } - } - }); - targetInitFileBrowse.setData(".uid", "SophiaWizardPage.targetInitFileBrowse"); - - final Label processorsLabel = new Label(composite, SWT.NONE); - processorsLabel.setText(Messages.getString("SophiaWizardPage.11")); //$NON-NLS-1$ - data = new GridData(); - data.horizontalSpan = 3; - processorsLabel.setLayoutData(data); - processorsLabel.setToolTipText(Messages.getString("SophiaWizardPage.12")); //$NON-NLS-1$ - processorsLabel.setData(".uid", "SophiaWizardPage.processorsLabel"); - - processorsList = new Combo(composite, SWT.READ_ONLY); - processorsList.setItems(new String[] { "ARM920T", "ARM926TEJ", "ARM1136EJ-S", "OMAP3xx", "OMAP15xx", "OMAP16xx", "OMAP24xx", "OMAP34xx", "Generic" }); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$ //$NON-NLS-6$ //$NON-NLS-7$ //$NON-NLS-8$ //$NON-NLS-9$ //$NON-NLS-10$ - processorsList.select(8); //by default, select the generic - data = new GridData(GridData.HORIZONTAL_ALIGN_FILL); - data.horizontalSpan = 3; - processorsList.setLayoutData(data); - processorsList.setToolTipText(Messages.getString("SophiaWizardPage.12")); //$NON-NLS-1$ - processorsList.setData(".uid", "SophiaWizardPage.processorsList"); - - setControl(composite); - Dialog.applyDialogFont(parent); - setPageComplete(true); - } - - void updateConfiguration(ILaunchConfigurationWorkingCopy config) { - if (isDisposed) { - if (sophiaSTIDLL.length()>0 && new File(sophiaSTIDLL).exists()) { - config.setAttribute(SettingsData.spn_SophiaSTIConn_DllPath, sophiaSTIDLL); - } - - if (targetInitFile.length()>0 && new File(targetInitFile).exists()) { - config.setAttribute(PreferenceConstants.J_PN_TargetInitFilePath, targetInitFile); - config.setAttribute(PreferenceConstants.J_PN_RunTargetInitFile, true); - } - - config.setAttribute(PreferenceConstants.J_PN_TargetProcessor, selectedProcIndex); - } else { - if ((sophiaSTIDLLPath.getText().trim().length()>0) && (new File(sophiaSTIDLLPath.getText().trim()).exists())) { - config.setAttribute(SettingsData.spn_SophiaSTIConn_DllPath, sophiaSTIDLLPath.getText()); - } - - if (targetInitFilePath.getText().trim().length()>0 && new File(targetInitFilePath.getText().trim()).exists()) { - config.setAttribute(PreferenceConstants.J_PN_TargetInitFilePath, targetInitFilePath.getText().trim()); - config.setAttribute(PreferenceConstants.J_PN_RunTargetInitFile, true); - } - - config.setAttribute( PreferenceConstants.J_PN_TargetProcessor, processorsList.getSelectionIndex()); - } - } - - public void setVisible(boolean visible) { - super.setVisible(visible); - if (!visible) { - summaryTextItemContainer.putSummaryTextItem("SophiaTargetInterface", //$NON-NLS-1$ - MessageFormat.format("{0} {1}", new Object[] { //$NON-NLS-1$ - Messages.getString("SophiaWizardPage.2"), //$NON-NLS-1$ - sophiaSTIDLLPath.getText() } )); - summaryTextItemContainer.putSummaryTextItem("TargetInitFile", //$NON-NLS-1$ - MessageFormat.format("{0} {1}", new Object[] { //$NON-NLS-1$ - Messages.getString("SophiaWizardPage.7"), //$NON-NLS-1$ - targetInitFilePath.getText() } )); - summaryTextItemContainer.putSummaryTextItem("TargetProcessor", //$NON-NLS-1$ - MessageFormat.format("{0} {1}", new Object[] { //$NON-NLS-1$ - Messages.getString("SophiaWizardPage.11"), //$NON-NLS-1$ - processorsList.getItem(processorsList.getSelectionIndex()) } )); - } - } - - @Override - public void performHelp() { - PlatformUI.getWorkbench().getHelpSystem().displayHelp(LaunchWizardHelpIds.WIZARD_SOPHIA_PAGE); - } -} \ No newline at end of file diff -r 0396114c1f2e -r ce9defbd72a6 debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/messages.properties --- a/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/messages.properties Mon Jan 25 15:43:57 2010 -0600 +++ b/debuggercdi/com.nokia.cdt.debug.launch/src/com/nokia/cdt/internal/debug/launch/wizard/messages.properties Wed Jan 27 10:34:50 2010 -0600 @@ -48,23 +48,6 @@ MainExecutableSelectionWizardPage.SelectExectuableTitle=Select Exectuable To Launch MainExecutableSelectionWizardPage.UsePathLabel.device=Specify device path of remote process to launch MainExecutableSelectionWizardPage.UsePathLabel.device.ToolTip=The specified process will be launched on the phone -SophiaLaunchWizard.1=New Sophia STI Launch Configuration -SophiaLaunchWizard.2=Sophia STI Launch Configuration -SophiaLaunchWizard.3=Sophia STI is an external debugger that Carbide debugger communicates with, to debug any Symbian OS module on a target using a JTAG connection. -SophiaWizardPage.0=Sophia Initialization Settings -SophiaWizardPage.1=Choose the Sophia WTI DLL, the target initialization file and the processor for initializing the target through Sophia STI. -SophiaWizardPage.10=Initialization Files (*.cfg) -SophiaWizardPage.11=Target Processor\: -SophiaWizardPage.12=Choose the target processor from the list -SophiaWizardPage.13=Browse... -SophiaWizardPage.2=Sophia Target Interface (WTI.DLL)\: -SophiaWizardPage.3=Choose the Sophia's WTI.DLL which is used by the Carbide debugger to connect to the target through Sophia target interface. -SophiaWizardPage.4=Choose the Sophia Target Interface (WTI.DLL) library -SophiaWizardPage.5=DLL files (.dll) -SophiaWizardPage.6=All files -SophiaWizardPage.7=Target Initialization File\: -SophiaWizardPage.8=Choose the target initialization file which is run by the Carbide debugger after connecting to the target. -SophiaWizardPage.9=Choose the target initialization file StopModeRomImageWizardPage.0=Symbian ROM Image Settings StopModeRomImageWizardPage.1=Choose either soft attach or debug from start option. With soft attach option, you can start debugging without changing the state of the target. Specify the ROM log file for debugging Symbian OS components. StopModeRomImageWizardPage.10=All Files