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

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

?? uc_interface.vhd

?? SPI.zip
?? VHD
?? 第 1 頁 / 共 2 頁
字號:
                        stat_en <= '1';
                    cntrl_en <= '0';
                    xmit_en <= '0';
                    rcv_en  <= '0';
                    ssel_en <= '0';

                    when SPICR_ADDR =>  -- control register has been addressed
                        stat_en <= '0';
                    cntrl_en <= '1';
                    xmit_en <= '0';
                    rcv_en  <= '0';
                    ssel_en <= '0';

                    when SPITR_ADDR =>  -- transmit data register has been addressed
                        stat_en <= '0';
                    cntrl_en <= '0';
                    xmit_en <= '1';
                    rcv_en  <= '0';
                    ssel_en <= '0';

                    when SPIRR_ADDR =>  -- transmit data register has been addressed
                        stat_en <= '0';
                    cntrl_en <= '0';
                    xmit_en <= '0';
                    rcv_en  <= '1';
                    ssel_en <= '0';

                    when SPISSR_ADDR => -- slave select register has been addressed 
                        stat_en <= '0';
                    cntrl_en <= '0';
                    xmit_en <= '0';
                    rcv_en  <= '0';
                    ssel_en <= '1';

                    when others =>      -- error condition, no registers are enabled 
                        stat_en <= '0';
                    cntrl_en <= '0';
                    xmit_en <= '0';
                    rcv_en  <= '0';
                    ssel_en <= '0';
                     
            end case;
          else
            -- this device is not addressed
            address_match <= '0';
                stat_en <= '0';
            cntrl_en <= '0';
            xmit_en <= '0';
            rcv_en  <= '0';
            ssel_en <= '0';
                     
          end if;
          
        end if;
        
    end process;
    
--************************** Read/Write uC registers **********************************
-- This process reads data from or writes data to the enabled register  

register_rw: process(clk, reset)
begin

        -- Initialize all internal registers upon reset
        if reset = RESET_ACTIVE then
            
            -- Status Register
            spierr_reset    <= RESET_ACTIVE;-- write to this bit clears it
            int_reset   <= RESET_ACTIVE;-- write to this bit clears it
            
            
            -- Control Register
            spien   <= '0';         -- enables the SPI interface
            inten   <= '0';         -- enables interrupts
            start   <= '0';         -- instructs SPI interface to start transfer
            clkdiv  <= (others => '0'); -- divisor for SCLK from system clock
            cpha    <= '0';         -- clock phase
            cpol    <= '0';         -- clock polarity
            rcv_cpol <= '0';        -- edge to use to clock incoming data

            -- Slave Select Register
            spissr  <= (others => '0'); -- initialize to no slaves selected

            -- Transmit data register
            spitr <= (others => '0');   -- initialize transmit data to 0
            xmit_empty_reset <= (RESET_ACTIVE); -- when transmit register is written,
                            -- the empty flag is reset
            -- Receive data register
            rcv_full_reset <= (RESET_ACTIVE);   -- when receive register is read, the
                            -- full flag is reset

            -- Initialize data bus
            data_out <= (others => '0');
    
        -- Check for rising edge of clock
        elsif clk'event and (clk = '1') then

          -- Check for data transfer state
          if (prs_state = DATA_TRS) then

                -- Control Register
                if cntrl_en = '1' then
              if wr_n = '0' then
                -- uC write            
                    spien   <= data_in(7);
                    inten   <= data_in(6);
                    start   <= data_in(5);
                    clkdiv  <= data_in(4 downto 3);
                    cpha    <= data_in(2);
                    cpol    <= data_in(1);
                    rcv_cpol<= data_in(0);
                  end if;
                  if rd_n = '0' then
                -- uC read
                data_out <= spien & inten & start &
                        clkdiv & cpha & cpol & rcv_cpol;
              
              end if;
            end if;

                -- Status Register
                if stat_en = '1' then
              if wr_n = '0' then
                            -- uC write to these bits generates a reset
                   if data_in(6) = '0' then
                    spierr_reset <= RESET_ACTIVE;
                   else
                        spierr_reset <= not(RESET_ACTIVE);
                   end if;

              end if;
              if rd_n = '0' then
                -- uC read
                data_out <= dt & spierr & bb & int_n & 
                      xmit_empty & rcv_full & "00";

              end if;
            end if;             

                -- Transmit Data Register
                if xmit_en = '1' then
                    if wr_n = '0' then
                    -- uC write
                     spitr <= data_in;
                     -- reset the empty flag
                     xmit_empty_reset <= RESET_ACTIVE;
                    end if;
                    if rd_n = '0' then
                     -- uC Read
                     data_out <= spitr;
                    end if;
            end if;
            
                -- Receive Data Register
                if rcv_en = '1' then
                    if rd_n = '0' then
                     -- uC Read
                     data_out <= spirr;
                     -- reset the full flag
                     rcv_full_reset <= RESET_ACTIVE;
                    end if;
            end if;     

                -- Slave select Register
                if ssel_en = '1' then
                    if wr_n = '0' then
                    -- uC write
                     spissr <= data_in;
                    end if;
                    if rd_n = '0' then
                     -- uC Read
                     data_out <= spissr;
                    end if;
            end if;         
          else
            xmit_empty_reset<= not(RESET_ACTIVE);
            rcv_full_reset  <= not(RESET_ACTIVE);
            spierr_reset    <= not(RESET_ACTIVE);

          end if;
    end if;
    
