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

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

?? altera_mf_87.vhd

?? 一本老師推薦的經典的VHDL覆蓋基礎的入門書籍
?? VHD
?? 第 1 頁 / 共 5 頁
字號:
-- This function converts an integer to a string
function INT_TO_STR_RAM (value : in integer) return string is
variable ivalue : integer := 0;
variable index  : integer := 0;
variable digit : integer := 0;
variable line_no: string(8 downto 1) := "        ";
begin
    ivalue := value;
    index := 1;

    while (ivalue > 0) loop
        digit := ivalue MOD 10;
        ivalue := ivalue/10;
        case digit is
            when 0 => line_no(index) := '0';
            when 1 => line_no(index) := '1';
            when 2 => line_no(index) := '2';
            when 3 => line_no(index) := '3';
            when 4 => line_no(index) := '4';
            when 5 => line_no(index) := '5';
            when 6 => line_no(index) := '6';
            when 7 => line_no(index) := '7';
            when 8 => line_no(index) := '8';
            when 9 => line_no(index) := '9';
            when others =>
                ASSERT FALSE
                REPORT "Illegal number!"
                SEVERITY ERROR;
        end case;
        index := index + 1;
    end loop;

    return line_no;
end INT_TO_STR_RAM;

function INT_TO_STR_ARITH (value : in integer) return string is
    variable ivalue : integer := 0;
    variable index : integer := 0;
    variable digit : integer := 0;
    variable temp: string(10 downto 1) := "0000000000";
begin
    ivalue := value;
    index := 1;

    while (ivalue > 0) loop
        digit := ivalue mod 10;
        ivalue := ivalue/10;

        case digit is
            when 0 => temp(index) := '0';
            when 1 => temp(index) := '1';
            when 2 => temp(index) := '2';
            when 3 => temp(index) := '3';
            when 4 => temp(index) := '4';
            when 5 => temp(index) := '5';
            when 6 => temp(index) := '6';
            when 7 => temp(index) := '7';
            when 8 => temp(index) := '8';
            when 9 => temp(index) := '9';
            when others =>
                ASSERT FALSE
                REPORT "Illegal number!"
                SEVERITY ERROR;
        end case;
        index := index + 1;
    end loop;

    if value < 0 then
        return '-'& temp(index downto 1);
    else
        return temp(index downto 1);
    end if;
end INT_TO_STR_ARITH;

-- This function converts a hexadecimal number to an integer
function HEX_STR_TO_INT (str : in string) return integer is
variable len : integer := str'length;
variable ivalue : integer := 0;
variable digit : integer := 0;
begin
    for i in len downto 1 loop
        case str(i) is
            when '0' => digit := 0;
            when '1' => digit := 1;
            when '2' => digit := 2;
            when '3' => digit := 3;
            when '4' => digit := 4;
            when '5' => digit := 5;
            when '6' => digit := 6;
            when '7' => digit := 7;
            when '8' => digit := 8;
            when '9' => digit := 9;
            when 'A' => digit := 10;
            when 'a' => digit := 10;
            when 'B' => digit := 11;
            when 'b' => digit := 11;
            when 'C' => digit := 12;
            when 'c' => digit := 12;
            when 'D' => digit := 13;
            when 'd' => digit := 13;
            when 'E' => digit := 14;
            when 'e' => digit := 14;
            when 'F' => digit := 15;
            when 'f' => digit := 15;
            when others =>
                ASSERT FALSE
                REPORT "Illegal character "&  str(i) & "in Intel Hex File! "
                SEVERITY ERROR;
        end case;
        ivalue := ivalue * 16 + digit;
    end loop;
    return ivalue;
end HEX_STR_TO_INT;

-- This procedure "cuts" the str_line into desired length
procedure SHRINK_LINE (str_line : inout line; pos : in integer) is
subtype nstring is string(1 to pos);
variable str : nstring;
begin
    if (pos >= 1) then
        read(str_line, str);
    end if;
end;
end ALTERA_COMMON_CONVERSION;
-- END OF PACKAGE

