实现USB接口功能的VHDL和verilog完整源代码

源代码在线查看: usb_new_synchronizer_rtl.vhdl

软件大小: 255 K
上传用户: sy361
关键词: verilog VHDL USB 接口功能
下载地址: 免注册下载 普通下载 VIP

相关代码

				--------------------------------------------------------------------------------
				--
				--  P H I L I P S  C O M P A N Y  R E S T R I C T E D
				--                                         
				--  Copyright (c) 1998.                    
				--
				--  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_synchronizer_rtl.vhdl 
				--
				--  Module          : Synchronizer block
				-- 
				--  Project         : VPB bus interface to USB 1.1 device 
				--
				--  Author          :              
				-- 
				--  Description     : This block provides synchronization for signals crossing
				--                    from Fs clock to APB clock. All signals are provided
				--                    double FF syncronization.
				--
				--  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_GENERAL.all;
				
				library work;
				use work.PCK_APB.all; 
				
				architecture RTL of SYNCHRONIZER is
				
				  signal End_Transfer_Q:        one_bit;
				  signal End_Transfer_2Q:       one_bit;
				  signal End_Transfer_3Q:       one_bit;
				  signal Read_Q:                one_bit;
				  signal Read_2Q:               one_bit;
				  signal Trans_Enable_Q:        one_bit;
				  signal Trans_Enable_2Q:       one_bit;
				  signal Trans_Enable_3Q:       one_bit;
				  signal Trans_Enable_Int:      one_bit; 
				  signal USBEp0Intr_Set_Q:      one_bit;
				  signal USBEp0Intr_Set_2Q:     one_bit;
				  signal USBEp0Intr_Set_3Q:     one_bit;
				  signal USBEp1Intr_Set_Q:      one_bit;
				  signal USBEp1Intr_Set_2Q:     one_bit;
				  signal USBEp1Intr_Set_3Q:     one_bit;
				  signal USBEp2Intr_Set_Q:      one_bit;
				  signal USBEp2Intr_Set_2Q:     one_bit;
				  signal USBEp2Intr_Set_3Q:     one_bit;
				  signal USBEp3Intr_Set_Q:      one_bit;
				  signal USBEp3Intr_Set_2Q:     one_bit;
				  signal USBEp3Intr_Set_3Q:     one_bit;
				  signal USBEp4Intr_Set_Q:      one_bit;
				  signal USBEp4Intr_Set_2Q:     one_bit;
				  signal USBEp4Intr_Set_3Q:     one_bit;
				  signal USBEp5Intr_Set_Q:      one_bit;
				  signal USBEp5Intr_Set_2Q:     one_bit;
				  signal USBEp5Intr_Set_3Q:     one_bit;
				  signal USBEp6Intr_Set_Q:      one_bit;
				  signal USBEp6Intr_Set_2Q:     one_bit;
				  signal USBEp6Intr_Set_3Q:     one_bit;
				  signal USBEp7Intr_Set_Q:      one_bit;
				  signal USBEp7Intr_Set_2Q:     one_bit;
				  signal USBEp7Intr_Set_3Q:     one_bit;
				  signal USBDevIntr_Set_Q:      one_bit;
				  signal USBDevIntr_Set_2Q:     one_bit;
				  signal USBDevIntr_Set_3Q:     one_bit;
				  signal FullBuffer_UC_Q:       T_Full;
				  signal EndTransfer_Cmd_Q:     one_bit;
				  signal EndTransfer_Cmd_2Q:    one_bit;
				  signal EndTransfer_Cmd_3Q:    one_bit;
				  signal RxError_Q:             boolean;
				  signal RxError_2Q:            boolean;
				  signal RxError_3Q:            boolean;
				  signal USBToggleBuffer_Q:     T_ToggleArray; 
				  signal UCToggleBuffer_Q:      T_ToggleArray; 
				  signal PI_IsoToggle_Q:        integer range 0 to 1;
				  signal PI_IsoToggle_2Q:       integer range 0 to 1;
				  signal CmdDataValid_Q:        boolean;
				  signal CmdDataValid_2Q:       boolean;
				  signal CmdDataValid_3Q:       boolean;
				  signal CmdAccept_Q:           boolean;
				  signal CmdAccept_2Q:          boolean;
				  signal CmdAccept_3Q:          boolean;
				  signal start_in_tx_Q:         one_bit;
				  signal start_in_tx_2Q:        one_bit;
				  signal start_in_tx_I:         one_bit;
				  signal FrameIntr_Set_I:       one_bit;  
				  signal FrameIntr_Set_Q:       one_bit;  
				
				 begin
				
				  CmdCodeValid_Out   				  CommandDataChannel 				  CommandCodeChannel 				  PI_IsoToggle_Out   				  
				  process(clk) 
				    begin
				      if(clk'event AND clk = '1') then
				         
				          -- syncronus reset for all registers
				         if(pvci_reset_n = '0') then
				            RxCore_Data               '0');
				            EP_number_out            				            If_Busy                  				            USBEp0IntrSet            				            USBEp0Intr_Set_Q         				            USBEp0Intr_Set_2Q        				            USBEp0Intr_Set_3Q        				            USBEp1IntrSet            				            USBEp1Intr_Set_Q         				            USBEp1Intr_Set_2Q        				            USBEp1Intr_Set_3Q        				            USBEp2IntrSet            				            USBEp2Intr_Set_Q         				            USBEp2Intr_Set_2Q        				            USBEp2Intr_Set_3Q        				            USBEp3IntrSet            				            USBEp3Intr_Set_Q         				            USBEp3Intr_Set_2Q        				            USBEp3Intr_Set_3Q        				            USBEp4IntrSet            				            USBEp4Intr_Set_Q         				            USBEp4Intr_Set_2Q        				            USBEp4Intr_Set_3Q        				            USBEp5IntrSet            				            USBEp5Intr_Set_Q         				            USBEp5Intr_Set_2Q        				            USBEp5Intr_Set_3Q        				            USBEp6IntrSet            				            USBEp6Intr_Set_Q         				            USBEp6Intr_Set_2Q        				            USBEp6Intr_Set_3Q        				            USBEp7IntrSet            				            USBEp7Intr_Set_Q         				            USBEp7Intr_Set_2Q        				            USBEp7Intr_Set_3Q        				            USBDevIntrSet            				            USBDevIntr_Set_Q         				            USBDevIntr_Set_2Q        				            USBDevIntr_Set_3Q        				            Trans_Enable_Int         				            Trans_Enable_Q           				            Trans_Enable_2Q          				            Trans_Enable_3Q          				            Read_Data                				            Read_Q                   				            Read_2Q                  				            End_Transfer_D           				            End_Transfer_Q           				            End_Transfer_2Q          				            End_Transfer_3Q          				            EndTransfer_Cmd_D        				            EndTransfer_Cmd_Q        				            EndTransfer_Cmd_2Q       				            EndTransfer_Cmd_3Q       				            RxError_Out              				            RxError_Q                				            RxError_2Q               				            RxError_3Q               				            USBToggleBuffer_Q         0);
				            USBToggleBuffer_Out       0);
				            UCToggleBuffer_Q          0);
				            UCToggleBuffer_Out        0);
				            FullBuffer_UC_Q           (others => false));
				            FullBuffer_EP             (others => false));
				            PI_IsoToggle_2Q          				            PI_IsoToggle_Q           				            CmdDataValid_Q           				            CmdDataValid_2Q          				            CmdDataValid_3Q          				            CmdAccept_Q              				            CmdAccept_2Q             				            CmdAccept_3Q             				            start_in_tx_Q            				            start_in_tx_2Q           				            start_in_tx_I            				            TxDest_Endp              				            start_in_tx              				            FrameIntr_Set_I          				            FrameIntr_Set_Q          				            FrameIntr_Set            				
				         else
				            
				            -- Read in to GIF from PI handler.
				            if(Trans_Enable_Int = '1' ) then
				               RxCore_Data     				               EP_number_out   				               If_Busy         				            end if;  
				
				            -- Edge Detection with Double Flip-Flop for Trans_Enable
				            Trans_Enable_Q   				            Trans_Enable_2Q  				            Trans_Enable_3Q  				            Trans_Enable_Int 				
				            -- Edge detection with Double Flip-Flop for Read_Write
				            Read_Q    				            Read_2Q   				            Read_Data 				
				            --Edge detection with Double Flip-Flop for End_Transfer.
				            End_Transfer_Q   				            End_Transfer_2Q  				            End_Transfer_3Q  				            End_Transfer_D   				
				            -- Edge detection with Double Flip-Flop for EndTransfer_Cmd
				            EndTransfer_Cmd_Q  				            EndTransfer_Cmd_2Q 				            EndTransfer_Cmd_3Q 				            EndTransfer_Cmd_D  				
				            -- Edge detection with Double Flip-Flop for USBEp0Intr_Set 
				            USBEp0Intr_Set_Q  				            USBEp0Intr_Set_2Q 				            USBEp0Intr_Set_3Q 				            USBEp0IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBEp1Intr_Set 
				            USBEp1Intr_Set_Q  				            USBEp1Intr_Set_2Q 				            USBEp1Intr_Set_3Q 				            USBEp1IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBEp2Intr_Set 
				            USBEp2Intr_Set_Q  				            USBEp2Intr_Set_2Q 				            USBEp2Intr_Set_3Q 				            USBEp2IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBEp3Intr_Set 
				            USBEp3Intr_Set_Q  				            USBEp3Intr_Set_2Q 				            USBEp3Intr_Set_3Q 				            USBEp3IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBEp4Intr_Set 
				            USBEp4Intr_Set_Q  				            USBEp4Intr_Set_2Q 				            USBEp4Intr_Set_3Q 				            USBEp4IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBEp5Intr_Set 
				            USBEp5Intr_Set_Q  				            USBEp5Intr_Set_2Q 				            USBEp5Intr_Set_3Q 				            USBEp5IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBEp6Intr_Set 
				            USBEp6Intr_Set_Q  				            USBEp6Intr_Set_2Q 				            USBEp6Intr_Set_3Q 				            USBEp6IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBEp7Intr_Set 
				            USBEp7Intr_Set_Q  				            USBEp7Intr_Set_2Q 				            USBEp7Intr_Set_3Q 				            USBEp7IntrSet     				
				            -- Edge detection with Double Flip-Flop for USBDevIntr_Set 
				            USBDevIntr_Set_Q  				            USBDevIntr_Set_2Q 				            USBDevIntr_Set_3Q 				            USBDevIntrSet     				
				            -- Rx DMA Valid Data
				            FullBuffer_UC_Q   				            FullBuffer_EP     				
				            -- USB Toggle 
				            USBToggleBuffer_Q   				            USBToggleBuffer_Out 				
				            -- UC Toggle
				            UCToggleBuffer_Q    				            UCToggleBuffer_Out  				
				            -- Edge detection for RxError.
				            RxError_Q   				            RxError_2Q  				            RxError_3Q  				            RxError_Out 				
				            -- IsoToggle
				            PI_IsoToggle_Q   				            PI_IsoToggle_2Q  				
				            -- Generation of Frame interrupt
				            if(PI_IsoToggle_2Q = 0) then
				               FrameIntr_Set_I 				            else
				               FrameIntr_Set_I 				            end if;
				            FrameIntr_Set_Q 				            FrameIntr_Set   				
				            -- Command accept
				            CmdAccept_Q   				            CmdAccept_2Q  				            CmdAccept_3Q  				            CmdAccept_Out 				
				            -- Command data valid
				            CmdDataValid_Q   				            CmdDataValid_2Q  				            CmdDataValid_3Q  				            CmdDataValid_Out 				 
				            -- start_in_tx
				            start_in_tx_Q  				            start_in_tx_2Q 				            start_in_tx_I  				  
				            if(start_in_tx_I = '1') then
				               start_in_tx 				               TxDest_Endp 				            else
				               start_in_tx 				            end if;
				          
				            -- Resetting of if_busy
				            if(RxDataAccepted) then
				               If_Busy   				            end if;
				          
				         end if;
				      end if;
				  end process;
				end RTL;          
							

相关资源