mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 09:38:14 +00:00 
			
		
		
		
	- Added I2C support for ML300.
  - Added support for ML300 to read out its environment information
    stored on the EEPROM.
  - Added support to use board specific parameters as part of
    U-Boot's environment information.
  - Updated MLD files to support configuration for new features
    above.
* Patches by Travis Sawyer, 5 Aug 2004:
  - Remove incorrect bridge settings for eth group 6
  - Add call to setup bridge in ppc_440x_eth_initialize
  - Fix ppc_440x_eth_init to reset the phy only if its the
    first time through, otherwise, just check the phy for the
    autonegotiated speed/duplex.  This allows the use of netconsole
  - only print the speed/duplex the first time the phy is reset.
		
	
			
		
			
				
	
	
		
			747 lines
		
	
	
		
			28 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			747 lines
		
	
	
		
			28 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* $Id: xipif_v1_23_b.h,v 1.1 2002/03/18 23:24:52 linnj Exp $ */
 | |
| /******************************************************************************
 | |
| *
 | |
| *	XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS"
 | |
| *	AS A COURTESY TO YOU, SOLELY FOR USE IN DEVELOPING PROGRAMS AND
 | |
| *	SOLUTIONS FOR XILINX DEVICES.  BY PROVIDING THIS DESIGN, CODE,
 | |
| *	OR INFORMATION AS ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE,
 | |
| *	APPLICATION OR STANDARD, XILINX IS MAKING NO REPRESENTATION
 | |
| *	THAT THIS IMPLEMENTATION IS FREE FROM ANY CLAIMS OF INFRINGEMENT,
 | |
| *	AND YOU ARE RESPONSIBLE FOR OBTAINING ANY RIGHTS YOU MAY REQUIRE
 | |
| *	FOR YOUR IMPLEMENTATION.  XILINX EXPRESSLY DISCLAIMS ANY
 | |
| *	WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE
 | |
| *	IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR
 | |
| *	REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF
 | |
| *	INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 | |
| *	FOR A PARTICULAR PURPOSE.
 | |
| *
 | |
| *	(c) Copyright 2002 Xilinx Inc.
 | |
| *	All rights reserved.
 | |
| *
 | |
| ******************************************************************************/
 | |
| /******************************************************************************
 | |
| *
 | |
| * FILENAME:
 | |
| *
 | |
| * xipif.h
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * The XIpIf component encapsulates the IPIF, which is the standard interface
 | |
| * that IP must adhere to when connecting to a bus.  The purpose of this
 | |
| * component is to encapsulate the IPIF processing such that maintainability
 | |
| * is increased.	 This component does not provide a lot of abstraction from
 | |
| * from the details of the IPIF as it is considered a building block for
 | |
| * device drivers.  A device driver designer must be familiar with the
 | |
| * details of the IPIF hardware to use this component.
 | |
| *
 | |
| * The IPIF hardware provides a building block for all hardware devices such
 | |
| * that each device does not need to reimplement these building blocks. The
 | |
| * IPIF contains other building blocks, such as FIFOs and DMA channels, which
 | |
| * are also common to many devices.  These blocks are implemented as separate
 | |
| * hardware blocks and instantiated within the IPIF.  The primary hardware of
 | |
| * the IPIF which is implemented by this software component is the interrupt
 | |
| * architecture.	 Since there are many blocks of a device which may generate
 | |
| * interrupts, all the interrupt processing is contained in the common part
 | |
| * of the device, the IPIF.  This interrupt processing is for the device level
 | |
| * only and does not include any processing for the interrupt controller.
 | |
| *
 | |
| * A device is a mechanism such as an Ethernet MAC.  The device is made
 | |
| * up of several parts which include an IPIF and the IP.	 The IPIF contains most
 | |
| * of the device infrastructure which is common to all devices, such as
 | |
| * interrupt processing, DMA channels, and FIFOs.  The infrastructure may also
 | |
| * be referred to as IPIF internal blocks since they are part of the IPIF and
 | |
| * are separate blocks that can be selected based upon the needs of the device.
 | |
| * The IP of the device is the logic that is unique to the device and interfaces
 | |
| * to the IPIF of the device.
 | |
| *
 | |
| * In general, there are two levels of registers within the IPIF.  The first
 | |
| * level, referred to as the device level, contains registers which are for the
 | |
| * entire device.  The second level, referred to as the IP level, contains
 | |
| * registers which are specific to the IP of the device.	 The two levels of
 | |
| * registers are designed to be hierarchical such that the device level is
 | |
| * is a more general register set above the more specific registers of the IP.
 | |
| * The IP level of registers provides functionality which is typically common
 | |
| * across all devices and allows IP designers to focus on the unique aspects
 | |
| * of the IP.
 | |
| *
 | |
| * Critical Sections
 | |
| *
 | |
| * It is the responsibility of the device driver designer to use critical
 | |
| * sections as necessary when calling functions of the IPIF.  This component
 | |
| * does not use critical sections and it does access registers using
 | |
| * read-modify-write operations.	 Calls to IPIF functions from a main thread
 | |
| * and from an interrupt context could produce unpredictable behavior such that
 | |
| * the caller must provide the appropriate critical sections.
 | |
| *
 | |
| * Mutual Exclusion
 | |
| *
 | |
| * The functions of the IPIF are not thread safe such that the caller of all
 | |
| * functions is responsible for ensuring mutual exclusion for an IPIF.  Mutual
 | |
| * exclusion across multiple IPIF components is not necessary.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * MODIFICATION HISTORY:
 | |
| *
 | |
| * Ver	Who  Date     Changes
 | |
| * ----- ---- -------- -----------------------------------------------
 | |
| * 1.23b jhl  02/27/01 Repartioned to minimize size
 | |
| *
 | |
| ******************************************************************************/
 | |