end process;

--************************** Status register **********************************
-- This process implements the bits in the status register
statusreg_process: process(clk, reset)

begin
    if reset = RESET_ACTIVE then
        bb <= '0';
        spierr <= '0';
        int_n <= '1';
        dt <= '0';
    elsif clk'event and clk = '1' then
        
        -- bus busy asserts when slave select is asserted
        if ss_n = '0' then
            bb <= '1';
        else
            bb <= '0';
        end if;
        
        -- spi error asserts when the input slave select is asserted 
        -- once asserted, this bit stays asserted until written to by the uC
        if spierr_reset = RESET_ACTIVE then
            spierr <= '0';
        elsif ss_in_int = '0' then
            spierr <= '1';
        end if;
        
        -- interrupt is asserted when the SPITR is empty or an error
        -- occurs IF interrupts are enabled
        -- interrupt service routine should read status register to determine
        -- cause of interrupt. After the first byte transfer, the RCV_FULL flag
        -- should be set when XMIT_EMPTY asserts so that uC can read receive data
        -- once asserted, this bit stays asserted until uC reads the status register.
        if spierr_reset = RESET_ACTIVE or xmit_empty_reset = RESET_ACTIVE or
            rcv_full_reset = RESET_ACTIVE then
            int_n <= '1';
        elsif inten = '1' then
            -- interrupts are enabled
            -- interrupt processor if there is an spierr, the xmit buffer is
            -- empty or if the receive buffer is full and its the end of the 
            -- transmission
            if spierr = '1' or 
            (start = '1' and xmit_empty = '1')  or
            (start = '0' and rcv_full = '1') then
                int_n <= '0';
            end if;
        end if;
        
        -- data transfer bit asserts when done is asserted
        if done = '1' then
            dt <= '1';
        else
            dt <= '0';
        end if;
    end if;
end process;

--************************** Receive data register **********************************
-- This process implements the bits in the receive register
receivereg_process: process(clk, reset)
begin
    if reset = RESET_ACTIVE then
        spirr <= (others => '0');
    elsif clk'event and clk = '1' then
        if spien = '0' then
            spirr <= (others => '0');
        elsif rcv_load = '1' then
            -- load the receive register
            spirr <= receive_data;
        else
            spirr <= spirr;
        end if;

    end if;
end process;


