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

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

?? usb_new_usb_cntrl_rtl.vhdl

?? 實現USB接口功能的VHDL和verilog完整源代碼
?? VHDL
?? 第 1 頁 / 共 2 頁
字號:
--------------------------------------------------------------------------------
--
--  Philips Electronics N.V.
--
--  Philips Semiconductors
--  Interconnectivity and Processor Peripheral group
--  Bangalore, India
--  All rights reserved. Reproduction in whole or in part is prohibited
--  without the written permission of the copyright owner.
--
--------------------------------------------------------------------------------
--
--  File            : usb_new_usb_cntrl_rtl.vhdl 
--  
--  Module          : USB controller
--
--  Project         : VPB bus interface to USB 1.1 device (USBFS22)
--
--  Author          :
--
--  Description     : The architecture of USB controller module
--                    This block has a interrupt controller and all the interface
--                    registers.
--
--  Contact address : sanjeev@blr.sc.philips.com
--
--------------------------------------------------------------------------------

library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;

library work;
use work.PCK_APB.all;

architecture RTL of USB_CNTRL is

constant N_intrbits : integer := 13;
signal Cmd_Code_Reg:           eleven_bits;
signal Cmd_Data_Reg:           byte;
signal Receive_Data_Reg:       four_bytes;
signal Tramsmt_Data_Reg:       four_bytes;
signal Intr_Status_Reg:        twenty_bits;
signal Intr_Enable_Reg:        fourteen_bits;
signal TxPkt_Lngth_Reg:        ten_bits; 
signal RxPkt_Lngth_Reg:        eleven_bits;
signal Usb_Cntrl_Reg:          six_bits;
signal Fiq_Sel_Reg:            three_bits;

signal Cmd_Code_Reg_Full:      one_bit;
signal Cmd_Data_Reg_full:      one_bit;
signal Receive_Data_Reg_Full:  one_bit;
signal Trnsmt_Data_Reg_Full:   one_bit;

signal Read_Enable:            one_bit;
signal Read_Enable_Q:          one_bit;
signal Write_Enable:           one_bit;
signal Write_Enable_Q:         one_bit;
signal CmdCodeEmpty_IntrSet:   one_bit;
signal CmdCodeValid_I:         boolean;
signal CmdDataFull_IntrSet:    one_bit; 
signal EndPaktOut_IntrSet:     one_bit;
signal EndPaktIn_IntrSet:      one_bit;
signal Tx_Pkt_End_I:           one_bit;
signal Tx_Pkt_End_Q:           one_bit;
signal Rx_Pkt_End_I:           one_bit;
signal Read_Enable_I:          one_bit;