| 
 | |
| #ifndef XIPIF_H			/* prevent circular inclusions */
 | |
| #define XIPIF_H			/* by using protection macros */
 | |
| 
 | |
| /***************************** Include Files *********************************/
 | |
| #include "xbasic_types.h"
 | |
| #include "xstatus.h"
 | |
| #include "xversion.h"
 | |
| 
 | |
| /************************** Constant Definitions *****************************/
 | |
| 
 | |
| /* the following constants define the register offsets for the registers of the
 | |
|  * IPIF, there are some holes in the memory map for reserved addresses to allow
 | |
|  * other registers to be added and still match the memory map of the interrupt
 | |
|  * controller registers
 | |
|  */
 | |
| #define XIIF_V123B_DISR_OFFSET	   0UL	/* device interrupt status register */
 | |
| #define XIIF_V123B_DIPR_OFFSET	   4UL	/* device interrupt pending register */
 | |
| #define XIIF_V123B_DIER_OFFSET	   8UL	/* device interrupt enable register */
 | |
| #define XIIF_V123B_DIIR_OFFSET	   24UL /* device interrupt ID register */
 | |
| #define XIIF_V123B_DGIER_OFFSET	   28UL /* device global interrupt enable reg */
 | |
| #define XIIF_V123B_IISR_OFFSET	   32UL /* IP interrupt status register */
 | |
| #define XIIF_V123B_IIER_OFFSET	   40UL /* IP interrupt enable register */
 | |
| #define XIIF_V123B_RESETR_OFFSET   64UL /* reset register */
 | |
| 
 | |
| #define XIIF_V123B_RESET_MASK		  0xAUL
 | |
| 
 | |
| /* the following constant is used for the device global interrupt enable
 | |
|  * register, to enable all interrupts for the device, this is the only bit
 | |
|  * in the register
 | |
|  */
 | |
| #define XIIF_V123B_GINTR_ENABLE_MASK	  0x80000000UL
 | |
| 
 | |
| /* the following constants contain the masks to identify each internal IPIF
 | |
|  * condition in the device registers of the IPIF, interrupts are assigned
 | |
|  * in the register from LSB to the MSB
 | |
|  */
 | |
| #define XIIF_V123B_ERROR_MASK		  1UL	/* LSB of the register */
 | |
| 
 | |
| /* The following constants contain interrupt IDs which identify each internal
 | |
|  * IPIF condition, this value must correlate with the mask constant for the
 | |
|  * error
 | |
|  */
 | |
| #define XIIF_V123B_ERROR_INTERRUPT_ID	  0	/* interrupt bit #, (LSB = 0) */
 | |
| #define XIIF_V123B_NO_INTERRUPT_ID	  128	/* no interrupts are pending */
 | |
| 
 | |
| /**************************** Type Definitions *******************************/
 | |
| 
 | |
| /***************** Macros (Inline Functions) Definitions *********************/
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_RESET
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * Reset the IPIF component and hardware.  This is a destructive operation that
 | |
| * could cause the loss of data since resetting the IPIF of a device also
 | |
| * resets the device using the IPIF and any blocks, such as FIFOs or DMA
 | |
