在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 5135|回复: 10

[原创] 【求救】简单自动售饮料机 哪里错了?

[复制链接]
发表于 2010-5-19 20:48:42 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer:   
//
// Create Date:    20:13:02 05/19/2010
// Design Name:   
// Module Name:    drink_machine
// Project Name:   drink_machine
// Target Devices:  xc2s300e
// Tool versions:  Xilinx ISE 9.1
// Description:   简单的自动售饮料机,假定一瓶饮料价格为2元5角,投币分别为一元和五角两种硬币。
//       每次投入硬币为一元或者五角,如果投入金币的总和是两元五角时,输出一瓶饮料;
//       如果投币总和是三元时,输出一瓶饮料,并且找回五角。
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
//////////////////////////////////////////////////////////////////////////////////
module drink_machine(onedollar_in,fifty_in,fifty_out,drink_out,rst,clk);
parameter IDLE   = 0;
parameter ZERO_FIFTY = 1;
parameter ONE   = 2;
parameter ONE_FIFTY = 3;
parameter TWO   = 4;
input  fifty_in,onedollar_in,rst,clk;
output fifty_out,drink_out;
reg fifty_out,drink_out;
reg[2:0] state,next_state;
[email=always@(onedollar_in]always@(onedollar_in[/email] or fifty_in or rst)
begin
fifty_out <= 0;
drink_out <= 0;
if(!rst)
  state  <= IDLE;
else
  begin
  state  <= next_state;
  case(next_state)
  IDLE:
    if(fifty_in)
    state <= ZERO_FIFTY;
    else if(onedollar_in)
    state <=  ONE_FIFTY;
  ZERO_FIFTY:
    if(fifty_in)
    state <= ONE;
    else if(onedollar_in)
    state <= ONE_FIFTY;
  ONE:
    if(fifty_in)
    state <= ONE_FIFTY;
    else if(onedollar_in)
    state <= TWO;
  ONE_FIFTY:
    if(fifty_in)
    state <= TWO;
    else if(onedollar_in)
    begin
     state   <= IDLE;
     drink_out <= 1;
    end
  TWO:
    if(fifty_in)
    begin
    state   <= IDLE;
    drink_out <= 1;
    end
    else if(onedollar_in)
    begin
     state   <= IDLE;
     drink_out <= 1;
     fifty_out <= 1;
    end
  endcase
end
end
[email=always@(posedge]always@(posedge[/email] clk)
begin
next_state <= state;
end
endmodule
发表于 2010-5-20 08:55:32 | 显示全部楼层
case每个分支最好都对相同的一些寄存器赋值,case一定要加default。if else最好一一配对。有一个if就要一个else而且if里赋值的寄存器。在else里也要写出来。这些是容易产生latch的。
在这里你的状态机和输出最好分开两个always来写。
fifty_out <= 0;
drink_out <= 0;

if(!rst)
  state  <= IDLE;
else
  begin
  state  <= next_state;
红色语句是不需要的。
发表于 2010-5-22 18:38:49 | 显示全部楼层
"<= " need to modify to " = " in combination block.
发表于 2010-5-22 21:30:49 | 显示全部楼层
后一个always语句是干什么的?有必要吗?
发表于 2010-5-23 10:46:00 | 显示全部楼层
第二个always block是用来把将上一个状态(nxt_state)在clk positive posedge来时,变成现在的状况(state).属於sequence circuit.

第一个always block是用根据目前的输入讯号来决定下一个状态是什么.属於combination circuit.
发表于 2010-6-2 09:23:55 | 显示全部楼层
这样写的话,仿真没问题,在综合中就会碰到问题,因为next_state分别在2个always中进行了赋值所以不可综合,我认为你只要保留前面的组合逻辑就可以了。还请高手指点!
发表于 2010-6-3 17:20:12 | 显示全部楼层
module drink_machine(rst,clk,onedollar_in,fifty_in,fifty_out,drink_out);

parameter IDLE   = 0;
parameter ZERO_FIFTY = 1;
parameter ONE   = 2;
parameter ONE_FIFTY = 3;
parameter TWO   = 4;

input  clk;
input  fifty_in;
input  onedollar_in;
input  rst;
output fifty_out;
output drink_out;

reg fifty_out,drink_out;
reg[2:0] state,next_state;

always@(onedollar_in or fifty_in or rst)
begin
if(!rst)
begin
  fifty_out = 0;
  drink_out = 0;
  state = IDLE;
end
else
  begin
  case(next_state)
  IDLE:
    begin
    fifty_out = 0;
    drink_out = 0;
    if(fifty_in)
    state = ZERO_FIFTY;
    else if(onedollar_in)
    state =  ONE_FIFTY;
    end
  ZERO_FIFTY:
    if(fifty_in)
    state = ONE;
    else if(onedollar_in)
    state = ONE_FIFTY;
  ONE:
    if(fifty_in)
    state = ONE_FIFTY;
    else if(onedollar_in)
    state = TWO;
  ONE_FIFTY:
    if(fifty_in)
    state = TWO;
    else if(onedollar_in)
    begin
     state   = IDLE;
     drink_out = 1;
    end
  TWO:
    if(fifty_in)
    begin
    state   = IDLE;
    drink_out = 1;
    end
    else if(onedollar_in)
    begin
     state   = IDLE;
     drink_out = 1;
     fifty_out = 1;
    end
   default: state = IDLE;
  endcase
  end
end

always@(posedge clk)
begin
next_state <= state;
end

endmodule
发表于 2010-6-3 17:21:13 | 显示全部楼层
改了下,你再试试
 楼主| 发表于 2010-6-3 19:13:35 | 显示全部楼层
谢谢啊哈,借鉴2楼的建议,我已经解决了这个问题!~
发表于 2016-8-10 16:26:32 | 显示全部楼层
// Description:   简单的自动售饮料机,假定一瓶饮料价格为2元5角,投币分别为一元和五角两种硬币。
//       每次投入硬币为一元或者五角,如果投入金币的总和是两元五角时,输出一瓶饮料;
//       如果投币总和是三元时,输出一瓶饮料,并且找回五角。
//

//   三段式方法


module drink_machine(rst,clk,onedollar_in,fifty_in,fifty_out,drink_out);

parameter IDLE   = 0;
parameter ZERO_FIFTY = 1;
parameter ONE   = 2;
parameter ONE_FIFTY = 3;
parameter TWO   = 4;

input  clk;
input  fifty_in;
input  onedollar_in;
input  rst;
output fifty_out;
output drink_out;

reg fifty_out,drink_out;
reg[2:0] state,next_state;

//state switch each cycle
always@(posedge clk or negedge rst)
begin
  if(!rst)
     state <= IDLE;
  else
     state <= next_state;
end

//next_state judge
always@(onedollar_in or fifty_in or rst)
begin
if(!rst)
begin
  next_state = IDLE;
end
else
  begin
  case(state)
  IDLE:
    begin
      if(fifty_in)
        next_state = ZERO_FIFTY;
      else if(onedollar_in)
        next_state =  ONE;
    end
  ZERO_FIFTY:
    begin
      if(fifty_in)
        next_state = ONE;
      else if(onedollar_in)
        next_state = ONE_FIFTY;
    end
  ONE:
    begin
      if(fifty_in)
        next_state = ONE_FIFTY;
      else if(onedollar_in)
        next_state = TWO;
    end
  ONE_FIFTY:
    begin
      if(fifty_in)
        next_state = TWO;
      else if(onedollar_in)
        next_state   = IDLE;
    end
  TWO:
    begin
        next_state   = IDLE;
    end
  default: next_state = IDLE;
  endcase
  end

//reg output to remove glitch
always@(posedge clk or negedge rst)
begin
  if(!rst)
     begin
       drink_out <= 0;
     end
  else if (next_state==TWO)
     begin
       drink_out <= 1;
     end
end
always@(posedge clk or negedge rst)
begin
  if(!rst)
     begin
       fifty_out <= 0;
     end
  else if ((next_state==TWO)&&(onedollar_in))
     begin
       fifty_out <= 1;
     end
end   




endmodule
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条


小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-1-3 12:30 , Processed in 0.041432 second(s), 9 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表