begin
  Endpoint_Nr  <= to_integer(Wr_Data(5 downto 2)) when Write_Usb_Cntrl = '1' 
		  else to_integer(Usb_Cntrl_Reg(5 downto 2));
  RxRam_Read  <=  not Receive_Data_Reg_Full and Read_Enable;
  TxRam_Write <=  Trnsmt_Data_Reg_Full and Usb_Cntrl_Reg(1);
  DataToRam    <=  Tramsmt_Data_Reg;
  Read_Enable  <=  Wr_data(0) when Write_Usb_Cntrl = '1' else
		   Read_Enable_I;
  CmdCodeValid <= Cmd_Code_Reg_Full = '1' ;
  CommandCode  <= Cmd_Code_Reg;
  Tx_Pkt_End   <= Tx_Pkt_End_Q;
  Receive_Data_Reg <= DataFromRam;
  Rx_Pkt_End    <=  Rx_Pkt_End_I;

  process(clk)
    
    ------------------------------------------------------------------------------
    procedure  InterruptController is
      variable irqstatus_var:    one_bit;
      variable fiqstatus_var:    one_bit;
    begin
       -- Writing into Interrupt Enable Register
       if(Write_Intr_Enable = '1') then
          Intr_Enable_Reg <= Wr_Data(13 downto 0);
       end if;
       -- Clearing of the status Register
       if(Write_Intr_Clear = '1') then
          for i in 0 to N_intrbits loop
             if(Wr_Data(i) = '1') then
                Intr_Status_Reg(i) <= '0';
             end if;
          end loop;
       end if;
       -- Setting the interrupts for debug purposes
       if(Write_Intr_Set = '1') then
          for i in 0 to N_intrbits loop
             if(Wr_Data(i) = '1') then
                Intr_Status_Reg(i)   <= '1';
             end if;
          end loop;
       end if;
       
       -- Update status register when there is flag is set
       if(FrameIntr_Set = '1') then
          Intr_Status_Reg(IntrNo_Frame) <= '1';
       end if; 
       --if(UsbCoreIntrSet = '1') then
       --   Intr_Status_Reg(IntrNo_USB_Core) <= '1';
          -- Set '1' in Int Status register's EP status bits when an IN token is NAKed and
	  -- Buffer is full
          -- Bit  8: EP1 IN
          -- Bit  9: EP3 IN
          -- Bit 10: EP5 IN
          -- Bit 11: EP7 IN
       if(UsbEp0IntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Ep0) <= '1';
       end if;
       if(UsbEp1IntrSet = '1') then 
          Intr_Status_Reg(IntrNo_USB_Ep1) <= '1';
	  if(FullBuffer_EP(1)(0)) then
	     Intr_Status_Reg(Ep1_NAK) <= '1';
          else
	     Intr_Status_Reg(Ep1_NAK) <= '0';
          end if;
       end if;
       if(UsbEp2IntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Ep2) <= '1';
       end if;
       if(UsbEp3IntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Ep3) <= '1';
	  if(FullBuffer_EP(3)(0)) then
	     Intr_Status_Reg(Ep3_NAK) <= '1';
          else
	     Intr_Status_Reg(Ep3_NAK) <= '0';
          end if;
       end if;
       if(UsbEp4IntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Ep4) <= '1';
       end if;
       if(UsbEp5IntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Ep5) <= '1';
	  if(FullBuffer_EP(5)(0)) then
	     Intr_Status_Reg(Ep5_NAK) <= '1';
          else
	     Intr_Status_Reg(Ep5_NAK) <= '0';
          end if;
       end if;
       if(UsbEp6IntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Ep6) <= '1';
       end if;
       if(UsbEp7IntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Ep7) <= '1';
	  if(FullBuffer_EP(7)(USBToggleBuffer_Out(7))) then
	     Intr_Status_Reg(Ep7_NAK) <= '1';
          else
	     Intr_Status_Reg(Ep7_NAK) <= '0';
          end if;
       end if;
       if(UsbDevIntrSet = '1') then
          Intr_Status_Reg(IntrNo_USB_Dev) <= '1';
       end if;
       
       --end if;
       if(CmdCodeEmpty_IntrSet = '1') then
          Intr_Status_Reg(IntrNo_CmdCodeReg_Empty) <= '1'; 
       end if;    
       if(CmdDataFull_IntrSet = '1') then
          Intr_Status_Reg(IntrNo_CmdDataReg_Full) <= '1'; 
       end if;     
       if(EndPaktOut_IntrSet = '1') then
          Intr_Status_Reg(IntrNo_OUT_EndOfPacket) <= '1';
       end if;
       if(EndPaktIn_IntrSet = '1') then
          Intr_Status_Reg(IntrNo_IN_EndOfPacket) <= '1';
       end if;   
       irqstatus_var := '0';
       
       -- Select FIQ interrupt from Frame_Interrupt, EP6_Interrupt and Ep7_Interrupt
       -- depending on the flag that is set in Fiq_Sel_Reg
       case Fiq_Sel_Reg is
          when "001" => 
               fiqstatus_var := Intr_Status_Reg(0) and Intr_Enable_Reg(0);
               for i in 1 to N_intrbits loop
                   irqstatus_var := irqstatus_var or (Intr_Status_Reg(i) and Intr_Enable_Reg(i));
               end loop;
          when "010" =>
               fiqstatus_var := Intr_Status_Reg(7) and Intr_Enable_Reg(7);
               for i in 0 to 6 loop
                   irqstatus_var := irqstatus_var or (Intr_Status_Reg(i) and Intr_Enable_Reg(i));
               end loop;
               for i in 8 to N_intrbits loop
                   irqstatus_var := irqstatus_var or (Intr_Status_Reg(i) and Intr_Enable_Reg(i));
               end loop;
          when "100" =>
               fiqstatus_var := Intr_Status_Reg(8) and Intr_Enable_Reg(8);
               for i in 0 to 7 loop
                   irqstatus_var := irqstatus_var or (Intr_Status_Reg(i) and Intr_Enable_Reg(i));
               end loop;
               for i in 9 to N_intrbits loop
                   irqstatus_var := irqstatus_var or (Intr_Status_Reg(i) and Intr_Enable_Reg(i));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美丰满美乳xxx高潮www| av动漫一区二区| 亚洲图片一区二区| 亚洲人成精品久久久久| 1区2区3区精品视频| 国产精品久久久久久久久搜平片| 国产网红主播福利一区二区| 精品国产乱码久久久久久久| 精品福利视频一区二区三区| 国产欧美一区二区三区网站| 综合亚洲深深色噜噜狠狠网站| 亚洲视频 欧洲视频| 一区二区三区毛片| 亚洲成av人片| 精品在线观看视频| 成人午夜碰碰视频| 在线观看网站黄不卡| 欧美一二三四区在线| 久久久久久久久久久久久夜| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 一区二区在线看| 五月综合激情日本mⅴ| 日韩三级中文字幕| 欧美人妇做爰xxxⅹ性高电影| 这里是久久伊人| 久久久亚洲高清| 亚洲同性gay激情无套| 天天做天天摸天天爽国产一区 | 中文一区二区完整视频在线观看| 国产精品无遮挡| 一区二区免费看| 国产麻豆视频精品| 色又黄又爽网站www久久| 欧美日韩黄色一区二区| 精品久久99ma| 亚洲图片一区二区| 国产精品一区在线观看你懂的| 91蝌蚪porny| 久久婷婷久久一区二区三区| 亚洲欧美偷拍卡通变态| 秋霞影院一区二区| 91久久精品午夜一区二区| 欧美一区二区黄色| 亚洲色图在线播放| 精品一区二区三区在线观看 | 亚洲综合在线电影| 国产一区二区三区精品视频| 在线一区二区观看| 国产免费成人在线视频| 免费观看久久久4p| 欧洲精品一区二区三区在线观看| 久久亚洲精精品中文字幕早川悠里 | 五月天丁香久久| 成人性色生活片免费看爆迷你毛片| 在线成人免费观看| 亚洲另类春色校园小说| 国产成人在线视频网站| 欧美一卡二卡三卡| 亚洲午夜久久久久中文字幕久| 粉嫩av一区二区三区粉嫩| 日韩精品一区二区三区四区| 亚洲chinese男男1069| 色久优优欧美色久优优| 国产精品白丝在线| 不卡的电影网站| 中文成人av在线| 国产成人av电影在线观看| 精品久久人人做人人爱| 精品制服美女久久| 精品理论电影在线观看| 狠狠色丁香久久婷婷综| 日韩欧美中文一区二区| 美日韩一区二区| 精品国产三级电影在线观看| 久久精品国产网站| 久久久久99精品国产片| 国产精品 日产精品 欧美精品| 久久综合九色综合久久久精品综合| 美女诱惑一区二区| 2023国产精品视频| 成人综合婷婷国产精品久久免费| 日本一区二区免费在线观看视频| 国产成人一区在线| 中文字幕亚洲不卡| 91久久人澡人人添人人爽欧美 | xnxx国产精品| 国产精品一区专区| 最新不卡av在线| 欧亚一区二区三区| 蜜桃免费网站一区二区三区| 久久久精品免费观看| 9久草视频在线视频精品| 亚洲欧美韩国综合色| 欧美日韩一区二区三区免费看 | 国产无人区一区二区三区| 成人美女视频在线看| 国产精品美女一区二区三区| 色综合久久久久综合体| 日本在线不卡一区| 国产精品网站导航| 欧美三级三级三级| 久久激情综合网| 亚洲视频精选在线| 日韩一区二区三区电影| 成人的网站免费观看| 日韩精品一区第一页| 国产日韩成人精品| 欧美亚洲图片小说| 国产乱理伦片在线观看夜一区| 日韩毛片在线免费观看| 欧美一级二级在线观看| 99久久99久久精品国产片果冻 | 国产精品不卡在线| 91精品国产欧美日韩| 成人高清视频在线| 琪琪久久久久日韩精品| 亚洲欧洲日韩综合一区二区| 欧美日韩国产大片| 成人精品国产一区二区4080 | 欧美精品一区二区久久婷婷| 91免费看`日韩一区二区| 日本不卡高清视频| 亚洲另类一区二区| 久久久国产精品不卡| 日韩一区二区中文字幕| 欧美天天综合网| 不卡一区二区在线| 国产美女一区二区三区| 日韩中文欧美在线| 亚洲永久精品大片| 中文字幕一区二区三区视频| 久久综合久久综合九色| 欧美另类高清zo欧美| 欧美优质美女网站| 日本高清成人免费播放| 成人激情免费网站| 国产一区二区三区国产| 奇米影视一区二区三区小说| 亚洲成国产人片在线观看| 1024精品合集| 最好看的中文字幕久久| 国产精品亲子乱子伦xxxx裸| 久久久国产综合精品女国产盗摄| 日韩视频在线一区二区| 337p亚洲精品色噜噜| 欧美日韩一区二区三区高清| 欧美日韩免费电影| 欧美日免费三级在线| 欧美日高清视频| 欧美久久久一区| 欧美精品自拍偷拍| 3751色影院一区二区三区| 欧美一区二区三区公司| 日韩无一区二区| 亚洲精品在线网站| 亚洲精品一区二区三区四区高清 | 99久久夜色精品国产网站| 国产suv精品一区二区6| 成人动漫一区二区在线| 色综合色狠狠综合色| 欧美最猛性xxxxx直播| 欧美绝品在线观看成人午夜影视| 欧美日韩精品高清| 日韩精品专区在线| 国产欧美精品一区二区三区四区| 日本一区二区在线不卡| 亚洲婷婷综合久久一本伊一区| 亚洲免费伊人电影| 五月综合激情日本mⅴ| 美女免费视频一区| 国产一区二区三区av电影 | 欧美日韩专区在线| 欧美一区永久视频免费观看| 欧美大片在线观看| 国产精品久久夜| 亚洲国产美女搞黄色| 久久精工是国产品牌吗| 成人激情图片网| 欧美人狂配大交3d怪物一区| 久久久美女毛片 | 欧美日韩成人高清| 欧美本精品男人aⅴ天堂| 欧美国产乱子伦| 亚洲图片欧美色图| 麻豆精品视频在线观看视频| 成人精品亚洲人成在线| 51精品久久久久久久蜜臀| 久久精品欧美一区二区三区不卡 | 欧美另类一区二区三区| 久久久另类综合| 一区二区三区四区激情| 精品一区二区精品| 色综合久久天天| 久久久美女艺术照精彩视频福利播放| 亚洲欧美激情在线| 国产乱妇无码大片在线观看| 欧美人与z0zoxxxx视频| 国产精品日韩精品欧美在线| 免费观看在线色综合| 91蜜桃传媒精品久久久一区二区|