From 5ec6a48a4b8c1d5b3ec0eea61d3ea30a1e1d5469 Mon Sep 17 00:00:00 2001
From: oharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60>
Date: Mon, 6 Oct 2008 12:14:52 +0000
Subject: [PATCH] basic smoketest on lm3s3748.elf

git-svn-id: svn://svn.berlios.de/openocd/trunk@1020 b42882b7-edfa-0310-969c-e2dbd0fdcd60
---
 src/target/target/zy1000.cfg         |  25 ++-
 testing/examples/cortex/lm3s3748.elf | Bin 0 -> 10122 bytes
 testing/examples/cortex/test.c       |  27 ++++
 testing/examples/cortex/test.ld      | 220 +++++++++++++++++++++++++++
 4 files changed, 271 insertions(+), 1 deletion(-)
 create mode 100644 testing/examples/cortex/lm3s3748.elf
 create mode 100644 testing/examples/cortex/test.c
 create mode 100644 testing/examples/cortex/test.ld

diff --git a/src/target/target/zy1000.cfg b/src/target/target/zy1000.cfg
index 7a1b8b98a..d54925a58 100644
--- a/src/target/target/zy1000.cfg
+++ b/src/target/target/zy1000.cfg
@@ -21,7 +21,30 @@ arm7_9 fast_memory_access enable
 arm7_9 dcc_downloads enable
 
 flash bank ecosflash 0x01000000 0x200000 2 2 0 ecos/at91eb40a.elf
-[new_target_name] configure -event old-post_reset { script event/zy1000_reset.script }
+[new_target_name] configure -event reset-init { 
+
+# Set up chip selects & timings
+mww 0xFFE00000 0x0100273D
+mww 0xFFE00004 0x08002125
+mww 0xFFEe0008 0x02002125
+mww 0xFFE0000c 0x03002125
+mww 0xFFE00010 0x40000000
+mww 0xFFE00014 0x50000000
+mww 0xFFE00018 0x60000000
+mww 0xFFE0001c 0x70000000
+mww 0xFFE00020 0x00000001
+mww 0xFFE00024 0x00000000
+
+# remap  
+mww 0xFFFFF124 0xFFFFFFFF  
+mww 0xffff0010 0x100
+mww 0xffff0034 0x100
+
+#disable 16x5x UART interrupts
+mww 0x08020004 0
+
+
+}
 
 # required for usable performance. Used for lots of
 # other things than flash programming.
