 |
AM261x MCU+ SDK
11.00.00
|
|
Go to the documentation of this file.
55 #include <drivers/hw_include/csl_types.h>
66 #define ICSS_EMAC_MAX_PORTS_PER_INSTANCE (2)
67 #ifdef BUILD_HSR_PRP_MII
69 #define ICSS_EMAC_FW_LEARNING_EN (2U)
71 #define ICSS_EMAC_LOW_PRIORITY (1U)
73 #define ICSS_EMAC_HIGH_PRIORITY (2U)
83 #define ICSS_EMAC_MODE_MAC1 (1U)
85 #define ICSS_EMAC_MODE_MAC2 (2U)
87 #define ICSS_EMAC_MODE_SWITCH (3U)
89 #define ICSS_EMAC_MODE_DUALMAC (4U)
99 #define ICSS_EMAC_MII_MODE (0U)
101 #define ICSS_EMAC_RGMII_MODE (1U)
111 #define ICSS_EMAC_LEARNING_DISABLE (0U)
113 #define ICSS_EMAC_LEARNING_ENABLE (1U)
123 #define ICSS_EMAC_ENABLE_PACING (0)
125 #define ICSS_EMAC_DISABLE_PACING (1)
135 #define ICSS_EMAC_INTR_PACING_MODE1 (0)
145 #define ICSS_EMAC_QUEUE1 ((uint32_t)0U)
147 #define ICSS_EMAC_QUEUE2 ((uint32_t)1U)
149 #define ICSS_EMAC_QUEUE3 ((uint32_t)2U)
151 #define ICSS_EMAC_QUEUE4 ((uint32_t)3U)
153 #define ICSS_EMAC_QUEUE5 ((uint32_t)4U)
155 #define ICSS_EMAC_QUEUE6 ((uint32_t)5U)
157 #define ICSS_EMAC_QUEUE7 ((uint32_t)6U)
159 #define ICSS_EMAC_QUEUE8 ((uint32_t)7U)
161 #define ICSS_EMAC_QUEUE9 ((uint32_t)8U)
163 #define ICSS_EMAC_QUEUE10 ((uint32_t)9U)
165 #define ICSS_EMAC_QUEUE11 ((uint32_t)10U)
167 #define ICSS_EMAC_QUEUE12 ((uint32_t)11U)
169 #define ICSS_EMAC_QUEUE13 ((uint32_t)12U)
171 #define ICSS_EMAC_QUEUE14 ((uint32_t)13U)
173 #define ICSS_EMAC_QUEUE15 ((uint32_t)14U)
175 #define ICSS_EMAC_QUEUE16 ((uint32_t)15U)
177 #define ICSS_EMAC_COLQUEUE ((uint32_t)16U)
180 #ifdef BUILD_HSR_PRP_MII
182 #define ICSS_EMAC_SET_TX_OCCUPIED (1U)
184 #define ICSS_EMAC_CLR_TX_OCCUPIED (0U)
186 #define ICSS_EMAC_SCAN_PORT1_HIGH_FIRST (0U)
188 #define ICSS_EMAC_SCAN_PORT2_HIGH_FIRST (1U)
191 #define ICSS_EMAC_NUMQUEUES ((uint32_t)17U)
200 #define ICSS_EMAC_SWITCH_ERROR_BASE ((uint32_t)0x21Fu)
202 #define ICSS_EMAC_SWITCH_ERROR_CODE (ICSS_EMAC_SWITCH_ERROR_BASE)
204 #define ICSS_EMAC_SWITCH_ERROR_INFO (ICSS_EMAC_SWITCH_ERROR_CODE)
206 #define ICSS_EMAC_SWITCH_ERROR_WARNING (ICSS_EMAC_SWITCH_ERROR_CODE | 0x1000u)
208 #define ICSS_EMAC_SWITCH_ERROR_MINOR (ICSS_EMAC_SWITCH_ERROR_CODE | 0x2000u)
210 #define ICSS_EMAC_SWITCH_ERROR_MAJOR (ICSS_EMAC_SWITCH_ERROR_CODE | 0x3000u)
212 #define ICSS_EMAC_SWITCH_ERROR_CRITICAL (ICSS_EMAC_SWITCH_ERROR_CODE | 0x4000u)
215 #define ICSS_EMAC_SWITCH_SUCCESS (0u)
217 #define ICSS_EMAC_PORT1_TX_ERROR_MASK (0xFFFFu)
219 #define ICSS_EMAC_PORT2_TX_ERROR_MASK (0xFFFF0000u)
223 #define ICSS_EMAC_ERR_DEV_NOT_INSTANTIATED (ICSS_EMAC_SWITCH_ERROR_MAJOR + 1u)
225 #define ICSS_EMAC_ERR_SWITCH_INVALID_PARAM (ICSS_EMAC_SWITCH_ERROR_MAJOR + 2u)
227 #define ICSS_EMAC_ERR_CH_INVALID (ICSS_EMAC_SWITCH_ERROR_CRITICAL + 3u)
229 #define ICSS_EMAC_ERR_CH_ALREADY_INIT (ICSS_EMAC_SWITCH_ERROR_MAJOR + 4u)
231 #define ICSS_EMAC_ERR_TX_CH_ALREADY_CLOSED (ICSS_EMAC_SWITCH_ERROR_MAJOR + 5u)
233 #define ICSS_EMAC_ERR_TX_CH_NOT_OPEN (ICSS_EMAC_SWITCH_ERROR_MAJOR + 6u)
235 #define ICSS_EMAC_ERR_TX_NO_LINK (ICSS_EMAC_SWITCH_ERROR_MAJOR + 7u)
237 #define ICSS_EMAC_ERR_TX_OUT_OF_BD (ICSS_EMAC_SWITCH_ERROR_MAJOR + 8u)
239 #define ICSS_EMAC_ERR_RX_CH_INVALID (ICSS_EMAC_SWITCH_ERROR_CRITICAL + 9u)
241 #define ICSS_EMAC_ERR_RX_CH_ALREADY_INIT (ICSS_EMAC_SWITCH_ERROR_MAJOR + 10u)
243 #define ICSS_EMAC_ERR_RX_CH_ALREADY_CLOSED (ICSS_EMAC_SWITCH_ERROR_MAJOR + 11u)
245 #define ICSS_EMAC_ERR_RX_CH_NOT_OPEN (ICSS_EMAC_SWITCH_ERROR_MAJOR + 12u)
247 #define ICSS_EMAC_ERR_DEV_ALREADY_CREATED (ICSS_EMAC_SWITCH_ERROR_MAJOR + 13u)
249 #define ICSS_EMAC_ERR_DEV_NOT_OPEN (ICSS_EMAC_SWITCH_ERROR_MAJOR + 14u)
251 #define ICSS_EMAC_ERR_DEV_ALREADY_CLOSED (ICSS_EMAC_SWITCH_ERROR_MAJOR + 15u)
253 #define ICSS_EMAC_ERR_DEV_ALREADY_OPEN (ICSS_EMAC_SWITCH_ERROR_MAJOR + 16u)
255 #define ICSS_EMAC_ERR_RX_BUFFER_ALLOC_FAIL (ICSS_EMAC_SWITCH_ERROR_CRITICAL + 17u)
257 #define ICSS_EMAC_SWITCH_INTERNAL_FAILURE (ICSS_EMAC_SWITCH_ERROR_MAJOR + 18u)
259 #define ICSS_EMAC_SWITCH_VLAN_UNAWARE_MODE (ICSS_EMAC_SWITCH_ERROR_MAJOR + 19u)
261 #define ICSS_EMAC_SWITCH_ALE_TABLE_FULL (ICSS_EMAC_SWITCH_ERROR_MAJOR + 20u)
263 #define ICSS_EMAC_SWITCH_ADDR_NOTFOUND (ICSS_EMAC_SWITCH_ERROR_MAJOR + 21u)
265 #define ICSS_EMAC_SWITCH_INVALID_VLANID (ICSS_EMAC_SWITCH_ERROR_MAJOR + 22u)
267 #define ICSS_EMAC_SWITCH_INVALID_PORT (ICSS_EMAC_SWITCH_ERROR_MAJOR + 23u)
269 #define ICSS_EMAC_SWITCH_BD_ALLOC_FAIL (ICSS_EMAC_SWITCH_ERROR_MAJOR + 24u)
271 #define ICSS_EMAC_ERR_BADPACKET (ICSS_EMAC_SWITCH_ERROR_MAJOR + 25u)
273 #define ICSS_EMAC_ERR_COLLISION_FAIL (ICSS_EMAC_SWITCH_ERROR_MAJOR + 26u)
275 #define ICSS_EMAC_ERR_MACFATAL (ICSS_EMAC_SWITCH_ERROR_CRITICAL + 26u)
279 #define ICSS_EMAC_MAXMTU (1518U)
281 #define ICSS_EMAC_MINMTU (14U)
286 #define ICSS_EMAC_PORT_0 (0)
291 #define ICSS_EMAC_PORT_1 (1U)
296 #define ICSS_EMAC_PORT_2 (2U)
301 #define ICSS_EMAC_IOCTL_PORT_CTRL_DISABLE (0u)
304 #define ICSS_EMAC_IOCTL_PORT_CTRL_ENABLE (1u)
313 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE (0u)
315 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE (1u)
317 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS (2u)
319 #define ICSS_EMAC_STORM_PREV_CTRL_INIT (3u)
321 #define ICSS_EMAC_STORM_PREV_CTRL_RESET (4u)
323 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE_BC (5u)
325 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE_BC (6u)
327 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS_BC (7u)
329 #define ICSS_EMAC_STORM_PREV_CTRL_INIT_BC (8u)
331 #define ICSS_EMAC_STORM_PREV_CTRL_RESET_BC (9u)
333 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE_MC (10u)
335 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE_MC (11u)
337 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS_MC (12u)
339 #define ICSS_EMAC_STORM_PREV_CTRL_INIT_MC (13u)
341 #define ICSS_EMAC_STORM_PREV_CTRL_RESET_MC (14u)
343 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE_UC (15u)
345 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE_UC (16u)
347 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS_UC (17u)
349 #define ICSS_EMAC_STORM_PREV_CTRL_INIT_UC (18u)
351 #define ICSS_EMAC_STORM_PREV_CTRL_RESET_UC (19u)
361 #define ICSS_EMAC_LEARN_CTRL_UPDATE_TABLE (0u)
363 #define ICSS_EMAC_LEARN_CTRL_CLR_TABLE (1u)
365 #define ICSS_EMAC_LEARN_CTRL_AGEING (2u)
367 #define ICSS_EMAC_LEARN_CTRL_FIND_MAC (3u)
369 #define ICSS_EMAC_LEARN_CTRL_REMOVE_MAC (4u)
371 #define ICSS_EMAC_LEARN_CTRL_INC_COUNTER (5u)
373 #define ICSS_EMAC_LEARN_CTRL_INIT_TABLE (6u)
375 #define ICSS_EMAC_LEARN_CTRL_SET_PORTSTATE (7u)
385 #define ICSS_EMAC_IOCTL_STAT_CTRL_GET (0u)
387 #define ICSS_EMAC_IOCTL_STAT_CTRL_CLEAR (1u)
397 #define ICSS_EMAC_IOCTL_PORT_CTRL (0u)
399 #define ICSS_EMAC_IOCTL_LEARNING_CTRL (1u)
401 #define ICSS_EMAC_IOCTL_STORM_PREV_CTRL (2u)
403 #define ICSS_EMAC_IOCTL_STATS_CTRL (3u)
405 #define ICSS_EMAC_IOCTL_PROMISCUOUS_CTRL (4u)
407 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL (5u)
409 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL (6u)
411 #define ICSS_EMAC_IOCTL_PORT_FLUSH_CTRL (7u)
413 #define ICSS_EMAC_IOCTL_SPECIAL_UNICAST_MAC_CTRL (8u)
423 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_ENABLE (0u)
425 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_DISABLE (1u)
427 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_OVERRIDE_HASHMASK (2u)
429 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_ADD_MACID (3u)
431 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_REMOVE_MACID (4u)
433 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_GET_DROPPED (5u)
443 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_ENABLE_CMD (0u)
445 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_DISABLE_CMD (1u)
447 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_UNTAG_HOST_RCV_ALL_CMD (2u)
449 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_UNTAG_HOST_RCV_NAL_CMD (3u)
451 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_PRIOTAG_HOST_RCV_ALL_CMD (4u)
453 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_PRIOTAG_HOST_RCV_NAL_CMD (5u)
455 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_ADD_VID_CMD (6u)
457 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_REMOVE_VID_CMD (7u)
467 #define ICSS_EMAC_IOCTL_SPECIAL_UNICAST_MAC_CTRL_DISABLE_CMD (0u)
469 #define ICSS_EMAC_IOCTL_SPECIAL_UNICAST_MAC_CTRL_ENABLE_CMD (1u)
476 #define ICSS_EMAC_LEARNING_PORT_STATE_LEARNING (0U)
477 #define ICSS_EMAC_LEARNING_PORT_STATE_NOT_LEARNING (1U)
478 #define ICSS_EMAC_LEARNING_PORT_STATE_LOCKED (2U)
480 #define ICSS_EMAC_OBJECT_SIZE_IN_BYTES (42000)
482 #ifdef BUILD_HSR_PRP_MII
484 #define ICSS_EMAC_BD_FDB_LOOKUP_SUCCESS_MASK ((uint32_t)0x00000040U)
487 #define ICSS_EMAC_BD_FDB_LOOKUP_SUCCESS_SHIFT ((uint32_t)6U)
490 #define ICSS_EMAC_BD_FW_FLOOD_MASK ((uint32_t)0x00000080U)
493 #define ICSS_EMAC_BD_FW_FLOOD_SHIFT ((uint32_t)7U)
516 typedef struct ICSS_EMAC_FwStaticMmap_s
545 typedef struct ICSS_EMAC_FwDynamicMmap_s
568 typedef struct ICSS_EMAC_FwVlanFilterParams_s
581 typedef struct ICSS_EMAC_FwMulticastFilterParams_s
600 typedef struct ICSS_EMAC_Attrs_s
672 #ifdef BUILD_HSR_PRP_MII
685 typedef struct ICSS_EMAC_InternalObject_t
695 typedef struct ICSS_EMAC_Config_s
710 typedef struct ICSS_EMAC_CallBackConfig_s
725 typedef struct ICSS_EMAC_CallBackObject_s
763 typedef struct ICSS_EMAC_Params_s
794 typedef struct ICSS_EMAC_RxArgument_s
806 #ifdef BUILD_HSR_PRP_MII
807 uint32_t host_recv_flag;
816 typedef struct ICSS_EMAC_TxArgument_s
833 typedef struct ICSS_EMAC_IoctlCmd_s
843 typedef struct ICSS_EMAC_PruStatistics_s
968 uint32_t ioctlCommand,
1000 int32_t *portNumber,
1001 int32_t *queueNumber);
volatile uint32_t tx128_255byte
Definition: icss_emac.h:862
uint8_t portMask
Definition: icss_emac.h:637
uint8_t hostQueueIsolationMode
Definition: icss_emac.h:668
uint32_t p0ColBufferOffset
Definition: icss_emac.h:557
uint8_t intrPacingMode
Definition: icss_emac.h:622
uint32_t p0ColQueueDescOffset
Definition: icss_emac.h:533
uint32_t rxTaskPriority
Definition: icss_emac.h:662
Tx packet processing information block that needs to passed into call to ICSS_EMAC_txPacket.
Definition: icss_emac.h:817
ICSS_EMAC_CallBackConfig rxNRTCallBack
Definition: icss_emac.h:731
struct ICSS_EMAC_Config_s * ICSS_EMAC_Handle
Alias for ICSS EMAC Handle containing base addresses and modules.
Definition: icss_emac.h:498
uint32_t portMacAddr
Definition: icss_emac.h:528
volatile uint32_t rxBcast
Definition: icss_emac.h:855
volatile uint32_t defTx
Definition: icss_emac.h:886
uint8_t learningEnable
Definition: icss_emac.h:633
Rx packet processing information block that needs to passed into call to ICSS_EMAC_RxPktGet.
Definition: icss_emac.h:795
volatile uint32_t rxUcast
Definition: icss_emac.h:857
volatile uint32_t TXqueueLevel
Definition: icss_emac.h:898
uint32_t portStatusOffset
Definition: icss_emac.h:526
volatile uint32_t droppedPackets
Definition: icss_emac.h:892
uint32_t p1Q1SwitchTxContextOffset
Definition: icss_emac.h:559
uint8_t queueNumber
Definition: icss_emac.h:800
uint32_t p0QueueDescOffset
Definition: icss_emac.h:532
int32_t ICSS_EMAC_txPacket(const ICSS_EMAC_TxArgument *txArg, void *userArg)
API to queue a frame which has to be transmitted on the specified port queue.
uint8_t port
Definition: icss_emac.h:802
uint32_t l3OcmcBaseAddr
Definition: icss_emac.h:656
uint32_t p0ColBufferDescOffset
Definition: icss_emac.h:554
void ICSS_EMAC_Params_init(ICSS_EMAC_Params *params)
Initialize the parmeters data structure with defaults.
uint32_t ctrlUntagHostRcvAllowBit
Definition: icss_emac.h:572
#define ICSS_EMAC_NUMQUEUES
Total Queues available.
Definition: icss_emac.h:191
uint32_t overrideStatusOffset
Definition: icss_emac.h:587
uint32_t stormPreventionOffsetBC
Definition: icss_emac.h:524
volatile uint32_t rxUnderSizedFrames
Definition: icss_emac.h:889
int32_t ICSS_EMAC_ioctl(ICSS_EMAC_Handle icssEmacHandle, uint32_t ioctlCommand, uint8_t portNo, void *ioctlParams)
IOCTL Function for ICSS EMAC.
volatile uint32_t tx64byte
Definition: icss_emac.h:860
uint32_t l3OcmcSize
Definition: icss_emac.h:658
uint32_t collisionQueueSize
Definition: icss_emac.h:552
uint32_t hostQ1RxContextOffset
Definition: icss_emac.h:558
uint8_t txInterruptEnable
Definition: icss_emac.h:642
uint32_t more
Definition: icss_emac.h:804
uint32_t txIntNum
Definition: icss_emac.h:653
#define ICSS_EMAC_OBJECT_SIZE_IN_BYTES
Definition: icss_emac.h:480
ICSS_EMAC_CallBackConfig learningExCallBack
Definition: icss_emac.h:741
uint32_t transmitQueuesBufferOffset
Definition: icss_emac.h:556
uint16_t pacingThreshold
Definition: icss_emac.h:626
volatile uint32_t rxOctets
Definition: icss_emac.h:858
uint16_t lengthOfPacket
Definition: icss_emac.h:826
uint8_t portNumber
Definition: icss_emac.h:822
uint32_t maskInitVal
Definition: icss_emac.h:585
volatile uint32_t rx512_1023byte
Definition: icss_emac.h:871
uint32_t emacTtsConfigBaseOffset
Definition: icss_emac.h:534
volatile uint32_t sqeTestError
Definition: icss_emac.h:897
volatile uint32_t singleColl
Definition: icss_emac.h:875
volatile uint32_t macRxError
Definition: icss_emac.h:883
uint32_t p0Q1BufferDescOffset
Definition: icss_emac.h:553
void ICSS_EMAC_init(void)
This function initializes the ICSS_EMAC module.
uint32_t ctrlOffset
Definition: icss_emac.h:583
ICSS EMAC Dynamic Firmware Memory Map offsets.
Definition: icss_emac.h:546
uint8_t command
Definition: icss_emac.h:835
ICSS_EMAC_CallBackConfig port0LinkCallBack
Definition: icss_emac.h:727
void * object
Definition: icss_emac.h:697
int32_t(* ICSS_EMAC_CallBack)(void *arg0, void *arg1, void *arg2)
Definition for a generic callback function used in ICSS-EMAC. While calling this,...
Definition: icss_emac.h:506
volatile uint32_t tx65_127byte
Definition: icss_emac.h:861
volatile uint32_t CSError
Definition: icss_emac.h:899
uint32_t specialUnicastMACAddressFeatureEnableOffset
Definition: icss_emac.h:539
uint32_t ctrlEnableBit
Definition: icss_emac.h:571
uint32_t statisticsOffset
Definition: icss_emac.h:522
uint32_t filterTableBaseAddress
Definition: icss_emac.h:574
const PRUICSS_IntcInitData * pruicssIntcInitData
Definition: icss_emac.h:767
uint32_t phySpeedOffset
Definition: icss_emac.h:525
void * ioctlVal
Definition: icss_emac.h:836
uint32_t hostRcvAllowedValue
Definition: icss_emac.h:593
uint32_t p0Q1BufferOffset
Definition: icss_emac.h:555
volatile uint32_t lateColl
Definition: icss_emac.h:874
void * userArg
Definition: icss_emac.h:714
uint32_t colStatusAddr
Definition: icss_emac.h:536
uint32_t maskOverrideSetValue
Definition: icss_emac.h:591
uint32_t portControlAddr
Definition: icss_emac.h:527
uint32_t rxInterruptStatusOffset
Definition: icss_emac.h:529
volatile uint32_t rx65_127byte
Definition: icss_emac.h:868
uint32_t stormPreventionOffsetUC
Definition: icss_emac.h:531
int32_t ICSS_EMAC_rxPktGet(ICSS_EMAC_RxArgument *rxArg, void *userArg)
Retrieves a frame from a host queue and copies it in the allocated stack buffer.
volatile uint32_t rx64byte
Definition: icss_emac.h:867
uint32_t maskOffset
Definition: icss_emac.h:586
uint8_t emacMode
Definition: icss_emac.h:602
uint32_t futureFeatureOffset
Definition: icss_emac.h:521
uint8_t portPrioritySelection
Definition: icss_emac.h:670
uint32_t versionOffset
Definition: icss_emac.h:518
ICSS_EMAC_FwDynamicMmap * fwDynamicMMap
Definition: icss_emac.h:771
volatile uint32_t rxOverSizedFrames
Definition: icss_emac.h:888
volatile uint32_t multiColl
Definition: icss_emac.h:876
uint32_t ctrlBitmapOffset
Definition: icss_emac.h:570
ICSS_EMAC_FwMulticastFilterParams * fwMulticastFilterParams
Definition: icss_emac.h:775
ICSS EMAC VLAN Filtering Parameters.
Definition: icss_emac.h:569
volatile uint32_t txOverFlow
Definition: icss_emac.h:895
uint32_t q1EmacTxContextOffset
Definition: icss_emac.h:561
ICSS_EMAC_Handle ICSS_EMAC_open(uint32_t idx, const ICSS_EMAC_Params *params)
API to initialize and configure ICSS in MAC/Switch Mode.
uint32_t txTaskPriority
Definition: icss_emac.h:664
volatile uint32_t txUcast
Definition: icss_emac.h:852
Statistics structure for capturing statistics on PRU.
Definition: icss_emac.h:844
volatile uint32_t txUnderFlow
Definition: icss_emac.h:896
uint8_t ethPrioQueue
Definition: icss_emac.h:628
volatile uint32_t rx1024byte
Definition: icss_emac.h:872
volatile uint32_t excessColl
Definition: icss_emac.h:877
uint32_t numQueues
Definition: icss_emac.h:562
uint32_t interfaceMacAddrOffset
Definition: icss_emac.h:535
ICSS_EMAC_CallBackConfig rxRTCallBack
Definition: icss_emac.h:735
ICSS_EMAC_CallBackConfig customRxCallBack
Definition: icss_emac.h:747
uint32_t tableOffset
Definition: icss_emac.h:588
volatile uint32_t rxCRCFrames
Definition: icss_emac.h:890
const uint8_t * srcAddress
Definition: icss_emac.h:820
uint32_t maskOverrideNotSetValue
Definition: icss_emac.h:592
volatile uint32_t stormPrevCounter
Definition: icss_emac.h:880
void ICSS_EMAC_close(ICSS_EMAC_Handle icssEmacHandle)
API to stop MAC/Switch Mode.
uint32_t ctrlEnabledValue
Definition: icss_emac.h:589
ICSS_EMAC_CallBackConfig customTxCallBack
Definition: icss_emac.h:743
const ICSS_EMAC_Attrs * attrs
Definition: icss_emac.h:699
PRUICSS Interrupt controller initialisation data structure.
Definition: pruicss/m_v0/pruicss.h:265
uint32_t linkIntNum
Definition: icss_emac.h:649
int32_t ICSS_EMAC_rxPktInfo(ICSS_EMAC_Handle icssEmacHandle, int32_t *portNumber, int32_t *queueNumber)
API to retrieve the information about the received frame which is then used to dequeue the frame from...
volatile uint32_t txOctets
Definition: icss_emac.h:853
void ICSS_EMAC_deinit(void)
This function de-initializes the ICSS_EMAC module.
uint8_t phyToMacInterfaceMode
Definition: icss_emac.h:609
uint32_t destAddress
Definition: icss_emac.h:798
uint32_t maskSizeBytes
Definition: icss_emac.h:584
volatile uint32_t rx256_511byte
Definition: icss_emac.h:870
volatile uint32_t macTxError
Definition: icss_emac.h:887
uint8_t halfDuplexEnable
Definition: icss_emac.h:613
volatile uint32_t SFDError
Definition: icss_emac.h:885
uint32_t featureOffset
Definition: icss_emac.h:520
uint32_t vidMaxValue
Definition: icss_emac.h:575
uint32_t splitQueue
Definition: icss_emac.h:666
volatile uint32_t stormPrevCounterMC
Definition: icss_emac.h:881
uint32_t linkTaskPriority
Definition: icss_emac.h:660
Different callbacks which can be registered. While calling the function set in ICSS_EMAC_CallBack,...
Definition: icss_emac.h:726
uint32_t hostRcvNotAllowedValue
Definition: icss_emac.h:594
uint32_t queueSizeOffset
Definition: icss_emac.h:547
volatile uint32_t rxMisAlignmentFrames
Definition: icss_emac.h:879
uint32_t ctrlPriotagHostRcvAllowBit
Definition: icss_emac.h:573
volatile uint32_t txBcast
Definition: icss_emac.h:850
volatile uint32_t txMcast
Definition: icss_emac.h:851
uint8_t enableIntrPacing
Definition: icss_emac.h:618
ICSS EMAC Static Firmware Memory Map offsets. These are offsets for PRU0 and PRU1 DRAM memory.
Definition: icss_emac.h:517
Opaque ICSS EMAC driver object.
Definition: icss_emac.h:686
ICSS_EMAC_CallBackConfig txCallBack
Definition: icss_emac.h:739
uint32_t ctrlDisabledValue
Definition: icss_emac.h:590
ICSS_EMAC_CallBack callBack
Definition: icss_emac.h:712
Definition: icss_emac.h:601
volatile uint32_t stormPrevCounterUC
Definition: icss_emac.h:882
ICSS EMAC Multicast Filtering Parameters.
Definition: icss_emac.h:582
volatile uint32_t tx256_511byte
Definition: icss_emac.h:863
ICSS_EMAC Parameters.
Definition: icss_emac.h:764
volatile uint32_t rx128_255byte
Definition: icss_emac.h:869
uint32_t rxIntNum
Definition: icss_emac.h:651
Generic callback configuration for protocol specific callbacks. ICSS_EMAC_CallBack is the function ...
Definition: icss_emac.h:711
uint32_t version2Offset
Definition: icss_emac.h:519
void * ETHPHY_Handle
Handle to the ETHPHY driver returned by ETHPHY_open()
Definition: ethphy.h:173
IOCTL command members for configuring switch/EMAC.
Definition: icss_emac.h:834
uint8_t enableHostQueueIsolation
Definition: icss_emac.h:786
ICSS_EMAC_CallBackObject callBackObject
Definition: icss_emac.h:777
uint32_t specialUnicastMACAddrOffset
Definition: icss_emac.h:538
volatile uint32_t tx512_1023byte
Definition: icss_emac.h:864
uint32_t queueOffset
Definition: icss_emac.h:548
PRUICSS_Handle pruicssHandle
Definition: icss_emac.h:765
uint32_t stormPreventionOffsetMC
Definition: icss_emac.h:530
struct PRUICSS_Config_s * PRUICSS_Handle
A handle that is returned from a PRUICSS_open() call. This handle is required for calling other APIs.
Definition: pruicss/m_v0/pruicss.h:226
ICSS_EMAC_CallBackConfig port1LinkCallBack
Definition: icss_emac.h:729
uint32_t promiscuousModeOffset
Definition: icss_emac.h:537
ICSS_EMAC_Handle icssEmacHandle
Definition: icss_emac.h:818
uint32_t statisticsSize
Definition: icss_emac.h:523
uint8_t queuePriority
Definition: icss_emac.h:824
volatile uint32_t rxMcast
Definition: icss_emac.h:856
uint32_t portQueueDescOffset
Definition: icss_emac.h:560
volatile uint32_t tx1024byte
Definition: icss_emac.h:865
ICSS_EMAC_FwStaticMmap * fwStaticMMap
Definition: icss_emac.h:769
#define ICSS_EMAC_MAX_PORTS_PER_INSTANCE
Maximum number of Ports in a single ICSS
Definition: icss_emac.h:66
ICSS_EMAC_FwVlanFilterParams * fwVlanFilterParams
Definition: icss_emac.h:773
uint32_t queueDescriptorOffset
Definition: icss_emac.h:549
Base EMAC handle containing pointers to all modules required for driver to work.
Definition: icss_emac.h:696
ICSS_EMAC_Handle icssEmacHandle
Definition: icss_emac.h:796