-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathscore_info.vhd
88 lines (71 loc) · 2.95 KB
/
score_info.vhd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;
entity score_info is
port(
clk, not_reset: in std_logic;
px_x, px_y: in std_logic_vector(9 downto 0);
score: in std_logic_vector(15 downto 0);
rgb_pixel: out std_logic_vector(0 to 2)
);
end score_info;
architecture display of score_info is
constant WIDTH: integer := 48;
constant HEIGHT: integer := 8;
constant Y_OFFSET: integer := 8;
signal font_addr: std_logic_vector(8 downto 0);
signal font_data: std_logic_vector(0 to 7);
signal font_pixel: std_logic;
signal text_font_addr: std_logic_vector(8 downto 0);
signal number_font_addr: std_logic_vector(8 downto 0);
signal text_enable: std_logic;
signal number_enable: std_logic;
signal bcd: std_logic_vector(3 downto 0);
signal bcd0, bcd1, bcd2, bcd3, bcd4: std_logic_vector(3 downto 0);
begin
text_enable <= '1' when (px_x >= 0 and
px_x < WIDTH and
px_y >= Y_OFFSET and
px_y < Y_OFFSET + HEIGHT) else
'0';
number_enable <= '1' when (px_x >= WIDTH and
px_x < WIDTH + 40 and
px_y >= Y_OFFSET and
px_y < Y_OFFSET + HEIGHT) else
'0';
with px_x(9 downto 3) select
text_font_addr <= "110011000" when "0000000", -- S
"100011000" when "0000001", -- C
"101111000" when "0000010", -- O
"110010000" when "0000011", -- R
"100101000" when "0000100", -- E
"000000000" when others; -- space
bcd <= bcd0 when px_x(9 downto 3) = 10 else
bcd1 when px_x(9 downto 3) = 9 else
bcd2 when px_x(9 downto 3) = 8 else
bcd3 when px_x(9 downto 3) = 7 else
bcd4 when px_x(9 downto 3) = 6 else
(others => '0');
-- numbers start at memory location 128
-- '1' starts at 136, '2' at 144 and so on
-- bcd is multiplied by 8 to get the right digit
number_font_addr <= conv_std_logic_vector(128, 9) + (bcd & "000");
font_addr <= px_y(2 downto 0) + text_font_addr when text_enable = '1' else
px_y(2 downto 0) + number_font_addr when number_enable = '1' else
(others => '0');
font_pixel <= font_data(conv_integer(px_x(2 downto 0)));
rgb_pixel <= "111" when font_pixel = '1' else "000";
bin_to_bcd:
entity work.bin2bcd(behaviour)
generic map(N_BIN => 16)
port map(
clk => clk, not_reset => not_reset,
binary_in => score,
bcd0 => bcd0, bcd1 => bcd1, bcd2 => bcd2,
bcd3 => bcd3, bcd4 => bcd4
);
codepage:
entity work.codepage_rom(content)
port map(addr => font_addr, data => font_data);
end display;