code-comments
authorLuke Kenneth Casson Leighton <lkcl@lkcl.net>
Fri, 21 Oct 2022 12:29:07 +0000 (13:29 +0100)
committerLuke Kenneth Casson Leighton <lkcl@lkcl.net>
Fri, 21 Oct 2022 12:29:07 +0000 (13:29 +0100)
src/openpower/decoder/isa/test_caller_svp64_chacha20.py

index 05aa0955f4717a7b8e08bd5ffa8a484a6b52d566..b402fb413e6aa429442ecb503ae1f88e1d8c8176 100644 (file)
@@ -102,6 +102,14 @@ class SVSTATETestCase(FHDLTestCase):
 
         RA, RB, RS and RT are set up via Indexing to perform the *individual*
         add/xor/rotl32 operations (with elwidth=32)
+
+        the inner loop uses "svstep." which detects src/dst-step reaching
+        the end of the loop, setting CR0.eq=1.  no need for an additional
+        counter-register-with-a-decrement.  this has the side-effect of
+        freeing up CTR for use as a straight decrement-counter.
+
+        both loops are 100% deterministic meaning that there should be
+        *ZERO* branch-prediction misses, obviating a need for loop-unrolling.
         """
 
         nrounds = 2 # should be 10 for full algorithm
@@ -127,7 +135,8 @@ class SVSTATETestCase(FHDLTestCase):
             'sv.rldcl/w=32 *0, *0, *18, 0',
             'svstep. 16, 1, 0',              # step to next in-regs element
             'bc 6, 3, -0x28',               # svstep. Rc=1 loop-end-condition?
-            'bc 16, 0, -0x30',              # bdnz to the outer loop setvl
+            # inner-loop done: outer loop standard CTR-decrement to setvl again
+            'bc 16, 0, -0x30',
                        ])
         lst = list(isa)
         print ("listing", lst)