| * channels, within the IPIF.  All registers of the IPIF will contain their
 | |
| * reset value when this function returns.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| 
 | |
| /* the following constant is used in the reset register to cause the IPIF to
 | |
|  * reset
 | |
|  */
 | |
| #define XIIF_V123B_RESET(RegBaseAddress) \
 | |
|     XIo_Out32(RegBaseAddress + XIIF_V123B_RESETR_OFFSET, XIIF_V123B_RESET_MASK)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_WRITE_DISR
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function sets the device interrupt status register to the value.
 | |
| * This register indicates the status of interrupt sources for a device
 | |
| * which contains the IPIF.  The status is independent of whether interrupts
 | |
| * are enabled and could be used for polling a device at a higher level rather
 | |
| * than a more detailed level.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * device which contains the IPIF.  With the exception of some internal IPIF
 | |
| * conditions, the contents of this register are not latched but indicate
 | |
| * the live status of the interrupt sources within the device.  Writing any of
 | |
| * the non-latched bits of the register will have no effect on the register.
 | |
| *
 | |
| * For the latched bits of this register only, setting a bit which is zero
 | |
| * within this register causes an interrupt to generated.  The device global
 | |
| * interrupt enable register and the device interrupt enable register must be set
 | |
| * appropriately to allow an interrupt to be passed out of the device. The
 | |
| * interrupt is cleared by writing to this register with the bits to be
 | |
| * cleared set to a one and all others to zero.	This register implements a
 | |
| * toggle on write functionality meaning any bits which are set in the value
 | |
| * written cause the bits in the register to change to the opposite state.
 | |
| *
 | |
| * This function writes the specified value to the register such that
 | |
| * some bits may be set and others cleared.  It is the caller's responsibility
 | |
| * to get the value of the register prior to setting the value to prevent a
 | |
| * destructive behavior.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * Status contains the value to be written to the interrupt status register of
 | |
| * the device.  The only bits which can be written are the latched bits which
 | |
| * contain the internal IPIF conditions.	 The following values may be used to
 | |
| * set the status register or clear an interrupt condition.
 | |
| *
 | |
| *   XIIF_V123B_ERROR_MASK     Indicates a device error in the IPIF
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_WRITE_DISR(RegBaseAddress, Status) \
 | |
|     XIo_Out32((RegBaseAddress) + XIIF_V123B_DISR_OFFSET, (Status))
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_READ_DISR
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function gets the device interrupt status register contents.
 | |
| * This register indicates the status of interrupt sources for a device
 | |
| * which contains the IPIF.  The status is independent of whether interrupts
 | |
| * are enabled and could be used for polling a device at a higher level.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * device which contains the IPIF.  With the exception of some internal IPIF
 | |
| * conditions, the contents of this register are not latched but indicate
 | |
| * the live status of the interrupt sources within the device.
 | |
| *
 | |
| * For only the latched bits of this register, the interrupt may be cleared by
 | |
| * writing to these bits in the status register.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * A status which contains the value read from the interrupt status register of
 | |
| * the device. The bit definitions are specific to the device with
 | |
| * the exception of the latched internal IPIF condition bits. The following
 | |
| * values may be used to detect internal IPIF conditions in the status.
 | |
| *
 | |
| *   XIIF_V123B_ERROR_MASK     Indicates a device error in the IPIF
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_READ_DISR(RegBaseAddress) \
 | |
|     XIo_In32((RegBaseAddress) + XIIF_V123B_DISR_OFFSET)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_WRITE_DIER
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function sets the device interrupt enable register contents.
 | |
| * This register controls which interrupt sources of the device are allowed to
 | |
| * generate an interrupt.  The device global interrupt enable register must also
 | |
| * be set appropriately for an interrupt to be passed out of the device.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * device which contains the IPIF.  Setting a bit in this register enables that
 | |
| * interrupt source to generate an interrupt.  Clearing a bit in this register
 | |
| * disables interrupt generation for that interrupt source.
 | |
| *
 | |
| * This function writes only the specified value to the register such that
 | |
| * some interrupts source may be enabled and others disabled.  It is the
 | |
| * caller's responsibility to get the value of the interrupt enable register
 | |
| * prior to setting the value to prevent an destructive behavior.
 | |
| *
 | |
| * An interrupt source may not be enabled to generate an interrupt, but can
 | |
| * still be polled in the interrupt status register.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * Enable contains the value to be written to the interrupt enable register
 | |
| * of the device.  The bit definitions are specific to the device with
 | |
