OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [gdb-5.0/] [gdb/] [testsuite/] [config/] [slite.exp] - Diff between revs 107 and 1765

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 107 Rev 1765
#   Copyright (C) 1993, 1997, 1998 Free Software Foundation, Inc.
#   Copyright (C) 1993, 1997, 1998 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
# (at your option) any later version.
#
#
# This program is distributed in the hope that it will be useful,
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
# GNU General Public License for more details.
#
#
# You should have received a copy of the GNU General Public License
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
# Please email any bugs, comments, and/or additions to this file to:
# Please email any bugs, comments, and/or additions to this file to:
# DejaGnu@cygnus.com
# DejaGnu@cygnus.com
# This file was written by Ian Lance Taylor .
# This file was written by Ian Lance Taylor .
# GDB support routines for a board using the MIPS remote debugging
# GDB support routines for a board using the MIPS remote debugging
# protocol.  These are actually pretty generic.
# protocol.  These are actually pretty generic.
# DejaGnu currently assumes that debugging is being done over the main
# DejaGnu currently assumes that debugging is being done over the main
# console port.  It would probably be more convenient for people using
# console port.  It would probably be more convenient for people using
# IDT boards to permit the debugging port and the connected port to be
# IDT boards to permit the debugging port and the connected port to be
# different, since an IDT board has two ports.  This would require
# different, since an IDT board has two ports.  This would require
# extending some of the tests in a fashion similar to that done for
# extending some of the tests in a fashion similar to that done for
# VxWorks, because the test output would appear on the other port,
# VxWorks, because the test output would appear on the other port,
# rather than being displayed by gdb.
# rather than being displayed by gdb.
load_lib remote.exp
load_lib remote.exp
load_lib gdb.exp
load_lib gdb.exp
set gdb_prompt "\\(gdb\\)"
set gdb_prompt "\\(gdb\\)"
#
#
# gdb_load -- load a file into the GDB.
# gdb_load -- load a file into the GDB.
#             Returns a 0 if there was an error,
#             Returns a 0 if there was an error,
#                       1 if it load successfully.
#                       1 if it load successfully.
#
#
proc gdb_load { arg } {
proc gdb_load { arg } {
    global verbose
    global verbose
    global loadpath
    global loadpath
    global loadfile
    global loadfile
    global gdb_prompt
    global gdb_prompt
    global GDB
    global GDB
    global expect_out
    global expect_out
    set loadfile [file tail $arg]
    set loadfile [file tail $arg]
    set loadpath [file dirname $arg]
    set loadpath [file dirname $arg]
    gdb_file_cmd $arg
    gdb_file_cmd $arg
    if [target_info exists gdb_protocol] {
    if [target_info exists gdb_protocol] {
        set protocol [target_info gdb_protocol];
        set protocol [target_info gdb_protocol];
    } else {
    } else {
        set protocol "sparclite"
        set protocol "sparclite"
    }
    }
    if [target_info exists serial] {
    if [target_info exists serial] {
        set targetname [target_info serial];
        set targetname [target_info serial];
        set command "target $protocol [target_info serial]\n";
        set command "target $protocol [target_info serial]\n";
    } else {
    } else {
        if ![target_info exists netport] {
        if ![target_info exists netport] {
            perror "Need either netport or gdb_serial entry for [target_info name].";
            perror "Need either netport or gdb_serial entry for [target_info name].";
            return -1;
            return -1;
        }
        }
        set targetname [target_info netport];
        set targetname [target_info netport];
        set command "target $protocol udp [target_info netport]\n";
        set command "target $protocol udp [target_info netport]\n";
    }
    }
    set timeout 60
    set timeout 60
    verbose "Timeout is now $timeout seconds" 2
    verbose "Timeout is now $timeout seconds" 2
    set try_count 0;
    set try_count 0;
    send_gdb $command;
    send_gdb $command;
    gdb_expect {
    gdb_expect {
         -re "Unknown response.*resetting the board.|remote timeout" {
         -re "Unknown response.*resetting the board.|remote timeout" {
            incr try_count;
            incr try_count;
            if { $try_count > 3 } {
            if { $try_count > 3 } {
                set try_count 0;
                set try_count 0;
                reboot_target;
                reboot_target;
                sleep 5;
                sleep 5;
            }
            }
            sleep 1;
            sleep 1;
            send_gdb $command;
            send_gdb $command;
            exp_continue;
            exp_continue;
        }
        }
         -re "Remote target.*$gdb_prompt $" { }
         -re "Remote target.*$gdb_prompt $" { }
         -re ".*SPARClite appears to be alive.*$gdb_prompt $"   {
         -re ".*SPARClite appears to be alive.*$gdb_prompt $"   {
            if $verbose>1 then {
            if $verbose>1 then {
                send_user "Set target to $targetname\n"
                send_user "Set target to $targetname\n"
            }
            }
        }
        }
         timeout {
         timeout {
            perror "Couldn't set SLITE target."
            perror "Couldn't set SLITE target."
            set timeout 10
            set timeout 10
            verbose "Timeout is now $timeout seconds" 2
            verbose "Timeout is now $timeout seconds" 2
            return -1
            return -1
        }
        }
    }
    }
    if [target_info exists gdb_load_offset] {
    if [target_info exists gdb_load_offset] {
        set offset "[target_info gdb_load_offset]";
        set offset "[target_info gdb_load_offset]";
    } else {
    } else {
        set offset "";
        set offset "";
    }
    }
    if { 1 } {
    if { 1 } {
        if [is_remote host] {
        if [is_remote host] {
            set arg [remote_download host $arg];
            set arg [remote_download host $arg];
            if { $arg == "" } {
            if { $arg == "" } {
                error "download failed"
                error "download failed"
                return -1;
                return -1;
            }
            }
        }
        }
        send_gdb "load $arg $offset\n"
        send_gdb "load $arg $offset\n"
        verbose "Loading $arg into $GDB" 2
        verbose "Loading $arg into $GDB" 2
        set timeout 2400
        set timeout 2400
        verbose "Timeout is now $timeout seconds" 2
        verbose "Timeout is now $timeout seconds" 2
        gdb_expect {
        gdb_expect {
             -re "Loading.*$gdb_prompt $" {
             -re "Loading.*$gdb_prompt $" {
                verbose "Loaded $arg into $GDB" 1
                verbose "Loaded $arg into $GDB" 1
                set timeout 30
                set timeout 30
                verbose "Timeout is now $timeout seconds" 2
                verbose "Timeout is now $timeout seconds" 2
            }
            }
             -re "$gdb_prompt $"     {
             -re "$gdb_prompt $"     {
                if $verbose>1 then {
                if $verbose>1 then {
                    perror "GDB couldn't load."
                    perror "GDB couldn't load."
                }
                }
            }
            }
             timeout {
             timeout {
                if $verbose>1 then {
                if $verbose>1 then {
                    perror "Timed out trying to load $arg."
                    perror "Timed out trying to load $arg."
                }
                }
            }
            }
        }
        }
    }
    }
    # Some SPARClite boards automagically do a run after the program is
    # Some SPARClite boards automagically do a run after the program is
    # loaded.
    # loaded.
    if [target_info exists need_monitor_run] {
    if [target_info exists need_monitor_run] {
        set timeout 10
        set timeout 10
        verbose "Timeout is now $timeout seconds, doing monitor run" 2
        verbose "Timeout is now $timeout seconds, doing monitor run" 2
        send_gdb "monitor run\n";
        send_gdb "monitor run\n";
        sleep 2;
        sleep 2;
        send_gdb "";
        send_gdb "";
        gdb_expect {
        gdb_expect {
             -re ".*$gdb_prompt $" { verbose "Run command succeded" }
             -re ".*$gdb_prompt $" { verbose "Run command succeded" }
             default {
             default {
                perror "error sending monitor run command";
                perror "error sending monitor run command";
            }
            }
        }
        }
    } else {
    } else {
        sleep 2;
        sleep 2;
    }
    }
    if [target_info exists gdb_serial] {
    if [target_info exists gdb_serial] {
        set serial [target_info gdb_serial];
        set serial [target_info gdb_serial];
    } else {
    } else {
        set serial [target_info serial];
        set serial [target_info serial];
    }
    }
    send_gdb "target remote $serial\n"
    send_gdb "target remote $serial\n"
    set timeout 60
    set timeout 60
    verbose "Timeout is now $timeout seconds" 2
    verbose "Timeout is now $timeout seconds" 2
    gdb_expect {
    gdb_expect {
         -re ".*Kill it?.*y or n.*" {
         -re ".*Kill it?.*y or n.*" {
            send_gdb "y\n";
            send_gdb "y\n";
            exp_continue
            exp_continue
        }
        }
         -re ".*$gdb_prompt $"  {
         -re ".*$gdb_prompt $"  {
            verbose "Set remote target to [target_info serial]" 2
            verbose "Set remote target to [target_info serial]" 2
        }
        }
         timeout {
         timeout {
            perror "Couldn't set remote target."
            perror "Couldn't set remote target."
            set timeout 10
            set timeout 10
            verbose "Timeout is now $timeout seconds" 2
            verbose "Timeout is now $timeout seconds" 2
            return -1
            return -1
        }
        }
    }
    }
    if [info exists expect_out(buffer)] then {
    if [info exists expect_out(buffer)] then {
        send_log $expect_out(buffer)
        send_log $expect_out(buffer)
    }
    }
    return 0
    return 0
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.