自己编写的一个小程序,功能是:时钟信号CLK1使数加1,CLK2使数减1,最后设置好的这个数要和一个给定的数进行大小比较。
可编译时报错,实在不知道怎么改:
Error: Can't resolve multiple constant drivers for net "D_OUT[7]" at zdz.vhd(15)
共6条
1/1 1 跳转至页
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY zdz IS
PORT(CLK1:IN STD_LOGIC; --加1单脉冲
CLK2:IN STD_LOGIC; --减1单脉冲
RST:IN STD_LOGIC;
DA :OUT STD_LOGIC; --LED指示信号
DATA:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));
END zdz;
ARCHITECTURE behav OF zdz IS
SIGNAL D_IN : STD_LOGIC_VECTOR(7 DOWNTO 0);
SIGNAL D_OUT: STD_LOGIC_VECTOR(7 DOWNTO 0);
BEGIN
P1:PROCESS(CLK1,RST)
BEGIN
IF RST='1' THEN D_OUT<="10001000";
ELSIF CLK1'EVENT AND CLK1='1' THEN
D_OUT<=D_OUT+1;
END IF;
END PROCESS P1;
P2:PROCESS(CLK2,RST)
BEGIN
IF RST='1' THEN D_OUT<="10001000";
ELSIF CLK2'EVENT AND CLK2='1' THEN
D_OUT<=D_OUT-1;
END IF;
END PROCESS P2;
-----------------------------------------
DATA<=D_OUT;
D_IN<="10101010";
P3:PROCESS(D_OUT)
BEGIN
IF D_OUT > D_IN THEN DA<='1';
ELSE DA<='0';
END IF;
END PROCESS P3;
END behav;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY zdz IS
PORT(CLK1:IN STD_LOGIC; --加1单脉冲
CLK2:IN STD_LOGIC; --减1单脉冲
RST:IN STD_LOGIC;
DA :OUT STD_LOGIC; --LED指示信号
DATA:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));
END zdz;
ARCHITECTURE behav OF zdz IS
SIGNAL D_IN : STD_LOGIC_VECTOR(7 DOWNTO 0);
SIGNAL D_OUT: STD_LOGIC_VECTOR(7 DOWNTO 0);
BEGIN
P1:PROCESS(CLK1,RST)
BEGIN
IF RST='1' THEN D_OUT<="10001000";
ELSIF CLK1'EVENT AND CLK1='1' THEN
D_OUT<=D_OUT+1;
END IF;
END PROCESS P1;
P2:PROCESS(CLK2,RST)
BEGIN
IF RST='1' THEN D_OUT<="10001000";
ELSIF CLK2'EVENT AND CLK2='1' THEN
D_OUT<=D_OUT-1;
END IF;
END PROCESS P2;
-----------------------------------------
DATA<=D_OUT;
D_IN<="10101010";
P3:PROCESS(D_OUT)
BEGIN
IF D_OUT > D_IN THEN DA<='1';
ELSE DA<='0';
END IF;
END PROCESS P3;
END behav;
我改了一下,clk1和clk2为两个输入信号端,非时钟。
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY zdz IS
PORT(CLK1:IN std_logic; --加1输入信号
CLK2:IN std_logic; --减1输入信号
RST:IN std_logic;
DA :OUT std_logic; --LED指示信号
DATA:OUT std_logic_vector(7 DOWNTO 0));
END zdz;
ARCHITECTURE behav OF zdz IS
SIGNAL D_OUT: std_logic_vector(7 DOWNTO 0);
BEGIN
P1:PROCESS(CLK1,CLK2,RST)
BEGIN
IF RST='1' THEN D_OUT<="00001000";
ELSIF clk1='1' THEN
D_OUT<=D_OUT+1;
ELSIF clk2='1' THEN
D_OUT<=D_OUT-1;
END IF;
END PROCESS P1;
-----------------------------------------
P3:PROCESS(D_OUT)
VARIABLE D_IN : STD_LOGIC_VECTOR(7 DOWNTO 0):="00001000";
BEGIN
IF D_OUT > D_IN THEN DA<='1';
ELSE DA<='0';
END IF;
END PROCESS P3;
DATA<=D_OUT;
END behav;
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY zdz IS
PORT(CLK1:IN std_logic; --加1输入信号
CLK2:IN std_logic; --减1输入信号
RST:IN std_logic;
DA :OUT std_logic; --LED指示信号
DATA:OUT std_logic_vector(7 DOWNTO 0));
END zdz;
ARCHITECTURE behav OF zdz IS
SIGNAL D_OUT: std_logic_vector(7 DOWNTO 0);
BEGIN
P1:PROCESS(CLK1,CLK2,RST)
BEGIN
IF RST='1' THEN D_OUT<="00001000";
ELSIF clk1='1' THEN
D_OUT<=D_OUT+1;
ELSIF clk2='1' THEN
D_OUT<=D_OUT-1;
END IF;
END PROCESS P1;
-----------------------------------------
P3:PROCESS(D_OUT)
VARIABLE D_IN : STD_LOGIC_VECTOR(7 DOWNTO 0):="00001000";
BEGIN
IF D_OUT > D_IN THEN DA<='1';
ELSE DA<='0';
END IF;
END PROCESS P3;
DATA<=D_OUT;
END behav;
共6条
1/1 1 跳转至页
回复
| 有奖活动 | |
|---|---|
| 这个春节你犒赏自己什么了?分享你的故事,有奖征集 | |
| 2026年“我要开发板活动”第三季,开始了! | |
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
我要赚赏金打赏帖 |
|
|---|---|
| 【S32K3XX】SWT 模块使用被打赏¥22元 | |
| 【分享开发笔记,赚取280元手持便携数字示波器】32位linux内核内存映射896的理解被打赏¥14元 | |
| AG32VH407开发板例程体系的构成与使用方法被打赏¥20元 | |
| 【S32K3XX】SEMA42 模块使用被打赏¥26元 | |
| 【S32K3XX】XRDC 功能使用被打赏¥22元 | |
| 【分享开发笔记,赚取280元手持便携数字示波器】8051使用keil编译的程序移动心得被打赏¥21元 | |
| 【S32K3XX】HSE 密钥管理被打赏¥17元 | |
| 【S32K3XX】Standby RAM的初始化流程被打赏¥18元 | |
| Gravity:中英文语音合成模块V2.0及其串口控制被打赏¥24元 | |
| 全彩色度变化图的绘制被打赏¥27元 | |
我要赚赏金