| * the exception of the internal IPIF conditions. The following
 | |
| * values may be used to enable the internal IPIF conditions interrupts.
 | |
| *
 | |
| *   XIIF_V123B_ERROR_MASK     Indicates a device error in the IPIF
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * Signature: u32 XIIF_V123B_WRITE_DIER(u32 RegBaseAddress,
 | |
| *					  u32 Enable)
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_WRITE_DIER(RegBaseAddress, Enable) \
 | |
|     XIo_Out32((RegBaseAddress) + XIIF_V123B_DIER_OFFSET, (Enable))
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_READ_DIER
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function gets the device interrupt enable register contents.
 | |
| * This register controls which interrupt sources of the device
 | |
| * are allowed to generate an interrupt.	 The device global interrupt enable
 | |
| * register and the device interrupt enable register must also be set
 | |
| * appropriately for an interrupt to be passed out of the device.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * device which contains the IPIF.  Setting a bit in this register enables that
 | |
| * interrupt source to generate an interrupt if the global enable is set
 | |
| * appropriately.  Clearing a bit in this register disables interrupt generation
 | |
| * for that interrupt source regardless of the global interrupt enable.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * The value read from the interrupt enable register of the device.  The bit
 | |
| * definitions are specific to the device with the exception of the internal
 | |
| * IPIF conditions. The following values may be used to determine from the
 | |
| * value if the internal IPIF conditions interrupts are enabled.
 | |
| *
 | |
| *   XIIF_V123B_ERROR_MASK     Indicates a device error in the IPIF
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_READ_DIER(RegBaseAddress) \
 | |
|     XIo_In32((RegBaseAddress) + XIIF_V123B_DIER_OFFSET)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_READ_DIPR
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function gets the device interrupt pending register contents.
 | |
| * This register indicates the pending interrupt sources, those that are waiting
 | |
| * to be serviced by the software, for a device which contains the IPIF.
 | |
| * An interrupt must be enabled in the interrupt enable register of the IPIF to
 | |
| * be pending.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * the device which contains the IPIF.  With the exception of some internal IPIF
 | |
| * conditions, the contents of this register are not latched since the condition
 | |
| * is latched in the IP interrupt status register, by an internal block of the
 | |
| * IPIF such as a FIFO or DMA channel, or by the IP of the device.  This register
 | |
| * is read only and is not latched, but it is necessary to acknowledge (clear)
 | |
| * the interrupt condition by performing the appropriate processing for the IP
 | |
| * or block within the IPIF.
 | |
| *
 | |
| * This register can be thought of as the contents of the interrupt status
 | |
| * register ANDed with the contents of the interrupt enable register.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * The value read from the interrupt pending register of the device.  The bit
 | |
| * definitions are specific to the device with the exception of the latched
 | |
| * internal IPIF condition bits. The following values may be used to detect
 | |
| * internal IPIF conditions in the value.
 | |
| *
 | |
| *   XIIF_V123B_ERROR_MASK     Indicates a device error in the IPIF
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_READ_DIPR(RegBaseAddress) \
 | |
|     XIo_In32((RegBaseAddress) + XIIF_V123B_DIPR_OFFSET)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_READ_DIIR
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function gets the device interrupt ID for the highest priority interrupt
 | |
| * which is pending from the interrupt ID register. This function provides
 | |
| * priority resolution such that faster interrupt processing is possible.
 | |
| * Without priority resolution, it is necessary for the software to read the
 | |
| * interrupt pending register and then check each interrupt source to determine
 | |
| * if an interrupt is pending.  Priority resolution becomes more important as the
 | |
| * number of interrupt sources becomes larger.
 | |
| *
 | |
| * Interrupt priorities are based upon the bit position of the interrupt in the
 | |
| * interrupt pending register with bit 0 being the highest priority. The
 | |
| * interrupt ID is the priority of the interrupt, 0 - 31, with 0 being the
 | |
| * highest priority. The interrupt ID register is live rather than latched such
 | |
| * that multiple calls to this function may not yield the same results.	A
 | |
| * special value, outside of the interrupt priority range of 0 - 31, is
 | |
| * contained in the register which indicates that no interrupt is pending.  This
 | |
| * may be useful for allowing software to continue processing interrupts in a
 | |
| * loop until there are no longer any interrupts pending.
 | |
| *
 | |
| * The interrupt ID is designed to allow a function pointer table to be used
 | |
| * in the software such that the interrupt ID is used as an index into that
 | |
| * table.  The function pointer table could contain an instance pointer, such
 | |
