new version
[Chiptunes.git] / foo.c
CommitLineData
61fab018 1#include <stdio.h>
da32ed67 2#include "fakeasm.h"
61fab018 3typedef unsigned char u8;
da32ed67 4
24abdcbb
TG
5u8 data[] = {
6 0x84, 0x9d, 0xb0, 0x69, 0x9d, 0x84, 0x69, 0x58,
7 0x75, 0x8c, 0xb0, 0x69, 0x8c, 0x75, 0x69, 0x58
8};
06aad1ff
TG
9u8 i0;
10u8 i1;
11u8 i2;
12u8 i3;
3b86ca43
TG
13u8 x;
14u8 t;
15u8 o;
965274e2 16void g(void) {
46a8d83c 17 // g(i, x, t, o) -> t
63363195 18 u8 tmp;
0f219114 19 ANDI (t, 0x07)
32632e61 20 MOV (tmp, i2)
63363195 21 ANDI (tmp, 3)
09cf3949
TG
22 TST (tmp)
23 BREQ (skip)
24 SUBI (t, -8)
25 skip:
c616f0c2 26 t = data[t];
965274e2 27 t = ((i3<<24|i2<<16|i1<<8|i0)*t) >> o;
c616f0c2
TG
28 AND (t, x)
29 ANDI (t, 3)
46a8d83c 30 RET
61fab018
TG
31};
32
33int main(void) {
a1631438
TG
34 u8 n;
35 u8 s;
ab6fe4c2 36 u8 acc;
89f35588 37 //TODO: clear all vars/registers
5dd8b8ff 38 for (;;) {
7874ed03
TG
39 MOV (n, i2)
40 LSL (n)
41 LSL (n)
bc7680e3
TG
42 #define tmp acc
43 MOV (tmp, i1)
5d4207f9
TG
44 SWAP (tmp)
45 ANDI (tmp, 0x0f)
3eef1ade
TG
46 LSR (tmp)
47 LSR (tmp)
128ff01a 48 OR (n, tmp)
bc7680e3 49 #undef tmp
df192822
TG
50 #define tmp acc
51 MOV (s, i3)
52 //ROR (s)
53 //ROR (s)
54 //ANDI (s, 0x01)
55 s<<=7;
56 s = (s | i2>>1);
57 #undef tmp
3b86ca43
TG
58
59 //voice 1:
60 LDI (x, 1)
61 MOV (t, n)
62 LDI (o, 12)
965274e2 63 RCALL g();
46a8d83c 64 MOV (acc, t)
3b86ca43
TG
65
66 //voice 2:
67 MOV (x, s)
1b023e92 68 #define tmp o
94c4920f
TG
69 MOV (tmp, i2)
70 LSL (tmp)
71 LSL (tmp)
72 LSL (tmp)
73 MOV (t, i1)
4b0b7dc5
TG
74 SWAP (t)
75 ANDI (t, 0xf)
76 LSR (t)
94c4920f 77 OR (t, tmp)
1b023e92 78 #undef tmp
23872091 79 EOR (t, n)
3b86ca43 80 LDI (o, 10)
965274e2 81 RCALL g();
46a8d83c 82 ADD (acc, t)
3b86ca43
TG
83
84 //voice 3:
85 x = s / 3;
d9218a18 86 t = n + ((i3<<13 | i2<<5 | i1>>3) % 3);
3b86ca43 87 LDI (o, 10)
965274e2 88 RCALL g();
46a8d83c 89 ADD (acc, t)
3b86ca43
TG
90
91 //voice 4:
92 x = s / 5;
704b11ab 93 t = 8 + n - ((i3<<14 | i2<<6 | i1>>2) % 3);
3b86ca43 94 LDI (o, 9)
965274e2 95 RCALL g();
46a8d83c 96 ADD (acc, t)
bfce2f8c 97
ab6fe4c2 98 putchar(acc<<4);
89f35588
TG
99 #define tmp acc
100 LDI (tmp, 0)
101 SUBI (i0, -1)
102 ADC (i1, tmp, !i0)
103 ADC (i2, tmp, !i0&&!i1)
104 ADC (i3, tmp, !i0&&!i1&&!i2)
dd7bbc4a 105 #undef tmp
fe9a76e4 106 }
61fab018 107}
Imprint / Impressum