From bb756eebdac6fd24e8919e2c43f7d2c8c4091f59 Mon Sep 17 00:00:00 2001 From: RajithaY Date: Tue, 25 Apr 2017 03:31:15 -0700 Subject: Adding qemu as a submodule of KVMFORNFV This Patch includes the changes to add qemu as a submodule to kvmfornfv repo and make use of the updated latest qemu for the execution of all testcase Change-Id: I1280af507a857675c7f81d30c95255635667bdd7 Signed-off-by:RajithaY --- qemu/roms/ipxe/src/drivers/net/smsc75xx.h | 309 ------------------------------ 1 file changed, 309 deletions(-) delete mode 100644 qemu/roms/ipxe/src/drivers/net/smsc75xx.h (limited to 'qemu/roms/ipxe/src/drivers/net/smsc75xx.h') diff --git a/qemu/roms/ipxe/src/drivers/net/smsc75xx.h b/qemu/roms/ipxe/src/drivers/net/smsc75xx.h deleted file mode 100644 index 2463b72a1..000000000 --- a/qemu/roms/ipxe/src/drivers/net/smsc75xx.h +++ /dev/null @@ -1,309 +0,0 @@ -#ifndef _SMSC75XX_H -#define _SMSC75XX_H - -/** @file - * - * SMSC LAN75xx USB Ethernet driver - * - */ - -FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL ); - -#include -#include -#include -#include - -/** Register write command */ -#define SMSC75XX_REGISTER_WRITE \ - ( USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE | \ - USB_REQUEST_TYPE ( 0xa0 ) ) - -/** Register read command */ -#define SMSC75XX_REGISTER_READ \ - ( USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE | \ - USB_REQUEST_TYPE ( 0xa1 ) ) - -/** Get statistics command */ -#define SMSC75XX_GET_STATISTICS \ - ( USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE | \ - USB_REQUEST_TYPE ( 0xa2 ) ) - -/** Interrupt status register */ -#define SMSC75XX_INT_STS 0x00c -#define SMSC75XX_INT_STS_RDFO_INT 0x00400000UL /**< RX FIFO overflow */ -#define SMSC75XX_INT_STS_PHY_INT 0x00020000UL /**< PHY interrupt */ - -/** Hardware configuration register */ -#define SMSC75XX_HW_CFG 0x010 -#define SMSC75XX_HW_CFG_BIR 0x00000080UL /**< Bulk IN use NAK */ -#define SMSC75XX_HW_CFG_LRST 0x00000002UL /**< Soft lite reset */ - -/** Interrupt endpoint control register */ -#define SMSC75XX_INT_EP_CTL 0x038 -#define SMSC75XX_INT_EP_CTL_RDFO_EN 0x00400000UL /**< RX FIFO overflow */ -#define SMSC75XX_INT_EP_CTL_PHY_EN 0x00020000UL /**< PHY interrupt */ - -/** Bulk IN delay register */ -#define SMSC75XX_BULK_IN_DLY 0x03c -#define SMSC75XX_BULK_IN_DLY_SET(ticks) ( (ticks) << 0 ) /**< Delay / 16.7ns */ - -/** EEPROM command register */ -#define SMSC75XX_E2P_CMD 0x040 -#define SMSC75XX_E2P_CMD_EPC_BSY 0x80000000UL /**< EPC busy */ -#define SMSC75XX_E2P_CMD_EPC_CMD_READ 0x00000000UL /**< READ command */ -#define SMSC75XX_E2P_CMD_EPC_ADDR(addr) ( (addr) << 0 ) /**< EPC address */ - -/** EEPROM data register */ -#define SMSC75XX_E2P_DATA 0x044 -#define SMSC75XX_E2P_DATA_GET(e2p_data) \ - ( ( (e2p_data) >> 0 ) & 0xff ) /**< EEPROM data */ - -/** MAC address EEPROM address */ -#define SMSC75XX_EEPROM_MAC 0x01 - -/** Receive filtering engine control register */ -#define SMSC75XX_RFE_CTL 0x060 -#define SMSC75XX_RFE_CTL_AB 0x00000400UL /**< Accept broadcast */ -#define SMSC75XX_RFE_CTL_AM 0x00000200UL /**< Accept multicast */ -#define SMSC75XX_RFE_CTL_AU 0x00000100UL /**< Accept unicast */ - -/** FIFO controller RX FIFO control register */ -#define SMSC75XX_FCT_RX_CTL 0x090 -#define SMSC75XX_FCT_RX_CTL_EN 0x80000000UL /**< FCT RX enable */ -#define SMSC75XX_FCT_RX_CTL_BAD 0x02000000UL /**< Store bad frames */ - -/** FIFO controller TX FIFO control register */ -#define SMSC75XX_FCT_TX_CTL 0x094 -#define SMSC75XX_FCT_TX_CTL_EN 0x80000000UL /**< FCT TX enable */ - -/** MAC receive register */ -#define SMSC75XX_MAC_RX 0x104 -#define SMSC75XX_MAC_RX_MAX_SIZE(mtu) ( (mtu) << 16 ) /**< Max frame size */ -#define SMSC75XX_MAC_RX_MAX_SIZE_DEFAULT \ - SMSC75XX_MAC_RX_MAX_SIZE ( ETH_FRAME_LEN + 4 /* VLAN */ + 4 /* CRC */ ) -#define SMSC75XX_MAC_RX_FCS 0x00000010UL /**< FCS stripping */ -#define SMSC75XX_MAC_RX_EN 0x00000001UL /**< RX enable */ - -/** MAC transmit register */ -#define SMSC75XX_MAC_TX 0x108 -#define SMSC75XX_MAC_TX_EN 0x00000001UL /**< TX enable */ - -/** MAC receive address high register */ -#define SMSC75XX_RX_ADDRH 0x118 - -/** MAC receive address low register */ -#define SMSC75XX_RX_ADDRL 0x11c - -/** MII access register */ -#define SMSC75XX_MII_ACCESS 0x120 -#define SMSC75XX_MII_ACCESS_PHY_ADDRESS 0x00000800UL /**< PHY address */ -#define SMSC75XX_MII_ACCESS_MIIRINDA(addr) ( (addr) << 6 ) /**< MII register */ -#define SMSC75XX_MII_ACCESS_MIIWNR 0x00000002UL /**< MII write */ -#define SMSC75XX_MII_ACCESS_MIIBZY 0x00000001UL /**< MII busy */ - -/** MII data register */ -#define SMSC75XX_MII_DATA 0x124 -#define SMSC75XX_MII_DATA_SET(data) ( (data) << 0 ) /**< Set data */ -#define SMSC75XX_MII_DATA_GET(mii_data) \ - ( ( (mii_data) >> 0 ) & 0xffff ) /**< Get data */ - -/** PHY interrupt source MII register */ -#define SMSC75XX_MII_PHY_INTR_SOURCE 29 - -/** PHY interrupt mask MII register */ -#define SMSC75XX_MII_PHY_INTR_MASK 30 - -/** PHY interrupt: auto-negotiation complete */ -#define SMSC75XX_PHY_INTR_ANEG_DONE 0x0040 - -/** PHY interrupt: link down */ -#define SMSC75XX_PHY_INTR_LINK_DOWN 0x0010 - -/** MAC address perfect filter N high register */ -#define SMSC75XX_ADDR_FILTH(n) ( 0x300 + ( 8 * (n) ) ) -#define SMSC75XX_ADDR_FILTH_VALID 0x80000000UL /**< Address valid */ - -/** MAC address perfect filter N low register */ -#define SMSC75XX_ADDR_FILTL(n) ( 0x304 + ( 8 * (n) ) ) - -/** MAC address */ -union smsc75xx_mac { - /** MAC receive address registers */ - struct { - /** MAC receive address low register */ - uint32_t l; - /** MAC receive address high register */ - uint32_t h; - } __attribute__ (( packed )) addr; - /** Raw MAC address */ - uint8_t raw[ETH_ALEN]; -}; - -/** Receive packet header */ -struct smsc75xx_rx_header { - /** RX command word */ - uint32_t command; - /** VLAN tag */ - uint16_t vtag; - /** Checksum */ - uint16_t csum; - /** Two-byte padding used to align Ethernet payload */ - uint16_t pad; -} __attribute__ (( packed )); - -/** Receive error detected */ -#define SMSC75XX_RX_RED 0x00400000UL - -/** Transmit packet header */ -struct smsc75xx_tx_header { - /** TX command word */ - uint32_t command; - /** VLAN tag */ - uint16_t tag; - /** Maximum segment size */ - uint16_t mss; -} __attribute__ (( packed )); - -/** Insert frame checksum and pad */ -#define SMSC75XX_TX_FCS 0x00400000UL - -/** Interrupt packet format */ -struct smsc75xx_interrupt { - /** Current value of INT_STS register */ - uint32_t int_sts; -} __attribute__ (( packed )); - -/** Byte count statistics */ -struct smsc75xx_byte_statistics { - /** Unicast byte count */ - uint32_t unicast; - /** Broadcast byte count */ - uint32_t broadcast; - /** Multicast byte count */ - uint32_t multicast; -} __attribute__ (( packed )); - -/** Frame count statistics */ -struct smsc75xx_frame_statistics { - /** Unicast frames */ - uint32_t unicast; - /** Broadcast frames */ - uint32_t broadcast; - /** Multicast frames */ - uint32_t multicast; - /** Pause frames */ - uint32_t pause; - /** Frames by length category */ - uint32_t len[7]; -} __attribute__ (( packed )); - -/** Receive error statistics */ -struct smsc75xx_rx_error_statistics { - /** FCS errors */ - uint32_t fcs; - /** Alignment errors */ - uint32_t alignment; - /** Fragment errors */ - uint32_t fragment; - /** Jabber errors */ - uint32_t jabber; - /** Undersize frame errors */ - uint32_t undersize; - /** Oversize frame errors */ - uint32_t oversize; - /** Dropped frame errors */ - uint32_t dropped; -} __attribute__ (( packed )); - -/** Receive statistics */ -struct smsc75xx_rx_statistics { - /** Error statistics */ - struct smsc75xx_rx_error_statistics err; - /** Byte count statistics */ - struct smsc75xx_byte_statistics byte; - /** Frame count statistics */ - struct smsc75xx_frame_statistics frame; -} __attribute__ (( packed )); - -/** Transmit error statistics */ -struct smsc75xx_tx_error_statistics { - /** FCS errors */ - uint32_t fcs; - /** Excess deferral errors */ - uint32_t deferral; - /** Carrier errors */ - uint32_t carrier; - /** Bad byte count */ - uint32_t count; - /** Single collisions */ - uint32_t single; - /** Multiple collisions */ - uint32_t multiple; - /** Excession collisions */ - uint32_t excessive; - /** Late collisions */ - uint32_t late; -} __attribute__ (( packed )); - -/** Transmit statistics */ -struct smsc75xx_tx_statistics { - /** Error statistics */ - struct smsc75xx_tx_error_statistics err; - /** Byte count statistics */ - struct smsc75xx_byte_statistics byte; - /** Frame count statistics */ - struct smsc75xx_frame_statistics frame; -} __attribute__ (( packed )); - -/** Statistics */ -struct smsc75xx_statistics { - /** Receive statistics */ - struct smsc75xx_rx_statistics rx; - /** Transmit statistics */ - struct smsc75xx_tx_statistics tx; -} __attribute__ (( packed )); - -/** A SMSC75xx network device */ -struct smsc75xx_device { - /** USB device */ - struct usb_device *usb; - /** USB bus */ - struct usb_bus *bus; - /** Network device */ - struct net_device *netdev; - /** USB network device */ - struct usbnet_device usbnet; - /** MII interface */ - struct mii_interface mii; - /** Interrupt status */ - uint32_t int_sts; -}; - -/** Reset delay (in microseconds) */ -#define SMSC75XX_RESET_DELAY_US 2 - -/** Maximum time to wait for EEPROM (in milliseconds) */ -#define SMSC75XX_EEPROM_MAX_WAIT_MS 100 - -/** Maximum time to wait for MII (in milliseconds) */ -#define SMSC75XX_MII_MAX_WAIT_MS 100 - -/** Interrupt maximum fill level - * - * This is a policy decision. - */ -#define SMSC75XX_INTR_MAX_FILL 2 - -/** Bulk IN maximum fill level - * - * This is a policy decision. - */ -#define SMSC75XX_IN_MAX_FILL 8 - -/** Bulk IN buffer size */ -#define SMSC75XX_IN_MTU \ - ( sizeof ( struct smsc75xx_rx_header ) + \ - ETH_FRAME_LEN + 4 /* possible VLAN header */ ) - -#endif /* _SMSC75XX_H */ -- cgit 1.2.3-korg