stlink: add hardware srst functions to stlink/v2
[openocd/libswd.git] / testing / smoketests.html
blob7d5efc1cb3ae19af20890633c43b069c3f927b4d
1 <html>
3 <meta http-equiv="content-type" content="text/html;charset=iso-8859-1">
5 <body>
6 <h1>OpenOCD smoketest results</h1>
7 These tests can be performed on any JTAG device as long as they are
8 executed using the unmodified code from git.
9 <p>The latest version in which the test is known to have passed is in the table below.</p>
10 <h2>Vocabulary</h2>
11 <table border="1">
12 <tr>
13 <td width="100">Passed version</td>
14 <td>The latest branch and version on which the test is known to pass</td>
15 </tr>
16 <tr>
17 <td width="100">Broken version</td>
18 <td>The latest branch and version on which the test is known to fail. n/a when older than passed version.</td>
19 </tr>
20 <tr>
21 <td width="100">ID</td>
22 <td>A unqiue ID to refer to a test. The unique numbers are maintained in this file. Note that the same test can be run on different hardware/interface. Each combination yields a unique id. </td>
23 </tr>
24 </table>
25 <p></p>
26 <table border="1">
27 <tr>
28 <th width="100">Unique ID</th>
29 <th width="165">Synopsis</th>
30 <th align="center" width="110">JTAG device</th>
31 <th align="center" width="110">Passed version</th>
32 <th align="center" width="110">Broken version</th>
33 </tr>
34 <tr>
35 <td >fill_malloc</td>
36 <td width="165">Fill malloc() memory with garbage</td>
37 <td align="center" >n/a</td>
38 <td align="center" >n/a</td>
39 <td align="center" >n/a</td>
40 </tr>
41 <tr>
42 <td >ocd1</td>
43 <td width="165">Telnet Windows</td>
44 <td align="center" >n/a</td>
45 <td align="center" >n/a</td>
46 <td align="center" >n/a</td>
47 </tr>
48 <tr>
49 <td >ocd2</td>
50 <td width="165">Telnet Linux</td>
51 <td align="center" >n/a</td>
52 <td align="center" >n/a</td>
53 <td align="center" >n/a</td>
54 </tr>
55 <tr>
56 <td >ocd3</td>
57 <td width="165">Telnet Cygwin</td>
58 <td align="center" >n/a</td>
59 <td align="center" >n/a</td>
60 <td align="center" >n/a</td>
61 </tr>
62 <tr>
63 <td ><a href="#test_ocd4">ocd4</a></td>
64 <td width="165">ARM7 debugging</td>
65 <td align="center" >n/a</td>
66 <td align="center" >n/a</td>
67 <td align="center" >n/a</td>
68 </tr>
69 <tr>
70 <td >SAM9260</td>
71 <td width="165">SAM9260 debugging</td>
72 <td align="center">ft2232 </td>
73 <td align="center">500</td>
74 <td align="center">n/a</td>
75 </tr>
76 <tr>
77 <td >xscale1</td>
78 <td width="165">XScale debugging</td>
79 <td align="center" >bitbang</td>
80 <td align="center" >505</td>
81 <td align="center" >n/a</td>
82 </tr>
83 <tr>
84 <td >xscale2</td>
85 <td width="165">XScale debugging</td>
86 <td align="center" >FT2232</td>
87 <td align="center" >202</td>
88 <td align="center" >n/a</td>
89 </tr>
90 <tr>
91 <td ><a href="#bdte-ram">bdte-ram1</a></td>
92 <td width="165">str710 ram debugging</td>
93 <td align="center" >JTAGkey</td>
94 <td align="center" >657</td>
95 <td align="center" >n/a</td>
96 </tr>
97 <tr>
98 <td ><a href="#bdte-rom">bdte-rom2</a></td>
99 <td width="165">str710 rom debugging</td>
100 <td align="center" >JTAGkey</td>
101 <td align="center" >657</td>
102 <td align="center" >n/a</td>
103 </tr>
104 <tr>
105 <td ><a href="#bdte-ram">bdte-ram3</a></td>
106 <td width="165">str912 ram debugging</td>
107 <td align="center" >JTAGkey</td>
108 <td align="center" >657</td>
109 <td align="center" >n/a</td>
110 </tr>
111 <tr>
112 <td ><a href="#bdte-rom">bdte-rom4</a></td>
113 <td width="165">str912 rom debugging</td>
114 <td align="center" >JTAGkey</td>
115 <td align="center" >657</td>
116 <td align="center" >n/a</td>
117 </tr>
118 <tr>
119 <td ><a href="#bdte-ram">bdte-ram5</a></td>
120 <td width="165">lpc2148 ram debugging</td>
121 <td align="center" >JTAGkey</td>
122 <td align="center" >657</td>
123 <td align="center" >n/a</td>
124 </tr>
125 <tr>
126 <td ><a href="#bdte-rom">bdte-rom6</a></td>
127 <td width="165">lpc2148 rom debugging</td>
128 <td align="center" >JTAGkey</td>
129 <td align="center" >657</td>
130 <td align="center" >n/a</td>
131 </tr>
132 <tr>
133 <td ><a href="#bdte-ram">bdte-ram7</a></td>
134 <td width="165">lpc2294 ram debugging</td>
135 <td align="center" >JTAGkey</td>
136 <td align="center" >657</td>
137 <td align="center" >n/a</td>
138 </tr>
139 <tr>
140 <td ><a href="#bdte-rom">bdte-rom8</a></td>
141 <td width="165">lpc2294 rom debugging</td>
142 <td align="center" >JTAGkey</td>
143 <td align="center" >657</td>
144 <td align="center" >n/a</td>
145 </tr>
146 <tr>
147 <td ><a href="#bdte-ram">bdte-ram9</a></td>
148 <td width="165">sam7s256 ram debugging</td>
149 <td align="center" >JTAGkey</td>
150 <td align="center" >657</td>
151 <td align="center" >n/a</td>
152 </tr>
153 <tr>
154 <td ><a href="#bdte-rom">bdte-rom10</a></td>
155 <td width="165">sam7s256 rom debugging</td>
156 <td align="center" >JTAGkey</td>
157 <td align="center" >657</td>
158 <td align="center" >n/a</td>
159 </tr>
160 <tr>
161 <td ><a href="#bdte-ram">bdte-ram11</a></td>
162 <td width="165">sam7x256 ram debugging</td>
163 <td align="center" >JTAGkey</td>
164 <td align="center" >657</td>
165 <td align="center" >n/a</td>
166 </tr>
167 <tr>
168 <td ><a href="#bdte-rom">bdte-rom12</a></td>
169 <td width="165">sam7x256 rom debugging</td>
170 <td align="center" >JTAGkey</td>
171 <td align="center" >657</td>
172 <td align="center" >n/a</td>
173 </tr>
174 <tr>
175 <td ><a href="#bdte-ram">bdte-ram13</a></td>
176 <td width="165">at91r40008 ram debugging</td>
177 <td align="center" >JTAGkey</td>
178 <td align="center" >657</td>
179 <td align="center" >n/a</td>
180 </tr>
181 </table>
182 <p></p>
183 <hr>
184 <h1>OpenOCD JTAG device test results</h1>
185 Each JTAG device must be tested
187 <table border="1">
188 <tr>
189 <th align="center" width="40">ID</th>
190 <th width="90">Synopsis</th>
191 <th >Passed version</th>
192 <th >Broken version</th>
193 </tr>
194 <tr>
195 <td width="40">jtag1</td>
196 <td width="90">Parport</td>
197 <td align="center" >n/a</td>
198 <td align="center" >n/a</td>
199 </tr>
200 <tr>
201 <td width="40">jtag2</td>
202 <td width="90">JTAGkey</td>
203 <td align="center" >657</td>
204 <td align="center" >n/a</td>
205 </tr>
206 <tr>
207 <td width="40">jtag3</td>
208 <td width="90">Turtelizer2</td>
209 <td align="center" >657</td>
210 <td align="center" >n/a</td>
211 </tr>
212 <tr>
213 <td width="40">jtag4</td>
214 <td width="90">JTAGkey</td>
215 <td align="center" >657</td>
216 <td align="center" >n/a</td>
217 </tr>
218 <tr>
219 <td width="40">jtag5</td>
220 <td width="90">add new one</td>
221 <td align="center" >n/a</td>
222 <td align="center" >n/a</td>
223 </tr>
224 </table>
225 <p>jtag1:</p>
226 <p>jtag2: Tested on Windows XP Prof. (SP2) with original FTDI&nbsp;driver.</p>
227 <p>jtag3: Tested on Windows XP Prof. (SP2) with original FTDI&nbsp;driver.</p>
228 <p>jtag4: Tested on Mac OS X (10.5.2, Intel) with libftdi-0.10 and libusb-0.1.12</p>
229 <p>jtag5:</p>
230 <hr>
231 <h1>OpenOCD JTAG device speed test result</h1>
232 <p>The test result is in KB/sec.</p>
233 <table border="1">
234 <tr>
235 <th align="center" width="50">ID</th>
236 <th width="90">Synopsis</th>
237 <th width="40">r320</th>
238 <th width="40">r420</th>
239 <th width="40">r423</th>
240 <th width="40">r459</th>
241 <th width="40">r517</th>
242 <th width="40">r536</th>
243 <th width="40">r651</th>
244 <th width="40">r657</th>
245 </tr>
246 <tr>
247 <td width="50"><a href="#speed1">speed1</a></td>
248 <td width="90">JTAGkey</td>
249 <td align="center" width="40">93</td>
250 <td align="center" width="40">64 </td>
251 <td align="center" width="40">93</td>
252 <td align="center" width="40">93</td>
253 <td align="center" width="40">93</td>
254 <td align="center" width="40">93</td>
255 <td align="center" width="40">162</td>
256 <td align="center" width="40">165</td>
257 </tr>
258 <tr>
259 <td width="50"><a href="#speed2">speed2</a></td>
260 <td width="90">JTAGkey</td>
261 <td align="center" width="40">n/a</td>
262 <td align="center" width="40">n/a</td>
263 <td align="center" width="40">n/a</td>
264 <td align="center" width="40">n/a</td>
265 <td align="center" width="40">52</td>
266 <td align="center" width="40">52</td>
267 <td align="center" width="40">110</td>
268 <td align="center" width="40">111</td>
269 </tr>
270 <tr>
271 <td width="50">speed3</td>
272 <td width="90">add new one</td>
273 <td align="center" width="40">n/a</td>
274 <td align="center" width="40">n/a</td>
275 <td align="center" width="40">n/a</td>
276 <td align="center" width="40">n/a</td>
277 <td align="center" width="40">n/a</td>
278 <td align="center" width="40">n/a</td>
279 <td align="center" width="40">n/a</td>
280 <td align="center" width="40">n/a</td>
281 </tr>
282 </table>
283 <p></p>
284 <hr>
285 <h1>Policy on removing features from OpenOCD</h1>
286 If a feature in OpenOCD is known to be broken and nobody has submitted
287 a fix and the feature is causing trouble for maintainence, it can be
288 removed from OpenOCD mainline. The threshold for temporarily removing
289 something from OpenOCD mainline is low to ease maintainence and place the burden of maintainence on those that care about a feature.
290 <p>Note that code is never deleted from OpenOCD git, it remains in the
291 repository so if somebody sees a feature removed that they would like
292 kept, they have but to port and fix that feature back up to main
293 mainline. This document can be helpful in this regard in that the latest working version and the known broken version may be listed.</p>
294 <h1>Policy on adding features from OpenOCD</h1>
295 To add a feature to OpenOCD, generally it should not break any
296 existing features and it should be functional and the code reasonably
297 readable and useful to others in the OpenOCD community. The code does
298 not have to be completed. Work in progress is fine for OpenOCD
299 mainline.
300 <p>Also new tests should be defined. Note that the code does not have to pass all the tests. In fact it can be helpful to have tests to describe facets that really should be working, but aren't done yet. </p>
301 <hr>
302 <h1>ocd4 - ARM7 debugging<a name="test_ocd4"></a></h1>
303 Connect to ARM7 device(any), use GDB load to load a program into RAM and single halt, resume and single step.
304 <hr>
305 <h1>bdte-ram (Basic debugging test with Eclipse in RAM)<a id="bdte-ram" name="bdte-ram"></a></h1>
306 <p>This test was made under Eclipse with the Zylin Embedded CDT&nbsp;plugin. For the GDB &quot;Initialize commands&quot; take a look in the examples/&lt;target&gt;/prj/<b>eclipse_ram.gdb</b> file.</p>
307 <p>Start debugging, the debugger should stop at main. set some breakpoints and &quot;Resume&quot;. If the debugger hit a breakpoint check if the &quot;Variables&quot; looks correct. Remove some breakpoints and &quot;Resume&quot; again. If the target is running, use the &quot;Suspend&quot; function and use &quot;Step Into&quot; or &quot;Step Over&quot; through the source. Even open the &quot;Disassembly&quot; view and enable the &quot;Instruction Stepping Mode&quot;. Now you can single step through the assembler source. Use &quot;Resume&quot; again to run the program, set a breakpoint while the target is running. Check if you can inspect the variables with the mouse over. Play a little with the target...</p>
308 <hr>
309 <h1>bdte-rom (Basic debugging test with Eclipse in ROM)<a id="bdte-rom" name="bdte-rom"></a></h1>
310 <p>This test was made under Eclipse with the Zylin Embedded CDT&nbsp;plugin. For the GDB &quot;Initialize commands&quot; take a look in the examples/&lt;target&gt;/prj/<b>eclipse_rom.gdb</b> file.</p>
311 <p>Start debugging, the debugger should download and store the program in the flash of the target.</p>
312 <p>Now you can make some tests like described in the <a href="#bdte-ram">bdte-ram</a> section above too.</p>
313 <hr>
314 <h1>speed1 - Download speed test<a id="speed1" name="speed1"></a></h1>
315 <p>For this test a STR710 with external memory was used. The example project can be found under examples/STR710JtagSpeed. Here Eclipse or the arm-elf-gdb can be used to download the test.elf file into the RAM. The result of the GDB&nbsp;can look like:</p>
316 <p>Loading section .text, size 0x6019c lma 0x62000000<br>
317 Start address 0x62000040, load size 393628<br>
318 Transfer rate: 93 KB/sec, 2008 bytes/write.</p>
319 <p>In this example a speed of 93 KB/sec was reached. The hardware which was used for the test can be found <a href="http://www.yagarto.de/projects/str7usbmsd/index.html" target="new">here</a>.</p>
320 <p>The test was made on Windows XP Prof. (SP2) with a JTAGkey and the original FTDI driver.</p>
321 <hr>
322 <h1>speed2 - Download speed test<a id="speed2" name="speed2"></a></h1>
323 <p>For this test a STR710 with external memory was used. The example project can be found under examples/STR710JtagSpeed. Here Eclipse or the arm-elf-gdb can be used to download the test.elf file into the RAM. The result of the GDB&nbsp;can look like:</p>
324 <p>Loading section .text, size 0x6019c lma 0x62000000<br>
325 Start address 0x62000040, load size 393628<br>Transfer rate: 52 KB/sec, 2008 bytes/write.</p>
326 <p>In this example a speed of 52 KB/sec was reached. The hardware which was used for the test can be found <a href="http://www.yagarto.de/projects/str7usbmsd/index.html" target="new">here</a>.</p>
327 <p>The test was made on Mac OS X (10.5.2, Intel) with a JTAGkey and the following driver:</p>
328 <p>- libftdi 0.10<br>
329 - libusb 0.1.12</p>
330 <p></p>
331 <p></p>
332 </body>
334 </html>