new version
[Chiptunes.git] / foo.c
diff --git a/foo.c b/foo.c
index 1265e776057c81f90b9e2d91318d84556d0441b3..fcb07cdaec9f6a310494b512f9880b749e08480e 100644 (file)
--- a/foo.c
+++ b/foo.c
@@ -43,12 +43,14 @@ void mod3(void) {
        ADD     (Ml, tmp)
        CPI     (Ml, 3)
        BRPL    (skip)
-       Ml = Ml - 3; //TODO
+       SUBI    (Ml, 3)
        skip:;
+       RET
        #undef tmp
 }
 void g(void) {
-       // g(i, x, t, o) -> t
+       // g(i, t) -> t
+       // tempvars: `x` and `_`
        #define tmp _
        ANDI    (t, 0x07)
        MOV     (tmp, i2)
@@ -65,10 +67,7 @@ void g(void) {
          ADC X_hi, zero
          LD  t, X         */
        t = (((i1&0x1f)<<8|i0)*t)>>8; //TODO
-       t >>= o; //NOTE: o == {1, 2, 4}
-       AND     (t, x)
-       ANDI    (t, 3)
-       RET
+       RET //TODO: CALL/RET is expensive; store PC in register and RJMP, then JRMP back
 };
 
 int main(void) {
@@ -99,14 +98,15 @@ int main(void) {
                #undef tmp
 
                //voice 1:
-               LDI     (x, 1)
                MOV     (t, n)
                LDI     (o, 4)
                RCALL   g();
+       t >>= o; //NOTE: o == {1, 2, 4}
+       ANDI    (t, 3)
+               ANDI    (t, 1)
                MOV     (acc, t)
 
                //voice 2:
-               MOV     (x, s)
                #define tmp o
                MOV     (tmp, i2)
                LSL     (tmp)
@@ -121,9 +121,40 @@ int main(void) {
                EOR     (t, n)
                LDI     (o, 2)
                RCALL   g();
+       t >>= o; //NOTE: o == {1, 2, 4}
+       ANDI    (t, 3)
+               AND     (t, s)
                ADD     (acc, t)
 
                //voice 3:
+               MOV     (Ml, i2)
+               SWAP    (Ml)
+               ANDI    (Ml, 0xf0)
+               LSL     (Ml)
+               #define tmp Mh
+               MOV     (tmp, i1)
+               LSR     (tmp)
+               LSR     (tmp)
+               LSR     (tmp)
+               OR      (Ml, tmp)
+               #undef tmp
+               MOV     (Mh, i3)
+               SWAP    (Mh)
+               ANDI    (Mh, 0xf0)
+               LSL     (Mh)
+               #define tmp _
+               MOV     (tmp, i2)
+               LSR     (tmp)
+               LSR     (tmp)
+               LSR     (tmp)
+               OR      (Mh, tmp)
+               #undef tmp
+               RCALL   mod3();
+               ADD     (t, n)
+               LDI     (o, 2)
+               RCALL   g();
+       t >>= o; //NOTE: o == {1, 2, 4}
+       ANDI    (t, 3)
                MOV     (x, s)
                INC     (x)
                #define tmp o
@@ -141,15 +172,40 @@ int main(void) {
                LSR     (tmp)
                 MOV    (x, tmp)
                #undef tmp
-               Ml = i2<<5 | i1>>3;
-               Mh = i3<<5 | i2>>3;
-               RCALL   mod3();
-               ADD     (t, n)
-               LDI     (o, 2)
-               RCALL   g();
+               AND     (t, x)
                ADD     (acc, t)
 
                //voice 4:
+               MOV     (Ml, i2)
+               SWAP    (Ml)
+               ANDI    (Ml, 0xf0)
+               LSL     (Ml)
+               LSL     (Ml)
+               #define tmp Mh
+               MOV     (tmp, i1)
+               LSR     (tmp)
+               LSR     (tmp)
+               OR      (Ml, tmp)
+               #undef tmp
+               MOV     (Mh, i3)
+               SWAP    (Mh)
+               ANDI    (Mh, 0xf0)
+               LSL     (Mh)
+               LSL     (Mh)
+               #define tmp _
+               MOV     (tmp, i2)
+               LSR     (tmp)
+               LSR     (tmp)
+               OR      (Mh, tmp)
+               #undef tmp
+               RCALL   mod3();
+               SUB     (t, n)
+               NEG     (t)
+               SUBI    (t, -8)
+               LDI     (o, 1)
+               RCALL   g();
+       t >>= o; //NOTE: o == {1, 2, 4}
+       ANDI    (t, 3)
                MOV     (x, s)
                INC     (x)
                #define tmp o
@@ -167,14 +223,7 @@ int main(void) {
                LSR     (tmp)
                 MOV    (x, tmp)
                #undef tmp
-               Ml = i2<<6 | i1>>2;
-               Mh = i3<<6 | i2>>2;
-               RCALL   mod3();
-               SUB     (t, n)
-               NEG     (t)
-               SUBI    (t, -8)
-               LDI     (o, 1)
-               RCALL   g();
+               AND     (t, x)
                ADD     (acc, t)
 
                putchar(acc<<4); //TODO
Imprint / Impressum