AM243x MCU+ SDK  08.00.00
icss_emac.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2021 Texas Instruments Incorporated
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  *
11  * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in the
13  * documentation and/or other materials provided with the
14  * distribution.
15  *
16  * Neither the name of Texas Instruments Incorporated nor the names of
17  * its contributors may be used to endorse or promote products derived
18  * from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 #ifndef ICSS_EMAC_H_
34 #define ICSS_EMAC_H_
35 
47 /* ========================================================================== */
48 /* Include Files */
49 /* ========================================================================== */
50 
51 #include <stdint.h>
52 #include <kernel/dpl/SystemP.h>
53 #include <drivers/pruicss.h>
54 #include <board/ethphy.h>
55 #include <drivers/hw_include/csl_types.h>
56 
57 #ifdef __cplusplus
58 extern "C" {
59 #endif
60 
61 /* ========================================================================== */
62 /* Macros & Typedefs */
63 /* ========================================================================== */
64 
66 #define ICSS_EMAC_MAX_PORTS_PER_INSTANCE (2)
67 
75 #define ICSS_EMAC_MODE_MAC1 (1U)
76 
77 #define ICSS_EMAC_MODE_MAC2 (2U)
78 
79 #define ICSS_EMAC_MODE_SWITCH (3U)
80 
81 #define ICSS_EMAC_MODE_DUALMAC (4U)
82 
91 #define ICSS_EMAC_MII_MODE (0U)
92 
93 #define ICSS_EMAC_RGMII_MODE (1U)
94 
103 #define ICSS_EMAC_LEARNING_DISABLE (0U)
104 
105 #define ICSS_EMAC_LEARNING_ENABLE (1U)
106 
115 #define ICSS_EMAC_ENABLE_PACING (0)
116 
117 #define ICSS_EMAC_DISABLE_PACING (1)
118 
127 #define ICSS_EMAC_INTR_PACING_MODE1 (0)
128 
137 #define ICSS_EMAC_QUEUE1 ((uint32_t)0U)
138 
139 #define ICSS_EMAC_QUEUE2 ((uint32_t)1U)
140 
141 #define ICSS_EMAC_QUEUE3 ((uint32_t)2U)
142 
143 #define ICSS_EMAC_QUEUE4 ((uint32_t)3U)
144 
145 #define ICSS_EMAC_QUEUE5 ((uint32_t)4U)
146 
147 #define ICSS_EMAC_QUEUE6 ((uint32_t)5U)
148 
149 #define ICSS_EMAC_QUEUE7 ((uint32_t)6U)
150 
151 #define ICSS_EMAC_QUEUE8 ((uint32_t)7U)
152 
153 #define ICSS_EMAC_QUEUE9 ((uint32_t)8U)
154 
155 #define ICSS_EMAC_QUEUE10 ((uint32_t)9U)
156 
157 #define ICSS_EMAC_QUEUE11 ((uint32_t)10U)
158 
159 #define ICSS_EMAC_QUEUE12 ((uint32_t)11U)
160 
161 #define ICSS_EMAC_QUEUE13 ((uint32_t)12U)
162 
163 #define ICSS_EMAC_QUEUE14 ((uint32_t)13U)
164 
165 #define ICSS_EMAC_QUEUE15 ((uint32_t)14U)
166 
167 #define ICSS_EMAC_QUEUE16 ((uint32_t)15U)
168 
169 #define ICSS_EMAC_COLQUEUE ((uint32_t)16U)
170 
173 #define ICSS_EMAC_NUMQUEUES ((uint32_t)17U)
174 
176 #define ICSS_EMAC_MAXMTU (1518U)
177 
178 #define ICSS_EMAC_MINMTU (14U)
179 
183 #define ICSS_EMAC_PORT_0 (0)
184 
188 #define ICSS_EMAC_PORT_1 (1U)
189 
193 #define ICSS_EMAC_PORT_2 (2U)
194 
198 #define ICSS_EMAC_IOCTL_PORT_CTRL_DISABLE (0u)
199 
201 #define ICSS_EMAC_IOCTL_PORT_CTRL_ENABLE (1u)
202 
210 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE (0u)
211 
212 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE (1u)
213 
214 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS (2u)
215 
216 #define ICSS_EMAC_STORM_PREV_CTRL_INIT (3u)
217 
218 #define ICSS_EMAC_STORM_PREV_CTRL_RESET (4u)
219 
220 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE_BC (5u)
221 
222 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE_BC (6u)
223 
224 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS_BC (7u)
225 
226 #define ICSS_EMAC_STORM_PREV_CTRL_INIT_BC (8u)
227 
228 #define ICSS_EMAC_STORM_PREV_CTRL_RESET_BC (9u)
229 
230 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE_MC (10u)
231 
232 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE_MC (11u)
233 
234 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS_MC (12u)
235 
236 #define ICSS_EMAC_STORM_PREV_CTRL_INIT_MC (13u)
237 
238 #define ICSS_EMAC_STORM_PREV_CTRL_RESET_MC (14u)
239 
240 #define ICSS_EMAC_STORM_PREV_CTRL_ENABLE_UC (15u)
241 
242 #define ICSS_EMAC_STORM_PREV_CTRL_DISABLE_UC (16u)
243 
244 #define ICSS_EMAC_STORM_PREV_CTRL_SET_CREDITS_UC (17u)
245 
246 #define ICSS_EMAC_STORM_PREV_CTRL_INIT_UC (18u)
247 
248 #define ICSS_EMAC_STORM_PREV_CTRL_RESET_UC (19u)
249 
258 #define ICSS_EMAC_LEARN_CTRL_UPDATE_TABLE (0u)
259 
260 #define ICSS_EMAC_LEARN_CTRL_CLR_TABLE (1u)
261 
262 #define ICSS_EMAC_LEARN_CTRL_AGEING (2u)
263 
264 #define ICSS_EMAC_LEARN_CTRL_FIND_MAC (3u)
265 
266 #define ICSS_EMAC_LEARN_CTRL_REMOVE_MAC (4u)
267 
268 #define ICSS_EMAC_LEARN_CTRL_INC_COUNTER (5u)
269 
270 #define ICSS_EMAC_LEARN_CTRL_INIT_TABLE (6u)
271 
272 #define ICSS_EMAC_LEARN_CTRL_SET_PORTSTATE (7u)
273 
282 #define ICSS_EMAC_IOCTL_STAT_CTRL_GET (0u)
283 
284 #define ICSS_EMAC_IOCTL_STAT_CTRL_CLEAR (1u)
285 
294 #define ICSS_EMAC_IOCTL_PORT_CTRL (0u)
295 
296 #define ICSS_EMAC_IOCTL_LEARNING_CTRL (1u)
297 
298 #define ICSS_EMAC_IOCTL_STORM_PREV_CTRL (2u)
299 
300 #define ICSS_EMAC_IOCTL_STATS_CTRL (3u)
301 
302 #define ICSS_EMAC_IOCTL_PROMISCUOUS_CTRL (4u)
303 
304 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL (5u)
305 
306 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL (6u)
307 
316 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_ENABLE (0u)
317 
318 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_DISABLE (1u)
319 
320 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_OVERRIDE_HASHMASK (2u)
321 
322 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_ADD_MACID (3u)
323 
324 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_REMOVE_MACID (4u)
325 
326 #define ICSS_EMAC_IOCTL_MULTICAST_FILTER_CTRL_GET_DROPPED (5u)
327 
336 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_ENABLE_CMD (0u)
337 
338 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_DISABLE_CMD (1u)
339 
340 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_UNTAG_HOST_RCV_ALL_CMD (2u)
341 
342 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_UNTAG_HOST_RCV_NAL_CMD (3u)
343 
344 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_PRIOTAG_HOST_RCV_ALL_CMD (4u)
345 
346 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_PRIOTAG_HOST_RCV_NAL_CMD (5u)
347 
348 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_ADD_VID_CMD (6u)
349 
350 #define ICSS_EMAC_IOCTL_VLAN_FILTER_CTRL_REMOVE_VID_CMD (7u)
351 
357 #define ICSS_EMAC_LEARNING_PORT_STATE_LEARNING (0U)
358 #define ICSS_EMAC_LEARNING_PORT_STATE_NOT_LEARNING (1U)
359 #define ICSS_EMAC_LEARNING_PORT_STATE_LOCKED (2U)
360 
361 #define ICSS_EMAC_OBJECT_SIZE_IN_BYTES (42000)
362 
366 typedef struct ICSS_EMAC_Config_s *ICSS_EMAC_Handle;
367 
374 typedef int32_t (*ICSS_EMAC_CallBack)(void *arg0, void *arg1, void *arg2);
375 
376 /* ========================================================================== */
377 /* Structure Declarations */
378 /* ========================================================================== */
379 
384 typedef struct ICSS_EMAC_FwStaticMmap_s
385 {
386  uint32_t versionOffset;
387  uint32_t version2Offset;
388  uint32_t featureOffset;
390  uint32_t statisticsOffset;
391  uint32_t statisticsSize;
393  uint32_t phySpeedOffset;
394  uint32_t portStatusOffset;
395  uint32_t portControlAddr;
396  uint32_t portMacAddr;
400  uint32_t p0QueueDescOffset;
404  uint32_t colStatusAddr;
407 
411 typedef struct ICSS_EMAC_FwDynamicMmap_s
412 {
413  uint32_t queueSizeOffset;
414  uint32_t queueOffset;
416  uint32_t txQueueSize[ICSS_EMAC_NUMQUEUES-1U];
417  uint32_t rxHostQueueSize[ICSS_EMAC_NUMQUEUES - 1U];
421  uint32_t p0Q1BufferOffset;
423  uint32_t p0ColBufferOffset;
428  uint32_t numQueues;
430 
434 typedef struct ICSS_EMAC_FwVlanFilterParams_s
435 {
437  uint32_t ctrlEnableBit;
441  uint32_t vidMaxValue;
443 
447 typedef struct ICSS_EMAC_FwMulticastFilterParams_s
448 {
449  uint32_t ctrlOffset;
450  uint32_t maskSizeBytes;
451  uint32_t maskInitVal;
452  uint32_t maskOffset;
454  uint32_t tableOffset;
462 
463 /*
464 * \brief ICSS EMAC Init Configuration Structure
465 */
466 typedef struct ICSS_EMAC_Attrs_s
467 {
468  uint8_t emacMode;
488  uint8_t intrPacingMode;
492  uint16_t pacingThreshold;
494  uint8_t ethPrioQueue;
499  uint8_t learningEnable;
503  uint8_t portMask;
515  uint32_t linkIntNum;
516  /* Link interrupt number on R5F*/
517  uint32_t rxIntNum;
518  /* Receive Packet interrupt number on R5F*/
519  uint32_t txIntNum;
520  /* Transmit completion interrupt number on R5F.
521  Valid only if txInterruptEnable is set to 1 */
522  uint32_t l3OcmcBaseAddr;
524  uint32_t l3OcmcSize;
528  uint32_t rxTaskPriority;
530  uint32_t txTaskPriority;
533 
537 typedef struct ICSS_EMAC_InternalObject_t
538 {
539  uint32_t reserved[ICSS_EMAC_OBJECT_SIZE_IN_BYTES/sizeof(uint32_t)];
542 
547 typedef struct ICSS_EMAC_Config_s
548 {
549  void *object;
554 
562 typedef struct ICSS_EMAC_CallBackConfig_s
563 {
566  void *userArg;
569 
577 typedef struct ICSS_EMAC_CallBackObject_s
578 {
596 
607 typedef struct ICSS_EMAC_Params_s
608 {
628  uint8_t macId[6];
631 
636 typedef struct ICSS_EMAC_RxArgument_s
637 {
640  uint32_t destAddress;
642  uint8_t queueNumber;
644  uint8_t port;
646  uint32_t more;
649 
654 typedef struct ICSS_EMAC_TxArgument_s
655 {
658  const uint8_t *srcAddress;
660  uint8_t portNumber;
662  uint8_t queuePriority;
664  uint16_t lengthOfPacket;
667 
671 typedef struct ICSS_EMAC_IoctlCmd_s
672 {
673  uint8_t command;
674  void *ioctlVal;
676 
681 typedef struct ICSS_EMAC_PruStatistics_s
682 {
683 /* The fields here are aligned here so that it's consistent
684  with the memory layout in PRU DRAM, this is to facilitate easy
685  memcpy or DMA transfer. Don't change the order of fields without
686  modifying the order of fields in PRU DRAM. For details refer to guide
687 */
688  volatile uint32_t txBcast;
689  volatile uint32_t txMcast;
690  volatile uint32_t txUcast;
691  volatile uint32_t txOctets;
693  volatile uint32_t rxBcast;
694  volatile uint32_t rxMcast;
695  volatile uint32_t rxUcast;
696  volatile uint32_t rxOctets;
698  volatile uint32_t tx64byte;
699  volatile uint32_t tx65_127byte;
700  volatile uint32_t tx128_255byte;
701  volatile uint32_t tx256_511byte;
702  volatile uint32_t tx512_1023byte;
703  volatile uint32_t tx1024byte;
705  volatile uint32_t rx64byte;
706  volatile uint32_t rx65_127byte;
707  volatile uint32_t rx128_255byte;
708  volatile uint32_t rx256_511byte;
709  volatile uint32_t rx512_1023byte;
710  volatile uint32_t rx1024byte;
712  volatile uint32_t lateColl;
713  volatile uint32_t singleColl;
714  volatile uint32_t multiColl;
715  volatile uint32_t excessColl;
717  volatile uint32_t rxMisAlignmentFrames;
718  volatile uint32_t stormPrevCounter;
719  volatile uint32_t stormPrevCounterMC;
720  volatile uint32_t stormPrevCounterUC;
721  volatile uint32_t macRxError;
723  volatile uint32_t SFDError;
724  volatile uint32_t defTx;
725  volatile uint32_t macTxError;
726  volatile uint32_t rxOverSizedFrames;
727  volatile uint32_t rxUnderSizedFrames;
728  volatile uint32_t rxCRCFrames;
730  volatile uint32_t droppedPackets;
731 /* Debug variables, these are not part of standard MIB. Useful for debugging */
732 /* Reserved for future Use */
733  volatile uint32_t txOverFlow;
734  volatile uint32_t txUnderFlow;
735  volatile uint32_t sqeTestError;
736  volatile uint32_t TXqueueLevel;
737  volatile uint32_t CSError;
739 /* ========================================================================== */
740 /* Function Declarations */
741 /* ========================================================================== */
742 
746 void ICSS_EMAC_init(void);
747 
751 void ICSS_EMAC_deinit(void);
752 
759 
768 ICSS_EMAC_Handle ICSS_EMAC_open(uint32_t idx, const ICSS_EMAC_Params *params);
769 
776 void ICSS_EMAC_close(ICSS_EMAC_Handle icssEmacHandle);
777 
802 int32_t ICSS_EMAC_ioctl(ICSS_EMAC_Handle icssEmacHandle,
803  uint32_t ioctlCommand,
804  uint8_t portNo,
805  void *ioctlParams);
806 
820 int32_t ICSS_EMAC_rxPktGet(ICSS_EMAC_RxArgument *rxArg, void *userArg);
821 
834 int32_t ICSS_EMAC_rxPktInfo(ICSS_EMAC_Handle icssEmacHandle,
835  int32_t *portNumber,
836  int32_t *queueNumber);
837 
850 int32_t ICSS_EMAC_txPacket(const ICSS_EMAC_TxArgument *txArg, void *userArg);
851 
852 /* ========================================================================== */
853 /* Global Variables */
854 /* ========================================================================== */
855 
856 #ifdef __cplusplus
857 }
858 #endif
859 
862 #endif /* #ifndef ICSS_EMAC_H_ */
ICSS_EMAC_PruStatistics::tx128_255byte
volatile uint32_t tx128_255byte
Definition: icss_emac.h:700
ICSS_EMAC_Attrs::portMask
uint8_t portMask
Definition: icss_emac.h:503
ICSS_EMAC_FwDynamicMmap::p0ColBufferOffset
uint32_t p0ColBufferOffset
Definition: icss_emac.h:423
ICSS_EMAC_Attrs::intrPacingMode
uint8_t intrPacingMode
Definition: icss_emac.h:488
ICSS_EMAC_FwStaticMmap::p0ColQueueDescOffset
uint32_t p0ColQueueDescOffset
Definition: icss_emac.h:401
ICSS_EMAC_Attrs::rxTaskPriority
uint32_t rxTaskPriority
Definition: icss_emac.h:528
ICSS_EMAC_TxArgument
Tx packet processing information block that needs to passed into call to ICSS_EMAC_TxPacket.
Definition: icss_emac.h:655
ICSS_EMAC_CallBackObject::rxNRTCallBack
ICSS_EMAC_CallBackConfig rxNRTCallBack
Definition: icss_emac.h:583
ICSS_EMAC_Handle
struct ICSS_EMAC_Config_s * ICSS_EMAC_Handle
Alias for ICSS EMAC Handle containing base addresses and modules.
Definition: icss_emac.h:366
ICSS_EMAC_FwStaticMmap::portMacAddr
uint32_t portMacAddr
Definition: icss_emac.h:396
ICSS_EMAC_PruStatistics::rxBcast
volatile uint32_t rxBcast
Definition: icss_emac.h:693
ICSS_EMAC_PruStatistics::defTx
volatile uint32_t defTx
Definition: icss_emac.h:724
ICSS_EMAC_Attrs::learningEnable
uint8_t learningEnable
Definition: icss_emac.h:499
ICSS_EMAC_RxArgument
Rx packet processing information block that needs to passed into call to ICSS_EMAC_RxPktGet.
Definition: icss_emac.h:637
ICSS_EMAC_PruStatistics::rxUcast
volatile uint32_t rxUcast
Definition: icss_emac.h:695
ICSS_EMAC_PruStatistics::TXqueueLevel
volatile uint32_t TXqueueLevel
Definition: icss_emac.h:736
ICSS_EMAC_FwStaticMmap::portStatusOffset
uint32_t portStatusOffset
Definition: icss_emac.h:394
ICSS_EMAC_PruStatistics::droppedPackets
volatile uint32_t droppedPackets
Definition: icss_emac.h:730
ICSS_EMAC_FwDynamicMmap::p1Q1SwitchTxContextOffset
uint32_t p1Q1SwitchTxContextOffset
Definition: icss_emac.h:425
ICSS_EMAC_RxArgument::queueNumber
uint8_t queueNumber
Definition: icss_emac.h:642
ICSS_EMAC_FwStaticMmap::p0QueueDescOffset
uint32_t p0QueueDescOffset
Definition: icss_emac.h:400
ICSS_EMAC_txPacket
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.
ICSS_EMAC_RxArgument::port
uint8_t port
Definition: icss_emac.h:644
SystemP.h
ICSS_EMAC_Attrs::l3OcmcBaseAddr
uint32_t l3OcmcBaseAddr
Definition: icss_emac.h:522
ICSS_EMAC_FwDynamicMmap::p0ColBufferDescOffset
uint32_t p0ColBufferDescOffset
Definition: icss_emac.h:420
ICSS_EMAC_Params_init
void ICSS_EMAC_Params_init(ICSS_EMAC_Params *params)
Initialize the parmeters data structure with defaults.
ICSS_EMAC_FwVlanFilterParams::ctrlUntagHostRcvAllowBit
uint32_t ctrlUntagHostRcvAllowBit
Definition: icss_emac.h:438
ICSS_EMAC_NUMQUEUES
#define ICSS_EMAC_NUMQUEUES
Total Queues available.
Definition: icss_emac.h:173
ICSS_EMAC_FwMulticastFilterParams::overrideStatusOffset
uint32_t overrideStatusOffset
Definition: icss_emac.h:453
ICSS_EMAC_FwStaticMmap::stormPreventionOffsetBC
uint32_t stormPreventionOffsetBC
Definition: icss_emac.h:392
ICSS_EMAC_PruStatistics::rxUnderSizedFrames
volatile uint32_t rxUnderSizedFrames
Definition: icss_emac.h:727
ICSS_EMAC_ioctl
int32_t ICSS_EMAC_ioctl(ICSS_EMAC_Handle icssEmacHandle, uint32_t ioctlCommand, uint8_t portNo, void *ioctlParams)
IOCTL Function for ICSS EMAC.
ICSS_EMAC_PruStatistics::tx64byte
volatile uint32_t tx64byte
Definition: icss_emac.h:698
ICSS_EMAC_Attrs::l3OcmcSize
uint32_t l3OcmcSize
Definition: icss_emac.h:524
ICSS_EMAC_FwDynamicMmap::collisionQueueSize
uint32_t collisionQueueSize
Definition: icss_emac.h:418
ICSS_EMAC_FwDynamicMmap::hostQ1RxContextOffset
uint32_t hostQ1RxContextOffset
Definition: icss_emac.h:424
ICSS_EMAC_Attrs::txInterruptEnable
uint8_t txInterruptEnable
Definition: icss_emac.h:508
pruicss.h
ICSS_EMAC_RxArgument::more
uint32_t more
Definition: icss_emac.h:646
ICSS_EMAC_Attrs::txIntNum
uint32_t txIntNum
Definition: icss_emac.h:519
ICSS_EMAC_OBJECT_SIZE_IN_BYTES
#define ICSS_EMAC_OBJECT_SIZE_IN_BYTES
Definition: icss_emac.h:361
ICSS_EMAC_CallBackObject::learningExCallBack
ICSS_EMAC_CallBackConfig learningExCallBack
Definition: icss_emac.h:593
ICSS_EMAC_FwDynamicMmap::transmitQueuesBufferOffset
uint32_t transmitQueuesBufferOffset
Definition: icss_emac.h:422
ICSS_EMAC_Attrs::pacingThreshold
uint16_t pacingThreshold
Definition: icss_emac.h:492
ICSS_EMAC_PruStatistics::rxOctets
volatile uint32_t rxOctets
Definition: icss_emac.h:696
ICSS_EMAC_TxArgument::lengthOfPacket
uint16_t lengthOfPacket
Definition: icss_emac.h:664
ICSS_EMAC_TxArgument::portNumber
uint8_t portNumber
Definition: icss_emac.h:660
ICSS_EMAC_FwMulticastFilterParams::maskInitVal
uint32_t maskInitVal
Definition: icss_emac.h:451
ICSS_EMAC_PruStatistics::rx512_1023byte
volatile uint32_t rx512_1023byte
Definition: icss_emac.h:709
ICSS_EMAC_FwStaticMmap::emacTtsConfigBaseOffset
uint32_t emacTtsConfigBaseOffset
Definition: icss_emac.h:402
ICSS_EMAC_PruStatistics::sqeTestError
volatile uint32_t sqeTestError
Definition: icss_emac.h:735
ICSS_EMAC_PruStatistics::singleColl
volatile uint32_t singleColl
Definition: icss_emac.h:713
ICSS_EMAC_PruStatistics::macRxError
volatile uint32_t macRxError
Definition: icss_emac.h:721
ICSS_EMAC_FwDynamicMmap::p0Q1BufferDescOffset
uint32_t p0Q1BufferDescOffset
Definition: icss_emac.h:419
ICSS_EMAC_init
void ICSS_EMAC_init(void)
This function initializes the ICSS_EMAC module.
ICSS_EMAC_FwMulticastFilterParams::ctrlOffset
uint32_t ctrlOffset
Definition: icss_emac.h:449
ICSS_EMAC_FwDynamicMmap
ICSS EMAC Dynamic Firmware Memory Map offsets.
Definition: icss_emac.h:412
ICSS_EMAC_IoctlCmd::command
uint8_t command
Definition: icss_emac.h:673
ICSS_EMAC_CallBackObject::port0LinkCallBack
ICSS_EMAC_CallBackConfig port0LinkCallBack
Definition: icss_emac.h:579
ICSS_EMAC_Config::object
void * object
Definition: icss_emac.h:549
ICSS_EMAC_CallBack
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:374
ICSS_EMAC_PruStatistics::tx65_127byte
volatile uint32_t tx65_127byte
Definition: icss_emac.h:699
ICSS_EMAC_PruStatistics::CSError
volatile uint32_t CSError
Definition: icss_emac.h:737
ICSS_EMAC_FwVlanFilterParams::ctrlEnableBit
uint32_t ctrlEnableBit
Definition: icss_emac.h:437
ICSS_EMAC_FwStaticMmap::statisticsOffset
uint32_t statisticsOffset
Definition: icss_emac.h:390
ICSS_EMAC_FwVlanFilterParams::filterTableBaseAddress
uint32_t filterTableBaseAddress
Definition: icss_emac.h:440
ICSS_EMAC_Params::pruicssIntcInitData
const PRUICSS_IntcInitData * pruicssIntcInitData
Definition: icss_emac.h:611
ICSS_EMAC_FwStaticMmap::phySpeedOffset
uint32_t phySpeedOffset
Definition: icss_emac.h:393
ICSS_EMAC_IoctlCmd::ioctlVal
void * ioctlVal
Definition: icss_emac.h:674
ICSS_EMAC_FwMulticastFilterParams::hostRcvAllowedValue
uint32_t hostRcvAllowedValue
Definition: icss_emac.h:459
ICSS_EMAC_FwDynamicMmap::p0Q1BufferOffset
uint32_t p0Q1BufferOffset
Definition: icss_emac.h:421
ICSS_EMAC_PruStatistics::lateColl
volatile uint32_t lateColl
Definition: icss_emac.h:712
ICSS_EMAC_CallBackConfig::userArg
void * userArg
Definition: icss_emac.h:566
ICSS_EMAC_FwStaticMmap::colStatusAddr
uint32_t colStatusAddr
Definition: icss_emac.h:404
ICSS_EMAC_FwMulticastFilterParams::maskOverrideSetValue
uint32_t maskOverrideSetValue
Definition: icss_emac.h:457
ICSS_EMAC_FwStaticMmap::portControlAddr
uint32_t portControlAddr
Definition: icss_emac.h:395
ICSS_EMAC_FwStaticMmap::rxInterruptStatusOffset
uint32_t rxInterruptStatusOffset
Definition: icss_emac.h:397
ICSS_EMAC_PruStatistics::rx65_127byte
volatile uint32_t rx65_127byte
Definition: icss_emac.h:706
ICSS_EMAC_FwStaticMmap::stormPreventionOffsetUC
uint32_t stormPreventionOffsetUC
Definition: icss_emac.h:399
ICSS_EMAC_rxPktGet
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.
ICSS_EMAC_PruStatistics::rx64byte
volatile uint32_t rx64byte
Definition: icss_emac.h:705
ICSS_EMAC_FwMulticastFilterParams::maskOffset
uint32_t maskOffset
Definition: icss_emac.h:452
ICSS_EMAC_Attrs::emacMode
uint8_t emacMode
Definition: icss_emac.h:468
ICSS_EMAC_FwStaticMmap::futureFeatureOffset
uint32_t futureFeatureOffset
Definition: icss_emac.h:389
ICSS_EMAC_FwStaticMmap::versionOffset
uint32_t versionOffset
Definition: icss_emac.h:386
ICSS_EMAC_Params::fwDynamicMMap
ICSS_EMAC_FwDynamicMmap * fwDynamicMMap
Definition: icss_emac.h:615
ICSS_EMAC_PruStatistics::rxOverSizedFrames
volatile uint32_t rxOverSizedFrames
Definition: icss_emac.h:726
ICSS_EMAC_PruStatistics::multiColl
volatile uint32_t multiColl
Definition: icss_emac.h:714
ICSS_EMAC_FwVlanFilterParams::ctrlBitmapOffset
uint32_t ctrlBitmapOffset
Definition: icss_emac.h:436
ICSS_EMAC_Params::fwMulticastFilterParams
ICSS_EMAC_FwMulticastFilterParams * fwMulticastFilterParams
Definition: icss_emac.h:619
ICSS_EMAC_FwVlanFilterParams
ICSS EMAC VLAN Filtering Parameters.
Definition: icss_emac.h:435
ICSS_EMAC_PruStatistics::txOverFlow
volatile uint32_t txOverFlow
Definition: icss_emac.h:733
ICSS_EMAC_FwDynamicMmap::q1EmacTxContextOffset
uint32_t q1EmacTxContextOffset
Definition: icss_emac.h:427
ICSS_EMAC_open
ICSS_EMAC_Handle ICSS_EMAC_open(uint32_t idx, const ICSS_EMAC_Params *params)
API to initialize and configure ICSS in MAC/Switch Mode.
ICSS_EMAC_Attrs::txTaskPriority
uint32_t txTaskPriority
Definition: icss_emac.h:530
ICSS_EMAC_PruStatistics::txUcast
volatile uint32_t txUcast
Definition: icss_emac.h:690
ICSS_EMAC_PruStatistics
Statistics structure for capturing statistics on PRU.
Definition: icss_emac.h:682
ICSS_EMAC_PruStatistics::txUnderFlow
volatile uint32_t txUnderFlow
Definition: icss_emac.h:734
ICSS_EMAC_Attrs::ethPrioQueue
uint8_t ethPrioQueue
Definition: icss_emac.h:494
ICSS_EMAC_PruStatistics::rx1024byte
volatile uint32_t rx1024byte
Definition: icss_emac.h:710
ICSS_EMAC_PruStatistics::excessColl
volatile uint32_t excessColl
Definition: icss_emac.h:715
ICSS_EMAC_FwDynamicMmap::numQueues
uint32_t numQueues
Definition: icss_emac.h:428
ICSS_EMAC_FwStaticMmap::interfaceMacAddrOffset
uint32_t interfaceMacAddrOffset
Definition: icss_emac.h:403
ICSS_EMAC_CallBackObject::rxRTCallBack
ICSS_EMAC_CallBackConfig rxRTCallBack
Definition: icss_emac.h:587
ICSS_EMAC_FwMulticastFilterParams::tableOffset
uint32_t tableOffset
Definition: icss_emac.h:454
ICSS_EMAC_PruStatistics::rxCRCFrames
volatile uint32_t rxCRCFrames
Definition: icss_emac.h:728
ICSS_EMAC_TxArgument::srcAddress
const uint8_t * srcAddress
Definition: icss_emac.h:658
reserved
uint16_t reserved
Definition: tisci_boardcfg_rm.h:2
ICSS_EMAC_FwMulticastFilterParams::maskOverrideNotSetValue
uint32_t maskOverrideNotSetValue
Definition: icss_emac.h:458
ICSS_EMAC_PruStatistics::stormPrevCounter
volatile uint32_t stormPrevCounter
Definition: icss_emac.h:718
ICSS_EMAC_close
void ICSS_EMAC_close(ICSS_EMAC_Handle icssEmacHandle)
API to stop MAC/Switch Mode.
ICSS_EMAC_FwMulticastFilterParams::ctrlEnabledValue
uint32_t ctrlEnabledValue
Definition: icss_emac.h:455
ICSS_EMAC_Config::attrs
const ICSS_EMAC_Attrs * attrs
Definition: icss_emac.h:551
PRUICSS_IntcInitData
PRUICSS Interrupt controller initialisation data structure.
Definition: pruicss/v0/pruicss.h:273
ethphy.h
ICSS_EMAC_Attrs::linkIntNum
uint32_t linkIntNum
Definition: icss_emac.h:515
ICSS_EMAC_rxPktInfo
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...
ICSS_EMAC_PruStatistics::txOctets
volatile uint32_t txOctets
Definition: icss_emac.h:691
ICSS_EMAC_deinit
void ICSS_EMAC_deinit(void)
This function de-initializes the ICSS_EMAC module.
ICSS_EMAC_Attrs::phyToMacInterfaceMode
uint8_t phyToMacInterfaceMode
Definition: icss_emac.h:475
ICSS_EMAC_RxArgument::destAddress
uint32_t destAddress
Definition: icss_emac.h:640
ICSS_EMAC_FwMulticastFilterParams::maskSizeBytes
uint32_t maskSizeBytes
Definition: icss_emac.h:450
ICSS_EMAC_PruStatistics::rx256_511byte
volatile uint32_t rx256_511byte
Definition: icss_emac.h:708
ICSS_EMAC_PruStatistics::macTxError
volatile uint32_t macTxError
Definition: icss_emac.h:725
ICSS_EMAC_Attrs::halfDuplexEnable
uint8_t halfDuplexEnable
Definition: icss_emac.h:479
ICSS_EMAC_PruStatistics::SFDError
volatile uint32_t SFDError
Definition: icss_emac.h:723
ICSS_EMAC_FwStaticMmap::featureOffset
uint32_t featureOffset
Definition: icss_emac.h:388
ICSS_EMAC_FwVlanFilterParams::vidMaxValue
uint32_t vidMaxValue
Definition: icss_emac.h:441
ICSS_EMAC_PruStatistics::stormPrevCounterMC
volatile uint32_t stormPrevCounterMC
Definition: icss_emac.h:719
ICSS_EMAC_Attrs::linkTaskPriority
uint32_t linkTaskPriority
Definition: icss_emac.h:526
ICSS_EMAC_CallBackObject
Different callbacks which can be registered. While calling the function set in ICSS_EMAC_CallBack,...
Definition: icss_emac.h:578
ICSS_EMAC_FwMulticastFilterParams::hostRcvNotAllowedValue
uint32_t hostRcvNotAllowedValue
Definition: icss_emac.h:460
ICSS_EMAC_FwDynamicMmap::queueSizeOffset
uint32_t queueSizeOffset
Definition: icss_emac.h:413
ICSS_EMAC_PruStatistics::rxMisAlignmentFrames
volatile uint32_t rxMisAlignmentFrames
Definition: icss_emac.h:717
ICSS_EMAC_FwVlanFilterParams::ctrlPriotagHostRcvAllowBit
uint32_t ctrlPriotagHostRcvAllowBit
Definition: icss_emac.h:439
ICSS_EMAC_PruStatistics::txBcast
volatile uint32_t txBcast
Definition: icss_emac.h:688
ICSS_EMAC_PruStatistics::txMcast
volatile uint32_t txMcast
Definition: icss_emac.h:689
ICSS_EMAC_Attrs::enableIntrPacing
uint8_t enableIntrPacing
Definition: icss_emac.h:484
ICSS_EMAC_FwStaticMmap
ICSS EMAC Static Firmware Memory Map offsets. These are offsets for PRU0 and PRU1 DRAM memory.
Definition: icss_emac.h:385
ICSS_EMAC_InternalObject
Opaque ICSS EMAC driver object.
Definition: icss_emac.h:538
ICSS_EMAC_CallBackObject::txCallBack
ICSS_EMAC_CallBackConfig txCallBack
Definition: icss_emac.h:591
ICSS_EMAC_FwMulticastFilterParams::ctrlDisabledValue
uint32_t ctrlDisabledValue
Definition: icss_emac.h:456
ICSS_EMAC_CallBackConfig::callBack
ICSS_EMAC_CallBack callBack
Definition: icss_emac.h:564
ICSS_EMAC_Attrs
Definition: icss_emac.h:467
ICSS_EMAC_PruStatistics::stormPrevCounterUC
volatile uint32_t stormPrevCounterUC
Definition: icss_emac.h:720
ICSS_EMAC_FwMulticastFilterParams
ICSS EMAC Multicast Filtering Parameters.
Definition: icss_emac.h:448
ICSS_EMAC_PruStatistics::tx256_511byte
volatile uint32_t tx256_511byte
Definition: icss_emac.h:701
ICSS_EMAC_Params
ICSS_EMAC Parameters.
Definition: icss_emac.h:608
ICSS_EMAC_PruStatistics::rx128_255byte
volatile uint32_t rx128_255byte
Definition: icss_emac.h:707
ICSS_EMAC_Attrs::rxIntNum
uint32_t rxIntNum
Definition: icss_emac.h:517
ICSS_EMAC_CallBackConfig
Generic callback configuration for protocol specific callbacks. ICSS_EMAC_CallBack is the function ...
Definition: icss_emac.h:563
ICSS_EMAC_FwStaticMmap::version2Offset
uint32_t version2Offset
Definition: icss_emac.h:387
ETHPHY_Handle
void * ETHPHY_Handle
Handle to the ETHPHY driver returned by ETHPHY_open()
Definition: ethphy.h:169
ICSS_EMAC_IoctlCmd
IOCTL command members for configuring switch/EMAC.
Definition: icss_emac.h:672
ICSS_EMAC_Params::callBackObject
ICSS_EMAC_CallBackObject callBackObject
Definition: icss_emac.h:621
ICSS_EMAC_PruStatistics::tx512_1023byte
volatile uint32_t tx512_1023byte
Definition: icss_emac.h:702
ICSS_EMAC_FwDynamicMmap::queueOffset
uint32_t queueOffset
Definition: icss_emac.h:414
ICSS_EMAC_Params::pruicssHandle
PRUICSS_Handle pruicssHandle
Definition: icss_emac.h:609
ICSS_EMAC_FwStaticMmap::stormPreventionOffsetMC
uint32_t stormPreventionOffsetMC
Definition: icss_emac.h:398
PRUICSS_Handle
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/v0/pruicss.h:234
ICSS_EMAC_CallBackObject::port1LinkCallBack
ICSS_EMAC_CallBackConfig port1LinkCallBack
Definition: icss_emac.h:581
ICSS_EMAC_FwStaticMmap::promiscuousModeOffset
uint32_t promiscuousModeOffset
Definition: icss_emac.h:405
ICSS_EMAC_TxArgument::icssEmacHandle
ICSS_EMAC_Handle icssEmacHandle
Definition: icss_emac.h:656
ICSS_EMAC_FwStaticMmap::statisticsSize
uint32_t statisticsSize
Definition: icss_emac.h:391
ICSS_EMAC_TxArgument::queuePriority
uint8_t queuePriority
Definition: icss_emac.h:662
ICSS_EMAC_PruStatistics::rxMcast
volatile uint32_t rxMcast
Definition: icss_emac.h:694
ICSS_EMAC_FwDynamicMmap::portQueueDescOffset
uint32_t portQueueDescOffset
Definition: icss_emac.h:426
ICSS_EMAC_PruStatistics::tx1024byte
volatile uint32_t tx1024byte
Definition: icss_emac.h:703
ICSS_EMAC_Params::fwStaticMMap
ICSS_EMAC_FwStaticMmap * fwStaticMMap
Definition: icss_emac.h:613
ICSS_EMAC_MAX_PORTS_PER_INSTANCE
#define ICSS_EMAC_MAX_PORTS_PER_INSTANCE
Maximum number of Ports in a single ICSS
Definition: icss_emac.h:66
ICSS_EMAC_Params::fwVlanFilterParams
ICSS_EMAC_FwVlanFilterParams * fwVlanFilterParams
Definition: icss_emac.h:617
ICSS_EMAC_FwDynamicMmap::queueDescriptorOffset
uint32_t queueDescriptorOffset
Definition: icss_emac.h:415
ICSS_EMAC_Config
Base EMAC handle containing pointers to all modules required for driver to work.
Definition: icss_emac.h:548
ICSS_EMAC_RxArgument::icssEmacHandle
ICSS_EMAC_Handle icssEmacHandle
Definition: icss_emac.h:638