270 lines
6.1 KiB
C
270 lines
6.1 KiB
C
#ifndef _W5500_H_
|
||
#define _W5500_H_
|
||
|
||
#include "main.h"
|
||
|
||
/***************** Common Register *****************/
|
||
#define MR 0x0000
|
||
#define RST 0x80
|
||
#define WOL 0x20
|
||
#define PB 0x10
|
||
#define PPP 0x08
|
||
#define FARP 0x02
|
||
|
||
#define GAR 0x0001
|
||
#define SUBR 0x0005
|
||
#define SHAR 0x0009
|
||
#define SIPR 0x000f
|
||
|
||
#define INTLEVEL 0x0013
|
||
#define IR 0x0015
|
||
#define CONFLICT 0x80
|
||
#define UNREACH 0x40
|
||
#define PPPOE 0x20
|
||
#define MP 0x10
|
||
|
||
#define IMR 0x0016
|
||
#define IM_IR7 0x80
|
||
#define IM_IR6 0x40
|
||
#define IM_IR5 0x20
|
||
#define IM_IR4 0x10
|
||
|
||
#define SIR 0x0017
|
||
#define S7_INT 0x80
|
||
#define S6_INT 0x40
|
||
#define S5_INT 0x20
|
||
#define S4_INT 0x10
|
||
#define S3_INT 0x08
|
||
#define S2_INT 0x04
|
||
#define S1_INT 0x02
|
||
#define S0_INT 0x01
|
||
|
||
#define SIMR 0x0018
|
||
#define S7_IMR 0x80
|
||
#define S6_IMR 0x40
|
||
#define S5_IMR 0x20
|
||
#define S4_IMR 0x10
|
||
#define S3_IMR 0x08
|
||
#define S2_IMR 0x04
|
||
#define S1_IMR 0x02
|
||
#define S0_IMR 0x01
|
||
|
||
#define RTR 0x0019
|
||
#define RCR 0x001b
|
||
|
||
#define PTIMER 0x001c
|
||
#define PMAGIC 0x001d
|
||
#define PHA 0x001e
|
||
#define PSID 0x0024
|
||
#define PMRU 0x0026
|
||
|
||
#define UIPR 0x0028
|
||
#define UPORT 0x002c
|
||
|
||
#define PHYCFGR 0x002e
|
||
#define RST_PHY 0x80
|
||
#define OPMODE 0x40
|
||
#define DPX 0x04
|
||
#define SPD 0x02
|
||
#define LINK 0x01
|
||
|
||
#define VERR 0x0039
|
||
|
||
/********************* Socket Register *******************/
|
||
#define Sn_MR 0x0000
|
||
#define MULTI_MFEN 0x80
|
||
#define BCASTB 0x40
|
||
#define ND_MC_MMB 0x20
|
||
#define UCASTB_MIP6B 0x10
|
||
#define MR_CLOSE 0x00
|
||
#define MR_TCP 0x01
|
||
#define MR_UDP 0x02
|
||
#define MR_MACRAW 0x04
|
||
|
||
#define Sn_CR 0x0001
|
||
#define OPEN 0x01
|
||
#define LISTEN 0x02
|
||
#define CONNECT 0x04
|
||
#define DISCON 0x08
|
||
#define CLOSE 0x10
|
||
#define SEND 0x20
|
||
#define SEND_MAC 0x21
|
||
#define SEND_KEEP 0x22
|
||
#define RECV 0x40
|
||
|
||
#define Sn_IR 0x0002
|
||
#define IR_SEND_OK 0x10
|
||
#define IR_TIMEOUT 0x08
|
||
#define IR_RECV 0x04
|
||
#define IR_DISCON 0x02
|
||
#define IR_CON 0x01
|
||
|
||
#define Sn_SR 0x0003
|
||
#define SOCK_CLOSED 0x00
|
||
#define SOCK_INIT 0x13
|
||
#define SOCK_LISTEN 0x14
|
||
#define SOCK_ESTABLISHED 0x17
|
||
#define SOCK_CLOSE_WAIT 0x1c
|
||
#define SOCK_UDP 0x22
|
||
#define SOCK_MACRAW 0x02
|
||
|
||
#define SOCK_SYNSEND 0x15
|
||
#define SOCK_SYNRECV 0x16
|
||
#define SOCK_FIN_WAI 0x18
|
||
#define SOCK_CLOSING 0x1a
|
||
#define SOCK_TIME_WAIT 0x1b
|
||
#define SOCK_LAST_ACK 0x1d
|
||
|
||
#define Sn_PORT 0x0004
|
||
#define Sn_DHAR 0x0006
|
||
#define Sn_DIPR 0x000c
|
||
#define Sn_DPORTR 0x0010
|
||
|
||
#define Sn_MSSR 0x0012
|
||
#define Sn_TOS 0x0015
|
||
#define Sn_TTL 0x0016
|
||
|
||
#define Sn_RXBUF_SIZE 0x001e
|
||
#define Sn_TXBUF_SIZE 0x001f
|
||
#define Sn_TX_FSR 0x0020
|
||
#define Sn_TX_RD 0x0022
|
||
#define Sn_TX_WR 0x0024
|
||
#define Sn_RX_RSR 0x0026
|
||
#define Sn_RX_RD 0x0028
|
||
#define Sn_RX_WR 0x002a
|
||
|
||
#define Sn_IMR 0x002c
|
||
#define IMR_SENDOK 0x10
|
||
#define IMR_TIMEOUT 0x08
|
||
#define IMR_RECV 0x04
|
||
#define IMR_DISCON 0x02
|
||
#define IMR_CON 0x01
|
||
|
||
#define Sn_FRAG 0x002d
|
||
#define Sn_KPALVTR 0x002f
|
||
|
||
/*******************************************************************/
|
||
/************************ SPI Control Byte *************************/
|
||
/*******************************************************************/
|
||
/* Operation mode bits */
|
||
#define VDM 0x00
|
||
#define FDM1 0x01
|
||
#define FDM2 0x02
|
||
#define FDM4 0x03
|
||
|
||
/* Read_Write control bit */
|
||
#define RWB_READ 0x00
|
||
#define RWB_WRITE 0x04
|
||
|
||
/* Block select bits */
|
||
#define COMMON_R 0x00
|
||
|
||
/* Socket 0 */
|
||
#define S0_REG 0x08
|
||
#define S0_TX_BUF 0x10
|
||
#define S0_RX_BUF 0x18
|
||
|
||
/* Socket 1 */
|
||
#define S1_REG 0x28
|
||
#define S1_TX_BUF 0x30
|
||
#define S1_RX_BUF 0x38
|
||
|
||
/* Socket 2 */
|
||
#define S2_REG 0x48
|
||
#define S2_TX_BUF 0x50
|
||
#define S2_RX_BUF 0x58
|
||
|
||
/* Socket 3 */
|
||
#define S3_REG 0x68
|
||
#define S3_TX_BUF 0x70
|
||
#define S3_RX_BUF 0x78
|
||
|
||
/* Socket 4 */
|
||
#define S4_REG 0x88
|
||
#define S4_TX_BUF 0x90
|
||
|
||
/* Socket 5 */
|
||
#define S5_REG 0xa8
|
||
#define S5_TX_BUF 0xb0
|
||
#define S5_RX_BUF 0xb8
|
||
|
||
/* Socket 6 */
|
||
#define S6_REG 0xc8
|
||
#define S6_TX_BUF 0xd0
|
||
#define S6_RX_BUF 0xd8
|
||
|
||
/* Socket 7 */
|
||
#define S7_REG 0xe8
|
||
#define S7_TX_BUF 0xf0
|
||
#define S7_RX_BUF 0xf8
|
||
|
||
#define TRUE 0xff
|
||
#define FALSE 0x00
|
||
|
||
#define S_RX_SIZE 2048 /*<2A><><EFBFBD><EFBFBD>Socket<65><74><EFBFBD>ջ<EFBFBD><D5BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ĵ<EFBFBD>С<EFBFBD><D0A1><EFBFBD><EFBFBD><EFBFBD>Ը<EFBFBD><D4B8><EFBFBD>W5500_RMSR<53><52><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
||
#define S_TX_SIZE 2048 /*<2A><><EFBFBD><EFBFBD>Socket<65><74><EFBFBD>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ĵ<EFBFBD>С<EFBFBD><D0A1><EFBFBD><EFBFBD><EFBFBD>Ը<EFBFBD><D4B8><EFBFBD>W5500_TMSR<53><52><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
||
|
||
/***************----- W5500 GPIO<49><4F><EFBFBD><EFBFBD> -----***************/
|
||
#define W5500_SCS W5500_SPI1_CS_Pin // <20><><EFBFBD><EFBFBD>W5500<30><30>CS<43><53><EFBFBD><EFBFBD>
|
||
#define W5500_SCS_PORT W5500_SPI1_CS_GPIO_Port
|
||
|
||
#define W5500_RST W5500_RST_Pin // <20><><EFBFBD><EFBFBD>W5500<30><30>RST<53><54><EFBFBD><EFBFBD>
|
||
#define W5500_RST_PORT W5500_RST_GPIO_Port
|
||
|
||
#define W5500_INT W5500_INT_Pin // <20><><EFBFBD><EFBFBD>W5500<30><30>INT<4E><54><EFBFBD><EFBFBD>
|
||
#define W5500_INT_PORT W5500_INT_GPIO_Port
|
||
|
||
typedef u8 SOCKET; // <20>Զ<EFBFBD><D4B6><EFBFBD><EFBFBD>˿ں<CBBF><DABA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
#define BSP_W5500_PORT_NUM 1
|
||
|
||
#define BSP_W5500_TX_DATA_LEN 2048
|
||
#define BSP_W5500_RX_DATA_LEN 2048
|
||
|
||
typedef struct bsp_W5500_Class_t bsp_W5500_Class_t;
|
||
|
||
struct bsp_W5500_Class_t
|
||
{
|
||
SOCKET SocketPort;
|
||
struct
|
||
{
|
||
/***************----- <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> -----***************/
|
||
u8 Port[2]; /*<2A>˿<EFBFBD>0<EFBFBD>Ķ˿ں<CBBF>(5000) */
|
||
u8 DIP[4]; /*<2A>˿<EFBFBD>0Ŀ<30><C4BF>IP<49><50>ַ*/
|
||
u8 DPort[2]; /*<2A>˿<EFBFBD>0Ŀ<30>Ķ˿ں<CBBF>(6000)*/
|
||
|
||
u8 UDP_DIPR[4]; /*UDP(<28>㲥)ģʽ,Ŀ<><C4BF><EFBFBD><EFBFBD><EFBFBD><EFBFBD>IP<49><50>ַ*/
|
||
u8 UDP_DPORT[2]; /*UDP(<28>㲥)ģʽ,Ŀ<><C4BF><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˿ں<CBBF>*/
|
||
}ConfigData;
|
||
/***************----- <20>˿ڵ<CBBF><DAB5><EFBFBD><EFBFBD><EFBFBD>ģʽ -----***************/
|
||
u8 Run_Mode;
|
||
/***************----- <20>˿ڵ<CBBF><DAB5><EFBFBD><EFBFBD><EFBFBD>״̬ -----***************/
|
||
u8 Run_State;
|
||
/***************----- <20>˿<EFBFBD><CBBF>շ<EFBFBD><D5B7><EFBFBD><EFBFBD>ݵ<EFBFBD>״̬ -----***********/
|
||
u8 TR_Data_State;
|
||
/***************----- <20>˿<EFBFBD><CBBF><EFBFBD><EFBFBD>ݻ<EFBFBD><DDBB><EFBFBD><EFBFBD><EFBFBD> -----***************/
|
||
u8 Rx_Buffer[BSP_W5500_RX_DATA_LEN]; // <20>˿ڽ<CBBF><DABD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݻ<EFBFBD><DDBB><EFBFBD><EFBFBD><EFBFBD>
|
||
u8 Tx_Buffer[BSP_W5500_TX_DATA_LEN]; // <20>˿ڷ<CBBF><DAB7><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݻ<EFBFBD><DDBB><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
u8 Interrupt; // W5500<30>жϱ<D0B6>־(0:<3A><><EFBFBD>ж<EFBFBD>,1:<3A><><EFBFBD>ж<EFBFBD>)
|
||
|
||
void (*Rx_DataAnalysis)(u8 *,u16 ,void *);
|
||
};
|
||
|
||
|
||
typedef struct
|
||
{
|
||
u8 Gateway_IP[4]; /*<2A><><EFBFBD><EFBFBD>IP<49><50>ַ*/
|
||
u8 Sub_Mask[4]; /*<2A><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>*/
|
||
u8 Phy_Addr[6]; /*<2A><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ(MAC)*/
|
||
u8 IP_Addr[4]; /*<2A><><EFBFBD><EFBFBD>IP<49><50>ַ*/
|
||
bsp_W5500_Class_t W5500_Class[BSP_W5500_PORT_NUM]; /*<2A>˿ڳ<CBBF>Ա*/
|
||
void (*Interrupt_Process)(void); /*<2A><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>*/
|
||
void (*Init)(void); /*<2A><>ʼ<EFBFBD><CABC>*/
|
||
void (*Task)(void); /*<2A><><EFBFBD><EFBFBD>*/
|
||
void (*Socket_Send)(bsp_W5500_Class_t *, u8 *, u16 ); /*<2A>˿ڷ<CBBF><DAB7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>*/
|
||
}bsp_W5500_t;
|
||
|
||
|
||
extern bsp_W5500_t W5500;
|
||
#endif
|