题解 | #非整数倍数据位宽转换24to128#

非整数倍数据位宽转换24to128

http://www.nowcoder.com/practice/6312169e30a645bba5d832c7313c64cc

用144bit位移寄存器实现,整理清楚循环,每三次一个循环,第一次移位6次(全部更新),第二次移位5次(留一个旧的,下次需要低2byte),第三次移位5次(留一个旧的,下次需要低1byte),然后循环。

`timescale 1ns/1ns

module width_24to128(
	input 				clk 		,   
	input 				rst_n		,
	input				valid_in	,
	input	[23:0]		data_in		,
 
 	output	reg			valid_out	,
	output  reg [127:0]	data_out
);
    //parameter
    parameter N = 6;
    parameter BYTE_N = 3;
    
    //defination 
    reg [143 : 0] SR; 
    
    reg [2 : 0] cnt;
    wire add_cnt;
    wire end_cnt;

    reg [1 : 0] cnt_byte;
    wire add_cnt_byte;
    wire end_cnt_byte;
    //output
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) SR <= 'd0;
        else if(add_cnt) SR <= {SR[119 : 0], data_in};
    end
    
    assign add_cnt = valid_in;
    assign end_cnt = (add_cnt && (cnt == N - 1) && (cnt_byte == 0)) | (add_cnt && (cnt == N - 2) && (cnt_byte != 0));
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) cnt <= 'd0;
        else if(end_cnt) cnt <= 'd0;
        else if(add_cnt) cnt <= cnt + 1'b1;
    end
    
    assign add_cnt_byte = end_cnt;
    assign end_cnt_byte = add_cnt_byte && (cnt_byte == BYTE_N - 1);
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) cnt_byte <= 'd0;
        else if(end_cnt_byte) cnt_byte <= 'd0;
        else if(add_cnt_byte) cnt_byte <= cnt_byte + 1'b1;
    end
    
    
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) data_out <= 'd0;
        else if(end_cnt) 
            case (cnt_byte)
                2'b00 : data_out <= {SR[119 : 0], data_in[7 : 0]};
                2'b01 : data_out <= {SR[111 : 0], data_in[15 : 0]};
                2'b10 : data_out <= {SR[103 : 0], data_in[23 : 0]};
                default :;
            endcase
    end
    
    always@(posedge clk or negedge rst_n)begin
        if(!rst_n) valid_out <= 'd0;
        else if(end_cnt) valid_out <= 1'b1;
        else valid_out <= 1'b0;
    end
endmodule
全部评论

相关推荐

关于我大学本科四年,想了很多,但还是不知道该怎么动笔&nbsp;“大学四年,是我从懵懂少年走向职场青年的转折期。这一路跌跌撞撞,有迷茫,有遗憾,也有成长和决心。”&nbsp;大一刚进来时仍然有高中那股学习劲,经常一个人去图书馆学高等数学,但后面劲头一过便开始在宿舍开启躺平生活(现在想想那段时间真的很爽,无忧无虑)。由于大一担任班干部,所以经常要跟其他班的班干部交流,在此期间认识了隔壁班的一位女生,短发而很可爱,因为很多团建还有比赛都是我们两班一起参加的,而且我和她都是负责人,所以交集很多,后面慢慢地彼此对产生了好感,所以在大一刚开学的2个月后,我们在一起了,彼此之前都是初恋。但当时我真的是太太太直男了,对感情的想...
真烦好烦真烦:骗哥们可以,别把你自己也骗到了就行。哥们被你骗了真无所谓的,打个哈哈就过了。但希望你打完这段话后擦一下眼角,别让眼泪掉在手机屏幕上了就行。你说的这些话,哥们信一下也是没什么的。还能让你有个心里安慰,但这种话说出来骗骗兄弟就差不多得了,哥们信你一下也不会少块肉,但是你别搞得自己也当真了就行。哥们被你骗一下是真无所谓的,兄弟笑笑也就过去了。真不是哥们想要破你防,你擦擦眼泪好好想想,除了兄弟谁还会信你这些话?
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务