/* * Routines to access hardware * * Copyright (c) 2013 Realtek Semiconductor Corp. * * This module is a confidential and proprietary property of RealTek and * possession or use of this module requires written permission of RealTek. */ #ifndef _RTL8195A_USB_H_ #define _RTL8195A_USB_H_ // common command for USB #define USB_CMD_TX_ETH 0x83 // request to TX a 802.3 packet #define USB_CMD_TX_WLN 0x81 // request to TX a 802.11 packet #define USB_CMD_H2C 0x11 // H2C(host to device) command packet #define USB_CMD_MEMRD 0x51 // request to read a block of memory data #define USB_CMD_MEMWR 0x53 // request to write a block of memory #define USB_CMD_MEMST 0x55 // request to set a block of memory with a value #define USB_CMD_STARTUP 0x61 // request to jump to the start up function #define USB_CMD_RX_ETH 0x82 // indicate a RX 802.3 packet #define USB_CMD_RX_WLN 0x80 // indicate a RX 802.11 packet #define USB_CMD_C2H 0x10 // C2H(device to host) command packet #define USB_CMD_MEMRD_RSP 0x50 // response to memory block read command #define USB_CMD_MEMWR_RSP 0x52 // response to memory write command #define USB_CMD_MEMST_RSP 0x54 // response to memory set command #define USB_CMD_STARTED 0x60 // indicate the program has jumped to the given function // TODO: This data structer just for test, we should modify it for the normal driver typedef struct _USB_TX_DESC{ // u4Byte 0 #if (SYSTEM_ENDIAN==PLATFORM_LITTLE_ENDIAN) u32 txpktsize:16; // bit[15:0] u32 offset:8; // bit[23:16], store the sizeof(SDIO_TX_DESC) u32 bus_agg_num:8; // bit[31:24], the bus aggregation number #else u32 bus_agg_num:8; // bit[31:24], the bus aggregation number u32 offset:8; // bit[23:16], store the sizeof(SDIO_TX_DESC) u32 txpktsize:16; // bit[15:0] #endif // u4Byte 1 #if (SYSTEM_ENDIAN==PLATFORM_LITTLE_ENDIAN) u32 type:8; // bit[7:0], the packet type u32 rsvd0:24; #else u32 rsvd0:24; u32 type:8; // bit[7:0], the packet type #endif // u4Byte 2 u32 rsvd1; // u4Byte 3 u32 rsvd2; // u4Byte 4 u32 rsvd3; // u4Byte 5 u32 rsvd4; } USB_TX_DESC, *PUSB_TX_DESC; #define SIZE_USB_TX_DESC sizeof(USB_TX_DESC) // TODO: This data structer just for test, we should modify it for the normal driver typedef struct _USB_RX_DESC{ // u4Byte 0 #if (SYSTEM_ENDIAN==PLATFORM_LITTLE_ENDIAN) u32 pkt_len:16; // bit[15:0], the packet size u32 offset:8; // bit[23:16], the offset from the packet start to the buf start, also means the size of RX Desc u32 rsvd0:6; // bit[29:24] u32 icv:1; // bit[30], ICV error u32 crc:1; // bit[31], CRC error #else u32 crc:1; // bit[31], CRC error u32 icv:1; // bit[30], ICV error u32 rsvd0:6; // bit[29:24] u32 offset:8; // bit[23:16], the offset from the packet start to the buf start, also means the size of RX Desc u32 pkt_len:16; // bit[15:0], the packet size #endif // u4Byte 1 #if (SYSTEM_ENDIAN==PLATFORM_LITTLE_ENDIAN) u32 type:8; // bit[7:0], the type of this packet u32 rsvd1:24; // bit[31:8] #else u32 rsvd1:24; // bit[31:8] u32 type:8; // bit[7:0], the type of this packet #endif // u4Byte 2 u32 rsvd2; // u4Byte 3 u32 rsvd3; // u4Byte 4 u32 rsvd4; // u4Byte 5 u32 rsvd5; } USB_RX_DESC, *PUSB_RX_DESC; #define SIZE_USB_RX_DESC sizeof(USB_RX_DESC) #endif // #ifndef _RTL8195A_USB_H_