diff options
author | Jason Molenda <jsm@bugshack.cygnus.com> | 2000-02-07 00:19:45 +0000 |
---|---|---|
committer | Jason Molenda <jsm@bugshack.cygnus.com> | 2000-02-07 00:19:45 +0000 |
commit | 4a0a51e37f1d7dd770d0306310c82c3aaeb8baa7 (patch) | |
tree | 9af57893831870241bb5ce54310653be97a51621 /gdb/gdbtk/library/targetselection.itb | |
parent | b7ebfe07f32e9873605d6ff420e63f1c9b627559 (diff) | |
download | gdb-4a0a51e37f1d7dd770d0306310c82c3aaeb8baa7.tar.gz |
Initial revision
Diffstat (limited to 'gdb/gdbtk/library/targetselection.itb')
-rw-r--r-- | gdb/gdbtk/library/targetselection.itb | 995 |
1 files changed, 995 insertions, 0 deletions
diff --git a/gdb/gdbtk/library/targetselection.itb b/gdb/gdbtk/library/targetselection.itb new file mode 100644 index 00000000000..f7630872c16 --- /dev/null +++ b/gdb/gdbtk/library/targetselection.itb @@ -0,0 +1,995 @@ +# Target selection dialog for GDBtk. +# Copyright 1997, 1998, 1999 Cygnus Solutions +# +# This program is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License (GPL) as published by +# the Free Software Foundation; either version 2 of the License, or (at +# your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + + +# ---------------------------------------------------------------------- +# Implements GDB TargetSelection dialog +# ---------------------------------------------------------------------- + +# ------------------------------------------------------------------ +# CONSTRUCTOR - create new target selection window +# ------------------------------------------------------------------ +body TargetSelection::constructor {args} { + eval itk_initialize $args + set top [winfo toplevel $itk_interior] + _init + build_win +} + +body TargetSelection::getname {target name} { + + # Init target database if we haven't already done so + init_target_db + + if {[info exists gdb_target($target,$name)]} { + return $gdb_target($target,$name) + } else { + return "" + } +} + +body TargetSelection::init_target_db {} { + # check to see if we already initialized this database + if {$db_inited} { + return + } + set db_inited 1 + + # Target Database + # Set the following members: + # TARGET,pretty-name: Name to display to user + # TARGET,debaud: Default baudrate + # TARGET,baud-rates: Permissible baudrates + # TARGET,cmd: Abstracted command to run for this target (tcpX and com1 are + # replaced with the real port and host/port in set_target) + # TARGET,runlist: List of preferences for the target: {attach download run cont} + # TARGET,after_attaching: a command to run after attaching to the target + + # Default target + set gdb_target(default,pretty-name) "Default" + set gdb_target(default,defbaud) "" + set gdb_target(default,baud-rates) {} + set gdb_target(default,cmd) "" + set gdb_target(default,runlist) {0 0 1 0} + set gdb_target(default,options) "" + set gdb_target(default,after_attaching) {} + + # Exec target + set gdb_target(exec,pretty-name) "Exec" + set gdb_target(exec,defbaud) "" + set gdb_target(exec,baud-rates) {} + set gdb_target(exec,cmd) "" + set gdb_target(exec,runlist) {0 0 1 0} + set gdb_target(exec,options) "" + set gdb_target(exec,after_attaching) {} + + # ADS board w/SDS protocol + set gdb_target(sds,pretty-name) "SDS" + set gdb_target(sds,defbaud) "38400" + set gdb_target(sds,baud-rates) {9600 38400} + set gdb_target(sds,cmd) "sds com1" + set gdb_target(sds,runlist) {1 1 0 1} + set gdb_target(sds,after_attaching) {} + + # Simulator + set gdb_target(sim,pretty-name) "Simulator" + set gdb_target(sim,defbaud) "" + set gdb_target(sim,baud-rates) {} + set gdb_target(sim,cmd) "sim" + set gdb_target(sim,runlist) {1 1 1 0} + set gdb_target(sim,options) "" + set gdb_target(sim,after_attaching) {} + + # Remote + set gdb_target(remote,pretty-name) "Remote/Serial" + set gdb_target(remote,defbaud) "9600" + set gdb_target(remote,baud-rates) {9600 19200 38400 57600} + set gdb_target(remote,cmd) "remote com1" + set gdb_target(remote,runlist) {1 1 0 1} + set gdb_target(remote,after_attaching) {} + set gdb_target(remotetcp,pretty-name) "Remote/TCP" + set gdb_target(remotetcp,defbaud) "TCP" + set gdb_target(remotetcp,baud-rates) {} + set gdb_target(remotetcp,cmd) "remote tcpX" + set gdb_target(remotetcp,runlist) {1 1 0 1} + set gdb_target(remotetcp,after_attaching) {} + + # ARM Angel + set gdb_target(rdi,pretty-name) "ARM Angel/Serial" + set gdb_target(rdi,defbaud) "9600" + set gdb_target(rdi,baud-rates) {9600 19200 38400 57600 115200} + set gdb_target(rdi,cmd) "rdi com1" + set gdb_target(rdi,runlist) {1 1 0 1} + set gdb_target(rdi,after_attaching) {} + + # ARM Angel/Ethernet + set gdb_target(rditcp,pretty-name) "ARM Angel/Ethernet" + set gdb_target(rditcp,defbaud) "ETH" + set gdb_target(rditcp,baud-rates) {} + set gdb_target(rditcp,cmd) "rdi ethX" + set gdb_target(rditcp,runlist) {1 1 0 1} + set gdb_target(rditcp,after_attaching) {} + + # ARM Remote + set gdb_target(rdp,pretty-name) "ARM Remote/Serial" + set gdb_target(rdp,defbaud) "9600" + set gdb_target(rdp,baud-rates) {9600} + set gdb_target(rdp,cmd) "rdp com1" + set gdb_target(rdp,runlist) {1 1 0 1} + set gdb_target(rdp,after_attaching) {} + set gdb_target(rdptcp,pretty-name) "ARM Remote/TCP" + set gdb_target(rdptcp,defbaud) "TCP" + set gdb_target(rdptcp,baud-rates) {} + set gdb_target(rdptcp,cmd) "rdp tcpX" + set gdb_target(rdptcp,runlist) {1 1 0 1} + set gdb_target(rdptcp,after_attaching) {} + + # m32r rev C + set gdb_target(m32r,pretty-name) "M32R/Serial" + set gdb_target(m32r,defbaud) "9600" + set gdb_target(m32r,baud-rates) {9600} + set gdb_target(m32r,cmd) "m32r com1" + set gdb_target(m32r,runlist) {1 1 0 1} + set gdb_target(m32r,after_attaching) {} + set gdb_target(m32rtcp,pretty-name) "M32R/TCP" + set gdb_target(m32rtcp,defbaud) "TCP" + set gdb_target(m32rtcp,baud-rates) {} + set gdb_target(m32rtcp,cmd) "m32r tcpX" + set gdb_target(m32rtcp,runlist) {1 1 0 1} + set gdb_target(m32rtcp,after_attaching) {} + + # m32r msa2000 + set gdb_target(mon2000,pretty-name) "MON2000/Serial" + set gdb_target(mon2000,defbaud) "9600" + set gdb_target(mon2000,baud-rates) {9600} + set gdb_target(mon2000,cmd) "mon2000 com1" + set gdb_target(mon2000,runlist) {1 1 0 1} + set gdb_target(mon2000,after_attaching) {} + set gdb_target(mon2000tcp,pretty-name) "MON2000/TCP" + set gdb_target(mon2000tcp,defbaud) "TCP" + set gdb_target(mon2000tcp,baud-rates) {} + set gdb_target(mon2000tcp,cmd) "mon2000 tcpX" + set gdb_target(mon2000tcp,runlist) {1 1 0 1} + set gdb_target(mon2000tcp,after_attaching) {} + + # sparclite + set gdb_target(sparclite,pretty-name) "SPARClite/Serial" + set gdb_target(sparclite,defbaud) "9600" + set gdb_target(sparclite,baud-rates) {9600} + set gdb_target(sparclite,cmd) "sparclite com1" + set gdb_target(sparclite,runlist) {1 1 0 1} + set gdb_target(sparclite,after_attaching) {} + set gdb_target(sparclitetcp,pretty-name) "SPARClite/TCP" + set gdb_target(sparclitetcp,defbaud) "TCP" + set gdb_target(sparclitetcp,baud-rates) {} + set gdb_target(sparclitetcp,cmd) "sparclite tcpX" + set gdb_target(sparclitetcp,runlist) {1 1 0 1} + set gdb_target(sparclitetcp,after_attaching) {} + + # V850 ICE + set gdb_target(ice,pretty-name) "V850 ICE" + set gdb_target(ice,defbaud) "" + set gdb_target(ice,baud-rates) {} + set gdb_target(ice,cmd) "ice" + set gdb_target(ice,runlist) {1 1 0 1} + set gdb_target(ice,after_attaching) {} + + # MIPS + set gdb_target(mips,pretty-name) "MIPS/Serial" + set gdb_target(mips,defbaud) "9600" + set gdb_target(mips,baud-rates) {9600} + set gdb_target(mips,cmd) "mips com1" + set gdb_target(mips,runlist) {1 1 0 1} + set gdb_target(mips,after_attaching) {} + set gdb_target(mipstcp,pretty-name) "MIPS/TCP" + set gdb_target(mipstcp,defbaud) "TCP" + set gdb_target(mipstcp,baud-rates) {} + set gdb_target(mipstcp,cmd) "mips tcpX" + set gdb_target(mipstcp,runlist) {1 1 0 1} + set gdb_target(mipstcp,after_attaching) {} + + # Picobug + set gdb_target(picobug,pretty-name) "Picobug/Serial" + set gdb_target(picobug,defbaud) "19200" + set gdb_target(picobug,baud-rates) {19200} + set gdb_target(picobug,cmd) "picobug com1" + set gdb_target(picobug,runlist) {1 1 0 1} + set gdb_target(picobug,after_attaching) {} + set gdb_target(picobugtcp,pretty-name) "Picobug/TCP" + set gdb_target(picobugtcp,defbaud) "TCP" + set gdb_target(picobugtcp,baud-rates) {} + set gdb_target(picobugtcp,cmd) "picobug tcpX" + set gdb_target(picobugtcp,runlist) {1 1 0 1} + set gdb_target(picobugtcp,after_attaching) {} + + # Cisco. + set gdb_target(cisco,pretty-name) "Cisco/Serial" + set gdb_target(cisco,defbaud) "38400" + set gdb_target(cisco,baud-rates) {9600 19200 38400 56000} + set gdb_target(cisco,cmd) "cisco com1" + set gdb_target(cisco,runlist) {1 0 0 0} + set gdb_target(cisco,after_attaching) "set os cisco" + set gdb_target(ciscotcp,pretty-name) "Cisco/TCP" + set gdb_target(ciscotcp,defbaud) "TCP" + set gdb_target(ciscotcp,baud-rates) {} + set gdb_target(ciscotcp,cmd) "cisco tcpX" + set gdb_target(ciscotcp,runlist) {1 0 0 0} + set gdb_target(ciscotcp,after_attaching) "set os cisco" +} + +body TargetSelection::default_port {} { + global tcl_platform + switch -regexp $tcl_platform(os) { + Windows { set port com1 } + Linux { set port /dev/ttyS0 } + SunOS { set port /dev/ttya } + AIX { set port /dev/foo1 } + ULTRIX { set port /dev/foo1 } + IRIX { set port /dev/foo1 } + OSF1 { set port /dev/foo1 } + NetBSD { set port /dev/foo1 } + HP-UX { + # Special case... + switch -regexp $tcl_platform(osVersion) { + A.09 { set port /dev/tty00 } + B.10 { set port /dev/tty0p0 } + } + } + default { set port /dev/ttya } + } + + return $port +} + + +body TargetSelection::_init_prefs {} { + + if {$prefs_inited} { + return + } + set prefs_inited 1 + + # these are not target-specific + + pref define gdb/load/main 1 + pref define gdb/load/exit 1 + pref define gdb/load/check 0 + + # these are target-specific + # set up the defaults + pref define gdb/load/default-verbose 0 + pref define gdb/load/default-port [default_port] + pref define gdb/load/default-hostname "" + pref define gdb/load/default-after_attaching {} +} + +body TargetSelection::_init_target {} { + global gdb_target_name + set target_list [get_target_list] + set target $gdb_target_name + + # target = CANCEL should never come into here. If the target was + # returned as CANCEL, it should be fixed by the caller... But it + # should not be harmful if it gets in here. + + if {$target == "" || [string compare $target CANCEL] == 0} { + set target default + } + + set defbaud $gdb_target($target,defbaud) + pref define gdb/load/$target-baud $defbaud + pref define gdb/load/$target-port [pref get gdb/load/default-port] + pref define gdb/load/$target-verbose [pref get gdb/load/default-verbose] + pref define gdb/load/$target-portname 1000 + pref define gdb/load/$target-hostname [pref get gdb/load/default-hostname] + + set err [catch {pref get gdb/load/$target-runlist} run_list] + if {$err} { + set run_list $gdb_target($target,runlist) + pref setd gdb/load/$target-runlist $run_list + } + pref set gdb/src/run_attach [lindex $run_list 0] + pref set gdb/src/run_load [lindex $run_list 1] + pref set gdb/src/run_run [lindex $run_list 2] + pref set gdb/src/run_cont [lindex $run_list 3] + + set err [catch {pref get gdb/load/$target-after_attaching} aa] + if {$err} { + set aa $gdb_target($target,after_attaching) + pref setd gdb/load/$target-after_attaching $aa + } +} + +body TargetSelection::_init {} { + + if {!$trace_inited} { + # Trace all gdb_loaded changes based on target + trace variable gdb_loaded w [code TargetSelection::target_trace] + } + set trace_inited 1 + + init_target_db ;# initialize database + _init_prefs ;# initialize load prefs + _init_target ;# initialize target prefs + set_saved + + # This tells us that the target system is inited. Some of these + # init functions need to be called every time the target dialog is + # posted, some only once. The latter functions can check inited to + # see what they should do. + +} + +# ------------------------------------------------------------------ +# METHOD: build_win - build the dialog +# ------------------------------------------------------------------ +body TargetSelection::build_win {} { + global tcl_platform PREFS_state gdb_ImageDir gdb_target_name + + set f [frame $itk_interior.f] + set opts [frame $itk_interior.moreoptions] + frame $itk_interior.moreoptionsframe + set btns [frame $itk_interior.buttons] + + #labelled frame "Connection" + iwidgets::Labeledframe $f.lab -labelpos nw -labeltext [gettext "Connection"] + set fr [$f.lab childsite] + + # target name + label $fr.tarl -text [gettext "Target:"] + combobox::combobox $fr.tar -editable 0 -command [code $this change_target] \ + -width $Width -maxheight 10 + + # baud rate combobox + label $fr.cbl -text [gettext "Baud Rate:"] + combobox::combobox $fr.cb -editable 0 -command [code $this change_baud] \ + -textvariable [pref varname gdb/load/$target-baud] -width $Width \ + -maxheight 10 + + if {[catch {gdb_cmd "show remotebaud"} res]} { + set baud [pref get gdb/load/$target-baud] + } else { + set baud [lindex $res end] + set baud [string trimright $baud "."] + # When uninitialized, GDB returns a baud rate of 2^32 + # Detect this and ignore it. + if {$baud > 4000000000} { + set baud [pref get gdb/load/$target-baud] + } else { + pref setd gdb/load/$target-baud $baud + } + } + + # host entry widget + entry $fr.host -textvariable [pref varname gdb/load/$target-hostname] \ + -width $Width + + # port combobox + if {$tcl_platform(platform) == "windows"} { + set editable 0 + } else { + set editable 1 + } + + label $fr.portl -text [gettext "Port:"] + combobox::combobox $fr.port -editable $editable \ + -textvariable [pref varname gdb/load/$target-port] \ + -width $Width -maxheight 10 + + # load baud rates into combobox + fill_rates + + # load port combobox + if {$tcl_platform(platform) == "windows"} { + foreach val [port_list] { + $fr.port list insert end $val + } + } else { + # fixme: how do I find valid values for these???? + switch $tcl_platform(os) { + Linux { set ports [list /dev/cua0 /dev/ttyS0 /dev/ttyS1 /dev/ttyS2 /dev/ttyS3]} + SunOS { set ports [list /dev/ttya /dev/ttyb] } + AIX { set ports [list /dev/foo1 /dev/foo2] } + ULTRIX { set ports [list /dev/foo1 /dev/foo2] } + IRIX { set ports [list /dev/foo1 /dev/foo2] } + OSF1 { set ports [list /dev/foo1 /dev/foo2] } + NetBSD { set ports [list /dev/foo1 /dev/foo2] } + HP-UX { + # Special case... + switch -regexp $tcl_platform(osVersion) { + A.09 { set ports [list /dev/tty00 /dev/tty01] } + B.10 { set ports [list /dev/tty0p0 /dev/tty1p0] } + } + } + default { set ports [list UNKNOWN UNKNOWN] } + } + foreach val $ports { + $fr.port list insert end $val + } + } + + # Port entry widget + entry $fr.porte -textvariable [pref varname gdb/load/$target-port] -width $Width + + frame $f.fr + checkbutton $f.fr.main -text [gettext "Set breakpoint at 'main'"] \ + -variable [pref varname gdb/load/main] + checkbutton $f.fr.exit -text [gettext "Set breakpoint at 'exit'"] \ + -variable [pref varname gdb/load/exit] + frame $f.fr.bp + checkbutton $f.fr.bp.at_func -text [gettext "Set breakpoint at"] \ + -variable [pref varname gdb/load/bp_at_func] + entry $f.fr.bp.func -textvariable [pref varname gdb/load/bp_func] -width 20 + checkbutton $f.fr.verb -text [gettext "Display Download Dialog"] \ + -variable [pref varname gdb/load/$target-verbose] + + if {![pref get gdb/control_target]} { + $f.fr.main configure -state disabled + $f.fr.exit configure -state disabled + $f.fr.verb configure -state disabled + $f.fr.bp.at_func configure -state disabled + $f.fr.bp.func configure -state disabled + checkbutton $f.fr.check -text [gettext "Compare to remote executable"] \ + -variable [pref varname gdb/load/check] + if { $gdb_target_name == "exec" } { + $f.fr.check configure -state disabled + } + } + + grid $fr.tarl $fr.tar -sticky w -padx 5 -pady 5 + grid $fr.cbl $fr.cb -sticky w -padx 5 -pady 5 + grid $fr.portl $fr.port -sticky w -padx 5 -pady 5 + set mapped1 $fr.cb + set mapped2 $fr.port + + grid $f.fr.main -sticky w -padx 5 -pady 5 + grid $f.fr.exit -sticky w -padx 5 -pady 5 + pack $f.fr.bp.at_func $f.fr.bp.func -side left + grid $f.fr.bp -sticky w -padx 5 -pady 5 + grid $f.fr.verb -sticky w -padx 5 -pady 5 + if {![pref get gdb/control_target]} { + grid $f.fr.check -sticky w -padx 5 -pady 5 + } + + grid $f.lab $f.fr -sticky w -padx 5 -pady 5 + + # Create the "More Options" thingy + if {[lsearch [image names] _MORE_] == -1} { + image create photo _MORE_ -file [file join $gdb_ImageDir more.gif] + image create photo _LESS_ -file [file join $gdb_ImageDir less.gif] + } + + set MoreButton [button $opts.button -image _MORE_ \ + -relief flat -command [code $this toggle_more_options]] + set MoreLabel [label $opts.lbl -text {More Options}] + frame $opts.frame -relief raised -bd 1 + pack $opts.button $opts.lbl -side left + place $opts.frame -relx 1 -x -10 -rely 0.5 -relwidth 0.73 -height 2 -anchor e + + # Create the (hidden) more options frame + set MoreFrame [iwidgets::Labeledframe $itk_interior.moreoptionsframe.frame \ + -labelpos nw -labeltext {Run Options}] + set frame [$MoreFrame childsite] + + set var [pref varname gdb/src/run_attach] + checkbutton $frame.attach -text {Attach to Target} -variable $var + + set var [pref varname gdb/src/run_load] + checkbutton $frame.load -text {Download Program} -variable $var + + set var [pref varname gdb/src/run_cont] + checkbutton $frame.cont -text {Continue from Last Stop} -variable $var \ + -command [code $this set_run run] + + set var [pref varname gdb/src/run_run] + checkbutton $frame.run -text {Run Program} -variable $var \ + -command [code $this set_run cont] + + # The after attaching command entry + set _after_entry [entry $frame.aftere] + label $frame.afterl -text {Command to issue after attaching:} + grid $frame.attach $frame.run -sticky w + grid $frame.load $frame.cont -sticky w + grid $frame.afterl -sticky we -columnspan 2 + grid $frame.aftere -sticky we -columnspan 2 + grid columnconfigure $frame 0 -weight 1 + grid columnconfigure $frame 1 -weight 1 + + # Map everything onto the screen + # This looks like a possible packing bug -- our topmost frame + # will not resize itself. So, instead, use the topmost frame. + #pack $f $opts $itk_interior.moreoptionsframe -side top -fill x + pack $MoreFrame -fill x -expand yes + pack $f $opts -side top -fill x + + change_target $gdb_target($target,pretty-name) + + button $btns.ok -text [gettext OK] -width 7 -command [code $this save] \ + -default active + button $btns.cancel -text [gettext Cancel] -width 7 \ + -command [code $this cancel] + button $btns.help -text [gettext Help] -width 7 -command [code $this help] \ + -state disabled + standard_button_box $btns + bind $btns.ok <Return> "$btns.ok flash; $btns.ok invoke" + bind $btns.cancel <Return> "$btns.cancel flash; $btns.cancel invoke" + bind $btns.help <Return> "$btns.help flash; $btns.help invoke" + + pack $btns -side bottom -anchor e + focus $btns.ok + + # set up balloon help + balloon register $f.fr.bp.at_func "Set User-Speficied Breakpoints at Run Time" + balloon register $f.fr.bp.func "Enter a List of Functions for Breakpoints" + + window_name "Target Selection" + + if {[valid_target $target]} { + $fr.tar configure -value $gdb_target($target,pretty-name) + } + fill_targets + + +} + +# ------------------------------------------------------------------ +# METHOD: set_saved - set saved values +# ------------------------------------------------------------------ +body TargetSelection::set_saved {} { + set saved_baud [pref get gdb/load/$target-baud] + set saved_port [pref get gdb/load/$target-port] + set saved_main [pref get gdb/load/main] + set saved_exit [pref get gdb/load/exit] + set saved_check [pref get gdb/load/check] + set saved_verb [pref get gdb/load/$target-verbose] + set saved_portname [pref get gdb/load/$target-portname] + set saved_hostname [pref get gdb/load/$target-hostname] + set saved_attach [pref get gdb/src/run_attach] + set saved_load [pref get gdb/src/run_load] + set saved_run [pref get gdb/src/run_run] + set saved_cont [pref get gdb/src/run_cont] + if {[info exists gdb_target($target,options)]} { + if {[catch {pref get gdb/load/$target-opts} saved_options]} { + set saved_options "" + } + } +} + +# ------------------------------------------------------------------ +# METHOD: write_saved - write saved values to preferences +# ------------------------------------------------------------------ +body TargetSelection::write_saved {} { + pref setd gdb/load/$target-baud $saved_baud + pref setd gdb/load/$target-port $saved_port + pref setd gdb/load/main $saved_main + pref setd gdb/load/exit $saved_exit + pref setd gdb/load/check $saved_check + pref setd gdb/load/$target-verbose $saved_verb + pref setd gdb/load/$target-portname $saved_portname + pref setd gdb/load/$target-hostname $saved_hostname + pref setd gdb/load/$target-runlist [list $saved_attach $saved_load $saved_run $saved_cont] + if {[info exists gdb_target($target,options)]} { + pref setd gdb/load/$target-opts $saved_options + } + if {[catch {$_after_entry get} saved_after_attaching]} { + set saved_after_attaching "" + } + pref setd gdb/load/$target-after_attaching $saved_after_attaching +} + +# ------------------------------------------------------------------ +# METHOD: fill_rates - fill baud rate combobox +# ------------------------------------------------------------------ +body TargetSelection::fill_rates {} { + $fr.cb list delete 0 end + + if {$gdb_target($target,baud-rates) != ""} { + foreach val $gdb_target($target,baud-rates) { + $fr.cb list insert end $val + } + } +} + +# ------------------------------------------------------------------ +# METHOD: fill_targets - fill target combobox +# ------------------------------------------------------------------ +body TargetSelection::fill_targets {} { + #[$fr.tar subwidget listbox] delete 0 end + $fr.tar list delete 0 end + + foreach val $target_list { + if {[info exists gdb_target($val,pretty-name)]} { + $fr.tar list insert end $gdb_target($val,pretty-name) + + # Insert TCP target, if it exists + if {[info exists gdb_target(${val}tcp,pretty-name)]} { + $fr.tar list insert end $gdb_target(${val}tcp,pretty-name) + } + } + } +} + +# ------------------------------------------------------------------ +# METHOD: config_dialog - Convenience method to map/unmap/rename +# components onto the screen based on target T. +# ------------------------------------------------------------------ +body TargetSelection::config_dialog {t} { + pref define gdb/load/$t-verbose [pref get gdb/load/verbose] + $f.fr.verb config -variable [pref varname gdb/load/$t-verbose] + # Map the correct entries and comboboxes onto the screen + if {$gdb_target($t,defbaud) == "TCP"} { + # we have a tcp target + # map host and porte + if {$mapped1 != "$fr.host"} { + grid forget $mapped1 + set mapped1 $fr.host + grid $mapped1 -row 1 -column 1 -sticky w -padx 5 -pady 5 + } + $fr.cbl configure -text "Hostname:" + $fr.host config -textvariable [pref varname gdb/load/$t-hostname] + + if {$mapped2 != "$fr.porte"} { + grid forget $mapped2 + set mapped2 $fr.porte + grid $mapped2 -row 2 -column 1 -sticky w -padx 5 -pady 5 + } + $fr.portl configure -text {Port:} + $fr.porte config -textvariable [pref varname gdb/load/$t-portname] -fg black + + $mapped1 configure -state normal + $mapped2 configure -state normal + } elseif {$gdb_target($t,defbaud) == "ETH"} { + # we have a udp target + # map host and porte + if {$mapped1 != "$fr.host"} { + grid forget $mapped1 + set mapped1 $fr.host + grid $mapped1 -row 1 -column 1 -sticky w -padx 5 -pady 5 + } + $fr.cbl configure -text "Hostname:" + $fr.host config -textvariable [pref varname gdb/load/$t-hostname] + + if {$mapped2 != "$fr.porte"} { + grid forget $mapped2 + } + $fr.portl configure -text {Port: N/A (fixed)} + + $mapped1 configure -state normal + $mapped2 configure -state disabled + } elseif {$gdb_target($t,defbaud) != ""} { + # we have a serial target + # map port and cb + if {$mapped1 != "$fr.cb"} { + grid forget $mapped1 + set mapped1 $fr.cb + grid $mapped1 -row 1 -column 1 -sticky w -padx 5 -pady 5 + } + $fr.cbl configure -text "Baud Rate:" + $fr.cb configure -textvariable [pref varname gdb/load/$t-baud] + + if {$mapped2 != "$fr.port"} { + grid forget $mapped2 + set mapped2 $fr.port + grid $mapped2 -row 2 -column 1 -sticky w -padx 5 -pady 5 + } + $fr.portl configure -text {Port:} + $fr.port configure -textvariable [pref varname gdb/load/$t-port] + + $mapped1 configure -state normal + $mapped2 configure -state normal + } else { + # we have a non-remote(-like) target + # disable all (except tar) and check for + # options + $mapped1 configure -state disabled + $mapped2 configure -state disabled + $fr.porte configure -fg gray + + if {[info exists gdb_target($t,options)]} { + if {$mapped1 != "$fr.host"} { + grid forget $mapped1 + set mapped1 $fr.host + grid $mapped1 -row 1 -column 1 -sticky w -padx 5 -pady 5 + } + $mapped1 configure -state normal + $fr.host config -textvariable [pref varname gdb/load/$t-opts] + + # We call options "arguments" for the exec target + # FIXME: this is really overloaded!! + if {$t == "exec"} { + set text "Arguments:" + } else { + set text "Options:" + } + $fr.cbl configure -text $text + } + } +} + +# ------------------------------------------------------------------ +# METHOD: change_target - callback for target combobox +# ------------------------------------------------------------------ +body TargetSelection::change_target {w {name ""}} { + if {$name == ""} {return} + set target [get_target $name] + debug "$target" + set defbaud $gdb_target($target,defbaud) + pref define gdb/load/$target-baud $defbaud + pref define gdb/load/$target-portname 1000 + pref define gdb/load/$target-hostname [pref get gdb/load/default-hostname] + if {$defbaud == ""} { + pref define gdb/load/$target-port "" + } else { + pref define gdb/load/$target-port [pref get gdb/load/default-port] + } + + config_dialog $target + fill_rates + + # Configure the default run options for this target + set err [catch {pref get gdb/load/$target-runlist} run_list] + if {$err} { + set run_list $gdb_target($target,runlist) + pref setd gdb/load/$target-runlist $run_list + } + + pref set gdb/src/run_attach [lindex $run_list 0] + pref set gdb/src/run_load [lindex $run_list 1] + pref set gdb/src/run_run [lindex $run_list 2] + pref set gdb/src/run_cont [lindex $run_list 3] + set_check_button $name + + set err [catch {pref get gdb/load/$target-after_attaching} aa] + if {$err} { + set aa $gdb_target($target,after_attaching) + pref setd gdb/load/$target-after_attaching $aa + } + + $_after_entry delete 0 end + $_after_entry insert 0 $aa + + set_saved + + set changes 0 +} + +# ------------------------------------------------------------------ +# PRIVATE METHOD: change_baud - called when the baud rate is changed. +# If GDB is running, set baud rate in GDB and read it back. +# ------------------------------------------------------------------ +body TargetSelection::change_baud {w {baud ""}} { + if {$baud != ""} { + if {[string compare $baud "TCP"] != 0} { + gdb_cmd "set remotebaud $baud" + if {[catch {gdb_cmd "show remotebaud"} res]} { + set newbaud 0 + } else { + set newbaud [lindex $res end] + set newbaud [string trimright $newbaud "."] + if {$newbaud > 4000000} { + set newbaud 0 + } + } + if {$newbaud != $baud} { + pref set gdb/load/$target-baud $newbaud + } + } + } +} + + +# ------------------------------------------------------------------ +# METHOD: port_list - return a list of valid ports for Windows +# ------------------------------------------------------------------ +body TargetSelection::port_list {} { + set plist "" + # Scan com1 - com8 trying to open each one. + # If permission is denied that means it is in use, + # which is OK because we may be using it or the user + # may be setting up the remote target manually with + # a terminal program. + for {set i 1} {$i < 9} { incr i} { + if {[catch { set fd [::open COM$i: RDWR] } msg]} { + # Failed. Find out why. + if {[string first "permission denied" $msg] != -1} { + # Port is there, but busy right now. That's OK. + lappend plist com$i + } + } else { + # We got it. Now close it and add to list. + close $fd + lappend plist com$i + } + } + return $plist +} + +# ------------------------------------------------------------------ +# METHOD: get_target_list - return a list of targets supported +# by this GDB. Parses the output of "help target" +# ------------------------------------------------------------------ +body TargetSelection::get_target_list {} { + set native [native_debugging] + set names "" + set res [gdb_cmd "help target"] + foreach line [split $res \n] { + if {![string compare [lindex $line 0] "target"]} { + set name [lindex $line 1] + + # For cross debuggers, do not allow the target "exec" + if {$name == "exec" && !$native} { + continue + } + lappend names $name + } + } + return $names +} + +# ------------------------------------------------------------------ +# METHOD: save - save values +# ------------------------------------------------------------------ +body TargetSelection::save {} { + global gdb_target_name + set err [catch { + set_saved + write_saved + set gdb_target_name $target + pref setd gdb/load/target $target + } errtxt] + if {$err} {debug "target: $errtxt"} + if {[valid_target $gdb_target_name]} { + # Dismiss the dialog box + unpost + } else { + tk_messageBox -message "The current target is not valid." + } + +} + + +# ------------------------------------------------------------------ +# METHOD: cancel - restore previous values +# ------------------------------------------------------------------ +body TargetSelection::cancel {} { + global gdb_target_name + catch {gdb_cmd "set remotebaud $saved_baud"} + + $fr.cb configure -value $saved_baud + write_saved + if {$exportcancel} { + set gdb_target_name CANCEL + } + + # Now dismiss the dialog + unpost +} + +# ------------------------------------------------------------------ +# METHOD: set_check_button - enable/disable compare-section command +# ------------------------------------------------------------------ +body TargetSelection::set_check_button {name} { + if {[winfo exists $itk_interior.f.fr.check]} { + if { $name == "exec" } { + $itk_interior.f.fr.check configure -state disabled + } else { + $itk_interior.f.fr.check configure -state normal + } + } +} + +# ------------------------------------------------------------------ +# METHOD: help - launches context sensitive help. +# ------------------------------------------------------------------ +body TargetSelection::help {} { +} + +# ------------------------------------------------------------------ +# METHOD: reconfig - used when preferences change +# ------------------------------------------------------------------ +body TargetSelection::reconfig {} { + # for now, just delete and recreate + destroy $itk_interior.f + build_win +} + +# ------------------------------------------------------------------ +# METHOD: get_target - get the internal name of a target from the +# pretty-name +# ------------------------------------------------------------------ +body TargetSelection::get_target {name} { + set t {} + set list [array get gdb_target *,pretty-name] + set i [lsearch -exact $list $name] + if {$i != -1} { + incr i -1 + set t [lindex [split [lindex $list $i] ,] 0] + } else { + debug "unknown pretty-name \"$name\"" + } + return $t +} + +# ------------------------------------------------------------------ +# METHOD: toggle_more_options -- toggle displaying the More/Fewer +# Options pane +# ------------------------------------------------------------------ +body TargetSelection::toggle_more_options {} { + if {[$MoreLabel cget -text] == "More Options"} { + $MoreLabel configure -text "Fewer Options" + $MoreButton configure -image _LESS_ + # Bug in Tk? The top-most frame does not shrink... + #pack $MoreFrame + pack $itk_interior.moreoptionsframe -after $itk_interior.moreoptions -fill both -padx 5 -pady 5 + } else { + $MoreLabel configure -text "More Options" + $MoreButton configure -image _MORE_ + #pack forget $MoreFrame + pack forget $itk_interior.moreoptionsframe + } +} + +# ------------------------------------------------------------------ +# METHOD: set_run - set the run button. Make sure not both run and +# continue are selected. +# ------------------------------------------------------------------ +body TargetSelection::set_run {check_which} { + global PREFS_state + set var [pref varname gdb/src/run_$check_which] + global $var + if {[set $var]} { + set $var 0 + } +} + +# ------------------------------------------------------------------ +# PROCEDURE: target_trace +# This procedure is used to configure gdb_loaded +# and possible more) whenever the value of gdb_loaded +# is changed based on the current target. +# ------------------------------------------------------------------ +body TargetSelection::target_trace {variable index op} { + global gdb_target_name gdb_loaded + + switch $gdb_target_name { + + exec { + # The exec target is always loaded. + set gdb_loaded 1 + } + } +} + +# Returns 1 if TARGET is a _runnable_ target for this gdb. +body TargetSelection::valid_target {target} { + set err [catch {gdb_cmd "help target $target"}] + if {$target == "exec" && ![native_debugging]} { + set err 1 + } + + if {[regexp "tcp$" $target]} { + # Special case (of course) + regsub tcp$ $target {} foo + return [valid_target $foo] + } + + return [expr {$err == 0}] +} + +# Returns 1 if this is not a cross debugger. +body TargetSelection::native_debugging {} { + global GDBStartup + + set r [string compare $GDBStartup(host_name) $GDBStartup(target_name)] + return [expr {!$r}] +} |