搜索
bottom↓
回复: 12

verilog如何实现串行接收8位数据转换为16位,下面这样是否....

[复制链接]

出0入0汤圆

发表于 2012-11-7 08:43:24 | 显示全部楼层 |阅读模式
verilog如何实现串行接收8位数据转换为16位, 总是逃脱不了在一个时钟周期啊?
reg [31:0]data;
always @(posedge clk or posedge uart_data_com)
     if(Quart_data_com)
           begin
              data<=data<<4'd8;
               data <=uart_data_com
          end
这样不行吧,如何实现新接收的数据在data的最低8位,然后 原来的数据顺序左移?
            

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2012-11-7 14:21:35 | 显示全部楼层
data <= {data[23:0],uart_data_com};

出0入0汤圆

 楼主| 发表于 2012-11-7 16:10:52 | 显示全部楼层
DepravedLucien 发表于 2012-11-7 14:21
data

一个时钟周期内可以  正确完成此操作吗 ?

出0入0汤圆

发表于 2012-11-7 17:35:21 | 显示全部楼层
german010 发表于 2012-11-7 16:10
一个时钟周期内可以  正确完成此操作吗 ?

你的程序寫錯了

出0入0汤圆

发表于 2012-11-7 19:05:11 | 显示全部楼层
sky5566 发表于 2012-11-7 17:35
你的程序寫錯了

左移啊!错了么?

哪里啊?

出0入0汤圆

发表于 2012-11-7 19:06:20 | 显示全部楼层
german010 发表于 2012-11-7 16:10
一个时钟周期内可以  正确完成此操作吗 ?

可以啊 ,不是你想的那样顺序操作的   如果你是这样想的话  呵呵

出0入0汤圆

发表于 2012-11-7 19:06:43 | 显示全部楼层
sky5566 发表于 2012-11-7 17:35
你的程序寫錯了

看错了  我以为你在回复我呢

出0入0汤圆

发表于 2012-11-8 10:13:08 | 显示全部楼层
你这个事非阻塞的吧,弄个阻塞的试试

出0入0汤圆

发表于 2012-11-16 18:27:41 来自手机 | 显示全部楼层
做一个二分频,然后拼位宽

出0入0汤圆

发表于 2012-11-16 21:42:41 | 显示全部楼层
module bit8tobit16
(
        input              clk    ,
        input              rst_n  ,
        input       [7 :0] dat_in ,
        output reg  [15:0] dat_out,
    output             vld_out
);
reg       div2_reg;
reg [7:0] dat_reg ;
always @(posedge clk or negedge rst_n)
begin
        if(rst_n == 1'b0)
                div2_reg <= 1'd0;
        else
                div2_reg <= ~div2_reg;
end

always @(posedge clk or negedge rst_n)
begin
        if(rst_n == 1'b0)
                dat_reg <= 8'd0;
        else
                dat_reg <= dat_in;
end

always @(posedge clk or negedge rst_n)
begin
        if(rst_n == 1'b0)
                dat_out <= 16'd0;
        else
                dat_out <= {dat_reg,dat_in};
end
assign vld_out = div_2reg;
endmodule

出0入0汤圆

 楼主| 发表于 2012-11-17 09:30:42 | 显示全部楼层
按着fxyzhqr坛友的建议,
我用 阻塞了,效果还好,然后直接解析

出0入0汤圆

发表于 2012-11-20 22:16:13 | 显示全部楼层
加个fifo不行么

出0入0汤圆

 楼主| 发表于 2012-11-21 11:01:45 | 显示全部楼层
理论应该可以,可能我哪里没弄好,
现在省事了,直接去了fifo,直接解析更简单
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 07:22

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表