diff --git a/testing/examples/cortex/lm3s3748.elf b/testing/examples/cortex/lm3s3748.elf
new file mode 100644
index 0000000000000000000000000000000000000000..a3b90dca22463d65cf5ac95d112d9cb044e3a672
GIT binary patch
literal 10122
zcmb<-^>JflWK3j$0wx9x21W)321W%21rr7ah7U>%3`|T63?>W;42%pK3<3<iV0ox=
z1qKEN1seqh1_wn326m8O1Be*KqaiRF0;3@?8UmvsFd71*Aut*OqaiRF0;3@?8Umvs
zFd71*Aut*OqaiRF0;3@?8UmvsFd71*Aut*OqaiRF0;3@?8UmvsFd72%41tC%jT;!&
z`+s0ywoc%Dz~wES!TgbtiNjke!5YM3wob6haQO7xc$U+LyX+rX*!Q|M>?v?R;AW%9
zpuphn>};i=;qDizsbHdKtY^d^!@$761a>|Pm}F33P_Tipz@$7}K8b;WL6w1lA-=dI
zv8aS0kb!|A3#=p#u7m}&4uOG@hk=1X3M2(GOMwBj;(&pPQ5dvFK@@C0RLqNkfq^-b
zfl&;^V47ILz{0|snODNVn#I5<3=(5xWd^&NQIJuUPnesTPnu7VQHW81je&tlkI|lo
zna_&bnj0kKzy>m(*@S_a10>`r%*4gOz@oyy&27ic%)!9GijcAA0m(6#fn6;NA{l@4
z@iH(nGJ;&s$iTqJP?B0)qL&Qv0Rsao6UfQTB8+xEDN~p@7{IDPKK%dx|9?gX#u`2z
zUIqz>S_Y6(Q0O`Fu{iN@v@<&KvNO2*g(^5hLmO%^Gzj&RE7MboGRso+ll9B<i?WLg
z5|dN)^9xe*@{?2aL25Je()Cj-5_1c3Qj7JI^NUJSE5J5^VvLa?7DR!fjftU_1w^xf
ze8W)70ir?9U}7le0IO$UU~uGTU|>j0O-#yUU}Oae>J?Y!mLw)I=oOa~LFfz^t0c9e
zgh4N<xR^mNIX^cyHLrw0FC{gpG(A4CC^0WRwHU@NC{4;s%ti1s^V0HRa*0VvMX6;l
zUQT9SDvX_0l$Z<W6qgji#B=hK8T1^3eDxAbN{TX*N=s6UK@KGnOM}uE0|Nud^PqSD
zr8`g{z_fz`2*g%oU|;}+3Nr%(11NQY*22K#K=LrQ8q_?H7zl&Z34s_;3`#8^raqcF
zKLt=S0LefwOr0H?x;zC224#p6FbPxVho)|#0s{jm?|~H|$weWtL2{oJ7#Ko83@C<~
zmw~3vU6Fyo3aSP~!PJ$YscTVWV9)_6fMQs<G(y!GK*cvGGB5-{*&qsJ9tih9)q%vo
zSc!qb9L#_aAT=P?bWkb4z)%2UgRr?01A_pF0mU$Nf)I63Q3eKgB?gA&a2_bzLO3Ax
zpo{_GF)$RUGB9jlWMBZLe~`H#e}HICH1ibHVFemQC&(NK3kwM?!I+^dt3c@pq>33@
zmV($I%*+5vWgr#=Gc$l}hp<5;GXpp)f|y{;3`xCUHi%$`tk426!I&AGa=}b6!OQ^i
z1(*pYm>IahG>l+o;D#~5G&2Ja)Wu*f0}I2)|De18&M#mgMz9VGsQ*Br$_LFSAeRd=
zFoEO70aTYTfa2-ne^9=&fvOi^`1oH5svcw<h!099$m&6P60}wgL<=!6GB~5D_h$gF
zO#{~&ApPNJ@}TMl**tJL?EuQ{AouVvz)EkG5(bqNhAf8oq~hZE)V!4Vc!u~?aLE=A
j76MmeAVDw>ssJp=fTVyS9<Dbfu_TcJ!~<7>$=M75pTFqC

literal 0
HcmV?d00001

diff --git a/testing/examples/cortex/test.c b/testing/examples/cortex/test.c
new file mode 100644
index 000000000..7e0c303fa
--- /dev/null
+++ b/testing/examples/cortex/test.c
@@ -0,0 +1,27 @@
+/* simple app. 
+
+modify test.ld to change address.
+
+Even if the app is position independent, the symbols
+need to match to test basic debugging.
+
+To load the app to 0x20000000 in GDB, use:
+
+load a.out
+monitor reg sp 0x20004000
+monitor reg pc 0x20002000
+stepi
+
+arm-elf-gcc -mthumb -mcpu=cortex-m3 -nostdlib -Ttest.ld test.c
+
+
+*/
+int j;
+void _start()
+{
+  int i;
+  for (i=0; i<1000; i++)
+    {
+      j++;
+    }
+}
diff --git a/testing/examples/cortex/test.ld b/testing/examples/cortex/test.ld
new file mode 100644
index 000000000..03b804e1d
--- /dev/null
+++ b/testing/examples/cortex/test.ld
@@ -0,0 +1,220 @@
+OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm",
+	      "elf32-littlearm")
+OUTPUT_ARCH(arm)
+ENTRY(_start)
+/* Do we need any of these for elf?
+   __DYNAMIC = 0;    */
+SECTIONS
+{
+  /* Read-only sections, merged into text segment: */
+  . = 0x20002000;
+  .interp     : { *(.interp) 	}
+  .hash          : { *(.hash)		}
+  .dynsym        : { *(.dynsym)		}
+  .dynstr        : { *(.dynstr)		}
+  .gnu.version   : { *(.gnu.version)	}
+  .gnu.version_d   : { *(.gnu.version_d)	}
+  .gnu.version_r   : { *(.gnu.version_r)	}
+  .rel.init      : { *(.rel.init)	}
+  .rela.init     : { *(.rela.init)	}
+  .rel.text      :
+    {
+      *(.rel.text)
+      *(.rel.text.*)
+      *(.rel.gnu.linkonce.t*)
+    }
+  .rela.text     :
+    {
+      *(.rela.text)
+      *(.rela.text.*)
+      *(.rela.gnu.linkonce.t*)
+    }
+  .rel.fini      : { *(.rel.fini)	}
+  .rela.fini     : { *(.rela.fini)	}
+  .rel.rodata    :
+    {
+      *(.rel.rodata)
+      *(.rel.rodata.*)
+      *(.rel.gnu.linkonce.r*)
+    }
+  .rela.rodata   :
+    {
+      *(.rela.rodata)
+      *(.rela.rodata.*)
+      *(.rela.gnu.linkonce.r*)
+    }
+  .rel.data      :
+    {
+      *(.rel.data)
+      *(.rel.data.*)
+      *(.rel.gnu.linkonce.d*)
+    }
+  .rela.data     :
+    {
+      *(.rela.data)
+      *(.rela.data.*)
+      *(.rela.gnu.linkonce.d*)
+    }
+  .rel.ctors     : { *(.rel.ctors)	}
+  .rela.ctors    : { *(.rela.ctors)	}
+  .rel.dtors     : { *(.rel.dtors)	}
+  .rela.dtors    : { *(.rela.dtors)	}
+  .rel.got       : { *(.rel.got)		}
+  .rela.got      : { *(.rela.got)		}
+  .rel.sdata     :
+    {
+      *(.rel.sdata)
+      *(.rel.sdata.*)
+      *(.rel.gnu.linkonce.s*)
+    }
+  .rela.sdata     :
+    {
+      *(.rela.sdata)
+      *(.rela.sdata.*)
+      *(.rela.gnu.linkonce.s*)
+    }
+  .rel.sbss      : { *(.rel.sbss)		}
+  .rela.sbss     : { *(.rela.sbss)	}
+  .rel.bss       : { *(.rel.bss)		}
+  .rela.bss      : { *(.rela.bss)		}
+  .rel.plt       : { *(.rel.plt)		}
+  .rela.plt      : { *(.rela.plt)		}
+  .plt      : { *(.plt)	}
+  .text      :
+  {
+    *(.text)
+    *(.text.*)
+    *(.stub)
+    /* .gnu.warning sections are handled specially by elf32.em.  */
+    *(.gnu.warning)
+    *(.gnu.linkonce.t*)
+    *(.glue_7t) *(.glue_7)
+  } =0
+  .init          : 
+  { 
+    KEEP (*(.init))
+  } =0
+  _etext = .;
+  PROVIDE (etext = .);
+  .fini      :
+  {
+    KEEP (*(.fini))
+  } =0
+  .rodata   : { *(.rodata) *(.rodata.*) *(.gnu.linkonce.r*) }
+  .rodata1   : { *(.rodata1) }
+  .eh_frame_hdr : { *(.eh_frame_hdr) }
+  /* Adjust the address for the data segment.  We want to adjust up to
+     the same address within the page on the next page up.  */
+  . = ALIGN(256) + (. & (256 - 1));
+  .data    :
+  {
+    *(.data)
+    *(.data.*)
+    *(.gnu.linkonce.d*)
+    SORT(CONSTRUCTORS)
+  }
+  .data1   : { *(.data1) }
+  .eh_frame : { KEEP (*(.eh_frame)) }
+  .gcc_except_table : { *(.gcc_except_table) }
+  .ctors   : 
+  {
+    /* gcc uses crtbegin.o to find the start of
+       the constructors, so we make sure it is
+       first.  Because this is a wildcard, it
+       doesn't matter if the user does not
+       actually link against crtbegin.o; the
+       linker won't look for a file to match a
+       wildcard.  The wildcard also means that it
+       doesn't matter which directory crtbegin.o
+       is in.  */
+    KEEP (*crtbegin.o(.ctors))
+    /* We don't want to include the .ctor section from
+       from the crtend.o file until after the sorted ctors.
+       The .ctor section from the crtend file contains the
+       end of ctors marker and it must be last */
+    KEEP (*(EXCLUDE_FILE (*crtend.o ) .ctors))
+    KEEP (*(SORT(.ctors.*)))
+    KEEP (*(.ctors))
+  }
+   .dtors         :
+  {
+    KEEP (*crtbegin.o(.dtors))
+    KEEP (*(EXCLUDE_FILE (*crtend.o ) .dtors))
+    KEEP (*(SORT(.dtors.*)))
+    KEEP (*(.dtors))
+  }
+  .jcr            : { KEEP (*(.jcr)) }
+  .got           : { *(.got.plt) *(.got) }
+  .dynamic       : { *(.dynamic) }
+  /* We want the small data sections together, so single-instruction offsets
+     can access them all, and initialized data all before uninitialized, so
+     we can shorten the on-disk segment size.  */
+  .sdata     : 
+  {
+    *(.sdata) 
+    *(.sdata.*)
+    *(.gnu.linkonce.s.*)
+  }
+  _edata = .;
+  PROVIDE (edata = .);
+  __bss_start = .;
+  __bss_start__ = .;
+  .sbss      :
+  {
+    *(.dynsbss)
+    *(.sbss)
+    *(.sbss.*)
+    *(.scommon)
+  }
+  .bss       :
+  {
+   *(.dynbss)
+   *(.bss)
+   *(.bss.*)
+   *(COMMON)
+   /* Align here to ensure that the .bss section occupies space up to
+      _end.  Align after .bss to ensure correct alignment even if the
+      .bss section disappears because there are no input sections.  */
+   . = ALIGN(32 / 8);
+  }
+  . = ALIGN(32 / 8);
+  _end = .;
+  _bss_end__ = . ; __bss_end__ = . ; __end__ = . ;
+  PROVIDE (end = .);
+  /* Stabs debugging sections.  */
+  .stab 0 : { *(.stab) }
+  .stabstr 0 : { *(.stabstr) }
+  .stab.excl 0 : { *(.stab.excl) }
+  .stab.exclstr 0 : { *(.stab.exclstr) }
+  .stab.index 0 : { *(.stab.index) }
+  .stab.indexstr 0 : { *(.stab.indexstr) }
+  .comment 0 : { *(.comment) }
+  /* DWARF debug sections.
+     Symbols in the DWARF debugging sections are relative to the beginning
+     of the section so we begin them at 0.  */
+  /* DWARF 1 */
+  .debug          0 : { *(.debug) }
+  .line           0 : { *(.line) }
+  /* GNU DWARF 1 extensions */
+  .debug_srcinfo  0 : { *(.debug_srcinfo) }
+  .debug_sfnames  0 : { *(.debug_sfnames) }
+  /* DWARF 1.1 and DWARF 2 */
+  .debug_aranges  0 : { *(.debug_aranges) }
+  .debug_pubnames 0 : { *(.debug_pubnames) }
+  /* DWARF 2 */
+  .debug_info     0 : { *(.debug_info) }
+  .debug_abbrev   0 : { *(.debug_abbrev) }
+  .debug_line     0 : { *(.debug_line) }
+  .debug_frame    0 : { *(.debug_frame) }
+  .debug_str      0 : { *(.debug_str) }
+  .debug_loc      0 : { *(.debug_loc) }
+  .debug_macinfo  0 : { *(.debug_macinfo) }
+  .debug_ranges   0 : { *(.debug_ranges) }
+  /* SGI/MIPS DWARF 2 extensions */
+  .debug_weaknames 0 : { *(.debug_weaknames) }
+  .debug_funcnames 0 : { *(.debug_funcnames) }
+  .debug_typenames 0 : { *(.debug_typenames) }
+  .debug_varnames  0 : { *(.debug_varnames) }
+  .stack 0x20004000 : { _stack = .; *(.stack) }
+  /* These must appear regardless of  .  */
+}
-- 
GitLab