summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--swim/flash_prog/README39
-rw-r--r--swim/flash_prog/sample1.srbin0 -> 27931 bytes
-rw-r--r--swim/tests/README75
-rw-r--r--swim/tests/sample1.srbin0 -> 4469 bytes
-rw-r--r--swim/tests/sample2.srbin0 -> 4590 bytes
-rw-r--r--swim/tests/sample3.srbin0 -> 4666 bytes
-rw-r--r--swim/tests/sample4.srbin0 -> 4240 bytes
7 files changed, 114 insertions, 0 deletions
diff --git a/swim/flash_prog/README b/swim/flash_prog/README
new file mode 100644
index 0000000..547d83c
--- /dev/null
+++ b/swim/flash_prog/README
@@ -0,0 +1,39 @@
+-------------------------------------------------------------------------------
+SWIM
+-------------------------------------------------------------------------------
+
+This is a capture of an ST-Link V2 programming an STM8 using the SWIM protocol.
+
+Details:
+https://www.st.com/content/ccc/resource/technical/document/user_manual/ca/89/41/4e/72/31/49/f4/CD00173911.pdf/files/CD00173911.pdf/jcr:content/translations/en.CD00173911.pdf
+
+
+Logic analyzer setup
+--------------------
+
+The logic analyser used was a DreamSourceLab DSLogic (at 10MHz).
+
+ Probe Target
+ ------------------
+ 0 RST
+ 1 SWIM
+
+
+sample1.sr
+----------
+
+Using stm8flash with an ST-Link V2 adapter to program an STM8S003F3.
+
+Command line:
+
+ $ stm8flash -c stlinkv2 -p stm8s003f3 -s flash -w prog.ihx
+
+stm8flash is modified both for correctness and to generate the test sequences.
+The updated version can be found at https://github.com/mjagdis/stm8flash.
+
+A complete flash programming operation. SWIM is enabled and set to high
+speed mode (notice how the pulse width and period decreases after the
+initial chatter). A read of the affected memory region is made, compared to
+the data to be written and those blocks that contain differences are written
+back. Finally an SRST SWIM command is sent to terminate the conversation
+and reset the target.
diff --git a/swim/flash_prog/sample1.sr b/swim/flash_prog/sample1.sr
new file mode 100644
index 0000000..05e6da7
--- /dev/null
+++ b/swim/flash_prog/sample1.sr
Binary files differ
diff --git a/swim/tests/README b/swim/tests/README
new file mode 100644
index 0000000..298fdad
--- /dev/null
+++ b/swim/tests/README
@@ -0,0 +1,75 @@
+-------------------------------------------------------------------------------
+SWIM
+-------------------------------------------------------------------------------
+
+These are captures of an ST-Link V2 programming an STM8 using the SWIM protocol.
+
+Details:
+https://www.st.com/content/ccc/resource/technical/document/user_manual/ca/89/41/4e/72/31/49/f4/CD00173911.pdf/files/CD00173911.pdf/jcr:content/translations/en.CD00173911.pdf
+
+
+Logic analyzer setup
+--------------------
+
+The logic analyser used was a DreamSourceLab DSLogic (at 10MHz).
+
+ Probe Target
+ ------------------
+ 0 RST
+ 1 SWIM
+
+
+Data
+----
+
+Using stm8flash with an ST-Link V2 adapter to program an STM8S003F3.
+
+Command line:
+
+ $ stm8flash -c stlinkv2 -p stm8s003f3 -s opt -r /tmp/data; stm8flash -c \
+ stlinkv2 -p stm8s003f3 -s opt -r /tmp/data
+
+ stm8flash is modified both for correctness and to generate the test sequences.
+ The updated version can be found at https://github.com/mjagdis/stm8flash.
+
+
+tests/sample1.sr
+----------------
+
+Read of two blocks of memory from an STM8S103 starting at the base address
+of the OPTs. Repeated twice with no SRST to disable SWIM in between.
+Note that the second enter sequence is not seen as an enter sequence. Since
+SWIM is already active on the target it does NOT recognise a second enter
+sequence and instead sees each low sent by the host as a SWIM reset request
+to which it responds, if you zoom in enough, with its own 16μs sync frame.
+
+
+tests/sample2.sr
+----------------
+
+As sample1 but each of the runs ends with an SWIM reset followed by an SRST
+(system reset) SWIM command. Note that the SWIM reset consists of the host
+pulling the SWIM line low for 16μs to reset the target's SWIM module followed
+by the target acknowledging with its own synchronization frame (i.e. it pulls
+the line low for another 16μs). Note too that the RST bit is not set in
+SWIM_CSR so the SRST does not disable SWIM and the second enter sequence is
+treated as resyncing just as in sample1.
+
+
+tests/sample3.sr
+----------------
+
+As sample2 but now we modify stm8flash to set RST (bit 2) in SWIM_CSR (0x7f80)
+as part of its shutdown. This causes the SRST to disable SWIM as well as reset
+the target and now the subsequent enter sequence behaves as expected.
+
+
+tests/sample4.sr
+----------------
+
+As sample3 but the SRST at the end of each run is removed again. The second
+enter sequence is no longer recognised as an enter sequence and the target
+again responds to each low by with a sync frame indicating it is treating them
+as SWIM reset requests. This demonstrates that the SRST SWIM command is indeed
+responsible for disabling the SWIM module and that an external reset via the
+RST pin is insufficient regardless of the setting of the RST bit in SWIM_CSR.
diff --git a/swim/tests/sample1.sr b/swim/tests/sample1.sr
new file mode 100644
index 0000000..8750641
--- /dev/null
+++ b/swim/tests/sample1.sr
Binary files differ
diff --git a/swim/tests/sample2.sr b/swim/tests/sample2.sr
new file mode 100644
index 0000000..8890c51
--- /dev/null
+++ b/swim/tests/sample2.sr
Binary files differ
diff --git a/swim/tests/sample3.sr b/swim/tests/sample3.sr
new file mode 100644
index 0000000..30d5aa3
--- /dev/null
+++ b/swim/tests/sample3.sr
Binary files differ
diff --git a/swim/tests/sample4.sr b/swim/tests/sample4.sr
new file mode 100644
index 0000000..9678132
--- /dev/null
+++ b/swim/tests/sample4.sr
Binary files differ