CHG: changed initial Program to print Geraffel Processor

This commit is contained in:
Dominik Meyer 2014-01-07 21:34:30 +01:00
parent 0be13ee269
commit c0031f415c

View File

@ -34,22 +34,22 @@ architecture arch of RAM is
type MEMORY is ARRAY(0 to 255) of DATA; --! array of data words type MEMORY is ARRAY(0 to 255) of DATA; --! array of data words
constant Prog1 : MEMORY := ( --! 4k * 32bit of RAM constant Prog1 : MEMORY := ( --! 4k * 32bit of RAM
0 => B"00111111110000000000000000000001", --lui $30, 1 0 => B"00001100001000000000000011001000", --loa $1, 200
1 => B"00001100001000001111111111110000", --loa $1, 65520 1 => B"01000011111000000000000000001101", --jmc print
2 => B"01000011111000000000000000000101", --jmc print 2 => B"00001100001000000000000011001001", --loa $1, 201
3 => B"01000011111000000000000000100011", --jmc wait 3 => B"01000011111000000000000000001101", --jmc print
4 => B"00111000000000000000000000000000", --jmp start 4 => B"00001100001000000000000011001010", --loa $1, 202
5 => B"00010010100000010000000000000000", --add $20, $1, $0 5 => B"01000011111000000000000000001101", --jmc print
6 => B"00001000000101001111111111110001", --sto $20, 65521 6 => B"00001100001000000000000011001011", --loa $1, 203
7 => B"00000110100101000000000000000000", --shr $20, $20, $0 7 => B"01000011111000000000000000001101", --jmc print
8 => B"00000110100101000000000000000000", --shr $20, $20, $0 8 => B"00001100001000000000000011001100", --loa $1, 204
9 => B"00000110100101000000000000000000", --shr $20, $20, $0 9 => B"01000011111000000000000000001101", --jmc print
10 => B"00000110100101000000000000000000", --shr $20, $20, $0 10 => B"00111100001000000000001000000000", --lui $1, 512
11 => B"00000110100101000000000000000000", --shr $20, $20, $0 11 => B"01000011111000000000000000011010", --jmc printAscii
12 => B"00000110100101000000000000000000", --shr $20, $20, $0 12 => B"11111100000000000000000000000000", --hlt
13 => B"00000110100101000000000000000000", --shr $20, $20, $0 13 => B"00010010100000010000000000000000", --add $20, $1, $0
14 => B"00000110100101000000000000000000", --shr $20, $20, $0 14 => B"00001000000101001111111111110001", --sto $20, 65521
15 => B"00001000000101001111111111110001", --sto $20, 65521 15 => B"00000110100101000000000000000000", --shr $20, $20, $0
16 => B"00000110100101000000000000000000", --shr $20, $20, $0 16 => B"00000110100101000000000000000000", --shr $20, $20, $0
17 => B"00000110100101000000000000000000", --shr $20, $20, $0 17 => B"00000110100101000000000000000000", --shr $20, $20, $0
18 => B"00000110100101000000000000000000", --shr $20, $20, $0 18 => B"00000110100101000000000000000000", --shr $20, $20, $0
@ -57,42 +57,41 @@ architecture arch of RAM is
20 => B"00000110100101000000000000000000", --shr $20, $20, $0 20 => B"00000110100101000000000000000000", --shr $20, $20, $0
21 => B"00000110100101000000000000000000", --shr $20, $20, $0 21 => B"00000110100101000000000000000000", --shr $20, $20, $0
22 => B"00000110100101000000000000000000", --shr $20, $20, $0 22 => B"00000110100101000000000000000000", --shr $20, $20, $0
23 => B"00000110100101000000000000000000", --shr $20, $20, $0 23 => B"00110000000000000000000000011001", --jpz endPrint
24 => B"00001000000101001111111111110001", --sto $20, 65521 24 => B"00111000000000000000000000001110", --jmp printLoop
25 => B"00000110100101000000000000000000", --shr $20, $20, $0 25 => B"01000100000111110000000000000000", --ret
26 => B"00000110100101000000000000000000", --shr $20, $20, $0 26 => B"00010010100000010000000000000000", --add $20, $1, $0
27 => B"00000110100101000000000000000000", --shr $20, $20, $0 27 => B"00100110101101000111100000000000", --and $21, $20, 15
28 => B"00000110100101000000000000000000", --shr $20, $20, $0 28 => B"00100010101101011000000000000000", --or $21, $21, 48
29 => B"00000110100101000000000000000000", --shr $20, $20, $0 29 => B"00010110110101010101000000000000", --sub $22, $21, 10
30 => B"00000110100101000000000000000000", --shr $20, $20, $0 30 => B"00110100000000000000000000100000", --jpc smaller
31 => B"00000110100101000000000000000000", --shr $20, $20, $0 31 => B"00010010101101010011100000000000", --add $21, $21, 7
32 => B"00000110100101000000000000000000", --shr $20, $20, $0 32 => B"00001000000101011111111111110001", --sto $21, 65521
33 => B"00001000000101001111111111110001", --sto $20, 65521 33 => B"00000110100101000000000000000000", --shr $20, $20, $0
34 => B"01000100000111110000000000000000", --ret 34 => B"00000110100101000000000000000000", --shr $20, $20, $0
35 => B"00111101010000000000001001011000", --lui $10, 600 35 => B"00000110100101000000000000000000", --shr $20, $20, $0
36 => B"00000001010010100000000000000000", --shl $10, $10, $0 36 => B"00000110100101000000000000000000", --shr $20, $20, $0
37 => B"00000001010010100000000000000000", --shl $10, $10, $0 37 => B"00110000000000000000000000000000", --jpz asciloop:
38 => B"00000001010010100000000000000000", --shl $10, $10, $0 38 => B"01000100000111110000000000000000", --ret
39 => B"00000001010010100000000000000000", --shl $10, $10, $0
40 => B"00000001010010100000000000000000", --shl $10, $10, $0
41 => B"00000001010010100000000000000000", --shl $10, $10, $0
42 => B"00000001010010100000000000000000", --shl $10, $10, $0
43 => B"00000001010010100000000000000000", --shl $10, $10, $0
44 => B"00000001010010100000000000000000", --shl $10, $10, $0
45 => B"00000001010010100000000000000000", --shl $10, $10, $0
46 => B"00000001010010100000000000000000", --shl $10, $10, $0
47 => B"00000001010010100000000000000000", --shl $10, $10, $0
48 => B"00000001010010100000000000000000", --shl $10, $10, $0
49 => B"00000001010010100000000000000000", --shl $10, $10, $0
50 => B"00000001010010100000000000000000", --shl $10, $10, $0
51 => B"00111101011000000000000000000001", --lui $11, 1
52 => B"00010101010010100101100000000000", --sub $10, $10, $11
53 => B"00110000000000000000000000110111", --jpz endloop
54 => B"00111000000000000000000000110100", --jmp loop
55 => B"01000100000111110000000000000000", --ret
--
others => (others => '0') -- Some variables
--
-- Geraffel
200 => x"61726547",
201 => x"6c656666",
-- Processor
202 => x"6f725020",
203 => x"73736563",
204 => x"0a20726f",
-- Return
205 => x"0a202020",
others => (others => '0')
); );
signal sRam : MEMORY; signal sRam : MEMORY;