| * as to DMA channel, and a function pointer to the function which handles
 | |
| * that interrupt.  This design requires the interrupt processing of the device
 | |
| * driver to be partitioned into smaller more granular pieces based upon
 | |
| * hardware used by the device, such as DMA channels and FIFOs.
 | |
| *
 | |
| * It is not mandatory that this function be used by the device driver software.
 | |
| * It may choose to read the pending register and resolve the pending interrupt
 | |
| * priorities on it's own.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * An interrupt ID, 0 - 31, which identifies the highest priority interrupt
 | |
| * which is pending.  A value of XIIF_NO_INTERRUPT_ID indicates that there is
 | |
| * no interrupt pending. The following values may be used to identify the
 | |
| * interrupt ID for the internal IPIF interrupts.
 | |
| *
 | |
| *   XIIF_V123B_ERROR_INTERRUPT_ID     Indicates a device error in the IPIF
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_READ_DIIR(RegBaseAddress) \
 | |
|     XIo_In32((RegBaseAddress) + XIIF_V123B_DIIR_OFFSET)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_GLOBAL_INTR_DISABLE
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function disables all interrupts for the device by writing to the global
 | |
| * interrupt enable register.  This register provides the ability to disable
 | |
| * interrupts without any modifications to the interrupt enable register such
 | |
| * that it is minimal effort to restore the interrupts to the previous enabled
 | |
| * state.  The corresponding function, XIpIf_GlobalIntrEnable, is provided to
 | |
| * restore the interrupts to the previous enabled state.	 This function is
 | |
| * designed to be used in critical sections of device drivers such that it is
 | |
| * not necessary to disable other device interrupts.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_GINTR_DISABLE(RegBaseAddress) \
 | |
|     XIo_Out32((RegBaseAddress) + XIIF_V123B_DGIER_OFFSET, 0)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_GINTR_ENABLE
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function writes to the global interrupt enable register to enable
 | |
| * interrupts from the device.  This register provides the ability to enable
 | |
| * interrupts without any modifications to the interrupt enable register such
 | |
| * that it is minimal effort to restore the interrupts to the previous enabled
 | |
| * state.  This function does not enable individual interrupts as the interrupt
 | |
| * enable register must be set appropriately.  This function is designed to be
 | |
| * used in critical sections of device drivers such that it is not necessary to
 | |
| * disable other device interrupts.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_GINTR_ENABLE(RegBaseAddress)		  \
 | |
|     XIo_Out32((RegBaseAddress) + XIIF_V123B_DGIER_OFFSET, \
 | |
| 	       XIIF_V123B_GINTR_ENABLE_MASK)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_IS_GINTR_ENABLED
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function determines if interrupts are enabled at the global level by
 | |
| * reading the gloabl interrupt register. This register provides the ability to
 | |
| * disable interrupts without any modifications to the interrupt enable register
 | |
| * such that it is minimal effort to restore the interrupts to the previous
 | |
| * enabled state.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * XTRUE if interrupts are enabled for the IPIF, XFALSE otherwise.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_IS_GINTR_ENABLED(RegBaseAddress)		\
 | |
|     (XIo_In32((RegBaseAddress) + XIIF_V123B_DGIER_OFFSET) ==	\
 | |
| 	      XIIF_V123B_GINTR_ENABLE_MASK)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_WRITE_IISR
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function sets the IP interrupt status register to the specified value.
 | |
| * This register indicates the status of interrupt sources for the IP of the
 | |
| * device.  The IP is defined as the part of the device that connects to the
 | |
| * IPIF.	 The status is independent of whether interrupts are enabled such that
 | |
| * the status register may also be polled when interrupts are not enabled.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * IP.  All bits of this register are latched. Setting a bit which is zero
 | |
| * within this register causes an interrupt to be generated.  The device global
 | |
| * interrupt enable register and the device interrupt enable register must be set
 | |
| * appropriately to allow an interrupt to be passed out of the device. The
 | |
| * interrupt is cleared by writing to this register with the bits to be
 | |
| * cleared set to a one and all others to zero.	This register implements a
 | |
| * toggle on write functionality meaning any bits which are set in the value
 | |
| * written cause the bits in the register to change to the opposite state.
 | |
| *
 | |
| * This function writes only the specified value to the register such that
 | |
| * some status bits may be set and others cleared.  It is the caller's
 | |
| * responsibility to get the value of the register prior to setting the value
 | |
| * to prevent an destructive behavior.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * Status contains the value to be written to the IP interrupt status
 | |
