Document new workflow for creating vec unit tests
The workflow is a moving target, creating a document
to track the workflow and will attempt to keep this up to date
through further developments.
Change-Id: I13633ead690ff63f4bc41c7408e37938b3d02e71
diff --git a/Create_Springbok_Vector_Unit_Test.md b/Create_Springbok_Vector_Unit_Test.md
new file mode 100644
index 0000000..6973ba8
--- /dev/null
+++ b/Create_Springbok_Vector_Unit_Test.md
@@ -0,0 +1,163 @@
+# Create Springbok Vector Unit Test
+
+* [Step 0: Repo Sync and Build Prequisties](#step-0:-repo-sync-and-build-prequisties)
+* [Step 1: Select Instruction and Update Tracker](#step-1:-select-instruction-and-update-tracker)
+* [Step 2: Go to the vector testing directory, and select a template](#step-2:-go-to-the-vector-testing-directory,-and-select-a-template)
+* [Step 3: Create Demo Test and Macro Test](#step-3:-create-demo-test-and-macro-test)
+* [Step 4: Add Test to CMakeLists.txt](#step-4:-add-test-to-cmakelists.txt)
+* [Step 5: Build springbok](#step-5:-build-springbok)
+* [Step 6: Run Qemu Tests](#step-6:-run-qemu-tests)
+* [Step 7: Run Renode Tests](#step-7:-run-renode-tests)
+* [Step 8: Mark Tests as Passing](#step-8:-mark-tests-as-passing)
+* [Step 9: Disable demo test](#step-9:-disable-demo-test)
+
+## Step 0: Repo Sync and Build Prequisties
+
+```sh
+repo sync
+m renode_clean renode
+m qemu
+```
+## Step 1: Select Instruction and Update Tracker
+
+Go to the following spreadsheet and write or select one's name under the `DRI - Unit Test`.
+
+[Select Instructions Here](https://docs.google.com/spreadsheets/d/1MVh0eQjdKkPiBOCXysfuLWWkFiL3gWzqvk-xA8-1rNg/edit#gid=1311575874)
+
+Now you've signed up to develop a unit test for this vector instruction :)
+
+
+Side Note: The following pivot table is very useful for quickly scanning through the instructions available:
+[DRI Pivot Table](https://docs.google.com/spreadsheets/d/1MVh0eQjdKkPiBOCXysfuLWWkFiL3gWzqvk-xA8-1rNg/edit#gid=1165644093)
+
+## Step 2: Go to the vector testing directory, and select a template
+
+The easiest way to get started will be to look at a test that should be similar to the test one is planning to write.
+
+These tests are located at:
+
+```sh
+cd ${ROOTDIR}/sw/vec/tests
+```
+
+Then change the names in the template to match one's current vector instruction of interest.
+
+## Step 3: Create Demo Test and Macro Test
+
+
+There is a demo test written in C++, which serves as a sample of the testing strategy, a convenient way to develop before making a macro version, as well as a place to debug and step through need be.
+
+Demo test will look like the following:
+
+```cpp
+TEST_F(VaddViTest, vadd_vi_demo) {
+```
+
+One possible workflow is to develop the demo test, then proceed through the following steps to make sure it builds and passes in Qemu(proceeding straight to the next step), and then developing the macro version and ensuring it builds/passes as well.
+
+
+Note: To disable a demo test, prefix the test with `DISABLED_` as shown:
+```cpp
+TEST_F(VaddViTest, DISABLED_vadd_vi_demo) {
+```
+
+## Step 4: Add Test to CMakeLists.txt
+
+
+Edit the CmakeLists.txt (path follows):
+
+```sh
+${ROOTDIR}/sw/vec/tests/CMakeLists.txt
+```
+
+Include a new `vec_cc_test` at the bottom of the file:
+
+```cmake
+vec_cc_test(
+ NAME
+ vadd_test
+ SRCS
+ vadd_vi_test.cpp
+ vadd_vx_test.cpp
+ vadd_vv_test.cpp
+ LINKOPTS
+ -Xlinker --defsym=__itcm_length__=128K
+ TIMEOUT
+ 20
+)
+```
+
+Name should be the root type of the test (e.g. as above `vadd_test` which covers `vadd.vi`, `vadd.vx`, and `vadd.vv`).
+
+Sources to be included in the test go under the `SRCS` section.
+
+Note: Most tests will only need around 20 seconds and require less than 128K, but some tests may require more, we need to play this by ear.
+
+## Step 5: Build springbok
+
+Check and address any build errors:
+
+```sh
+m springbok
+```
+
+## Step 6: Run Qemu Tests
+
+We're using Qemu as our baseline for out tests, unit tests should at minimum pass in Qemu.
+If a test passes in Qemu, and not in Renode (whose vector support is WIP), it may indicate a problem in Renode's vector implementation.
+
+`cd` into the following directory:
+
+```sh
+${ROOTDIR}/out/springbok
+```
+Then use the following to start running through all of the tests from `CMakeLists.txt` file earlier:
+
+```sh
+ctest --verbose -R qemu --gtest_color=yes
+```
+
+For convenience, one might include the building/testing in a single line:
+
+```sh
+cd ${OUT}/springbok && m springbok && ctest --verbose -R qemu --gtest_color=yes
+```
+
+Note: The `-R` flag filters tests which match a regular expression, in this case we're filtering on qemu tests, but more specific filters are possble:
+
+For example, if you had wanted only to test the `vadd_tests` in qemu:
+
+```sh
+cd ${OUT}/springbok && m springbok && ctest --verbose -R qemu_vadd --gtest_color=yes
+```
+
+## Step 7: Run Renode Tests
+
+Renode tests won't necessarily pass, many of these are still in progress on the Antmicro side, but please do log success/fail of the Renode tests on the tracker:
+
+```sh
+ctest --verbose -R renode --gtest_color=yes
+```
+Running a specific test can be done (to save time), example below for the `vadd_test` group:
+
+```sh
+ctest --verbose -R renode_vadd --gtest_color=yes
+```
+
+## Step 8: Mark Tests as Passing
+
+Note: at minimum, one's test should be expected to pass in Qemu. Since Renode vec support is WIP, a unit test failing may indicate problem in the Renode implementation.
+
+On the [unit test tracker](https://docs.google.com/spreadsheets/d/1MVh0eQjdKkPiBOCXysfuLWWkFiL3gWzqvk-xA8-1rNg/edit#gid=1311575874):
+
+1. Mark whether the unit test passes in Qemu
+2. Mark whether the unit test passes in Renode
+3. Mark the instruction "Springbok Unit Test" as "implemented"
+
+## Step 9: Disable demo test
+
+When done testing, disable the demo test by prefixing the demo test name with "`DISABLED_`":
+
+```cpp
+TEST_F(VaddViTest, DISABLED_vadd_vi_demo) {
+```