Go to the documentation of this file.
   31 #ifndef _PIC32CX_ETH_DRIVER_H 
   32 #define _PIC32CX_ETH_DRIVER_H 
   38 #ifndef PIC32CX_ETH_TX_BUFFER_COUNT 
   39    #define PIC32CX_ETH_TX_BUFFER_COUNT 3 
   40 #elif (PIC32CX_ETH_TX_BUFFER_COUNT < 1) 
   41    #error PIC32CX_ETH_TX_BUFFER_COUNT parameter is not valid 
   45 #ifndef PIC32CX_ETH_TX_BUFFER_SIZE 
   46    #define PIC32CX_ETH_TX_BUFFER_SIZE 1536 
   47 #elif (PIC32CX_ETH_TX_BUFFER_SIZE != 1536) 
   48    #error PIC32CX_ETH_TX_BUFFER_SIZE parameter is not valid 
   52 #ifndef PIC32CX_ETH_RX_BUFFER_COUNT 
   53    #define PIC32CX_ETH_RX_BUFFER_COUNT 72 
   54 #elif (PIC32CX_ETH_RX_BUFFER_COUNT < 12) 
   55    #error PIC32CX_ETH_RX_BUFFER_COUNT parameter is not valid 
   59 #ifndef PIC32CX_ETH_RX_BUFFER_SIZE 
   60    #define PIC32CX_ETH_RX_BUFFER_SIZE 128 
   61 #elif (PIC32CX_ETH_RX_BUFFER_SIZE != 128) 
   62    #error PIC32CX_ETH_RX_BUFFER_SIZE parameter is not valid 
   66 #ifndef PIC32CX_ETH_IRQ_PRIORITY_GROUPING 
   67    #define PIC32CX_ETH_IRQ_PRIORITY_GROUPING 4 
   68 #elif (PIC32CX_ETH_IRQ_PRIORITY_GROUPING < 0) 
   69    #error PIC32CX_ETH_IRQ_PRIORITY_GROUPING parameter is not valid 
   73 #ifndef PIC32CX_ETH_IRQ_GROUP_PRIORITY 
   74    #define PIC32CX_ETH_IRQ_GROUP_PRIORITY 6 
   75 #elif (PIC32CX_ETH_IRQ_GROUP_PRIORITY < 0) 
   76    #error PIC32CX_ETH_IRQ_GROUP_PRIORITY parameter is not valid 
   80 #ifndef PIC32CX_ETH_IRQ_SUB_PRIORITY 
   81    #define PIC32CX_ETH_IRQ_SUB_PRIORITY 0 
   82 #elif (PIC32CX_ETH_IRQ_SUB_PRIORITY < 0) 
   83    #error PIC32CX_ETH_IRQ_SUB_PRIORITY parameter is not valid 
   87 #define GMAC_TX_USED           0x80000000 
   88 #define GMAC_TX_WRAP           0x40000000 
   89 #define GMAC_TX_RLE_ERROR      0x20000000 
   90 #define GMAC_TX_UNDERRUN_ERROR 0x10000000 
   91 #define GMAC_TX_AHB_ERROR      0x08000000 
   92 #define GMAC_TX_LATE_COL_ERROR 0x04000000 
   93 #define GMAC_TX_CHECKSUM_ERROR 0x00700000 
   94 #define GMAC_TX_NO_CRC         0x00010000 
   95 #define GMAC_TX_LAST           0x00008000 
   96 #define GMAC_TX_LENGTH         0x00003FFF 
   99 #define GMAC_RX_ADDRESS        0xFFFFFFFC 
  100 #define GMAC_RX_WRAP           0x00000002 
  101 #define GMAC_RX_OWNERSHIP      0x00000001 
  102 #define GMAC_RX_BROADCAST      0x80000000 
  103 #define GMAC_RX_MULTICAST_HASH 0x40000000 
  104 #define GMAC_RX_UNICAST_HASH   0x20000000 
  105 #define GMAC_RX_SAR            0x08000000 
  106 #define GMAC_RX_SAR_MASK       0x06000000 
  107 #define GMAC_RX_TYPE_ID        0x01000000 
  108 #define GMAC_RX_SNAP           0x01000000 
  109 #define GMAC_RX_TYPE_ID_MASK   0x00C00000 
  110 #define GMAC_RX_CHECKSUM_VALID 0x00C00000 
  111 #define GMAC_RX_VLAN_TAG       0x00200000 
  112 #define GMAC_RX_PRIORITY_TAG   0x00100000 
  113 #define GMAC_RX_VLAN_PRIORITY  0x000E0000 
  114 #define GMAC_RX_CFI            0x00010000 
  115 #define GMAC_RX_EOF            0x00008000 
  116 #define GMAC_RX_SOF            0x00004000 
  117 #define GMAC_RX_LENGTH_MSB     0x00002000 
  118 #define GMAC_RX_BAD_FCS        0x00002000 
  119 #define GMAC_RX_LENGTH         0x00001FFF 
  
void pic32cxEthTick(NetInterface *interface)
PIC32CX Ethernet MAC timer handler.
uint16_t pic32cxEthReadPhyReg(uint8_t opcode, uint8_t phyAddr, uint8_t regAddr)
Read PHY register.
Structure describing a buffer that spans multiple chunks.
void pic32cxEthWritePhyReg(uint8_t opcode, uint8_t phyAddr, uint8_t regAddr, uint16_t data)
Write PHY register.
void pic32cxEthEventHandler(NetInterface *interface)
PIC32CX Ethernet MAC event handler.
const NicDriver pic32cxEthDriver
PIC32CX Ethernet MAC driver.
void pic32cxEthDisableIrq(NetInterface *interface)
Disable interrupts.
error_t pic32cxEthReceivePacket(NetInterface *interface)
Receive a packet.
void pic32cxEthInitGpio(NetInterface *interface)
GPIO configuration.
error_t pic32cxEthUpdateMacConfig(NetInterface *interface)
Adjust MAC configuration parameters for proper operation.
void pic32cxEthEnableIrq(NetInterface *interface)
Enable interrupts.
Receive buffer descriptor.
Network interface controller abstraction layer.
void pic32cxEthInitBufferDesc(NetInterface *interface)
Initialize buffer descriptors.
Transmit buffer descriptor.
error_t pic32cxEthSendPacket(NetInterface *interface, const NetBuffer *buffer, size_t offset, NetTxAncillary *ancillary)
Send a packet.
error_t pic32cxEthUpdateMacAddrFilter(NetInterface *interface)
Configure MAC address filtering.
error_t pic32cxEthInit(NetInterface *interface)
PIC32CX Ethernet MAC initialization.