From 0750ec764cbea33d0b4646558619a0b5e365cc15 Mon Sep 17 00:00:00 2001 From: Aaron Taylor Date: Wed, 31 Jul 2019 18:16:23 -0700 Subject: [PATCH] Fixed bugs in `rshift` subroutine. --- stdlib/logic.pvvs | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/stdlib/logic.pvvs b/stdlib/logic.pvvs index e8f63cb..8ac7a39 100644 --- a/stdlib/logic.pvvs +++ b/stdlib/logic.pvvs @@ -138,13 +138,17 @@ NTN | RTS @ X >> shiftcount @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ NSSVTSTTSSN | Mark: 101100 (rshift) - @ Test for loop completion first since it is allowable to shift by zero. -NSSVSSTSTTSSSSSSSSSTN | Mark: 00101100 00000001 SNS | DUP NTSSSTSTTSSSSSSSSSSN | BRZ > 00101100 00000000 -@ Shift by one bit on each pass. + +@ Negative numbers need special handling. SNT | SWAP +SNS | DUP +NTTSSTSTTSSSSSSSTSTN | BMI > 00101100 00000101 + +@ Shift by one bit on each pass. +NSSVSSTSTTSSSSSSSTSSN | Mark: 00101100 00000100 SSSTSN | PUSH 2 TSTS | DIVIDE @ Decrement the counter. @@ -152,13 +156,23 @@ SNT | SWAP SSSTN | PUSH 1 TSST | SUBTRACT @ Loop again. -NSNSSTSTTSSSSSSSSSTN | JMP > 00101100 00000001 +NSNTSTTSSN | JMP > 101100 (rshift) -@ Clean up and return. +@ Clean up NSSVSSTSTTSSSSSSSSSSN | Mark: 00101100 00000000 SNN | DROP NTN | RTS +@ Found a negative number. Subtract one before proceeding if odd. +NSSVSSTSTTSSSSSSSTSTN | Mark: 00101100 00000101 +SNS | DUP +SSSTSN | PUSH 2 +TSTT | MODULO +NTSSSTSTTSSSSSSSTSSN | BRZ > 00101100 00000100 +SSSTN | PUSH 1 +TSST | SUBTRACT +NSNSSTSTTSSSSSSSTSSN | JMP > 00101100 00000100 + @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ Name: @ lshift (101101) -- 2.20.1