I'm trying to write a behavioural description of an 8-bit binary
counter. my code is as follows. I keep getting an error that says:
near text "process"; expecting "if";
the error is on the line that says "end process;". I thought I might not
have ended one of my if statements but as far as I can tell I have an
"end if;" for each one of my if statements. just wondering what else I
might have done wrong. thanks in advance.
Tom Turner
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
entity COUNT8 is
port(
CLK : in std_logic;
CLR : in std_logic;
DIR : in std_logic;
ENA : in std_logic;
LOAD : in std_logic;
DATA : in std_logic_vector(7 downto 0);
COUNT : out std_logic_vector(7 downto 0)
);
end COUNT8;
architecture behavior of COUNT8 is
begin
process(CLK)
begin
if (CLR = '0') then
COUNT <= "00000000";
else if (CLK'EVENT AND CLK = '1') then
if (LOAD = '0') then
if ENA = '1' then
if DIR = '1' then
COUNT <= COUNT + 1;
else
COUNT <= COUNT - 1;
end if;
end if;
else
COUNT <= DATA;
end if;
end if;
end process;
end behavior;
U need to add a
1 | end if; |
just before
1 | end process; |
But after setting this right the compiler throwing errors
1 | Error (10309): VHDL Interface Declaration error in COUNT8.vhd(29): interface object "COUNT" of mode out cannot be read. Change object mode to buffer or inout. |
2 | Error (10327): VHDL error at COUNT8.vhd(29): can't determine definition of operator ""+"" -- found 0 possible definitions |
With proper formatting your code looks like this:
1 | process(CLK) begin |
2 | if (CLR = '0') then |
3 | COUNT <= "00000000"; |
4 | else
|
5 | if (CLK'EVENT AND CLK = '1') then |
6 | if (LOAD = '0') then |
7 | if ENA = '1' then |
8 | if DIR = '1' then |
9 | COUNT <= COUNT + 1; |
10 | else
|
11 | COUNT <= COUNT - 1; |
12 | end if; |
13 | end if; |
14 | else
|
15 | COUNT <= DATA; |
16 | end if; |
17 | end if; |
18 | ???????
|
19 | end process; |
What you wanted was this:
1 | process(CLK) begin |
2 | if (CLR = '0') then |
3 | COUNT <= "00000000"; |
4 | elsif (CLK'EVENT AND CLK = '1') then -- an "elsif" is somehow different than an "else if" |
5 | if (LOAD = '0') then |
6 | if ENA = '1' then |
7 | if DIR = '1' then |
8 | COUNT <= COUNT + 1; |
9 | else
|
10 | COUNT <= COUNT - 1; |
11 | end if; |
12 | end if; |
13 | else
|
14 | COUNT <= DATA; |
15 | end if; |
16 | end if; |
17 | end process; |
> But after setting this right the compiler throwing errors 1. You cannot read an output. Use internal signals instead. 2. You cannot add two std_logic vectors with numeric_std. Use unsigned or signed vectors instead. Cast between std_logic_vector and unsigned/singed. See the picture there: http://www.lothar-miller.de/s9y/categories/16-Numeric_Std
thanks this was very helpful. I have changed a few things including using a buffer for my count vector.
Its good to know that your problem has been solved. I have a presentation in next 2 days about VHDL in my university and i am collecting some sample project to show in my presentation and your 8-bit counter seems a good idea. I wonder to know can your post your corrected version of your codes so i can use them in my presentation? tnx
Thomas Turner wrote: > thanks this was very helpful. De nada. > I have changed a few things including using a buffer for my count vector. You did not read my post? It is bad idea to be lazy and NOT to use internal signals. You will find this out sooner or later. The major problem is that a counter signal is not a buffer but a simple internal signal. That was the reason why i wrote: >> Use internal signals instead. I did with full intention not write "use a buffer". Get accustomed to the flowery and talky style of VHDL.
Please log in before posting. Registration is free and takes only a minute.
Existing account
Do you have a Google/GoogleMail account? No registration required!
Log in with Google account
Log in with Google account
No account? Register here.