亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? altera_mf.v

?? 一本老師推薦的經典的VHDL覆蓋基礎的入門書籍
?? V
?? 第 1 頁 / 共 5 頁
字號:
    reg [width_out+1:0] result_full;
    reg [width_out+1:0] result_full2;

    reg a;

    // INTERNAL WIRE DECLARATION
    wire [width_out:0] temp_sum_wire;
    wire cout;
    wire cout_int_wire;
    wire cout_delayed_wire;
    wire overflow_int_wire;
    wire [width_out+1:0] result_int_wire;

    // INTERNAL TRI DECLARATION

    tri0 aclr_int;
    tri0 sign_data_int;
    tri0 sload_int;

    tri1 clken_int;
    tri1 add_sub_int;

    // LOCAL INTEGER DECLARATION
    integer head;
    integer i;

    // INITIAL CONSTRUCT BLOCK
    initial
    begin
    
        // Checking for invalid parameters
        if( width_in <= 0 )
        begin
            $display("Error! Value of width_in parameter must be greater than 0.");
            $stop;
        end

        if( width_out <= 0 )
        begin
            $display("Error! Value of width_out parameter must be greater than 0.");
            $stop;
        end
        
        if( extra_latency > width_out )
        begin
            $display("Info: Value of extra_latency parameter should be lower than width_out parameter for better performance/utilization.");
        end
        
        if( width_in > width_out )
        begin
            $display("Error! Value of width_in parameter should be lower than or equal to width_out.");
            $stop;
        end
    
        result = 0;
        cout_delayed = 0;
        overflow = 0;
        head = 0;
        result_int = 0;
        for (i = 0; i <= extra_latency; i = i +1)
        begin
            result_pipe [i] = 0;
        end
    end

    // ALWAYS CONSTRUCT BLOCK
    always @(posedge clock or posedge aclr_int)
    begin

        if (aclr_int == 1)
        begin
            result_int = 0;
            result = 0;
            overflow = 0;
            cout_delayed = 0;
            for (i = 0; i <= extra_latency; i = i +1)
            begin
                result_pipe [i] = 0;
            end
        end
        else
        begin
            if (clken_int == 1)
            begin
                //get result from output register
                if (extra_latency > 0)
                begin
                    result_pipe [head] = {
                                          result_int [width_out+1],
                                          {cout_int_wire, result_int [width_out-1:0]}
                                         };

                    head = (head + 1) % (extra_latency);

                    result_full = result_pipe [head];
                    cout_delayed = result_full [width_out];
                    result = result_full [width_out-1:0];
                    overflow = result_full [width_out+1];
                end
                else
                begin
                    result = temp_sum_wire;
                    overflow = overflow_int_wire;
                end

                result_int = {overflow_int_wire, {cout_int_wire, temp_sum_wire [width_out-1:0]}};
            end
        end
    end


    always @ (data or cin or add_sub_int or sign_data_int or
              result_int_wire [width_out -1:0] or sload_int or aclr_int)
    begin


        // If asynchronous clear, reset and skip.
        if (aclr_int == 1)  // asynchronous clear
        begin
            cout_int = 0;
            overflow_int = 0;
        end
        else
        begin

            if ((lpm_representation == "SIGNED") || (sign_data_int == 1))
            begin
                zeropad = (data [width_in-1] ==0) ? 0 : -1;
            end
            else
            begin
                zeropad = 0;
            end

            fb_int = (sload_int == 1'b1) ? 0 : result_int_wire [width_out-1:0];
            data_int = {zeropad, data};

            if ((add_sub_int == 1) || (sload_int == 1))
            begin
                cin_int = ((sload_int == 1'b1) ? 0 : ((cin === 1'bz) ? 0 : cin));
                temp_sum = fb_int + data_int + cin_int;
                cout_int = temp_sum [width_out];
            end
            else
            begin
                cin_int = (cin === 1'bz) ? 1 : cin;
                borrow = ~cin_int;

                temp_sum = fb_int - data_int - borrow;

                result_full2 = data_int + borrow;
                cout_int = (fb_int >= result_full2) ? 1 : 0;
            end

            if ((lpm_representation == "SIGNED") || (sign_data_int == 1))
            begin
                a = (data [width_in-1] ~^ fb_int [width_out-1]) ^ (~add_sub_int);
                overflow_int = a & (fb_int [width_out-1] ^ temp_sum[width_out-1]);
            end
            else
            begin
                overflow_int = (add_sub_int == 1) ? cout_int : ~cout_int;
            end

            if (sload_int == 1)
            begin
                cout_int = !add_sub_int;
                overflow_int = 0;
            end
        end
    end

    // CONTINOUS ASSIGNMENT

    // Get the input data and control signals.
    assign sign_data_int = sign_data;
    assign sload_int =  sload;
    assign add_sub_int = add_sub;

    assign clken_int = clken;
    assign aclr_int = aclr;
    assign result_int_wire = result_int;
    assign temp_sum_wire = temp_sum;
    assign cout_int_wire = cout_int;
    assign overflow_int_wire = overflow_int;
    assign cout = (extra_latency == 0) ? cout_int_wire : cout_delayed_wire;
    assign cout_delayed_wire = cout_delayed;

endmodule   // End of altaccumulate

// END OF MODULE

//--------------------------------------------------------------------------
// Module Name      : altmult_accum
//
// Description      : a*b + x (MAC)
//
// Limitation       : Stratix DSP block
//
// Results expected : signed & unsigned, maximum of 3 pipelines(latency) each.
//
//--------------------------------------------------------------------------

`timescale 1 ps / 1 ps

module altmult_accum (dataa, 
                      datab, 
                      scanina,
                      scaninb,
                      sourcea,
                      sourceb,
                      accum_sload_upper_data,
                      addnsub, 
                      accum_sload, 
                      signa, 
                      signb,
                      clock0, 
                      clock1, 
                      clock2, 
                      clock3,
                      ena0, 
                      ena1, 
                      ena2, 
                      ena3,
                      aclr0, 
                      aclr1, 
                      aclr2, 
                      aclr3,
                      result, 
                      overflow, 
                      scanouta, 
                      scanoutb,
                      mult_round,
                      mult_saturation,
                      accum_round,
                      accum_saturation,
                      mult_is_saturated,
                      accum_is_saturated);

    // ---------------------
    // PARAMETER DECLARATION
    // ---------------------
    parameter width_a                   = 1;
    parameter width_b                   = 1;
    parameter width_result              = 2;
    parameter input_reg_a               = "CLOCK0";
    parameter input_aclr_a              = "ACLR3";
    parameter input_reg_b               = "CLOCK0";
    parameter input_aclr_b              = "ACLR3";
    parameter addnsub_reg               = "CLOCK0";
    parameter addnsub_aclr              = "ACLR3";
    parameter addnsub_pipeline_reg      = "CLOCK0";
    parameter addnsub_pipeline_aclr     = "ACLR3";
    parameter accum_direction           = "ADD";
    parameter accum_sload_reg           = "CLOCK0";
    parameter accum_sload_aclr          = "ACLR3";
    parameter accum_sload_pipeline_reg  = "CLOCK0";
    parameter accum_sload_pipeline_aclr = "ACLR3";
    parameter representation_a          = "UNSIGNED";
    parameter sign_reg_a                = "CLOCK0";
    parameter sign_aclr_a               = "ACLR3";
    parameter sign_pipeline_reg_a       = "CLOCK0";
    parameter sign_pipeline_aclr_a      = "ACLR3";
    parameter representation_b          = "UNSIGNED";
    parameter sign_reg_b                = "CLOCK0";
    parameter sign_aclr_b               = "ACLR3";
    parameter sign_pipeline_reg_b       = "CLOCK0";
    parameter sign_pipeline_aclr_b      = "ACLR3";
    parameter multiplier_reg            = "CLOCK0";
    parameter multiplier_aclr           = "ACLR3";
    parameter output_reg                = "CLOCK0";
    parameter output_aclr               = "ACLR3";
    parameter lpm_type                  = "altmult_accum";

    parameter extra_multiplier_latency       = 0;
    parameter extra_accumulator_latency      = 0;
    parameter dedicated_multiplier_circuitry = "AUTO";
    parameter dsp_block_balancing            = "AUTO";
    parameter intended_device_family         = "Stratix";

    // StratixII related parameter
    parameter accum_round_aclr = "ACLR3";
    parameter accum_round_pipeline_aclr = "ACLR3";
    parameter accum_round_pipeline_reg = "CLOCK0";
    parameter accum_round_reg = "CLOCK0";
    parameter accum_saturation_aclr = "ACLR3";
    parameter accum_saturation_pipeline_aclr = "ACLR3";
    parameter accum_saturation_pipeline_reg = "CLOCK0";
    parameter accum_saturation_reg = "CLOCK0";
    parameter accum_sload_upper_data_aclr = "ACLR3";
    parameter accum_sload_upper_data_pipeline_aclr = "ACLR3";
    parameter accum_sload_upper_data_pipeline_reg = "CLOCK0";
    parameter accum_sload_upper_data_reg = "CLOCK0";
    parameter mult_round_aclr = "ACLR3";
    parameter mult_round_reg = "CLOCK0";
    parameter mult_saturation_aclr = "ACLR3";
    parameter mult_saturation_reg = "CLOCK0";
    
    parameter input_source_a  = "DATAA";
    parameter input_source_b  = "DATAB";
    parameter width_upper_data = 1;
    parameter multiplier_rounding = "NO";
    parameter multiplier_saturation = "NO";
    parameter accumulator_rounding = "NO";
    parameter accumulator_saturation = "NO";
    parameter port_mult_is_saturated = "UNUSED";
    parameter port_accum_is_saturated = "UNUSED";


    // ----------------
    // PORT DECLARATION
    // ----------------

    // data input ports
    input [width_a -1 : 0] dataa;
    input [width_b -1 : 0] datab;
    input [width_a -1 : 0] scanina;
    input [width_b -1 : 0] scaninb;
    input sourcea;
    input sourceb;
    input [width_result -1 : width_result - width_upper_data] accum_sload_upper_data;

    // control signals
    input addnsub;
    input accum_sload;
    input signa;
    input signb;

    // clock ports
    input clock0;
    input clock1;
    input clock2;
    input clock3;

    // clock enable ports
    input ena0;
    input ena1;
    input ena2;
    input ena3;

    // clear ports
    input aclr0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人a在线| 美腿丝袜在线亚洲一区| 亚洲成a人v欧美综合天堂下载 | 色综合天天综合网天天狠天天| 在线一区二区三区做爰视频网站| 日韩一区二区电影在线| 国产精品网站在线观看| 亚洲一二三区视频在线观看| 蜜臀99久久精品久久久久久软件| 国产xxx精品视频大全| 欧美影院一区二区| 久久综合久色欧美综合狠狠| 日韩美女精品在线| 麻豆一区二区在线| 日本精品一区二区三区四区的功能| 91精品欧美综合在线观看最新| 久久只精品国产| 一区二区三区不卡在线观看| 精一区二区三区| 色天使久久综合网天天| 久久免费的精品国产v∧| 亚洲一区二区美女| 丁香天五香天堂综合| 欧美日韩情趣电影| 国产精品三级av| 日韩黄色在线观看| 91在线视频在线| www国产精品av| 亚洲123区在线观看| 成人av在线网站| 日韩欧美中文字幕一区| 亚洲一区二区三区免费视频| 成人一区二区三区在线观看| 日韩欧美成人一区| 亚洲国产综合人成综合网站| 国产成人综合在线观看| 日韩午夜电影在线观看| 亚洲综合一区二区精品导航| 成人美女在线观看| 欧美精品一区视频| 日本aⅴ免费视频一区二区三区| 91蜜桃在线免费视频| 欧美精品一区二区久久婷婷| 国产日本欧美一区二区| 日本不卡视频一二三区| 欧洲av在线精品| 国产精品成人一区二区三区夜夜夜| 国产在线视频一区二区三区| 宅男噜噜噜66一区二区66| 一区二区三区日韩精品视频| 欧洲国内综合视频| 中文字幕日韩av资源站| 国产精品中文字幕欧美| 欧美成人aa大片| 日韩av一区二| 7777精品伊人久久久大香线蕉超级流畅 | 一区二区三区久久| 91啪亚洲精品| 日韩毛片高清在线播放| 99久久综合99久久综合网站| 欧美高清一级片在线观看| 国产成人在线观看| 久久精品人人做人人综合| 激情综合网天天干| 2021久久国产精品不只是精品| 日本成人在线不卡视频| 7777精品伊人久久久大香线蕉超级流畅| 亚洲综合男人的天堂| 91国产精品成人| 亚洲国产日产av| 欧美日韩精品一区二区在线播放| 一区二区三区欧美视频| 91精品91久久久中77777| 亚洲日本电影在线| 一本一道久久a久久精品| 亚洲美女在线一区| 91成人网在线| 性做久久久久久久久| 欧美人妇做爰xxxⅹ性高电影 | 日韩欧美一级片| 韩国女主播一区| 久久女同精品一区二区| 国产高清在线精品| 国产精品久久毛片| av爱爱亚洲一区| 伊人夜夜躁av伊人久久| 欧美日韩免费观看一区二区三区 | 日韩免费高清视频| 国产一区 二区| 中文一区一区三区高中清不卡| 99视频精品在线| 亚洲一区二区五区| 欧美日韩精品三区| 久久精品噜噜噜成人88aⅴ| 国产三区在线成人av| 成人av中文字幕| 亚洲国产精品天堂| 欧美大片顶级少妇| 成年人国产精品| 亚洲精品久久7777| 91精品国产综合久久久久久| 国产一区二区成人久久免费影院| 国产片一区二区| 91黄色在线观看| 免费视频一区二区| 国产日韩av一区| 日本丰满少妇一区二区三区| 日韩成人午夜精品| 欧美国产日产图区| 欧美日韩高清影院| 国内久久精品视频| 亚洲女女做受ⅹxx高潮| 欧美一区二区三区电影| 国产精品1区二区.| 亚洲女子a中天字幕| 欧美一卡二卡三卡四卡| 成人一区二区三区视频| 丝袜美腿亚洲综合| 日本一区二区三区久久久久久久久不| 色呦呦网站一区| 精品一区二区在线视频| 亚洲三级在线看| 2023国产精品视频| 在线视频一区二区免费| 狠狠色丁香婷婷综合| 亚洲一区中文在线| 久久精品欧美一区二区三区麻豆| 91福利在线导航| 国产aⅴ综合色| 免费国产亚洲视频| 亚洲欧美日韩中文字幕一区二区三区| 91精品国产综合久久久久久久| av高清久久久| 国产一区在线不卡| 日韩电影在线免费看| 亚洲乱码国产乱码精品精98午夜 | 国产精品伊人色| 日韩制服丝袜av| 中文字幕久久午夜不卡| 欧美精品vⅰdeose4hd| 成人sese在线| 国产制服丝袜一区| 午夜精品久久久久久| 18成人在线观看| 久久久高清一区二区三区| 欧美精品乱码久久久久久| www.66久久| 国产综合久久久久影院| 视频一区二区中文字幕| 亚洲裸体xxx| 国产欧美一二三区| 欧美变态凌虐bdsm| 欧美人xxxx| 欧美日韩一区久久| 91丨九色丨尤物| 大白屁股一区二区视频| 久久精品理论片| 免费人成在线不卡| 日韩电影免费一区| 亚洲va欧美va人人爽午夜| 亚洲激情中文1区| 亚洲欧洲综合另类在线| 亚洲欧洲在线观看av| 国产欧美日韩一区二区三区在线观看| 日韩午夜电影av| 欧美一区二区三区四区久久| 欧美欧美午夜aⅴ在线观看| 色婷婷亚洲婷婷| 色婷婷国产精品| 在线精品视频一区二区| 色美美综合视频| 色婷婷av一区二区| 欧美综合一区二区三区| 欧洲一区二区三区免费视频| 91蜜桃视频在线| 色噜噜狠狠色综合欧洲selulu| 97精品久久久午夜一区二区三区| 成人av免费在线观看| av影院午夜一区| 色婷婷综合中文久久一本| 在线亚洲一区观看| 欧美亚洲日本一区| 欧美日韩一本到| 欧美一区二区视频网站| 日韩三区在线观看| 欧美成人a视频| 国产亚洲欧美日韩日本| 欧美激情一区二区三区四区| 国产精品素人一区二区| 中文字幕亚洲不卡| 一区二区欧美国产| 亚洲mv在线观看| 久久国产日韩欧美精品| 狠狠色丁香九九婷婷综合五月| 国产福利一区二区三区在线视频| 日日摸夜夜添夜夜添国产精品| 美腿丝袜在线亚洲一区| 欧美a一区二区| 日韩电影一区二区三区| 免费久久99精品国产|