---START_ENTITY_HEADER---------------------------------------------------------
--
-- Entity Name     :  altaccumulate
--
-- Description     :  Parameterized accumulator megafunction. The accumulator
-- performs an add function or a subtract function based on the add_sub
-- parameter. The input data can be signed or unsigned.
--
-- Limitation      : n/a
--
-- Results expected:  result - The results of add or subtract operation. Output
--                             port [width_out-1 .. 0] wide.
--                    cout   - The cout port has a physical interpretation as 
--                             the carry-out (borrow-in) of the MSB. The cout
--                             port is most meaningful for detecting overflow
--                             in unsigned operations. The cout port operates
--                             in the same manner for signed and unsigned
--                             operations.
--                    overflow - Indicates the accumulator is overflow.
--
---END_ENTITY_HEADER-----------------------------------------------------------

library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_arith.all;

-- BEGINNING OF ENTITY
entity altaccumulate is
    -- GENERIC DECLARATION
    generic (
        width_in           : integer := 4;      -- Required
        width_out          : integer := 8;      -- Required
        lpm_representation : string  := "UNSIGNED";
        extra_latency      : integer := 0;
        use_wys            : string  := "ON";
        lpm_hint           : string  := "UNUSED";
        lpm_type           : string  := "altaccumulate"
    );

    -- PORT DECLARATION
    port (
        -- INPUT PORT DECLARATION
        cin       : in std_logic := 'Z';
        data      : in std_logic_vector(width_in -1 downto 0);  -- Required port
        add_sub   : in std_logic := '1';
        clock     : in std_logic;   -- Required port
        sload     : in std_logic := '0';
        clken     : in std_logic := '1';
        sign_data : in std_logic := '0';
        aclr      : in std_logic := '0';

        -- OUTPUT PORT DECLARATION
        result    : out std_logic_vector(width_out -1 downto 0) := (others => '0'); -- Required port
        cout      : out std_logic := '0';
        overflow  : out std_logic := '0'
    );
end altaccumulate;
-- END OF ENTITY

-- BEGINNING OF ARCHITECTURE
architecture behaviour of altaccumulate is

-- TYPE DECLARATION
type pipeline is array (extra_latency-1 downto 0) of std_logic_vector (width_out+1 downto 0);

-- SIGNAL DECLARATION
signal temp_sum : std_logic_vector (width_out downto 0) := (others => '0');
signal cout_int : std_logic := '0';
signal overflow_int : std_logic := '0';
signal result_int : std_logic_vector (width_out+1 downto 0) := (others => '0');

signal result_pipe : pipeline := (others => (others => '0'));

signal head : integer := 0;

