Error (10500): VDHL code line 88 (Quartus)
Error (10500): VDHL code line 88 (Quartus)
我们似乎遇到了以下代码的问题。我们得到的错误是:
Error (10500): VHDL syntax error at pract3.vhd(88) near text "PORT";
expecting "end", or "(", or an identifier ("port" is a reserved
keyword), or a concurrent statement
我们是 Quartus 的新手,所以我们不知道这是什么意思。
这是我们的代码
</p>
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY work;
ENTITY pract3 IS
PORT
(
clk : IN STD_LOGIC;
I_0 : IN STD_LOGIC_VECTOR (0 TO 3);
I_1 : IN STD_LOGIC_VECTOR (0 TO 3);
I_2 : IN STD_LOGIC_VECTOR (0 TO 3);
I_3 : IN STD_LOGIC_VECTOR (0 TO 3);
Oper : IN STD_LOGIC_VECTOR (2 DOWNTO 0);
act_dis1: OUT STD_LOGIC;
act_dis2: OUT STD_LOGIC;
act_dis4: OUT STD_LOGIC;
act_dis3: OUT STD_LOGIC;
C_out : OUT STD_LOGIC;
--D : OUT STD_LOGIC_VECTOR (0 TO 1);
display : OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
oper_led: OUT STD_LOGIC_VECTOR (2 DOWNTO 0)
);
END pract3;
ARCHITECTURE bdf_type OF pract3 IS
COMPONENT Practica2
PORT
(
clk : IN STD_LOGIC;
I0 : IN STD_LOGIC_VECTOR (0 TO 3);
I1 : IN STD_LOGIC_VECTOR (0 TO 3);
I2 : IN STD_LOGIC_VECTOR (0 TO 3);
I3 : IN STD_LOGIC_VECTOR (0 TO 3);
dec : OUT STD_LOGIC_VECTOR (0 TO 3);
--D : OUT STD_LOGIC_VECTOR (0 TO 1);
sal : OUT STD_LOGIC_VECTOR (6 DOWNTO 0));
END COMPONENT;
COMPONENT arithmetic_circuit
PORT
(
C_in : IN STD_LOGIC;
A : IN STD_LOGIC_VECTOR (15 DOWNTO 0);
B : IN STD_LOGIC_VECTOR (15 DOWNTO 0);
S : IN STD_LOGIC_VECTOR (1 DOWNTO 0);
C_out : OUT STD_LOGIC;
G : OUT STD_LOGIC_VECTOR (15 DOWNTO 0)
);
END COMPONENT;
COMPONENT binary_to_bcd
GENERIC
(
bits : INTEGER := 16; --bits of the binary input
digits : INTEGER := 4 --number of BCD digits to convert to
);
PORT
(
clk : IN STD_LOGIC; --sys clk
reset_n : IN STD_LOGIC;
ena : IN STD_LOGIC; --enable
binary : IN STD_LOGIC_VECTOR(bits -1 DOWNTO 0); --num to convert
busy : OUT STD_LOGIC; --indicates conversion in progress
bcd : OUT STD_LOGIC_VECTOR(digits *4-1 DOWNTO 0) --BCD number
);
END COMPONENT;
SIGNAL A_in : STD_LOGIC_VECTOR (15 DOWNTO 0);
SIGNAL B_in : STD_LOGIC_VECTOR (15 DOWNTO 0);
SIGNAL BCD : STD_LOGIC_VECTOR (0 TO 15);
SIGNAL G : STD_LOGIC_VECTOR (15 DOWNTO 0);
BEGIN
oper_led <= Oper;
b2v_inst_Practica2 : Practica2
PORT MAP
(
clk => clk ,
dip_1 => BCD(12 TO 15),
dip_2 => BCD(8 TO 11),
dip_3 => BCD(4 TO 7),
dip_4 => BCD(0 TO 3),
dec_D0 => act_dis1 ,
dec_D1 => act_dis2 ,
dec_D2 => act_dis3 ,
dec_D3 => act_dis4 ,
--D => D,
sal => display
);
PORT MAP //Error is in this line!!!!!!!!!
(
C_in => Oper(2),
A => A_in ,
B => B_in ,
S => Oper(1 DOWNTO 0),
C_out => C_out,
G => G
);
stbin : binary_to_bcd
PORT MAP
(
CLK => clk ,
reset_n => ’1’,
ena => ’1’,
binary => G,
bcd => BCD
);
A_in(7 DOWNTO 4) <= I_0;
A_in(3 DOWNTO 0) <= I_1;
B_in(7 DOWNTO 4) <= I_2;
B_in(3 DOWNTO 0) <= I_3;
A_in (8) <= ’0’;
A_in (9) <= ’0’;
A_in (10) <= ’0’;
A_in (11) <= ’0’;
A_in (12) <= ’0’;
A_in (13) <= ’0’;
A_in (14) <= ’0’;
A_in (15) <= ’0’;
B_in (8) <= ’0’;
B_in (9) <= ’0’;
B_in (10) <= ’0’;
B_in (11) <= ’0’;
B_in (12) <= ’0’;
B_in (13) <= ’0’;
B_in (14) <= ’0’;
END bdf_type;
A port map
是将 entity
或 component
的实例连接到 signal
的构造。第 88 行有一个 port map
,但没有 entity
或 component
的实例。 (端口表明丢失的 component
可能是 arithmetic_circuit
)。
我猜你想要这样的东西:
some_instance_name : arithmetic_circuit
PORT MAP
(
C_in => Oper(2),
A => A_in ,
B => B_in ,
S => Oper(1 DOWNTO 0),
C_out => C_out,
G => G
);
更重要的是,你说是 Quartus 给出了这个错误。这段代码永远不会在任何东西上编译。 Quartus 是一个合成器。只有当你让它工作时,你才可以综合它,换句话说,当你使用模拟器测试它时。
我们似乎遇到了以下代码的问题。我们得到的错误是:
Error (10500): VHDL syntax error at pract3.vhd(88) near text "PORT"; expecting "end", or "(", or an identifier ("port" is a reserved keyword), or a concurrent statement
我们是 Quartus 的新手,所以我们不知道这是什么意思。
这是我们的代码
</p>
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY work;
ENTITY pract3 IS
PORT
(
clk : IN STD_LOGIC;
I_0 : IN STD_LOGIC_VECTOR (0 TO 3);
I_1 : IN STD_LOGIC_VECTOR (0 TO 3);
I_2 : IN STD_LOGIC_VECTOR (0 TO 3);
I_3 : IN STD_LOGIC_VECTOR (0 TO 3);
Oper : IN STD_LOGIC_VECTOR (2 DOWNTO 0);
act_dis1: OUT STD_LOGIC;
act_dis2: OUT STD_LOGIC;
act_dis4: OUT STD_LOGIC;
act_dis3: OUT STD_LOGIC;
C_out : OUT STD_LOGIC;
--D : OUT STD_LOGIC_VECTOR (0 TO 1);
display : OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
oper_led: OUT STD_LOGIC_VECTOR (2 DOWNTO 0)
);
END pract3;
ARCHITECTURE bdf_type OF pract3 IS
COMPONENT Practica2
PORT
(
clk : IN STD_LOGIC;
I0 : IN STD_LOGIC_VECTOR (0 TO 3);
I1 : IN STD_LOGIC_VECTOR (0 TO 3);
I2 : IN STD_LOGIC_VECTOR (0 TO 3);
I3 : IN STD_LOGIC_VECTOR (0 TO 3);
dec : OUT STD_LOGIC_VECTOR (0 TO 3);
--D : OUT STD_LOGIC_VECTOR (0 TO 1);
sal : OUT STD_LOGIC_VECTOR (6 DOWNTO 0));
END COMPONENT;
COMPONENT arithmetic_circuit
PORT
(
C_in : IN STD_LOGIC;
A : IN STD_LOGIC_VECTOR (15 DOWNTO 0);
B : IN STD_LOGIC_VECTOR (15 DOWNTO 0);
S : IN STD_LOGIC_VECTOR (1 DOWNTO 0);
C_out : OUT STD_LOGIC;
G : OUT STD_LOGIC_VECTOR (15 DOWNTO 0)
);
END COMPONENT;
COMPONENT binary_to_bcd
GENERIC
(
bits : INTEGER := 16; --bits of the binary input
digits : INTEGER := 4 --number of BCD digits to convert to
);
PORT
(
clk : IN STD_LOGIC; --sys clk
reset_n : IN STD_LOGIC;
ena : IN STD_LOGIC; --enable
binary : IN STD_LOGIC_VECTOR(bits -1 DOWNTO 0); --num to convert
busy : OUT STD_LOGIC; --indicates conversion in progress
bcd : OUT STD_LOGIC_VECTOR(digits *4-1 DOWNTO 0) --BCD number
);
END COMPONENT;
SIGNAL A_in : STD_LOGIC_VECTOR (15 DOWNTO 0);
SIGNAL B_in : STD_LOGIC_VECTOR (15 DOWNTO 0);
SIGNAL BCD : STD_LOGIC_VECTOR (0 TO 15);
SIGNAL G : STD_LOGIC_VECTOR (15 DOWNTO 0);
BEGIN
oper_led <= Oper;
b2v_inst_Practica2 : Practica2
PORT MAP
(
clk => clk ,
dip_1 => BCD(12 TO 15),
dip_2 => BCD(8 TO 11),
dip_3 => BCD(4 TO 7),
dip_4 => BCD(0 TO 3),
dec_D0 => act_dis1 ,
dec_D1 => act_dis2 ,
dec_D2 => act_dis3 ,
dec_D3 => act_dis4 ,
--D => D,
sal => display
);
PORT MAP //Error is in this line!!!!!!!!!
(
C_in => Oper(2),
A => A_in ,
B => B_in ,
S => Oper(1 DOWNTO 0),
C_out => C_out,
G => G
);
stbin : binary_to_bcd
PORT MAP
(
CLK => clk ,
reset_n => ’1’,
ena => ’1’,
binary => G,
bcd => BCD
);
A_in(7 DOWNTO 4) <= I_0;
A_in(3 DOWNTO 0) <= I_1;
B_in(7 DOWNTO 4) <= I_2;
B_in(3 DOWNTO 0) <= I_3;
A_in (8) <= ’0’;
A_in (9) <= ’0’;
A_in (10) <= ’0’;
A_in (11) <= ’0’;
A_in (12) <= ’0’;
A_in (13) <= ’0’;
A_in (14) <= ’0’;
A_in (15) <= ’0’;
B_in (8) <= ’0’;
B_in (9) <= ’0’;
B_in (10) <= ’0’;
B_in (11) <= ’0’;
B_in (12) <= ’0’;
B_in (13) <= ’0’;
B_in (14) <= ’0’;
END bdf_type;
A port map
是将 entity
或 component
的实例连接到 signal
的构造。第 88 行有一个 port map
,但没有 entity
或 component
的实例。 (端口表明丢失的 component
可能是 arithmetic_circuit
)。
我猜你想要这样的东西:
some_instance_name : arithmetic_circuit
PORT MAP
(
C_in => Oper(2),
A => A_in ,
B => B_in ,
S => Oper(1 DOWNTO 0),
C_out => C_out,
G => G
);
更重要的是,你说是 Quartus 给出了这个错误。这段代码永远不会在任何东西上编译。 Quartus 是一个合成器。只有当你让它工作时,你才可以综合它,换句话说,当你使用模拟器测试它时。