mirror of
https://github.com/eggman/ameba-gcc-sample-rtos.git
synced 2025-01-03 20:05:20 +00:00
111 lines
3.6 KiB
C
111 lines
3.6 KiB
C
/*
|
|
* 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_
|
|
|