aboutsummaryrefslogtreecommitdiff
path: root/amforth-6.5/avr8/words/umstar.asm
diff options
context:
space:
mode:
authorDimitri Sokolyuk <demon@dim13.org>2017-08-19 12:15:28 +0200
committerDimitri Sokolyuk <demon@dim13.org>2017-08-19 12:15:28 +0200
commit67d25d837ac55f28a366c0a3b262e439a6e75fc3 (patch)
treedf7715c7724c5935ab87c807f3b8b4ef529315e3 /amforth-6.5/avr8/words/umstar.asm
parente0d6784e89dba33226c0edb815bb974486fa7c48 (diff)
Add AmForth
Diffstat (limited to 'amforth-6.5/avr8/words/umstar.asm')
-rw-r--r--amforth-6.5/avr8/words/umstar.asm37
1 files changed, 37 insertions, 0 deletions
diff --git a/amforth-6.5/avr8/words/umstar.asm b/amforth-6.5/avr8/words/umstar.asm
new file mode 100644
index 0000000..ee53c87
--- /dev/null
+++ b/amforth-6.5/avr8/words/umstar.asm
@@ -0,0 +1,37 @@
+; ( u1 u2 -- d)
+; Arithmetics
+; multiply 2 unsigned cells to a double cell
+VE_UMSTAR:
+ .dw $ff03
+ .db "um*",0
+ .dw VE_HEAD
+ .set VE_HEAD = VE_UMSTAR
+XT_UMSTAR:
+ .dw PFA_UMSTAR
+PFA_UMSTAR:
+ movw temp0, tosl
+ loadtos
+ ; result: (temp3*temp1)* 65536 + (temp3*temp0 + temp1*temp2) * 256 + (temp0 * temp2)
+ ; low bytes
+ mul tosl,temp0
+ movw zl, r0
+ clr temp2
+ clr temp3
+ ; middle bytes
+ mul tosh, temp0
+ add zh, r0
+ adc temp2, r1
+ adc temp3, zeroh
+
+ mul tosl, temp1
+ add zh, r0
+ adc temp2, r1
+ adc temp3, zeroh
+
+ mul tosh, temp1
+ add temp2, r0
+ adc temp3, r1
+ movw tosl, zl
+ savetos
+ movw tosl, temp2
+ jmp_ DO_NEXT