| * register.  The bit definitions are specific to the device IP.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_WRITE_IISR(RegBaseAddress, Status) \
 | |
|     XIo_Out32((RegBaseAddress) + XIIF_V123B_IISR_OFFSET, (Status))
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_READ_IISR
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function gets the contents of the IP interrupt status register.
 | |
| * This register indicates the status of interrupt sources for the IP of the
 | |
| * device.  The IP is defined as the part of the device that connects to the
 | |
| * IPIF. The status is independent of whether interrupts are enabled such
 | |
| * that the status register may also be polled when interrupts are not enabled.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * device.  All bits of this register are latched.  Writing a 1 to a bit within
 | |
| * this register causes an interrupt to be generated if enabled in the interrupt
 | |
| * enable register and the global interrupt enable is set.  Since the status is
 | |
| * latched, each status bit must be acknowledged in order for the bit in the
 | |
| * status register to be updated.  Each bit can be acknowledged by writing a
 | |
| * 0 to the bit in the status register.
 | |
| 
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * A status which contains the value read from the IP interrupt status register.
 | |
| * The bit definitions are specific to the device IP.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_READ_IISR(RegBaseAddress) \
 | |
|     XIo_In32((RegBaseAddress) + XIIF_V123B_IISR_OFFSET)
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_WRITE_IIER
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| * This function sets the IP interrupt enable register contents.	 This register
 | |
| * controls which interrupt sources of the IP are allowed to generate an
 | |
| * interrupt.  The global interrupt enable register and the device interrupt
 | |
| * enable register must also be set appropriately for an interrupt to be
 | |
| * passed out of the device containing the IPIF and the IP.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * IP.  Setting a bit in this register enables the interrupt source to generate
 | |
| * an interrupt.	 Clearing a bit in this register disables interrupt generation
 | |
| * for that interrupt source.
 | |
| *
 | |
| * This function writes only the specified value to the register such that
 | |
| * some interrupt sources may be enabled and others disabled.  It is the
 | |
| * caller's responsibility to get the value of the interrupt enable register
 | |
| * prior to setting the value to prevent an destructive behavior.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * Enable contains the value to be written to the IP interrupt enable register.
 | |
| * The bit definitions are specific to the device IP.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * None.
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_WRITE_IIER(RegBaseAddress, Enable) \
 | |
|     XIo_Out32((RegBaseAddress) + XIIF_V123B_IIER_OFFSET, (Enable))
 | |
| 
 | |
| /******************************************************************************
 | |
| *
 | |
| * MACRO:
 | |
| *
 | |
| * XIIF_V123B_READ_IIER
 | |
| *
 | |
| * DESCRIPTION:
 | |
| *
 | |
| *
 | |
| * This function gets the IP interrupt enable register contents.	 This register
 | |
| * controls which interrupt sources of the IP are allowed to generate an
 | |
| * interrupt.  The global interrupt enable register and the device interrupt
 | |
| * enable register must also be set appropriately for an interrupt to be
 | |
| * passed out of the device containing the IPIF and the IP.
 | |
| *
 | |
| * Each bit of the register correlates to a specific interrupt source within the
 | |
| * IP.  Setting a bit in this register enables the interrupt source to generate
 | |
| * an interrupt.	 Clearing a bit in this register disables interrupt generation
 | |
| * for that interrupt source.
 | |
| *
 | |
| * ARGUMENTS:
 | |
| *
 | |
| * RegBaseAddress contains the base address of the IPIF registers.
 | |
| *
 | |
| * RETURN VALUE:
 | |
| *
 | |
| * The contents read from the IP interrupt enable register.  The bit definitions
 | |
| * are specific to the device IP.
 | |
| *
 | |
| * NOTES:
 | |
| *
 | |
| * Signature: u32 XIIF_V123B_READ_IIER(u32 RegBaseAddress)
 | |
| *
 | |
| ******************************************************************************/
 | |
| #define XIIF_V123B_READ_IIER(RegBaseAddress) \
 | |
|     XIo_In32((RegBaseAddress) + XIIF_V123B_IIER_OFFSET)
 | |
| 
 | |
| /************************** Function Prototypes ******************************/
 | |
| 
 | |
| /*
 | |
|  * Initialization Functions
 | |
|  */
 | |
| XStatus XIpIfV123b_SelfTest(u32 RegBaseAddress, u8 IpRegistersWidth);
 | |
| 
 | |
| #endif				/* end of protection macro */
 |