end BEHAVIOUR;
  

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲另类激情小说| 欧美激情一区二区三区蜜桃视频| 91精品国产91久久久久久一区二区| 精品剧情在线观看| 亚洲主播在线播放| 成人涩涩免费视频| 精品处破学生在线二十三| 亚洲成人免费电影| 91丨九色丨尤物| 国产欧美日韩精品a在线观看| 亚洲国产精品久久一线不卡| 北岛玲一区二区三区四区 | 日韩电影网1区2区| 色天天综合色天天久久| 欧美经典三级视频一区二区三区| 免费人成黄页网站在线一区二区| 色婷婷综合久久久中文字幕| 亚洲乱码国产乱码精品精的特点| 免费成人在线视频观看| 欧美日韩不卡一区| 亚洲精品一二三| 一本一道久久a久久精品| 国产精品每日更新| 国产成a人亚洲精| 精品播放一区二区| 国产乱子伦一区二区三区国色天香 | 亚洲在线成人精品| 一本久久精品一区二区| 亚洲色图欧美偷拍| 在线日韩一区二区| 亚洲国产精品一区二区www在线 | 国产精品 欧美精品| 精品国产乱码久久久久久夜甘婷婷| 视频精品一区二区| 欧美一级精品在线| 久久国内精品自在自线400部| 欧美日韩成人在线一区| 婷婷丁香激情综合| 日韩女优av电影在线观看| 免费在线观看一区| 久久人人超碰精品| 成人动漫精品一区二区| 国产精品女主播在线观看| 不卡一区二区三区四区| 亚洲乱码中文字幕| 欧美妇女性影城| 久久超碰97人人做人人爱| 久久精品网站免费观看| 成人av在线一区二区三区| 亚洲激情在线激情| 69堂亚洲精品首页| 国产麻豆视频精品| 亚洲免费看黄网站| 日韩一区二区免费在线观看| 久久99精品久久久久久动态图| 久久欧美中文字幕| 色88888久久久久久影院野外| 亚洲mv在线观看| 久久奇米777| 91久久精品网| 精品亚洲国内自在自线福利| 中文字幕第一区| 欧美日本韩国一区二区三区视频| 激情亚洲综合在线| 亚洲精品成人在线| www激情久久| 欧美在线观看18| 国产自产高清不卡| 一区二区三区日韩精品| 精品国产一区二区亚洲人成毛片| 不卡视频一二三| 久久国产人妖系列| 亚洲精品一二三区| 国产亚洲一区二区三区在线观看| 91黄视频在线| 风间由美中文字幕在线看视频国产欧美| 亚洲蜜臀av乱码久久精品蜜桃| 日韩欧美一级在线播放| 在线视频你懂得一区二区三区| 国产综合色精品一区二区三区| 亚洲影视在线观看| 欧美极品美女视频| 精品久久久久久久久久久久久久久| 色综合久久综合网97色综合| 精品亚洲成av人在线观看| 亚洲国产视频直播| 亚洲婷婷在线视频| 久久精品视频在线看| 91精品国产综合久久香蕉麻豆| 99在线视频精品| 国产一区999| 韩国精品主播一区二区在线观看| 亚洲国产综合在线| 亚洲丝袜制服诱惑| 国产视频在线观看一区二区三区| 91精品国产色综合久久ai换脸| 日本韩国一区二区三区视频| 丁香天五香天堂综合| 久久国产精品无码网站| 日本亚洲最大的色成网站www| 樱花草国产18久久久久| 日韩伦理av电影| 国产精品全国免费观看高清| 国产性天天综合网| 久久综合国产精品| 精品国产亚洲一区二区三区在线观看| 91麻豆精品国产91久久久久| 欧美性猛交一区二区三区精品| 91小视频免费看| 色婷婷精品久久二区二区蜜臂av| 99国产欧美另类久久久精品| 成人av影视在线观看| 国产69精品久久99不卡| 成人久久18免费网站麻豆| 福利一区二区在线观看| 成a人片国产精品| 91香蕉视频mp4| 色婷婷精品久久二区二区蜜臂av| 99久久国产综合精品麻豆| av电影在线观看完整版一区二区| 成人免费毛片app| 91色porny蝌蚪| 欧美性感一类影片在线播放| 欧美日韩国产乱码电影| 欧美一区二区三区免费大片| 欧美v亚洲v综合ⅴ国产v| 久久久一区二区三区捆绑**| 欧美激情综合在线| 亚洲裸体xxx| 天涯成人国产亚洲精品一区av| 日韩av高清在线观看| 精品在线观看视频| 成人免费高清在线观看| 色吊一区二区三区| 欧美男同性恋视频网站| xnxx国产精品| 亚洲欧洲精品成人久久奇米网 | 精品国产乱码久久久久久久久| 久久九九国产精品| 亚洲人成小说网站色在线 | 国产麻豆日韩欧美久久| 成人免费精品视频| 欧美性色黄大片手机版| 日韩欧美美女一区二区三区| 欧美韩日一区二区三区四区| 一区二区三区蜜桃| 精品午夜久久福利影院| 97超碰欧美中文字幕| 在线播放91灌醉迷j高跟美女| 精品国产免费久久| 亚洲九九爱视频| 国产一区亚洲一区| 在线观看成人小视频| 精品国产精品一区二区夜夜嗨| 国产精品久久久久影视| 视频一区免费在线观看| 国产成人8x视频一区二区| 欧美精品日韩一区| 国产精品亲子伦对白| 蜜臀av一区二区| 在线影院国内精品| 国产午夜精品一区二区三区嫩草| 亚洲国产精品久久人人爱蜜臀| 国产一区中文字幕| 欧美情侣在线播放| 综合激情成人伊人| 国产精品888| 日韩一区二区视频| 亚洲黄色小视频| 国产91精品一区二区麻豆网站 | 精品久久人人做人人爱| 日韩理论在线观看| 国产成人av电影在线| 91精品国产一区二区三区| 亚洲视频中文字幕| 成人高清av在线| 久久久久久电影| 久久精品久久久精品美女| 欧美日韩精品综合在线| 亚洲欧美日韩电影| 99国产欧美另类久久久精品| 国产欧美一区二区精品忘忧草| 青青草国产精品亚洲专区无| 在线观看日韩毛片| 亚洲男人电影天堂| 99久久精品国产毛片| 国产精品乱子久久久久| 国产精品一区二区免费不卡| 精品国产网站在线观看| 日本不卡一区二区| 这里只有精品免费| 日韩激情一二三区| 91精品国产一区二区三区香蕉 | 久久er精品视频| 日韩午夜激情av| 另类小说色综合网站| 精品免费99久久| 国产精品一区二区在线观看不卡| 日韩欧美一区二区三区在线| 久久国内精品自在自线400部|