startup.tcl (former commands.tcl) is now embedded into OpenOCD executable.
git-svn-id: svn://svn.berlios.de/openocd/trunk@787 b42882b7-edfa-0310-969c-e2dbd0fdcd60
This commit is contained in:
parent
2b3f4fd293
commit
efc6063df8
|
@ -7,7 +7,7 @@ MAINFILE = main.c jim.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
openocd_SOURCES = $(MAINFILE) openocd.c
|
openocd_SOURCES = $(MAINFILE) openocd.c startup.c
|
||||||
|
|
||||||
# set the include path found by configure
|
# set the include path found by configure
|
||||||
INCLUDES = -I$(top_srcdir)/src/helper \
|
INCLUDES = -I$(top_srcdir)/src/helper \
|
||||||
|
@ -82,7 +82,6 @@ openocd_LDADD = $(top_builddir)/src/xsvf/libxsvf.a \
|
||||||
|
|
||||||
|
|
||||||
nobase_dist_pkglib_DATA = \
|
nobase_dist_pkglib_DATA = \
|
||||||
tcl/commands.tcl \
|
|
||||||
tcl/bitsbytes.tcl \
|
tcl/bitsbytes.tcl \
|
||||||
tcl/chip/atmel/at91/aic.tcl \
|
tcl/chip/atmel/at91/aic.tcl \
|
||||||
tcl/chip/atmel/at91/at91sam7x128.tcl \
|
tcl/chip/atmel/at91/at91sam7x128.tcl \
|
||||||
|
@ -98,3 +97,6 @@ nobase_dist_pkglib_DATA = \
|
||||||
tcl/mmr_helpers.tcl \
|
tcl/mmr_helpers.tcl \
|
||||||
tcl/readable.tcl
|
tcl/readable.tcl
|
||||||
|
|
||||||
|
# Convert .tcl to .c file
|
||||||
|
startup.c: $(top_srcdir)/src/startup.tcl Makefile $(top_srcdir)/src/file2c.tcl
|
||||||
|
tclsh $(top_srcdir)/src/file2c.tcl $(top_srcdir)/src/startup.tcl startup.c
|
|
@ -0,0 +1,125 @@
|
||||||
|
#!/bin/bash
|
||||||
|
# restart using a Tcl shell \
|
||||||
|
exec sh -c 'for tclshell in tclsh tclsh83 cygtclsh80 ; do \
|
||||||
|
( echo | $tclshell ) 2> /dev/null && exec $tclshell "`( cygpath -w \"$0\" ) 2> /dev/null || echo $0`" "$@" ; \
|
||||||
|
done ; \
|
||||||
|
echo "file2c.tcl: cannot find Tcl shell" ; exit 1' "$0" "$@"
|
||||||
|
|
||||||
|
#===============================================================================
|
||||||
|
#
|
||||||
|
# file2c.tcl
|
||||||
|
#
|
||||||
|
# Convert a file into a header that can be #included from C.
|
||||||
|
#
|
||||||
|
#===============================================================================
|
||||||
|
#####ECOSGPLCOPYRIGHTBEGIN####
|
||||||
|
## -------------------------------------------
|
||||||
|
## This file is part of eCos, the Embedded Configurable Operating System.
|
||||||
|
## Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
|
||||||
|
##
|
||||||
|
## eCos is free software; you can redistribute it and/or modify it under
|
||||||
|
## the terms of the GNU General Public License as published by the Free
|
||||||
|
## Software Foundation; either version 2 or (at your option) any later version.
|
||||||
|
##
|
||||||
|
## eCos 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.
|
||||||
|
##
|
||||||
|
## You should have received a copy of the GNU General Public License along
|
||||||
|
## with eCos; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
## 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
|
||||||
|
##
|
||||||
|
## As a special exception, if other files instantiate templates or use macros
|
||||||
|
## or inline functions from this file, or you compile this file and link it
|
||||||
|
## with other works to produce a work based on this file, this file does not
|
||||||
|
## by itself cause the resulting work to be covered by the GNU General Public
|
||||||
|
## License. However the source code for this file must still be made available
|
||||||
|
## in accordance with section (3) of the GNU General Public License.
|
||||||
|
##
|
||||||
|
## This exception does not invalidate any other reasons why a work based on
|
||||||
|
## this file might be covered by the GNU General Public License.
|
||||||
|
##
|
||||||
|
## Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
|
||||||
|
## at http://sources.redhat.com/ecos/ecos-license/
|
||||||
|
## -------------------------------------------
|
||||||
|
#####ECOSGPLCOPYRIGHTEND####
|
||||||
|
#===============================================================================
|
||||||
|
######DESCRIPTIONBEGIN####
|
||||||
|
#
|
||||||
|
# Author(s): jlarmour,bartv
|
||||||
|
# Contact(s):
|
||||||
|
# Date: 2001-07-20
|
||||||
|
# Purpose:
|
||||||
|
# Description:
|
||||||
|
# Usage: file2c.tcl <file to encode> <output C header file>
|
||||||
|
#
|
||||||
|
#####DESCRIPTIONEND####
|
||||||
|
#===============================================================================
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if { $argc != 2 } {
|
||||||
|
puts "Usage: file2c.tcl <file to encode> <output C file>"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
set infile [lindex $argv 0]
|
||||||
|
set outfile [lindex $argv 1]
|
||||||
|
set label [string range $outfile [expr 1+[string last / $outfile]] [expr [string last . $outfile]-1]]
|
||||||
|
|
||||||
|
set status [ catch {
|
||||||
|
set infilefd [open $infile "r"]
|
||||||
|
fconfigure $infilefd -translation binary
|
||||||
|
set data [read $infilefd]
|
||||||
|
close $infilefd
|
||||||
|
} message]
|
||||||
|
|
||||||
|
if { $status != 0 } {
|
||||||
|
error "Unable to read file $infile: $message"
|
||||||
|
}
|
||||||
|
|
||||||
|
set result ""
|
||||||
|
|
||||||
|
set status [ catch {
|
||||||
|
set outfilefd [ open $outfile "w" ]
|
||||||
|
} message ]
|
||||||
|
|
||||||
|
if { $status != 0 } {
|
||||||
|
error "Unable to create file $outfile: $message"
|
||||||
|
}
|
||||||
|
|
||||||
|
append result "/* This is a generated file. Do not edit. */\n\n"
|
||||||
|
append result "const unsigned char filedata_$label\[\] = {\n"
|
||||||
|
|
||||||
|
set datalength [ string length $data ]
|
||||||
|
|
||||||
|
set aligned_datalength [expr $datalength - ($datalength % 8)]
|
||||||
|
|
||||||
|
for { set i 0 } {$i < $aligned_datalength} {incr i 8} {
|
||||||
|
binary scan $data "@[set i]H16" var0
|
||||||
|
append result [format " 0x%2s, 0x%2s, 0x%2s, 0x%2s, 0x%2s, 0x%2s, 0x%2s, 0x%2s,\n" \
|
||||||
|
[string range $var0 0 1] \
|
||||||
|
[string range $var0 2 3] \
|
||||||
|
[string range $var0 4 5] \
|
||||||
|
[string range $var0 6 7] \
|
||||||
|
[string range $var0 8 9] \
|
||||||
|
[string range $var0 10 11] \
|
||||||
|
[string range $var0 12 13] \
|
||||||
|
[string range $var0 14 15]]
|
||||||
|
}
|
||||||
|
|
||||||
|
if { $aligned_datalength != $datalength } {
|
||||||
|
append result " "
|
||||||
|
for { set i $aligned_datalength } {$i < $datalength} {incr i} {
|
||||||
|
binary scan $data "@[set i]H2" var0
|
||||||
|
append result [format "0x%2s, " $var0]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Remove either comma+newline or comma+space from the end
|
||||||
|
set result [string range $result 0 [expr [string length $result] - 3]]
|
||||||
|
|
||||||
|
append result "\n};"
|
||||||
|
|
||||||
|
puts $outfilefd $result
|
||||||
|
close $outfilefd
|
|
@ -742,12 +742,15 @@ void initJim(void)
|
||||||
interp->cb_fgets = openocd_jim_fgets;
|
interp->cb_fgets = openocd_jim_fgets;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern const unsigned char filedata_startup[];
|
||||||
|
|
||||||
/* after command line parsing */
|
/* after command line parsing */
|
||||||
void initJim2(void)
|
void initJim2(void)
|
||||||
{
|
{
|
||||||
if (Jim_Eval(interp, "source [find tcl/commands.tcl]")==JIM_ERR)
|
if (Jim_Eval(interp, filedata_startup)==JIM_ERR)
|
||||||
{
|
{
|
||||||
LOG_ERROR("Can not find tcl/commands.tcl - check installation");
|
LOG_ERROR("Failed to run startup.tcl (embedded into OpenOCD compile time)");
|
||||||
|
Jim_PrintErrorMessage(interp);
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,9 @@
|
||||||
|
#
|
||||||
|
# Defines basic Tcl procs that must be there for
|
||||||
|
# OpenOCD to work.
|
||||||
|
#
|
||||||
|
# Embedded into OpenOCD executable
|
||||||
|
#
|
||||||
|
|
||||||
# Production command
|
# Production command
|
||||||
# FIX!!! need to figure out how to feed back relevant output
|
# FIX!!! need to figure out how to feed back relevant output
|
Loading…
Reference in New Issue