begin

    MSG: process
    begin
        if( width_in <= 0 ) then
            ASSERT FALSE
            REPORT "Error! Value of width_in parameter must be greater than 0."
            SEVERITY ERROR;
        end if;

        if( width_out <= 0 ) then
            ASSERT FALSE
            REPORT "Error! Value of width_out parameter must be greater than 0."
            SEVERITY ERROR;
        end if;
        
        if( extra_latency > width_out ) then
            ASSERT FALSE
            REPORT "Info: Value of extra_latency parameter should be lower than width_out parameter for better performance/utilization."
            SEVERITY NOTE;
        end if;
        
        if( width_in > width_out ) then
            ASSERT FALSE
            REPORT "Error! Value of width_in parameter should be lower than or equal to width_out."
            SEVERITY ERROR;
        end if;
        wait;
    end process MSG;

    -- PROCESS DECLARATION
    ADDSUB : process (data, add_sub, sload, cin, sign_data,
                      result_int (width_out-1 downto 0))

    -- VARIABLE DECLARATIOM
    variable fb_int : std_logic_vector (width_out downto 0) := (others => '0');
    variable data_int : std_logic_vector (width_out-1 downto 0) := (others => '0');
    variable zeropad : std_logic_vector ((width_out - width_in)-1 downto 0) := (others => '0');
    variable temp_sum_int : std_logic_vector (width_out downto 0) := (others => '0');
    variable cout_temp, borrow : std_logic;
    variable result_full : std_logic_vector (width_out downto 0);
    variable temp_sum_zero : std_logic_vector (width_out downto 0) := (others => '0');
    variable cin_int : std_logic;
    begin

        if ((LPM_REPRESENTATION = "SIGNED") or (sign_data = '1')) then
            zeropad := (others => data (width_in-1));
        else
            zeropad := (others => '0');
        end if;

        if (sload = '1') then
            fb_int := (others => '0');
        else
            fb_int := ('0' & result_int (width_out-1 downto 0));
        end if;

        if ((data (0) = '1') or (data (0) = '0')) then
            data_int := (zeropad & data);
        end if;

        -- If cin is omitted (i.e. cin = 'z'), cin default is 0 for add operation
        -- and 1 for subtract operation.
        if ((cin /= '0') and (cin /= '1')) then
            cin_int := not add_sub;
        else
            cin_int := cin;
        end if;

        if (sload = '1') then
            temp_sum_int := unsigned(temp_sum_zero) + unsigned(data_int);
        else
            if (add_sub = '1') then
                temp_sum_int := unsigned(temp_sum_zero) + unsigned(fb_int) +
                                unsigned(data_int) + cin_int;
                cout_temp := temp_sum_int(width_out);
            else
                borrow := not cin_int;
                if ((borrow /= '1') and (borrow /= '0')) then
                    borrow := '0';
                end if;

                temp_sum_int := unsigned(temp_sum_zero) + unsigned (fb_int) -
                                unsigned (data_int) - borrow;
                result_full := unsigned(temp_sum_zero) + unsigned(data_int) +
                               borrow;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区二区黑丝| av成人免费在线观看| 国产精品麻豆一区二区| 欧亚一区二区三区| 国产在线一区二区| 亚洲sss视频在线视频| 久久久久久久久久看片| 欧美日韩一区精品| 国产盗摄一区二区三区| 日本强好片久久久久久aaa| 国产精品沙发午睡系列990531| 欧美四级电影在线观看| 粉嫩蜜臀av国产精品网站| 日韩av网站免费在线| 亚洲欧美激情一区二区| 精品久久久久久久人人人人传媒 | 欧美xxxxx裸体时装秀| 色婷婷久久久综合中文字幕| 精品一区二区三区香蕉蜜桃| 亚洲成人www| 一区二区三区鲁丝不卡| 日本一区二区三区视频视频| 日韩一区二区三区免费看| 色呦呦一区二区三区| 国产成人亚洲精品青草天美| 麻豆精品久久精品色综合| 丝袜亚洲另类欧美| 亚洲在线观看免费| 亚洲女同女同女同女同女同69| 国产无一区二区| 精品国产91洋老外米糕| 欧美三级韩国三级日本一级| 99re这里只有精品视频首页| 成人av中文字幕| 国产a区久久久| 国产黄色精品网站| 国产一区二区三区四| 国产一区欧美日韩| 国精产品一区一区三区mba视频| 奇米888四色在线精品| 亚洲成人av福利| 天天综合网天天综合色| 午夜日韩在线电影| 日韩在线卡一卡二| 日韩国产精品久久久久久亚洲| 亚洲va欧美va人人爽午夜| 午夜精品久久久久久久久久| 亚洲图片欧美视频| 午夜精品久久久久久久99樱桃 | 最新不卡av在线| 最新国产精品久久精品| 亚洲视频图片小说| 亚洲精品免费播放| 亚洲国产成人av好男人在线观看| 香蕉久久一区二区不卡无毒影院 | 激情偷乱视频一区二区三区| 国产一区久久久| 国产不卡一区视频| 99久久精品国产观看| 在线中文字幕不卡| 欧美一区二区三区视频免费| 日本一区二区三区高清不卡| 久久精品人人做人人综合| 欧美精品一区二区三| 欧美高清在线一区二区| 中文字幕一区二区三中文字幕| 亚洲激情在线播放| 日韩影院免费视频| 国产一区二区三区四| 成人aa视频在线观看| 91久久一区二区| 717成人午夜免费福利电影| 精品国产乱码久久久久久蜜臀| 国产午夜精品理论片a级大结局| 国产精品久久三| 亚洲国产成人高清精品| 九九国产精品视频| 成人黄色综合网站| 欧美系列一区二区| 久久日一线二线三线suv| 国产精品伦理在线| 三级欧美在线一区| 成人免费毛片嘿嘿连载视频| 在线观看视频91| 久久精品日产第一区二区三区高清版 | 丝袜亚洲精品中文字幕一区| 国产乱子轮精品视频| 色悠久久久久综合欧美99| 日韩欧美www| 一区二区在线观看视频在线观看| 久久精品国产亚洲高清剧情介绍| 91亚洲精华国产精华精华液| 日韩丝袜情趣美女图片| 亚洲日本韩国一区| 国产在线视视频有精品| 欧美色视频在线| 欧美经典三级视频一区二区三区| 日韩精品一级中文字幕精品视频免费观看| 狠狠色狠狠色合久久伊人| 在线视频欧美精品| 国产欧美日韩中文久久| 水野朝阳av一区二区三区| 成人动漫精品一区二区| 欧美α欧美αv大片| 一区二区三区**美女毛片| 国产成人啪午夜精品网站男同| 欧美视频在线播放| 亚洲四区在线观看| 国产自产视频一区二区三区| 欧美三级日韩在线| 亚洲男女毛片无遮挡| 国产一区三区三区| 欧美一区二区精美| 亚洲国产精品久久不卡毛片| 97成人超碰视| 国产精品三级av在线播放| 另类中文字幕网| 欧美日韩一区二区电影| 亚洲婷婷国产精品电影人久久| 激情国产一区二区| 91精品国产品国语在线不卡| 一区二区在线观看视频| 不卡视频在线观看| 国产人成亚洲第一网站在线播放| 久久精品国产**网站演员| 欧美绝品在线观看成人午夜影视| 亚洲精品亚洲人成人网在线播放| av一本久道久久综合久久鬼色| 久久综合久久综合久久| 成人精品电影在线观看| 精品国产乱码久久久久久老虎| 老色鬼精品视频在线观看播放| 欧美日韩一区不卡| 五月激情综合色| 欧美日韩亚洲综合| 亚洲成人动漫一区| 欧美日韩国产免费| 日韩影院精彩在线| 欧美一卡2卡三卡4卡5免费| 日本女人一区二区三区| 欧美一区二区三区电影| 老司机精品视频导航| 久久这里只有精品视频网| 国产乱码精品一区二区三区忘忧草 | 精品一区二区三区久久久| 日韩三级高清在线| 紧缚捆绑精品一区二区| 精品电影一区二区| 国产在线看一区| 国产午夜精品美女毛片视频| 粉嫩aⅴ一区二区三区四区| 中文字幕免费一区| 91丝袜美腿高跟国产极品老师 | 国产另类ts人妖一区二区| 久久久久国产精品麻豆ai换脸 | 亚洲丝袜自拍清纯另类| 91论坛在线播放| 亚洲成人动漫av| 日韩女优视频免费观看| 国产成人综合在线播放| 亚洲色图都市小说| 欧美日韩国产美| 国产在线不卡一卡二卡三卡四卡| 国产精品―色哟哟| 色噜噜久久综合| 秋霞电影网一区二区| 久久精品这里都是精品| 91天堂素人约啪| 免费一级片91| 国产精品久久看| 欧美日本精品一区二区三区| 久草中文综合在线| 亚洲视频你懂的| 日韩一区二区三区四区 | 欧美一区二区三区公司| 国产69精品久久久久毛片| 亚洲综合视频在线观看| 精品女同一区二区| 99国产精品99久久久久久| 日本欧美久久久久免费播放网| 国产精品情趣视频| 欧美一三区三区四区免费在线看 | 亚洲第四色夜色| 国产欧美一区二区精品久导航| 91女厕偷拍女厕偷拍高清| 婷婷六月综合亚洲| 欧美韩日一区二区三区四区| 欧美伊人久久久久久久久影院| 国产一区二区三区在线观看免费视频| 亚洲精品写真福利| 国产视频一区二区三区在线观看| 91久久精品一区二区| 国产一区二区在线看| 亚洲不卡一区二区三区| 国产精品进线69影院| 精品国精品国产| 精品1区2区3区| 99久久免费视频.com| 韩国精品主播一区二区在线观看| 亚洲综合成人在线|