X-Git-Url: http://j8takagi.net/cgi-bin/gitweb.cgi?p=YACASL2.git;a=blobdiff_plain;f=as%2Fcasl2lib%2Fmula.casl;h=2ac0524114c0f6bda3255bfb71ce61dcabe6b531;hp=6155e55e89f3cd1eb587ee521bf202eeff802b88;hb=5be8def29beb565c49e7268f71add4a7758ba77b;hpb=955b8eab6e12f9d9704d7f9bd1f12613a57a6ca0 diff --git a/as/casl2lib/mula.casl b/as/casl2lib/mula.casl index 6155e55..2ac0524 100644 --- a/as/casl2lib/mula.casl +++ b/as/casl2lib/mula.casl @@ -41,32 +41,27 @@ ALLON DC #FFFF END ;;; 0〜65535の範囲にある正数のかけ算(筆算方式)を行う ;;; 入力 GR1:被乗数 GR2:乗数 -;;; 出力 GR0:積 -;;; 積が65535より大きい場合は、GR0は積の下位16ビットになり、オーバーフロー +;;; 出力 GR3:積 +;;; 積が65535より大きい場合は、オーバーフロー MULL START - PUSH 0,GR1 - PUSH 0,GR3 - XOR GR0,GR0 ; 積 - AND GR1,GR1 ; (GR1 = 0)の場合、終了 + XOR GR3,GR3 ; GR3の初期化 + AND GR1,GR1 ; GR1 = 0 の場合、FINへジャンプ JZE FIN ; ↓ - AND GR2,GR2 ; (GR2 = 0)の場合、終了 + AND GR2,GR2 ; GR2 = 0 の場合、FINへジャンプ JZE FIN ; ↓ - LAD GR3,1 ; 対象ビット -LOOP PUSH 0,GR3 ; ループ先頭。GR2のビット中でGR3が示すビットが0の場合、NEXTへジャンプ - AND GR3,GR2 ; ↓ - POP GR3 ; ↓ - JZE NEXT ; ↓ - ADDL GR0,GR1 ; GR0 <- GR0 + GR1 - JOV FIN ; GR0がオーバーフローした場合、ループ脱出 -NEXT SLL GR3,1 ; GR3を1回左シフト - AND GR3,GR3 ; (GR3 = 0)の場合、ループ脱出 - JZE FIN ; ↓ - CPL GR3,GR2 ; (GR3 > GR2)の場合、ループ脱出 - JPL FIN ; ↓ - SLL GR1,1 ; GR1を1回左シフト - JOV FIN ; GR1がオーバーフローした場合、ループ脱出 + PUSH 0,GR1 ; GR1の退避 + PUSH 0,GR2 ; GR2の退避 +LOOP SRL GR2,1 ; ループ開始。SRLを1つ右シフト + JOV ON ; 乗数の最下位ビットが1の場合、ONへジャンプ + JUMP NEXT ; NEXTへジャンプ +ON ADDL GR3,GR1 ; GR3 <- GR3 + GR1 + JOV POST ; GR3がオーバーフローした場合、POSTへジャンプ +NEXT AND GR2,GR2 ; GR2 = 0 の場合、POSTへジャンプ + JZE POST ; ↓ + SLL GR1,1 ; GR1を1つ左シフト + JOV POST ; GR1がオーバーフローした場合、POSTへジャンプ JUMP LOOP ; ループ終端 -FIN POP GR3 - POP GR1 - RET +POST POP GR2 ; GR2の復元 + POP GR1 ; GR1の復元 +FIN RET END