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

Subversion Repositories openmsp430

[/] [openmsp430/] [trunk/] [tools/] [openmsp430-gdbproxy/] [server.tcl] - Diff between revs 158 and 172

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 158 Rev 172
Line 27... Line 27...
# 
# 
# Author(s):
# Author(s):
#             - Olivier Girard,    olgirard@gmail.com
#             - Olivier Girard,    olgirard@gmail.com
#
#
#------------------------------------------------------------------------------
#------------------------------------------------------------------------------
# $Rev: 158 $
# $Rev: 172 $
# $LastChangedBy: olivier.girard $
# $LastChangedBy: olivier.girard $
# $LastChangedDate: 2012-10-15 23:49:09 +0200 (Mon, 15 Oct 2012) $
# $LastChangedDate: 2012-12-28 00:06:56 +0100 (Fri, 28 Dec 2012) $
#------------------------------------------------------------------------------
#------------------------------------------------------------------------------
 
 
global clients
global clients
global server
global server
 
 
 
global CpuNr
 
set    CpuNr 0
 
 
 
 
###############################################################################
###############################################################################
#                                                                             #
#                                                                             #
#                           START/STOP LOCAL SERVER                           #
#                           START/STOP LOCAL SERVER                           #
#                                                                             #
#                                                                             #
###############################################################################
###############################################################################
 
 
proc startServer { } {
proc startServer { CpuNr } {
 
 
    global server
    global server
    if {![info exists server(socket)]} {
 
        putsLog "Open socket on port $server(port) ... " 1
    if {![info exists server($CpuNr,socket)]} {
        if {[catch {socket -server clientAccept $server(port)} server(socket)]} {
        putsLog "CORE $CpuNr: Open socket on port $server($CpuNr,port)... " 1
 
        if {[catch {socket -server "clientAccept $CpuNr" $server($CpuNr,port)} server($CpuNr,socket)]} {
            putsLog "failed"
            putsLog "failed"
            putsLog "ERROR: $server(socket)."
            putsLog "CORE $CpuNr: ERROR: $server($CpuNr,socket)."
            unset server(socket)
            unset server($CpuNr,socket)
            return 0
            return 0
        }
        }
        putsLog "done"
        putsLog "done"
        putsLog "INFO: Waiting on TCP port $server(port)"
        putsLog "CORE $CpuNr: INFO: Waiting on TCP port $server($CpuNr,port)"
    } else {
    } else {
        putsLog "Server is already up."
        putsLog "CORE $CpuNr: Server is already up and running."
    }
    }
    return 1
    return 1
}
}
 
 
proc stopServer { } {
proc stopAllServers { } {
    global omsp_info
    global omsp_info
    global server
    global server
    global CpuNr
    global omsp_nr
 
 
 
    for { set CpuNr 0 } { $CpuNr < $omsp_nr } { incr CpuNr } {
 
 
    if {[info exists server(socket)]} {
        if {[info exists server($CpuNr,socket)]} {
        set port [lindex [fconfigure $server(socket) -sockname] 2]
            set port [lindex [fconfigure $server($CpuNr,socket) -sockname] 2]
        putsLog "Stop server (port $port)"
            putsLog "CORE $CpuNr: Stop server (port $port)"
        close $server(socket)
            close $server($CpuNr,socket)
        unset server(socket)
            unset server($CpuNr,socket)
    }
    }
    if {$omsp_info($CpuNr,connected)} {
    if {$omsp_info($CpuNr,connected)} {
        ReleaseDevice $CpuNr 0xfffe
        ReleaseDevice $CpuNr 0xfffe
    }
    }
}
}
 
}
 
 
proc clientAccept {sock addr port} {
proc clientAccept {CpuNr sock addr port} {
    global clients
    global clients
    global CpuNr
 
 
 
    putsLog "Accept client: $addr ($port)\n"
    putsLog "CORE $CpuNr: Accept client: $addr ($port)\n"
 
 
    set clients(addr,$sock) [list $addr $port]
    set clients($CpuNr,addr,$sock) [list $addr $port]
    fconfigure $sock -buffering none
    fconfigure $sock -buffering none
    fileevent  $sock readable [list receiveRSPpacket $sock]
    fileevent  $sock readable [list receiveRSPpacket $CpuNr $sock]
 
 
    InitBreakUnits $CpuNr
    InitBreakUnits $CpuNr
}
}
 
 
proc startServerGUI { } {
proc startServerGUI { } {
    global omsp_conf
    global omsp_conf
    global omsp_info
    global omsp_info
    global CpuNr
    global omsp_nr
 
    global breakSelect
 
 
    # Connect to device
    # Connect to all devices
    if {![GetDevice $CpuNr]} {
    set connection_status 0
 
    set connection_sum    0
 
    for { set CpuNr 0 } { $CpuNr < $omsp_nr } { incr CpuNr } {
 
        set connection_ok  [GetDevice $CpuNr]
 
        set connection_sum [expr $connection_sum + $connection_ok]
 
        if {$connection_ok==0} {
 
            set error_nr "$CpuNr"
 
        }
 
    }
 
    if {$connection_sum==$omsp_nr} {
 
        set connection_status 1
 
    }
 
 
 
    if {!$connection_status} {
        .info.cpu.con   configure -text "Connection problem" -fg red
        .info.cpu.con   configure -text "Connection problem" -fg red
        putsLog "ERROR: Could not open \"$omsp_conf(device)\""
 
        putsLog ""
        putsLog ""
        putsLog "         -------------------------------------------------------------"
        putsLog "ERROR: Could not connect to Core $error_nr"
 
        putsLog ""
 
        putsLog "         -----------------------------------------------------------------------"
        putsLog "       !!!! Please consider the following options:                  !!!!"
        putsLog "       !!!! Please consider the following options:                  !!!!"
        putsLog "       !!!!                                                         !!!!"
        putsLog "       !!!!                                                         !!!!"
 
        putsLog "       !!!!      - make sure \"$omsp_conf(device)\" is the right device."
        putsLog "       !!!!      - check the physical connection to the board.      !!!!"
        putsLog "       !!!!      - check the physical connection to the board.      !!!!"
        putsLog "       !!!!      - adjust the serial connection baudrate.           !!!!"
        putsLog "       !!!!      - adjust the serial connection baudrate.           !!!!"
        putsLog "       !!!!      - don't forget to reset the serial debug interface !!!!"
        putsLog "       !!!!      - for UART, don't forget to reset the serial debug interface !!!!"
        putsLog "       !!!!        between each attempt.                            !!!!"
        putsLog "       !!!!        between each attempt.                            !!!!"
        putsLog "         -------------------------------------------------------------"
        putsLog "       !!!!      - for I2C, make sure $omsp_conf($error_nr,cpuaddr) the is the right address.            !!!!"
 
        putsLog "         -----------------------------------------------------------------------"
        putsLog ""
        putsLog ""
        return 0
        return 0
    }
    }
 
 
    if {$omsp_info($CpuNr,alias)==""} {
    if {$breakSelect==1} {
 
        if {$omsp_info(0,hw_break)==0} {
 
            .info.cpu.con   configure -text "No Hardware breakpoint unit detected" -fg red
 
            putsLog ""
 
            putsLog "ERROR: Could not detect any Hardware Breakpoint Unit"
 
            putsLog "       Consider switching to the Software Breakpoint configuration"
 
            putsLog ""
 
            return 0
 
        }
 
    }
 
 
 
    if {$omsp_info(0,alias)==""} {
        .info.cpu.con   configure -text "Connected" -fg "\#00ae00"
        .info.cpu.con   configure -text "Connected" -fg "\#00ae00"
    } else {
    } else {
        .info.cpu.con   configure -text "Connected to $omsp_info($CpuNr,alias)" -fg "\#00ae00"
        .info.cpu.con   configure -text "Connected to $omsp_info(0,alias)" -fg "\#00ae00"
    }
    }
 
 
    # Display info
    # Display info
    putsLog "INFO: Sucessfully connected with the openMSP430 target."
    putsLog "INFO: Sucessfully connected with the openMSP430 target."
    set sizes [GetCPU_ID_SIZE $CpuNr]
    set sizes [GetCPU_ID_SIZE 0]
    if {$omsp_info($CpuNr,asic)} {
    if {$omsp_info(0,asic)} {
        putsLog "INFO: CPU Version              - $omsp_info($CpuNr,cpu_ver) / ASIC"
        putsLog "INFO: CPU Version              - $omsp_info(0,cpu_ver) / ASIC"
    } else {
    } else {
        putsLog "INFO: CPU Version              - $omsp_info($CpuNr,cpu_ver) / FPGA"
        putsLog "INFO: CPU Version              - $omsp_info(0,cpu_ver) / FPGA"
    }
    }
    putsLog "INFO: User Version             - $omsp_info($CpuNr,user_ver)"
    putsLog "INFO: User Version             - $omsp_info(0,user_ver)"
    if {$omsp_info($CpuNr,cpu_ver)==1} {
    if {$omsp_info(0,cpu_ver)==1} {
        putsLog "INFO: Hardware Multiplier      - --"
        putsLog "INFO: Hardware Multiplier      - --"
    } elseif {$omsp_info($CpuNr,mpy)} {
    } elseif {$omsp_info(0,mpy)} {
        putsLog "INFO: Hardware Multiplier      - Yes"
        putsLog "INFO: Hardware Multiplier      - Yes"
    } else {
    } else {
        putsLog "INFO: Hardware Multiplier      - No"
        putsLog "INFO: Hardware Multiplier      - No"
    }
    }
    putsLog "INFO: Program Memory Size      - $omsp_info($CpuNr,pmem_size) B"
    putsLog "INFO: Program Memory Size      - $omsp_info(0,pmem_size) B"
    putsLog "INFO: Data Memory Size         - $omsp_info($CpuNr,dmem_size) B"
    putsLog "INFO: Data Memory Size         - $omsp_info(0,dmem_size) B"
    putsLog "INFO: Peripheral Address Space - $omsp_info($CpuNr,per_size) B"
    putsLog "INFO: Peripheral Address Space - $omsp_info(0,per_size) B"
    putsLog "INFO: $omsp_info($CpuNr,hw_break) Hardware Break/Watch-point unit(s) detected"
    putsLog "INFO: $omsp_info(0,hw_break) Hardware Break/Watch-point unit(s) detected"
    putsLog ""
    putsLog ""
 
 
    # Activate Load TCL script section
    # Activate Load TCL script section
    .tclscript.ft.l          configure -state normal
    .tclscript.ft.l          configure -state normal
    .tclscript.ft.file       configure -state normal
    .tclscript.ft.file       configure -state normal
Line 149... Line 182...
    .tclscript.fb.read       configure -state normal
    .tclscript.fb.read       configure -state normal
 
 
    # Activate extra cpu info button
    # Activate extra cpu info button
    .info.cpu.more           configure -state normal
    .info.cpu.more           configure -state normal
 
 
 
    for { set CpuNr 0 } { $CpuNr < $omsp_nr } { incr CpuNr } {
 
 
    # Reset & Stop CPU
    # Reset & Stop CPU
    ExecutePOR_Halt $CpuNr
    ExecutePOR_Halt $CpuNr
 
 
    # Start server for GDB
    # Start server for GDB
    if {![startServer]} {
        if {![startServer $CpuNr]} {
        .info.server.con configure -text "Connection problem" -fg red
        .info.server.con configure -text "Connection problem" -fg red
        return 0
        return 0
    }
    }
 
    }
 
 
    .info.server.con     configure -text "Running" -fg "\#00ae00"
    .info.server.con     configure -text "Running" -fg "\#00ae00"
 
 
    # Disable gui entries
    # Disable gui entries
    .connect.cfg.if.config1.adapter.p1       configure -state disabled
    .connect.cfg.if.config1.adapter.p1       configure -state disabled
    .connect.cfg.if.config2.adapter.p2       configure -state disabled
    .connect.cfg.if.config2.adapter.p2       configure -state disabled
Line 173... Line 210...
    .connect.cfg.ad.i2c_addr.s0              configure -state disabled
    .connect.cfg.ad.i2c_addr.s0              configure -state disabled
    .connect.cfg.ad.i2c_addr.s1              configure -state disabled
    .connect.cfg.ad.i2c_addr.s1              configure -state disabled
    .connect.cfg.ad.i2c_addr.s2              configure -state disabled
    .connect.cfg.ad.i2c_addr.s2              configure -state disabled
    .connect.cfg.ad.i2c_addr.s3              configure -state disabled
    .connect.cfg.ad.i2c_addr.s3              configure -state disabled
    .connect.cfg.ad.i2c_nr.s                 configure -state disabled
    .connect.cfg.ad.i2c_nr.s                 configure -state disabled
 
 
 
    .connect.cfg.ad.i2c_nr.f.soft.b          configure -state disabled
 
    .connect.cfg.ad.i2c_nr.f.soft.r          configure -state disabled
 
    .connect.cfg.ad.i2c_nr.f.hard.r          configure -state disabled
 
    if {[winfo exists .omsp_sft_brk]} {
 
        .omsp_sft_brk.map.b.share            configure -state disabled
 
        .omsp_sft_brk.map.b.dedic            configure -state disabled
 
        .omsp_sft_brk.map.r.core_nr.l0       configure -state disabled
 
        .omsp_sft_brk.map.r.pmem0.p0         configure -state disabled
 
        .omsp_sft_brk.map.r.core_nr.l1       configure -state disabled
 
        .omsp_sft_brk.map.r.pmem0.p1         configure -state disabled
 
        .omsp_sft_brk.map.r.pmem1.p1         configure -state disabled
 
        .omsp_sft_brk.map.r.core_nr.l2       configure -state disabled
 
        .omsp_sft_brk.map.r.pmem0.p2         configure -state disabled
 
        .omsp_sft_brk.map.r.pmem1.p2         configure -state disabled
 
        .omsp_sft_brk.map.r.pmem2.p2         configure -state disabled
 
        .omsp_sft_brk.map.r.core_nr.l3       configure -state disabled
 
        .omsp_sft_brk.map.r.pmem0.p3         configure -state disabled
 
        .omsp_sft_brk.map.r.pmem1.p3         configure -state disabled
 
        .omsp_sft_brk.map.r.pmem2.p3         configure -state disabled
 
        .omsp_sft_brk.map.r.pmem3.p3         configure -state disabled
 
    }
}
}
 
 
###############################################################################
###############################################################################
#                                                                             #
#                                                                             #
#                        RECEIVE / SEND RSP PACKETS                           #
#                        RECEIVE / SEND RSP PACKETS                           #
#                                                                             #
#                                                                             #
###############################################################################
###############################################################################
 
 
proc receiveRSPpacket {sock} {
proc receiveRSPpacket {CpuNr sock} {
 
 
    global CpuNr
 
 
 
    # Get client info
    # Get client info
    set ip   [lindex [fconfigure $sock -peername] 0]
    set ip   [lindex [fconfigure $sock -peername] 0]
    set port [lindex [fconfigure $sock -peername] 2]
    set port [lindex [fconfigure $sock -peername] 2]
 
 
    # Check if a new packet arrives
    # Check if a new packet arrives
    set rx_packet 0
    set rx_packet 0
    set rsp_cmd [getDebugChar $sock]
    set rsp_cmd [getDebugChar $CpuNr $sock]
    set rsp_sum ""
    set rsp_sum ""
    if {[string eq $rsp_cmd "\$"]} {
    if {[string eq $rsp_cmd "\$"]} {
        set rx_packet 1
        set rx_packet 1
        set rsp_cmd ""
        set rsp_cmd ""
    } else {
    } else {
Line 205... Line 262...
            HaltCPU $CpuNr
            HaltCPU $CpuNr
        }
        }
    }
    }
    # Receive packet
    # Receive packet
    while {$rx_packet} {
    while {$rx_packet} {
        set char [getDebugChar $sock]
        set char [getDebugChar $CpuNr $sock]
        if {$char==-1} {
        if {$char==-1} {
            set    rx_packet 0
            set    rx_packet 0
        } elseif {[string eq $char "\#"]} {
        } elseif {[string eq $char "\#"]} {
            set    rx_packet 0
            set    rx_packet 0
            set    rsp_sum   [getDebugChar $sock]
            set    rsp_sum   [getDebugChar $CpuNr $sock]
            append rsp_sum   [getDebugChar $sock]
            append rsp_sum   [getDebugChar $CpuNr $sock]
 
 
            # Re-calculate the checksum
            # Re-calculate the checksum
            set    tmp_sum   [RSPcheckSum  $rsp_cmd]
            set    tmp_sum   [RSPcheckSum  $rsp_cmd]
 
 
            # Acknowledge and analyse the packet
            # Acknowledge and analyse the packet
            if {[string eq $rsp_sum $tmp_sum]} {
            if {[string eq $rsp_sum $tmp_sum]} {
                putDebugChar $sock "+"
                putDebugChar $sock "+"
 
 
                # Remove escape characters
                # Remove escape characters
                set rsp_cmd [removeEscapeChar $rsp_cmd]
                set rsp_cmd [removeEscapeChar $rsp_cmd]
                putsVerbose "+ w $rsp_cmd"
                putsVerbose "CORE $CpuNr: + w $rsp_cmd"
 
 
                # Parse packet and send back the answer
                # Parse packet and send back the answer
                set rsp_answer [rspParse $sock $rsp_cmd]
                set rsp_answer [rspParse $CpuNr $sock $rsp_cmd]
                if {$rsp_answer != "-1"} {
                if {$rsp_answer != "-1"} {
                    sendRSPpacket $sock $rsp_answer
                    sendRSPpacket $CpuNr $sock $rsp_answer
                }
                }
            } else {
            } else {
                putDebugChar $sock "-"
                putDebugChar $sock "-"
            }
            }
        } else {
        } else {
Line 239... Line 296...
        }
        }
    }
    }
}
}
 
 
 
 
proc sendRSPpacket {sock rsp_cmd} {
proc sendRSPpacket {CpuNr sock rsp_cmd} {
 
 
    # Set escape characters
    # Set escape characters
    set rsp_cmd [setEscapeChar $rsp_cmd]
    set rsp_cmd [setEscapeChar $rsp_cmd]
 
 
    # Calculate checksum
    # Calculate checksum
Line 254... Line 311...
 
 
    # Send the packet until the "+" aknowledge is received
    # Send the packet until the "+" aknowledge is received
    set send_ok 0
    set send_ok 0
    while {!$send_ok} {
    while {!$send_ok} {
        putDebugChar $sock "$rsp_packet"
        putDebugChar $sock "$rsp_packet"
        set char [getDebugChar $sock]
        set char [getDebugChar $CpuNr $sock]
 
 
        putsVerbose "$char r $rsp_cmd"
        putsVerbose "CORE $CpuNr: $char r $rsp_cmd"
 
 
        if {$char==-1} {
        if {$char==-1} {
            set    send_ok 1
            set    send_ok 1
        } elseif {[string eq $char "+"]} {
        } elseif {[string eq $char "+"]} {
            set    send_ok 1
            set    send_ok 1
Line 314... Line 371...
 
 
    return "$rsp_cmd"
    return "$rsp_cmd"
}
}
 
 
 
 
proc getDebugChar {sock} {
proc getDebugChar {CpuNr sock} {
    global clients
    global clients
 
 
    # Get client info
    # Get client info
    set ip   [lindex [fconfigure $sock -peername] 0]
    set ip   [lindex [fconfigure $sock -peername] 0]
    set port [lindex [fconfigure $sock -peername] 2]
    set port [lindex [fconfigure $sock -peername] 2]
 
 
    if {[eof $sock] || [catch {set char [read $sock 1]}]} {
    if {[eof $sock] || [catch {set char [read $sock 1]}]} {
        # end of file or abnormal connection drop
        # end of file or abnormal connection drop
        close $sock
        close $sock
        putsLog "Connection closed: $ip ($port)\n"
        putsLog "CORE $CpuNr: Connection closed: $ip ($port)\n"
        unset clients(addr,$sock)
        unset clients($CpuNr,addr,$sock)
        return -1
        return -1
    } else {
    } else {
        return $char
        return $char
    }
    }
}
}
Line 360... Line 417...
    wm geometry .omsp_extra_info +380+200
    wm geometry .omsp_extra_info +380+200
    wm resizable .omsp_extra_info 0 0
    wm resizable .omsp_extra_info 0 0
 
 
    # Title
    # Title
    set title "openMSP430"
    set title "openMSP430"
    if {$omsp_info($CpuNr,alias)!=""} {
    if {$omsp_info(0,alias)!=""} {
        set title $omsp_info($CpuNr,alias)
        set title $omsp_info(0,alias)
    }
    }
    label  .omsp_extra_info.title  -text "$title"   -anchor center -fg "\#00ae00" -font {-weight bold -size 16}
    label  .omsp_extra_info.title  -text "$title"   -anchor center -fg "\#00ae00" -font {-weight bold -size 16}
    pack   .omsp_extra_info.title  -side top -padx {20 20} -pady {20 10}
    pack   .omsp_extra_info.title  -side top -padx {20 20} -pady {20 10}
 
 
    # Add extra info
    # Add extra info
Line 382... Line 439...
 
 
 
 
    # Fill the text widget will configuration info
    # Fill the text widget will configuration info
    .omsp_extra_info.extra.text tag configure bold -font {-family TkFixedFont -weight bold}
    .omsp_extra_info.extra.text tag configure bold -font {-family TkFixedFont -weight bold}
    .omsp_extra_info.extra.text insert end         "Configuration\n\n" bold
    .omsp_extra_info.extra.text insert end         "Configuration\n\n" bold
    .omsp_extra_info.extra.text insert end [format "CPU Version                : %5s\n" $omsp_info($CpuNr,cpu_ver)]
    .omsp_extra_info.extra.text insert end [format "CPU Version                : %5s\n" $omsp_info(0,cpu_ver)]
    .omsp_extra_info.extra.text insert end [format "User Version               : %5s\n" $omsp_info($CpuNr,user_ver)]
    .omsp_extra_info.extra.text insert end [format "User Version               : %5s\n" $omsp_info(0,user_ver)]
    if {$omsp_info($CpuNr,cpu_ver)==1} {
    if {$omsp_info(0,cpu_ver)==1} {
    .omsp_extra_info.extra.text insert end [format "Implementation             : %5s\n" --]
    .omsp_extra_info.extra.text insert end [format "Implementation             : %5s\n" --]
    } elseif {$omsp_info($CpuNr,asic)==0} {
    } elseif {$omsp_info(0,asic)==0} {
    .omsp_extra_info.extra.text insert end [format "Implementation             : %5s\n" FPGA]
    .omsp_extra_info.extra.text insert end [format "Implementation             : %5s\n" FPGA]
    } elseif {$omsp_info($CpuNr,asic)==1} {
    } elseif {$omsp_info(0,asic)==1} {
    .omsp_extra_info.extra.text insert end [format "Implementation             : %5s\n" ASIC]
    .omsp_extra_info.extra.text insert end [format "Implementation             : %5s\n" ASIC]
    }
    }
    if {$omsp_info($CpuNr,mpy)==1} {
    if {$omsp_info(0,mpy)==1} {
    .omsp_extra_info.extra.text insert end [format "Hardware Multiplier support: %5s\n" Yes]
    .omsp_extra_info.extra.text insert end [format "Hardware Multiplier support: %5s\n" Yes]
    } elseif {$omsp_info($CpuNr,mpy)==0} {
    } elseif {$omsp_info(0,mpy)==0} {
    .omsp_extra_info.extra.text insert end [format "Hardware Multiplier support: %5s\n" No]
    .omsp_extra_info.extra.text insert end [format "Hardware Multiplier support: %5s\n" No]
    } else {
    } else {
    .omsp_extra_info.extra.text insert end [format "Hardware Multiplier support: %5s\n" --]
    .omsp_extra_info.extra.text insert end [format "Hardware Multiplier support: %5s\n" --]
    }
    }
    .omsp_extra_info.extra.text insert end [format "Program memory size        : %5s B\n" $omsp_info($CpuNr,pmem_size)]
    .omsp_extra_info.extra.text insert end [format "Program memory size        : %5s B\n" $omsp_info(0,pmem_size)]
    .omsp_extra_info.extra.text insert end [format "Data memory size           : %5s B\n" $omsp_info($CpuNr,dmem_size)]
    .omsp_extra_info.extra.text insert end [format "Data memory size           : %5s B\n" $omsp_info(0,dmem_size)]
    .omsp_extra_info.extra.text insert end [format "Peripheral address space   : %5s B\n" $omsp_info($CpuNr,per_size)]
    .omsp_extra_info.extra.text insert end [format "Peripheral address space   : %5s B\n" $omsp_info(0,per_size)]
    if {$omsp_info($CpuNr,alias)==""} {
    if {$omsp_info(0,alias)==""} {
    .omsp_extra_info.extra.text insert end [format "Alias                      : %5s\n\n\n" None]
    .omsp_extra_info.extra.text insert end [format "Alias                      : %5s\n\n\n" None]
    } else {
    } else {
    .omsp_extra_info.extra.text insert end [format "Alias                      : %5s\n\n\n" $omsp_info($CpuNr,alias)]
    .omsp_extra_info.extra.text insert end [format "Alias                      : %5s\n\n\n" $omsp_info(0,alias)]
    }
    }
 
 
    .omsp_extra_info.extra.text insert end         "Extra Info\n\n" bold
    .omsp_extra_info.extra.text insert end         "Extra Info\n\n" bold
 
 
    if {$omsp_info($CpuNr,alias)!=""} {
    if {$omsp_info(0,alias)!=""} {
 
 
        set aliasEXTRA  [lsort -increasing [array names omsp_info -glob "extra,*"]]
        set aliasEXTRA  [lsort -increasing [array names omsp_info -glob "extra,*"]]
        if {[llength $aliasEXTRA]} {
        if {[llength $aliasEXTRA]} {
 
 
            foreach currentEXTRA $aliasEXTRA {
            foreach currentEXTRA $aliasEXTRA {
                regexp {^.+,.+,(.+)$} $currentEXTRA whole_match extraATTR
                regexp {^.+,.+,(.+)$} $currentEXTRA whole_match extraATTR
                .omsp_extra_info.extra.text insert end     [format "%-15s: %s\n" $extraATTR  $omsp_info($CpuNr,$currentEXTRA)]
                .omsp_extra_info.extra.text insert end     [format "%-15s: %s\n" $extraATTR  $omsp_info(0,$currentEXTRA)]
            }
            }
            .omsp_extra_info.extra.text insert end         "\n\n"
            .omsp_extra_info.extra.text insert end         "\n\n"
        }
        }
    } else {
    } else {
        .omsp_extra_info.extra.text insert end  "No alias found in 'omsp_alias.xml' file"
        .omsp_extra_info.extra.text insert end  "No alias found in 'omsp_alias.xml' file"

powered by: WebSVN 2.1.0

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